Project

General

Profile

Statistics
| Revision:

root / trunk / toolbox / main.c @ 150

History | View | Annotate | Download (8.13 KB)

1
/********
2
 * This file is part of Tooltron.
3
 *
4
 * Tooltron is free software: you can redistribute it and/or modify
5
 * it under the terms of the Lesser GNU General Public License as published by
6
 * the Free Software Foundation, either version 3 of the License, or
7
 * (at your option) any later version.
8
 *
9
 * Tooltron is distributed in the hope that it will be useful,
10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
 * Lesser GNU General Public License for more details.
13
 * You should have received a copy of the Lesser GNU General Public License
14
 * along with Tooltron.  If not, see <http://www.gnu.org/licenses/>.
15
 *
16
 * Copyright 2009 Kevin Woo <kwoo@2ndt.com>
17
 *
18
 ********/
19
/** @file main.c
20
 *  @brief Contains the main function for the toolbox code.
21
 *
22
 *  @author Suresh Nidhiry (snidhiry), Kevin Woo (kwoo)
23
 */
24

    
25
//Includes
26
#include <avr/io.h>
27
#include <avr/interrupt.h>
28
#include <stdint.h>
29
#include <util/delay.h>
30
#include "uart.h"
31

    
32
#define RELAY       _BV(PORTD4)
33
#define VAC_SENSE   _BV(PIND3)
34
#define BUT_RED     _BV(PINB4)
35
#define BUT_BLACK   _BV(PINB3)
36
#define LED_GREEN   _BV(PORTB2)
37
#define LED_YELLOW  _BV(PORTB1)
38
#define LED_RED     _BV(PORTB0)
39
#define ON      0x01
40
#define OFF     0x00
41

    
42
/***** change ADDR ****/
43
#define ADDR 18
44
#define DELIM '^'
45
#define SERVER 1
46
#define TURNON 'O'
47

    
48
/***
49
 * TWAIT - minutes to wait before green button is pressed to kill power
50
 * TWARN - minutes until warning (blink yellow, allow more time with green button)
51
 * TMAX  - minutes until power is killed (unless tool is on)
52
 */
