diff options
author | David Lamparter <equinox@diac24.net> | 2011-03-06 06:45:24 +0100 |
---|---|---|
committer | David Lamparter <equinox@diac24.net> | 2011-03-06 06:45:24 +0100 |
commit | d3dcf97e28cfeffe5d2e27a119077e12b61b2e7e (patch) | |
tree | 44bf0f8f022e4168f613f79c8b21bb39a8dd3e2e | |
parent | 75ff498d410a42b4cce52409f2abcfa9e3856143 (diff) |
use eeprom for pin
-rw-r--r-- | Makefile | 2 | ||||
-rw-r--r-- | kbc.c | 16 |
2 files changed, 14 insertions, 4 deletions
@@ -15,7 +15,7 @@ CC=gcc CXX=g++ -g LDXX=g++ -g -love: kbc.flash +love: kbc.flash kbc.eeprom %.flash: %.ld.o $(AOBJCOPY) -O binary $< $@ @@ -5,6 +5,7 @@ #include <avr/interrupt.h> #include <avr/sleep.h> #include <avr/pgmspace.h> +#include <avr/eeprom.h> #include <util/delay.h> #ifndef PIN @@ -331,7 +332,7 @@ static uint8_t cntr = 0; static uint8_t error; #endif -static const char passwd[sizeof(PIN) - 1] = PIN; +static const EEMEM char passwd[sizeof(PIN) - 1] = PIN; static char code[sizeof(PIN)]; static void state_enter(void) @@ -543,17 +544,26 @@ static void handle_keypress(uint8_t data) unlock = ascii == ENT || data == NUMPAD_ENTER; if (lock || unlock) { + uint8_t eebyte, pos, ok = 1; + /* passwd: a b c d * code: \0 a b c d */ + + if (code[0]) + ok = 0; #ifdef KILLSWITCH - if (code[0] || !memcmp("9164", code + 1, 4)) { + if (!memcmp("9164", code + 1, 4)) { error = 0; nextstate = STATE_ERROR; return; } #endif - if (code[0] || memcmp(passwd, code + 1, sizeof(passwd))) { + for (pos = 1; pos < sizeof(code); pos++) + if (code[pos] != eeprom_read_byte(passwd + pos - 1)) + ok = 0; + + if (!ok) { dbg_wr(0x20); nextstate = STATE_REJECT; } else { |