Projekt

Allgemein

Profil

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                                                                                     |