FreeCalypso > hg > fc-selenite
comparison src/cs/services/dar/dar_emergency.c @ 0:b6a5e36de839
src/cs: initial import from Magnetite
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 15 Jul 2018 04:39:26 +0000 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:b6a5e36de839 |
---|---|
1 /****************************************************************************/ | |
2 /* */ | |
3 /* File Name: dar_emergency.c */ | |
4 /* */ | |
5 /* Purpose: This function is called when the DAR entity has detected */ | |
6 /* an emergency ( Error or exception) */ | |
7 /* */ | |
8 /* */ | |
9 /* Version 0.1 */ | |
10 /* */ | |
11 /* Date Modification */ | |
12 /* ------------------------------------ */ | |
13 /* 17 October 2001 Create */ | |
14 /* */ | |
15 /* Author Stephanie Gerthoux */ | |
16 /* */ | |
17 /* (C) Copyright 2001 by Texas Instruments Incorporated, All Rights Reserved*/ | |
18 /****************************************************************************/ | |
19 | |
20 #include "rv/rv_defined_swe.h" | |
21 #ifdef RVM_DAR_SWE | |
22 /* ************************************************ */ | |
23 /* THE DAR ENTITY IS ENABLED */ | |
24 /* ************************************************ */ | |
25 | |
26 #include <string.h> | |
27 #include "rvm/rvm_gen.h" | |
28 #include "dar/dar_api.h" | |
29 #include "dar/dar_macro_i.h" | |
30 #include "dar/dar_messages_i.h" | |
31 #include "dar/dar_const_i.h" | |
32 #include "dar/dar_diagnose_i.h" | |
33 #include "dar/dar_msg_ft.h" | |
34 | |
35 #ifndef _WINDOWS | |
36 #include "timer/timer.h" | |
37 #endif | |
38 | |
39 /**** Global variable ****/ | |
40 /* index used in the circular buffer*/ | |
41 extern UINT16 dar_current_index; | |
42 | |
43 /* Write buffer*/ | |
44 extern char dar_write_buffer[DAR_MAX_BUFFER_SIZE]; | |
45 | |
46 /* Get the dar current status */ | |
47 extern T_DAR_RECOVERY_STATUS dar_current_status; | |
48 | |
49 /* Get the dar exception status */ | |
50 extern UINT8 dar_exception_status; | |
51 | |
52 /* Define a pointer to the Global Environment Control block */ | |
53 extern T_DAR_ENV_CTRL_BLK *dar_gbl_var_p; | |
54 | |
55 /* Define the recovery buffer */ | |
56 extern UINT8 dar_recovery_buffer[DAR_RECOVERY_DATA_MAX_BUFFER_SIZE]; | |
57 | |
58 /* Ram buffer that contains the Debug Unit register */ | |
59 extern UINT32 debug_RAM[DEBUG_UNIT_WORD_SIZE]; | |
60 | |
61 | |
62 /**** Extern functions ****/ | |
63 extern void * dar_read_mbox (UINT8 mbox); | |
64 | |
65 extern void exception(void); | |
66 | |
67 | |
68 /********************************************************************************/ | |
69 /* */ | |
70 /* Function Name: dar_process_emergency */ | |
71 /* */ | |
72 /* Purpose: This function is called to process emergency data and to store */ | |
73 /* them in RAM buffer when an emergency has been detected */ | |
74 /* */ | |
75 /* */ | |
76 /* Input Parameters: */ | |
77 /* Pointer to the message to store */ | |
78 /* Data Format, ( the Binary format is not supported) */ | |
79 /* Data Use Id, */ | |
80 /* Flags */ | |
81 /* */ | |
82 /* Output Parameters: */ | |
83 /* Validation of the diagnose execution. */ | |
84 /* */ | |
85 /* */ | |
86 /* */ | |
87 /* Revision History: */ | |
88 /* None. */ | |
89 /* */ | |
90 /********************************************************************************/ | |
91 T_RV_RET dar_process_emergency( T_DAR_INFO *buffer_p, | |
92 T_DAR_FORMAT format, | |
93 T_RVM_USE_ID dar_use_id, | |
94 UINT32 flags) | |
95 { | |
96 /* Declare local variables */ | |
97 UINT32 i = 0; | |
98 UINT32 length = 0; | |
99 T_RV_HDR *msg_p = ( T_RV_HDR*) dar_read_mbox(DAR_MBOX); | |
100 | |
101 /**** Update the DAR recovery status ****/ | |
102 dar_current_status = DAR_EMERGENCY_SCUTTLING; | |
103 | |
104 /**** Empty the mail box before the reset of the system ****/ | |
105 while(msg_p != NULL) | |
106 { | |
107 /* If it's a Write message, store it in the RAM */ | |
108 /* ( it is not interesting to store filter message ) */ | |
109 if ((msg_p->msg_id) == DAR_WRITE_REQ) | |
110 { | |
111 /* store the message in the RAM*/ | |
112 dar_write_data_in_buffer((T_DAR_WRITE_START *)msg_p); | |
113 } | |
114 | |
115 /* free the Header of the message */ | |
116 rvf_free_buf((T_RVF_BUFFER *) msg_p); | |
117 | |
118 /* Read the next message */ | |
119 msg_p = ( T_RV_HDR*) dar_read_mbox(DAR_MBOX); | |
120 | |
121 } /* while (msg_p != NULL) */ | |
122 | |
123 /**** Store emergency data in RAM buffer ****/ | |
124 /* Diagnose string length */ | |
125 length = (UINT16) strlen(buffer_p); | |
126 | |
127 /**** Check if the DAR entity is started ****/ | |
128 if (dar_gbl_var_p != NULL ) | |
129 { | |
130 /* Data format */ | |
131 dar_gbl_var_p->format = format; | |
132 } | |
133 | |
134 if ( flags & DAR_NEW_ENTRY ) | |
135 { | |
136 /** Circular buffer to store data **/ | |
137 /* Add 0xFF to separate 2 strings */ | |
138 dar_write_buffer[dar_current_index] = 0xF; | |
139 DAR_PLUS_PLUS(dar_current_index); /* to detected if it is the end of the buffer */ | |
140 dar_write_buffer[dar_current_index] = 0xF; | |
141 DAR_PLUS_PLUS(dar_current_index); /* to detected if it is the end of the buffer */ | |
142 | |
143 /* The group_nb is 16 bit length, and the buffer is an UINT8 length */ | |
144 /* So the group_nb must be stocked by dividing it in 2 parts */ | |
145 dar_write_buffer[dar_current_index] = ((dar_use_id>>16)& 0x7FFF)>>8; | |
146 /*add the 8 first bits of the Use id group*/ | |
147 DAR_PLUS_PLUS(dar_current_index); | |
148 dar_write_buffer[dar_current_index] = (dar_use_id>>16)& 0x7FFF; | |
149 /*add the 8 last bits of the Use id group*/ | |
150 DAR_PLUS_PLUS(dar_current_index); | |
151 | |
152 /* The mask is 16 bit length, and the buffer is an UINT8 length */ | |
153 /* So the mask must be stocked by dividing it in 2 parts */ | |
154 dar_write_buffer[dar_current_index] = ((dar_use_id)&0xFFFF)>>8; | |
155 /* add the 8 first bits of the Use id mask */ | |
156 DAR_PLUS_PLUS(dar_current_index); | |
157 dar_write_buffer[dar_current_index] = (dar_use_id)&0xFFFF; | |
158 /* add the 8 last bits of the Use id mask */ | |
159 DAR_PLUS_PLUS(dar_current_index); | |
160 | |
161 /* Add the dar_level data */ | |
162 dar_write_buffer[dar_current_index] = DAR_ERROR; | |
163 DAR_PLUS_PLUS(dar_current_index); | |
164 } | |
165 | |
166 /* circular buffer to store diagnose data in RAM buffer */ | |
167 for (i=0; i < length; i++ ) | |
168 { | |
169 /* copy string in the RAM char by char*/ | |
170 dar_write_buffer[dar_current_index]=buffer_p[i]; | |
171 | |
172 /* detection of the end of the buffer */ | |
173 /* When current = DAR_MAX_BUFFER_SIZE , current = 0 */ | |
174 DAR_PLUS_PLUS(dar_current_index); | |
175 } | |
176 | |
177 /* DAR information is redirected to standard trace */ | |
178 //DAR_SEND_TRACE("Circular buffer :",RV_TRACE_LEVEL_ERROR); | |
179 //rvf_send_trace(buffer_p, length, NULL_PARAM, RV_TRACE_LEVEL_ERROR, DAR_USE_ID); | |
180 | |
181 /* Trace the buffer (used for debug) */ | |
182 rvf_delay(RVF_MS_TO_TICKS(1000)); | |
183 | |
184 | |
185 /**** Check if the DAR entity is started ****/ | |
186 if (dar_gbl_var_p != NULL ) | |
187 { | |
188 if (dar_gbl_var_p->entity_dar_callback != NULL ) | |
189 { | |
190 /* Call the MMI callback function to save some parameters before reset */ | |
191 dar_gbl_var_p->entity_dar_callback(dar_recovery_buffer,DAR_RECOVERY_DATA_MAX_BUFFER_SIZE); | |
192 } | |
193 } | |
194 | |
195 /* The system is reset if requested */ | |
196 if ( flags & DAR_EMERGENCY_RESET ) | |
197 { | |
198 dar_reset(); | |
199 } | |
200 return(RV_OK); | |
201 | |
202 } /* dar_process_emergency */ | |
203 | |
204 | |
205 /********************************************************************************/ | |
206 /* */ | |
207 /* Function Name: dar_exception_arm_undefined */ | |
208 /* */ | |
209 /* Purpose: This function is called to process ARM undefined instruction */ | |
210 /* exception and to store this exception in the RAM buffer */ | |
211 /* */ | |
212 /* Input Parameters: */ | |
213 /* None */ | |
214 /* */ | |
215 /* Output Parameters: */ | |
216 /* Validation of the diagnose execution. */ | |
217 /* */ | |
218 /* */ | |
219 /* */ | |
220 /* Revision History: */ | |
221 /* None. */ | |
222 /* */ | |
223 /********************************************************************************/ | |
224 void dar_exception_arm_undefined(void) | |
225 { | |
226 /* Declare local variables */ | |
227 T_DAR_INFO *buffer_p= " DAR Emergency exception : ARM undefined ";/*exception data to store*/ | |
228 | |
229 /* Update the DAR recovery status */ | |
230 dar_current_status = DAR_EMERGENCY_SCUTTLING; | |
231 | |
232 /* Update the DAR exception status */ | |
233 dar_exception_status = DAR_EXCEPTION_UNDEFINED; | |
234 | |
235 /* Empty the mail box and store data in RAM buffer */ | |
236 dar_empty_mb_and_save_data(buffer_p); | |
237 | |
238 /* Check if the DAR entity is started */ | |
239 if (dar_gbl_var_p != NULL ) | |
240 { | |
241 if (dar_gbl_var_p->entity_dar_callback != NULL) | |
242 { | |
243 /* Call the MMI callback function to save some parameters before reset */ | |
244 dar_gbl_var_p->entity_dar_callback(dar_recovery_buffer,DAR_RECOVERY_DATA_MAX_BUFFER_SIZE); | |
245 } | |
246 } | |
247 | |
248 #ifndef _WINDOWS | |
249 /* branch to "exception" defined in the int.s*/ | |
250 exception(); | |
251 #endif | |
252 | |
253 } /* dar_exception_arm_undefined */ | |
254 | |
255 /********************************************************************************/ | |
256 /* */ | |
257 /* Function Name: dar_exception_arm_swi */ | |
258 /* */ | |
259 /* Purpose: This function is called to process ARM SW Interrupt exception */ | |
260 /* and to store this exception in the RAM buffer */ | |
261 /* */ | |
262 /* Input Parameters: */ | |
263 /* None */ | |
264 /* */ | |
265 /* Output Parameters: */ | |
266 /* Validation of the diagnose execution. */ | |
267 /* */ | |
268 /* */ | |
269 /* */ | |
270 /* Revision History: */ | |
271 /* None. */ | |
272 /* */ | |
273 /********************************************************************************/ | |
274 void dar_exception_arm_swi(void) | |
275 { | |
276 /* Declare local variables */ | |
277 T_DAR_INFO *buffer_p= " DAR Emergency exception : ARM SWI ";/*exception data to store*/ | |
278 | |
279 /* Update the DAR recovery status */ | |
280 dar_current_status = DAR_EMERGENCY_SCUTTLING; | |
281 | |
282 /* Update the DAR exception status */ | |
283 dar_exception_status = DAR_EXCEPTION_SWI; | |
284 | |
285 /* Empty the mail box and store data in RAM buffer */ | |
286 dar_empty_mb_and_save_data(buffer_p); | |
287 | |
288 /* Check if the DAR entity is started */ | |
289 if (dar_gbl_var_p != NULL ) | |
290 { | |
291 if ( dar_gbl_var_p->entity_dar_callback != NULL) | |
292 { | |
293 /* Call the MMI callback function to save some parameters before reset */ | |
294 dar_gbl_var_p->entity_dar_callback(dar_recovery_buffer,DAR_RECOVERY_DATA_MAX_BUFFER_SIZE); | |
295 } | |
296 } | |
297 | |
298 #ifndef _WINDOWS | |
299 /* branch to "exception" defined in the int.s*/ | |
300 exception(); | |
301 #endif | |
302 | |
303 } /* dar_exception_arm_swi */ | |
304 | |
305 /********************************************************************************/ | |
306 /* */ | |
307 /* Function Name: dar_exception_arm_abort_prefetch */ | |
308 /* */ | |
309 /* Purpose: This function is called to process ARM abort prefetch exception */ | |
310 /* and to store this exception in the RAM buffer */ | |
311 /* */ | |
312 /* Input Parameters: */ | |
313 /* None */ | |
314 /* */ | |
315 /* Output Parameters: */ | |
316 /* Validation of the diagnose execution. */ | |
317 /* */ | |
318 /* */ | |
319 /* */ | |
320 /* Revision History: */ | |
321 /* None. */ | |
322 /* */ | |
323 /********************************************************************************/ | |
324 void dar_exception_arm_abort_prefetch(void) | |
325 { | |
326 #ifndef _WINDOWS | |
327 /* Local variable */ | |
328 UINT8 i; | |
329 #endif | |
330 | |
331 #if ((CHIPSET == 7) || (CHIPSET == 8) || (CHIPSET == 10) || (CHIPSET == 11) || (CHIPSET == 12)) | |
332 /* Debug unit pointer */ | |
333 volatile UINT32 *debug_register_p; | |
334 #endif | |
335 | |
336 /* Declare local variables */ | |
337 T_DAR_INFO *buffer_p = " DAR Emergency exception : ARM abort prefetch";/*exception data to store*/ | |
338 | |
339 /* Update the DAR recovery status */ | |
340 dar_current_status = DAR_EMERGENCY_SCUTTLING; | |
341 | |
342 /* Update the DAR exception status */ | |
343 dar_exception_status = DAR_EXCEPTION_PREFETCH_ABORT; | |
344 | |
345 /* Empty the mail box and store data in RAM buffer */ | |
346 dar_empty_mb_and_save_data(buffer_p); | |
347 | |
348 /* Check if the DAR entity is started */ | |
349 if (dar_gbl_var_p != NULL ) | |
350 { | |
351 if (dar_gbl_var_p->entity_dar_callback != NULL) | |
352 { | |
353 /* Call the MMI callback function to save some parameters before reset */ | |
354 dar_gbl_var_p->entity_dar_callback(dar_recovery_buffer,DAR_RECOVERY_DATA_MAX_BUFFER_SIZE); | |
355 } | |
356 } | |
357 | |
358 #if ((CHIPSET == 7) || (CHIPSET == 8) || (CHIPSET == 10) || (CHIPSET == 11) || (CHIPSET == 12)) | |
359 /* Initialize the adress of the Debug Unit pointer */ | |
360 debug_register_p = (volatile UINT32*) DAR_DEBUG_UNIT_REGISTER; | |
361 #endif | |
362 | |
363 #ifndef _WINDOWS | |
364 #if ((CHIPSET == 7) || (CHIPSET == 8) || (CHIPSET == 10) || (CHIPSET == 11) || (CHIPSET == 12)) | |
365 /* Save the Debug Unit into the RAM */ | |
366 for (i=0; i<DEBUG_UNIT_WORD_SIZE; i++ ) | |
367 { | |
368 debug_RAM[i] = *debug_register_p; | |
369 debug_register_p++; | |
370 } | |
371 #endif | |
372 | |
373 /* branch to "exception" defined in the int.s*/ | |
374 exception(); | |
375 #endif | |
376 | |
377 } /* dar_exception_arm_abort_prefetch */ | |
378 | |
379 /********************************************************************************/ | |
380 /* */ | |
381 /* Function Name: dar_exception_arm_abort_data */ | |
382 /* */ | |
383 /* Purpose: This function is called to process ARM abort data exception */ | |
384 /* and to store this exception in the RAM buffer */ | |
385 /* */ | |
386 /* Input Parameters: */ | |
387 /* None */ | |
388 /* */ | |
389 /* Output Parameters: */ | |
390 /* Validation of the diagnose execution. */ | |
391 /* */ | |
392 /* */ | |
393 /* */ | |
394 /* Revision History: */ | |
395 /* None. */ | |
396 /* */ | |
397 /********************************************************************************/ | |
398 void dar_exception_arm_abort_data(void) | |
399 { | |
400 #ifndef _WINDOWS | |
401 /* Local variable */ | |
402 UINT8 i; | |
403 #endif | |
404 | |
405 #if ((CHIPSET == 7) || (CHIPSET == 8) || (CHIPSET == 10) || (CHIPSET == 11) || (CHIPSET == 12)) | |
406 /* Debug unit pointer */ | |
407 volatile UINT32 *debug_register_p; | |
408 #endif | |
409 | |
410 /* Declare local variables */ | |
411 T_DAR_INFO *buffer_p= " DAR Emergency exception : ARM abort data";/*exception data to store*/ | |
412 | |
413 /* Update the DAR recovery status */ | |
414 dar_current_status = DAR_EMERGENCY_SCUTTLING; | |
415 | |
416 /* Update the DAR exception status */ | |
417 dar_exception_status = DAR_EXCEPTION_DATA_ABORT; | |
418 | |
419 /* Empty the mail box and store data in RAM buffer */ | |
420 dar_empty_mb_and_save_data(buffer_p); | |
421 | |
422 /* Check if the DAR entity is started */ | |
423 if (dar_gbl_var_p != NULL ) | |
424 { | |
425 if (dar_gbl_var_p->entity_dar_callback != NULL) | |
426 { | |
427 | |
428 /* Call the MMI callback function to save some parameters before reset */ | |
429 dar_gbl_var_p->entity_dar_callback(dar_recovery_buffer,DAR_RECOVERY_DATA_MAX_BUFFER_SIZE); | |
430 } | |
431 } | |
432 | |
433 #if ((CHIPSET == 7) || (CHIPSET == 8) || (CHIPSET == 10) || (CHIPSET == 11) || (CHIPSET == 12)) | |
434 /* Initialize the adress of the Debug Unit pointer */ | |
435 debug_register_p = (volatile UINT32*) DAR_DEBUG_UNIT_REGISTER; | |
436 #endif | |
437 | |
438 #ifndef _WINDOWS | |
439 #if ((CHIPSET == 7) || (CHIPSET == 8) || (CHIPSET == 10) || (CHIPSET == 11) || (CHIPSET == 12)) | |
440 /* Save the Debug Unit into the RAM */ | |
441 for (i=0; i<DEBUG_UNIT_WORD_SIZE; i++ ) | |
442 { | |
443 debug_RAM[i] = *debug_register_p; | |
444 debug_register_p++; | |
445 } | |
446 #endif | |
447 | |
448 /* branch to "exception" defined in the int.s*/ | |
449 exception(); | |
450 #endif | |
451 | |
452 } /* dar_exception_arm_abort_data */ | |
453 | |
454 /********************************************************************************/ | |
455 /* */ | |
456 /* Function Name: dar_exception_arm_reserved */ | |
457 /* */ | |
458 /* Purpose: This function is called to process ARM exception */ | |
459 /* and to store this exception in the RAM buffer */ | |
460 /* */ | |
461 /* Input Parameters: */ | |
462 /* None */ | |
463 /* */ | |
464 /* Output Parameters: */ | |
465 /* Validation of the diagnose execution. */ | |
466 /* */ | |
467 /* */ | |
468 /* */ | |
469 /* Revision History: */ | |
470 /* None. */ | |
471 /* */ | |
472 /********************************************************************************/ | |
473 void dar_exception_arm_reserved(void) | |
474 { | |
475 /* Declare local variables */ | |
476 T_DAR_INFO *buffer_p= " DAR Emergency exception : ARM reserved";/*exception data to store*/ | |
477 | |
478 /* Update the DAR recovery status */ | |
479 dar_current_status = DAR_EMERGENCY_SCUTTLING; | |
480 | |
481 /* Update the DAR exception status */ | |
482 dar_exception_status = DAR_EXCEPTION_RESERVED; | |
483 | |
484 /* Empty the mail box and store data in RAM buffer */ | |
485 dar_empty_mb_and_save_data(buffer_p); | |
486 | |
487 /* Check if the DAR entity is started */ | |
488 if (dar_gbl_var_p != NULL ) | |
489 { | |
490 if (dar_gbl_var_p->entity_dar_callback != NULL) | |
491 { | |
492 /* Call the MMI callback function to save some parameters before reset */ | |
493 dar_gbl_var_p->entity_dar_callback(dar_recovery_buffer,DAR_RECOVERY_DATA_MAX_BUFFER_SIZE); | |
494 } | |
495 } | |
496 | |
497 #ifndef _WINDOWS | |
498 /* branch to "exception" defined in the int.s*/ | |
499 exception(); | |
500 #endif | |
501 | |
502 } /* dar_exception_arm_reserved */ | |
503 | |
504 /********************************************************************************/ | |
505 /* */ | |
506 /* Function Name: dar_exception */ | |
507 /* */ | |
508 /* Purpose: This function is called to vector exceptions to the correct */ | |
509 /* handler */ | |
510 /* */ | |
511 /* Input Parameters: */ | |
512 /* abort type which come from int.s ( -> magic number) */ | |
513 /* */ | |
514 /* Output Parameters: */ | |
515 /* Validation of the diagnose execution. */ | |
516 /* */ | |
517 /* */ | |
518 /* */ | |
519 /* Revision History: */ | |
520 /* None. */ | |
521 /* */ | |
522 /********************************************************************************/ | |
523 void dar_exception(int abort_type) | |
524 { | |
525 switch (abort_type) | |
526 { | |
527 /* magic numbers come from int.s There is no way to make compiler derived | |
528 * constants out of them | |
529 */ | |
530 case 1: | |
531 dar_exception_arm_undefined(); | |
532 break; | |
533 case 2: | |
534 dar_exception_arm_swi(); | |
535 break; | |
536 case 3: | |
537 dar_exception_arm_abort_prefetch(); | |
538 break; | |
539 case 4: | |
540 dar_exception_arm_abort_data(); | |
541 break; | |
542 case 5: | |
543 dar_exception_arm_reserved(); | |
544 break; | |
545 } | |
546 } /* dar_exception */ | |
547 | |
548 #else | |
549 /* ************************************************ */ | |
550 /* THE DAR ENTITY IS DISABLED */ | |
551 /* ************************************************ */ | |
552 | |
553 void dar_exception(int abort_type) | |
554 { | |
555 #ifndef _WINDOWS | |
556 /* branch to "exception" defined in the int.s*/ | |
557 exception(); | |
558 #endif | |
559 } /* dar_exception */ | |
560 | |
561 #endif /* #ifdef RVM_DAR_SWE */ | |
562 |