1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-15 14:32:43 +01:00
RIOT/drivers/include/lc709203f.h

389 lines
13 KiB
C

/*
* Copyright (C) 2017 RWTH Aachen
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @defgroup drivers_lc709203f LC709203F
* @ingroup drivers_sensors
* @brief Device driver interface for the LC709203F Battery Fuel Gauge
* @{
*
* @file
* @brief Device driver interface for the LC709203F Battery Fuel Gauge
*
* @author Steffen Robertz <steffen.robertz@rwth-aachen.de>
* @author Josua Arndt <jarndt@ias.rwth-aachen.de>
*/
#ifndef LC709203F_H
#define LC709203F_H
#ifdef __cplusplus
extern "C" {
#endif
#include "periph/i2c.h"
#include "periph/gpio.h"
/**
* @brief Current direction modes
* @details For more details please see the datasheet (http://www.onsemi.com/pub/Collateral/LC709203F-D.PDF)
* @{
*/
typedef enum {
AUTO_MODE = 0x0,
CHARGE_MODE = 0x1,
DISCHARGE_MODE = 0xffff
} lc709203f_current_direction_t;
/** @} */
/**
* @brief Battery Profile Options
* @details For more details please see the datasheet (http://www.onsemi.com/pub/Collateral/LC709203F-D.PDF)
* @{
*/
typedef enum {
BAT_PROFILE_1 = 0,
BAT_PROFILE_2 = 1
} lc709203f_battery_profile_t;
/** @} */
/**
* @brief Power mode choices
* @details For more details please see the datasheet (http://www.onsemi.com/pub/Collateral/LC709203F-D.PDF)
* @{
*/
typedef enum {
OPERATIONAL_MODE = 1,
SLEEP_MODE = 2
} lc709203f_power_mode_t;
/** @} */
/**
* @brief Temperature obtaining mode options
* @details For more details please see the datasheet (http://www.onsemi.com/pub/Collateral/LC709203F-D.PDF)
* @{
*/
typedef enum {
I2C_MODE = 0,
THERMISTOR_MODE = 1
} lc709203f_temp_obtaining_mode_t;
/** @} */
/**
* @brief Typedef for the Callback function
* @details A function of this type will be called when an Interrupt is triggered on low RSOC or Voltage
* @param[in] arg Additional Arguments that will be passed to the function
*/
typedef void (*lc709203f_cb_t)(void *arg);
/**
* @brief Parameter struct for driver initialization
* @{
*/
typedef struct {
gpio_t alarm_pin; /**< Pin which is connected to the interrupt pin of the sensor */
i2c_t bus; /**< I2C bus to use */
uint8_t addr; /**< I2C Address of the fuel gauge */
} lc709203f_params_t;
/** @} */
enum {
LC709203F_OK = 0, /**< all went as expected */
LC709203F_NOI2C = -1, /**< error using the I2C bus */
LC709203F_CELL_TEMP_INVALID = -2 /**< Cell temp invalid */
};
/**
* @brief Device descriptor for the fuel gauge
* @details This struct will hold all information and configuration for the sensor
* @{
*/
typedef struct {
i2c_t bus; /**< I2C bus to use */
uint8_t addr; /**< I2C Address of fuel gauge */
uint8_t scale; /**< scale for returned values */
lc709203f_params_t params; /**< param struct with static settings etc*/
lc709203f_cb_t cb; /**< callback method*/
void *arg; /**< additional arguments for the callback method*/
} lc709203f_t;
/** @} */
/**
* @brief Register Addresses
* @details For more information on the registers and its functions see the datasheet
* @{
*/
#define LC709203F_REG_CELL_VOLTAGE 0x09 /**< Register Cell Voltage */
#define LC709203F_REG_RSOC 0x0d /**< Register RSOC (Relative State of Charge) */
#define LC709203F_REG_ITE 0x0f /**< Register ITE (Indicator To Empty) */
#define LC709203F_REG_ID 0x11 /**< Register IC Version */
#define LC709203F_REG_CELL_TEMP 0x08 /**< Register Cell Temperature */
#define LC709203F_REG_STATUS 0x16 /**< Register Status Bit */
#define LC709203F_REG_POWER_MODE 0x15 /**< Register IC Power Mode */
#define LC709203F_REG_ALARM_VOLTAGE 0x14 /**< Register Alarm Low Cell Voltage */
#define LC709203F_REG_ALARM_RSOC 0x13 /**< Register Alarm Low RSOC */
#define LC709203F_REG_CHANGE_PARAMETER 0x12 /**< Register Change of the parameter */
#define LC709203F_REG_APT 0x0c /**< Register APT (Adjustment Pack Thermistor) */
#define LC709203F_REG_APA 0x0b /**< Register APA (Adjustment Pack Application) */
#define LC709203F_REG_CURRENT_DIRECTION 0x0a /**< Register Current Direction */
#define LC709203F_REG_THERMISTOR 0x06 /**< Register Thermistor B */
#define LC709203F_REG_BEFORE_RSOC 0x04 /**< Register Before RSOC */
#define LC709203F_REG_INITIAL_RSOC 0x07 /**< Register Initial RSOC */
/** @} */
#define LC709203F_CRC_POLYNOMIAL 0x07 /**< CRC Polynomial */
/**
* @brief initializes the sensor and i2c
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
* @param[in] *params pointer to lc709203f_param_t struct containing the interrupt pin and callback
*
* @return LC709203F_OK on a working initialization
* @return LC709203F_NOI2C on undefined i2c device given in periph_conf
*/
int lc709203f_init(lc709203f_t *dev, const lc709203f_params_t *params);
/**
* @brief reads battery voltage from Sensor
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*
* @return voltage in mV
*/
int16_t lc709203f_get_voltage(const lc709203f_t *dev);
/**
* @brief reads battery state of charge from Sensor
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*
* @return rsoc in %
*/
int16_t lc709203f_get_rsoc(const lc709203f_t *dev);
/**
* @brief reads battery indicator to empty from Sensor
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*
* @return ite in 0.1%
*/
int16_t lc709203f_get_ite(const lc709203f_t *dev);
/**
* @brief reads Sensor id
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*
* @return id value
*/
int16_t lc709203f_get_id(const lc709203f_t *dev);
/**
* @brief reads cell temperature from sensor
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*
* @return temp in 0.1°C steps
*/
int16_t lc709203f_get_cell_temp(const lc709203f_t *dev);
/**
* @brief reads status bit register (Temperature obtaining mode)
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*
* @return THERMISTOR_MODE Thermistor mode
* @return I2C_MODE I2C Mode
*/
lc709203f_temp_obtaining_mode_t lc709203f_get_status_bit(const lc709203f_t *dev);
/**
* @brief reads IC Power Mode register
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*
* @return OPERATIONAL_MODE Operational Mode
* @return SLEEP_MODE Sleep mode
*/
lc709203f_power_mode_t lc709203f_get_power_mode(const lc709203f_t *dev);
/**
* @brief reads Alarm Low Cell Voltage Register
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*
* @return 0 Disable
* @return Threshold value in 1mV steps
*/
int16_t lc709203f_get_alarm_low_voltage(const lc709203f_t *dev);
/**
* @brief reads Alarm Low RSOC Register
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*
* @return 0 Disable
* @return Threshold value in %
*/
int16_t lc709203f_get_alarm_low_rsoc(const lc709203f_t *dev);
/**
* @brief reads Change of the Parameter register, Battery Profile selection
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*
* @return Battery profile number (1 or 0)
*/
int16_t lc709203f_get_change_of_parameter(const lc709203f_t *dev);
/**
* @brief reads APT (Adjustment Pack Thermistor)
* value to adjust temperature measurement delay timing.
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*
* @return value to adjust temperature measurement delay timing.
*/
int16_t lc709203f_get_apt(const lc709203f_t *dev);
/**
* @brief reads APA (Adjustment Pack Application) in 1mOhm steps
* value to adjust temperature measurement delay timing.
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*
* @return parasitic impedance
*/
int16_t lc709203f_get_apa(const lc709203f_t *dev);
/**
* @brief reads Current Direction Register
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*
* @return AUTO_MODE Auto mode
* @return CHARGE_MODE charge mode
* @return DISCHARGE_MODE Discharge mode
*/
lc709203f_current_direction_t lc709203f_get_current_direction(const lc709203f_t *dev);
/**
* @brief reads Thermistor-B register (Thermistor B constant to be measured)
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*
* @return B Value in 1K steps
*/
int16_t lc709203f_get_thermistor_b(const lc709203f_t *dev);
/**
* @brief Executes RSOC initialization with sampled maximum voltage
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*/
void lc709203f_set_rsoc_before(const lc709203f_t *dev);
/**
* @brief Sets B constant of the Thermistor
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
* @param[in] value Bconstant of thermistor
*/
void lc709203f_set_thermistor_b(const lc709203f_t *dev, const unsigned int value);
/**
* @brief Executes RSOC initialization
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
*/
void lc709203f_set_rsoc_initial(const lc709203f_t *dev);
/**
* @brief Sets cell temperature in I2C-mode
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
* @param[in] value temp in 0.1K 0xAAC=0°C
*
* @return LC709203F_CELL_TEMP_INVALID Invalid cell temp
*/
int8_t lc709203f_set_cell_temp(const lc709203f_t *dev, const unsigned int value);
/**
* @brief Sets current direction
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
* @param[in] direction current direction, AUTO_MODE, CHARGE_MODE, DISCHARGE_MODE
*/
void lc709203f_set_current_direction(const lc709203f_t *dev, const lc709203f_current_direction_t direction);
/**
* @brief Sets parasitic impedance (adjustment pack application)
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
* @param[in] value impedance in 1mOhm steps
*/
void lc709203f_set_apa(const lc709203f_t *dev, const uint8_t value);
/**
* @brief Sets value to adjust temperature measurement delay timing (adjusmtent pack thermistor)
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
* @param[in] value adjustment value
*/
void lc709203f_set_apt(const lc709203f_t *dev, const unsigned int value);
/**
* @brief Sets battery profile
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
* @param[in] value profile (enum) BAT_PROFILE_1 BAT_PROFILE_2
*/
void lc709203f_set_change_of_parameter(const lc709203f_t *dev, const lc709203f_battery_profile_t value);
/**
* @brief Sets threshold for low rsoc alert
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
* @param[in] value alert threshold (0-100%)
*/
void lc709203f_set_alarm_low_rsoc(const lc709203f_t *dev, const uint8_t value);
/**
* @brief Sets threshold for low cell voltage alert
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
* @param[in] value alert threshold in 1mV steps
*/
void lc709203f_set_alarm_low_cell_voltage(const lc709203f_t *dev, const unsigned int value);
/**
* @brief Sets power mode
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
* @param[in] value Power mode (enum) OPERATIONAL_MODE, SLEEP_MODE
*/
void lc709203f_set_power_mode(const lc709203f_t *dev, const lc709203f_power_mode_t value);
/**
* @brief Sets temperature obtaining method
*
* @param[in] *dev pointer to lc709203f_t struct containing the i2c device and the address
* @param[in] value method to be used (enum) I2C_MODE, THERMISTOR_MODE
*/
void lc709203f_set_status_bit(const lc709203f_t *dev, const lc709203f_temp_obtaining_mode_t value);
#ifdef __cplusplus
}
#endif
#endif /* LC709203F_H */
/** @} */