foxBMS  1.4.1
The foxBMS Battery Management System API Documentation
database_cfg.h
Go to the documentation of this file.
1 /**
2  *
3  * @copyright © 2010 - 2022, 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 database_cfg.h
44  * @author foxBMS Team
45  * @date 2015-08-18 (date of creation)
46  * @updated 2022-10-27 (date of last update)
47  * @version v1.4.1
48  * @ingroup ENGINE_CONFIGURATION
49  * @prefix DATA
50  *
51  * @brief Database configuration header
52  *
53  * @details Provides interfaces to database configuration
54  *
55  */
56 
57 #ifndef FOXBMS__DATABASE_CFG_H_
58 #define FOXBMS__DATABASE_CFG_H_
59 
60 /*========== Includes =======================================================*/
61 #include "general.h"
62 
63 #include "battery_system_cfg.h"
64 
65 #include "mcu.h"
66 
67 /*========== Macros and Definitions =========================================*/
68 /** configuration struct of database channel (data block) */
69 typedef struct {
70  void *pDatabaseEntry; /*!< pointer to the database entry */
71  uint32_t dataLength; /*!< length of the entry */
72 } DATA_BASE_s;
73 
74 /** data block identification numbers */
75 typedef enum {
109  DATA_BLOCK_ID_MAX, /**< DO NOT CHANGE, MUST BE THE LAST ENTRY */
111 
113  (int16_t)DATA_BLOCK_ID_MAX < UINT8_MAX,
114  "Maximum number of database entries exceeds UINT8_MAX; adapted length "
115  "checking in DATA_Initialize and DATA_IterateOverDatabaseEntries");
116 
117 /** data block header */
118 typedef struct {
119  DATA_BLOCK_ID_e uniqueId; /*!< uniqueId of database entry */
120  uint32_t timestamp; /*!< timestamp of last database update */
121  uint32_t previousTimestamp; /*!< timestamp of previous database update */
123 
124 /** data block struct of cell voltage */
125 typedef struct {
126  /* This struct needs to be at the beginning of every database entry. During
127  * the initialization of a database struct, uniqueId must be set to the
128  * respective database entry representation in enum DATA_BLOCK_ID_e. */
129  DATA_BLOCK_HEADER_s header; /*!< Data block header */
130  uint8_t state; /*!< for future use */
131  int32_t packVoltage_mV[BS_NR_OF_STRINGS]; /*!< uint: mV */
132  int16_t cellVoltage_mV[BS_NR_OF_STRINGS][BS_NR_OF_CELL_BLOCKS_PER_STRING]; /*!< unit: mV */
133  uint64_t
134  invalidCellVoltage[BS_NR_OF_STRINGS]
135  [BS_NR_OF_MODULES_PER_STRING]; /*!< bitmask if voltages are valid. 0->valid, 1->invalid */
136  uint16_t nrValidCellVoltages[BS_NR_OF_STRINGS]; /*!< number of valid voltages */
137  uint32_t moduleVoltage_mV[BS_NR_OF_STRINGS][BS_NR_OF_MODULES_PER_STRING]; /*!< unit: mV */
138  bool validModuleVoltage[BS_NR_OF_STRINGS][BS_NR_OF_MODULES_PER_STRING]; /*!< 0 -> if PEC okay; 1 -> PEC error */
140 
141 /** data block struct of cell temperatures */
142 typedef struct {
143  /* This struct needs to be at the beginning of every database entry. During
144  * the initialization of a database struct, uniqueId must be set to the
145  * respective database entry representation in enum DATA_BLOCK_ID_e. */
146  DATA_BLOCK_HEADER_s header; /*!< Data block header */
147  uint8_t state; /*!< for future use */
148  int16_t cellTemperature_ddegC[BS_NR_OF_STRINGS][BS_NR_OF_TEMP_SENSORS_PER_STRING]; /*!< unit: deci &deg;C */
149  uint16_t invalidCellTemperature
150  [BS_NR_OF_STRINGS][BS_NR_OF_MODULES_PER_STRING]; /*!< bitmask if temperatures are valid. 0->valid, 1->invalid */
151  uint16_t nrValidTemperatures[BS_NR_OF_STRINGS]; /*!< number of valid temperatures in each string */
153 
154 /** data block struct of minimum and maximum values */
155 typedef struct {
156  /* This struct needs to be at the beginning of every database entry. During
157  * the initialization of a database struct, uniqueId must be set to the
158  * respective database entry representation in enum DATA_BLOCK_ID_e. */
159  DATA_BLOCK_HEADER_s header; /*!< Data block header */
160 
161  int16_t averageCellVoltage_mV[BS_NR_OF_STRINGS]; /*!< average cell voltages, unit: mV */
162  int16_t minimumCellVoltage_mV[BS_NR_OF_STRINGS]; /*!< minimum cell voltages, unit: mV */
163  int16_t previousMinimumCellVoltage_mV[BS_NR_OF_STRINGS]; /*!< previous minimum cell voltages, unit: mV */
164  int16_t maximumCellVoltage_mV[BS_NR_OF_STRINGS]; /*!< maximum cell voltages, unit: mV */
165  int16_t previousMaximumCellVoltage_mV[BS_NR_OF_STRINGS]; /*!< previous maximum cell voltages, unit: mV */
166  uint16_t nrModuleMinimumCellVoltage[BS_NR_OF_STRINGS]; /*!< number of the module with minimum cell voltage */
167  uint16_t nrCellMinimumCellVoltage[BS_NR_OF_STRINGS]; /*!< number of the cell with minimum cell voltage */
168  uint16_t nrModuleMaximumCellVoltage[BS_NR_OF_STRINGS]; /*!< number of the module with maximum cell voltage */
169  uint16_t nrCellMaximumCellVoltage[BS_NR_OF_STRINGS]; /*!< number of the cell with maximum cell voltage */
170  uint16_t validMeasuredCellVoltages[BS_NR_OF_STRINGS]; /*!< number of valid measured cell voltages */
171  float averageTemperature_ddegC[BS_NR_OF_STRINGS]; /*!< unit: deci &deg;C */
172  int16_t minimumTemperature_ddegC[BS_NR_OF_STRINGS]; /*!< unit: deci &deg;C */
173  uint16_t nrModuleMinimumTemperature[BS_NR_OF_STRINGS]; /*!< number of the module with minimum temperature */
174  uint16_t nrSensorMinimumTemperature[BS_NR_OF_STRINGS]; /*!< number of the sensor with minimum temperature */
175  int16_t maximumTemperature_ddegC[BS_NR_OF_STRINGS]; /*!< unit: deci &deg;C */
176  uint16_t nrModuleMaximumTemperature[BS_NR_OF_STRINGS]; /*!< number of the module with maximum temperature */
177  uint16_t nrSensorMaximumTemperature[BS_NR_OF_STRINGS]; /*!< number of the sensor with maximum temperature */
178  uint16_t validMeasuredCellTemperatures[BS_NR_OF_STRINGS]; /*!< number of valid measured cell temperatures */
179  uint8_t state; /*!< state of the min max module */
181 
182 /** data block struct of pack measurement values */
183 typedef struct {
184  /* This struct needs to be at the beginning of every database entry. During
185  * the initialization of a database struct, uniqueId must be set to the
186  * respective database entry representation in enum DATA_BLOCK_ID_e. */
187  DATA_BLOCK_HEADER_s header; /*!< Data block header */
188 
189  int32_t packCurrent_mA; /*!< current in the whole battery pack, unit: mA */
190  uint8_t invalidPackCurrent; /*!< bitmask if current is valid. 0->valid, 1->invalid */
191  int32_t batteryVoltage_mV; /*!< voltage between negative and positive battery pole, unit: mV */
192  uint8_t invalidBatteryVoltage; /*!< bitmask if voltage is valid. 0->valid, 1->invalid */
193  int32_t
194  highVoltageBusVoltage_mV; /*!< voltage between negative battery pole and after positive main contactor, unit: mV */
195  uint8_t invalidHvBusVoltage; /*!< bitmask if voltage is valid. 0->valid, 1->invalid */
196  int32_t packPower_W; /*!< power provided by respectively supplied to the battery pack, unit: W */
197  uint8_t invalidPackPower; /*!< bitmask if power is valid. 0->valid, 1->invalid */
198  int32_t stringVoltage_mV[BS_NR_OF_STRINGS]; /*!< voltage of each string, unit: mV */
199  uint8_t invalidStringVoltage[BS_NR_OF_STRINGS]; /*!< bitmask if voltages are valid. 0->valid, 1->invalid */
200  int32_t stringCurrent_mA[BS_NR_OF_STRINGS]; /*!< current in each string, unit: mA */
201  uint8_t invalidStringCurrent[BS_NR_OF_STRINGS]; /*!< bitmask if currents are valid. 0->valid, 1->invalid */
202  int32_t stringPower_W[BS_NR_OF_STRINGS]; /*!< power of each string, unit: W */
203  uint8_t invalidStringPower[BS_NR_OF_STRINGS]; /*!< bitmask if power values are valid. 0->valid, 1->invalid */
205 
206 /** data block struct of current measurement */
207 typedef struct {
208  /* This struct needs to be at the beginning of every database entry. During
209  * the initialization of a database struct, uniqueId must be set to the
210  * respective database entry representation in enum DATA_BLOCK_ID_e. */
211  DATA_BLOCK_HEADER_s header; /*!< Data block header */
212  int32_t current_mA[BS_NR_OF_STRINGS]; /*!< unit: mA */
213  uint8_t invalidCurrentMeasurement[BS_NR_OF_STRINGS]; /*!< 0: measurement valid, 1: measurement invalid */
214  uint8_t newCurrent; /*!< 0: measurement valid, 1: measurement invalid */
215  uint32_t previousTimestampCurrent[BS_NR_OF_STRINGS]; /*!< timestamp of current measurement */
216  uint32_t timestampCurrent[BS_NR_OF_STRINGS]; /*!< timestamp of current measurement */
217  int32_t sensorTemperature_ddegC[BS_NR_OF_STRINGS]; /*!< unit: 0.1&deg;C */
218  uint8_t invalidSensorTemperatureMeasurement[BS_NR_OF_STRINGS]; /*!< 0: measurement valid, 1: measurement invalid */
219  int32_t power_W[BS_NR_OF_STRINGS]; /*!< unit: W */
220  uint8_t invalidPowerMeasurement[BS_NR_OF_STRINGS]; /*!< 0: measurement valid, 1: measurement invalid */
221  uint8_t newPower; /*!< counter that indicates a new power measurement */
222  uint32_t previousTimestampPower[BS_NR_OF_STRINGS]; /*!< previous timestamp of power measurement */
223  uint32_t timestampPower[BS_NR_OF_STRINGS]; /*!< timestamp of power measurement */
224  int32_t currentCounter_As[BS_NR_OF_STRINGS]; /*!< unit: A.s */
225  uint8_t invalidCurrentCountingMeasurement[BS_NR_OF_STRINGS]; /*!< 0: measurement valid, 1: measurement invalid */
226  uint32_t previousTimestampCurrentCounting[BS_NR_OF_STRINGS]; /*!< previous timestamp of CC measurement */
227  uint32_t timestampCurrentCounting[BS_NR_OF_STRINGS]; /*!< timestamp of CC measurement */
228  int32_t energyCounter_Wh[BS_NR_OF_STRINGS]; /*!< unit: Wh */
229  uint8_t invalidEnergyCountingMeasurement[BS_NR_OF_STRINGS]; /*!< 0: measurement valid, 1: measurement invalid */
230  uint32_t previousTimestampEnergyCounting[BS_NR_OF_STRINGS]; /*!< previous timestamp of EC measurement */
231  uint32_t timestampEnergyCounting[BS_NR_OF_STRINGS]; /*!< timestamp of EC measurement */
232  uint8_t invalidHighVoltageMeasurement
233  [BS_NR_OF_STRINGS][BS_NR_OF_VOLTAGES_FROM_CURRENT_SENSOR]; /*!< 0: measurement valid, 1: measurement invalid */
234  int32_t highVoltage_mV[BS_NR_OF_STRINGS][BS_NR_OF_VOLTAGES_FROM_CURRENT_SENSOR]; /*!< unit: mV */
235  uint32_t previousTimestampHighVoltage
237  [BS_NR_OF_VOLTAGES_FROM_CURRENT_SENSOR]; /*!< previous timestamp of high voltage measurement */
238  uint32_t timestampHighVoltage[BS_NR_OF_STRINGS]
239  [BS_NR_OF_VOLTAGES_FROM_CURRENT_SENSOR]; /*!< timestamp of high voltage measurement */
241 
242 /** data structure declaration of DATA_BLOCK_BALANCING_CONTROL */
243 typedef struct {
244  /* This struct needs to be at the beginning of every database entry. During
245  * the initialization of a database struct, uniqueId must be set to the
246  * respective database entry representation in enum DATA_BLOCK_ID_e. */
247  DATA_BLOCK_HEADER_s header; /*!< Data block header */
248  uint8_t enableBalancing; /*!< Switch for enabling/disabling balancing */
249  uint8_t threshold_mV; /*!< balancing threshold in mV */
250  uint8_t request; /*!< balancing request per CAN */
251  uint8_t balancingState[BS_NR_OF_STRINGS]
252  [BS_NR_OF_CELL_BLOCKS_PER_STRING]; /*!< 0: no balancing, 1: balancing active */
253  uint32_t deltaCharge_mAs[BS_NR_OF_STRINGS]
254  [BS_NR_OF_CELL_BLOCKS_PER_STRING]; /*!< Difference in Depth-of-Discharge in mAs */
255  uint16_t nrBalancedCells[BS_NR_OF_STRINGS];
257 
258 /** data structure declaration of DATA_BLOCK_USER_IO_CONTROL */
259 typedef struct {
260  /* This struct needs to be at the beginning of every database entry. During
261  * the initialization of a database struct, uniqueId must be set to the
262  * respective database entry representation in enum DATA_BLOCK_ID_e. */
263  DATA_BLOCK_HEADER_s header; /*!< Data block header */
264  uint8_t state; /*!< for future use */
265  uint32_t eepromReadAddressToUse; /*!< address to read from for slave EEPROM */
266  uint32_t eepromReadAddressLastUsed; /*!< last address used to read fromfor slave EEPROM */
267  uint32_t eepromWriteAddressToUse; /*!< address to write to for slave EEPROM */
268  uint32_t eepromWriteAddressLastUsed; /*!< last address used to write to for slave EEPROM */
269  uint8_t ioValueOut[BS_NR_OF_MODULES_PER_STRING]; /*!< data to be written to the port expander */
270  uint8_t ioValueIn[BS_NR_OF_MODULES_PER_STRING]; /*!< data read from to the port expander */
271  uint8_t eepromValueWrite[BS_NR_OF_MODULES_PER_STRING]; /*!< data to be written to the slave EEPROM */
272  uint8_t eepromValueRead[BS_NR_OF_MODULES_PER_STRING]; /*!< data read from to the slave EEPROM */
273  uint8_t
274  externalTemperatureSensor[BS_NR_OF_MODULES_PER_STRING]; /*!< temperature from the external sensor on slave */
276 
277 /** data block struct of cell balancing feedback */
278 typedef struct {
279  /* This struct needs to be at the beginning of every database entry. During
280  * the initialization of a database struct, uniqueId must be set to the
281  * respective database entry representation in enum DATA_BLOCK_ID_e. */
282  DATA_BLOCK_HEADER_s header; /*!< Data block header */
283  uint8_t state; /*!< for future use */
284  uint16_t value[BS_NR_OF_STRINGS][BS_NR_OF_MODULES_PER_STRING]; /*!< unit: mV (optocoupler output) */
286 
287 /** data block struct of user multiplexer values */
288 typedef struct {
289  /* This struct needs to be at the beginning of every database entry. During
290  * the initialization of a database struct, uniqueId must be set to the
291  * respective database entry representation in enum DATA_BLOCK_ID_e. */
292  DATA_BLOCK_HEADER_s header; /*!< Data block header */
293  uint8_t state; /*!< for future use */
294  uint16_t value[BS_NR_OF_STRINGS][8u * 2u * BS_NR_OF_MODULES_PER_STRING]; /*!< unit: mV (mux voltage input) */
296 
297 /** data block struct of cell open wire */
298 typedef struct {
299  /* This struct needs to be at the beginning of every database entry. During
300  * the initialization of a database struct, uniqueId must be set to the
301  * respective database entry representation in enum DATA_BLOCK_ID_e. */
302  DATA_BLOCK_HEADER_s header; /*!< Data block header */
303  uint8_t state; /*!< for future use */
304  uint16_t nrOpenWires[BS_NR_OF_STRINGS]; /*!< number of open wires */
305  uint8_t openwire[BS_NR_OF_STRINGS]
307  (BS_NR_OF_CELL_BLOCKS_PER_MODULE + 1u)]; /*!< 1 -> open wire, 0 -> everything ok */
309 
310 /** data block struct of GPIO voltage */
311 typedef struct {
312  /* This struct needs to be at the beginning of every database entry. During
313  * the initialization of a database struct, uniqueId must be set to the
314  * respective database entry representation in enum DATA_BLOCK_ID_e. */
315  DATA_BLOCK_HEADER_s header; /*!< Data block header */
316  uint8_t state; /*!< for future use */
317  uint16_t gpioVoltages_mV[BS_NR_OF_STRINGS]
319  uint16_t
320  invalidGpioVoltages[BS_NR_OF_STRINGS]
321  [BS_NR_OF_MODULES_PER_STRING]; /*!< bitmask if voltages are valid. 0->valid, 1->invalid */
323 
324 /** data block struct of error flags */
325 typedef struct {
326  /* This struct needs to be at the beginning of every database entry. During
327  * the initialization of a database struct, uniqueId must be set to the
328  * respective database entry representation in enum DATA_BLOCK_ID_e. */
329  DATA_BLOCK_HEADER_s header; /*!< Data block header */
330  uint8_t currentSensor[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error, not responding */
331  uint8_t stringMinusContactor[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error, not responding */
332  uint8_t stringPlusContactor[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error, not responding */
333  uint8_t prechargeContactor[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error, not responding */
334  uint8_t interlock; /*!< 0 -> no error, 1 -> error */
335  uint8_t crcError[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
336  uint8_t muxError[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
337  uint8_t spiError[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
338  uint8_t afeConfigurationError[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
339  uint8_t afeCellVoltageError[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
340  uint8_t afeCellTemperatureError[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
341  uint8_t baseCellVoltageMeasurementTimeout; /*!< 0 -> no error, 1 -> error */
342  uint8_t redundancy0CellVoltageMeasurementTimeout; /*!< 0 -> no error, 1 -> error */
343  uint8_t baseCellTemperatureMeasurementTimeout; /*!< 0 -> no error, 1 -> error */
344  uint8_t redundancy0CellTemperatureMeasurementTimeout; /*!< 0 -> no error, 1 -> error */
345  uint8_t currentMeasurementTimeout[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
346  uint8_t currentMeasurementError[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
347  uint8_t currentSensorTimeoutV1[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
348  uint8_t currentSensorTimeoutV3[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
349  uint8_t currentSensorPowerTimeout[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
350  uint8_t powerMeasurementError[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
351  bool insulationMeasurementValid; /*!< false -> not valid, true -> valid */
352  bool
353  criticalLowInsulationResistance; /*!< false -> no critical resistance measured, true -> critical low resistance measured */
354  bool
355  warnableLowInsulationResistance; /*!< false -> no warnable resistance measured, true -> warnable low resistance measured */
356  bool
357  insulationGroundFaultDetected; /*!< false -> no insulation fault between HV and chassis detected, true -> insulation fault detected */
358  uint8_t fuseStateNormal[BS_NR_OF_STRINGS]; /*!< 0 -> fuse ok, 1 -> fuse tripped */
359  uint8_t fuseStateCharge[BS_NR_OF_STRINGS]; /*!< 0 -> fuse ok, 1 -> fuse tripped */
360  uint8_t open_wire[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
361  uint8_t canTiming; /*!< 0 -> no error, 1 -> error */
362  uint8_t canRxQueueFull; /*!< 0 -> no error, 1 -> error */
363  uint8_t canTimingCc[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
364  uint8_t canTimingEc[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
365  uint8_t mcuDieTemperature; /*!< 0 -> no error, 1 -> error */
366  uint8_t coinCellVoltage; /*!< 0 -> no error, 1 -> error */
367  uint8_t plausibilityCheckPackvoltage[BS_NR_OF_STRINGS]; /*!< 0 -> no error, else: error */
368  uint8_t plausibilityCheckCellVoltage[BS_NR_OF_STRINGS]; /*!< 0 -> no error, else: error */
369  uint8_t plausibilityCheckCellVoltageSpread[BS_NR_OF_STRINGS]; /*!< 0 -> no error, else: error */
370  uint8_t plausibilityCheckCelltemperatureSpread[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
371  uint8_t plausibilityCheckCelltemperature[BS_NR_OF_STRINGS]; /*!< 0 -> no error, else: error */
372  uint8_t deepDischargeDetected[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
373  uint8_t currentOnOpenString[BS_NR_OF_STRINGS]; /*!< 0 -> no error, 1 -> error */
374  uint8_t sbcFinState; /*!< 0 -> okay, 1 -> error: short-circuit to RSTB */
375  uint8_t sbcRstbState; /*!< 0 -> okay, 1 -> error: RSTB not working */
376  uint8_t i2cPexError; /*!< the I2C port expander does not work as expected */
377  uint8_t framReadCrcError; /*!< 0 if read CRC matches with CRC of read data , 1 otherwise */
378  bool timingViolationEngine; /*!< timing violation in engine task */
379  bool timingViolation1ms; /*!< timing violation in 1ms task */
380  bool timingViolation10ms; /*!< timing violation in 10ms task */
381  bool timingViolation100ms; /*!< timing violation in 100ms task */
382  bool timingViolation100msAlgo; /*!< timing violation in 100ms algorithm task */
383  bool alertFlag; /*!< true: ALERT situation detected, false: everything okay */
385 
386 /** data block struct of contactor feedback */
387 typedef struct {
388  /* This struct needs to be at the beginning of every database entry. During
389  * the initialization of a database struct, uniqueId must be set to the
390  * respective database entry representation in enum DATA_BLOCK_ID_e. */
391  DATA_BLOCK_HEADER_s header; /*!< Data block header */
392  uint32_t contactorFeedback; /*!< feedback of all contactors, without interlock */
394 
395 /** data block struct of interlock feedback */
396 typedef struct {
397  /* This struct needs to be at the beginning of every database entry. During
398  * the initialization of a database struct, uniqueId must be set to the
399  * respective database entry representation in enum DATA_BLOCK_ID_e. */
400  DATA_BLOCK_HEADER_s header; /*!< Data block header */
401  uint8_t interlockFeedback_IL_STATE; /*!< feedback of interlock, connected to pin */
402  float interlockVoltageFeedback_IL_HS_VS_mV; /*!< voltage feedback of interlock, connected to ADC input 2 */
403  float interlockVoltageFeedback_IL_LS_VS_mV; /*!< voltage feedback of interlock, connected to ADC input 3 */
404  float interlockCurrentFeedback_IL_HS_CS_mA; /*!< current feedback of interlock, connected to ADC input 4 */
405  float interlockCurrentFeedback_IL_LS_CS_mA; /*!< current feedback of interlock, connected to ADC input 5 */
407 
408 /** data block struct of sof limits */
409 typedef struct {
410  /* This struct needs to be at the beginning of every database entry. During
411  * the initialization of a database struct, uniqueId must be set to the
412  * respective database entry representation in enum DATA_BLOCK_ID_e. */
413  DATA_BLOCK_HEADER_s header; /*!< Data block header */
414  float recommendedContinuousPackChargeCurrent_mA; /*!< recommended continuous operating pack charge current */
415  float recommendedContinuousPackDischargeCurrent_mA; /*!< recommended continuous operating pack discharge current */
416  float recommendedPeakPackChargeCurrent_mA; /*!< recommended peak operating pack charge current */
417  float recommendedPeakPackDischargeCurrent_mA; /*!< recommended peak operating pack discharge current */
418  float recommendedContinuousChargeCurrent_mA
419  [BS_NR_OF_STRINGS]; /*!< recommended continuous operating charge current */
420  float recommendedContinuousDischargeCurrent_mA
421  [BS_NR_OF_STRINGS]; /*!< recommended continuous operating discharge current */
422  float recommendedPeakChargeCurrent_mA[BS_NR_OF_STRINGS]; /*!< recommended peak operating charge current */
423  float recommendedPeakDischargeCurrent_mA[BS_NR_OF_STRINGS]; /*!< recommended peak operating discharge current */
425 
426 /** data block struct of system state */
427 typedef struct {
428  /* This struct needs to be at the beginning of every database entry. During
429  * the initialization of a database struct, uniqueId must be set to the
430  * respective database entry representation in enum DATA_BLOCK_ID_e. */
431  DATA_BLOCK_HEADER_s header; /*!< Data block header */
432  int32_t bmsCanState; /*!< system state for CAN messages (e.g., standby, normal) */
434 
435 /** data block struct of the maximum safe limits */
436 typedef struct {
437  /* This struct needs to be at the beginning of every database entry. During
438  * the initialization of a database struct, uniqueId must be set to the
439  * respective database entry representation in enum DATA_BLOCK_ID_e. */
440  DATA_BLOCK_HEADER_s header; /*!< Data block header */
441  uint8_t packChargeOvercurrent; /*!< 0 -> MSL NOT violated, 1 -> MSL violated */
442  uint8_t packDischargeOvercurrent; /*!< 0 -> MSL NOT violated, 1 -> MSL violated */
443  uint8_t overVoltage[BS_NR_OF_STRINGS]; /*!< 0 -> MSL NOT violated, 1 -> MSL violated */
444  uint8_t underVoltage[BS_NR_OF_STRINGS]; /*!< 0 -> MSL NOT violated, 1 -> MSL violated */
445  uint8_t overtemperatureCharge[BS_NR_OF_STRINGS]; /*!< 0 -> MSL NOT violated, 1 -> MSL violated */
446  uint8_t overtemperatureDischarge[BS_NR_OF_STRINGS]; /*!< 0 -> MSL NOT violated, 1 -> MSL violated */
447  uint8_t undertemperatureCharge[BS_NR_OF_STRINGS]; /*!< 0 -> MSL NOT violated, 1 -> MSL violated */
448  uint8_t undertemperatureDischarge[BS_NR_OF_STRINGS]; /*!< 0 -> MSL NOT violated, 1 -> MSL violated */
449  uint8_t cellChargeOvercurrent[BS_NR_OF_STRINGS]; /*!< 0 -> MSL NOT violated, 1 -> MSL violated */
450  uint8_t stringChargeOvercurrent[BS_NR_OF_STRINGS]; /*!< 0 -> MSL NOT violated, 1 -> MSL violated */
451  uint8_t cellDischargeOvercurrent[BS_NR_OF_STRINGS]; /*!< 0 -> MSL NOT violated, 1 -> MSL violated */
452  uint8_t stringDischargeOvercurrent[BS_NR_OF_STRINGS]; /*!< 0 -> MSL NOT violated, 1 -> MSL violated */
453  uint8_t pcbOvertemperature[BS_NR_OF_STRINGS]; /*!< 0 -> MSL NOT violated, 1 -> MSL violated */
454  uint8_t pcbUndertemperature[BS_NR_OF_STRINGS]; /*!< 0 -> MSL NOT violated, 1 -> MSL violated */
456 
457 /** data block struct of the recommended safety limit */
458 typedef struct {
459  /* This struct needs to be at the beginning of every database entry. During
460  * the initialization of a database struct, uniqueId must be set to the
461  * respective database entry representation in enum DATA_BLOCK_ID_e. */
462  DATA_BLOCK_HEADER_s header; /*!< Data block header */
463  uint8_t overVoltage[BS_NR_OF_STRINGS]; /*!< 0 -> RSL NOT violated, 1 -> RSL violated */
464  uint8_t underVoltage[BS_NR_OF_STRINGS]; /*!< 0 -> RSL NOT violated, 1 -> RSL violated */
465  uint8_t overtemperatureCharge[BS_NR_OF_STRINGS]; /*!< 0 -> RSL NOT violated, 1 -> RSL violated */
466  uint8_t overtemperatureDischarge[BS_NR_OF_STRINGS]; /*!< 0 -> RSL NOT violated, 1 -> RSL violated */
467  uint8_t undertemperatureCharge[BS_NR_OF_STRINGS]; /*!< 0 -> RSL NOT violated, 1 -> RSL violated */
468  uint8_t undertemperatureDischarge[BS_NR_OF_STRINGS]; /*!< 0 -> RSL NOT violated, 1 -> RSL violated */
469  uint8_t cellChargeOvercurrent[BS_NR_OF_STRINGS]; /*!< 0 -> RSL NOT violated, 1 -> RSL violated */
470  uint8_t stringChargeOvercurrent[BS_NR_OF_STRINGS]; /*!< 0 -> RSL NOT violated, 1 -> RSL violated */
471  uint8_t cellDischargeOvercurrent[BS_NR_OF_STRINGS]; /*!< 0 -> RSL NOT violated, 1 -> RSL violated */
472  uint8_t stringDischargeOvercurrent[BS_NR_OF_STRINGS]; /*!< 0 -> RSL NOT violated, 1 -> RSL violated */
473  uint8_t pcbOvertemperature[BS_NR_OF_STRINGS]; /*!< 0 -> RSL NOT violated, 1 -> RSL violated */
474  uint8_t pcbUndertemperature[BS_NR_OF_STRINGS]; /*!< 0 -> RSL NOT violated, 1 -> RSL violated */
476 
477 /** data block struct of the maximum operating limit */
478 typedef struct {
479  /* This struct needs to be at the beginning of every database entry. During
480  * the initialization of a database struct, uniqueId must be set to the
481  * respective database entry representation in enum DATA_BLOCK_ID_e. */
482  DATA_BLOCK_HEADER_s header; /*!< Data block header */
483  uint8_t overVoltage[BS_NR_OF_STRINGS]; /*!< 0 -> MOL NOT violated, 1 -> MOL violated */
484  uint8_t underVoltage[BS_NR_OF_STRINGS]; /*!< 0 -> MOL NOT violated, 1 -> MOL violated */
485  uint8_t overtemperatureCharge[BS_NR_OF_STRINGS]; /*!< 0 -> MOL NOT violated, 1 -> MOL violated */
486  uint8_t overtemperatureDischarge[BS_NR_OF_STRINGS]; /*!< 0 -> MOL NOT violated, 1 -> MOL violated */
487  uint8_t undertemperatureCharge[BS_NR_OF_STRINGS]; /*!< 0 -> MOL NOT violated, 1 -> MOL violated */
488  uint8_t undertemperatureDischarge[BS_NR_OF_STRINGS]; /*!< 0 -> MOL NOT violated, 1 -> MOL violated */
489  uint8_t cellChargeOvercurrent[BS_NR_OF_STRINGS]; /*!< 0 -> MOL NOT violated, 1 -> MOL violated */
490  uint8_t stringChargeOvercurrent[BS_NR_OF_STRINGS]; /*!< 0 -> MOL NOT violated, 1 -> MOL violated */
491  uint8_t cellDischargeOvercurrent[BS_NR_OF_STRINGS]; /*!< 0 -> MOL NOT violated, 1 -> MOL violated */
492  uint8_t stringDischargeOvercurrent[BS_NR_OF_STRINGS]; /*!< 0 -> MOL NOT violated, 1 -> MOL violated */
493  uint8_t pcbOvertemperature[BS_NR_OF_STRINGS]; /*!< 0 -> MOL NOT violated, 1 -> MOL violated */
494  uint8_t pcbUndertemperature[BS_NR_OF_STRINGS]; /*!< 0 -> MOL NOT violated, 1 -> MOL violated */
496 
497 /** data block struct of sox */
498 typedef struct {
499  /* This struct needs to be at the beginning of every database entry. During
500  * the initialization of a database struct, uniqueId must be set to the
501  * respective database entry representation in enum DATA_BLOCK_ID_e. */
502  DATA_BLOCK_HEADER_s header; /*!< Data block header */
503  float averageSoc_perc[BS_NR_OF_STRINGS]; /*!< 0.0 <= averageSoc <= 100.0 */
504  float minimumSoc_perc[BS_NR_OF_STRINGS]; /*!< 0.0 <= minSoc <= 100.0 */
505  float maximumSoc_perc[BS_NR_OF_STRINGS]; /*!< 0.0 <= maxSoc <= 100.0 */
506  float averageSoe_perc[BS_NR_OF_STRINGS]; /*!< 0.0 <= averageSoe <= 100.0 */
507  float minimumSoe_perc[BS_NR_OF_STRINGS]; /*!< 0.0 <= minimumSoe <= 100.0 */
508  float maximumSoe_perc[BS_NR_OF_STRINGS]; /*!< 0.0 <= maximumSoe <= 100.0 */
509  float averageSoh_perc[BS_NR_OF_STRINGS]; /*!< 0.0 <= averageSoh <= 100.0 */
510  float minimumSoh_perc[BS_NR_OF_STRINGS]; /*!< 0.0 <= minimumSoh <= 100.0 */
511  float maximumSoh_perc[BS_NR_OF_STRINGS]; /*!< 0.0 <= maximumSoh <= 100.0 */
512  uint32_t maximumSoe_Wh[BS_NR_OF_STRINGS]; /*!< maximum string energy in Wh */
513  uint32_t averageSoe_Wh[BS_NR_OF_STRINGS]; /*!< average string energy in Wh */
514  uint32_t minimumSoe_Wh[BS_NR_OF_STRINGS]; /*!< minimum string energy in Wh */
516 
517 /** data block struct of can state request */
518 typedef struct {
519  /* This struct needs to be at the beginning of every database entry. During
520  * the initialization of a database struct, uniqueId must be set to the
521  * respective database entry representation in enum DATA_BLOCK_ID_e. */
522  DATA_BLOCK_HEADER_s header; /*!< Data block header */
523  uint8_t stateRequestViaCan; /*!< state request */
524  uint8_t previousStateRequestViaCan; /*!< previous state request */
525  uint8_t stateRequestViaCanPending; /*!< pending state request */
526  uint8_t stateCounter; /*!< counts state updates */
528 
529 /** data block struct of the moving average algorithm */
530 typedef struct {
531  /* This struct needs to be at the beginning of every database entry. During
532  * the initialization of a database struct, uniqueId must be set to the
533  * respective database entry representation in enum DATA_BLOCK_ID_e. */
534  DATA_BLOCK_HEADER_s header; /*!< Data block header */
535  float movingAverageCurrent1sInterval_mA; /*!< current moving average over the last 1s */
536  float movingAverageCurrent5sInterval_mA; /*!< current moving average over the last 5s */
537  float movingAverageCurrent10sInterval_mA; /*!< current moving average over the last 10s */
538  float movingAverageCurrent30sInterval_mA; /*!< current moving average over the last 30s */
539  float movingAverageCurrent60sInterval_mA; /*!< current moving average over the last 60s */
540  float movingAverageCurrentConfigurableInterval_mA; /*!< current moving average over the last configured time */
541  float movingAveragePower1sInterval_mA; /*!< power moving average over the last 1s */
542  float movingAveragePower5sInterval_mA; /*!< power moving average over the last 5s */
543  float movingAveragePower10sInterval_mA; /*!< power moving average over the last 10s */
544  float movingAveragePower30sInterval_mA; /*!< power moving average over the last 30s */
545  float movingAveragePower60sInterval_mA; /*!< power moving average over the last 60s */
546  float movingAveragePowerConfigurableInterval_mA; /*!< power moving average over the last configured time */
548 
549 /** data block struct of insulation monitoring device measurement */
550 typedef struct {
551  /* This struct needs to be at the beginning of every database entry. During
552  * the initialization of a database struct, uniqueId must be set to the
553  * respective database entry representation in enum DATA_BLOCK_ID_e. */
554  DATA_BLOCK_HEADER_s header; /*!< Data block header */
555  bool isImdRunning; /*!< true -> Insulation resistance measurement active, false -> not active */
556  bool isInsulationMeasurementValid; /*!< true -> resistance value valid, false -> resistance unreliable */
557  uint32_t insulationResistance_kOhm; /*!< insulation resistance measured in kOhm */
558  bool
559  areDeviceFlagsValid; /*!< true -> flags below this database entry valid, false -> flags unreliable e.g. if device error detected */
560  bool
561  dfIsCriticalResistanceDetected; /*!< device status flag: false -> resistance value okay, true -> resistance value too low/error */
562  bool dfIsWarnableResistanceDetected; /*!< true: warning threshold violated, false: no warning active */
563  bool dfIsChassisFaultDetected; /*!< true: short between HV potential and chassis detected, false: no error */
564  bool dfIsChassisShortToHvPlus; /*!< true: bias/tendency to the location of the insulation fault to HV plus */
565  bool dfIsChassisShortToHvMinus; /*!< true: bias/tendency to the location of the insulation fault to HV minus */
566  bool dfIsDeviceErrorDetected; /*!< true: device error detected, false: no error detected */
567  bool dfIsMeasurmentedUpToDate; /*!< true: measurement up to-date, false: outdated */
569 
570 /** data block struct for the I2C humidity/temperature sensor */
571 typedef struct {
572  /* This struct needs to be at the beginning of every database entry. During
573  * the initialization of a database struct, uniqueId must be set to the
574  * respective database entry representation in enum DATA_BLOCK_ID_e. */
575  DATA_BLOCK_HEADER_s header; /*!< Data block header */
577  uint8_t humidity_perc;
579 
580 /** data block struct of internal ADC voltage measurement */
581 typedef struct {
582  /* This struct needs to be at the beginning of every database entry. During
583  * the initialization of a database struct, uniqueId must be set to the
584  * respective database entry representation in enum DATA_BLOCK_ID_e. */
585  DATA_BLOCK_HEADER_s header; /*!< Data block header */
586  float adc1ConvertedVoltages_mV[MCU_ADC1_MAX_NR_CHANNELS]; /*!< voltages measured by the internal ADC ADC1 */
588 
589 /** data block struct for the database built-in self-test */
590 typedef struct {
591  /* This struct needs to be at the beginning of every database entry. During
592  * the initialization of a database struct, uniqueId must be set to the
593  * respective database entry representation in enum DATA_BLOCK_ID_e. */
594  DATA_BLOCK_HEADER_s header; /*!< Data block header */
595  uint8_t member1; /*!< first member of self-test struct */
596  uint8_t member2; /*!< second member of self-test struct */
598 
599 /** array for the database */
601 
602 /*========== Extern Constant and Variable Declarations ======================*/
603 
604 /*========== Extern Function Prototypes =====================================*/
605 
606 /*========== Externalized Static Functions Prototypes (Unit Test) ===========*/
607 
608 #endif /* FOXBMS__DATABASE_CFG_H_ */
Configuration of the battery system (e.g., number of battery modules, battery cells,...
#define BS_NR_OF_VOLTAGES_FROM_CURRENT_SENSOR
number of high voltage inputs measured by current sensors (like IVT-MOD)
#define BS_NR_OF_CELL_BLOCKS_PER_MODULE
number of cells per module
#define BS_NR_OF_STRINGS
Number of parallel strings in the battery pack.
#define BS_NR_OF_GPIOS_PER_MODULE
Number of GPIOs on the LTC IC.
#define BS_NR_OF_CELL_BLOCKS_PER_STRING
#define BS_NR_OF_MODULES_PER_STRING
number of modules in a string
#define BS_NR_OF_TEMP_SENSORS_PER_STRING
DATA_BLOCK_ID_e
Definition: database_cfg.h:75
@ DATA_BLOCK_ID_CELL_VOLTAGE_REDUNDANCY0
Definition: database_cfg.h:99
@ DATA_BLOCK_ID_OPEN_WIRE_REDUNDANCY0
Definition: database_cfg.h:103
@ DATA_BLOCK_ID_INTERLOCK_FEEDBACK
Definition: database_cfg.h:88
@ DATA_BLOCK_ID_BALANCING_CONTROL
Definition: database_cfg.h:80
@ DATA_BLOCK_ID_MIN_MAX
Definition: database_cfg.h:78
@ DATA_BLOCK_ID_ALL_GPIO_VOLTAGES_REDUNDANCY0
Definition: database_cfg.h:102
@ DATA_BLOCK_ID_USER_MUX
Definition: database_cfg.h:83
@ DATA_BLOCK_ID_SOX
Definition: database_cfg.h:94
@ DATA_BLOCK_ID_DUMMY_FOR_SELF_TEST
Definition: database_cfg.h:108
@ DATA_BLOCK_ID_RSL_FLAG
Definition: database_cfg.h:92
@ DATA_BLOCK_ID_INSULATION_MONITORING
Definition: database_cfg.h:104
@ DATA_BLOCK_ID_CELL_VOLTAGE
Definition: database_cfg.h:76
@ DATA_BLOCK_ID_MOVING_AVERAGE
Definition: database_cfg.h:96
@ DATA_BLOCK_ID_CELL_TEMPERATURE_REDUNDANCY0
Definition: database_cfg.h:100
@ DATA_BLOCK_ID_CELL_TEMPERATURE_BASE
Definition: database_cfg.h:98
@ DATA_BLOCK_ID_CURRENT_SENSOR
Definition: database_cfg.h:79
@ DATA_BLOCK_ID_MAX
Definition: database_cfg.h:109
@ DATA_BLOCK_ID_SYSTEMSTATE
Definition: database_cfg.h:90
@ DATA_BLOCK_ID_OPEN_WIRE_BASE
Definition: database_cfg.h:84
@ DATA_BLOCK_ID_SLAVE_CONTROL
Definition: database_cfg.h:81
@ DATA_BLOCK_ID_CONTACTOR_FEEDBACK
Definition: database_cfg.h:87
@ DATA_BLOCK_ID_SOF
Definition: database_cfg.h:89
@ DATA_BLOCK_ID_ADC_VOLTAGE
Definition: database_cfg.h:107
@ DATA_BLOCK_ID_CELL_VOLTAGE_BASE
Definition: database_cfg.h:97
@ DATA_BLOCK_ID_MSL_FLAG
Definition: database_cfg.h:91
@ DATA_BLOCK_ID_ERRORSTATE
Definition: database_cfg.h:86
@ DATA_BLOCK_ID_HTSEN
Definition: database_cfg.h:106
@ DATA_BLOCK_ID_ALL_GPIO_VOLTAGES_BASE
Definition: database_cfg.h:85
@ DATA_BLOCK_ID_PACK_VALUES
Definition: database_cfg.h:105
@ DATA_BLOCK_ID_BALANCING_FEEDBACK_BASE
Definition: database_cfg.h:82
@ DATA_BLOCK_ID_MOL_FLAG
Definition: database_cfg.h:93
@ DATA_BLOCK_ID_BALANCING_FEEDBACK_REDUNDANCY0
Definition: database_cfg.h:101
@ DATA_BLOCK_ID_CELL_TEMPERATURE
Definition: database_cfg.h:77
@ DATA_BLOCK_ID_STATEREQUEST
Definition: database_cfg.h:95
DATA_BASE_s data_database[DATA_BLOCK_ID_MAX]
channel configuration of database (data blocks)
Definition: database_cfg.c:177
FAS_STATIC_ASSERT((int16_t) DATA_BLOCK_ID_MAX< UINT8_MAX, "Maximum number of database entries exceeds UINT8_MAX; adapted length " "checking in DATA_Initialize and DATA_IterateOverDatabaseEntries")
General macros and definitions for the whole platform.
Headers for the driver for the MCU module.
#define MCU_ADC1_MAX_NR_CHANNELS
maximum number of channels measured by the ADC1
Definition: mcu.h:76
uint32_t dataLength
Definition: database_cfg.h:71
void * pDatabaseEntry
Definition: database_cfg.h:70
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:585
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:315
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:247
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:282
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:146
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:129
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:391
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:211
uint8_t baseCellVoltageMeasurementTimeout
Definition: database_cfg.h:341
uint8_t redundancy0CellVoltageMeasurementTimeout
Definition: database_cfg.h:342
uint8_t baseCellTemperatureMeasurementTimeout
Definition: database_cfg.h:343
uint8_t redundancy0CellTemperatureMeasurementTimeout
Definition: database_cfg.h:344
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:329
uint32_t previousTimestamp
Definition: database_cfg.h:121
DATA_BLOCK_ID_e uniqueId
Definition: database_cfg.h:119
int16_t temperature_ddegC
Definition: database_cfg.h:576
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:575
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:400
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:159
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:482
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:534
float movingAverageCurrentConfigurableInterval_mA
Definition: database_cfg.h:540
float movingAveragePowerConfigurableInterval_mA
Definition: database_cfg.h:546
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:440
uint8_t packDischargeOvercurrent
Definition: database_cfg.h:442
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:302
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:187
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:462
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:263
float recommendedPeakPackChargeCurrent_mA
Definition: database_cfg.h:416
float recommendedPeakPackDischargeCurrent_mA
Definition: database_cfg.h:417
float recommendedContinuousPackChargeCurrent_mA
Definition: database_cfg.h:414
float recommendedContinuousPackDischargeCurrent_mA
Definition: database_cfg.h:415
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:413
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:502
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:522
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:431
DATA_BLOCK_HEADER_s header
Definition: database_cfg.h:292