2020-12-02 13:47:13 +03:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
|
|
|
|
#define BQ27220_ERROR 0x0
|
|
|
|
#define BQ27220_SUCCESS 0x1
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
// Low byte, Low bit first
|
2021-03-10 16:23:54 +03:00
|
|
|
bool DSG : 1; // The device is in DISCHARGE
|
|
|
|
bool SYSDWN : 1; // System down bit indicating the system should shut down
|
|
|
|
bool TDA : 1; // Terminate Discharge Alarm
|
|
|
|
bool BATTPRES : 1; // Battery Present detected
|
|
|
|
bool AUTH_GD : 1; // Detect inserted battery
|
|
|
|
bool OCVGD : 1; // Good OCV measurement taken
|
|
|
|
bool TCA : 1; // Terminate Charge Alarm
|
|
|
|
bool RSVD : 1; // Reserved
|
2020-12-02 13:47:13 +03:00
|
|
|
// High byte, Low bit first
|
2021-03-10 16:23:54 +03:00
|
|
|
bool CHGINH : 1; // Charge inhibit
|
|
|
|
bool FC : 1; // Full-charged is detected
|
|
|
|
bool OTD : 1; // Overtemperature in discharge condition is detected
|
|
|
|
bool OTC : 1; // Overtemperature in charge condition is detected
|
|
|
|
bool SLEEP : 1; // Device is operating in SLEEP mode when set
|
|
|
|
bool OCVFAIL : 1; // Status bit indicating that the OCV reading failed due to current
|
|
|
|
bool OCVCOMP : 1; // An OCV measurement update is complete
|
|
|
|
bool FD : 1; // Full-discharge is detected
|
2020-12-02 13:47:13 +03:00
|
|
|
} BatteryStatus;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
// Low byte, Low bit first
|
2021-03-10 16:23:54 +03:00
|
|
|
bool CALMD : 1;
|
|
|
|
bool SEC0 : 1;
|
|
|
|
bool SEC1 : 1;
|
|
|
|
bool EDV2 : 1;
|
|
|
|
bool VDQ : 1;
|
|
|
|
bool INITCOMP : 1;
|
|
|
|
bool SMTH : 1;
|
|
|
|
bool BTPINT : 1;
|
2020-12-02 13:47:13 +03:00
|
|
|
// High byte, Low bit first
|
2021-03-10 16:23:54 +03:00
|
|
|
uint8_t RSVD1 : 2;
|
|
|
|
bool CFGUPDATE : 1;
|
|
|
|
uint8_t RSVD0 : 5;
|
2020-12-02 13:47:13 +03:00
|
|
|
} OperationStatus;
|
|
|
|
|
2021-03-24 12:35:33 +03:00
|
|
|
/** Initialize Driver */
|
2020-12-02 13:47:13 +03:00
|
|
|
void bq27220_init();
|
|
|
|
|
2021-03-24 12:35:33 +03:00
|
|
|
/** Get battery voltage in mV or error */
|
2020-12-02 13:47:13 +03:00
|
|
|
uint16_t bq27220_get_voltage();
|
|
|
|
|
2021-03-24 12:35:33 +03:00
|
|
|
/** Get current in mA or error*/
|
2020-12-02 13:47:13 +03:00
|
|
|
int16_t bq27220_get_current();
|
|
|
|
|
2021-03-24 12:35:33 +03:00
|
|
|
/** Get battery status */
|
2020-12-02 13:47:13 +03:00
|
|
|
uint8_t bq27220_get_battery_status(BatteryStatus* battery_status);
|
|
|
|
|
2021-03-24 12:35:33 +03:00
|
|
|
/** Get operation status */
|
2020-12-02 13:47:13 +03:00
|
|
|
uint8_t bq27220_get_operation_status(OperationStatus* operation_status);
|
|
|
|
|
2021-03-24 12:35:33 +03:00
|
|
|
/** Get temperature in units of 0.1°K */
|
2020-12-02 13:47:13 +03:00
|
|
|
uint16_t bq27220_get_temperature();
|
|
|
|
|
2021-03-24 12:35:33 +03:00
|
|
|
/** Get compensated full charge capacity in in mAh */
|
2020-12-02 13:47:13 +03:00
|
|
|
uint16_t bq27220_get_full_charge_capacity();
|
|
|
|
|
2021-03-24 12:35:33 +03:00
|
|
|
/** Get remaining capacity in in mAh */
|
2020-12-02 13:47:13 +03:00
|
|
|
uint16_t bq27220_get_remaining_capacity();
|
|
|
|
|
2021-03-24 12:35:33 +03:00
|
|
|
/** Get predicted remaining battery capacity in percents */
|
2020-12-02 13:47:13 +03:00
|
|
|
uint16_t bq27220_get_state_of_charge();
|
2021-03-02 19:07:26 +03:00
|
|
|
|
2021-03-24 12:35:33 +03:00
|
|
|
/** Get ratio of full charge capacity over design capacity in percents */
|
2021-03-02 19:07:26 +03:00
|
|
|
uint16_t bq27220_get_state_of_health();
|