foxBMS
1.5.0
The foxBMS Battery Management System API Documentation
can_cfg_rx-message-definitions.h
Go to the documentation of this file.
1
/**
2
*
3
* @copyright © 2010 - 2023, Fraunhofer-Gesellschaft zur Foerderung der angewandten Forschung e.V.
4
* All rights reserved.
5
*
6
* SPDX-License-Identifier: BSD-3-Clause
7
*
8
* Redistribution and use in source and binary forms, with or without
9
* modification, are permitted provided that the following conditions are met:
10
*
11
* 1. Redistributions of source code must retain the above copyright notice, this
12
* list of conditions and the following disclaimer.
13
*
14
* 2. Redistributions in binary form must reproduce the above copyright notice,
15
* this list of conditions and the following disclaimer in the documentation
16
* and/or other materials provided with the distribution.
17
*
18
* 3. Neither the name of the copyright holder nor the names of its
19
* contributors may be used to endorse or promote products derived from
20
* this software without specific prior written permission.
21
*
22
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
23
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
25
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
26
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
28
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
30
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32
*
33
* We kindly request you to use one or more of the following phrases to refer to
34
* foxBMS in your hardware, software, documentation or advertising materials:
35
*
36
* - ″This product uses parts of foxBMS®″
37
* - ″This product includes parts of foxBMS®″
38
* - ″This product is derived from foxBMS®″
39
*
40
*/
41
42
/**
43
* @file can_cfg_rx-message-definitions.h
44
* @author foxBMS Team
45
* @date 2022-07-01 (date of creation)
46
* @updated 2023-02-03 (date of last update)
47
* @version v1.5.0
48
* @ingroup DRIVERS
49
* @prefix CANRX
50
*
51
* @brief Header for the driver for the CAN module
52
*
53
*/
54
55
#ifndef FOXBMS__CAN_CFG_RX_MESSAGE_DEFINITIONS_H_
56
#define FOXBMS__CAN_CFG_RX_MESSAGE_DEFINITIONS_H_
57
58
/*========== Includes =======================================================*/
59
#include "
can_cfg.h
"
60
61
#include <stdint.h>
62
63
/*========== Macros and Definitions =========================================*/
64
#define CANRX_NOT_PERIODIC (0u)
65
66
/* Message IDs */
67
68
/** CAN message properties for state request message. Required properties are:
69
* - Message ID
70
* - Identifier type (standard or extended)
71
* - Expected message period in ms or if asynchronous message
72
* - Endianness of message data @{*/
73
#define CANRX_BMS_STATE_REQUEST_ID (0x230u)
74
#define CANRX_BMS_STATE_REQUEST_ID_TYPE (CAN_STANDARD_IDENTIFIER_11_BIT)
75
#define CANRX_BMS_STATE_REQUEST_PERIOD_ms (CANRX_NOT_PERIODIC)
76
#define CANRX_BMS_STATE_REQUEST_ENDIANNESS (CAN_BIG_ENDIAN)
77
/**@} */
78
79
/** CAN message properties for debug message. Required properties are:
80
* - Message ID
81
* - Identifier type (standard or extended)
82
* - Expected message period in ms or if asynchronous message
83
* - Endianness of message data @{*/
84
#define CANRX_DEBUG_ID (0x200u)
85
#define CANRX_DEBUG_ID_TYPE (CAN_STANDARD_IDENTIFIER_11_BIT)
86
#define CANRX_DEBUG_PERIOD_ms (CANRX_NOT_PERIODIC)
87
#define CANRX_DEBUG_ENDIANNESS (CAN_BIG_ENDIAN)
88
/**@}*/
89
90
/**
91
* -------------------------CAUTION-------------------------
92
* The following defines are used by the insulation monitoring device (IMD).
93
* If they are changed, the IMD will not work anymore
94
* -------------------------CAUTION-------------------------
95
*/
96
/** CAN message ID for info message from iso165c */
97
#define CANRX_IMD_INFO_ID (0x37u)
98
/** CAN message ID for response message from iso165c */
99
#define CANRX_IMD_RESPONSE_ID (0x23u)
100
/** CAN message identifier type */
101
#define CANRX_IMD_ID_TYPE (CAN_STANDARD_IDENTIFIER_11_BIT)
102
103
/** CAN message properties for Isabellenhuette current sensor messages. Properties are:
104
* - Data length of current sensor CAN messages
105
* - Identifier type (standard or extended)
106
* - Endianness of message data @{*/
107
#define CANRX_CURRENT_SENSOR_MESSAGES_DLC (6u)
108
#define CANRX_CURRENT_SENSOR_MESSAGES_ID_TYPE (CAN_STANDARD_IDENTIFIER_11_BIT)
109
#define CANRX_CURRENT_SENSOR_MESSAGES_ENDIANNESS (CAN_BIG_ENDIAN)
110
/**@} */
111
112
/** CAN message properties for string 0 current sensor messages. Properties for each message are:
113
* - Message ID
114
* - Expected message period in ms or if asynchronous message @{*/
115
#define CANRX_STRING0_CURRENT_ID (0x521u)
116
#define CANRX_STRING0_CURRENT_PERIOD_ms (CANRX_NOT_PERIODIC)
117
#define CANRX_STRING0_VOLTAGE1_ID (0x522u)
118
#define CANRX_STRING0_VOLTAGE1_PERIOD_ms (CANRX_NOT_PERIODIC)
119
#define CANRX_STRING0_VOLTAGE2_ID (0x523u)
120
#define CANRX_STRING0_VOLTAGE2_PERIOD_ms (CANRX_NOT_PERIODIC)
121
#define CANRX_STRING0_VOLTAGE3_ID (0x524u)
122
#define CANRX_STRING0_VOLTAGE3_PERIOD_ms (CANRX_NOT_PERIODIC)
123
#define CANRX_STRING0_TEMPERATURE_ID (0x525u)
124
#define CANRX_STRING0_TEMPERATURE_PERIOD_ms (CANRX_NOT_PERIODIC)
125
#define CANRX_STRING0_POWER_ID (0x526u)
126
#define CANRX_STRING0_POWER_PERIOD_ms (CANRX_NOT_PERIODIC)
127
#define CANRX_STRING0_CURRENT_COUNTER_ID (0x527u)
128
#define CANRX_STRING0_CURRENT_COUNTER_PERIOD_ms (CANRX_NOT_PERIODIC)
129
#define CANRX_STRING0_ENERGY_COUNTER_ID (0x528u)
130
#define CANRX_STRING0_ENERGY_COUNTER_PERIOD_ms (CANRX_NOT_PERIODIC)
131
/**@} */
132
133
/* composed Rx messages */
134
135
/* AXIVION Disable Style Generic-NoUnsafeMacro: These macros MUST only be used
136
to populate the 'can_rxMessages' array. The type of this array expects data
137
exactly as it is provided here and therefore these macros are good (for this
138
and only for this purpose!).*/
139
140
/* !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
141
timing check not implemented for RX messages!
142
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
143
*/
144
145
#define CANRX_DEBUG_MESSAGE \
146
{ \
147
.id = CANRX_DEBUG_ID, \
148
.idType = CANRX_DEBUG_ID_TYPE, \
149
.dlc = CAN_DEFAULT_DLC, \
150
.endianness = CANRX_DEBUG_ENDIANNESS, \
151
}, \
152
{ \
153
.period = CANRX_DEBUG_PERIOD_ms \
154
}
155
156
#define CANRX_IMD_INFO_MESSAGE \
157
{ \
158
.id = CANRX_IMD_INFO_ID, \
159
.idType = CANRX_IMD_ID_TYPE, \
160
.dlc = CAN_DEFAULT_DLC, \
161
.endianness = CAN_LITTLE_ENDIAN, \
162
}, \
163
{ \
164
.period = CANRX_NOT_PERIODIC \
165
}
166
167
#define CANRX_IMD_RESPONSE_MESSAGE \
168
{ \
169
.id = CANRX_IMD_RESPONSE_ID, \
170
.idType = CANRX_IMD_ID_TYPE, \
171
.dlc = CAN_DEFAULT_DLC, \
172
.endianness = CAN_LITTLE_ENDIAN, \
173
}, \
174
{ \
175
.period = CANRX_NOT_PERIODIC \
176
}
177
178
#define CANRX_BMS_STATE_REQUEST_MESSAGE \
179
{ \
180
.id = CANRX_BMS_STATE_REQUEST_ID, \
181
.idType = CANRX_BMS_STATE_REQUEST_ID_TYPE, \
182
.dlc = CAN_DEFAULT_DLC, \
183
.endianness = CANRX_BMS_STATE_REQUEST_ENDIANNESS, \
184
}, \
185
{ \
186
.period = CANRX_BMS_STATE_REQUEST_PERIOD_ms \
187
}
188
189
#define CANRX_STRING0_CURRENT_MESSAGE \
190
{ \
191
.id = CANRX_STRING0_CURRENT_ID, \
192
.idType = CANRX_CURRENT_SENSOR_MESSAGES_ID_TYPE, \
193
.dlc = CANRX_CURRENT_SENSOR_MESSAGES_DLC, \
194
.endianness = CANRX_CURRENT_SENSOR_MESSAGES_ENDIANNESS, \
195
}, \
196
{ \
197
.period = CANRX_STRING0_CURRENT_PERIOD_ms \
198
}
199
200
#define CANRX_STRING0_VOLTAGE1_MESSAGE \
201
{ \
202
.id = CANRX_STRING0_VOLTAGE1_ID, \
203
.idType = CANRX_CURRENT_SENSOR_MESSAGES_ID_TYPE, \
204
.dlc = CANRX_CURRENT_SENSOR_MESSAGES_DLC, \
205
.endianness = CANRX_CURRENT_SENSOR_MESSAGES_ENDIANNESS, \
206
}, \
207
{ \
208
.period = CANRX_STRING0_VOLTAGE1_PERIOD_ms \
209
}
210
211
#define CANRX_STRING0_VOLTAGE2_MESSAGE \
212
{ \
213
.id = CANRX_STRING0_VOLTAGE2_ID, \
214
.idType = CANRX_CURRENT_SENSOR_MESSAGES_ID_TYPE, \
215
.dlc = CANRX_CURRENT_SENSOR_MESSAGES_DLC, \
216
.endianness = CANRX_CURRENT_SENSOR_MESSAGES_ENDIANNESS, \
217
}, \
218
{ \
219
.period = CANRX_STRING0_VOLTAGE2_PERIOD_ms \
220
}
221
222
#define CANRX_STRING0_VOLTAGE3_MESSAGE \
223
{ \
224
.id = CANRX_STRING0_VOLTAGE3_ID, \
225
.idType = CANRX_CURRENT_SENSOR_MESSAGES_ID_TYPE, \
226
.dlc = CANRX_CURRENT_SENSOR_MESSAGES_DLC, \
227
.endianness = CANRX_CURRENT_SENSOR_MESSAGES_ENDIANNESS, \
228
}, \
229
{ \
230
.period = CANRX_STRING0_VOLTAGE3_PERIOD_ms \
231
}
232
233
#define CANRX_STRING0_TEMPERATURE_MESSAGE \
234
{ \
235
.id = CANRX_STRING0_TEMPERATURE_ID, \
236
.idType = CANRX_CURRENT_SENSOR_MESSAGES_ID_TYPE, \
237
.dlc = CANRX_CURRENT_SENSOR_MESSAGES_DLC, \
238
.endianness = CANRX_CURRENT_SENSOR_MESSAGES_ENDIANNESS, \
239
}, \
240
{ \
241
.period = CANRX_STRING0_TEMPERATURE_PERIOD_ms \
242
}
243
244
#define CANRX_STRING0_POWER_MESSAGE \
245
{ \
246
.id = CANRX_STRING0_POWER_ID, \
247
.idType = CANRX_CURRENT_SENSOR_MESSAGES_ID_TYPE, \
248
.dlc = CANRX_CURRENT_SENSOR_MESSAGES_DLC, \
249
.endianness = CANRX_CURRENT_SENSOR_MESSAGES_ENDIANNESS, \
250
}, \
251
{ \
252
.period = CANRX_STRING0_POWER_PERIOD_ms \
253
}
254
255
#define CANRX_STRING0_CURRENT_COUNTER_MESSAGE \
256
{ \
257
.id = CANRX_STRING0_CURRENT_COUNTER_ID, \
258
.idType = CANRX_CURRENT_SENSOR_MESSAGES_ID_TYPE, \
259
.dlc = CANRX_CURRENT_SENSOR_MESSAGES_DLC, \
260
.endianness = CANRX_CURRENT_SENSOR_MESSAGES_ENDIANNESS, \
261
}, \
262
{ \
263
.period = CANRX_STRING0_CURRENT_COUNTER_PERIOD_ms \
264
}
265
266
#define CANRX_STRING0_ENERGY_COUNTER_MESSAGE \
267
{ \
268
.id = CANRX_STRING0_ENERGY_COUNTER_ID, \
269
.idType = CANRX_CURRENT_SENSOR_MESSAGES_ID_TYPE, \
270
.dlc = CANRX_CURRENT_SENSOR_MESSAGES_DLC, \
271
.endianness = CANRX_CURRENT_SENSOR_MESSAGES_ENDIANNESS, \
272
}, \
273
{ \
274
.period = CANRX_STRING0_ENERGY_COUNTER_PERIOD_ms \
275
}
276
/* AXIVION Enable Style Generic-NoUnsafeMacro */
277
278
/*========== Extern Constant and Variable Declarations ======================*/
279
280
/*========== Extern Function Prototypes =====================================*/
281
282
/*========== Externalized Static Functions Prototypes (Unit Test) ===========*/
283
#ifdef UNITY_UNIT_TEST
284
#endif
285
286
#endif
/* FOXBMS__CAN_CFG_RX_MESSAGE_DEFINITIONS_H_ */
can_cfg.h
Headers for the configuration for the CAN module.
src
app
driver
config
can_cfg_rx-message-definitions.h
Generated by
1.9.1