Rev Author Line No. Line
1274 kakl 1 /**** IR Mrakomer 4 ****/
1720 kakl 2 #define VERSION "4.1"
1277 kakl 3 #define ID "$Id: irmrak4.c 4681 2016-08-16 14:39:27Z kakl $"
1293 kakl 4  
1274 kakl 5 #include "irmrak4.h"
6  
1293 kakl 7 #bit CREN = 0x18.4 // USART registers
8 #bit SPEN = 0x18.7
9 #bit OERR = 0x18.1
10 #bit FERR = 0x18.2
11  
12 #include <string.h>
13  
1289 kakl 14 #CASE // Case sensitive compiler
15  
1280 kakl 16 #define MAXHEAT 20 // Number of cycles for heating
17 #define MAXOPEN 20 // Number of cycles for dome open
1287 kakl 18 #define MEASURE_DELAY 6000 // Delay to a next measurement
1280 kakl 19 #define RESPONSE_DELAY 100 // Reaction time after receiving a command
1287 kakl 20 #define SAFETY_COUNT 90 // Time of one emergency cycle
1280 kakl 21 #define SEND_DELAY 50 // Time between two characters on RS232
1862 kakl 22 #define TEMPERATURE_INSIDE 1800 // Keep this temperature inside MM's box
1275 kakl 23  
1274 kakl 24 #define DOME PIN_B4 // Dome controll port
25 #define HEATING PIN_B3 // Heating for defrosting
26  
27  
1280 kakl 28 char VER[4]=VERSION; // Buffer for concatenate of a version string
1274 kakl 29  
1280 kakl 30 int8 heat; // Status variables
1274 kakl 31 int8 open;
32  
1284 kakl 33 inline void toggle_dome(void) // Wire exercise
1275 kakl 34 {
35 if (open>0)
1285 kakl 36 {output_toggle(DOME);} // Toggle = Open Dome
37 else
38 {output_high(DOME);} // Do not toggle = Close Dome
1275 kakl 39 }
1274 kakl 40  
1284 kakl 41 void delay(int16 cycles) // Wire exercise with delay
1274 kakl 42 {
1275 kakl 43 int16 i;
1278 kakl 44  
1275 kakl 45 for(i=0; i<cycles; i++) {toggle_dome(); delay_us(100);}
46 }
1274 kakl 47  
1284 kakl 48 void welcome(void) // Welcome message
49 {
1293 kakl 50 char REV[50]=ID; // Buffer for concatenate of a version string
51  
52 if (REV[strlen(REV)-1]=='$') REV[strlen(REV)-1]=0;
2177 kaklik 53 printf("\r\n\r\n# Mrakomer %s (C) 2011 UST\r\n",VER); // Welcome message
1720 kakl 54 printf("#%s\r\n",&REV[4]);
55 // printf("#\r\n");
1884 kakl 56 // printf("# commands: h, c, o, l, x, i, r, a, s, u\r\n");
1720 kakl 57 // printf("# h_eat, c_old, o_pen, l_ock, x_open, ");
58 // printf("i_nfo, r_epeat, a_uto, s_single, u_pdate\r\n");
59 // printf("#\r\n");
1862 kakl 60 // printf("# ver seq in[1/100 C] sky[1/100 C] sky[1/100 C] ");
61 // printf("out[1/100 C] heat[s] dome[s] check\r\n\r\n");
1720 kakl 62  
1303 kakl 63 //---WDT
64 restart_wdt();
1284 kakl 65 }
1274 kakl 66  
67  
1284 kakl 68 #include "smb.c" // System Management Bus driver
1720 kakl 69 #include "TOUCH.C"
1274 kakl 70  
1284 kakl 71  
1293 kakl 72 // Read sensor's RAM
1280 kakl 73 // Returns temperature in °K
1281 kakl 74 int16 ReadTemp(int8 addr, int8 select)
1274 kakl 75 {
76 unsigned char arr[6]; // Buffer for the sent bytes
77 int8 crc; // Readed CRC
78 int16 temp; // Readed temperature
79  
1275 kakl 80 addr<<=1;
81  
1284 kakl 82 SMB_STOP_bit(); //If slave send NACK stop comunication
83 SMB_START_bit(); //Start condition
1275 kakl 84 SMB_TX_byte(addr);
85 SMB_TX_byte(RAM_Access|select);
1284 kakl 86 SMB_START_bit(); //Repeated Start condition
1275 kakl 87 SMB_TX_byte(addr);
1284 kakl 88 arr[2]=SMB_RX_byte(ACK); //Read low data,master must send ACK
89 arr[1]=SMB_RX_byte(ACK); //Read high data,master must send ACK
1289 kakl 90 temp=make16(arr[1],arr[2]);
1284 kakl 91 crc=SMB_RX_byte(NACK); //Read PEC byte, master must send NACK
92 SMB_STOP_bit(); //Stop condition
1274 kakl 93  
94 arr[5]=addr;
95 arr[4]=RAM_Access|select;
96 arr[3]=addr;
97 arr[0]=0;
98 if (crc != PEC_calculation(arr)) temp=0; // Calculate and check CRC
99  
100 return temp;
101 }
102  
1720 kakl 103 // compute CRC
104 // *sn - pointer to the byte array
105 // num - length of array
106 inline int8 TM_check_CRC(unsigned int8 *sn, unsigned int8 num)
107 {
108 // CRC table
109 const int8 TouchCRC[256]= {
110 0, 94, 188, 226, 97, 63, 221, 131, 194, 156, 126, 32, 163, 253, 31, 65,
111 157, 195, 33, 127, 252, 162, 64, 30, 95, 1, 227, 189, 62, 96, 130, 220,
112 35, 125, 159, 193, 66, 28, 254, 160, 225, 191, 93, 3, 128, 222, 60, 98,
113 190, 224, 2, 92, 223, 129, 99, 61, 124, 34, 192, 158, 29, 67, 161, 255,
114 70, 24, 250, 164, 39, 121, 155, 197, 132, 218, 56, 102, 229, 187, 89, 7,
115 219, 133, 103, 57, 186, 228, 6, 88, 25, 71, 165, 251, 120, 38, 196, 154,
116 101, 59, 217, 135, 4, 90, 184, 230, 167, 249, 27, 69, 198, 152, 122, 36,
117 248, 166, 68, 26, 153, 199, 37, 123, 58, 100, 134, 216, 91, 5, 231, 185,
118 140, 210, 48, 110, 237, 179, 81, 15, 78, 16, 242, 172, 47, 113, 147, 205,
119 17, 79, 173, 243, 112, 46, 204, 146, 211, 141, 111, 49, 178, 236, 14, 80,
120 175, 241, 19, 77, 206, 144, 114, 44, 109, 51, 209, 143, 12, 82, 176, 238,
121 50, 108, 142, 208, 83, 13, 239, 177, 240, 174, 76, 18, 145, 207, 45, 115,
122 202, 148, 118, 40, 171, 245, 23, 73, 8, 86, 180, 234, 105, 55, 213, 139,
123 87, 9, 235, 181, 54, 104, 138, 212, 149, 203, 41, 119, 244, 170, 72, 22,
124 233, 183, 85, 11, 136, 214, 52, 106, 43, 117, 151, 201, 74, 20, 246, 168,
125 116, 42, 200, 150, 21, 75, 169, 247, 182, 232, 10, 84, 215, 137, 107, 53};
1298 kakl 126  
1720 kakl 127 int8 CRC;
128 int8 i;
129  
130 CRC=0;
131 for(i=0;i<num;i++) CRC=TouchCRC[CRC ^ *(sn+i)];
132 return(CRC);
133 }
134  
135  
1298 kakl 136 /*-------------------------------- MAIN --------------------------------------*/
1300 kakl 137 void main()
1274 kakl 138 {
1280 kakl 139 unsigned int16 seq, temp, tempa;
1958 kakl 140 signed int16 ta, to1, to2, tTouch;
1720 kakl 141 int8 tLSB,tMSB; // Temperatures from TouchMemory
1280 kakl 142 int8 safety_counter;
1958 kakl 143 int8 heatTime;
1720 kakl 144 int1 repeat; // Status flags
145 int1 automatic;
1274 kakl 146  
4248 kakl 147 //KAKL!!!
148 int8 SN[10];
149  
150  
1285 kakl 151 output_high(DOME); // Close Dome
1274 kakl 152 output_low(HEATING); // Heating off
153  
154 delay_ms(1000);
155 restart_wdt();
1284 kakl 156  
1285 kakl 157 seq=0; // Variables initiation
158 heat=0;
159 open=0;
1884 kakl 160 heatTime=0;
1291 kakl 161 repeat=TRUE;
1720 kakl 162 automatic=FALSE;
1289 kakl 163  
1284 kakl 164 welcome();
1285 kakl 165  
1274 kakl 166 tempa=ReadTemp(SA, RAM_Tamb); // Dummy read
167 temp=ReadTemp(SA, RAM_Tobj1);
1720 kakl 168 touch_present(); //Issues a reset of Touch Memory device
169 touch_write_byte(0xCC);
170 touch_write_byte(0x44);
1274 kakl 171  
1286 kakl 172 delay_ms(1000);
1280 kakl 173 //---WDT
1274 kakl 174 restart_wdt();
1862 kakl 175  
1284 kakl 176 while(TRUE) // Main Loop
1274 kakl 177 {
1284 kakl 178 safety_counter=SAFETY_COUNT; // Heating and Dome Count Down
1278 kakl 179 do
1274 kakl 180 {
1280 kakl 181 if (safety_counter<SAFETY_COUNT) safety_counter++;
1274 kakl 182  
1280 kakl 183 delay(RESPONSE_DELAY);
184  
185 if (safety_counter>=SAFETY_COUNT)
186 {
1862 kakl 187 if (heat>0) { output_high(HEATING); } else { output_low(HEATING); }
188  
1288 kakl 189 if (heat>0) heat--;
1280 kakl 190 if (open>0) open--;
191  
192 safety_counter=0;
193 //---WDT
194 restart_wdt();
195 }
1288 kakl 196 } while (!kbhit()&&!repeat);
1285 kakl 197  
1280 kakl 198 //---WDT
199 restart_wdt();
1284 kakl 200 { // Retrieve command
1288 kakl 201 char ch='k';
1278 kakl 202  
1288 kakl 203 if(kbhit()) ch=getc();
1278 kakl 204  
1274 kakl 205 switch (ch)
206 {
207 case 'h':
1280 kakl 208 heat=MAXHEAT; // Need heating
1720 kakl 209 automatic=FALSE;
1274 kakl 210 break;
1278 kakl 211  
1274 kakl 212 case 'c':
1280 kakl 213 heat=0; // Need colder
1720 kakl 214 automatic=FALSE;
1274 kakl 215 break;
1278 kakl 216  
1274 kakl 217 case 'o':
218 open=MAXOPEN; // Open the dome
1720 kakl 219 automatic=FALSE;
1274 kakl 220 break;
1278 kakl 221  
1284 kakl 222 case 'x':
223 open=MAXOPEN; // Open the dome
224 heat=MAXHEAT; // Need heating
1720 kakl 225 automatic=FALSE;
1284 kakl 226 break;
227  
1274 kakl 228 case 'l':
229 open=0; // Lock the dome
1720 kakl 230 automatic=FALSE;
1274 kakl 231 break;
1284 kakl 232  
233 case 'i':
1287 kakl 234 if (open==0) welcome(); // Information about version, etc...
235 break; // Only when dome is closed
1288 kakl 236  
237 case 'r':
1292 kakl 238 repeat=TRUE; // Repeated measure mode
1720 kakl 239 automatic=FALSE;
1288 kakl 240 break;
241  
242 case 's':
243 repeat=FALSE; // Single measure mode
1720 kakl 244 automatic=FALSE;
1288 kakl 245 break;
1293 kakl 246  
1720 kakl 247 case 'a':
248 repeat=TRUE; // Automatic mode
249 automatic=TRUE;
250 break;
251  
1293 kakl 252 case 'u':
1300 kakl 253 reset_cpu(); // Update firmware
1274 kakl 254 }
255 }
1288 kakl 256 CREN=0; CREN=1; // Reinitialise USART
1274 kakl 257  
1280 kakl 258 seq++; // Increment the number of measurement
1274 kakl 259  
260 tempa=ReadTemp(SA, RAM_Tamb); // Read temperatures from sensor
1720 kakl 261 ta=tempa*2-27315; // °K -> °C
262  
1274 kakl 263 temp=ReadTemp(SA, RAM_Tobj1);
1720 kakl 264 if (temp>0x48E1) {to1=-27315;} else {to1=temp*2-27315;}
265 temp=ReadTemp(SA, RAM_Tobj2);
266 if (temp>0x48E1) {to2=-27315;} else {to2=temp*2-27315;}
1274 kakl 267  
1720 kakl 268 touch_present(); //Issues a reset of Touch Memory device
269 touch_write_byte(0xCC);
270 touch_write_byte(0x44);
271  
272 //---WDT
273 restart_wdt();
274 delay(MEASURE_DELAY); // Delay to a next measurement
1274 kakl 275  
1720 kakl 276 {
4248 kakl 277 //KAKL!!! int8 SN[10];
1720 kakl 278 int8 n;
279  
280 touch_present(); //Issues a reset and returns true if the touch device is there.
281 touch_write_byte(0xCC);
282 touch_write_byte(0xBE);
283 for(n=0;n<9;n++) SN[n]=touch_read_byte();
284 tLSB=SN[0];
285 tMSB=SN[1];
4681 kakl 286 /*KAKL!!!
1720 kakl 287 if ((SN[8]==TM_check_CRC(SN,8))&&(SN[7]==0x10)) // Check CRC and family code to prevent O's error
288 {
289 tTouch=make16(tMSB,tLSB);
290 tTouch=tTouch*6+tTouch/4; // 1bit = 0,0625gradC recalculate to 1/100gradC
291 }
292 else
293 {
294 tTouch=-27315;
295 }
4681 kakl 296 */
297 tTouch=make16(tMSB,tLSB);
298 tTouch=tTouch*6+tTouch/4; // 1bit = 0,0625gradC recalculate to 1/100gradC
299  
1720 kakl 300 }
301  
4248 kakl 302 /*
1720 kakl 303 if(automatic) // Solve automatic mode
304 {
1884 kakl 305 if (heatTime==0)
1958 kakl 306 {
307 if((tTouch<=-300)&&(ta<=300)) {heat=(700-tTouch)/400;} else {heat=1;} // Needs warmer?
308 heatTime=MAXHEAT;
1884 kakl 309 }
310 heatTime--;
1958 kakl 311  
312 if(ta>2000) heat=0; // Overtemperature protection
313 if(tTouch>2000) heat=0;
314 if(ta<-10000) heat=0; // Sensor Error protection
315 if(tTouch<-10000) heat=0;
1884 kakl 316  
1958 kakl 317 if((abs(to1-to2)<100)&&(tTouch>to1)&&(abs(tTouch-to1)>800)) open=1; // Control the dome
318 if(to1<-10000) open=0; // Sensor Error protection
319 if(tTouch<-10000) open=0;
1720 kakl 320 }
4248 kakl 321 */
1274 kakl 322 { // printf
1284 kakl 323 char output[8]; // Output buffer
324 int8 j; // String pointer
1293 kakl 325 int8 check=0; // Checksum is calculated between '$' and '*'
1278 kakl 326  
1282 kakl 327 delay(SEND_DELAY);
1293 kakl 328 putc('$');
329 delay(SEND_DELAY);
1720 kakl 330 sprintf(output,"M%s \0",VER);
1293 kakl 331 j=0; while(output[j]!=0) { delay(SEND_DELAY); putc(output[j]); check^=output[j++]; }
1720 kakl 332 sprintf(output,"%Lu \0", seq);
1293 kakl 333 j=0; while(output[j]!=0) { delay(SEND_DELAY); putc(output[j]); check^=output[j++]; }
1720 kakl 334 sprintf(output,"%Ld \0", ta);
1293 kakl 335 j=0; while(output[j]!=0) { delay(SEND_DELAY); putc(output[j]); check^=output[j++]; }
1720 kakl 336 sprintf(output,"%Ld \0", to1);
1293 kakl 337 j=0; while(output[j]!=0) { delay(SEND_DELAY); putc(output[j]); check^=output[j++]; }
1720 kakl 338 sprintf(output,"%Ld \0", to2);
1293 kakl 339 j=0; while(output[j]!=0) { delay(SEND_DELAY); putc(output[j]); check^=output[j++]; }
1720 kakl 340 sprintf(output,"%Ld \0",tTouch);
1293 kakl 341 j=0; while(output[j]!=0) { delay(SEND_DELAY); putc(output[j]); check^=output[j++]; }
1720 kakl 342 sprintf(output,"%u \0", heat);
343 j=0; while(output[j]!=0) { delay(SEND_DELAY); putc(output[j]); check^=output[j++]; }
344 sprintf(output,"%u \0", open);
345 j=0; while(output[j]!=0) { delay(SEND_DELAY); putc(output[j]); check^=output[j++]; }
4248 kakl 346 //KAKL!!! sprintf(output,"*%X\r\n\0", check);
347 sprintf(output,"*%X \0", check);
1282 kakl 348 j=0; while(output[j]!=0) { delay(SEND_DELAY); putc(output[j++]); }
4248 kakl 349 {
350 int n;
351 for (n=0;n<9;n++)
352 {
353 sprintf(output,"%X \0", SN[n]);
354  
355 j=0; while(output[j]!=0) { delay(SEND_DELAY); putc(output[j++]); }
356 }
357 }
358 sprintf(output,"\r\n\0");
359 j=0; while(output[j]!=0) { delay(SEND_DELAY); putc(output[j++]); }
360  
1293 kakl 361 delay(SEND_DELAY);
1274 kakl 362 }
1720 kakl 363  
1280 kakl 364 //---WDT
365 restart_wdt();
1274 kakl 366 }
367 }
1298 kakl 368  
369  
1300 kakl 370 #include "dbloader.c" // Space reservation for the BootLoader