blob: 32b088a52f8559c955ddde6975ad3de9b0e9878f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
#include <stdint.h>
#include <string.h>
#include <avr/interrupt.h>
#include <avr/wdt.h>
#include <util/delay.h>
#include "nrfm.h"
#include "uart.h"
#include "util.h"
#define RX_PIN PD7
#define RX_DDR DDRD
#define RX_PORT PORTD
#define RX_PCIE PCIE2
#define RX_PCINT PCINT23
#define RX_PCMSK PCMSK2
#define RX_PCINTVEC PCINT2_vect
#define LOCK_PIN PD2
#define UNLOCK_PIN PD3
static volatile int rxdr = 0;
static volatile int lock = 0;
static inline void init_rx(void)
{
RX_DDR &= ~(1 << RX_PIN);
RX_PORT |= (1 << RX_PIN);
PCICR |= (1 << RX_PCIE);
RX_PCMSK |= (1 << RX_PCINT);
}
static inline void init_btns(void)
{
DDRD &= ~((1 << LOCK_PIN) | (1 << UNLOCK_PIN));
PORTD |= ((1 << LOCK_PIN) | (1 << UNLOCK_PIN));
EICRA = 0b00000000;
EIMSK = (1 << INT0) | (1 << INT1);
}
static inline int is_btn_pressed(unsigned char btn)
{
if (!((PIND >> btn) & 0x01)) {
_delay_us(2000);
return !((PIND >> btn) & 0x01);
}
return 0;
}
int main(void)
{
uint8_t n;
char buf[MAXPDLEN + 1];
uint8_t rxaddr[ADDRLEN] = { 194, 178, 82 };
uint8_t txaddr[ADDRLEN] = { 194, 178, 83 };
init_rx();
init_btns();
uart_init();
radio_init(rxaddr);
radio_print_config();
sei();
radio_listen();
for (;;) {
if (rxdr) {
n = radio_recv(buf, MAXPDLEN);
buf[n] = '\0';
rxdr = 0;
if (strncmp(buf, "ACK", 3) == 0) {
uart_write("INFO: ");
uart_write_line(buf);
}
}
if (lock) {
lock = 0;
radio_sendto(txaddr, "SYN", 3);
}
}
return 0;
}
ISR(RX_PCINTVEC)
{
rxdr = 1;
}
ISR(INT0_vect)
{
if (is_btn_pressed(LOCK_PIN))
lock = 1;
}
ISR(INT1_vect)
{
if (is_btn_pressed(UNLOCK_PIN))
lock = 1;
}
|