TDT-Protocol on CAN » Historie » Version 80
  Maximilian Seesslen, 11.07.2023 12:45 
  
| 1 | 12 | Maximilian Seesslen | h1. Intro | 
|---|---|---|---|
| 2 | 1 | Maximilian Seesslen | |
| 3 | 17 | Maximilian Seesslen | With the TDT-Protocol sensors can just send their values on the BUS without complex object catalogue. | 
| 4 | An monitor-software is able to display values without knowing anything about the sensors or their configuration. | ||
| 5 | 46 | Maximilian Seesslen | The CANId cinsists of an function code and the node id. Like CANOpen the function code is 4 Bits and the Node-ID is 7 Bit. | 
| 6 | In CAN2.0A there can only be 128 Nodes. | ||
| 7 | 1 | Maximilian Seesslen | |
| 8 | 35 | Maximilian Seesslen | CAN 2.0A: 0..0x7FF | 
| 9 | CANOpen: 4 Bit Function code, 7 Bit Node-ID | ||
| 10 | Node-Id: 0..0x7F | ||
| 11 | 1 | Maximilian Seesslen | Function-Code Mask: 0x780 | 
| 12 | 46 | Maximilian Seesslen | There are 14 or 28 Filters on STM32Fs | 
| 13 | Some STM32 have an internal 96-bit unique ID. | ||
| 14 | 1 | Maximilian Seesslen | |
| 15 | 74 | Maximilian Seesslen | |_. Bits |_. Area |_. Decription |_. Examples | | 
| 16 | 73 | Maximilian Seesslen | | 4 |/2.CAN-Id | Function code | Send object | | 
| 17 | 74 | Maximilian Seesslen | | 7 | NodeId | Sensemux WZ | | 
| 18 | | 16 |/4.Data | Object | Set illumination | | ||
| 19 | | 8 | Unit | promilPwm | | ||
| 20 | | 8 | Flags | Confirmation required | | ||
| 21 | | 32 | Value | 350‰ | | ||
| 22 | 71 | Maximilian Seesslen | |
| 23 | 44 | Maximilian Seesslen | h2. Function code | 
| 24 | |||
| 25 | 1 | Maximilian Seesslen | |_. Code |_. Decription |_. Examples | | 
| 26 | 51 | Maximilian Seesslen | | 0x0 | NMT-Write | | | 
| 27 | 1 | Maximilian Seesslen | | 0x1 | NMT-Send | | | 
| 28 | 79 | Maximilian Seesslen | | 0x2 | NMT-Introduce | Device sends UID only | | 
| 29 | | 0x3 | Alarms | | | ||
| 30 | | 0x4 | Write object | Set Date, illumination | | ||
| 31 | | 0x5 | Read object | Get product codes | | ||
| 32 | | 0x6 | Send object | Send temperature | | ||
| 33 | | 0x7 | Resend object | Replay recorded data | | ||
| 34 | | 0x8 | data blob | | | ||
| 35 | 58 | Maximilian Seesslen | |
| 36 | 1 | Maximilian Seesslen | |
| 37 | h1. IDs, ranges and commands | ||
| 38 | |||
| 39 | 46 | Maximilian Seesslen | h2. Node IDs | 
| 40 | 1 | Maximilian Seesslen | |
| 41 | 44 | Maximilian Seesslen | * 11-Bit-Identifier, (CAN 2.0A); 2048; 0x0 ... 0x7F0; 0x0 ... 0x7F with function code | 
| 42 | 1 | Maximilian Seesslen | * 29-Bit-Identifier, (CAN 2.0B); 0x20000000 | 
| 43 | |||
| 44 | |_. Range |_. Decription |_. Examples | | ||
| 45 | | 0x01-0x0F | Network Manager | PC | | ||
| 46 | | 0x10-0x2F | Active controller | CANDis | | ||
| 47 | | 0x30-0x4F | Actor | CANSwitch | | ||
| 48 | 47 | Maximilian Seesslen | | 0x50-0x6F | Sending sensors | Sensemux, CANIO | | 
| 49 | 1 | Maximilian Seesslen | | 0x70-0x7F | Passive Sensors | CANRec | | 
| 50 | |||
| 51 | 75 | Maximilian Seesslen | h2. CAN data structutre | 
| 52 | 1 | Maximilian Seesslen | |
| 53 | 68 | Maximilian Seesslen | |_. Size |_. Decription |_. Examples | | 
| 54 | | 2 | Object | Plain Sensor value; Set illumination | | ||
| 55 | | 1 | Unit | hz, Float, Time, Date, Percent, promilPwm, centiCelsius, canId, room, Multipacket-String | | ||
| 56 | 75 | Maximilian Seesslen | | 1 | Flags | Confirmation required | | 
| 57 | 68 | Maximilian Seesslen | | 4 | Value | 32Bit | | 
| 58 | |||
| 59 | 36 | Maximilian Seesslen | |
| 60 | 44 | Maximilian Seesslen | h2. Objects | 
| 61 | 36 | Maximilian Seesslen | |
| 62 | 59 | Maximilian Seesslen | |_. Code |_. Description | | 
| 63 | | none | | | ||
| 64 | | ambientLight | | | ||
| 65 | | plantLight | | | ||
| 66 | | multimediaSwitch | | | ||
| 67 | | mainSwitch | | | ||
| 68 | | date | | | ||
| 69 | | time | | | ||
| 70 | | dummy | | | ||
| 71 | | plantSensor | | | ||
| 72 | | plantSensor [0-7] | | | ||
| 73 | | firmwareVersion | | | ||
| 74 | | firmwareDate | | | ||
| 75 | | hardwareRevision | | | ||
| 76 | | hardwareDate | | | ||
| 77 | | temperatureIntern [0-7] | | | ||
| 78 | 64 | Maximilian Seesslen | | temperatureExtern [0-7] | | | 
| 79 | 59 | Maximilian Seesslen | | humidity | | | 
| 80 | | VOC | | | ||
| 81 | 60 | Maximilian Seesslen | | Replay | | | 
| 82 | 63 | Maximilian Seesslen | | Data-Dump (SD-Card) | | | 
| 83 | 1 | Maximilian Seesslen | |
| 84 | 44 | Maximilian Seesslen | h2. Units | 
| 85 | 17 | Maximilian Seesslen | |
| 86 | 44 | Maximilian Seesslen | * Date: year 2B, month 1B, day 1B | 
| 87 | 1 | Maximilian Seesslen | * Time: hour 1B, minute 1B, second 1B, subsecond 1B | 
| 88 | 17 | Maximilian Seesslen | |
| 89 | 46 | Maximilian Seesslen | h2. Example: Turn on the lights | 
| 90 | 1 | Maximilian Seesslen | |
| 91 | 46 | Maximilian Seesslen | |_.Data |_.Size |_.Description | | 
| 92 | |0x300 | 29 Bits | Function code: Write Object; All objects. | | ||
| 93 | |0x0 | 2 Byte | Message-Type: Global command | | ||
| 94 | 76 | Maximilian Seesslen | |0x1 | 1 Byte | Data-Type: PWM Permill | | 
| 95 | |0x1 | 1 Byte | Flags: None | | ||
| 96 | 46 | Maximilian Seesslen | |1000 | 4 Byte | Value: Full Brightness | | 
| 97 | 76 | Maximilian Seesslen | |
| 98 | 46 | Maximilian Seesslen | |
| 99 | 1 | Maximilian Seesslen | h1. Multipacket-Strings | 
| 100 | |||
| 101 | 46 | Maximilian Seesslen | There should be the posssibillity to write the complete SPI-Flash even if it takes forever. | 
| 102 | Not every slave needs to be able to send super big blocks. But every slave should be able to | ||
| 103 | send e.g. descriptions. | ||
| 104 | 61 | Maximilian Seesslen | There can not be multiple transfers at the same time from one node because there is no identification. | 
| 105 | 15 | Maximilian Seesslen | |
| 106 | 46 | Maximilian Seesslen | |_. Size |_. Type | | 
| 107 | | 0x4 | Package number (0: Data contains package count) | | ||
| 108 | | 0x4 | Data | | ||
| 109 | 61 | Maximilian Seesslen | |
| 110 | h2. Header | ||
| 111 | |||
| 112 | |_. Size |_. Type | | ||
| 113 | | 0x4 | Total size | | ||
| 114 | | 0x4 | Type (1=SDCard) | | ||
| 115 | 62 | Maximilian Seesslen | | 0x4 | Target node ID | | 
| 116 | 1 | Maximilian Seesslen | | 0x4 | CRC32 of data | | 
| 117 | 62 | Maximilian Seesslen | |
| 118 | 61 | Maximilian Seesslen | |
| 119 | h2. Example: CANRec | ||
| 120 | |||
| 121 | PC requests an complete dump from single Node. Node will just stream it out. | ||
| 122 | |||
| 123 | 54 | Maximilian Seesslen | h1. NMT | 
| 124 | 48 | Maximilian Seesslen | |
| 125 | h2. Actuator introduction | ||
| 126 | |||
| 127 | 80 | Maximilian Seesslen | When introduction is requested by system command, each device must send Its UID (function code "NMT introduce") and an description. | 
| 128 | 48 | Maximilian Seesslen | |
| 129 | |_. Size |_. Decription |_. Examples | | ||
| 130 | | 2 | Object | Object | | ||
| 131 | | 6 | MAC/Unique ID| 48Bit | | ||
| 132 | |||
| 133 | 52 | Maximilian Seesslen | h3. Objects | 
| 134 | 53 | Maximilian Seesslen | |
| 135 | 57 | Maximilian Seesslen | |_. Size |_. Decription | | 
| 136 | |1 | Request intoruction | | ||
| 137 | |2 | MAC low | | ||
| 138 | |3 | MAC high | | ||
| 139 | |4 | Protocol versions | | ||
| 140 | |5 | Firmware version | | ||
| 141 | |6 | Product Code | | ||
| 142 | |7 | Node-Id | | ||
| 143 | |||
| 144 | 55 | Maximilian Seesslen | |
| 145 | h3. Protocol versions | ||
| 146 | |||
| 147 | |_. Size |_. Decription | | ||
| 148 | |1 | TDT Major | | ||
| 149 | 56 | Maximilian Seesslen | |1 | TDT Minor | | 
| 150 | |1 | NMT Major | | ||
| 151 | |1 | NMT Minor | | ||
| 152 | 1 | Maximilian Seesslen | |1 | Blob Major | | 
| 153 | |1 | Blob Minor | | ||
| 154 | 78 | Maximilian Seesslen | |
| 155 | h2. Usecase: Setting Node-ID | ||
| 156 | |||
| 157 | Two nodes may have the same Node-ID. When scanning the network, the nodes will overwrite the counterparts information. | ||
| 158 | The new NodeID can not be part of the CAN-ID because the device may be filtering it out. | ||
| 159 | |||
| 160 | 55 | Maximilian Seesslen | |
| 161 | 25 | Maximilian Seesslen | h1. V2 | 
| 162 | |||
| 163 | |_. Size |_. Decription |_. Examples | | ||
| 164 | | 1 | Packet type | Standard TDT packet | | ||
| 165 | | 1 | Sub-Id; | Futher index; Sub-Sensor or more specifi kind of thing to be set | | ||
| 166 | | 1 | Data type | Int, Float, Time, Date, Percent, Promil, Multipacket-String | | ||
| 167 | 31 | Maximilian Seesslen | | 1 | Unit | Hz, °C, Time, Date, PWM, CAN-ID, Name, Description, Room | | 
| 168 | 1 | Maximilian Seesslen | | 4 | Value | 32Bit | | 
| 169 | 65 | Maximilian Seesslen | |
| 170 | h1. V3 | ||
| 171 | |||
| 172 | |_. Size |_. Decription |_. Examples | | ||
| 173 | | 2 | Object | | | ||
| 174 | | 1 | Sub-Id; | Flags, Subid | | ||
| 175 | | 1 | Unit/Type | Hz_int, °C_centi, Time, Date, PWM_milli, CAN-ID, Name, Description, Room | | ||
| 176 | | 4 | Value | 32Bit | | ||
| 177 | |||
| 178 | h2. Flags | ||
| 179 | 1 | Maximilian Seesslen | |
| 180 | 67 | Maximilian Seesslen | 4 Bit multi message count | 
| 181 | 4 Bit multi message pos | ||
| 182 | |||
| 183 | Length in Bytes given via CAN? | ||
| 184 | Strings with max. 64 characters. | ||
| 185 | |||
| 186 | 1 | Maximilian Seesslen | h2. Multimessage package | 
| 187 | |||
| 188 | 67 | Maximilian Seesslen | There should be the possibillity to write the complete SPI-Flash even if it takes forever. | 
| 189 | 1 | Maximilian Seesslen | Not every slave needs to be able to send super big blocks. But every slave should be able to | 
| 190 | send e.g. descriptions. | ||
| 191 | 69 | Maximilian Seesslen | |
| 192 | h2. Alarms/Alerts | ||
| 193 | |||
| 194 | Devices should indicate issues; e.g.: | ||
| 195 | |||
| 196 | * Battery low | ||
| 197 | * I2C problems | ||
| 198 | 70 | Maximilian Seesslen | |
| 199 | h2. Object structutre | ||
| 200 | |||
| 201 | |_. Size |_. Decription |_. Examples | | ||
| 202 | | 2 | Object | I2C, VBat, | | ||
| 203 | | 1 | Unit | hz, Float, Time, Date, Percent, promilPwm, centiCelsius, canId, room, Multipacket-String | | ||
| 204 | | 1 | Issue | Whats wrong, Undervolts, Communication error | | ||
| 205 | | 4 | Value | 32Bit | |