38 #include "drv_digital_out.h" 39 #include "drv_digital_in.h" 40 #include "drv_i2c_master.h" 53 #define BALANCER5_MAP_MIKROBUS( cfg, mikrobus ) \ 54 cfg.scl = MIKROBUS( mikrobus, MIKROBUS_SCL ); \ 55 cfg.sda = MIKROBUS( mikrobus, MIKROBUS_SDA ); \ 56 cfg.pg = MIKROBUS( mikrobus, MIKROBUS_AN ); \ 57 cfg.pss = MIKROBUS( mikrobus, MIKROBUS_RST ); \ 58 cfg.cd = MIKROBUS( mikrobus, MIKROBUS_CS ); \ 59 cfg.int_pin = MIKROBUS( mikrobus, MIKROBUS_INT ) 66 #define BALANCER5_RETVAL uint8_t 68 #define BALANCER5_OK 0x00 69 #define BALANCER5_INIT_ERROR 0xFF 76 #define BALANCER5_REG_CELL_V_LIMIT 0x00 77 #define BALANCER5_REG_CHARGE_CURR_LIMIT 0x01 78 #define BALANCER5_REG_INPUT_V_LIMIT 0x02 79 #define BALANCER5_REG_INPUT_CURR_LIMIT 0x03 80 #define BALANCER5_REG_PRECHARGE_N_TERMINATION_CTRL 0x04 81 #define BALANCER5_REG_CHARGER_CTRL_1 0x05 82 #define BALANCER5_REG_CHARGER_CTRL_2 0x06 83 #define BALANCER5_REG_CHARGER_CTRL_3 0x07 84 #define BALANCER5_REG_CHARGER_CTRL_4 0x08 85 #define BALANCER5_REG_ICO_CURR_LIMIT 0x0A 86 #define BALANCER5_REG_CHARGER_STATUS_1 0x0B 87 #define BALANCER5_REG_CHARGER_STATUS_2 0x0C 88 #define BALANCER5_REG_NTC_STATUS 0x0D 89 #define BALANCER5_REG_FAULT_STATUS 0x0E 90 #define BALANCER5_REG_CHARGER_FLAG_1 0x0F 91 #define BALANCER5_REG_CHARGER_FLAG_2 0x10 92 #define BALANCER5_REG_FAULT_FLAG 0x11 93 #define BALANCER5_REG_CHARGER_MASK_1 0x12 94 #define BALANCER5_REG_CHARGER_MASK_2 0x13 95 #define BALANCER5_REG_FAULT_MASK 0x14 96 #define BALANCER5_REG_ADC_CTRL 0x15 97 #define BALANCER5_REG_ADC_FUNCTION_DISABLE 0x16 98 #define BALANCER5_REG_IBUS_ADC1 0x17 99 #define BALANCER5_REG_IBUS_ADC0 0x18 100 #define BALANCER5_REG_ICHG_ADC1 0x19 101 #define BALANCER5_REG_ICHG_ADC0 0x1A 102 #define BALANCER5_REG_VBUS_ADC1 0x1B 103 #define BALANCER5_REG_VBUS_ADC0 0x1C 104 #define BALANCER5_REG_VBAT_ADC1 0x1D 105 #define BALANCER5_REG_VBAT_ADC0 0x1E 106 #define BALANCER5_REG_VCELLTOP_ADC1 0x1F 107 #define BALANCER5_REG_VCELLTOP_ADC0 0x20 108 #define BALANCER5_REG_TS_ADC1 0x21 109 #define BALANCER5_REG_TS_ADC0 0x22 110 #define BALANCER5_REG_TDIE_ADC1 0x23 111 #define BALANCER5_REG_TDIE_ADC0 0x24 112 #define BALANCER5_REG_PART_INFO 0x25 113 #define BALANCER5_REG_VCELLBOT_ADC1 0x26 114 #define BALANCER5_REG_VCELLBOT_ADC0 0x27 115 #define BALANCER5_REG_CELL_BALANCING_CTRL1 0x28 116 #define BALANCER5_REG_CELL_BALANCING_CTRL2 0x29 117 #define BALANCER5_REG_CELL_BALANCING_STATUS_N_CNTRL 0x2A 118 #define BALANCER5_REG_CELL_BALANCING_FLAG 0x2B 119 #define BALANCER5_REG_CELL_BALANCING_MASK 0x2C 126 #define BALANCER5_ERROR_ID 0xAA 127 #define BALANCER5_SUCCESSFUL 0xFF 134 #define BALANCER5_DEVICE_ID 0x29 140 #define BALANCER5_PIN_STATUS_HIGH 1 141 #define BALANCER5_PIN_STATUS_LOW 0 147 #define BALANCER5_CHARGE_OFF 1 148 #define BALANCER5_CHARGE_ON 0 154 #define BALANCER5_ADC_CTRL_ENABLE 0x80 155 #define BALANCER5_ADC_CTRL_DISABLE 0x00 156 #define BALANCER5_ADC_CTRL_CONT_CONV 0x00 157 #define BALANCER5_ADC_CTRL_ONE_SHOT_CONV 0x40 158 #define BALANCER5_ADC_CTRL_15BIT_RES 0x00 159 #define BALANCER5_ADC_CTRL_14BIT_RES 0x10 160 #define BALANCER5_ADC_CTRL_13BIT_RES 0x20 161 #define BALANCER5_ADC_CTRL_12BIT_RES 0x30 167 #define BALANCER5_CS1_IINDPM_NORMAL 0x00 168 #define BALANCER5_CS1_IINDPM_IN_REGULATION 0x40 169 #define BALANCER5_CS1_VINDPM_NORMAL 0x00 170 #define BALANCER5_CS1_VINDPM_IN_REGULATION 0x20 171 #define BALANCER5_CS1_IC_NORMAL 0x00 172 #define BALANCER5_CS1_IC_IN_THERMAL_REGULATION 0x10 173 #define BALANCER5_CS1_WD_NORMAL 0x00 174 #define BALANCER5_CS1_WD_TIMER_EXPIRED 0x08 175 #define BALANCER5_CS1_NOT_CHARGING 0x00 176 #define BALANCER5_CS1_TRICKLE_CHARGE 0x01 177 #define BALANCER5_CS1_PRE_CHARGE 0x02 178 #define BALANCER5_CS1_FAST_CHARGE 0x03 179 #define BALANCER5_CS1_TAPER_CHARGE 0x04 180 #define BALANCER5_CS1_TOP_OFF_TIMER_CHARGE 0x05 181 #define BALANCER5_CS1_CHARGE_TERMINATION 0x06 187 #define BALANCER5_CS2_POWER_GOOD 0x80 188 #define BALANCER5_CS2_POWER_NOT_GOOD 0x00 189 #define BALANCER5_CS2_NO_INPUT 0x00 190 #define BALANCER5_CS2_USB_HOST_SDP 0x10 191 #define BALANCER5_CS2_USB_CDP 0x20 192 #define BALANCER5_CS2_ADAPTER 0x30 193 #define BALANCER5_CS2_POORSRC 0x40 194 #define BALANCER5_CS2_UNKNOWN_ADAPTER 0x50 195 #define BALANCER5_CS2_NON_STANDARD_ADAPTER 0x60 196 #define BALANCER5_CS2_ICO_DISABLED 0x00 197 #define BALANCER5_CS2_ICO_OPTIMIZATION_IN_PROGRESS 0x02 198 #define BALANCER5_CS2_MAX_INPUT 0x04 204 #define BALANCER5_SLAVE_ADDRESS 0x6A 418 #endif // _BALANCER5_H_ void balancer5_generic_write(balancer5_t *ctx, uint8_t reg, uint8_t *data_buf, uint8_t len)
Generic write function.
digital_in_t int_pin
Definition: balancer5.h:229
pin_name_t cd
Definition: balancer5.h:255
Click configuration structure definition.
Definition: balancer5.h:244
digital_in_t pg
Definition: balancer5.h:227
void balancer5_generic_read(balancer5_t *ctx, uint8_t reg, uint8_t *data_buf, uint8_t len)
Generic read function.
uint8_t balancer5_check_id(balancer5_t *ctx)
Checks if device ID is good.
void balancer5_cfg_setup(balancer5_cfg_t *cfg)
Config Object Initialization function.
pin_name_t sda
Definition: balancer5.h:249
uint8_t slave_address
Definition: balancer5.h:237
uint8_t balancer5_get_power_good_status(balancer5_t *ctx)
Gets state of the pg pin on an.
Click ctx object definition.
Definition: balancer5.h:218
#define BALANCER5_RETVAL
Definition: balancer5.h:66
void balancer5_charge(balancer5_t *ctx, uint8_t state)
Function for setting charging status.
uint32_t i2c_speed
Definition: balancer5.h:260
digital_in_t pss
Definition: balancer5.h:228
i2c_master_t i2c
Definition: balancer5.h:233
uint8_t balancer5_get_power_source_status(balancer5_t *ctx)
Gets state of the psel pin on rst.
BALANCER5_RETVAL balancer5_init(balancer5_t *ctx, balancer5_cfg_t *cfg)
Initialization function.
pin_name_t pg
Definition: balancer5.h:253
uint8_t balancer5_get_int_status(balancer5_t *ctx)
Gets state of the int pin.
pin_name_t int_pin
Definition: balancer5.h:256
pin_name_t scl
Definition: balancer5.h:248
uint8_t balancer5_read_data(balancer5_t *ctx, uint8_t reg_addr)
Generic function for reading one Byte data from registar.
void balancer5_default_cfg(balancer5_t *ctx)
Click Default Configuration function.
void balancer5_write_data(balancer5_t *ctx, uint8_t reg_addr, uint8_t write_data)
Generic function for writing one Byte data to registar.
pin_name_t pss
Definition: balancer5.h:254
digital_out_t cd
Definition: balancer5.h:222
uint8_t i2c_address
Definition: balancer5.h:261