use batmon in battery_sensor

This commit is contained in:
Harald Pichler 2013-08-20 13:34:01 +02:00
parent ae732f4636
commit cead1c7ce0
3 changed files with 15 additions and 11 deletions

View file

@ -12,7 +12,7 @@ CONTIKI_TARGET_SOURCEFILES += dht11.c
#Needed for DS18S20 temperature sensor #Needed for DS18S20 temperature sensor
CONTIKI_TARGET_SOURCEFILES += ds1820.c CONTIKI_TARGET_SOURCEFILES += ds1820.c
#Needed for Battery test #Needed for Battery test
CONTIKI_TARGET_SOURCEFILES += battery-sensor.c CONTIKI_TARGET_SOURCEFILES += battery-sensor.c batmon.c
#Needed for PIR #Needed for PIR
CONTIKI_TARGET_SOURCEFILES += pir-sensor.c CONTIKI_TARGET_SOURCEFILES += pir-sensor.c
#Needed for OPTRIAC #Needed for OPTRIAC

View file

@ -17,10 +17,10 @@ int8_t batmon_get_voltage(uint16_t* voltage)
uint16_t offset = 2550; uint16_t offset = 2550;
int8_t ctr = 0; int8_t ctr = 0;
BATMON = 0 | BV(BATMON_HR); BATMON = 0 | _BV(BATMON_HR);
_delay_us(2); _delay_us(2);
if(BATMON & BV(BATMON_OK)) if(BATMON & _BV(BATMON_OK))
{ {
// voltage above 2.550 V // voltage above 2.550 V
resolution = 75; resolution = 75;
@ -29,7 +29,7 @@ int8_t batmon_get_voltage(uint16_t* voltage)
{ {
BATMON = (BATMON & 0xF0) | (ctr); BATMON = (BATMON & 0xF0) | (ctr);
_delay_us(2); _delay_us(2);
if(BATMON & BV(BATMON_OK)) break; if(BATMON & _BV(BATMON_OK)) break;
} }
} }
else else
@ -38,13 +38,13 @@ int8_t batmon_get_voltage(uint16_t* voltage)
resolution = 50; resolution = 50;
offset = 1700; offset = 1700;
BATMON &= ~BV(BATMON_HR); BATMON &= ~_BV(BATMON_HR);
for(ctr=15; ctr>=0; ctr--) for(ctr=15; ctr>=0; ctr--)
{ {
BATMON = (BATMON & 0xF0) | (ctr); BATMON = (BATMON & 0xF0) | (ctr);
_delay_us(2); _delay_us(2);
if(BATMON & BV(BATMON_OK)) break; if(BATMON & _BV(BATMON_OK)) break;
} }
} }

View file

@ -42,6 +42,7 @@
*/ */
#include "dev/battery-sensor.h" #include "dev/battery-sensor.h"
#include "dev/batmon.h"
const struct sensors_sensor battery_sensor; const struct sensors_sensor battery_sensor;
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
@ -52,20 +53,22 @@ const struct sensors_sensor battery_sensor;
static int static int
value(int type) value(int type)
{ {
uint16_t h; uint16_t h;
/*
uint8_t p1; uint8_t p1;
BATMON = 16; //give BATMON time to stabilize at highest range and lowest voltage BATMON = 16; //give BATMON time to stabilize at highest range and lowest voltage
/* Bandgap can't be measured against supply voltage in this chip. */ // Bandgap can't be measured against supply voltage in this chip.
/* Use BATMON register instead */ // Use BATMON register instead
for ( p1=16; p1<31; p1++) { for ( p1=16; p1<31; p1++) {
BATMON = p1; BATMON = p1;
clock_delay_usec(100); // delay needed !! clock_delay_usec(100); // delay needed !!
if ((BATMON&(1<<BATMON_OK))==0) break; if ((BATMON&(1<<BATMON_OK))==0) break;
} }
h=2550-75*16-75+75*p1; //-75 to take the floor of the 75 mv transition window h=2550-75*16-75+75*p1; //-75 to take the floor of the 75 mv transition window
*/
batmon_get_voltage(&h);
return h; return h;
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
@ -73,6 +76,7 @@ static int
configure(int type, int c) configure(int type, int c)
{ {
// No configuration needed. readADC() handles all the config needed. // No configuration needed. readADC() handles all the config needed.
batmon_init();
return type == SENSORS_ACTIVE; return type == SENSORS_ACTIVE;
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
@ -83,4 +87,4 @@ status(int type)
return 1; return 1;
} }
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
SENSORS_SENSOR(battery_sensor, BATTERY_SENSOR, value, configure, status); SENSORS_SENSOR(battery_sensor, BATTERY_SENSOR, value, configure, status);