X-Git-Url: https://www.fi.muni.cz/~kas/git//home/kas/public_html/git/?p=bike-lights.git;a=blobdiff_plain;f=firmware%2Fambient.c;h=02377ccd46586ab1895083adeb09dbda77ff50e5;hp=f62620862df49538a5a5ab282fb01d1168ec6f9e;hb=65c3ad96cf307c3b77b36e6f6a2af5201c213a3c;hpb=541892c2955660bdd068dc7bc0a2611592f408d7 diff --git a/firmware/ambient.c b/firmware/ambient.c index f626208..02377cc 100644 --- a/firmware/ambient.c +++ b/firmware/ambient.c @@ -1,10 +1,18 @@ #include +#include #include "lights.h" -#define AMBIENT_VAL_SHIFT 3 +#define AMBIENT_VAL_SHIFT 2 static uint16_t ambient_val; volatile unsigned char ambient_zone; +static unsigned char ambient_min, ambient_max; + +/* logging */ +#define AMBIENT_LOG_SIZE 128 +static unsigned char ambient_log_offset_stored EEMEM; +static unsigned char ambient_log_offset; +static unsigned char ambient_log[AMBIENT_LOG_SIZE] EEMEM; /* My photodiode reads 0x00C5 .. 0x033B */ typedef struct { @@ -16,17 +24,48 @@ typedef struct { * and having small overlaps in order to provide a bit of hysteresis. */ static ambient_zone_t ambient_zones[] = { - { 0x0000 , 0x0290<= AMBIENT_LOG_SIZE - 1) + return; + + eeprom_write_byte(&ambient_log[ambient_log_offset++], ambient_min); + eeprom_write_byte(&ambient_log[ambient_log_offset++], ambient_max); + + ambient_min = 0xFF; + ambient_max = 0; } void ambient_zone_changed() @@ -46,6 +85,7 @@ void ambient_zone_changed() void ambient_adc(uint16_t adcval) { unsigned char old_zone = ambient_zone; + unsigned char byte_val; ambient_val += adcval - (ambient_val >> (AMBIENT_VAL_SHIFT - AMBIENT_ADC_SHIFT)); @@ -56,6 +96,13 @@ void ambient_adc(uint16_t adcval) while (ambient_zones[ambient_zone].hi < ambient_val) ambient_zone++; + byte_val = adcval >> 2; + + if (ambient_min > byte_val) + ambient_min = byte_val; + + if (ambient_max < byte_val) + ambient_max = byte_val; #if 0 if (old_zone != ambient_zone) { log_byte(0xab);