1. 23 11月, 2018 1 次提交
    • N
      USB: serial: ftdi_sio: use rounding when calculating baud rate divisors · 6abd8371
      Nikolaj Fogh 提交于
      Improve baud-rate generation by using rounding-to-closest instead of
      truncation in divisor calculation.
      
      Results have been verified by logic analyzer on an FT232RT (232BM) chip.
      The following table shows the wanted baud rate, the baud rate obtained
      with the old method (truncation), with the new method (rounding) and the
      baud rate generated by the windows 10 driver. The numbers in parentheses
      is the error.
      
      +- Wanted --+------ Old -------+------ New -------+------ Win -------+
      |    9600   |    9600 (0.00%)  |    9604 (0.05%)  |    9605 (0.05%)  |
      |   19200   |   19200 (0.00%)  |   19199 (0.01%)  |   19198 (0.01%)  |
      |   38400   |   38395 (0.01%)  |   38431 (0.08%)  |   38394 (0.02%)  |
      |   57600   |   57725 (0.22%)  |   57540 (0.10%)  |   57673 (0.13%)  |
      |  115200   |  115307 (0.09%)  |  115330 (0.11%)  |  115320 (0.10%)  |
      |  921600   |  919963 (0.18%)  |  920386 (0.13%)  |  920810 (0.09%)  |
      |  961200   |  996512 (3.67%)  |  956480 (0.49%)  |  956937 (0.44%)  |
      +-----------+------------------+------------------+------------------+
      
      The error due to noise in the measurements is in the order of a few
      tenths of a %. As can be seen, the baud rate is significantly improved
      for some rates (e.g. 961200), and corresponds to the output given by the
      windows driver.
      
      The theoretical baud rate has been calculated for all baud rates from 1
      to 3M, and as expected, the error is centered around 0, with a triangle
      shape instead of a sawtooth, so the maximum error is decreased to half.
      Signed-off-by: NNikolaj Fogh <nikolajfogh@gmail.com>
      [ johan: edit commit message slightly ]
      Signed-off-by: NJohan Hovold <johan@kernel.org>
      6abd8371
  2. 13 10月, 2018 1 次提交
  3. 05 10月, 2018 2 次提交
    • J
      USB: serial: ftdi_sio: add support for FT232R CBUS gpios · ff32d97e
      Johan Hovold 提交于
      Enable support for cbus gpios on FT232R. The cbus configuration is
      stored in one word in the EEPROM at offset 0x0a (byte-offset 0x14) with
      the mux config for CBUS0, CBUS1, CBUS2 and CBUS3 in bits 0..3, 4..7,
      8..11 and 12..15, respectively.
      
      Tested using FT232RL by configuring one cbus pin at a time.
      Signed-off-by: NJohan Hovold <johan@kernel.org>
      ff32d97e
    • J
      USB: serial: ftdi_sio: fix gpio name collisions · e0658e30
      Johan Hovold 提交于
      Drop the gpio line names, which cause gpiolib to complain loudly
      whenever a second ftdi gpiochip is registered:
      
      	gpio gpiochip5: Detected name collision for GPIO name 'CBUS0'
      	gpio gpiochip5: Detected name collision for GPIO name 'CBUS1'
      	gpio gpiochip5: Detected name collision for GPIO name 'CBUS2'
      	gpio gpiochip5: Detected name collision for GPIO name 'CBUS3'
      
      and also prevents the legacy sysfs interface from being used (as the
      line names are used as device names whenever they are set):
      
      	sysfs: cannot create duplicate filename '/class/gpio/CBUS0'
      
      Until non-unique names are supported by gpiolib (without warnings and
      stack dumps), let's leave the gpio lines unnamed.
      Signed-off-by: NJohan Hovold <johan@kernel.org>
      e0658e30
  4. 26 9月, 2018 1 次提交
    • K
      USB: serial: ftdi_sio: implement GPIO support for FT-X devices · ba93cc7d
      Karoly Pados 提交于
      This patch allows using the CBUS pins of FT-X devices as GPIO in CBUS
      bitbanging mode. There is no conflict between the GPIO and VCP
      functionality in this mode. Tested on FT230X and FT231X.
      
      As there is no way to request the current CBUS register configuration
      from the device, all CBUS pins are set to a known state when the first
      GPIO is requested. This allows using libftdi to set the GPIO pins
      before loading this module for UART functionality, a behavior that
      existing applications might be relying upon (though no specific case
      is known to the authors of this patch).
      Signed-off-by: NKaroly Pados <pados@pados.hu>
      [ johan: minor style changes ]
      Signed-off-by: NJohan Hovold <johan@kernel.org>
      ba93cc7d
  5. 21 5月, 2018 4 次提交
  6. 16 4月, 2018 1 次提交
  7. 30 3月, 2018 1 次提交
  8. 29 3月, 2018 1 次提交
  9. 23 3月, 2018 2 次提交
  10. 24 1月, 2018 1 次提交
  11. 27 12月, 2017 1 次提交
  12. 04 11月, 2017 2 次提交
  13. 18 9月, 2017 1 次提交
  14. 13 6月, 2017 2 次提交
  15. 17 5月, 2017 1 次提交
    • A
      USB: serial: ftdi_sio: add Olimex ARM-USB-TINY(H) PIDs · 5f63424a
      Andrey Korolyov 提交于
      This patch adds support for recognition of ARM-USB-TINY(H) devices which
      are almost identical to ARM-USB-OCD(H) but lacking separate barrel jack
      and serial console.
      
      By suggestion from Johan Hovold it is possible to replace
      ftdi_jtag_quirk with a bit more generic construction. Since all
      Olimex-ARM debuggers has exactly two ports, we could safely always use
      only second port within the debugger family.
      Signed-off-by: NAndrey Korolyov <andrey@xdel.ru>
      Cc: stable <stable@vger.kernel.org>
      Signed-off-by: NJohan Hovold <johan@kernel.org>
      5f63424a
  16. 15 5月, 2017 1 次提交
    • A
      USB: serial: ftdi_sio: fix setting latency for unprivileged users · bb246681
      Anthony Mallet 提交于
      Commit 557aaa7f ("ft232: support the ASYNC_LOW_LATENCY
      flag") enables unprivileged users to set the FTDI latency timer,
      but there was a logic flaw that skipped sending the corresponding
      USB control message to the device.
      
      Specifically, the device latency timer would not be updated until next
      open, something which was later also inadvertently broken by commit
      c19db4c9 ("USB: ftdi_sio: set device latency timeout at port
      probe").
      
      A recent commit c6dce262 ("USB: serial: ftdi_sio: fix extreme
      low-latency setting") disabled the low-latency mode by default so we now
      need this fix to allow unprivileged users to again enable it.
      Signed-off-by: NAnthony Mallet <anthony.mallet@laas.fr>
      [johan: amend commit message]
      Fixes: 557aaa7f ("ft232: support the ASYNC_LOW_LATENCY flag")
      Fixes: c19db4c9 ("USB: ftdi_sio: set device latency timeout at port probe").
      Cc: stable <stable@vger.kernel.org>     # 2.6.31
      Signed-off-by: NJohan Hovold <johan@kernel.org>
      bb246681
  17. 19 4月, 2017 1 次提交
  18. 13 3月, 2017 5 次提交
  19. 07 2月, 2017 1 次提交
    • J
      USB: serial: ftdi_sio: fix line-status over-reporting · a6bb1e17
      Johan Hovold 提交于
      FTDI devices use a receive latency timer to periodically empty the
      receive buffer and report modem and line status (also when the buffer is
      empty).
      
      When a break or error condition is detected the corresponding status
      flags will be set on a packet with nonzero data payload and the flags
      are not updated until the break is over or further characters are
      received.
      
      In order to avoid over-reporting break and error conditions, these flags
      must therefore only be processed for packets with payload.
      
      This specifically fixes the case where after an overrun, the error
      condition is continuously reported and NULL-characters inserted until
      further data is received.
      Reported-by: NMichael Walle <michael@walle.cc>
      Fixes: 72fda3ca ("USB: serial: ftd_sio: implement sysrq handling on
      break")
      Fixes: 166ceb69 ("USB: ftdi_sio: clean up line-status handling")
      Cc: stable <stable@vger.kernel.org>	# v2.6.35
      Signed-off-by: NJohan Hovold <johan@kernel.org>
      a6bb1e17
  20. 26 1月, 2017 1 次提交
  21. 25 1月, 2017 1 次提交
    • J
      USB: serial: ftdi_sio: fix extreme low-latency setting · c6dce262
      Johan Hovold 提交于
      Since commit 557aaa7f ("ft232: support the ASYNC_LOW_LATENCY
      flag") the FTDI driver has been using a receive latency-timer value of
      1 ms instead of the device default of 16 ms.
      
      The latency timer is used to periodically empty a non-full receive
      buffer, but a status header is always sent when the timer expires
      including when the buffer is empty. This means that a two-byte bulk
      message is received every millisecond also for an otherwise idle port as
      long as it is open.
      
      Let's restore the pre-2009 behaviour which reduces the rate of the
      status messages to 1/16th (e.g. interrupt frequency drops from 1 kHz to
      62.5 Hz) by not setting ASYNC_LOW_LATENCY by default.
      
      Anyone willing to pay the price for the minimum-latency behaviour should
      set the flag explicitly instead using the TIOCSSERIAL ioctl or a tool
      such as setserial (e.g. setserial /dev/ttyUSB0 low_latency).
      
      Note that since commit 0cbd81a9 ("USB: ftdi_sio: remove
      tty->low_latency") the ASYNC_LOW_LATENCY flag has no other effects but
      to set a minimal latency timer.
      Reported-by: NAntoine Aubert <a.aubert@overkiz.com>
      Fixes: 557aaa7f ("ft232: support the ASYNC_LOW_LATENCY flag")
      Cc: stable@vger.kernel.org # v2.6.31: e3e574adSigned-off-by: NJohan Hovold <johan@kernel.org>
      c6dce262
  22. 16 1月, 2017 2 次提交
  23. 12 11月, 2016 1 次提交
  24. 07 11月, 2016 1 次提交
  25. 17 10月, 2016 1 次提交
  26. 08 8月, 2016 2 次提交
  27. 25 4月, 2016 1 次提交