Linduino  1.3.0
Linear Technology Arduino-Compatible Demonstration Board

Analog Devices DC2350A-A Demonstration Board. More...

Detailed Description

Analog Devices DC2350A-A Demonstration Board.

LTC6812: Multicell Battery Monitors

*NOTES
* Setup:
*   Set the terminal baud rate to 115200 and select the newline terminator.
*   Ensure all jumpers on the demo board are installed in their default positions from the factory.
*   Refer to Demo Manual.
*
*USER INPUT DATA FORMAT:
* decimal : 1024
* hex     : 0x400
* octal   : 02000  (leading 0)
* binary  : B10000000000
* float   : 1024.0
*

https://www.analog.com/en/products/ltc6812-1.html The schematic of DC2350A : https://www.analog.com/media/en/technical-documentation/eval-board-schematic/DC2350A-4-SCH.PDF ( Ensure that you modify the DC2350A board as mentioned on the schematic to work for LTC6812 (DC2350A-A) )

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.

Definition in file DC2350AA.ino.

Go to the source code of this file.

Functions

static void measurement_loop (uint8_t datalog_en)
 
More...
 
static void print_menu (void)
 
More...
 
static void print_wrconfig (void)
 
More...
 
static void print_wrconfigb (void)
 
More...
 
static void print_rxconfig (void)
 
More...
 
static void print_rxconfigb (void)
 
More...
 
static void print_cells (uint8_t datalog_en)
 
More...
 
static void print_aux (uint8_t datalog_en)
 
More...
 
static void print_stat (void)
 
More...
 
static void print_aux1 (void)
 
static void print_sumofcells (void)
 
More...
 
static void check_mux_fail (void)
 
More...
 
static void print_selftest_errors (uint8_t adc_reg,int8_t error)
 
More...
 
static void print_overlap_results (int8_t error)
 
More...
 
static void print_digital_redundancy_errors (uint8_t adc_reg,int8_t error)
 
More...
 
static void print_open_wires (void)
 
More...
 
static void print_pec_error_count (void)
 
More...
 
static int8_t select_s_pin (void)
 
More...
 
static void print_wrpwm (void)
 
More...
 
static void print_rxpwm (void)
 
More...
 
static void print_wrsctrl (void)
 
More...
 
static void print_rxsctrl (void)
 
More...
 
static void print_wrpsb (uint8_t type)
 
More...
 
static void print_rxpsb (uint8_t type)
 
More...
 
static void print_wrcomm (void)
 
More...
 
static void print_rxcomm (void)
 
More...
 
static void check_mute_bit (void)
 
More...
 
static void print_conv_time (uint32_t conv_time)
 
More...
 
static void check_error (int error)
 
More...
 
static void serial_print_text (char data[])
 
More...
 
static void serial_print_hex (uint8_t data)
 
More...
 
char read_hex (void)
 
More...
 
char get_char (void)
 
More...
 
static void setup ()
 
More...
 
static void loop ()
 
More...
 
static void run_command (uint32_t cmd)
 
More...
 
static void print_aux1 (uint8_t datalog_en)
 
More...
 

Macros

#define ENABLED   1
 
#define DISABLED   0
 
#define DATALOG_ENABLED   1
 
#define DATALOG_DISABLED   0
 
#define PWM   1
 
#define SCTL   2
 

Variables

const uint8_t TOTAL_IC = 2
 Number of ICs in the daisy chain. More...
 
const uint8_t ADC_OPT = ADC_OPT_DISABLED
 ADC Mode option bit. More...
 
const uint8_t ADC_CONVERSION_MODE = MD_7KHZ_3KHZ
 ADC Mode. More...
 
const uint8_t ADC_DCP = DCP_DISABLED
 Discharge Permitted. More...
 
const uint8_t CELL_CH_TO_CONVERT = CELL_CH_ALL
 Channel Selection for ADC conversion. More...
 
const uint8_t AUX_CH_TO_CONVERT = AUX_CH_ALL
 Channel Selection for ADC conversion. More...
 
const uint8_t STAT_CH_TO_CONVERT = STAT_CH_ALL
 Channel Selection for ADC conversion. More...
 
const uint8_t SEL_ALL_REG = REG_ALL
 Register Selection. More...
 
const uint8_t SEL_REG_A = REG_1
 Register Selection. More...
 
