--- trunk/Embedded/main.c 2007/12/06 12:53:06 174 +++ trunk/Embedded/main.c 2007/12/06 13:36:07 175 @@ -20,11 +20,11 @@ unsigned char global_Pot_Hi, global_Pot_Lo; unsigned char global_serial_send[BUFFER], global_serial_recieve_buffer[BUFFER]; bit global_recieve_done = 0, global_interval_changed = 0; -unsigned int global_serial_byte_counter = 0, global_sms_counter = 1, global_time_counter = 0; +unsigned int global_serial_byte_counter = 0, global_sms_counter = 1, global_time_counter = 0, global_time_counter_image = 0; unsigned int global_emergency_counter = 600, global_time_interval = 3600; unsigned char global_temp = 0; -unsigned char global_temp_update_display = 0; +unsigned int global_temp_update_display = 0; unsigned char global_message_buffer1[BUFFER]; unsigned char global_message_buffer2[BUFFER]; @@ -44,6 +44,7 @@ __EEPROM_DATA( 60, 0, 1, 8, '2', '1', '6', '8'); __EEPROM_DATA( '1', '7', '8', '4',0,0,0,0); + void serial_recieved(void); void serial_send(void); void update_lcd(void); @@ -55,6 +56,7 @@ void send_sms(const unsigned char* payload); void eeprom_writer(void); + void reset_recieve_buffer(void) { global_recieve_done = 0; @@ -67,7 +69,7 @@ memset(global_message_buffer1, 0, BUFFER); memset(global_message_buffer2, 0, BUFFER); } - +////////// INITS ////////// void pic18_io_init(void) { TRISA0 = 1; // analog input @@ -110,17 +112,7 @@ ADON=1; } -void rs232_init(void) -{ - SPEN = 0; // Serial Port Enable Bit... 0 = disabled - TRISC6 = 0; - TRISC7 = 1; - SPBRG = 207; // 1200 baud rate... 25 = 9600 - // x = (Fosc / (16*[baud rate]) )-1 - TXSTA = 0x24; // Enables BRGH and TXEN inthe TXSTA register - RCSTA = 0x90; // 0x90 enables SPEN and CREN in the RCSTA register -} void interrupt_init(void) { @@ -133,6 +125,8 @@ TMR1IE = 1; // Enables timer 1 } + + void timer_init(void) { TMR1CS = 1; //use external clock @@ -146,7 +140,19 @@ T1OSCEN = 1; //enable oscillator circuit RD16 = 0; //normal 8 bit writes TMR1ON = 1; -} +} + +void rs232_init(void) +{ + SPEN = 0; // Serial Port Enable Bit... 0 = disabled + TRISC6 = 0; + TRISC7 = 1; + + SPBRG = 207; // 1200 baud rate... 25 = 9600 + // x = (Fosc / (16*[baud rate]) )-1 + TXSTA = 0x24; // Enables BRGH and TXEN inthe TXSTA register + RCSTA = 0x90; // 0x90 enables SPEN and CREN in the RCSTA register +} void sms_init(void) { @@ -175,40 +181,26 @@ } } - - sprintf(global_serial_send,"%s", "at+cpin=8043\r"); + sprintf(global_serial_send,"%s", "at+cpin?\r"); serial_send(); + DelayMs(100); // To give the modem a chance to answer. - while(global_modem_init == 0) + if (strstr(global_message_buffer1, "+CPIN: SIM PIN") != 0) { - on_initial_recieve(); + sprintf(global_serial_send,"%s", "at+cpin=8043\r"); + serial_send(); + + while(global_modem_init == 0) + { + on_initial_recieve(); + } } - DelayMs(5); - reset_recieve_buffer(); sprintf(global_serial_send, "at+cmgd=1,4\r"); serial_send(); while ( strstr(global_message_buffer1,"OK") == 0) ; } - -void interrupt interrupt_handler(void) -{ - // Finds out what interrupt have been trigged, and starts the respective function. - if(RCIF == 1) // Serial recieve interrupt - { - serial_recieved(); - RCIF = 0; - } - - if(TMR1IF == 1) // timer1 interrupt trigger. - { - timer1_interrupt(); - TMR1IF = 0; - } -} - - void serial_send(void) { int i; @@ -226,10 +218,24 @@ global_serial_send[0] = 0; DelayMs(150); } +////////// INTERRUPT HANDLER ////////// +void interrupt interrupt_handler(void) +{ + // Finds out what interrupt have been trigged, and starts the respective function. + if(RCIF == 1) // Serial recieve interrupt + { + serial_recieved(); + RCIF = 0; + } + + if(TMR1IF == 1) // timer1 interrupt trigger. + { + timer1_interrupt(); + TMR1IF = 0; + } +} -/////////////////////////////////////////////////////////////////////////////////////////////////// -// Takes the recieving data and fills it in a buffer, when we meet a '\r' we fill the data from, -// global_serial_recieve_buffer, to global_message_buffer1, and sets the flag global_recieve_done. +////////// INTERRUPT TRIGGED ////////// void serial_recieved(void) { char data_byte; @@ -282,7 +288,7 @@ global_emergency_counter++; RA1 = !RA1; } - +////////// ORDENARY FUNKTIONS ////////// void update_lcd(void) { if(global_temp_update_display != global_time_counter) @@ -456,7 +462,12 @@ } - +void Delay(int time) +{ + int wanted = (global_time_counter + time) % global_time_interval; + + while (global_time_counter < wanted) ; +} void main() { @@ -470,6 +481,8 @@ rs232_init(); ad_init(); lcd_init(0); + lcd_clear(); + lcd_home(); interrupt_init(); timer_init(); sms_init(); @@ -490,8 +503,9 @@ send_update(); global_emergency_counter = 0; } + // Every X sec. a status sms is send. - if(global_time_counter >= 3600) + if(global_time_counter >= global_time_interval) { send_update(); global_time_counter = 0;