51
0

File dump from Analog

This commit is contained in:
2023-12-06 21:11:03 +01:00
commit 6ed0ac8f6d
1188 changed files with 1326858 additions and 0 deletions

View File

@ -0,0 +1,94 @@
/*******************************************************************************
Copyright (c) 2020 - Analog Devices Inc. All Rights Reserved.
This software is proprietary & confidential to Analog Devices, Inc.
and its licensor.
******************************************************************************
* @file: adBms_Application.h
* @brief: Bms application header file
* @version: $Revision$
* @date: $Date$
* Developed by: ADIBMS Software team, Bangalore, India
*****************************************************************************/
/*! @addtogroup APPLICATION
* @{
*
*/
/*! @addtogroup APPLICATION
* @{
*
*/
#ifndef __APPLICATION_H
#define __APPLICATION_H
#include <stdint.h>
#include "adbms_main.h"
void app_main(void);
void run_command(int cmd);
void adBms6830_init_config(uint8_t tIC, cell_asic *ic);
void adBms6830_write_read_config(uint8_t tIC, cell_asic *ic);
void adBms6830_read_config(uint8_t tIC, cell_asic *ic);
void adBms6830_start_adc_cell_voltage_measurment(uint8_t tIC);
void adBms6830_read_cell_voltages(uint8_t tIC, cell_asic *ic);
void adBms6830_start_adc_s_voltage_measurment(uint8_t tIC);
void adBms6830_read_s_voltages(uint8_t tIC, cell_asic *ic);
void adBms6830_start_avgcell_voltage_measurment(uint8_t tIC);
void adBms6830_read_avgcell_voltages(uint8_t tIC, cell_asic *ic);
void adBms6830_start_fcell_voltage_measurment(uint8_t tIC);
void adBms6830_read_fcell_voltages(uint8_t tIC, cell_asic *ic);
void adBms6830_start_aux_voltage_measurment(uint8_t tIC, cell_asic *ic);
void adBms6830_read_aux_voltages(uint8_t tIC, cell_asic *ic);
void adBms6830_start_raux_voltage_measurment(uint8_t tIC, cell_asic *ic);
void adBms6830_read_raux_voltages(uint8_t tIC, cell_asic *ic);
void adBms6830_read_status_registers(uint8_t tIC, cell_asic *ic);
void measurement_loop(void);
void adBms6830_read_device_sid(uint8_t tIC, cell_asic *ic);
void adBms6830_set_reset_gpio_pins(uint8_t tIC, cell_asic *ic);
void adBms6830_enable_mute(uint8_t tIC, cell_asic *ic);
void adBms6830_disable_mute(uint8_t tIC, cell_asic *ic);
void adBms6830_soft_reset(uint8_t tIC);
void adBms6830_reset_cmd_count(uint8_t tIC);
void adBms6830_reset_pec_error_flag(uint8_t tIC, cell_asic *ic);
void adBms6830_snap(uint8_t tIC);
void adBms6830_unsnap(uint8_t tIC);
void adBms6830_clear_cell_measurement(uint8_t tIC);
void adBms6830_clear_aux_measurement(uint8_t tIC);
void adBms6830_clear_spin_measurement(uint8_t tIC);
void adBms6830_clear_fcell_measurement(uint8_t tIC);
void adBms6830_clear_ovuv_measurement(uint8_t tIC);
void adBms6830_clear_all_flags(uint8_t tIC, cell_asic *ic);
void adBms6830_set_dcc_discharge(uint8_t tIC, cell_asic *ic);
void adBms6830_clear_dcc_discharge(uint8_t tIC, cell_asic *ic);
void adBms6830_write_read_pwm_duty_cycle(uint8_t tIC, cell_asic *ic);
void adBms6830_gpio_spi_communication(uint8_t tIC, cell_asic *ic);
void adBms6830_gpio_i2c_write_to_slave(uint8_t tIC, cell_asic *ic);
void adBms6830_gpio_i2c_read_from_slave(uint8_t tIC, cell_asic *ic);
void adBms6830_set_dtrng_dcto_value(uint8_t tIC, cell_asic *ic);
void adBms6830_run_osc_mismatch_self_test(uint8_t tIC, cell_asic *ic);
void adBms6830_run_thermal_shutdown_self_test(uint8_t tIC, cell_asic *ic);
void adBms6830_run_supply_error_detection_self_test(uint8_t tIC, cell_asic *ic);
void adBms6830_run_thermal_shutdown_self_test(uint8_t tIC, cell_asic *ic);
void adBms6830_run_fuse_ed_self_test(uint8_t tIC, cell_asic *ic);
void adBms6830_run_fuse_med_self_test(uint8_t tIC, cell_asic *ic);
void adBms6830_run_tmodchk_self_test(uint8_t tIC, cell_asic *ic);
void adBms6830_check_latent_fault_csflt_status_bits(uint8_t tIC, cell_asic *ic);
void adBms6830_check_rdstatc_err_bit_functionality(uint8_t tIC, cell_asic *ic);
void adBms6830_cell_openwire_test(uint8_t tIC, cell_asic *ic);
void adBms6830_redundant_cell_openwire_test(uint8_t tIC, cell_asic *ic);
void adBms6830_cell_ow_volatge_collect(uint8_t tIC, cell_asic *ic, TYPE type, OW_C_S ow_c_s);
void adBms6830_aux_openwire_test(uint8_t tIC, cell_asic *ic);
void adBms6830_gpio_pup_up_down_volatge_collect(uint8_t tIC, cell_asic *ic, PUP pup);
void adBms6830_open_wire_detection_condtion_check(uint8_t tIC, cell_asic *ic, TYPE type);
void adBms6830_read_rdcvall_voltage(uint8_t tIC, cell_asic *ic);
void adBms6830_read_rdacall_voltage(uint8_t tIC, cell_asic *ic);
void adBms6830_read_rdsall_voltage(uint8_t tIC, cell_asic *ic);
void adBms6830_read_rdfcall_voltage(uint8_t tIC, cell_asic *ic);
void adBms6830_read_rdcsall_voltage(uint8_t tIC, cell_asic *ic);
void adBms6830_read_rdacsall_voltage(uint8_t tIC, cell_asic *ic);
void adBms6830_read_rdasall_voltage(uint8_t tIC, cell_asic *ic);
#endif
/** @}*/
/** @}*/