const uint8_t SEL_REG_B = REG_2
 Register Selection. More...
 
const uint16_t MEASUREMENT_LOOP_TIME = 500
 Loop Time in milliseconds(ms) More...
 
const uint16_t OV_THRESHOLD = 41000
 Over voltage threshold ADC Code. More...
 
const uint16_t UV_THRESHOLD = 30000
 Under voltage threshold ADC Code. More...
 
const uint8_t WRITE_CONFIG = DISABLED
 This is to ENABLED or DISABLED writing into to configuration registers in a continuous loop. More...
 
const uint8_t READ_CONFIG = DISABLED
 This is to ENABLED or DISABLED reading the configuration registers in a continuous loop. More...
 
const uint8_t MEASURE_CELL = ENABLED
 This is to ENABLED or DISABLED measuring the cell voltages in a continuous loop. More...
 
const uint8_t MEASURE_AUX = DISABLED
 This is to ENABLED or DISABLED reading the auxiliary registers in a continuous loop. More...
 
const uint8_t MEASURE_STAT = DISABLED
 This is to ENABLED or DISABLED reading the status registers in a continuous loop. More...
 
const uint8_t PRINT_PEC = DISABLED
 This is to ENABLED or DISABLED printing the PEC Error Count in a continuous loop. More...
 
cell_asic BMS_IC [TOTAL_IC]
 Global Battery Variable. More...
 
bool REFON = true
 Reference Powered Up Bit. More...
 
bool ADCOPT = false
 ADC Mode option bit. More...
 
bool GPIOBITS_A [5] = {false,false,true,true,true}
 GPIO Pin Control // Gpio 1,2,3,4,5. More...
 
bool GPIOBITS_B [4] = {false,false,false,false}
 GPIO Pin Control // Gpio 6,7,8,9. More...
 
static uint16_t UV =UV_THRESHOLD
 Under voltage Comparison Voltage. More...
 
static uint16_t OV =OV_THRESHOLD
 Over voltage Comparison Voltage. More...
 
bool DCCBITS_A [12] = {false,false,false,false,false,false,false,false,false,false,false,false}
 Discharge cell switch //Dcc 1,2,3,4,5,6,7,8,9,10,11,12. More...
 
bool DCCBITS_B [7] = {false,false,false,false}
 Discharge cell switch //Dcc 0,13,14,15. More...
 
bool DCTOBITS [4] = {true,false,true,false}
 Discharge time value //Dcto 0,1,2,3 // Programed for 4 min. More...
 
bool FDRF = false
 Force Digital Redundancy Failure Bit. More...
 
bool DTMEN = true
 Enable Discharge Timer Monitor. More...
 
bool PSBits [2] = {false,false}
 Digital Redundancy Path Selection//ps-0,1. More...
 
char hex_digits [16]
 
More...
 
char hex_to_byte_buffer [5]
 
More...
 
char byte_to_hex_buffer [3]
 
More...
 

Function Documentation

◆ check_error()

static void check_error ( int  error)
static


Function to check error flag and print PEC error message

Returns
void

Definition at line 1547 of file DC2350AA.ino.

◆ check_mute_bit()

static void check_mute_bit ( void  )
static


Function to check the Mute bit in the Configuration Register

Returns
void

Definition at line 1520 of file DC2350AA.ino.

◆ check_mux_fail()

static void check_mux_fail ( void  )
static


Function to check the MUX fail bit in the Status Register

Returns
void

Definition at line 1110 of file DC2350AA.ino.

◆ get_char()

char get_char ( void  )


Read a command from the serial port

Returns
char

Definition at line 1622 of file DC2350AA.ino.

◆ loop()

static void loop ( void  )
static


Main loop

Returns
void

Definition at line 209 of file DC2350AA.ino.

◆ measurement_loop()

static void measurement_loop ( uint8_t  datalog_en)
static


For writing/reading configuration data or measuring cell voltages or reading aux register or reading status register in a continuous loop

Returns
void

Definition at line 721 of file DC2350AA.ino.

◆ print_aux()

static void print_aux ( uint8_t  datalog_en)
static


Prints GPIO voltage and Vref2 voltage code onto the serial port

Returns
void

Definition at line 963 of file DC2350AA.ino.

◆ print_aux1() [1/2]

static void print_aux1 ( void  )
static

◆ print_aux1() [2/2]

