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

226 lines
7.2 KiB
C
Raw Normal View History

2024-11-26 15:52:49 +08:00
/******************************************************************************
* @file drv_adbms1818.h
* @brief LT6820-ADBMS1818<EFBFBD>ջ<EFBFBD><EFBFBD><EFBFBD>оƬ<EFBFBD>ɼ<EFBFBD>
* @version V1.0
* @author Gary 2024-11-13
* @copyright
******************************************************************************/
#ifndef DRV_ADBMS1818_H_
#define DRV_ADBMS1818_H_
#ifdef __cplusplus
extern "C"
{
#endif
#include "stdlib.h"
#include "kit_data.h"
#include "drv_misc.h"
#include "drv_spi.h"
#include "kit_time.h"
#include "gpio_manager.h"
2025-02-06 15:08:48 +08:00
//#define cs_low() drv_gpio_set_pin_status(kGpioType_SP1_Cs_En1, kGpioStatus_Low); // Set Cs Signal
//#define cs_high() drv_gpio_set_pin_status(kGpioType_SP1_Cs_En1, kGpioStatus_High) // Set Cs Signal
#define cs_low() drv_gpio_set_pin_status(kGpioType_SP1_Cs_En2, kGpioStatus_Low); // Set Cs Signal
#define cs_high() drv_gpio_set_pin_status(kGpioType_SP1_Cs_En2, kGpioStatus_High) // Set Cs Signal
#define cs_low_reverse() drv_gpio_set_pin_status(kGpioType_SP1_Cs_En2, kGpioStatus_Low); // Set Cs Signal
#define cs_high_reverse() drv_gpio_set_pin_status(kGpioType_SP1_Cs_En2, kGpioStatus_High);// Set Cs Signal
2024-11-26 15:52:49 +08:00
#define IC_ADBMS1818
#define MD_422HZ_1KHZ 0
#define MD_27KHZ_14KHZ 1
#define MD_7KHZ_3KHZ 2
#define MD_26HZ_2KHZ 3
#define ADC_OPT_ENABLED 1
#define ADC_OPT_DISABLED 0
#define CELL_CH_ALL 0
#define CELL_CH_1and7 1
#define CELL_CH_2and8 2
#define CELL_CH_3and9 3
#define CELL_CH_4and10 4
#define CELL_CH_5and11 5
#define CELL_CH_6and12 6s
#define SELFTEST_1 1
#define SELFTEST_2 2
#define AUX_CH_ALL 0
#define AUX_CH_GPIO1 1
#define AUX_CH_GPIO2 2
#define AUX_CH_GPIO3 3
#define AUX_CH_GPIO4 4
#define AUX_CH_GPIO5 5
#define AUX_CH_VREF2 6
#define STAT_CH_ALL 0
#define STAT_CH_SOC 1
#define STAT_CH_ITEMP 2
#define STAT_CH_VREGA 3
#define STAT_CH_VREGD 4
#define REG_ALL 0
#define REG_1 1
#define REG_2 2
#define REG_3 3
#define REG_4 4
#define REG_5 5
#define REG_6 6
#define DCP_DISABLED 0
#define DCP_ENABLED 1
#define PULL_UP_CURRENT 1
#define PULL_DOWN_CURRENT 0
#define NUM_RX_BYT 8
#define CELL 1
#define AUX 2
#define STAT 3
#define CFGR 0
#define CFGRB 4
#define CS_PIN 10
typedef struct
{
uint8_t tx_data[6]; //!< Stores data to be transmitted
uint8_t rx_data[8]; //!< Stores received data
uint8_t rx_pec_match; //!< If a PEC error was detected during most recent read cmd
} ic_register;
typedef struct
{
uint16_t c_codes[18]; //!< Cell Voltage Codes
uint8_t pec_match[6]; //!< If a PEC error was detected during most recent read cmd
} cv;
/*! AUX Reg Voltage Data structure */
typedef struct
{
uint16_t a_codes[9]; //!< Aux Voltage Codes
uint8_t pec_match[4]; //!< If a PEC error was detected during most recent read cmd
} ax;
/*! Status Reg data structure. */
typedef struct
{
uint16_t stat_codes[4]; //!< Status codes.
uint8_t flags[3]; //!< Byte array that contains the uv/ov flag data
uint8_t mux_fail[1]; //!< Mux self test status flag
uint8_t thsd[1]; //!< Thermal shutdown status
uint8_t pec_match[2]; //!< If a PEC error was detected during most recent read cmd
} st;
/*! PEC error counter structure. */
typedef struct
{
uint16_t pec_count; //!< Overall PEC error count
uint16_t cfgr_pec; //!< Configuration register data PEC error count
uint16_t cell_pec[6]; //!< Cell voltage register data PEC error count
uint16_t aux_pec[4]; //!< Aux register data PEC error count
uint16_t stat_pec[2]; //!< Status register data PEC error count
} pec_counter;
/*! Register configuration structure */
typedef struct
{
uint8_t cell_channels; //!< Number of Cell channels
uint8_t stat_channels; //!< Number of Stat channels
uint8_t aux_channels; //!< Number of Aux channels
uint8_t num_cv_reg; //!< Number of Cell voltage register
uint8_t num_gpio_reg; //!< Number of Aux register
uint8_t num_stat_reg; //!< Number of Status register
} register_cfg;
/*! Cell variable structure */
typedef struct
{
ic_register config;
ic_register configb;
cv cells;
ax aux;
st stat;
ic_register com;
ic_register pwm;
ic_register pwmb;
ic_register sctrl;
ic_register sctrlb;
uint8_t sid[6];
bool isospi_reverse;
pec_counter crc_count;
register_cfg ic_reg;
long system_open_wire;
} cell_asic;
void wakeup_sleep(uint8_t total_ic);
void wakeup_idle(uint8_t total_ic);
void write_68(uint8_t total_ic, // Number of ICs to be written to
uint8_t tx_cmd[2], // The command to be transmitted
uint8_t data[] // Payload Data
);
void spi_write_read(uint8_t tx_Data[], // array of data to be written on SPI port
uint8_t tx_len, // length of the tx data arry
uint8_t *rx_data, // Input: array that will store the data read by the SPI port
uint8_t rx_len // Option: number of bytes to be read from the SPI port
);
/* Write the ADBMS181x CFGRA */
void ADBMS1818_wrcfg(uint8_t total_ic, // The number of ICs being written to
cell_asic ic[] // A two dimensional array of the configuration data that will be written
);
/* Write the ADBMS181x CFGRB */
void ADBMS1818_wrcfgb(uint8_t total_ic, // The number of ICs being written to
cell_asic ic[] // A two dimensional array of the configuration data that will be written
);
/* Read the ADBMS181x CFGA */
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 the ADBMS181x CFGB */
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 ADC conversion for cell voltage */
void ADBMS1818_adcv(uint8_t MD, // ADC Mode
uint8_t DCP, // Discharge Permit
uint8_t CH // Cell Channels to be measured
);
/* This function will block operation until the ADC has finished it's conversion */
uint32_t ADBMS1818_pollAdc(void);
/*
Reads and parses the ADBMS181x cell voltage registers.
The function is used to read the parsed Cell voltages codes of the ADBMS181x.
This function will send the requested read commands parse the data
and store the cell voltages in c_codes variable.
*/
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 system
cell_asic *ic // Array of the parsed cell codes
);
/* Start ADC Conversion for GPIO and Vref2 */
void ADBMS1818_adax(uint8_t MD, // ADC Mode
uint8_t CHG // GPIO Channels to be measured
);
int8_t ADBMS1818_rdaux(uint8_t reg, // Determines which GPIO voltage register is read back.
uint8_t total_ic, // The number of ICs in the system
cell_asic *ic // A two dimensional array of the gpio voltage codes.
);
#ifdef __cplusplusS
}
#endif
#endif