1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 01:52:45 +01:00
RIOT/drivers/ina2xx/include/ina2xx_defines.h
Marian Buschsieweke a6476bd813
drivers/ina2xx: Match RIOT's driver design goals
- Use standard RIOT style `ina2xx_params_t` on initialization as explained in
  [1] instead of a custom API
- Provided a default configuration via `ina2xx_params_t` as required by [1] that
  works fine for the INA219 breakout board and with an optimal resolution that
  still covers the whole range of USB high-power devices (500 mA @ 5V) with a
  comfortable safe margin.
- Changed initialization procedure to include a device reset and connectivity
  test, as required by [1]
- The calibration value is now calculated by the driver
    - This simplifies using the driver a lot
    - The user can still choose a trade-off between range and resolution that
      matches the application requirements, but now among predefined values
    - This allows the driver to easily convert the raw data into meaningful
      physical data, as the resolution of the raw data is known
- All measurements are provided as meaningful physical data as required by [1]

[1]: https://github.com/RIOT-OS/RIOT/wiki/Guide:-Writing-a-device-driver-in-RIOT
2019-11-22 20:28:57 +01:00

67 lines
1.8 KiB
C

/*
* Copyright (C) 2015 Eistec AB
* 2019 Otto-von-Guericke-Universität Magdeburg
*
* 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.
*/
/**
* @ingroup drivers_ina2xx
* @{
*
* @file
* @brief Various definitions for Texas Instruments INA219/INA220
* Bi-Directional CURRENT/POWER MONITOR with Two-Wire Interface
*
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
* @author Marian Buschsieweke <marian.buschsieweke@ovgu.de>
*/
#ifndef INA2XX_DEFINES_H
#define INA2XX_DEFINES_H
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief INA2XX register addresses
*
* All registers in the INA2XX are 16 bit wide and transmitted MSB first.
*/
typedef enum ina2xx_reg {
INA2XX_REG_CONFIGURATION = 0x00, /**< Configuration register (read/write) */
INA2XX_REG_SHUNT_VOLTAGE = 0x01, /**< Shunt voltage register (read only) */
INA2XX_REG_BUS_VOLTAGE = 0x02, /**< Bus voltage register (read only) */
INA2XX_REG_POWER = 0x03, /**< Power register (read only) */
INA2XX_REG_CURRENT = 0x04, /**< Current register (read only) */
INA2XX_REG_CALIBRATION = 0x05, /**< Calibration register (read/write) */
} ina2xx_reg_t;
/**
* @name Flags in the INA2XX Bus Voltage Register
* @{
*/
#define INA2XX_VBUS_CNVR (0x2) /**< Unread value in power register ready */
#define INA2XX_VBUS_OVF (0x1) /**< Math overflow during conversion */
/** @} */
/**
* @name Special configuration register values
* @{
*/
#define INA2XX_RESET (0x8000)/**< Write to config reg to reset device */
#define INA2XX_DEFCONFIG (0x399f)/**< Default config after reset */
/** @} */
#ifdef __cplusplus
}
#endif
#endif /* INA2XX_DEFINES_H */
/** @} */