A byte stuffing binary interface is used to talk to the module through the serial interface.
The protocol is created for VSCP Level I events but can be used for other purposes also, as the 16 byte data content indicates. In this case the class and type bytes can be used freely by the implementer.
Protocol defines are in vscp_serial.h
The crc (X8 + X2 + X + 1) is calculated from, and including, frame type up to the last data-byte. For DLE in data which is sent as DLE DLE the crc is is calculated over just one of them.
The channel byte can be used to logically separate different channels on the same physical line. Typically this can also be a serial line with many nodes which are polled for data.
The sequence number byte marks a number for a sequence of a special frame. For instance four frame are sent after each other and they will get different counter numbers. The NACKs/ACKs that are responded from the node use the same counter values to separate the frames from others. Can, for example, be used to implement a sliding window protocol.
As noted there can be two types of ACKs/NACKs one (251/252) is a general ACK/NACK that is the response when a frame is received and put in a buffer. This is generally all that is needed. The other version (249/250) can optionally be sent when the frame is actually sent on the interface.
Byte | Content | Description |
---|---|---|
0 | [DLE] | Escape character |
1 | [STX] | Start of frame |
2 | Frame type | (See table below ) |
3 | Channel | The channel is used to separate messages from different units on a multi device bus. |
4 | Sequence number | The sequence number is increased by one for each new message sent by a node. |
5/6 | Size of payload | Size of payload MSB/LSB |
7..n | Payload | This is the payload of the frame. |
len-3 | Frame check sum. | CRC (X8 + X2 + X + 1). |
len-2 | [DLE] | Escape character |
len-1 | [ETX] | End of frame |
Type | Description |
---|---|
0 | No operation(NOOP). |
1 | VSCP event to/from node. |
2 | CANAL message to/from node. |
3 | Configure - Can be used to configure a transmitting/receiving device. Actual data is device dependent. |
4 | Poll for event. A data frame is received if data is available and an operation=4 (no events to send) is returned if no data is available. |
5 | No events to send. |
6 | Multi frame CANAL message to/from node. |
7 | Multi frame VSCP event to/from node. |
8 | Capabilities request. |
9 | Capabilities response. |
10 (0x0a) | VSCP event to/from node WITH timestamp. |
11 (0x0b) | CANAL message to/from node WITH timestamp. |
12 (0x0c) | Multi frame VSCP event to/from node WITH timestamp. |
13 (0x0d) | Multi frame CANAL message to/from node WITH timestamp. |
14 (0x0e)-15 (0x0f) | Reserved. |
16 (0x10) | Unused/reserved and will never be used (DLE). |
17-248 | Reserved. |
249 (0xf9) | Sent ACK. |
250 (0xfa) | Sent NACK. |
251 (0xfb) | ACK. |
252 (0xfc) | NACK. |
253 (0xfd) | Error. |
254 (0xfe) | Command Reply. |
255 (0xff) | Command. |
No data bytes.
Data byte | Description |
---|---|
0 | VSCP head MSB |
1 | VSCP head LSB |
2 | MSB of VSCP class |
3 | LSB of VSCP class |
4 | MSB of VSCP type |
5 | LSB of VSCP type |
6-21 | GUID (MSB first) |
22-n | VSCP data (0-487 bytes/Max 8 byte for Level I) |
Data byte | Description |
---|---|
0 | CAN id (MSB) |
1 | CAN id |
2 | CAN id |
3 | CAN id (LSB) |
4 | dlc (0-8). Length of data. |
5-n | CAN data (0-8 bytes) |
Format for data bytes defined by the maker of the device
No data bytes.
No data bytes.
To make sending and receiving more efficient it is possible to send multiple CANAL frames as payload in one serial frame. Each frame is sent as
Data byte | Description |
---|---|
0 | id MSB |
1 | id |
2 | id |
3 | id LSB |
4 | datacount |
5-n | data |
n+1 | Start of next CANAL frame. |
and can therefore have a maximum size of 13 bytes each.
To make sending and receiving more efficient it is possible to send multiple VSCP frames as payload in one serial frame. Each frame is sent as
Data byte | Description |
---|---|
0 | VSCP head MSB |
1 | VSCP head LSB |
2 | MSB of VSCP class |
3 | LSB of VSCP class |
4 | MSB of VSCP type |
5 | LSB of VSCP type |
6-21 | GUID (MSB first) |
22 | data count MSB |
23 | data count LSB |
24-n | VSCP data (0-487 bytes/Max 8 byte for Level I) |
n+1 | start of next VSCP frame |
Request capabilities of a device. A device will respond with a Request capabilities reply that shows what the devices can do. The sent payload is the capabilities of the requesting device.
The default value is what a device should suppose is true if no capabilities request reply has been received from a host. It can of course itself send the capabilities request.
Do not make expectations of the length of this frame as it will most certainly grow in the future.
Data byte | Description |
---|---|
0 | Max number of VSCP frames this devices can receive in a multi frame (default=1) |
1 | Max number of CANAL frames this devices can receive in a multi frame (default=1) |
Answer to request for capabilities of device. The default value is what a driver should suppose is true if no capabilities request reply has been received from the device.
Do not make expectations of the length of this frame as it will most certainly grow in the future.
Data byte | Description |
---|---|
0 | Max number of VSCP frames this devices can receive in a multi frame (default=1) |
1 | Max number of CANAL frames this devices can receive in a multi frame (default=1) |
Data byte | Description |
---|---|
0 | VSCP head MSB |
1 | VSCP head LSB |
2 | Timestamp MSB Microsconds |
3 | Timestamp |
4 | Timestamp |
5 | Timestamp LSB |
6 | MSB of VSCP class |
7 | LSB of VSCP class |
8 | MSB of VSCP type |
9 | LSB of VSCP type |
10-25 | GUID (MSB first) |
26-n | VSCP data (0-487 bytes/Max 8 byte for Level I) |
Data byte | Description |
---|---|
0 | CAN id (MSB) |
1 | CAN id |
2 | CAN id |
3 | CAN id (LSB) |
4 | Timestamp MSB Microsconds |
5 | Timestamp |
6 | Timestamp |
7 | Timestamp LSB |
8 | dlc (0-8). Length of data. |
9-n | CAN data (0-8 bytes) |
To make sending and receiving more efficient it is possible to send multiple CANAL frames as payload in one serial frame. Each frame is sent as
Data byte | Description |
---|---|
0 | id MSB |
1 | id |
2 | id |
3 | id LSB |
4 | Timestamp MSB Microsconds |
5 | Timestamp |
6 | Timestamp |
7 | Timestamp LSB |
8 | datacount |
9 | dlc (0-8). Length of data. |
10-n | data |
n+1 | Start of next CANAL frame. |
and can therefore have a maximum size of 13 bytes each.
To make sending and receiving more efficient it is possible to send multiple VSCP frames as payload in one serial frame. Each frame is sent as
Data byte | Description |
---|---|
0 | VSCP head MSB |
1 | VSCP head LSB |
2 | Timestamp MSB Microsconds |
3 | Timestamp |
4 | Timestamp |
5 | Timestamp LSB |
6 | MSB of VSCP class |
7 | LSB of VSCP class |
8 | MSB of VSCP type |
9 | LSB of VSCP type |
10-25 | GUID (MSB first) |
26 | data count MSB |
27 | data count LSB |
28-n | VSCP data (0-487 bytes/Max 8 byte for Level I) |
n+1 | start of next VSCP frame |
No data bytes.
No data bytes.
No data bytes.
No data bytes.
Data byte | Description |
---|---|
0 | Error code |
1-255 | Possible real text message |
Data byte | Description |
---|---|
0 | Reply code (0 is OK other code is application specific error) |
1 | Command code |
Data byte | Description |
---|---|
0 | Command code |
1-n | Command parameters (0-256 bytes) |
As [DLE] is used as escape character the [DLE] itself is sent as [DLE][DLE]. The ASCII values for the reserved characters are
Character | ASCII code |
---|---|
[DLE] | 0x10 |
[NUL] | 0x00 |
[STX] | 0x02 |
[ETX] | 0x03 |
Command codes and data format is decided by the device implementer.
Response codes and data format is decided by the device implementer.
Error codes and data format is decided by the device implementer.