X-Git-Url: http://www.average.org/gitweb/?p=pulsecounter.git;a=blobdiff_plain;f=Pulsecounter-Prog.c;h=331dbf5366af78b29b9d5f79612c5b24d8132704;hp=d5170af1a5adc722a38b1d86ef05883570e6ac85;hb=440f8b92b68c9829d1b9ccf274db5f53fb4e0de7;hpb=4639a1ba298618c2a617ca4428cae14c6a531ae3 diff --git a/Pulsecounter-Prog.c b/Pulsecounter-Prog.c index d5170af..331dbf5 100644 --- a/Pulsecounter-Prog.c +++ b/Pulsecounter-Prog.c @@ -1,48 +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 base4 = 0; -static int32_t base5 = 1000; +static int32_t base5 = 0; static int32_t event4 = 0; static int32_t event5 = 0; -static bool cold = true; - 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; - cold = !cold; - if (cold) + switch (id) { + case 0: + Pulsecounter_accept(true); + Hal_greenLedOn(); + Hal_redLedOn(); + Hal_delay(10); + Hal_greenLedOff(); + Hal_redLedOff(); + Hal_tickStart(5000, tickHandler); + break; + case 1: event4++; - else - event5++; - if (connected) { - if (cold) + if (connected) Pulsecounter_event4_indicate(); - else - Pulsecounter_event5_indicate(); - } - else - Pulsecounter_accept(true); - for (i = 0; i < 3; i++) { 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) {