static void print_aux1 ( uint8_t  datalog_en)
static


Prints GPIO voltage codes (GPIO 1 & 2)

Returns
void

Definition at line 1057 of file DC2350AA.ino.

◆ print_cells()

static void print_cells ( uint8_t  datalog_en)
static


Prints cell voltage to the serial port

Returns
void

Definition at line 927 of file DC2350AA.ino.

◆ print_conv_time()

static void print_conv_time ( uint32_t  conv_time)
static


Function to print the Conversion Time

Returns
void

Definition at line 1534 of file DC2350AA.ino.

◆ print_digital_redundancy_errors()

static void print_digital_redundancy_errors ( uint8_t  adc_reg,
int8_t  error 
)
static


Prints Errors Detected during Digital Redundancy test

Returns
void

Definition at line 1160 of file DC2350AA.ino.

◆ print_menu()

static void print_menu ( void  )
static


Prints the main menu

Returns
void

Definition at line 801 of file DC2350AA.ino.

◆ print_open_wires()

static void print_open_wires ( void  )
static


Prints Open wire test results to the serial port

Returns
void

Definition at line 1179 of file DC2350AA.ino.

◆ print_overlap_results()

static void print_overlap_results ( int8_t  error)
static


Prints the output of the ADC overlap test

Returns
void

Definition at line 1150 of file DC2350AA.ino.

◆ print_pec_error_count()

static void print_pec_error_count ( void  )
static


Function to print the number of PEC Errors

Returns
void

Definition at line 1204 of file DC2350AA.ino.

◆ print_rxcomm()

static void print_rxcomm ( void  )
static


Prints received data from COMM register onto the serial port

Returns
void

Definition at line 1495 of file DC2350AA.ino.

◆ print_rxconfig()

static void print_rxconfig ( void  )
static


Prints the Configuration Register A data that was read back from the LTC6812 to the serial port.

Returns
void

Definition at line 878 of file DC2350AA.ino.

◆ print_rxconfigb()

static void print_rxconfigb ( void  )
static


Prints the Configuration Register B that was read back from the LTC6812 to the serial port.

Returns
void

Definition at line 903 of file DC2350AA.ino.

◆ print_rxpsb()

static void print_rxpsb ( uint8_t  type)
static


Prints received data from PWM/S control register group B onto the serial port

Returns
void

Definition at line 1406 of file DC2350AA.ino.

◆ print_rxpwm()

static void print_rxpwm ( void  )
static


Prints received data from PWM register onto the serial port

Returns
void

Definition at line 1261 of file DC2350AA.ino.

◆ print_rxsctrl()

static void print_rxsctrl ( void  )
static


Prints data which is read back from S Control register

Returns
void

Definition at line 1314 of file DC2350AA.ino.

◆ print_selftest_errors()

static void print_selftest_errors ( uint8_t  adc_reg,
int8_t  error 
)
static


Prints Errors Detected during self test

Returns
void

Definition at line 1128 of file DC2350AA.ino.

◆ print_stat()

static void print_stat ( void  )
static


Prints Status voltage codes and Vref2 voltage code onto the serial port

Returns
void

Definition at line 1017 of file DC2350AA.ino.

◆ print_sumofcells()

static void print_sumofcells ( void  )
static


Prints Status voltage codes for SOC onto the serial port

Returns
void

Definition at line 1093 of file DC2350AA.ino.

◆ print_wrcomm()

static void print_wrcomm ( void  )
static


prints data which is written on COMM register onto the serial port

Returns
void

Definition at line 1467 of file DC2350AA.ino.

◆ print_wrconfig()

static void print_wrconfig ( void  )
static


Prints the Configuration Register A data that is going to be written to the LTC6812 to the serial port.

Returns
void

Definition at line 824 of file DC2350AA.ino.

◆ print_wrconfigb()

static void print_wrconfigb ( void  )
static


Prints the Configuration Register B data that is going to be written to the LTC6812 to the serial port.

Returns
void

Definition at line 851 of file DC2350AA.ino.

◆ print_wrpsb()

static void print_wrpsb ( uint8_t  type)
static


Prints data which is written on PWM/S control register group B onto the serial port

Returns
void

Definition at line 1341 of file DC2350AA.ino.

◆ print_wrpwm()

static void print_wrpwm ( void  )
static


Prints data which is written on PWM register onto the serial port

Returns
void