53
#define TWAIT   1
54
#define TWARN   1
55
#define TMAX    2
56

    
57
uint8_t sec;
58
uint8_t min;
59

    
60
typedef enum {
61
    sd,     // start delimitor
62
    src,    // src
63
    dest,   // destination
64
    data,   // data
65
    cs,     // checksum
66
    ack,    // send ack
67
    pwron,  // poweron
68
    idiot,  // user tried to hit green with the machine switch on
69
    toolon, // tool on
70
    warn,   // time warning
71
    off     // tool off
72
} state_t;
73

    
74
void init_pins(void) {
75
    DDRB = 0x00;
76
    DDRB = _BV(DDB0) | _BV(DDB1) | _BV(DDB2) | _BV(DDB5);
77
    DDRD = _BV(DDB4);
78
    PORTB = 0x00;
79
}
80

    
81
void toggle_led(uint8_t which, uint8_t state) {
82
    if (state == ON) {
83
        PORTB &= ~which;
84
    } else {
85
        PORTB |= which;
86
    }
87
}
88

    
89
void toggle_relay(uint8_t state) {
90
    if (state == ON) {
91
        PORTD |= RELAY;
92
    } else {
93
        PORTD &= ~RELAY;
94
    }
95
}
96

    
97
inline uint8_t read_vac(void) {
98
    return (!(PIND & VAC_SENSE));
99
}
100

    
101
inline uint8_t read_button(uint8_t which) {
102
    return (!(PINB & which));
103
}
104

    
105
void init_timer(void) {
106
    // Clear timmer on OCRA1 Compare match
107
    // No prescale
108
    TCCR1B |= _BV(WGM12) | _BV(CS12);
109
    
110
    // 1 second @ 8MHz clock
111
    OCR1AH =0x7A;
112
    OCR1AL =0x12;
113

    
114
    TIMSK = _BV(OCIE1A);
115

    
116
    sec = 0;
117
    min = 0;
118
}
119

    
120
void reset_timer(void) {
121
    sec = 0;
122
    min = 0;
123
}
124

    
125
ISR(TIMER1_COMPA_vect) {
126
    if (sec == 59) {
127
        sec = 0;
128
        min++;
129
    } else {
130
        sec++;
131
    }
132
}
133

    
134

    
135
int main(int argc, char **argv) {
136
    state_t state = sd;
137
    uint8_t packet[3];
138
    uint8_t ms_timer=0;
139

    
140
        /***** Start Start-up Sequence *****/
141
        sei();                                //Enable interrupts
142
        init_timer();                //Set registers for timer
143
        init_pins();                //Set pin directions
144
        init_uart(51);                //Set registers for uart
145
        /***** End Start-up Sequence *****/
146

    
147
    uint8_t r;
148
    
149
    packet[0] = 0x00;
150
    packet[1] = 0x00;
151
    packet[2] = 0x00;
152
   
153
        while(1) {
154
        /*
155
        usb_puti(min);
156
        uart_send_byte('m');
157
        usb_puti(sec);
158
        uart_send_byte('s');
159
        uart_send_byte('\r');
160
        uart_send_byte('\n');
161
        _delay_ms(500);
162
        */
163
        
164
        switch (state) {
165
            case sd:
166
                toggle_led(LED_RED, ON);
167
                toggle_led(LED_YELLOW, OFF);
168
                toggle_led(LED_GREEN, OFF);
169
                toggle_relay(OFF);
170
                while ((uart_get_byte(&r)) < 0);
171
                if (r == DELIM) {
172
                    state = src;
173
                }
174
                break;
175
            case src:
176
                while ((uart_get_byte(&r)) < 0);
177

    
178
                if (r == DELIM) {
179
                    state = src;
180
                } else {
181
                    packet[0] = r;
182
                    state = dest;
183
                }
184
                break;
185
            case dest:
186
                while ((uart_get_byte(&r)) < 0);
187

    
188
                if (r == DELIM) {
189
                    packet[0] = 0x00;
190
                    state = src;
191
                } else if (r == ADDR) {
192
                    packet[1] = r;
193
                    state = data;
194
                } else {
195
                    packet[0] = 0x00;
196
                    state = sd;
197
                }
198
                break;
199
            case data:
200
                while ((uart_get_byte(&r)) < 0);
201
                
202
                if (r == DELIM) {
203
                    packet[0] = 0x00;
204
                    packet[1] = 0x00;
205
                    state = src;
206
                } else {
207
                    packet[2] = r;
208
                    state = cs;
209
                }
210
                break;
211
            case cs:
212
                while ((uart_get_byte(&r)) < 0);
213

    
214
                if (r == (packet[0] ^ packet[1] ^ packet[2])) {
215

    
216
                    if (packet[2] == TURNON) {
217
                        state = ack;
218
                        break;
219
                    }
220
                }
221

    
222
                packet[0] = 0x00;
223
                packet[1] = 0x00;
224
                packet[2] = 0x00;
225
                state = sd;
226
                break;
227
            case ack:
228
                uart_send_byte(DELIM);
229
                uart_send_byte(ADDR);
230
                uart_send_byte(SERVER);
231
                uart_send_byte('A');
232
                uart_send_byte(ADDR ^ SERVER ^ 'A');
233

    
234
                toggle_led(LED_RED, OFF);
235
                toggle_led(LED_YELLOW, ON);
236

    
237
                state = pwron;
238
                reset_timer();
239
                break;
240
            case pwron:
241
              if (read_vac() == ON) {
242
                ms_timer = 0;
243
                state = idiot;
244
                break;
245
              }
246

    
247
                if (read_button(BUT_BLACK)) {
248
                    toggle_led(LED_YELLOW, OFF);
249
                    toggle_led(LED_GREEN, ON);
250
                    toggle_relay(ON);
251

    
252
                    reset_timer();
253
                    state = toolon;
254
                } else if ((read_button(BUT_RED)) || (min >= TWAIT)) {
255
                    state = off;
256
                }
257
                break;
258
            case idiot:
259
              if (read_vac() == OFF) {
260
                state = pwron;
261
                toggle_led(LED_RED, OFF);
262
                toggle_led(LED_YELLOW, ON);
263
                break;
264
              }
265

    
266
              if (read_button(BUT_RED)) {
267
                state = off;
268
                break;
269
              }
270

    
271
              if(ms_timer >= 100) {
272
                toggle_led(LED_YELLOW, ON);
273
                toggle_led(LED_RED, OFF);
274
                
275
                if(ms_timer >= 200) {
276
                  ms_timer = 0;
277
                }
278
              }
279
              else {
280
                toggle_led(LED_YELLOW, OFF);
281
                toggle_led(LED_RED, ON);
282
              }
283

    
284
              _delay_ms(2);
285
              ms_timer++;
286
              break;
287

    
288
            case toolon:
289
                
290
                if ((read_button(BUT_RED)) && (read_vac() == OFF)) {
291
                        state = off;
292
                        toggle_relay(OFF);
293
                } else if (min >= TWARN) {
294
                    toggle_led(LED_GREEN, OFF);
295
                    state = warn;
296
                }
297
                break;
298

    
299
            case warn:
300
                if(ms_timer >= 100) {
301
                  toggle_led(LED_YELLOW, ON);
302
                
303
                  if(ms_timer >= 200) {
304
                    ms_timer = 0;
305
                  }
306
                }
307
                else {
308
                  toggle_led(LED_YELLOW, OFF);
309
                }
310

    
311
                if (read_button(BUT_RED) && read_vac() == OFF) {
312
                    toggle_relay(OFF);
313
                    state = off;
314
                } else if (read_button(BUT_BLACK)) {
315
                    toggle_led(LED_GREEN, ON);
316
                    toggle_led(LED_YELLOW, OFF);
317
                    reset_timer();
318
                    state = toolon;
319
                } else if ((min >= TMAX) && (read_vac() == OFF)) {
320
                    toggle_relay(OFF);
321
                    state = off;
322
                }
323

    
324
                _delay_ms(2);
325
                ms_timer++;
326

    
327
                break;
328
            case off:
329
                toggle_led(LED_GREEN, OFF);
330
                toggle_led(LED_YELLOW, OFF);
331
                toggle_led(LED_RED, ON);
332
                state = sd;
333
                break;
334
            default: state = sd;
335
        }     
336
        
337
        }
338
        
339
        return 0;
340
}