fault-codes.rst 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. =====================
  2. I2C/SMBUS Fault Codes
  3. =====================
  4. This is a summary of the most important conventions for use of fault
  5. codes in the I2C/SMBus stack.
  6. A "Fault" is not always an "Error"
  7. ----------------------------------
  8. Not all fault reports imply errors; "page faults" should be a familiar
  9. example. Software often retries idempotent operations after transient
  10. faults. There may be fancier recovery schemes that are appropriate in
  11. some cases, such as re-initializing (and maybe resetting). After such
  12. recovery, triggered by a fault report, there is no error.
  13. In a similar way, sometimes a "fault" code just reports one defined
  14. result for an operation ... it doesn't indicate that anything is wrong
  15. at all, just that the outcome wasn't on the "golden path".
  16. In short, your I2C driver code may need to know these codes in order
  17. to respond correctly. Other code may need to rely on YOUR code reporting
  18. the right fault code, so that it can (in turn) behave correctly.
  19. I2C and SMBus fault codes
  20. -------------------------
  21. These are returned as negative numbers from most calls, with zero or
  22. some positive number indicating a non-fault return. The specific
  23. numbers associated with these symbols differ between architectures,
  24. though most Linux systems use <asm-generic/errno*.h> numbering.
  25. Note that the descriptions here are not exhaustive. There are other
  26. codes that may be returned, and other cases where these codes should
  27. be returned. However, drivers should not return other codes for these
  28. cases (unless the hardware doesn't provide unique fault reports).
  29. Also, codes returned by adapter probe methods follow rules which are
  30. specific to their host bus (such as PCI, or the platform bus).
  31. EAFNOSUPPORT
  32. Returned by I2C adapters not supporting 10 bit addresses when
  33. they are requested to use such an address.
  34. EAGAIN
  35. Returned by I2C adapters when they lose arbitration in master
  36. transmit mode: some other master was transmitting different
  37. data at the same time.
  38. Also returned when trying to invoke an I2C operation in an
  39. atomic context, when some task is already using that I2C bus
  40. to execute some other operation.
  41. EBADMSG
  42. Returned by SMBus logic when an invalid Packet Error Code byte
  43. is received. This code is a CRC covering all bytes in the
  44. transaction, and is sent before the terminating STOP. This
  45. fault is only reported on read transactions; the SMBus slave
  46. may have a way to report PEC mismatches on writes from the
  47. host. Note that even if PECs are in use, you should not rely
  48. on these as the only way to detect incorrect data transfers.
  49. EBUSY
  50. Returned by SMBus adapters when the bus was busy for longer
  51. than allowed. This usually indicates some device (maybe the
  52. SMBus adapter) needs some fault recovery (such as resetting),
  53. or that the reset was attempted but failed.
  54. EINVAL
  55. This rather vague error means an invalid parameter has been
  56. detected before any I/O operation was started. Use a more
  57. specific fault code when you can.
  58. EIO
  59. This rather vague error means something went wrong when
  60. performing an I/O operation. Use a more specific fault
  61. code when you can.
  62. ENODEV
  63. Returned by driver probe() methods. This is a bit more
  64. specific than ENXIO, implying the problem isn't with the
  65. address, but with the device found there. Driver probes
  66. may verify the device returns *correct* responses, and
  67. return this as appropriate. (The driver core will warn
  68. about probe faults other than ENXIO and ENODEV.)
  69. ENOMEM
  70. Returned by any component that can't allocate memory when
  71. it needs to do so.
  72. ENXIO
  73. Returned by I2C adapters to indicate that the address phase
  74. of a transfer didn't get an ACK. While it might just mean
  75. an I2C device was temporarily not responding, usually it
  76. means there's nothing listening at that address.
  77. Returned by driver probe() methods to indicate that they
  78. found no device to bind to. (ENODEV may also be used.)
  79. EOPNOTSUPP
  80. Returned by an adapter when asked to perform an operation
  81. that it doesn't, or can't, support.
  82. For example, this would be returned when an adapter that
  83. doesn't support SMBus block transfers is asked to execute
  84. one. In that case, the driver making that request should
  85. have verified that functionality was supported before it
  86. made that block transfer request.
  87. Similarly, if an I2C adapter can't execute all legal I2C
  88. messages, it should return this when asked to perform a
  89. transaction it can't. (These limitations can't be seen in
  90. the adapter's functionality mask, since the assumption is
  91. that if an adapter supports I2C it supports all of I2C.)
  92. EPROTO
  93. Returned when slave does not conform to the relevant I2C
  94. or SMBus (or chip-specific) protocol specifications. One
  95. case is when the length of an SMBus block data response
  96. (from the SMBus slave) is outside the range 1-32 bytes.
  97. ESHUTDOWN
  98. Returned when a transfer was requested using an adapter
  99. which is already suspended.
  100. ETIMEDOUT
  101. This is returned by drivers when an operation took too much
  102. time, and was aborted before it completed.
  103. SMBus adapters may return it when an operation took more
  104. time than allowed by the SMBus specification; for example,
  105. when a slave stretches clocks too far. I2C has no such
  106. timeouts, but it's normal for I2C adapters to impose some
  107. arbitrary limits (much longer than SMBus!) too.