Definition at line 1234 of file DC2350AA.ino.

◆ print_wrsctrl()

static void print_wrsctrl ( void  )
static


prints data which is written on S Control register

Returns
void

Definition at line 1285 of file DC2350AA.ino.

◆ read_hex()

char read_hex ( void  )


Read 2 hex characters from the serial buffer and convert them to a byte

Returns
char data Read Data

Definition at line 1607 of file DC2350AA.ino.

◆ run_command()

static void run_command ( uint32_t  cmd)
static


Executes the user command

Returns
void

Definition at line 231 of file DC2350AA.ino.

◆ select_s_pin()

static int8_t select_s_pin ( void  )
static


Function to select the S pin for discharge

Returns
void

Definition at line 1220 of file DC2350AA.ino.

◆ serial_print_hex()

static void serial_print_hex ( uint8_t  data)
static


Function to print in HEX form

Returns
void

Definition at line 1568 of file DC2350AA.ino.

◆ serial_print_text()

static void serial_print_text ( char  data[])
static


Function to print text on serial monitor

Returns
void

Definition at line 1559 of file DC2350AA.ino.

◆ setup()

static void setup ( void  )
static


Initializes hardware and variables

Returns
void

Definition at line 188 of file DC2350AA.ino.

Macro Definition Documentation

◆ DATALOG_DISABLED

#define DATALOG_DISABLED   0

Definition at line 86 of file DC2350AA.ino.

◆ DATALOG_ENABLED

#define DATALOG_ENABLED   1

Definition at line 85 of file DC2350AA.ino.

◆ DISABLED

#define DISABLED   0

Definition at line 84 of file DC2350AA.ino.

◆ ENABLED

#define ENABLED   1

Definition at line 83 of file DC2350AA.ino.

◆ PWM

#define PWM   1

Definition at line 87 of file DC2350AA.ino.

◆ SCTL

#define SCTL   2

Definition at line 88 of file DC2350AA.ino.

Variable Documentation

◆ ADC_CONVERSION_MODE

const uint8_t ADC_CONVERSION_MODE = MD_7KHZ_3KHZ

ADC Mode.

Definition at line 133 of file DC2350AA.ino.

◆ ADC_DCP

const uint8_t ADC_DCP = DCP_DISABLED

Discharge Permitted.

Definition at line 134 of file DC2350AA.ino.

◆ ADC_OPT

const uint8_t ADC_OPT = ADC_OPT_DISABLED

ADC Mode option bit.

Definition at line 132 of file DC2350AA.ino.

◆ ADCOPT

bool ADCOPT = false

ADC Mode option bit.

Definition at line 171 of file DC2350AA.ino.

◆ AUX_CH_TO_CONVERT

const uint8_t AUX_CH_TO_CONVERT = AUX_CH_ALL

Channel Selection for ADC conversion.

Definition at line 136 of file DC2350AA.ino.

◆ BMS_IC

Global Battery Variable.

Definition at line 165 of file DC2350AA.ino.

◆ byte_to_hex_buffer

char byte_to_hex_buffer[3]
Initial value:
=
{
'\0','\0','\0'
}


Buffer for ASCII hex to byte conversion

Definition at line 1598 of file DC2350AA.ino.

◆ CELL_CH_TO_CONVERT

const uint8_t CELL_CH_TO_CONVERT = CELL_CH_ALL

Channel Selection for ADC conversion.

Definition at line 135 of file DC2350AA.ino.

◆ DCCBITS_A

bool DCCBITS_A[12] = {false,false,false,false,false,false,false,false,false,false,false,false}

Discharge cell switch //Dcc 1,2,3,4,5,6,7,8,9,10,11,12.

Definition at line 176 of file DC2350AA.ino.

◆ DCCBITS_B

bool DCCBITS_B[7] = {false,false,false,false}

Discharge cell switch //Dcc 0,13,14,15.

Definition at line 177 of file DC2350AA.ino.

◆ DCTOBITS

bool DCTOBITS[4] = {true,false,true,false}

Discharge time value //Dcto 0,1,2,3 // Programed for 4 min.

Definition at line 178 of file DC2350AA.ino.

◆ DTMEN

bool DTMEN = true

Enable Discharge Timer Monitor.

Definition at line 181 of file DC2350AA.ino.

◆ FDRF

bool FDRF = false

