Sun, 11 Dec 2011 17:34:40 +0100
finished live CLI, BB firmware improvements and fixes
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
1 | #include <avr/interrupt.h> |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
2 | #include <avr/io.h> |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
3 | #include <avr/wdt.h> |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
4 | #include <avr/eeprom.h> |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
5 | #include <stdlib.h> |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
6 | #include <stdint.h> |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
7 | #include <avr/pgmspace.h> |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
8 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
9 | #include "main.h" |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
10 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
11 | #include "driver/rs232.h" |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
12 | #include "util/delay.h" |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
13 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
14 | |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
15 | volatile char buffer[RS232_BUFSIZE+1]; |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
16 | volatile uint8_t buffer_len = 0; |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
17 | |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
18 | volatile uint8_t showall = 0; |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
19 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
20 | // USART0 RX interrupt |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
21 | ISR ( USART_RXC_vect ) { |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
22 | char c = UDR; |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
23 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
24 | // check for buffer overflow |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
25 | if (buffer_len==sizeof(buffer)) { |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
26 | buffer_len=0; |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
27 | if (c == 27) { |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
28 | // escape sequence, store to empty buffer |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
29 | buffer[buffer_len++] = c; |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
30 | } |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
31 | } else { |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
32 | // collect characters until end of line |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
33 | if (c == 27) { |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
34 | // escape sequence, clear buffer |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
35 | buffer_len = 0; |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
36 | buffer[buffer_len++] = c; |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
37 | } else if ( (c=='\n') && (buffer_len > 3) ) { |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
38 | buffer[buffer_len]=0; |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
39 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
40 | // packet end received, parse the received packet |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
41 | if (buffer[0] == 'A') { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
42 | showall = 1; |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
43 | RS232_puts_p(PSTR("Entering Livemode\n")); |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
44 | } |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
45 | if (buffer[0] == 'C') { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
46 | showall = 0; |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
47 | RS232_puts_p(PSTR("Showing only changes\n")); |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
48 | } |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
49 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
50 | // wait for the next packet |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
51 | buffer_len=0; |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
52 | } else { |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
53 | buffer[buffer_len++]=c; |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
54 | } |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
55 | } |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
56 | } |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
57 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
58 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
59 | #define PULSE_PORT PORTD |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
60 | #define PULSE_BIT PD2 |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
61 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
62 | volatile uint16_t data = 0; |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
63 | volatile uint8_t data_len = 0; |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
64 | volatile uint16_t response = 0; |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
65 | volatile uint8_t response_len = 0; |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
66 | volatile uint8_t bitbuf_len = 0; |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
67 | volatile uint16_t bitbuf = 0; |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
68 | |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
69 | volatile uint8_t sysclock = 0; |
31
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
70 | ISR ( TIMER0_OVF_vect ) { |
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
71 | PORTD ^= _BV(PD6); |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
72 | if (sysclock != 0xff) sysclock++; |
31
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
73 | } |
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
74 | |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
75 | ISR ( INT0_vect ) { |
28
d4235895fdbc
shark: corrected debug pins
Malte Bayer <mbayer@neo-soft.org>
parents:
12
diff
changeset
|
76 | PORTD ^= _BV(PD3); |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
77 | if ((sysclock > 0) && (sysclock<10)) { |
31
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
78 | // this is the answer slot start bit?? |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
79 | // configure the bitbuf to start receive of answer data |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
80 | if ((PIN(PULSE_PORT) & _BV(PULSE_BIT)) != 0) { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
81 | PORTD ^= _BV(PD7); // set indicator |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
82 | OCR2 = TIMER2_250US; |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
83 | GICR &= ~_BV(INT0) ; // Disable INT0 |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
84 | bitbuf = 0; // init |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
85 | bitbuf_len = 0b00100000; // init zero, first pulse is checked by timer, set answer receive flag! |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
86 | // START BIT RECEIVED! |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
87 | //OCR2 = TIMER2_250US; |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
88 | TCNT2 = 1; |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
89 | TIMSK |= _BV(OCIE2); //enable timer2 interrupt |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
90 | } else { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
91 | OCR2 = TIMER2_50US; |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
92 | } |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
93 | |
31
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
94 | } else { |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
95 | GICR &= ~_BV(INT0) ; // Disable INT0 |
31
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
96 | // Startsignal erkannt, ab hier den Timer2 starten, |
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
97 | // der liest dann alle 50µs den Zustand ein und schreibt das |
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
98 | // empfangene Bit in den Puffer |
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
99 | bitbuf = 0; // init |
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
100 | bitbuf_len = 0b10000000; // init 1 pulse received |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
101 | OCR2 = TIMER2_50US; |
31
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
102 | TCNT2 = 0; |
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
103 | TIMSK |= _BV(OCIE2); //enable timer2 interrupt |
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
104 | } |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
105 | } |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
106 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
107 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
108 | ISR ( TIMER2_COMP_vect ) { |
28
d4235895fdbc
shark: corrected debug pins
Malte Bayer <mbayer@neo-soft.org>
parents:
12
diff
changeset
|
109 | PORTD ^= _BV(PD4); |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
110 | uint8_t clock, state, state2, rxa; |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
111 | |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
112 | |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
113 | if ((bitbuf_len & 0b00100000) == 0) rxa = 0; else rxa = 0xff; |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
114 | if ((PIN(PULSE_PORT) & _BV(PULSE_BIT)) == 0) state2 = 0; else state2 = 0xff; |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
115 | |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
116 | if (rxa == 0) { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
117 | // receive a standard packet |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
118 | if ((bitbuf_len & 0b10000000) == 0) clock = 0; else clock = 0xff; |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
119 | if ((bitbuf_len & 0b01000000) == 0) state = 0; else state = 0xff; |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
120 | |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
121 | if (clock) { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
122 | // second pulse of bit |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
123 | bitbuf_len &= ~_BV(7); // switch clock to low |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
124 | if ((state==state2) & state2) { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
125 | // two cycles high: packet end received |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
126 | data_len = (bitbuf_len & 0b00011111); |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
127 | data = bitbuf; // output data |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
128 | if (data_len == 13) PORTD ^= _BV(6); // debug sync output on program packets |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
129 | sysclock = 0; // reset system clock counter |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
130 | TIMSK &= ~_BV(OCIE2); //disable timer2 interrupt |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
131 | GICR |= _BV(INT0); // Enable INT0 |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
132 | // GIFR &= ~_BV(INTF0); // clear int0 irq flag |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
133 | } else { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
134 | bitbuf_len++; // increment bit counter |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
135 | bitbuf = bitbuf << 1; // shift bits |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
136 | if (state2 == 0) bitbuf |= 1; // receive logic one |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
137 | } |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
138 | } else { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
139 | // first pulse of bit |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
140 | bitbuf_len |= _BV(7); // switch clock to high |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
141 | if (state2) { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
142 | bitbuf_len |= _BV(6); // store new state |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
143 | } else { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
144 | bitbuf_len &= ~_BV(6); // store new state |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
145 | } |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
146 | } |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
147 | } else { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
148 | // receive an answer packet! |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
149 | if ((bitbuf_len & 0xF) < 0xE) { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
150 | // receive one of max 15 bits to buffer |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
151 | bitbuf_len++; |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
152 | bitbuf = bitbuf << 1; // shift bits |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
153 | if (state2 != 0) bitbuf |= 1; // receive logic one |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
154 | } else { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
155 | OCR2 = TIMER2_50US; |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
156 | // END OF ANSWER |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
157 | response_len = (bitbuf_len & 0b00011111); |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
158 | response = bitbuf; // output data (full 16bits) |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
159 | PORTD ^= _BV(PD7); |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
160 | TIMSK &= ~_BV(OCIE2); //disable timer2 interrupt |
31
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
161 | GICR |= _BV(INT0); // Enable INT0 |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
162 | } |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
163 | } |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
164 | } |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
165 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
166 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
167 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
168 | int main(void) |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
169 | { |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
170 | uint8_t i, cycle_changed; |
29 | 171 | unsigned char s[10]; |
172 | uint16_t tmp; | |
173 | uint16_t cycle[11]; | |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
174 | uint16_t cycle_old[11]; |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
175 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
176 | // setup data bit timer |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
177 | TCCR2 = (1<<CS21) | (1<<WGM21); //divide by 8, set compare match |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
178 | OCR2 = TIMER2_50US; |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
179 | TIMSK |= 1<<OCIE2; //enable timer2 interrupt |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
180 | |
31
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
181 | // setup system timer |
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
182 | TCCR0 = (1<<CS21); //divide by 8 |
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
183 | TIMSK |= 1<<TOIE0; //enable timer0 interrupt |
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
184 | |
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
185 | |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
186 | MCUCR = _BV(ISC01); // falling edge |
31
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
187 | // MCUCR = _BV(ISC00) | _BV(ISC01); // rising edge |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
188 | GICR = _BV(INT0) ; // Enable INT0 |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
189 | |
31
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
190 | DDRD |= _BV(PD3) | _BV(PD4) | _BV(PD5) | _BV(PD6) | _BV(PD7); |
a8f082503782
carrerashark minor changes
Malte Bayer <mbayer@neo-soft.org>
parents:
30
diff
changeset
|
191 | PORTD |= _BV(PD7); |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
192 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
193 | RS232_init(); // initialize RS232 interface |
39 | 194 | RS232_puts_p(PSTR("CarreraShark 1.2\nA = Show all data live\nC = Show only when prog high changes")); |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
195 | |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
196 | sei(); |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
197 | i = 0; |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
198 | while (1) { |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
199 | // main loop |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
200 | |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
201 | if (response != 0) { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
202 | RS232_puts_p(PSTR("RX: ")); |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
203 | itoa(response, s, 2); |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
204 | response = 0; |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
205 | RS232_puts( s ); |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
206 | RS232_putc('\n'); |
39 | 207 | //while (1) ; |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
208 | } |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
209 | |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
210 | if (data != 0) { |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
211 | if (data_len > 5) { |
29 | 212 | tmp = data; |
213 | data = 0; | |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
214 | if (data_len == 13) { // sync to first packet |
28
d4235895fdbc
shark: corrected debug pins
Malte Bayer <mbayer@neo-soft.org>
parents:
12
diff
changeset
|
215 | PORTD ^= _BV(PD5); |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
216 | if (showall == 0) { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
217 | // compare old & new cycle |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
218 | cycle_changed = 0; |
39 | 219 | for (i=0; i<10;i++ ) if ( (cycle[i] & 0xff00) != (cycle_old[i] & 0xff00) ) cycle_changed = 1; |
29 | 220 | } |
38
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
221 | if ( (showall != 0) || (cycle_changed != 0) ) { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
222 | for (i=0; i<10;i++ ) { |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
223 | // output previous cycle data |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
224 | itoa( cycle[i], s, 16); |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
225 | RS232_putc('0'); |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
226 | RS232_putc('x'); |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
227 | RS232_puts( s ); |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
228 | RS232_putc(' '); |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
229 | } |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
230 | if (showall != 0) RS232_putc('*'); else RS232_putc('\n'); |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
231 | } |
ff76255904c4
implemented response reader to carrerashark
Malte Bayer <mbayer@neo-soft.org>
parents:
31
diff
changeset
|
232 | if (showall == 0) for (i=0; i<10;i++ ) cycle_old[i] = cycle[i]; |
29 | 233 | i = 0; |
234 | PORTD ^= _BV(PD5); | |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
235 | } |
29 | 236 | cycle[i] = tmp; |
237 | i++; | |
12
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
238 | } |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
239 | //if (i==10) for (;;); |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
240 | } |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
241 | } // main loop end |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
242 | }; |
a399f9d5e672
added carrerashark project-part to separate subdirectory
Malte Bayer <mbayer@neo-soft.org>
parents:
diff
changeset
|
243 |