View File

@ -0,0 +1,36 @@
/*******************************************************************************
Copyright (c) 2020 - Analog Devices Inc. All Rights Reserved.
This software is proprietary & confidential to Analog Devices, Inc.
and its licensor.
******************************************************************************
* @file: adbms_main.h
* @brief: adbms main Heade file
* @version: $Revision$
* @date: $Date$
* Developed by: ADIBMS Software team, Bangalore, India
*****************************************************************************/
/** @addtogroup MAIN
* @{
*
*/
/** @addtogroup ADBMS_MAIN MAIN
* @{
*
*/
#ifndef _ADBMS6830_MAIN_H
#define _ADBMS6830_MAIN_H
#include "main.h"
#include "common.h"
#include "adBms6830Data.h"
#include "adBms6830GenericType.h"
#include "adBms6830ParseCreate.h"
#include "mcuWrapper.h"
void adbms_main(void);
#endif
/** @}*/
/** @}*/

View File

@ -0,0 +1,29 @@
/*******************************************************************************
Copyright (c) 2020 - Analog Devices Inc. All Rights Reserved.
This software is proprietary & confidential to Analog Devices, Inc.
and its licensor.
******************************************************************************
* @file: common.h
* @brief: Standard common header files
* @version: $Revision$
* @date: $Date$
* Developed by: ADIBMS Software team, Bangalore, India
*****************************************************************************/
#ifndef __COMMON_H_
#define __COMMON_H_
#include <stdio.h>
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
#include <stdbool.h>
//#define MBED /* Switch between IAR Workbench or Mbed Studio. */
#ifdef MBED
#include "mbed.h"
#include "SPI.h"
#include "Timer.h"
#endif
#endif

View File

@ -0,0 +1,69 @@
/*******************************************************************************
Copyright (c) 2020 - Analog Devices Inc. All Rights Reserved.
This software is proprietary & confidential to Analog Devices, Inc.
and its licensor.
******************************************************************************
* @file: mcuWrapper.h
* @brief: Generic wrapper header file
* @version: $Revision$
* @date: $Date$
* Developed by: ADIBMS Software team, Bangalore, India
*****************************************************************************/
/** @addtogroup MUC_DRIVER
* @{
*
*/
/** @addtogroup SPI_DRIVER SPI DRIVER
* @{
*
*/
#ifndef __ADBMSWRAPPER_H
#define __ADBMSWRAPPER_H
#include "common.h"
#ifdef MBED
#else
#include "main.h"
#include "stm32f4xx_hal.h"
#include "stm32f4xx_hal_tim.h"
#include "stm32f4xx_it.h"
extern ADC_HandleTypeDef hadc1; /* Mcu dependent ADC handler */
extern I2C_HandleTypeDef hi2c1; /* Mcu dependent I2C handler */
extern I2C_HandleTypeDef hi2c3; /* Mcu dependent I2C handler */
extern SPI_HandleTypeDef hspi1; /* Mcu dependent SPI handler */
extern SPI_HandleTypeDef hspi5; /* Mcu dependent SPI handler */
extern UART_HandleTypeDef huart4; /* Mcu dependent UART handler */
extern UART_HandleTypeDef huart5; /* Mcu dependent UART handler */
extern TIM_HandleTypeDef htim2; /* Mcu dependent TIM handler */
extern TIM_HandleTypeDef htim5; /* Mcu dependent TIM handler */
#define CS_PIN ARDUINO_GPIO10_Pin /* Mcu dependent chip select */
#define GPIO_PORT ARDUINO_GPIO10_GPIO_Port /* Mcu dependent adc chip select port */
#endif
void Delay_ms(uint32_t delay);
void adBmsCsLow(void);
void adBmsCsHigh(void);
void spiWriteBytes
(
uint16_t size, /*Option: Number of bytes to be written on the SPI port*/
uint8_t *tx_Data /*Array of bytes to be written on the SPI port*/
);
void spiWriteReadBytes
(
uint8_t *tx_data, /*array of data to be written on SPI port*/
uint8_t *rx_data, /*Input: array that will store the data read by the SPI port*/
uint16_t size /*Option: number of bytes*/
);
void spiReadBytes(uint16_t size, uint8_t *rx_data);
void startTimer(void);
void stopTimer(void);
uint32_t getTimCount(void);
void adBmsWakeupIc(uint8_t total_ic);
#endif
/** @}*/
/** @}*/

View File

@ -0,0 +1,46 @@
/*******************************************************************************
Copyright (c) 2020 - Analog Devices Inc. All Rights Reserved.
This software is proprietary & confidential to Analog Devices, Inc.
and its licensor.
******************************************************************************
* @file: serialPrintResult.h
* @brief: Print IO terminal functions
* @version: $Revision$
* @date: $Date$
* Developed by: ADIBMS Software team, Bangalore, India
*****************************************************************************/
/*! @addtogroup RESULT_PRINT
* @{
*
*/
/*! @addtogroup RESULT PRINT I/O
* @{
*
*/
#ifndef __RESULT_H
#define __RESULT_H
#include "adbms_main.h"
void printWriteConfig(uint8_t tIC, cell_asic *IC, TYPE type, GRP grp);
void printReadConfig(uint8_t tIC, cell_asic *IC, TYPE type, GRP grp);
void printVoltages(uint8_t tIC, cell_asic *IC, TYPE type);
void printStatus(uint8_t tIC, cell_asic *IC, TYPE type, GRP grp);
void printDeviceSID(uint8_t tIC, cell_asic *IC, TYPE type);
void printWritePwmDutyCycle(uint8_t tIC, cell_asic *IC, TYPE type, GRP grp);
void printReadPwmDutyCycle(uint8_t tIC, cell_asic *IC, TYPE type, GRP grp);
void printWriteCommData(uint8_t tIC, cell_asic *IC, TYPE type);
void printReadCommData(uint8_t tIC, cell_asic *IC, TYPE type);
void printDiagnosticTestResult(uint8_t tIC, cell_asic *IC, DIAGNOSTIC_TYPE type);
void diagnosticTestResultPrint(uint8_t result);
void printOpenWireTestResult(uint8_t tIC, cell_asic *IC, TYPE type);
void openWireResultPrint(uint8_t result);
float getVoltage(int data);
void printPollAdcConvTime(int count);
void printMenu();
#endif
/** @}*/
/** @}*/