Force Digital Redundancy Failure Bit.

Definition at line 180 of file DC2350AA.ino.

◆ GPIOBITS_A

bool GPIOBITS_A[5] = {false,false,true,true,true}

GPIO Pin Control // Gpio 1,2,3,4,5.

Definition at line 172 of file DC2350AA.ino.

◆ GPIOBITS_B

bool GPIOBITS_B[4] = {false,false,false,false}

GPIO Pin Control // Gpio 6,7,8,9.

Definition at line 173 of file DC2350AA.ino.

◆ hex_digits

char hex_digits[16]
Initial value:
=
{
'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'
}


Hex conversion constants

Definition at line 1582 of file DC2350AA.ino.

◆ hex_to_byte_buffer

char hex_to_byte_buffer[5]
Initial value:
=
{
'0', 'x', '0', '0', '\0'
}


Global Variables

Definition at line 1590 of file DC2350AA.ino.

◆ MEASURE_AUX

const uint8_t MEASURE_AUX = DISABLED

This is to ENABLED or DISABLED reading the auxiliary registers in a continuous loop.

Definition at line 152 of file DC2350AA.ino.

◆ MEASURE_CELL

const uint8_t MEASURE_CELL = ENABLED

This is to ENABLED or DISABLED measuring the cell voltages in a continuous loop.

Definition at line 151 of file DC2350AA.ino.

◆ MEASURE_STAT

const uint8_t MEASURE_STAT = DISABLED

This is to ENABLED or DISABLED reading the status registers in a continuous loop.

Definition at line 153 of file DC2350AA.ino.

◆ MEASUREMENT_LOOP_TIME

const uint16_t MEASUREMENT_LOOP_TIME = 500

Loop Time in milliseconds(ms)

Definition at line 142 of file DC2350AA.ino.

◆ OV

uint16_t OV =OV_THRESHOLD
static

Over voltage Comparison Voltage.

Definition at line 175 of file DC2350AA.ino.

◆ OV_THRESHOLD

const uint16_t OV_THRESHOLD = 41000

Over voltage threshold ADC Code.

LSB = 0.0001 —(4.1V)

Definition at line 145 of file DC2350AA.ino.

◆ PRINT_PEC

const uint8_t PRINT_PEC = DISABLED

This is to ENABLED or DISABLED printing the PEC Error Count in a continuous loop.

Definition at line 154 of file DC2350AA.ino.

◆ PSBits

bool PSBits[2] = {false,false}

Digital Redundancy Path Selection//ps-0,1.

Definition at line 182 of file DC2350AA.ino.

◆ READ_CONFIG

const uint8_t READ_CONFIG = DISABLED

This is to ENABLED or DISABLED reading the configuration registers in a continuous loop.

Definition at line 150 of file DC2350AA.ino.

◆ REFON

bool REFON = true

Reference Powered Up Bit.

Definition at line 170 of file DC2350AA.ino.

◆ SEL_ALL_REG

const uint8_t SEL_ALL_REG = REG_ALL

Register Selection.

Definition at line 138 of file DC2350AA.ino.

◆ SEL_REG_A

const uint8_t SEL_REG_A = REG_1

Register Selection.

Definition at line 139 of file DC2350AA.ino.

◆ SEL_REG_B

const uint8_t SEL_REG_B = REG_2

Register Selection.

Definition at line 140 of file DC2350AA.ino.

◆ STAT_CH_TO_CONVERT

const uint8_t STAT_CH_TO_CONVERT = STAT_CH_ALL

Channel Selection for ADC conversion.

Definition at line 137 of file DC2350AA.ino.

◆ TOTAL_IC

const uint8_t TOTAL_IC = 2

Number of ICs in the daisy chain.

Definition at line 129 of file DC2350AA.ino.

◆ UV

uint16_t UV =UV_THRESHOLD
static

Under voltage Comparison Voltage.

Definition at line 174 of file DC2350AA.ino.

◆ UV_THRESHOLD

const uint16_t UV_THRESHOLD = 30000

Under voltage threshold ADC Code.

LSB = 0.0001 —(3V)

Definition at line 146 of file DC2350AA.ino.

◆ WRITE_CONFIG

const uint8_t WRITE_CONFIG = DISABLED

This is to ENABLED or DISABLED writing into to configuration registers in a continuous loop.

Definition at line 149 of file DC2350AA.ino.