forked from gary/BCU
2
0
Fork 0
BCU/library/drv_peripheral/ADBMS1818/ADBMS1818.h

638 lines
22 KiB
C
Raw Normal View History

2024-11-26 15:52:49 +08:00
/*! ADBMS1818: Multicell Battery Monitors
*
*@verbatim
*The ADBMS1818 is multi-cell battery stack monitor that measures up to 18 series
*connected battery cells with a total measurement error of less than 2.2mV.
*The cell measurement range of 0V to 5V makes the ADBMS1818 suitable for most
*battery chemistries. All 18 cell voltages can be captured in 290uS, and lower
*data acquisition rates can be selected for high noise reduction.
*Using the ADBMS1818, multiple devices are connected in a daisy-chain with one
*host processor connection for all devices, permitting simultaneous cell monitoring
*of long, high voltage battery strings.
*@endverbatim
*
* https://www.analog.com/en/products/ADBMS1818.html /TBD
* https://www.analog.com/en/design-center/evaluation-hardware-and-software/evaluation-boards-kits/EVAL-ADBMS1818.html /TBD
*
*********************************************************************************
* Copyright 2019(c) Analog Devices, Inc.
*
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
* - Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* - Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
* - Neither the name of Analog Devices, Inc. nor the names of its
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
* - The use of this software may or may not infringe the patent rights
* of one or more patent holders. This license does not release you
* from the requirement that you obtain separate licenses from these
* patent holders to use this software.
* - Use of the software either in source or binary form, must be run
* on or directly connected to an Analog Devices Inc. component.
*
* THIS SOFTWARE IS PROVIDED BY ANALOG DEVICES "AS IS" AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, NON-INFRINGEMENT,
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL ANALOG DEVICES BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, INTELLECTUAL PROPERTY RIGHTS, 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.
*******************************************************************************/
/*! @file
@ingroup ADBMS1818
Header for ADBMS1818 Multicell Battery Monitor
*/
#ifndef ADBMS1818_H
#define ADBMS1818_H
#include "stdint.h"
#include "ADBMS181x.h"
#define CELL 1
#define AUX 2
#define STAT 3
/*!
Helper function to initialize register limits
@return void
*/
void ADBMS1818_init_reg_limits(uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Write the ADBMS1818 configuration register A
@return void
*/
void ADBMS1818_wrcfg(uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array of the configuration data that will be written
);
/*!
Write the ADBMS1818 configuration register B
@return void
*/
void ADBMS1818_wrcfgb(uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array of the configuration data that will be written
);
/*!
Reads configuration register A of a ADBMS1818 daisy chain
@return int8_t, PEC Status.
0: Data read back has matching PEC
-1: Data read back has incorrect PEC
*/
int8_t ADBMS1818_rdcfg(uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array that the function stores the read configuration data
);
/*!
Reads configuration register B of a ADBMS1818 daisy chain
@return int8_t, pec_error PEC Status.
0: Data read back has matching PEC
-1: Data read back has incorrect PEC
*/
int8_t ADBMS1818_rdcfgb(uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array that the function stores the read configuration data
);
/*!
Starts cell voltage conversion
@return void
*/
void ADBMS1818_adcv(uint8_t MD, //!< ADC Conversion Mode
uint8_t DCP, //!< Controls if Discharge is permitted during conversion
uint8_t CH //!< Sets which Cell channels are converted
);
/*!
Start a GPIO and Vref2 Conversion
@return void
*/
void ADBMS1818_adax(uint8_t MD, //!< ADC Conversion Mode
uint8_t CHG //!< Sets which GPIO channels are converted
);
/*!
Start a Status ADC Conversion
@return void
*/
void ADBMS1818_adstat( uint8_t MD, //!< ADC Conversion Mode
uint8_t CHST //!< Sets which Stat channels are converted
);
/*!
Starts cell voltage and GPIO 1 & 2 conversion
@return void
*/
void ADBMS1818_adcvax(uint8_t MD, //!< ADC Conversion Mode
uint8_t DCP //!< Controls if Discharge is permitted during conversion
);
/*! Starts cell voltage and Sum of cells conversion
@return void
*/
void ADBMS1818_adcvsc(uint8_t MD, //!< ADC Conversion Mode
uint8_t DCP //!< Controls if Discharge is permitted during conversion
);
/*!
Reads and parses the ADBMS1818 cell voltage registers.
@return uint8_t, pec_error PEC Status.
0: No PEC error detected
-1: PEC error detected, retry read
*/
uint8_t ADBMS1818_rdcv(uint8_t reg, //!< Controls which cell voltage register is read back.
uint8_t total_ic, //!< The number of ICs in the daisy chain
cell_asic *ic //!< Array of the parsed cell codes from lowest to highest.
);
/*! Reads and parses the ADBMS1818 auxiliary registers.
@return int8_t, pec_error PEC Status
0: No PEC error detected
-1: PEC error detected, retry read
*/
int8_t ADBMS1818_rdaux(uint8_t reg, //!< Controls which GPIO voltage register is read back
uint8_t nIC, //!< The number of ICs in the daisy chain
cell_asic *ic //!< A two dimensional array of the parsed gpio voltage codes
);
/*!
Reads and parses the ADBMS1818 stat registers.
@return int8_t, pec_error PEC Status
0: No PEC error detected
-1: PEC error detected, retry read
*/
int8_t ADBMS1818_rdstat(uint8_t reg, //!< Determines which Stat register is read back.
uint8_t total_ic,//!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Sends the poll ADC command
@returns 1 byte read back after a pladc command. If the byte is not 0xFF ADC conversion has completed
*/
uint8_t ADBMS1818_pladc();
/*!
This function will block operation until the ADC has finished it's conversion
@returns uint32_t, counter The approximate time it took for the ADC function to complete.
*/
uint32_t ADBMS1818_pollAdc();
/*!
Clears the ADBMS1818 cell voltage registers
@return void
*/
void ADBMS1818_clrcell();
/*!
Clears the ADBMS1818 Auxiliary registers
@return void
*/
void ADBMS1818_clraux();
/*!
Clears the ADBMS1818 Stat registers
@return void
*/
void ADBMS1818_clrstat();
/*!
Starts the Mux Decoder diagnostic self test
Running this command will start the Mux Decoder Diagnostic Self Test
This test takes roughly 1mS to complete. The MUXFAIL bit will be updated,
the bit will be set to 1 for a failure and 0 if the test has been passed.
@return void
*/
void ADBMS1818_diagn();
/*!
Starts cell voltage self test conversion
@return void
*/
void ADBMS1818_cvst(uint8_t MD, //!< ADC Conversion Mode
uint8_t ST //!< Self Test Mode
);
/*!
Start an Auxiliary Register Self Test Conversion
@return void
*/
void ADBMS1818_axst(uint8_t MD, //!< ADC Conversion Mode
uint8_t ST //!< Sets if self test 1 or 2 is run
);
/*!
Start a Status Register Self Test Conversion
@return void
*/
void ADBMS1818_statst(uint8_t MD, //!< ADC Conversion Mode
uint8_t ST //!< Sets if self test 1 or 2 is run
);
/*!
Starts cell voltage overlap conversion
@return void
*/
void ADBMS1818_adol(uint8_t MD, //!< ADC Conversion Mode
uint8_t DCP //!< Discharge permitted during conversion
);
/*!
Start an GPIO Redundancy test
@return void
*/
void ADBMS1818_adaxd(uint8_t MD, //!< ADC Conversion Mode
uint8_t CHG //!< Sets which GPIO channels are converted
);
/*!
Start a Status register redundancy test Conversion
@return void
*/
void ADBMS1818_adstatd(uint8_t MD, //!< ADC Mode
uint8_t CHST //!< Sets which Status channels are converted
);
/*!
Helper function that runs the ADC Self Tests
@return int16_t, error Number of errors detected.
*/
int16_t ADBMS1818_run_cell_adc_st(uint8_t adc_reg, //!< Type of register
uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic, //!< A two dimensional array that will store the data
uint8_t md, //!< ADC Mode
bool adcopt //!< The adcopt bit in the configuration register
);
/*!
Helper Function that runs the ADC Overlap test
@return uint16_t, error
0: Pass
-1: False, Error detected
*/
uint16_t ADBMS1818_run_adc_overlap(uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Helper function that runs the ADC Digital Redundancy commands and checks output for errors
@return int16_t, error Number of errors detected.
*/
int16_t ADBMS1818_run_adc_redundancy_st(uint8_t adc_mode, //!< ADC Mode
uint8_t adc_reg, //!< Type of register
uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Start an open wire Conversion
@return void
*/
void ADBMS1818_adow(uint8_t MD, //!< ADC Conversion Mode
uint8_t PUP,//!< Pull up/Pull down current
uint8_t CH, //!< Sets which Cell channels are converted
uint8_t DCP //!< Discharge permitted during conversion
);
/*!
Start GPIOs open wire ADC conversion
@return void
*/
void ADBMS1818_axow(uint8_t MD, //!< ADC Mode
uint8_t PUP //!< Pull up/Pull down current
);
/*!
Helper function that runs the data sheet algorithm for open wire for single cell detection
@return void
*/
void ADBMS1818_run_openwire_single(uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Helper function that runs open wire for multiple cell and two consecutive cells detection
@return void
*/
void ADBMS1818_run_openwire_multi(uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Runs open wire for GPIOs
@return void
*/
void ADBMS1818_run_gpio_openwire(uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Helper Function to Set DCC bits in the CFGR Registers
@return void
*/
void ADBMS1818_set_discharge(int Cell, //!< The cell to be discharged
uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Helper Function to clear DCC bits in the CFGR Registers
@return void
*/
void ADBMS1818_clear_discharge(uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Write the ADBMS1818 PWM register
@return void
*/
void ADBMS1818_wrpwm(uint8_t total_ic, //!< Number of ICs in the daisy chain
uint8_t pwmReg, //!< PWM Register A or B
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Reads pwm registers of a ADBMS1818 daisy chain
@return int8_t, pec_error PEC Status.
0: Data read back has matching PEC
-1: Data read back has incorrect PEC
*/
int8_t ADBMS1818_rdpwm(uint8_t total_ic, //!< Number of ICs in the daisy chain
uint8_t pwmReg, //!< PWM Register A or B
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Write the ADBMS1818 Sctrl register
@return void
*/
void ADBMS1818_wrsctrl(uint8_t nIC, //!< Number of ICs in the daisy chain
uint8_t sctrl_reg,//! SCTRL Register A or B
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Reads sctrl registers of a ADBMS1818 daisy chain
@return int8_t, pec_error PEC Status.
0: Data read back has matching PEC
-1: Data read back has incorrect PEC
*/
int8_t ADBMS1818_rdsctrl(uint8_t nIC, //!< Number of ICs in the daisy chain
uint8_t sctrl_reg,//!< SCTRL Register A or B
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Start Sctrl data communication
This command will start the sctrl pulse communication over the spins
@return void
*/
void ADBMS1818_stsctrl();
/*!
Clears the ADBMS1818 Sctrl registers
@return void
*/
void ADBMS1818_clrsctrl();
/*!
Write the 6813 PWM/Sctrl Register B
@return void
*/
void ADBMS1818_wrpsb(uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Reading pwm/s control register B
@return uint8_t, pec_error PEC Status.
0: Data read back has matching PEC
-1: Data read back has incorrect PEC
*/
uint8_t ADBMS1818_rdpsb(uint8_t total_ic, //!< Number of ICs in the daisy chain
cell_asic *ic //!< A two dimensional array that the function stores the read data
);
/*!
Write the ADBMS1818 COMM register
@return void
*/
void ADBMS1818_wrcomm(uint8_t total_ic, //!< Number of ICs in the daisy chain
cell_asic *ic //!< A two dimensional array of the comm data that will be written
);
/*!
Reads comm registers of a ADBMS1818 daisy chain
@return int8_t, pec_error PEC Status.
0: Data read back has matching PEC
-1: Data read back has incorrect PEC
*/
int8_t ADBMS1818_rdcomm(uint8_t total_ic, //!< Number of ICs in the daisy chain
cell_asic *ic //!< Two dimensional array that the function stores the read comm data.
);
/*!
Issues a stcomm command and clocks data out of the COMM register
@return void
*/
void ADBMS1818_stcomm(uint8_t len //!< Length of data to be transmitted
);
/*!
Mutes the ADBMS1818 discharge transistors
@return void
*/
void ADBMS1818_mute();
/*!
Clears the ADBMS1818 Mute Discharge
@return void
*/
void ADBMS1818_unmute();
/*!
Helper Function that counts overall PEC errors and register/IC PEC errors
@return void
*/
void ADBMS1818_check_pec(uint8_t total_ic, //!< Number of ICs in the system
uint8_t reg, //!< Type of register
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Helper Function that resets the PEC error counters
@return void
*/
void ADBMS1818_reset_crc_count(uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Helper Function to initialize the CFGR data structures
@return void
*/
void ADBMS1818_init_cfg(uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Helper function to set appropriate bits in CFGR register based on bit function
@return void
*/
void ADBMS1818_set_cfgr(uint8_t nIC, //!< The number of ICs in the daisy chain
cell_asic *ic, //!< A two dimensional array that will store the data
bool refon, //!< The REFON bit
bool adcopt, //!< The ADCOPT bit
bool gpio[5], //!< The GPIO bits
bool dcc[12], //!< The DCC bits
bool dcto[4], //!< The Dcto bits
uint16_t uv, //!< The UV value
uint16_t ov //!< The OV value
);
/*!
Helper function to turn the REFON bit HIGH or LOW
@return void
*/
void ADBMS1818_set_cfgr_refon(uint8_t nIC, //!< The number of ICs in the daisy chain
cell_asic *ic, //!< A two dimensional array that will store the data
bool refon //!< The REFON bit
);
/*!
Helper function to turn the ADCOPT bit HIGH or LOW
@return void
*/
void ADBMS1818_set_cfgr_adcopt(uint8_t nIC, //!< The number of ICs in the daisy chain
cell_asic *ic, //!< A two dimensional array that will store the data
bool adcopt //!< The ADCOPT bit
);
/*!
Helper function to turn the GPIO bits HIGH or LOW
@return void
*/
void ADBMS1818_set_cfgr_gpio(uint8_t nIC, //!< The number of ICs in the daisy chain
cell_asic *ic, //!< A two dimensional array that will store the data
bool gpio[] //!< The GPIO bits
);
/*!
Helper function to turn the DCC bits HIGH or LOW
@return void
*/
void ADBMS1818_set_cfgr_dis(uint8_t nIC, //!< The number of ICs in the daisy chain
cell_asic *ic, //!< A two dimensional array that will store the data
bool dcc[] //!< The DCC bits
);
/*!
Helper function to set UV field in CFGRA register
@return void
*/
void ADBMS1818_set_cfgr_uv(uint8_t nIC, //!< The number of ICs in the daisy chain
cell_asic *ic, //!< A two dimensional array that will store the data
uint16_t uv //!< The UV value
);
/*!
Helper function to set DCTO field in CFGRA register
@return void
*/
void ADBMS1818_set_cfgr_dcto(uint8_t nIC, //!< The number of ICs in the daisy chain
cell_asic *ic, //!< A two dimensional array that will store the data
bool dcto[4] //!< The Dcto bits
);
/*!
Helper function to set OV field in CFGRA register
@return void
*/
void ADBMS1818_set_cfgr_ov(uint8_t nIC, //!< The number of ICs in the daisy chain
cell_asic *ic, //!< A two dimensional array that will store the data
uint16_t ov //!< The OV value
);
/*!
Helper Function to initialize the CFGR B data structures
@return void
*/
void ADBMS1818_init_cfgb(uint8_t total_ic, //!< Number of ICs in the system
cell_asic *ic //!< A two dimensional array that will store the data
);
/*!
Helper function to set appropriate bits in CFGR register based on bit function
@return void
*/
void ADBMS1818_set_cfgrb(uint8_t nIC, //!< The number of ICs in the daisy chain
cell_asic *ic, //!< A two dimensional array that will store the data
bool fdrf, //!< The FDRF bit
bool dtmen, //!< The DTMEN bit
bool ps[2], //!< Path selection bits
bool gpiobits[4], //!< The GPIO bits
bool dccbits[7] //!< The DCC bits
);
/*!
Helper function to turn the FDRF bit HIGH or LOW
@return void
*/
void ADBMS1818_set_cfgrb_fdrf(uint8_t nIC, //!< The number of ICs in the daisy chain
cell_asic *ic, //!< A two dimensional array that will store the data
bool fdrf //!< The FDRF bit
);
/*!
Helper function to turn the DTMEN bit HIGH or LOW
@return void
*/
void ADBMS1818_set_cfgrb_dtmen(uint8_t nIC, //!< The number of ICs in the daisy chain
cell_asic *ic, //!< A two dimensional array that will store the data
bool dtmen //!< The DTMEN bit
);
/*!
Helper function to turn the Path Select bit HIGH or LOW
@return void
*/
void ADBMS1818_set_cfgrb_ps(uint8_t nIC, //!< The number of ICs in the daisy chain
cell_asic *ic, //!< A two dimensional array that will store the data
bool ps[] //!< Path selection bits
);
/*!
Helper function to turn the GPIO bit HIGH or LOW
@return void
*/
void ADBMS1818_set_cfgrb_gpio_b(uint8_t nIC, //!< The number of ICs in the daisy chain
cell_asic *ic, //!< A two dimensional array that will store the data
bool gpiobits[] //!< The GPIO bits
);
/*!
Helper function to turn the DCC bit HIGH or LOW
@return void
*/
void ADBMS1818_set_cfgrb_dcc_b(uint8_t nIC, //!< The number of ICs in The daisy chain
cell_asic *ic, //!< A two dimensional array that will store The data
bool dccbits[] //!< The DCC bits
);
#endif