Lines Matching +full:bus +full:- +full:idle +full:- +full:timeout
13 Controller Area Network is a two-wire serial bus specified by the
14 Bosch CAN Specification, Bosch CAN with Flexible Data-Rate specification and the
15 ISO 11898-1:2003 standard.
21 CAN controllers can only initialize when the bus is in the idle (recessive)
26 The bit-timing as defined in ISO 11898-1:2003 looks as following:
37 * Prop_Seg: The signal propagation delay of the bus and other delays of the transceiver and node.
41 The bit-rate is calculated from the time of a time quantum and the values
45 The bit-rate is the inverse of the length of a single bit.
57 Phase_Seg1and Phase_Seg2) are initially set from the device-tree and can be
58 changed at run-time from the timing-API.
60 CAN uses so-called identifiers to identify the frame instead of addresses to
62 This identifier can either have 11-bit width (Standard or Basic Frame) or
63 29-bit in case of an Extended Frame. The Zephyr CAN API supports both Standard
68 Nodes monitor the bus and notice when their transmission is being overridden and
84 it partially overrides the current frame with an error-frame.
85 Error-frames can either be error passive or error active, depending on the state
93 * Error-active
94 * Error-passive
95 * Bus-off
97 After initialization, the node is in the error-active state. In this state, the
99 Every node has a receive- and transmit-error counter.
100 If either the receive- or the transmit-error counter exceeds 127,
101 the node changes to error-passive state.
102 In this state, the node is not allowed to send error-active frames anymore.
103 If the transmit-error counter increases further to 255, the node changes to the
104 bus-off state. In this state, the node is not allowed to send any dominant bits
105 to the bus. Nodes in the bus-off state may recover after receiving 128
108 You can read more about CAN bus in this
127 one other node or an error occurred. The timeout only takes effect on acquiring
130 .. code-block:: C
149 an error occurred. Passing :c:macro:`K_FOREVER` to the timeout causes the
153 .. code-block:: C
188 .. code-block:: C
203 .. code-block:: C
226 .. code-block:: C
251 .. code-block:: C
264 .. code-block:: C
272 LOG_INF("Sample-Point error: %d", ret);
303 SocketCAN brings the convenience of the well-known BSD Socket API to
305 implementation, where many other high-level CAN projects build on top.
312 We have two ready-to-build samples demonstrating use of the Zephyr CAN API:
313 :zephyr:code-sample:`Zephyr CAN counter sample <can-counter>` and
314 :zephyr:code-sample:`SocketCAN sample <socket-can>`.