View File

@ -0,0 +1,656 @@
/*******************************************************************************
Copyright (c) 2020 - Analog Devices Inc. All Rights Reserved.
This software is proprietary & confidential to Analog Devices, Inc.
and its licensor.
******************************************************************************
* @file: adbms_Application.c
* @brief: adbms application test cases
* @version: $Revision$
* @date: $Date$
* Developed by: ADIBMS Software team, Bangalore, India
*****************************************************************************/
/*! \addtogroup APPLICATION
* @{
*/
/*! @addtogroup Application
* @{
*/
#include "common.h"
#include "adBms_Application.h"
#include "adBms6830CmdList.h"
#include "adBms6830GenericType.h"
#include "serialPrintResult.h"
#include "mcuWrapper.h"
#ifdef MBED
extern Serial pc;
#endif
/**
*******************************************************************************
* @brief Setup Variables
* The following variables can be modified to configure the software.
*******************************************************************************
*/
#define TOTAL_IC 1
cell_asic IC[TOTAL_IC];
/* ADC Command Configurations */
RD REDUNDANT_MEASUREMENT = RD_OFF;
CH AUX_CH_TO_CONVERT = AUX_ALL;
CONT CONTINUOUS_MEASUREMENT = SINGLE;
OW_C_S CELL_OPEN_WIRE_DETECTION = OW_OFF_ALL_CH;
OW_AUX AUX_OPEN_WIRE_DETECTION = AUX_OW_OFF;
PUP OPEN_WIRE_CURRENT_SOURCE = PUP_DOWN;
DCP DISCHARGE_PERMITTED = DCP_OFF;
RSTF RESET_FILTER = RSTF_OFF;
ERR INJECT_ERR_SPI_READ = WITHOUT_ERR;
/* Set Under Voltage and Over Voltage Thresholds */
const float OV_THRESHOLD = 4.2; /* Volt */
const float UV_THRESHOLD = 3.0; /* Volt */
const int OWC_Threshold = 2000; /* Cell Open wire threshold(mili volt) */
const int OWA_Threshold = 50000; /* Aux Open wire threshold(mili volt) */
const uint32_t LOOP_MEASUREMENT_COUNT = 1; /* Loop measurment count */
const uint16_t MEASUREMENT_LOOP_TIME = 10; /* milliseconds(mS)*/
uint32_t loop_count = 0;
uint32_t pladc_count;
/*Loop Measurement Setup These Variables are ENABLED or DISABLED Remember ALL CAPS*/
LOOP_MEASURMENT MEASURE_CELL = ENABLED; /* This is ENABLED or DISABLED */
LOOP_MEASURMENT MEASURE_AVG_CELL = ENABLED; /* This is ENABLED or DISABLED */
LOOP_MEASURMENT MEASURE_F_CELL = ENABLED; /* This is ENABLED or DISABLED */
LOOP_MEASURMENT MEASURE_S_VOLTAGE = ENABLED; /* This is ENABLED or DISABLED */
LOOP_MEASURMENT MEASURE_AUX = DISABLED; /* This is ENABLED or DISABLED */
LOOP_MEASURMENT MEASURE_RAUX = DISABLED; /* This is ENABLED or DISABLED */
LOOP_MEASURMENT MEASURE_STAT = DISABLED; /* This is ENABLED or DISABLED */
void adbms_main()
{
printMenu();
adBms6830_init_config(TOTAL_IC, &IC[0]);
while(1)
{
int user_command;
#ifdef MBED
pc.scanf("%d", &user_command);
pc.printf("Enter cmd:%d\n", user_command);
#else
scanf("%d", &user_command);
printf("Enter cmd:%d\n", user_command);
#endif
run_command(user_command);
}
}
void run_command(int cmd)
{
switch(cmd)
{
case 1:
adBms6830_write_read_config(TOTAL_IC, &IC[0]);
break;
case 2:
adBms6830_read_config(TOTAL_IC, &IC[0]);
break;
case 3:
adBms6830_start_adc_cell_voltage_measurment(TOTAL_IC);
break;
case 4:
adBms6830_read_cell_voltages(TOTAL_IC, &IC[0]);
break;
case 5:
adBms6830_start_adc_s_voltage_measurment(TOTAL_IC);
break;
case 6:
adBms6830_read_s_voltages(TOTAL_IC, &IC[0]);
break;
case 7:
adBms6830_start_avgcell_voltage_measurment(TOTAL_IC);
break;
case 8:
adBms6830_read_avgcell_voltages(TOTAL_IC, &IC[0]);
break;
case 9:
adBms6830_start_fcell_voltage_measurment(TOTAL_IC);
break;
case 10:
adBms6830_read_fcell_voltages(TOTAL_IC, &IC[0]);
break;
case 11:
adBms6830_start_aux_voltage_measurment(TOTAL_IC, &IC[0]);
break;
case 12:
adBms6830_read_aux_voltages(TOTAL_IC, &IC[0]);
break;
case 13:
adBms6830_start_raux_voltage_measurment(TOTAL_IC, &IC[0]);
break;
case 14:
adBms6830_read_raux_voltages(TOTAL_IC, &IC[0]);
break;
case 15:
adBms6830_read_status_registers(TOTAL_IC, &IC[0]);
break;
case 16:
loop_count = 0;
adBmsWakeupIc(TOTAL_IC);
adBmsWriteData(TOTAL_IC, &IC[0], WRCFGA, Config, A);
adBmsWriteData(TOTAL_IC, &IC[0], WRCFGB, Config, B);
adBmsWakeupIc(TOTAL_IC);
adBms6830_Adcv(REDUNDANT_MEASUREMENT, CONTINUOUS, DISCHARGE_PERMITTED, RESET_FILTER, CELL_OPEN_WIRE_DETECTION);
Delay_ms(1); // ADCs are updated at their conversion rate is 1ms
adBms6830_Adcv(RD_ON, CONTINUOUS, DISCHARGE_PERMITTED, RESET_FILTER, CELL_OPEN_WIRE_DETECTION);
Delay_ms(1); // ADCs are updated at their conversion rate is 1ms
adBms6830_Adsv(CONTINUOUS, DISCHARGE_PERMITTED, CELL_OPEN_WIRE_DETECTION);
Delay_ms(8); // ADCs are updated at their conversion rate is 8ms
while(loop_count < LOOP_MEASUREMENT_COUNT)
{
measurement_loop();
Delay_ms(MEASUREMENT_LOOP_TIME);
loop_count = loop_count + 1;
}
printMenu();
break;
case 17:
adBms6830_clear_cell_measurement(TOTAL_IC);
break;
case 18:
adBms6830_clear_aux_measurement(TOTAL_IC);
break;
case 19:
adBms6830_clear_spin_measurement(TOTAL_IC);
break;
case 20:
adBms6830_clear_fcell_measurement(TOTAL_IC);
break;
case 0:
printMenu();
break;
default:
#ifdef MBED
pc.printf("Incorrect Option\n\n");
#else
printf("Incorrect Option\n\n");
#endif
break;
}
}
/**
*******************************************************************************
* @brief Set configuration register A. Refer to the data sheet
* Set configuration register B. Refer to the data sheet
*******************************************************************************
*/
void adBms6830_init_config(uint8_t tIC, cell_asic *ic)
{
for(uint8_t cic = 0; cic < tIC; cic++)
{
/* Init config A */
ic[cic].tx_cfga.refon = PWR_UP;
// ic[cic].cfga.cth = CVT_8_1mV;
// ic[cic].cfga.flag_d = ConfigA_Flag(FLAG_D0, FLAG_SET) | ConfigA_Flag(FLAG_D1, FLAG_SET);
// ic[cic].cfga.gpo = ConfigA_Gpo(GPO2, GPO_SET) | ConfigA_Gpo(GPO10, GPO_SET);
ic[cic].tx_cfga.gpo = 0X3FF; /* All GPIO pull down off */
// ic[cic].cfga.soakon = SOAKON_CLR;
// ic[cic].cfga.fc = IIR_FPA256;
/* Init config B */
// ic[cic].cfgb.dtmen = DTMEN_ON;
ic[cic].tx_cfgb.vov = SetOverVoltageThreshold(OV_THRESHOLD);
ic[cic].tx_cfgb.vuv = SetUnderVoltageThreshold(UV_THRESHOLD);
// ic[cic].cfgb.dcc = ConfigB_DccBit(DCC16, DCC_BIT_SET);
// SetConfigB_DischargeTimeOutValue(tIC, &ic[cic], RANG_0_TO_63_MIN, TIME_1MIN_OR_0_26HR);
}
adBmsWakeupIc(tIC);
adBmsWriteData(tIC, &ic[0], WRCFGA, Config, A);
adBmsWriteData(tIC, &ic[0], WRCFGB, Config, B);
}
/**
*******************************************************************************
* @brief Write and Read Configuration Register A/B
*******************************************************************************
*/
void adBms6830_write_read_config(uint8_t tIC, cell_asic *ic)
{
adBmsWakeupIc(tIC);
adBmsWriteData(tIC, &ic[0], WRCFGA, Config, A);
adBmsWriteData(tIC, &ic[0], WRCFGB, Config, B);
adBmsReadData(tIC, &ic[0], RDCFGA, Config, A);
adBmsReadData(tIC, &ic[0], RDCFGB, Config, B);
printWriteConfig(tIC, &ic[0], Config, ALL_GRP);
printReadConfig(tIC, &ic[0], Config, ALL_GRP);
}
/**
*******************************************************************************
* @brief Read Configuration Register A/B
*******************************************************************************
*/
void adBms6830_read_config(uint8_t tIC, cell_asic *ic)
{
adBmsWakeupIc(tIC);
adBmsReadData(tIC, &ic[0], RDCFGA, Config, A);
adBmsReadData(tIC, &ic[0], RDCFGB, Config, B);
printReadConfig(tIC, &ic[0], Config, ALL_GRP);
}
/**
*******************************************************************************
* @brief Start ADC Cell Voltage Measurement
*******************************************************************************
*/
void adBms6830_start_adc_cell_voltage_measurment(uint8_t tIC)
{
adBmsWakeupIc(tIC);
adBms6830_Adcv(REDUNDANT_MEASUREMENT, CONTINUOUS_MEASUREMENT, DISCHARGE_PERMITTED, RESET_FILTER, CELL_OPEN_WIRE_DETECTION);
pladc_count = adBmsPollAdc(PLADC);
#ifdef MBED
pc.printf("Cell conversion completed\n");
#else
printf("Cell conversion completed\n");
#endif
printPollAdcConvTime(pladc_count);
}
/**
*******************************************************************************
* @brief Read Cell Voltages
*******************************************************************************
*/
void adBms6830_read_cell_voltages(uint8_t tIC, cell_asic *ic)
{
adBmsWakeupIc(tIC);
adBmsReadData(tIC, &ic[0], RDCVA, Cell, A);
adBmsReadData(tIC, &ic[0], RDCVB, Cell, B);
adBmsReadData(tIC, &ic[0], RDCVC, Cell, C);
adBmsReadData(tIC, &ic[0], RDCVD, Cell, D);
adBmsReadData(tIC, &ic[0], RDCVE, Cell, E);
adBmsReadData(tIC, &ic[0], RDCVF, Cell, F);
printVoltages(tIC, &ic[0], Cell);
}
/**
*******************************************************************************
* @brief Start ADC S-Voltage Measurement
*******************************************************************************
*/
void adBms6830_start_adc_s_voltage_measurment(uint8_t tIC)
{
adBmsWakeupIc(tIC);
adBms6830_Adsv(CONTINUOUS_MEASUREMENT, DISCHARGE_PERMITTED, CELL_OPEN_WIRE_DETECTION);
pladc_count = adBmsPollAdc(PLADC);
#ifdef MBED
pc.printf("S-Voltage conversion completed\n");
#else
printf("S-Voltage conversion completed\n");
#endif
printPollAdcConvTime(pladc_count);
}
/**
*******************************************************************************
* @brief Read S-Voltages
*******************************************************************************
*/
void adBms6830_read_s_voltages(uint8_t tIC, cell_asic *ic)
{
adBmsWakeupIc(tIC);
adBmsReadData(tIC, &ic[0], RDSVA, S_volt, A);
adBmsReadData(tIC, &ic[0], RDSVB, S_volt, B);
adBmsReadData(tIC, &ic[0], RDSVC, S_volt, C);
adBmsReadData(tIC, &ic[0], RDSVD, S_volt, D);
adBmsReadData(tIC, &ic[0], RDSVE, S_volt, E);
adBmsReadData(tIC, &ic[0], RDSVF, S_volt, F);
printVoltages(tIC, &ic[0], S_volt);
}
/**
*******************************************************************************
* @brief Start Avarage Cell Voltage Measurement
*******************************************************************************
*/
void adBms6830_start_avgcell_voltage_measurment(uint8_t tIC)
{
adBmsWakeupIc(tIC);
adBms6830_Adcv(RD_ON, CONTINUOUS_MEASUREMENT, DISCHARGE_PERMITTED, RESET_FILTER, CELL_OPEN_WIRE_DETECTION);
pladc_count = adBmsPollAdc(PLADC);
#ifdef MBED
pc.printf("Avg Cell voltage conversion completed\n");
#else
printf("Avg Cell voltage conversion completed\n");
#endif
printPollAdcConvTime(pladc_count);
}
/**
*******************************************************************************
* @brief Read Avarage Cell Voltages
*******************************************************************************
*/
void adBms6830_read_avgcell_voltages(uint8_t tIC, cell_asic *ic)
{
adBmsWakeupIc(tIC);
adBmsReadData(tIC, &ic[0], RDACA, AvgCell, A);
adBmsReadData(tIC, &ic[0], RDACB, AvgCell, B);
adBmsReadData(tIC, &ic[0], RDACC, AvgCell, C);
adBmsReadData(tIC, &ic[0], RDACD, AvgCell, D);
adBmsReadData(tIC, &ic[0], RDACE, AvgCell, E);
adBmsReadData(tIC, &ic[0], RDACF, AvgCell, F);
printVoltages(tIC, &ic[0], AvgCell);
}
/**
*******************************************************************************
* @brief Start Filtered Cell Voltages Measurement
*******************************************************************************
*/
void adBms6830_start_fcell_voltage_measurment(uint8_t tIC)
{
adBmsWakeupIc(tIC);
adBms6830_Adcv(REDUNDANT_MEASUREMENT, CONTINUOUS_MEASUREMENT, DISCHARGE_PERMITTED, RESET_FILTER, CELL_OPEN_WIRE_DETECTION);
pladc_count = adBmsPollAdc(PLADC);
#ifdef MBED
pc.printf("F Cell voltage conversion completed\n");
#else
printf("F Cell voltage conversion completed\n");
#endif
printPollAdcConvTime(pladc_count);
}
/**
*******************************************************************************
* @brief Read Filtered Cell Voltages
*******************************************************************************
*/
void adBms6830_read_fcell_voltages(uint8_t tIC, cell_asic *ic)
{
adBmsWakeupIc(tIC);
adBmsReadData(tIC, &ic[0], RDFCA, F_volt, A);
adBmsReadData(tIC, &ic[0], RDFCB, F_volt, B);
adBmsReadData(tIC, &ic[0], RDFCC, F_volt, C);
adBmsReadData(tIC, &ic[0], RDFCD, F_volt, D);
adBmsReadData(tIC, &ic[0], RDFCE, F_volt, E);
adBmsReadData(tIC, &ic[0], RDFCF, F_volt, F);
printVoltages(tIC, &ic[0], F_volt);
}
/**
*******************************************************************************
* @brief Start AUX, VMV, V+ Voltages Measurement
*******************************************************************************
*/
void adBms6830_start_aux_voltage_measurment(uint8_t tIC, cell_asic *ic)
{
for(uint8_t cic = 0; cic < tIC; cic++)
{
/* Init config A */
ic[cic].tx_cfga.refon = PWR_UP;
ic[cic].tx_cfga.gpo = 0X3FF; /* All GPIO pull down off */
}
adBmsWakeupIc(tIC);
adBmsWriteData(tIC, &ic[0], WRCFGA, Config, A);
adBms6830_Adax(AUX_OPEN_WIRE_DETECTION, OPEN_WIRE_CURRENT_SOURCE, AUX_CH_TO_CONVERT);
pladc_count = adBmsPollAdc(PLADC);
#ifdef MBED
pc.printf("Aux voltage conversion completed\n");
#else
printf("Aux voltage conversion completed\n");
#endif
printPollAdcConvTime(pladc_count);
}
/**
*******************************************************************************
* @brief Read AUX, VMV, V+ Voltages
*******************************************************************************
*/
void adBms6830_read_aux_voltages(uint8_t tIC, cell_asic *ic)
{
adBmsWakeupIc(tIC);
adBmsReadData(tIC, &ic[0], RDAUXA, Aux, A);
adBmsReadData(tIC, &ic[0], RDAUXB, Aux, B);
adBmsReadData(tIC, &ic[0], RDAUXC, Aux, C);
adBmsReadData(tIC, &ic[0], RDAUXD, Aux, D);
printVoltages(tIC, &ic[0], Aux);
}
/**
*******************************************************************************
* @brief Start Redundant GPIO Voltages Measurement
*******************************************************************************
*/
void adBms6830_start_raux_voltage_measurment(uint8_t tIC, cell_asic *ic)
{
for(uint8_t cic = 0; cic < tIC; cic++)
{
/* Init config A */
ic[cic].tx_cfga.refon = PWR_UP;
ic[cic].tx_cfga.gpo = 0X3FF; /* All GPIO pull down off */
}
adBmsWakeupIc(tIC);
adBmsWriteData(tIC, &ic[0], WRCFGA, Config, A);
adBms6830_Adax2(AUX_CH_TO_CONVERT);
pladc_count = adBmsPollAdc(PLADC);
#ifdef MBED
pc.printf("RAux voltage conversion completed\n");
#else
printf("RAux voltage conversion completed\n");
#endif
printPollAdcConvTime(pladc_count);
}
/**
*******************************************************************************
* @brief Read Redundant GPIO Voltages
*******************************************************************************
*/
void adBms6830_read_raux_voltages(uint8_t tIC, cell_asic *ic)
{
adBmsWakeupIc(tIC);
adBmsReadData(tIC, &ic[0], RDRAXA, RAux, A);
adBmsReadData(tIC, &ic[0], RDRAXB, RAux, B);
adBmsReadData(tIC, &ic[0], RDRAXC, RAux, C);
adBmsReadData(tIC, &ic[0], RDRAXD, RAux, D);
printVoltages(tIC, &ic[0], RAux);
}
/**
*******************************************************************************
* @brief Read Status Reg. A, B, C, D and E.
*******************************************************************************
*/
void adBms6830_read_status_registers(uint8_t tIC, cell_asic *ic)
{
adBmsWakeupIc(tIC);
adBmsWriteData(tIC, &ic[0], WRCFGA, Config, A);
adBmsWriteData(tIC, &ic[0], WRCFGB, Config, B);
adBms6830_Adax(AUX_OPEN_WIRE_DETECTION, OPEN_WIRE_CURRENT_SOURCE, AUX_CH_TO_CONVERT);
pladc_count = adBmsPollAdc(PLADC);
adBms6830_Adcv(REDUNDANT_MEASUREMENT, CONTINUOUS_MEASUREMENT, DISCHARGE_PERMITTED, RESET_FILTER, CELL_OPEN_WIRE_DETECTION);
pladc_count = pladc_count + adBmsPollAdc(PLADC);
adBmsReadData(tIC, &ic[0], RDSTATA, Status, A);
adBmsReadData(tIC, &ic[0], RDSTATB, Status, B);
adBmsReadData(tIC, &ic[0], RDSTATC, Status, C);
adBmsReadData(tIC, &ic[0], RDSTATD, Status, D);
adBmsReadData(tIC, &ic[0], RDSTATE, Status, E);
printPollAdcConvTime(pladc_count);
printStatus(tIC, &ic[0], Status, ALL_GRP);
}
/**
*******************************************************************************
* @brief Loop measurment.
*******************************************************************************
*/
void measurement_loop()
{
if(MEASURE_CELL == ENABLED)
{
adBmsReadData(TOTAL_IC, &IC[0], RDCVA, Cell, A);
adBmsReadData(TOTAL_IC, &IC[0], RDCVB, Cell, B);
adBmsReadData(TOTAL_IC, &IC[0], RDCVC, Cell, C);
adBmsReadData(TOTAL_IC, &IC[0], RDCVD, Cell, D);
adBmsReadData(TOTAL_IC, &IC[0], RDCVE, Cell, E);
adBmsReadData(TOTAL_IC, &IC[0], RDCVF, Cell, F);
printVoltages(TOTAL_IC, &IC[0], Cell);
}
if(MEASURE_AVG_CELL == ENABLED)
{
adBmsReadData(TOTAL_IC, &IC[0], RDACA, AvgCell, A);
adBmsReadData(TOTAL_IC, &IC[0], RDACB, AvgCell, B);
adBmsReadData(TOTAL_IC, &IC[0], RDACC, AvgCell, C);
adBmsReadData(TOTAL_IC, &IC[0], RDACD, AvgCell, D);
adBmsReadData(TOTAL_IC, &IC[0], RDACE, AvgCell, E);
adBmsReadData(TOTAL_IC, &IC[0], RDACF, AvgCell, F);
printVoltages(TOTAL_IC, &IC[0], AvgCell);
}
if(MEASURE_F_CELL == ENABLED)
{
adBmsReadData(TOTAL_IC, &IC[0], RDFCA, F_volt, A);
adBmsReadData(TOTAL_IC, &IC[0], RDFCB, F_volt, B);
adBmsReadData(TOTAL_IC, &IC[0], RDFCC, F_volt, C);
adBmsReadData(TOTAL_IC, &IC[0], RDFCD, F_volt, D);
adBmsReadData(TOTAL_IC, &IC[0], RDFCE, F_volt, E);
adBmsReadData(TOTAL_IC, &IC[0], RDFCF, F_volt, F);
printVoltages(TOTAL_IC, &IC[0], F_volt);
}
if(MEASURE_S_VOLTAGE == ENABLED)
{
adBmsReadData(TOTAL_IC, &IC[0], RDSVA, S_volt, A);
adBmsReadData(TOTAL_IC, &IC[0], RDSVB, S_volt, B);
adBmsReadData(TOTAL_IC, &IC[0], RDSVC, S_volt, C);
adBmsReadData(TOTAL_IC, &IC[0], RDSVD, S_volt, D);
adBmsReadData(TOTAL_IC, &IC[0], RDSVE, S_volt, E);
adBmsReadData(TOTAL_IC, &IC[0], RDSVF, S_volt, F);
printVoltages(TOTAL_IC, &IC[0], S_volt);
}
if(MEASURE_AUX == ENABLED)
{
adBms6830_Adax(AUX_OPEN_WIRE_DETECTION, OPEN_WIRE_CURRENT_SOURCE, AUX_CH_TO_CONVERT);
adBmsPollAdc(PLAUX1);
adBmsReadData(TOTAL_IC, &IC[0], RDAUXA, Aux, A);
adBmsReadData(TOTAL_IC, &IC[0], RDAUXB, Aux, B);
adBmsReadData(TOTAL_IC, &IC[0], RDAUXC, Aux, C);
adBmsReadData(TOTAL_IC, &IC[0], RDAUXD, Aux, D);
printVoltages(TOTAL_IC, &IC[0], Aux);
}
if(MEASURE_RAUX == ENABLED)
{
adBmsWakeupIc(TOTAL_IC);
adBms6830_Adax2(AUX_CH_TO_CONVERT);
adBmsPollAdc(PLAUX2);
adBmsReadData(TOTAL_IC, &IC[0], RDRAXA, RAux, A);
adBmsReadData(TOTAL_IC, &IC[0], RDRAXB, RAux, B);
adBmsReadData(TOTAL_IC, &IC[0], RDRAXC, RAux, C);
adBmsReadData(TOTAL_IC, &IC[0], RDRAXD, RAux, D);
printVoltages(TOTAL_IC, &IC[0], RAux);
}
if(MEASURE_STAT == ENABLED)
{
adBmsReadData(TOTAL_IC, &IC[0], RDSTATA, Status, A);
adBmsReadData(TOTAL_IC, &IC[0], RDSTATB, Status, B);
adBmsReadData(TOTAL_IC, &IC[0], RDSTATC, Status, C);
adBmsReadData(TOTAL_IC, &IC[0], RDSTATD, Status, D);
adBmsReadData(TOTAL_IC, &IC[0], RDSTATE, Status, E);
printStatus(TOTAL_IC, &IC[0], Status, ALL_GRP);
}
}
/**
*******************************************************************************
* @brief Clear Cell measurement reg.
*******************************************************************************
*/
void adBms6830_clear_cell_measurement(uint8_t tIC)
{
adBmsWakeupIc(tIC);
spiSendCmd(CLRCELL);
#ifdef MBED
pc.printf("Cell Registers Cleared\n\n");
#else
printf("Cell Registers Cleared\n\n");
#endif
}
/**
*******************************************************************************
* @brief Clear Aux measurement reg.
*******************************************************************************
*/
void adBms6830_clear_aux_measurement(uint8_t tIC)
{
adBmsWakeupIc(tIC);
spiSendCmd(CLRAUX);
#ifdef MBED
pc.printf("Aux Registers Cleared\n\n");
#else
printf("Aux Registers Cleared\n\n");
#endif
}
/**
*******************************************************************************
* @brief Clear spin measurement reg.
*******************************************************************************
*/
void adBms6830_clear_spin_measurement(uint8_t tIC)
{
adBmsWakeupIc(tIC);
spiSendCmd(CLRSPIN);
#ifdef MBED
pc.printf("Spin Registers Cleared\n\n");
#else
printf("Spin Registers Cleared\n\n");
#endif
}
/**
*******************************************************************************
* @brief Clear fcell measurement reg.
*******************************************************************************
*/
void adBms6830_clear_fcell_measurement(uint8_t tIC)
{
adBmsWakeupIc(tIC);
spiSendCmd(CLRFC);
#ifdef MBED
pc.printf("Fcell Registers Cleared\n\n");
#else
printf("Fcell Registers Cleared\n\n");
#endif
}
/** @}*/
/** @}*/

