TDT-Protocol on CAN » Historie » Version 81
Maximilian Seesslen, 11.07.2023 13:39
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 | 81 | Maximilian Seesslen | The "NMT-Introduce"-function code is used by the nodes to send theyr complete UID. NMT can then send |
159 | The new NodeID can not be part of the CAN-ID because the device may be filtering it out. (The whole NMT ) |
||
160 | 78 | Maximilian Seesslen | |
161 | 55 | Maximilian Seesslen | |
162 | 25 | Maximilian Seesslen | h1. V2 |
163 | |||
164 | |_. Size |_. Decription |_. Examples | |
||
165 | | 1 | Packet type | Standard TDT packet | |
||
166 | | 1 | Sub-Id; | Futher index; Sub-Sensor or more specifi kind of thing to be set | |
||
167 | | 1 | Data type | Int, Float, Time, Date, Percent, Promil, Multipacket-String | |
||
168 | 31 | Maximilian Seesslen | | 1 | Unit | Hz, °C, Time, Date, PWM, CAN-ID, Name, Description, Room | |
169 | 1 | Maximilian Seesslen | | 4 | Value | 32Bit | |
170 | 65 | Maximilian Seesslen | |
171 | h1. V3 |
||
172 | |||
173 | |_. Size |_. Decription |_. Examples | |
||
174 | | 2 | Object | | |
||
175 | | 1 | Sub-Id; | Flags, Subid | |
||
176 | | 1 | Unit/Type | Hz_int, °C_centi, Time, Date, PWM_milli, CAN-ID, Name, Description, Room | |
||
177 | | 4 | Value | 32Bit | |
||
178 | |||
179 | h2. Flags |
||
180 | 1 | Maximilian Seesslen | |
181 | 67 | Maximilian Seesslen | 4 Bit multi message count |
182 | 4 Bit multi message pos |
||
183 | |||
184 | Length in Bytes given via CAN? |
||
185 | Strings with max. 64 characters. |
||
186 | |||
187 | 1 | Maximilian Seesslen | h2. Multimessage package |
188 | |||
189 | 67 | Maximilian Seesslen | There should be the possibillity to write the complete SPI-Flash even if it takes forever. |
190 | 1 | Maximilian Seesslen | Not every slave needs to be able to send super big blocks. But every slave should be able to |
191 | send e.g. descriptions. |
||
192 | 69 | Maximilian Seesslen | |
193 | h2. Alarms/Alerts |
||
194 | |||
195 | Devices should indicate issues; e.g.: |
||
196 | |||
197 | * Battery low |
||
198 | * I2C problems |
||
199 | 70 | Maximilian Seesslen | |
200 | h2. Object structutre |
||
201 | |||
202 | |_. Size |_. Decription |_. Examples | |
||
203 | | 2 | Object | I2C, VBat, | |
||
204 | | 1 | Unit | hz, Float, Time, Date, Percent, promilPwm, centiCelsius, canId, room, Multipacket-String | |
||
205 | | 1 | Issue | Whats wrong, Undervolts, Communication error | |
||
206 | | 4 | Value | 32Bit | |