1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/tests/driver_ina2xx/main.c
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

105 lines
2.7 KiB
C

/*
* Copyright (C) 2015 Eistec AB
*
* 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 tests
* @{
*
* @file
* @brief Test application for the INA2XX sensor driver
*
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
* @author Marian Buschsieweke <marian.buschsieweke@ovgu.de>
*
* @}
*/
#include <errno.h>
#include <stdlib.h>
#include "fmt.h"
#include "fmt_table.h"
#include "ina2xx.h"
#include "ina2xx_params.h"
int main(void)
{
ina2xx_t dev;
print_str("INA2XX sensor driver test application\n\n");
print_str("Initializing INA2XX sensor at I2C_");
print_s32_dec(ina2xx_params[0].i2c);
print_str(", address 0x");
print_u32_hex(ina2xx_params[0].addr);
print_str("\n");
if (ina2xx_init(&dev, &ina2xx_params[0]) == 0) {
print_str("[OK]\n");
} else {
print_str("[Failed]\n");
return EXIT_FAILURE;
}
const char *line = "+------------+--------------+----------+--------+\n";
print_str(line);
print_str("| U_Bus [mV] | U_Shunt [µV] | I [µA] | P [µW] |\n");
print_str(line);
while (1) {
uint16_t u_bus;
int16_t u_shunt;
int32_t i_shunt;
uint32_t p;
/* Read bus voltage until flag indicates new value is present */
switch (ina2xx_read_bus(&dev, &u_bus)){
case 0:
/* No measurement available yet */
continue;
case 1:
/* New measurement available, continue */
break;
case -EDOM:
print_str("[WARNING]: INA2xx detected math overflow ==> data "
"will be incorrect\n");
break;
default:
/* Error */
print_str("Error while reading bus voltage\n");
return EXIT_FAILURE;
}
if (ina2xx_read_shunt(&dev, &u_shunt) < 0) {
print_str("Error while reading shunt voltage\n");
return EXIT_FAILURE;
}
if (ina2xx_read_current(&dev, &i_shunt) < 0) {
print_str("Error while reading current\n");
return EXIT_FAILURE;
}
if (ina2xx_read_power(&dev, &p) < 0) {
print_str("Error while reading power\n");
return EXIT_FAILURE;
}
print_str("| ");
print_col_u32_dec(u_bus, 10);
print_str(" | ");
print_col_s32_dec(10 * (int32_t)u_shunt, 12);
print_str(" | ");
print_col_s32_dec(10 * i_shunt, 8);
print_str(" | ");
print_col_u32_dec(100 * p, 6);
print_str(" |\n");
}
return 0;
}