View File

@ -0,0 +1,426 @@
/*******************************************************************************
Copyright (c) 2020 - Analog Devices Inc. All Rights Reserved.
This software is proprietary & confidential to Analog Devices, Inc.
and its licensor.
******************************************************************************
* @file: mcuWrapper.c
* @brief: BMS SPI driver functions
* @version: $Revision$
* @date: $Date$
* Developed by: ADIBMS Software team, Bangalore, India
*****************************************************************************/
/*! \addtogroup MCU DRIVER
* @{
*/
/*! @addtogroup Mcu Driver
* @{
*/
#include "common.h"
#include "mcuWrapper.h"
#define WAKEUP_DELAY 4 /* BMS ic wakeup delay */
#ifdef MBED
extern Serial pc;
extern SPI spi;
extern Timer timer;
extern DigitalOut chip_select;
/**
*******************************************************************************
* Function: Delay_ms
* @brief Delay mili second
*
* @details This function insert delay in ms.
*
* Parameters:
* @param [in] delay Delay_ms
*
* @return None
*
*******************************************************************************
*/
void Delay_ms(uint32_t delay)
{
wait_ms((int)delay);
}
/**
*******************************************************************************
* Function: adBmsCsLow
* @brief Select chip select low
*
* @details This function does spi chip select low.
*
* @return None
*
*******************************************************************************
*/
void adBmsCsLow()
{
spi.lock();
chip_select = 0;
}
/**
*******************************************************************************
* Function: adBmsCsHigh
* @brief Select chip select High
*
* @details This function does spi chip select high.
*
* @return None
*
*******************************************************************************
*/
void adBmsCsHigh()
{
chip_select = 1;
spi.unlock();
}
/**
*******************************************************************************
* Function: spiWriteBytes
* @brief Writes an array of bytes out of the SPI port.
*
* @details This function wakeup bms ic in IsoSpi mode send dumy byte data in spi line..
*
* @param [in] size Numberof bytes to be send on the SPI line
*
* @param [in] *tx_Data Tx data pointer
*
* @return None
*
*******************************************************************************
*/
void spiWriteBytes
(
uint16_t size, /*Option: Number of bytes to be written on the SPI port*/
uint8_t *tx_data /*Array of bytes to be written on the SPI port*/
)
{
uint8_t rx_data[size];
spi.write((char *)tx_data, size ,(char *)rx_data, size);
}
/**
*******************************************************************************
* Function: spiWriteReadBytes
* @brief Writes and read a set number of bytes using the SPI port.
*
* @details This function writes and read a set number of bytes using the SPI port.
*
* @param [in] *tx_data Tx data pointer
*
* @param [in] *rx_data Rx data pointer
*
* @param [in] size Data size
*
* @return None
*
*******************************************************************************
*/
void spiWriteReadBytes
(
uint8_t *tx_data, /*array of data to be written on SPI port*/
uint8_t *rx_data, /*Input: array that will store the data read by the SPI port*/
uint16_t size /*Option: number of bytes*/
)
{
uint16_t data_size = (4 + size);
uint8_t cmd[data_size];
memcpy(&cmd[0], &tx_data[0], 4); /* dst, src, size */
spi.write((char *)cmd, data_size ,(char *)cmd, data_size);
memcpy(&rx_data[0], &cmd[4], size); /* dst, src, size */
}
/**
*******************************************************************************
* Function: spiReadBytes
* @brief Read number of bytes using the SPI port.
*
* @details This function Read a set number of bytes using the SPI port.
*
* @param [in] size Data size
*
* @param [in] *rx_data Rx data pointer
*
* @return None
*
*******************************************************************************
*/
void spiReadBytes(uint16_t size, uint8_t *rx_data)
{
uint8_t tx_data[size];
for(uint8_t i=0; i < size; i++)
{
tx_data[i] = 0xFF;
}
spi.write((char *)tx_data, size ,(char *)rx_data, size);
}
/**
*******************************************************************************
* Function: startTimer()
* @brief Start timer
*
* @details This function start the timer.
*
* @return None
*
*******************************************************************************
*/
void startTimer()
{
timer.start();
}
/**
*******************************************************************************
* Function: stopTimer()
* @brief Stop timer
*
* @details This function stop the timer.
*
* @return None
*
*******************************************************************************
*/
void stopTimer()
{
timer.stop();
}
/**
*******************************************************************************
* Function: getTimCount()
* @brief Get Timer Count Value
*
* @details This function return the timer count value.
*
* @return tim_count
*
*******************************************************************************
*/
uint32_t getTimCount()
{
uint32_t count = 0;
count = timer.read_us();
timer.reset();
return(count);
}
#else
#define SPI_TIME_OUT HAL_MAX_DELAY /* SPI Time out delay */
#define UART_TIME_OUT HAL_MAX_DELAY /* UART Time out delay */
#define I2C_TIME_OUT HAL_MAX_DELAY /* I2C Time out delay */
SPI_HandleTypeDef *hspi = &hspi1; /* MUC SPI Handler */
UART_HandleTypeDef *huart = &huart5; /* MUC UART Handler */
I2C_HandleTypeDef *hi2c = &hi2c1; /* MUC I2C Handler */
TIM_HandleTypeDef *htim = &htim2; /* Mcu TIM handler */
/**
*******************************************************************************
* Function: Delay_ms
* @brief Delay mili second
*
* @details This function insert delay in ms.
*
* Parameters:
* @param [in] delay Delay_ms
*
* @return None
*
*******************************************************************************
*/
void Delay_ms(uint32_t delay)
{
HAL_Delay(delay);
}
/**
*******************************************************************************
* Function: adBmsCsLow
* @brief Select chip select low
*
* @details This function does spi chip select low.
*
* @return None
*
*******************************************************************************
*/
void adBmsCsLow()
{
HAL_GPIO_WritePin(GPIO_PORT, CS_PIN, GPIO_PIN_RESET);
}
/**
*******************************************************************************
* Function: adBmsCsHigh
* @brief Select chip select High
*
* @details This function does spi chip select high.
*
* @return None
*
*******************************************************************************
*/
void adBmsCsHigh()
{
HAL_GPIO_WritePin(GPIO_PORT, CS_PIN, GPIO_PIN_SET);
}
/**
*******************************************************************************
* Function: spiWriteBytes
* @brief Writes an array of bytes out of the SPI port.
*
* @details This function wakeup bms ic in IsoSpi mode send dumy byte data in spi line..
*
* @param [in] size Numberof bytes to be send on the SPI line
*
* @param [in] *tx_Data Tx data pointer
*
* @return None
*
*******************************************************************************
*/
void spiWriteBytes
(
uint16_t size, /*Option: Number of bytes to be written on the SPI port*/
uint8_t *tx_Data /*Array of bytes to be written on the SPI port*/
)
{
HAL_SPI_Transmit(hspi, tx_Data, size, SPI_TIME_OUT); /* SPI1 , data, size, timeout */
}
/**
*******************************************************************************
* Function: spiWriteReadBytes
* @brief Writes and read a set number of bytes using the SPI port.
*
* @details This function writes and read a set number of bytes using the SPI port.
*
* @param [in] *tx_data Tx data pointer
*
* @param [in] *rx_data Rx data pointer
*
* @param [in] size Data size
*
* @return None
*
*******************************************************************************
*/
void spiWriteReadBytes
(
uint8_t *tx_data, /*array of data to be written on SPI port*/
uint8_t *rx_data, /*Input: array that will store the data read by the SPI port*/
uint16_t size /*Option: number of bytes*/
)
{
HAL_SPI_Transmit(hspi, tx_data, 4, SPI_TIME_OUT);
HAL_SPI_Receive(hspi, rx_data, size, SPI_TIME_OUT);
}
/**
*******************************************************************************
* Function: spiReadBytes
* @brief Read number of bytes using the SPI port.
*
* @details This function Read a set number of bytes using the SPI port.
*
* @param [in] size Data size
*
* @param [in] *rx_data Rx data pointer
*
* @return None
*
*******************************************************************************
*/
void spiReadBytes(uint16_t size, uint8_t *rx_data)
{
HAL_SPI_Receive(hspi, rx_data, size, SPI_TIME_OUT);
}
/**
*******************************************************************************
* Function: startTimer()
* @brief Start timer
*
* @details This function start the timer.
*
* @return None
*
*******************************************************************************
*/
void startTimer()
{
HAL_TIM_Base_Start(htim);
}
/**
*******************************************************************************
* Function: stopTimer()
* @brief Stop timer
*
* @details This function stop the timer.
*
* @return None
*
*******************************************************************************
*/
void stopTimer()
{
HAL_TIM_Base_Stop(htim);
}
/**
*******************************************************************************
* Function: getTimCount()
* @brief Get Timer Count Value
*
* @details This function return the timer count value.
*
* @return tim_count
*
*******************************************************************************
*/
uint32_t getTimCount()
{
uint32_t count = 0;
count = __HAL_TIM_GetCounter(htim);
__HAL_TIM_SetCounter(htim, 0);
return(count);
}
#endif
/**
*******************************************************************************
* Function: adBmsWakeupIc
* @brief Wakeup bms ic using chip select
*
* @details This function wakeup thr bms ic using chip select.
*
* @param [in] total_ic Total_ic
*
* @return None
*
*******************************************************************************
*/
void adBmsWakeupIc(uint8_t total_ic)
{
for (uint8_t ic = 0; ic < total_ic; ic++)
{
adBmsCsLow();
Delay_ms(WAKEUP_DELAY);
adBmsCsHigh();
Delay_ms(WAKEUP_DELAY);
}
}
/** @}*/
/** @}*/

File diff suppressed because it is too large Load Diff