can_ucan_protocol.rst (9091B)
1================= 2The UCAN Protocol 3================= 4 5UCAN is the protocol used by the microcontroller-based USB-CAN 6adapter that is integrated on System-on-Modules from Theobroma Systems 7and that is also available as a standalone USB stick. 8 9The UCAN protocol has been designed to be hardware-independent. 10It is modeled closely after how Linux represents CAN devices 11internally. All multi-byte integers are encoded as Little Endian. 12 13All structures mentioned in this document are defined in 14``drivers/net/can/usb/ucan.c``. 15 16USB Endpoints 17============= 18 19UCAN devices use three USB endpoints: 20 21CONTROL endpoint 22 The driver sends device management commands on this endpoint 23 24IN endpoint 25 The device sends CAN data frames and CAN error frames 26 27OUT endpoint 28 The driver sends CAN data frames on the out endpoint 29 30 31CONTROL Messages 32================ 33 34UCAN devices are configured using vendor requests on the control pipe. 35 36To support multiple CAN interfaces in a single USB device all 37configuration commands target the corresponding interface in the USB 38descriptor. 39 40The driver uses ``ucan_ctrl_command_in/out`` and 41``ucan_device_request_in`` to deliver commands to the device. 42 43Setup Packet 44------------ 45 46================= ===================================================== 47``bmRequestType`` Direction | Vendor | (Interface or Device) 48``bRequest`` Command Number 49``wValue`` Subcommand Number (16 Bit) or 0 if not used 50``wIndex`` USB Interface Index (0 for device commands) 51``wLength`` * Host to Device - Number of bytes to transmit 52 * Device to Host - Maximum Number of bytes to 53 receive. If the device send less. Commom ZLP 54 semantics are used. 55================= ===================================================== 56 57Error Handling 58-------------- 59 60The device indicates failed control commands by stalling the 61pipe. 62 63Device Commands 64--------------- 65 66UCAN_DEVICE_GET_FW_STRING 67~~~~~~~~~~~~~~~~~~~~~~~~~ 68 69*Dev2Host; optional* 70 71Request the device firmware string. 72 73 74Interface Commands 75------------------ 76 77UCAN_COMMAND_START 78~~~~~~~~~~~~~~~~~~ 79 80*Host2Dev; mandatory* 81 82Bring the CAN interface up. 83 84Payload Format 85 ``ucan_ctl_payload_t.cmd_start`` 86 87==== ============================ 88mode or mask of ``UCAN_MODE_*`` 89==== ============================ 90 91UCAN_COMMAND_STOP 92~~~~~~~~~~~~~~~~~~ 93 94*Host2Dev; mandatory* 95 96Stop the CAN interface 97 98Payload Format 99 *empty* 100 101UCAN_COMMAND_RESET 102~~~~~~~~~~~~~~~~~~ 103 104*Host2Dev; mandatory* 105 106Reset the CAN controller (including error counters) 107 108Payload Format 109 *empty* 110 111UCAN_COMMAND_GET 112~~~~~~~~~~~~~~~~ 113 114*Host2Dev; mandatory* 115 116Get Information from the Device 117 118Subcommands 119^^^^^^^^^^^ 120 121UCAN_COMMAND_GET_INFO 122 Request the device information structure ``ucan_ctl_payload_t.device_info``. 123 124 See the ``device_info`` field for details, and 125 ``uapi/linux/can/netlink.h`` for an explanation of the 126 ``can_bittiming fields``. 127 128 Payload Format 129 ``ucan_ctl_payload_t.device_info`` 130 131UCAN_COMMAND_GET_PROTOCOL_VERSION 132 133 Request the device protocol version 134 ``ucan_ctl_payload_t.protocol_version``. The current protocol version is 3. 135 136 Payload Format 137 ``ucan_ctl_payload_t.protocol_version`` 138 139.. note:: Devices that do not implement this command use the old 140 protocol version 1 141 142UCAN_COMMAND_SET_BITTIMING 143~~~~~~~~~~~~~~~~~~~~~~~~~~ 144 145*Host2Dev; mandatory* 146 147Setup bittiming by sending the structure 148``ucan_ctl_payload_t.cmd_set_bittiming`` (see ``struct bittiming`` for 149details) 150 151Payload Format 152 ``ucan_ctl_payload_t.cmd_set_bittiming``. 153 154UCAN_SLEEP/WAKE 155~~~~~~~~~~~~~~~ 156 157*Host2Dev; optional* 158 159Configure sleep and wake modes. Not yet supported by the driver. 160 161UCAN_FILTER 162~~~~~~~~~~~ 163 164*Host2Dev; optional* 165 166Setup hardware CAN filters. Not yet supported by the driver. 167 168Allowed interface commands 169-------------------------- 170 171================== =================== ================== 172Legal Device State Command New Device State 173================== =================== ================== 174stopped SET_BITTIMING stopped 175stopped START started 176started STOP or RESET stopped 177stopped STOP or RESET stopped 178started RESTART started 179any GET *no change* 180================== =================== ================== 181 182IN Message Format 183================= 184 185A data packet on the USB IN endpoint contains one or more 186``ucan_message_in`` values. If multiple messages are batched in a USB 187data packet, the ``len`` field can be used to jump to the next 188``ucan_message_in`` value (take care to sanity-check the ``len`` value 189against the actual data size). 190 191.. _can_ucan_in_message_len: 192 193``len`` field 194------------- 195 196Each ``ucan_message_in`` must be aligned to a 4-byte boundary (relative 197to the start of the start of the data buffer). That means that there 198may be padding bytes between multiple ``ucan_message_in`` values: 199 200.. code:: 201 202 +----------------------------+ < 0 203 | | 204 | struct ucan_message_in | 205 | | 206 +----------------------------+ < len 207 [padding] 208 +----------------------------+ < round_up(len, 4) 209 | | 210 | struct ucan_message_in | 211 | | 212 +----------------------------+ 213 [...] 214 215``type`` field 216-------------- 217 218The ``type`` field specifies the type of the message. 219 220UCAN_IN_RX 221~~~~~~~~~~ 222 223``subtype`` 224 zero 225 226Data received from the CAN bus (ID + payload). 227 228UCAN_IN_TX_COMPLETE 229~~~~~~~~~~~~~~~~~~~ 230 231``subtype`` 232 zero 233 234The CAN device has sent a message to the CAN bus. It answers with a 235list of tuples <echo-ids, flags>. 236 237The echo-id identifies the frame from (echos the id from a previous 238UCAN_OUT_TX message). The flag indicates the result of the 239transmission. Whereas a set Bit 0 indicates success. All other bits 240are reserved and set to zero. 241 242Flow Control 243------------ 244 245When receiving CAN messages there is no flow control on the USB 246buffer. The driver has to handle inbound message quickly enough to 247avoid drops. I case the device buffer overflow the condition is 248reported by sending corresponding error frames (see 249:ref:`can_ucan_error_handling`) 250 251 252OUT Message Format 253================== 254 255A data packet on the USB OUT endpoint contains one or more ``struct 256ucan_message_out`` values. If multiple messages are batched into one 257data packet, the device uses the ``len`` field to jump to the next 258ucan_message_out value. Each ucan_message_out must be aligned to 4 259bytes (relative to the start of the data buffer). The mechanism is 260same as described in :ref:`can_ucan_in_message_len`. 261 262.. code:: 263 264 +----------------------------+ < 0 265 | | 266 | struct ucan_message_out | 267 | | 268 +----------------------------+ < len 269 [padding] 270 +----------------------------+ < round_up(len, 4) 271 | | 272 | struct ucan_message_out | 273 | | 274 +----------------------------+ 275 [...] 276 277``type`` field 278-------------- 279 280In protocol version 3 only ``UCAN_OUT_TX`` is defined, others are used 281only by legacy devices (protocol version 1). 282 283UCAN_OUT_TX 284~~~~~~~~~~~ 285``subtype`` 286 echo id to be replied within a CAN_IN_TX_COMPLETE message 287 288Transmit a CAN frame. (parameters: ``id``, ``data``) 289 290Flow Control 291------------ 292 293When the device outbound buffers are full it starts sending *NAKs* on 294the *OUT* pipe until more buffers are available. The driver stops the 295queue when a certain threshold of out packets are incomplete. 296 297.. _can_ucan_error_handling: 298 299CAN Error Handling 300================== 301 302If error reporting is turned on the device encodes errors into CAN 303error frames (see ``uapi/linux/can/error.h``) and sends it using the 304IN endpoint. The driver updates its error statistics and forwards 305it. 306 307Although UCAN devices can suppress error frames completely, in Linux 308the driver is always interested. Hence, the device is always started with 309the ``UCAN_MODE_BERR_REPORT`` set. Filtering those messages for the 310user space is done by the driver. 311 312Bus OFF 313------- 314 315- The device does not recover from bus of automatically. 316- Bus OFF is indicated by an error frame (see ``uapi/linux/can/error.h``) 317- Bus OFF recovery is started by ``UCAN_COMMAND_RESTART`` 318- Once Bus OFF recover is completed the device sends an error frame 319 indicating that it is on ERROR-ACTIVE state. 320- During Bus OFF no frames are sent by the device. 321- During Bus OFF transmission requests from the host are completed 322 immediately with the success bit left unset. 323 324Example Conversation 325==================== 326 327#) Device is connected to USB 328#) Host sends command ``UCAN_COMMAND_RESET``, subcmd 0 329#) Host sends command ``UCAN_COMMAND_GET``, subcmd ``UCAN_COMMAND_GET_INFO`` 330#) Device sends ``UCAN_IN_DEVICE_INFO`` 331#) Host sends command ``UCAN_OUT_SET_BITTIMING`` 332#) Host sends command ``UCAN_COMMAND_START``, subcmd 0, mode ``UCAN_MODE_BERR_REPORT``