X-Git-Url: https://git.realraum.at/?a=blobdiff_plain;f=firmware%2Ftuer.pde;h=3813e0022cae357795f76df688659e47c4095a90;hb=d5e72b4ce575bcec2699edad4c9420cbc05855a3;hp=3feb05800f402a9c1b856015ff4cd60980f16380;hpb=da910f7d4d8727251856247e0653d18be917a425;p=svn42.git diff --git a/firmware/tuer.pde b/firmware/tuer.pde index 3feb058..3813e00 100644 --- a/firmware/tuer.pde +++ b/firmware/tuer.pde @@ -21,7 +21,9 @@ byte next_led = 0; #define LIMIT_CLOSED_PIN 19 // A5: limit switch for close #define AJAR_PIN 14 // input pin for reed relais (door ajar/shut) -boolean ajar_last_state = false; +#define SHUT 0 +#define AJAR 1 +byte ajar_last_state = SHUT; #define MANUAL_OPEN_PIN 12 // keys for manual open and close #define MANUAL_CLOSE_PIN 13 // @@ -80,19 +82,19 @@ boolean is_closed() //**********// -void init_ajar() +byte get_ajar_status() { - pinMode(AJAR_PIN, INPUT); // set pin to input - digitalWrite(AJAR_PIN, HIGH); // turn on pullup resistors - ajar_last_state = digitalRead(AJAR_PIN); + if(digitalRead(AJAR_PIN) == LOW) + return SHUT; + + return AJAR; } -boolean get_ajar_status() // shut = true, ajar = false +void init_ajar() { - if(digitalRead(AJAR_PIN)) - return false; - - return true; + pinMode(AJAR_PIN, INPUT); // set pin to input + digitalWrite(AJAR_PIN, HIGH); // turn on pullup resistors + ajar_last_state = get_ajar_status(); } //**********// @@ -390,7 +392,7 @@ ISR(TIMER1_COMPA_vect) else if(is_closed()) Serial.print("closed"); Serial.print(", idle"); - if(get_ajar_status()) + if(get_ajar_status() == SHUT) Serial.println(", shut"); else Serial.println(", ajar"); @@ -523,7 +525,7 @@ void print_status() case WAIT: Serial.print(", waiting"); break; default: Serial.print(", "); break; } - if(get_ajar_status()) + if(get_ajar_status() == SHUT) Serial.println(", shut"); else Serial.println(", ajar"); @@ -623,8 +625,10 @@ void loop() PORTD = LEDS_ON; } } - boolean a = get_ajar_status(); + byte a = get_ajar_status(); if(a != ajar_last_state) + { print_status(); - ajar_last_state = a; + ajar_last_state = a; + } }