9 |
9: |
9: |
10 |
10: #define LCD_LENGTH 16 |
10: #define LCD_LENGTH 16 |
11 |
11: #define LCD_ROWS 2 |
11: #define LCD_ROWS 2 |
12 |
12: #define SEND_BUFFER 128 |
12: #define BUFFER 128 |
13 |
13: #define PWRFAIL RB1 |
13: #define PWRFAIL RB1 |
14 |
14: #define FIREDET RB2 |
14: #define FIREDET RB2 |
15 |
15: #define FEEDING RB3 |
15: #define FEEDING RB3 |
18 |
18: |
18: |
19 |
19: unsigned char global_Pot_Hi, global_Pot_Lo; |
19: unsigned char global_Pot_Hi, global_Pot_Lo; |
20 |
20: unsigned char global_LCD_Buffer[LCD_ROWS][LCD_LENGTH]; |
20: unsigned char global_LCD_Buffer[LCD_ROWS][LCD_LENGTH]; |
21 |
21: unsigned char global_serial_send[SEND_BUFFER], global_serial_recieve_buffer[SEND_BUFFER]; |
21: unsigned char global_serial_send[BUFFER], global_serial_recieve_buffer[BUFFER]; |
22 |
22: bit global_recieve_done = 0, global_interval_changed = 0; |
22: bit global_recieve_done = 0, global_interval_changed = 0; |
23 |
23: unsigned int global_serial_byte_counter = 0, global_sms_counter = 1, global_time_counter = 0; |
23: unsigned int global_serial_byte_counter = 0, global_sms_counter = 1, global_time_counter = 0; |
24 |
24: unsigned int global_emergency_counter = 600, global_time_interval = 3600; |
24: unsigned int global_emergency_counter = 600, global_time_interval = 3600; |
25 |
25: unsigned char global_temp = 0; |
25: unsigned char global_temp = 0; |
26 |
26: |
26: |
27 |
27: unsigned char cell_nr[15] = ""; // = "21681784"; |
27: unsigned char global_lcd_buf[16]; |
28 |
28: |
28: |
29 |
29: |
29: unsigned short global_imei_tversum; |
30 |
30: __EEPROM_DATA( 60, 0, 1, 8, '2', '1', '6', '8'); |
30: |
31 |
31: __EEPROM_DATA( '1', '7', '8', '4',0,0,0,0); |
31: unsigned char cell_nr[15] = ""; // = "21681784"; |
32 |
32: |
32: bit global_modem_init = 0; |
33 |
33: void serial_recieved(void); |
33: |
34 |
34: void serial_send(void); |
34: __EEPROM_DATA( 60, 0, 1, 8, '2', '1', '6', '8'); |
35 |
35: void update_lcd(void); |
35: __EEPROM_DATA( '1', '7', '8', '4',0,0,0,0); |
36 |
36: void convertTemp(void); |
36: |
37 |
37: void timer1_interrupt(void); |
37: void serial_recieved(void); |
38 |
38: |
38: void serial_send(void); |
39 |
39: // Nicked from H7 |
39: void update_lcd(void); |
40 |
40: void ad_init(void) |
40: void convertTemp(void); |
41 |
41: { |
41: void timer1_interrupt(void); |
42 |
42: // AD Conversion clock |
42: void on_recieve(void); |
43 |
43: ADCS0 = 0; |
43: void on_initial_recieve(void); |
44 |
44: ADCS1 = 0; |
44: |
45 |
45: ADCS2 = 0; |
45: |
46 |
46: |
46: void reset_recieve_buffer(void) |
47 |
47: //Select AN0/RA0 for AD source |
47: { |
48 |
48: // In this (000) setup, it's only RA0/AN0 that does ad convertion. |
48: global_recieve_done = 0; |
49 |
49: CHS0=0; |
49: global_serial_byte_counter=0; |
50 |
50: CHS1=0; |
50: } |
51 |
51: CHS2=0; |
51: |
52 |
52: |
52: |
53 |
53: //Only AN0 is selected for AD and with Vdd/Vss as limits |
53: void ad_init(void) // Nicked from H7 |
54 |
54: PCFG0=0; |
54: { |
55 |
55: PCFG1=1; |
55: // AD Conversion clock |
56 |
56: PCFG2=1; |
56: ADCS0 = 0; |
57 |
57: PCFG3=1; |
57: ADCS1 = 0; |
58 |
58: |
58: ADCS2 = 0; |
59 |
59: //Result is right justified |
59: |
60 |
60: ADFM=1; |
60: //Select AN0/RA0 for AD source |
61 |
61: |
61: // In this (000) setup, it's only RA0/AN0 that does ad convertion. |
62 |
62: //Fire up for A/D converter module |
62: CHS0=0; |
63 |
63: ADON=1; |
63: CHS1=0; |
64 |
64: } |
64: CHS2=0; |
65 |
65: |
65: |
66 |
66: void rs232_init(void) |
66: //Only AN0 is selected for AD and with Vdd/Vss as limits |
67 |
67: { |
67: PCFG0=0; |
68 |
68: SPEN = 0; // Serial Port Enable Bit... 0 = disabled |
68: PCFG1=1; |
69 |
69: TRISC6 = 0; |
69: PCFG2=1; |
70 |
70: TRISC7 = 1; |
70: PCFG3=1; |
71 |
71: |
71: |
72 |
72: SPBRG = 207; // 1200 baud rate... 25 = 9600 |
72: //Result is right justified |
73 |
73: // x = (Fosc / (16*[baud rate]) )-1 |
73: ADFM=1; |
74 |
74: TXSTA = 0x24; // Enables BRGH and TXEN inthe TXSTA register |
74: |
75 |
75: RCSTA = 0x90; // 0x90 enables SPEN and CREN in the RCSTA register |
75: //Fire up for A/D converter module |
76 |
76: } |
76: ADON=1; |
77 |
77: |
77: } |
78 |
78: void interrupt_init(void) |
78: |
79 |
79: { |
79: void rs232_init(void) |
80 |
80: // Assumes that all interrupts default is 0 |
80: { |
81 |
81: PEIE = 1; |
81: SPEN = 0; // Serial Port Enable Bit... 0 = disabled |
82 |
82: GIE = 1; |
82: TRISC6 = 0; |
83 |
83: RCIE = 1; // Recieve interrupt enable. |
83: TRISC7 = 1; |
84 |
84: IPEN = 0; // Nfo interrupt priority |
84: |
85 |
85: TXIE = 0; // Serial interrupt enabled |
85: SPBRG = 207; // 1200 baud rate... 25 = 9600 |
86 |
86: TMR1IE = 1; // Enables timer 1 |
86: // x = (Fosc / (16*[baud rate]) )-1 |
87 |
87: } |
87: TXSTA = 0x24; // Enables BRGH and TXEN inthe TXSTA register |
88 |
88: |
88: RCSTA = 0x90; // 0x90 enables SPEN and CREN in the RCSTA register |
89 |
89: void timer_init(void) |
89: } |
90 |
90: { |
90: |
91 |
91: TMR1CS = 1; //use external clock |
91: void interrupt_init(void) |
92 |
92: |
92: { |
93 |
93: T1CKPS1 = 1; //1:8 prescale |
93: // Assumes that all interrupts default is 0 |
94 |
94: T1CKPS0 = 1; |
94: PEIE = 1; |
95 |
95: |
95: GIE = 1; |
96 |
96: TMR1H = 0xEF; |
96: RCIE = 1; // Recieve interrupt enable. |
97 |
97: TMR1L = 0xFF; |
97: IPEN = 0; // Nfo interrupt priority |
98 |
98: |
98: TXIE = 0; // Serial interrupt enabled |
99 |
99: T1OSCEN = 1; //enable oscillator circuit |
99: TMR1IE = 1; // Enables timer 1 |
100 |
100: RD16 = 0; //normal 8 bit writes |
100: } |
101 |
101: TMR1ON = 1; |
101: |
102 |
102: } |
102: void timer_init(void) |
103 |
103: |
103: { |
104 |
104: void pic18_io_init(void) |
104: TMR1CS = 1; //use external clock |
105 |
105: { |
105: |
106 |
106: TRISA0 = 1; // analog input |
106: T1CKPS1 = 1; //1:8 prescale |
107 |
107: TRISA1 = 0; // Output |
107: T1CKPS0 = 1; |
108 |
108: TRISB1 = 1; // TRISB1-4 Digital input |
108: |
109 |
109: TRISB2 = 1; |
109: TMR1H = 0xEF; |
110 |
110: TRISB3 = 1; |
110: TMR1L = 0xFF; |
111 |
111: TRISB4 = 1; |
111: |
112 |
112: } |
112: T1OSCEN = 1; //enable oscillator circuit |
113 |
113: |
113: RD16 = 0; //normal 8 bit writes |
114 |
114: void sms_init(void) |
114: TMR1ON = 1; |
115 |
115: { |
115: } |
116 |
116: int i; |
116: |
117 |
117: |
117: void pic18_io_init(void) |
118 |
118: sprintf(global_serial_send,"at+cgsn\r"); |
118: { |
119 |
119: serial_send(); |
119: TRISA0 = 1; // analog input |
120 |
120: DelaySek(1); |
120: TRISA1 = 0; // Output |
121 |
121: while(!global_recieve_done) ; |
121: TRISB1 = 1; // TRISB1-4 Digital input |
122 |
122: |
122: TRISB2 = 1; |
123 |
123: |
123: TRISB3 = 1; |
124 |
124: sprintf(global_serial_send,"%s", "at+cpin=8043\r"); |
124: TRISB4 = 1; |
125 |
125: serial_send(); |
125: } |
126 |
126: DelaySek(30); |
126: |
127 |
127: |
127: void sms_init(void) |
128 |
128: update_lcd(); |
128: { |
129 |
129: DelaySek(5); |
129: int i; |
130 |
130: } |
130: |
131 |
131: |
131: reset_recieve_buffer(); |
132 |
132: |
132: sprintf(global_serial_send,"at+cgsn\r"); |
133 |
133: void interrupt interrupt_handler(void) |
133: serial_send(); |
134 |
134: { |
134: DelaySek(1); |
135 |
135: // Finds out what interrupt have been trigged, and starts the respective function. |
135: while(!global_recieve_done) ; |
136 |
136: if(RCIF == 1) // Serial recieve interrupt |
136: |
137 |
137: { |
137: |
138 |
138: serial_recieved(); |
138: sprintf(global_serial_send,"%s", "at+cpin=8043\r"); |
139 |
139: RCIF = 0; |
139: serial_send(); |
140 |
140: } |
140: |
141 |
141: |
141: while(global_modem_init == 0) |
142 |
142: if(TMR1IF == 1) // timer1 interrupt trigger. |
142: { |
143 |
143: { |
143: on_initial_recieve(); |
144 |
144: timer1_interrupt(); |
144: } |
145 |
145: TMR1IF = 0; |
145: } |
146 |
146: } |
146: |
147 |
147: } |
147: |
148 |
148: |
148: void interrupt interrupt_handler(void) |
149 |
149: |
149: { |
150 |
150: void serial_send(void) |
150: // Finds out what interrupt have been trigged, and starts the respective function. |
151 |
151: { |
151: if(RCIF == 1) // Serial recieve interrupt |
152 |
152: int i; |
152: { |
153 |
153: char data_byte; |
153: serial_recieved(); |
154 |
154: for(i = 0; i < SEND_BUFFER; i++) |
154: RCIF = 0; |
155 |
155: { |
155: } |
156 |
156: data_byte = global_serial_send[i]; |
156: |
157 |
157: if( data_byte == '\r') |
157: if(TMR1IF == 1) // timer1 interrupt trigger. |
158 |
158: i = (SEND_BUFFER - 1); |
158: { |
159 |
159: TXREG = data_byte; |
159: timer1_interrupt(); |
160 |
160: while(TRMT==0) ; |
160: TMR1IF = 0; |
161 |
161: DelayMs(10); |
161: } |
162 |
162: } |
162: } |
163 |
163: DelayMs(250); |
163: |
164 |
164: DelayMs(250); |
164: |
165 |
165: } |
165: void serial_send(void) |
166 |
166: |
166: { |
167 |
167: void serial_recieved(void) |
167: int i; |
168 |
168: { |
168: char data_byte; |
169 |
169: char data_byte, saved_data[LCD_LENGTH]; |
169: for(i = 0; i < BUFFER; i++) |
170 |
170: |
170: { |
171 |
171: data_byte = RCREG; |
171: data_byte = global_serial_send[i]; |
172 |
172: |
172: if( data_byte == '\r') |
173 |
173: global_serial_recieve_buffer[global_serial_byte_counter] = data_byte; |
173: i = (BUFFER - 1); |
174 |
174: if(data_byte == '\r') |
174: TXREG = data_byte; |
175 |
175: { |
175: while(TRMT==0) ; |
176 |
176: global_recieve_done = 1; |
176: DelayMs(10); |
177 |
177: global_serial_byte_counter = 0; |
177: } |
178 |
178: } |
178: DelayMs(250); |
179 |
179: else |
179: DelayMs(250); |
180 |
180: { |
180: } |
181 |
181: global_serial_byte_counter++; |
181: |
182 |
182: } |
182: void serial_recieved(void) |
183 |
183: |
183: { |
184 |
184: } |
184: char data_byte, saved_data[LCD_LENGTH]; |
185 |
185: |
185: |
186 |
186: void timer1_interrupt(void) |
186: data_byte = RCREG; |
187 |
187: { |
187: |
188 |
188: TMR1H = 0xEF; |
188: if (data_byte == '\n') |
189 |
189: TMR1L = 0xFF; |
189: return; |
190 |
190: global_time_counter++; |
190: |
191 |
191: global_emergency_counter++; |
191: if (global_serial_byte_counter == 0 && data_byte == '\r') |
192 |
192: RA1 = !RA1; |
192: return; |
193 |
193: } |
193: |
194 |
194: |
194: global_serial_recieve_buffer[global_serial_byte_counter] = data_byte; |
195 |
195: void update_lcd(void) |
195: |
196 |
196: { |
196: if (data_byte == '\r') |
197 |
197: if( global_recieve_done == 1 ) |
197: { |
198 |
198: { |
198: global_recieve_done = 1; |
199 |
199: lcd_clear(); |
199: //global_serial_byte_counter = 0; |
200 |
200: lcd_goto(0x00); |
200: global_serial_recieve_buffer[global_serial_byte_counter+1] = 0; //zero terminate |
201 |
201: lcd_puts(global_serial_recieve_buffer); |
201: } |
202 |
202: global_recieve_done = 0; |
202: else |
203 |
203: } |
203: { |
204 |
204: } |
204: global_serial_byte_counter++; |
205 |
205: |
205: } |
206 |
206: void send_update(void) |
206: |
207 |
207: { |
207: } |
208 |
208: sprintf(global_serial_send, "at+cmgs=\"%s\"\r", cell_nr); |
208: |
209 |
209: serial_send(); |
209: void timer1_interrupt(void) |
210 |
210: sprintf(global_serial_send, "%d:%d:%d:%d:%d:%d%c", global_sms_counter, global_temp, FIREDET, EMPTYTANK, FEEDING, PWRFAIL, 0x1A); |
210: { |
211 |
211: lcd_goto(40); |
211: TMR1H = 0xEF; |
212 |
212: lcd_puts(global_serial_send); |
212: TMR1L = 0xFF; |
213 |
213: serial_send(); |
213: global_time_counter++; |
214 |
214: DelayMs(250); |
214: global_emergency_counter++; |
215 |
215: global_sms_counter++; |
215: RA1 = !RA1; |
216 |
216: } |
216: } |
217 |
217: |
217: |
218 |
218: void convertTemp() |
218: void update_lcd(void) |
219 |
219: |
219: { |
220 |
220: { |
220: lcd_clear(); |
221 |
221: short adVal; |
221: lcd_goto(0x00); |
222 |
222: adVal = (global_Pot_Hi << 8) | global_Pot_Lo; |
222: |
223 |
223: if( adVal >=840 ) |
223: sprintf(global_lcd_buf, "%d", global_temp); |
224 |
224: global_temp = 100; |
224: lcd_puts(global_lcd_buf); |
225 |
225: else |
225: |
226 |
226: global_temp = (adVal / 8.3886); |
226: } |
227 |
227: } |
227: |
228 |
228: |
228: void send_update(void) |
229 |
229: |
229: { |
230 |
230: |
230: sprintf(global_serial_send, "at+cmgs=\"%s\"\r", cell_nr); |
231 |
231: void eeprom_writer(void) |
231: serial_send(); |
232 |
232: { |
232: sprintf(global_serial_send, "%d:%d:%d:%d:%d:%d%c", global_sms_counter, global_temp, FIREDET, EMPTYTANK, FEEDING, PWRFAIL, 0x1A); |
233 |
233: char len,i; |
233: lcd_goto(40); |
234 |
234: |
234: lcd_puts(global_serial_send); |
235 |
235: if( global_interval_changed ) |
235: serial_send(); |
236 |
236: { |
236: DelayMs(250); |
237 |
237: len = strlen(cell_nr); |
237: global_sms_counter++; |
238 |
238: eeprom_write(0, (global_time_interval/60)); |
238: } |
239 |
239: eeprom_write(1, global_sms_counter>>8); |
239: |
240 |
240: eeprom_write(2, global_sms_counter); |
240: void convertTemp() |
241 |
241: eeprom_write(3, len); |
241: { |
242 |
242: |
242: short adVal; |
243 |
243: for (i=0; i<len; ++i) |
243: adVal = (global_Pot_Hi << 8) | global_Pot_Lo; |
244 |
244: { |
244: if( adVal >=840 ) |
245 |
245: eeprom_write(i+4, cell_nr[i] ); |
245: global_temp = 100; |
246 |
246: } |
246: else |
247 |
247: |
247: global_temp = (adVal / 8.3886); |
248 |
248: global_interval_changed = 0; |
248: } |
249 |
249: } |
249: |
250 |
250: } |
250: |
251 |
251: |
251: |
252 |
252: void eeprom_reader(void) |
252: void eeprom_writer(void) |
253 |
253: { |
253: { |
254 |
254: char len,i; |
254: char len,i; |
255 |
255: |
255: |
256 |
256: global_time_interval = eeprom_read(0); |
256: len = strlen(cell_nr); |
257 |
257: global_time_interval *= 60; |
257: eeprom_write(0, (global_time_interval/60)); |
258 |
258: global_sms_counter = (eeprom_read(1)<<8) | eeprom_read(2); |
258: eeprom_write(1, global_sms_counter>>8); |
259 |
259: len = eeprom_read(3); |
259: eeprom_write(2, global_sms_counter); |
260 |
260: |
260: eeprom_write(3, len); |
261 |
261: for (i=0; i<len; ++i) |
261: |
262 |
262: { |
262: for (i=0; i<len; ++i) |
263 |
263: cell_nr[i] = eeprom_read(i+4); |
263: { |
264 |
264: } |
264: eeprom_write(i+4, cell_nr[i] ); |
265 |
265: |
265: } |
266 |
266: cell_nr[i] = 0; //zero terminated! |
266: } |
267 |
267: } |
267: |
268 |
268: |
268: void eeprom_reader(void) |
269 |
269: |
269: { |
270 |
270: void main() |
270: char len,i; |
271 |
271: { |
271: |
272 |
272: ///////////////////////////////////////////// |
272: global_time_interval = eeprom_read(0); |
273 |
273: // Running Init's |
273: global_time_interval *= 60; |
274 |
274: |
274: global_sms_counter = (eeprom_read(1)<<8) | eeprom_read(2); |
275 |
275: // Running init for various components. |
275: len = eeprom_read(3); |
276 |
276: pic18_io_init(); |
276: |
277 |
277: rs232_init(); |
277: for (i=0; i<len; ++i) |
278 |
278: ad_init(); |
278: { |
279 |
279: lcd_init(0); |
279: cell_nr[i] = eeprom_read(i+4); |
280 |
280: interrupt_init(); |
280: } |
281 |
281: sms_init(); |
281: |
282 |
282: //eeprom_init(); |
282: cell_nr[i] = 0; //zero terminated! |
283 |
283: timer_init(); |
283: } |
284 |
284: eeprom_reader(); |
284: |
285 |
285: ///////////////////////////////////////////// |
285: void on_initial_recieve(void) |
286 |
286: // Main loop |
286: { |
287 |
287: send_update(); |
287: char imei[16]; |
288 |
288: while(1) |
288: char* ptr; |
289 |
289: { |
289: char i; |
290 |
290: if( (global_temp >= 90 || PWRFAIL == 1 || FIREDET == 0 || FEEDING == 1 || EMPTYTANK == 1) && global_emergency_counter >= 600 ) |
290: |
291 |
291: { |
291: if (strstr(global_serial_recieve_buffer,"+WIND: 11") != 0) |
292 |
292: send_update(); |
292: { |
293 |
293: global_emergency_counter = 0; |
293: global_modem_init = 1; |
294 |
294: } |
294: |
295 |
295: |
295: ptr = strstr(global_serial_recieve_buffer,"cgsn"); |
296 |
296: if(global_time_counter >= 3600) |
296: ptr +=4; |
297 |
297: { |
297: strncpy(imei, ptr,15); |
298 |
298: send_update(); |
298: imei[15] = 0; |
299 |
299: global_time_counter = 0; |
299: |
300 |
300: } |
300: global_imei_tversum = 0; |
301 |
301: // to avoid buffer overrun. |
301: for (i=0; i<15; ++i) |
302 |
302: if( global_emergency_counter > 7200 ) |
302: { |
303 |
303: global_emergency_counter = 600; |
303: global_imei_tversum += (imei[i] - '0'); |
304 |
304: |
304: } |
305 |
305: // Checking if A/D convertion is done, and save the data in global_Pot_?? |
305: |
306 |
306: if(GODONE==0) |
306: |
307 |
307: { |
307: reset_recieve_buffer(); |
308 |
308: global_Pot_Hi = ADRESH; |
308: } |
309 |
309: global_Pot_Lo = ADRESL; |
309: } |
310 |
310: convertTemp(); |
310: |
311 |
311: |
311: |
312 |
312: GODONE = 1; |
312: void on_recieve(void) |
313 |
313: } |
313: { |
314 |
314: |
314: char tmp[17]; |
315 |
315: update_lcd(); |
315: char* ptr; |
316 |
316: } |
316: tmp[0]=0; |
317 |
317: |
317: |
318 |
318: } |
318: if (global_recieve_done == 0) |
319 |
|
319: return; |
320 |
|
320: |
321 |
|
321: lcd_goto(0x00); |
322 |
|
322: lcd_puts(global_serial_recieve_buffer); |
323 |
|
323: |
324 |
|
324: if (strstr(global_serial_recieve_buffer,"CMTI") == 0) |
325 |
|
325: { |
326 |
|
326: ptr = strstr(global_serial_recieve_buffer,"'"); |
327 |
|
327: strcat(tmp,ptr); |
328 |
|
328: |
329 |
|
329: |
330 |
|
330: lcd_goto(0x40); |
331 |
|
331: lcd_puts(tmp); |
332 |
|
332: |
333 |
|
333: } |
334 |
|
334: |
335 |
|
335: reset_recieve_buffer(); |
336 |
|
336: } |
337 |
|
337: |
338 |
|
338: void main() |
339 |
|
339: { |
340 |
|
340: //////////////////// |
341 |
|
341: // Running Init's // |
342 |
|
342: |
343 |
|
343: // Running init for various components. |
344 |
|
344: pic18_io_init(); |
345 |
|
345: rs232_init(); |
346 |
|
346: ad_init(); |
347 |
|
347: lcd_init(0); |
348 |
|
348: interrupt_init(); |
349 |
|
349: sms_init(); |
350 |
|
350: //eeprom_init(); |
351 |
|
351: timer_init(); |
352 |
|
352: eeprom_reader(); |
353 |
|
353: /////////////// |
354 |
|
354: // Main loop // |
355 |
|
355: |
356 |
|
356: DelayMs(50); |
357 |
|
357: reset_recieve_buffer(); |
358 |
|
358: |
359 |
|
359: while(1) |
360 |
|
360: { |
361 |
|
361: // If there happends to be a critical state on the system, we send a sms. |
362 |
|
362: if( (global_temp >= 90 || PWRFAIL == 1 || FIREDET == 0 || FEEDING == 1 || EMPTYTANK == 1) && global_emergency_counter >= 600 ) |
363 |
|
363: { |
364 |
|
364: send_update(); |
365 |
|
365: global_emergency_counter = 0; |
366 |
|
366: } |
367 |
|
367: // Every X sec. a status sms is send. |
368 |
|
368: if(global_time_counter >= 3600) |
369 |
|
369: { |
370 |
|
370: send_update(); |
371 |
|
371: global_time_counter = 0; |
372 |
|
372: } |
373 |
|
373: // To avoid buffer overrun. |
374 |
|
374: if( global_emergency_counter > 7200 ) |
375 |
|
375: global_emergency_counter = 600; |
376 |
|
376: |
377 |
|
377: // Checks if there has been recieved a config sms. |
378 |
|
378: if(global_interval_changed ) |
379 |
|
379: { |
380 |
|
380: eeprom_writer(); |
381 |
|
381: global_interval_changed = 0; |
382 |
|
382: } |
383 |
|
383: // Checking if A/D convertion is done, and save the data in global_Pot_?? |
384 |
|
384: if(GODONE==0) |
385 |
|
385: { |
386 |
|
386: global_Pot_Hi = ADRESH; |
387 |
|
387: global_Pot_Lo = ADRESL; |
388 |
|
388: convertTemp(); |
389 |
|
389: //update_lcd(); |
390 |
|
390: GODONE = 1; |
391 |
|
391: } |
392 |
|
392: // Handels the recieve sms'es. |
393 |
|
393: on_recieve(); |
394 |
|
394: } |
395 |
|
395: } |