X-Git-Url: http://www.average.org/gitweb/?p=pulsecounter.git;a=blobdiff_plain;f=Pulsecounter-Prog.c;h=331dbf5366af78b29b9d5f79612c5b24d8132704;hp=f5071784b56c41126d9d58559242d7bf0ea0b090;hb=440f8b92b68c9829d1b9ccf274db5f53fb4e0de7;hpb=13db6cae32995a2f76fb4b4f1c5f40cea2470a55 diff --git a/Pulsecounter-Prog.c b/Pulsecounter-Prog.c index f507178..331dbf5 100644 --- a/Pulsecounter-Prog.c +++ b/Pulsecounter-Prog.c @@ -1,35 +1,61 @@ #include "Pulsecounter.h" #include "Hal.h" -static void buttonHandler(void); +static void gpioHandler(uint8_t id); static void tickHandler(void); static bool connected = false; -static int32_t buttonCnt = 0; +static int32_t base4 = 0; +static int32_t base5 = 0; +static int32_t event4 = 0; +static int32_t event5 = 0; void main() { Hal_init(); - Hal_buttonEnable(buttonHandler); + Hal_gpioEnable(gpioHandler); Pulsecounter_setDeviceName("PULS-CNTR"); Pulsecounter_start(); Hal_idleLoop(); } -static void buttonHandler(void) { +static void gpioHandler(uint8_t id) { uint8_t i; - buttonCnt++; - if (connected) - Pulsecounter_event3_indicate(); - else + switch (id) { + case 0: Pulsecounter_accept(true); - for (i = 0; i < 3; i++) { + Hal_greenLedOn(); + Hal_redLedOn(); + Hal_delay(10); + Hal_greenLedOff(); + Hal_redLedOff(); + Hal_tickStart(5000, tickHandler); + break; + case 1: + event4++; + if (connected) + Pulsecounter_event4_indicate(); Hal_greenLedOn(); - Hal_redLedOn(); Hal_delay(10); Hal_greenLedOff(); + break; + case 2: + event5++; + if (connected) + Pulsecounter_event5_indicate(); + Hal_redLedOn(); + Hal_delay(10); Hal_redLedOff(); + break; + default: + for (i = 0; i < 5; i++) { + Hal_greenLedOn(); + Hal_redLedOn(); + Hal_delay(10); + Hal_greenLedOff(); + Hal_redLedOff(); + Hal_delay(10); + } } - Hal_tickStart(5000, tickHandler); } static void tickHandler(void) { @@ -75,14 +101,26 @@ void Pulsecounter_disconnectHandler(void) { Hal_disconnected(); } -void Pulsecounter_event3_fetch(Pulsecounter_event3_t* const output) { - *output = buttonCnt; -} - void Pulsecounter_event4_fetch(Pulsecounter_event4_t* const output) { - *output = 4; + *output = base4 + event4; } void Pulsecounter_event5_fetch(Pulsecounter_event5_t* const output) { - *output = 5; + *output = base5 + event5; +} + +void Pulsecounter_base4_fetch(Pulsecounter_base4_t* const output) { + *output = base4; +} + +void Pulsecounter_base4_store(Pulsecounter_base4_t* const input) { + base4 = *input - event4; +} + +void Pulsecounter_base5_fetch(Pulsecounter_base5_t* const output) { + *output = base5; +} + +void Pulsecounter_base5_store(Pulsecounter_base5_t* const input) { + base5 = *input - event5; }