foxBMS
1.3.0
The foxBMS Battery Management System API Documentation
|
Driver for the MAX17841B ASCI and MAX1785x monitoring chip. More...
#include "mxm_1785x.h"
#include "afe_plausibility.h"
#include "database.h"
#include "diag.h"
#include "mxm_1785x_tools.h"
#include "mxm_battery_management.h"
#include "mxm_registry.h"
#include "os.h"
#include "tsi.h"
Go to the source code of this file.
Macros | |
#define | MXM_OFFSET_CELL_1 (0u) |
#define | MXM_OFFSET_CELL_2 (1u) |
#define | MXM_OFFSET_CELL_3 (2u) |
#define | MXM_OFFSET_CELL_4 (3u) |
#define | MXM_OFFSET_CELL_5 (4u) |
#define | MXM_OFFSET_CELL_6 (5u) |
#define | MXM_OFFSET_CELL_7 (6u) |
#define | MXM_OFFSET_CELL_8 (7u) |
#define | MXM_OFFSET_CELL_9 (8u) |
#define | MXM_OFFSET_CELL_10 (9u) |
#define | MXM_OFFSET_CELL_11 (10u) |
#define | MXM_OFFSET_CELL_12 (11u) |
#define | MXM_OFFSET_CELL_13 (12u) |
#define | MXM_OFFSET_CELL_14 (13u) |
#define | MXM_OFFSET_AUX0 (0u) |
#define | MXM_OFFSET_AUX2 (2u) |
#define | MXM_OFFSET_AUX3 (3u) |
#define | MXM_OFFSET_BLOCK (0u) |
#define | MXM_MAXIMUM_ERROR_COUNT (10u) |
#define | MXM_TIMEOUT_RESET_ERROR_COUNTER_ms (500) |
#define | MXM_TEST_BUFFER_MAXIMUM_LENGTH (120u) |
#define | MXM_REF_VAA_mV (3300u) |
VAA reference voltage (3.3V) More... | |
Functions | |
static void | MXM_GetDataFrom5XStateMachine (MXM_MONITORING_INSTANCE_s *pInstance) |
Retrieves data from lower statemachine and writes it to the rx buffer. More... | |
static void | MXM_ParseVoltageLineReadall (const uint8_t *const kpkVoltRxBuffer, uint16_t voltRxBufferLength, uint8_t measurementOffset, MXM_CONVERSION_TYPE_e conversionType, uint16_t *pVoltagesTarget, MXM_MEASURE_TYPE_e measurementType, uint32_t fullScaleReference_mV) |
Parse voltage values from a READALL receive buffer into an array. More... | |
static STD_RETURN_TYPE_e | MXM_ParseVoltageReadall (const uint8_t *const kpkVoltageRxBuffer, uint16_t voltageRxBufferLength, MXM_DATA_STORAGE_s *datastorage, MXM_CONVERSION_TYPE_e conversionType) |
Parse a RX buffer containing voltage values. More... | |
static STD_RETURN_TYPE_e must_check_return | MXM_ParseVoltageReadallTest (MXM_MONITORING_INSTANCE_s *pInstance) |
Test the MXM_ParseVoltageReadall()-function. More... | |
void | MXM_CheckIfErrorCounterCanBeReset (MXM_MONITORING_INSTANCE_s *pInstance) |
Function that checks if the error counter can be reset. More... | |
void | MXM_ErrorHandlerReset (MXM_MONITORING_INSTANCE_s *pInstance, bool immediateReset) |
This error handler is used as a last resort and tries a reset of the complete driver. More... | |
void | MXM_HandleStateWriteall (MXM_MONITORING_INSTANCE_s *pInstance, MXM_STATEMACHINE_OPERATION_STATES_e nextState) |
Handle the statemachine-transactions for a WRITEALL. More... | |
bool must_check_return | MXM_HandleStateReadall (MXM_MONITORING_INSTANCE_s *pInstance, MXM_REG_NAME_e registerName, MXM_STATEMACHINE_OPERATION_STATES_e nextState) |
Handle the statemachine-transactions for a READALL. More... | |
STD_RETURN_TYPE_e | MXM_ProcessOpenWire (const MXM_MONITORING_INSTANCE_s *const kpkInstance) |
Processes the retrieved information on openwire. More... | |
STD_RETURN_TYPE_e | MXM_ConstructBalancingBuffer (MXM_BALANCING_STATE_s *pBalancingInstance) |
Fill the balancing datastructure. More... | |
STD_RETURN_TYPE_e | MXM_ParseVoltagesIntoDB (const MXM_MONITORING_INSTANCE_s *const kpkInstance) |
Copies measured voltage data into the database. More... | |
void | MXM_InitializeStateStruct (MXM_BALANCING_STATE_s *pBalancingInstance, MXM_MONITORING_INSTANCE_s *pMonitoringInstance) |
Initializes the state structs with default values. More... | |
STD_RETURN_TYPE_e | MXM_PreInitSelfCheck (MXM_MONITORING_INSTANCE_s *pState) |
Execute all preinit selfchecks. More... | |
MXM_MONITORING_STATE_e must_check_return | MXM_MonGetVoltages (MXM_MONITORING_INSTANCE_s *pState, MXM_REG_NAME_e regAddress) |
Encapsulation for reading voltages from a register. More... | |
void | MXM_StateMachine (MXM_MONITORING_INSTANCE_s *pInstance) |
Main state-machine implementation. More... | |
Variables | |
static const AFE_PLAUSIBILITY_VALUES_s | mxm_plausibleCellVoltages |
Driver for the MAX17841B ASCI and MAX1785x monitoring chip.
SPDX-License-Identifier: BSD-3-Clause
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
We kindly request you to use one or more of the following phrases to refer to foxBMS in your hardware, software, documentation or advertising materials:
This file contains the main-state-machine that drives the monitoring ICs of the MAX1785x family by Maxim Integrated.
Definition in file mxm_1785x.c.
#define MXM_MAXIMUM_ERROR_COUNT (10u) |
maximum number of errors that may occur before the next error triggers a reset
Definition at line 92 of file mxm_1785x.c.
#define MXM_OFFSET_AUX0 (0u) |
storage offset for AUX0
Definition at line 86 of file mxm_1785x.c.
#define MXM_OFFSET_AUX2 (2u) |
storage offset for AUX2
Definition at line 87 of file mxm_1785x.c.
#define MXM_OFFSET_AUX3 (3u) |
storage offset for AUX3
Definition at line 88 of file mxm_1785x.c.
#define MXM_OFFSET_BLOCK (0u) |
storage offset for block voltage
Definition at line 89 of file mxm_1785x.c.
#define MXM_OFFSET_CELL_1 (0u) |
storage offset for cell 1
Definition at line 72 of file mxm_1785x.c.
#define MXM_OFFSET_CELL_10 (9u) |
storage offset for cell 10
Definition at line 81 of file mxm_1785x.c.
#define MXM_OFFSET_CELL_11 (10u) |
storage offset for cell 11
Definition at line 82 of file mxm_1785x.c.
#define MXM_OFFSET_CELL_12 (11u) |
storage offset for cell 12
Definition at line 83 of file mxm_1785x.c.
#define MXM_OFFSET_CELL_13 (12u) |
storage offset for cell 13
Definition at line 84 of file mxm_1785x.c.
#define MXM_OFFSET_CELL_14 (13u) |
storage offset for cell 14
Definition at line 85 of file mxm_1785x.c.
#define MXM_OFFSET_CELL_2 (1u) |
storage offset for cell 2
Definition at line 73 of file mxm_1785x.c.
#define MXM_OFFSET_CELL_3 (2u) |
storage offset for cell 3
Definition at line 74 of file mxm_1785x.c.
#define MXM_OFFSET_CELL_4 (3u) |
storage offset for cell 4
Definition at line 75 of file mxm_1785x.c.
#define MXM_OFFSET_CELL_5 (4u) |
storage offset for cell 5
Definition at line 76 of file mxm_1785x.c.
#define MXM_OFFSET_CELL_6 (5u) |
storage offset for cell 6
Definition at line 77 of file mxm_1785x.c.
#define MXM_OFFSET_CELL_7 (6u) |
storage offset for cell 7
Definition at line 78 of file mxm_1785x.c.
#define MXM_OFFSET_CELL_8 (7u) |
storage offset for cell 8
Definition at line 79 of file mxm_1785x.c.
#define MXM_OFFSET_CELL_9 (8u) |
storage offset for cell 9
Definition at line 80 of file mxm_1785x.c.
#define MXM_REF_VAA_mV (3300u) |
VAA reference voltage (3.3V)
Definition at line 108 of file mxm_1785x.c.
#define MXM_TEST_BUFFER_MAXIMUM_LENGTH (120u) |
maximum length of a test buffer
Definition at line 98 of file mxm_1785x.c.
#define MXM_TIMEOUT_RESET_ERROR_COUNTER_ms (500) |
timeout after which the error counter will be reset
Definition at line 95 of file mxm_1785x.c.
void MXM_CheckIfErrorCounterCanBeReset | ( | MXM_MONITORING_INSTANCE_s * | pInstance | ) |
Function that checks if the error counter can be reset.
[in,out] | pInstance | pointer to the state struct |
Definition at line 888 of file mxm_1785x.c.
STD_RETURN_TYPE_e MXM_ConstructBalancingBuffer | ( | MXM_BALANCING_STATE_s * | pBalancingInstance | ) |
Fill the balancing datastructure.
This function fills the data-structure that describes which balancing channels of the monitoring ICs should be activated.
[in,out] | pBalancingInstance | pointer to the balancing state |
Definition at line 1016 of file mxm_1785x.c.
void MXM_ErrorHandlerReset | ( | MXM_MONITORING_INSTANCE_s * | pInstance, |
bool | immediateReset | ||
) |
This error handler is used as a last resort and tries a reset of the complete driver.
A reset is done by setting the relevant flag in the state struct and waiting for the reset to occur (done by AFE on next tick). Before this last resort measure is taken, a error counter has to be counted up.
[in,out] | pInstance | pointer to the state struct in order to write the reset flag |
[in] | immediateReset | if set to true, a reset will be requested independently of the error counter |
Definition at line 901 of file mxm_1785x.c.
|
static |
Retrieves data from lower statemachine and writes it to the rx buffer.
Definition at line 191 of file mxm_1785x.c.
bool must_check_return MXM_HandleStateReadall | ( | MXM_MONITORING_INSTANCE_s * | pInstance, |
MXM_REG_NAME_e | registerName, | ||
MXM_STATEMACHINE_OPERATION_STATES_e | nextState | ||
) |
Handle the statemachine-transactions for a READALL.
Call this function and pass on the state-variable, the register to be read and the next state. The function will handle the communication with the lower state-machine and will transition into the next state, if the command has been sent successfully. Moreover it will return true when transitioning. The return value has to be checked and used to execute additional code if necessary.
[in,out] | pInstance | pointer to instance of the mxm monitoring state-machine |
[in] | registerName | register that should be read |
[in] | nextState | state that should be entered upon successful completion |
Definition at line 940 of file mxm_1785x.c.
void MXM_HandleStateWriteall | ( | MXM_MONITORING_INSTANCE_s * | pInstance, |
MXM_STATEMACHINE_OPERATION_STATES_e | nextState | ||
) |
Handle the statemachine-transactions for a WRITEALL.
Before calling this function, update the command buffer of the state-variable. Then call this function and pass on the state-variable and the next state. The function will handle the communication with the lower state-machine and will transition into the next state, if the command has been sent successfully.
[in,out] | pInstance | pointer to instance of the mxm monitoring state-machine |
[in] | nextState | state that should be entered upon successful completion |
Definition at line 912 of file mxm_1785x.c.
void MXM_InitializeStateStruct | ( | MXM_BALANCING_STATE_s * | pBalancingInstance, |
MXM_MONITORING_INSTANCE_s * | pMonitoringInstance | ||
) |
Initializes the state structs with default values.
This function is called through the startup of the driver in order to ensure proper default values.
[out] | pBalancingInstance | instance of the balancing state struct that shall be initialized |
[out] | pMonitoringInstance | instance of the monitoring state struct that shall be initialized |
Definition at line 1164 of file mxm_1785x.c.
MXM_MONITORING_STATE_e must_check_return MXM_MonGetVoltages | ( | MXM_MONITORING_INSTANCE_s * | pState, |
MXM_REG_NAME_e | regAddress | ||
) |
Encapsulation for reading voltages from a register.
This function encapsulates the request of state-changes and following conversion for the reading of an arbitrary measurement voltage of the daisy-chain. Its parameters are a variable for tracking the state of the underlying state-machines and the register address that has to be queried. It returns whether the action has been successful or not. In order to obtain all cell voltages this function has to be called for every relevant register address.
[in,out] | pState | pointer to the state-machine struct |
[in] | regAddress | register address that shall be queried |
Definition at line 1275 of file mxm_1785x.c.
|
static |
Parse voltage values from a READALL receive buffer into an array.
This function expects a preprocessed RX buffer with an answer to a READALL command. It will parse the data bytes from this message into an array structured like mxm_local_cellvoltages. The offset of the measured cell has to be defined. For example cell 1 has an offset of 0 and cell 4 has an offset of 3. The offset for the READALL command is always defined in reference to module 0.
If is_temperature_measurement is set to true, the function expects an auxiliary measurement (e.g. temperatures).
[in] | kpkVoltRxBuffer | array-pointer to the RX buffer |
[in] | voltRxBufferLength | length of the RX buffer |
[in] | measurementOffset | offset of the data in the cell voltage array (target) |
[in] | conversionType | type of conversion that has been used for the measured data |
[out] | pVoltagesTarget | array-pointer to the cell voltages array |
[in] | measurementType | whether the measurement is temperature or cell |
[in] | fullScaleReference_mV | reference voltage of full scale |
Definition at line 199 of file mxm_1785x.c.
|
static |
Parse a RX buffer containing voltage values.
This function parses a RX buffer containing the answer to a READALL command. It will check whether the message contains a READALL command and whether a supported register has been queried. Depending on the queried register, it will pass the proper parameters to MXM_ParseVoltageLineReadall(). The contained data from this message will be parsed into a struct structured like MXM_MONITORING_INSTANCE_s::localVoltages.
[in] | kpkVoltageRxBuffer | array-pointer to the RX buffer |
[in] | voltageRxBufferLength | length of the RX buffer |
[out] | datastorage | contains all measured voltages for local consumption in the module |
[in] | conversionType | type of conversion that has been used for the measured data |
Definition at line 270 of file mxm_1785x.c.
|
static |
Test the MXM_ParseVoltageReadall()-function.
Test the function MXM_ParseVoltageReadall() by passing predefined RX buffer to it and checking the outcome. This function writes to the variable MXM_MONITORING_INSTANCE_s::localVoltages and nulls it completely after execution. It is intended as a self-check that can be performed during startup of the driver.
Definition at line 485 of file mxm_1785x.c.
STD_RETURN_TYPE_e MXM_ParseVoltagesIntoDB | ( | const MXM_MONITORING_INSTANCE_s *const | kpkInstance | ) |
Copies measured voltage data into the database.
This function copies the acquired voltage data from MXM_MONITORING_INSTANCE_s::localVoltages into the database-struct mxm_tableCellVoltages and copies this struct into the database. This action is required due to different data layouts. This driver always stores its cell-voltages in an array with 14*32 = 448 cells in order to reduce the amount of different configurations and variants.
This function maps these values into the database-struct which scales with the number of connected cells and monitoring ICs.
[in] | kpkInstance | pointer to the MXM_MONITORING_INSTANCE_s struct |
< invalid configuration!
Definition at line 1075 of file mxm_1785x.c.
STD_RETURN_TYPE_e MXM_PreInitSelfCheck | ( | MXM_MONITORING_INSTANCE_s * | pState | ) |
Execute all preinit selfchecks.
Executes the following self-checks:
These self-checks do not need an initialized daisy-chain and can therefore be executed at startup of the state-machine.
After execution of each test, the return value is stored in the supplied state-struct. The function returns whether the self-check has successfully passed.
[in,out] | pState | pointer to the state-struct, will write status into |
Definition at line 1237 of file mxm_1785x.c.
STD_RETURN_TYPE_e MXM_ProcessOpenWire | ( | const MXM_MONITORING_INSTANCE_s *const | kpkInstance | ) |
Processes the retrieved information on openwire.
Parses through a retrieved RX buffer and writes into the database.
[in,out] | kpkInstance | pointer to instance of the Maxim monitoring state-machine |
Definition at line 971 of file mxm_1785x.c.
void MXM_StateMachine | ( | MXM_MONITORING_INSTANCE_s * | pInstance | ) |
Main state-machine implementation.
This state-machine handles the main state of the driver. It runs the self-check, initializes communication and then transitions into the operation state in which it executes the state-machine described in MXM_StateMachineOperation().
[in,out] | pInstance | used as both input and output (stores state-information, requests and intermediate values) |
Definition at line 1314 of file mxm_1785x.c.
|
static |
local definition of plausible cell voltage values
Definition at line 101 of file mxm_1785x.c.