~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/w1/masters/ds2490.rst

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /Documentation/w1/masters/ds2490.rst (Version linux-6.12-rc7) and /Documentation/w1/masters/ds2490.rst (Version linux-6.7.12)


  1 ====================                                1 ====================
  2 Kernel driver ds2490                                2 Kernel driver ds2490
  3 ====================                                3 ====================
  4                                                     4 
  5 Supported chips:                                    5 Supported chips:
  6                                                     6 
  7   * Maxim DS2490 based                              7   * Maxim DS2490 based
  8                                                     8 
  9 Author: Evgeniy Polyakov <johnpol@2ka.mipt.ru>       9 Author: Evgeniy Polyakov <johnpol@2ka.mipt.ru>
 10                                                    10 
 11                                                    11 
 12 Description                                        12 Description
 13 -----------                                        13 -----------
 14                                                    14 
 15 The Maxim/Dallas Semiconductor DS2490 is a chi     15 The Maxim/Dallas Semiconductor DS2490 is a chip
 16 which allows to build USB <-> W1 bridges.          16 which allows to build USB <-> W1 bridges.
 17                                                    17 
 18 DS9490(R) is a USB <-> W1 bus master device        18 DS9490(R) is a USB <-> W1 bus master device
 19 which has 0x81 family ID integrated chip and D     19 which has 0x81 family ID integrated chip and DS2490
 20 low-level operational chip.                        20 low-level operational chip.
 21                                                    21 
 22 Notes and limitations.                             22 Notes and limitations.
 23                                                    23 
 24 - The weak pullup current is a minimum of 0.9m     24 - The weak pullup current is a minimum of 0.9mA and maximum of 6.0mA.
 25 - The 5V strong pullup is supported with a min     25 - The 5V strong pullup is supported with a minimum of 5.9mA and a
 26   maximum of 30.4 mA.  (From DS2490.pdf)           26   maximum of 30.4 mA.  (From DS2490.pdf)
 27 - The hardware will detect when devices are at     27 - The hardware will detect when devices are attached to the bus on the
 28   next bus (reset?) operation, however only a      28   next bus (reset?) operation, however only a message is printed as
 29   the core w1 code doesn't make use of the inf     29   the core w1 code doesn't make use of the information.  Connecting
 30   one device tends to give multiple new device     30   one device tends to give multiple new device notifications.
 31 - The number of USB bus transactions could be      31 - The number of USB bus transactions could be reduced if w1_reset_send
 32   was added to the API.  The name is just a su     32   was added to the API.  The name is just a suggestion.  It would take
 33   a write buffer and a read buffer (along with     33   a write buffer and a read buffer (along with sizes) as arguments.
 34   The ds2490 block I/O command supports reset,     34   The ds2490 block I/O command supports reset, write buffer, read
 35   buffer, and strong pullup all in one command     35   buffer, and strong pullup all in one command, instead of the current
 36   1 reset bus, 2 write the match rom command a     36   1 reset bus, 2 write the match rom command and slave rom id, 3 block
 37   write and read data.  The write buffer needs     37   write and read data.  The write buffer needs to have the match rom
 38   command and slave rom id prepended to the fr     38   command and slave rom id prepended to the front of the requested
 39   write buffer, both of which are known to the     39   write buffer, both of which are known to the driver.
 40 - The hardware supports normal, flexible, and      40 - The hardware supports normal, flexible, and overdrive bus
 41   communication speeds, but only the normal is     41   communication speeds, but only the normal is supported.
 42 - The registered w1_bus_master functions don't     42 - The registered w1_bus_master functions don't define error
 43   conditions.  If a bus search is in progress      43   conditions.  If a bus search is in progress and the ds2490 is
 44   removed it can produce a good amount of erro     44   removed it can produce a good amount of error output before the bus
 45   search finishes.                                 45   search finishes.
 46 - The hardware supports detecting some error c     46 - The hardware supports detecting some error conditions, such as
 47   short, alarming presence on reset, and no pr     47   short, alarming presence on reset, and no presence on reset, but the
 48   driver doesn't query those values.               48   driver doesn't query those values.
 49 - The ds2490 specification doesn't cover short     49 - The ds2490 specification doesn't cover short bulk in reads in
 50   detail, but my observation is if fewer bytes     50   detail, but my observation is if fewer bytes are requested than are
 51   available, the bulk read will return an erro     51   available, the bulk read will return an error and the hardware will
 52   clear the entire bulk in buffer.  It would b     52   clear the entire bulk in buffer.  It would be possible to read the
 53   maximum buffer size to not run into this err     53   maximum buffer size to not run into this error condition, only extra
 54   bytes in the buffer is a logic error in the      54   bytes in the buffer is a logic error in the driver.  The code should
 55   match reads and writes as well as data sizes     55   match reads and writes as well as data sizes.  Reads and
 56   writes are serialized and the status verifie     56   writes are serialized and the status verifies that the chip is idle
 57   (and data is available) before the read is e     57   (and data is available) before the read is executed, so it should
 58   not happen.                                      58   not happen.
 59 - Running x86_64 2.6.24 UHCI under qemu 0.9.0      59 - Running x86_64 2.6.24 UHCI under qemu 0.9.0 under x86_64 2.6.22-rc6
 60   with a OHCI controller, ds2490 running in th     60   with a OHCI controller, ds2490 running in the guest would operate
 61   normally the first time the module was loade     61   normally the first time the module was loaded after qemu attached
 62   the ds2490 hardware, but if the module was u     62   the ds2490 hardware, but if the module was unloaded, then reloaded
 63   most of the time one of the bulk out or in,      63   most of the time one of the bulk out or in, and usually the bulk in
 64   would fail.  qemu sets a 50ms timeout and th     64   would fail.  qemu sets a 50ms timeout and the bulk in would timeout
 65   even when the status shows data available.       65   even when the status shows data available.  A bulk out write would
 66   show a successful completion, but the ds2490     66   show a successful completion, but the ds2490 status register would
 67   show 0 bytes written.  Detaching qemu from t     67   show 0 bytes written.  Detaching qemu from the ds2490 hardware and
 68   reattaching would clear the problem.  usbmon     68   reattaching would clear the problem.  usbmon output in the guest and
 69   host did not explain the problem.  My guess      69   host did not explain the problem.  My guess is a bug in either qemu
 70   or the host OS and more likely the host OS.      70   or the host OS and more likely the host OS.
 71                                                    71 
 72 03-06-2008 David Fries <David@Fries.net>            72 03-06-2008 David Fries <David@Fries.net>
                                                      

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php