diff options
| author | Sadeep Madurange <sadeep@asciimx.com> | 2025-04-11 11:50:13 +0800 |
|---|---|---|
| committer | Sadeep Madurange <sadeep@asciimx.com> | 2025-04-11 11:50:13 +0800 |
| commit | 94ebd8da9b256dea2f30dc33c40a1494e39152f8 (patch) | |
| tree | 59c2eda6c6be2a278eb1a535cc9ceed0c6a29da6 /lock/servo.c | |
| parent | 7949e45d8e8a6a0daea7264544c6361601bd12e1 (diff) | |
| download | smart-home-94ebd8da9b256dea2f30dc33c40a1494e39152f8.tar.gz | |
Update servo side code.
Diffstat (limited to 'lock/servo.c')
| -rw-r--r-- | lock/servo.c | 86 |
1 files changed, 14 insertions, 72 deletions
diff --git a/lock/servo.c b/lock/servo.c index dd4938a..fedc706 100644 --- a/lock/servo.c +++ b/lock/servo.c @@ -1,4 +1,4 @@ -/* Door back, connected to the fingerprint scanner */ +/* Lock back, connected to the servo */ #include <stdint.h> #include <string.h> @@ -16,6 +16,10 @@ #define PWM_MAX 2500 #define PWM_TOP 20000 +#define SERVO_PIN PB1 +#define LOCK_BTN PD6 +#define UNLOCK_BTN PD7 + #define RX_PIN PD7 #define RX_DDR DDRD #define RX_PORT PORTD @@ -24,55 +28,25 @@ #define RX_PCMSK PCMSK2 #define RX_PCINTVEC PCINT2_vect -static char chars[] = { - '0', '8', '3', '6', 'a', 'Z', '$', '4', 'v', 'R', '@', - 'E', '1', 'o', '#', ')', '2', '5', 'q', ';', '.', 'I', - 'c', '7', '9', '*', 'L', 'V', '&', 'k', 'K', '!', 'm', - 'N', '(', 'O', 'Q', 'A', '>', 'T', 't', '?', 'S', 'h', - 'w', '/', 'n', 'W', 'l', 'M', 'e', 'H', 'j', 'g', '[', - 'P', 'f', ':', 'B', ']', 'Y', '^', 'F', '%', 'C', 'x' -}; - -static volatile int rxdr = 0; -static uint8_t charslen = sizeof(chars) / sizeof(chars[0]); +static volatile uint8_t rxdr = 0; -static inline void await_reply(void) +static inline void servo_init(void) { - int i; - - radio_listen(); - for (i = 0; i < 500 && rxdr == 0; i += 100) - _delay_ms(100); -} + DDRB |= (1 << SERVO_PIN); -static inline void keygen(char *buf, uint8_t n) -{ - int i; - uint8_t sreg; - uint16_t idx; - - sreg = SREG; - cli(); - idx = TCNT1; - SREG = sreg; - - for (i = 0; i < n; i++, idx++) - buf[i] = chars[(idx % charslen)] ; - buf[n - 1] = '\0'; -} - -static inline void timer_init(void) -{ TCCR1A |= (1 << WGM11) | (1 << COM1A1); TCCR1B |= (1 << WGM13) | (1 << CS11); - ICR1 = PWM_TOP; /* we use the same timer for servo's PWM */ + + ICR1 = PWM_TOP; + + DDRD &= ~((1 << LOCK_BTN) | (1 << UNLOCK_BTN)); + PORTD |= (1 << LOCK_BTN) | (1 << UNLOCK_BTN); } int main(void) { uint8_t n; uint8_t rxaddr[ADDRLEN] = { 194, 178, 83 }; - uint8_t txaddr[ADDRLEN] = { 194, 178, 82 }; char buf[WDLEN + 1], key[WDLEN + 1], msg[WDLEN + 1]; @@ -82,7 +56,7 @@ int main(void) RX_PCMSK |= (1 << RX_PCINT); uart_init(); - timer_init(); + servo_init(); radio_init(rxaddr); radio_print_config(); @@ -91,39 +65,7 @@ int main(void) for (;;) { if (rxdr) { - n = radio_recv(buf, WDLEN); - buf[n] = '\0'; - rxdr = 0; - - xor(KEY, buf, msg, WDLEN); - uart_write("DEBUG: msg recv = "); - uart_write_line(msg); - - if (strncmp(msg, SYN, WDLEN) == 0) { - keygen(key, WDLEN); - uart_write("DEBUG: session key = "); - uart_write_line(key); - - xor(KEY, key, msg, WDLEN); - radio_sendto(txaddr, msg, WDLEN); - await_reply(); - - if (rxdr) { - n = radio_recv(buf, WDLEN); - buf[n] = '\0'; - rxdr = 0; - xor(key, buf, msg, WDLEN); - uart_write("DEBUG: msg = "); - uart_write_line(msg); - - xor(key, ACK, msg, WDLEN); - radio_sendto(txaddr, msg, WDLEN); - } - } else { - uart_write_line("ERROR: handshake failed"); - } } else { - uart_write_line("DEBUG: no new packets"); _delay_ms(2000); } } |
