| [158] | 1 | /////////////////////////////////////////////////////////////////////////////////// | 
|---|
|  | 2 | // File     : exc_handler.c | 
|---|
|  | 3 | // Date     : 01/04/2012 | 
|---|
|  | 4 | // Author   : alain greiner and joel porquet | 
|---|
|  | 5 | // Copyright (c) UPMC-LIP6 | 
|---|
|  | 6 | /////////////////////////////////////////////////////////////////////////////////// | 
|---|
|  | 7 | // The exc_handler.c and exc_handler.h files are part of the GIET nano-kernel. | 
|---|
|  | 8 | // They contains the exception handler code. | 
|---|
|  | 9 | /////////////////////////////////////////////////////////////////////////////////// | 
|---|
|  | 10 |  | 
|---|
|  | 11 | #include <exc_handler.h> | 
|---|
| [199] | 12 | #include <ctx_handler.h> | 
|---|
| [158] | 13 | #include <sys_handler.h> | 
|---|
|  | 14 | #include <drivers.h> | 
|---|
|  | 15 | #include <common.h> | 
|---|
|  | 16 |  | 
|---|
|  | 17 | /////////////////////////////////////////////////////////////////////////////////// | 
|---|
|  | 18 | // Prototypes of exception handlers. | 
|---|
|  | 19 | /////////////////////////////////////////////////////////////////////////////////// | 
|---|
|  | 20 |  | 
|---|
|  | 21 | static void _cause_ukn(); | 
|---|
|  | 22 | static void _cause_adel(); | 
|---|
|  | 23 | static void _cause_ades(); | 
|---|
|  | 24 | static void _cause_ibe(); | 
|---|
|  | 25 | static void _cause_dbe(); | 
|---|
|  | 26 | static void _cause_bp(); | 
|---|
|  | 27 | static void _cause_ri(); | 
|---|
|  | 28 | static void _cause_cpu(); | 
|---|
|  | 29 | static void _cause_ovf(); | 
|---|
|  | 30 |  | 
|---|
|  | 31 | extern void _int_handler(); | 
|---|
|  | 32 | extern void _sys_handler(); | 
|---|
|  | 33 |  | 
|---|
|  | 34 | /////////////////////////////////////////////////////////////////////////////////// | 
|---|
| [189] | 35 | // Initialize the exception vector indexed by the CR XCODE field | 
|---|
| [158] | 36 | /////////////////////////////////////////////////////////////////////////////////// | 
|---|
|  | 37 | const _exc_func_t _cause_vector[16] = { | 
|---|
|  | 38 | &_int_handler,  /* 0000 : external interrupt */ | 
|---|
|  | 39 | &_cause_ukn,    /* 0001 : undefined exception */ | 
|---|
|  | 40 | &_cause_ukn,    /* 0010 : undefined exception */ | 
|---|
|  | 41 | &_cause_ukn,    /* 0011 : undefined exception */ | 
|---|
|  | 42 | &_cause_adel,   /* 0100 : illegal address read exception */ | 
|---|
|  | 43 | &_cause_ades,   /* 0101 : illegal address write exception */ | 
|---|
|  | 44 | &_cause_ibe,    /* 0110 : instruction bus error exception */ | 
|---|
|  | 45 | &_cause_dbe,    /* 0111 : data bus error exception */ | 
|---|
|  | 46 | &_sys_handler,  /* 1000 : system call */ | 
|---|
|  | 47 | &_cause_bp,     /* 1001 : breakpoint exception */ | 
|---|
|  | 48 | &_cause_ri,     /* 1010 : illegal codop exception */ | 
|---|
|  | 49 | &_cause_cpu,    /* 1011 : illegal coprocessor access */ | 
|---|
|  | 50 | &_cause_ovf,    /* 1100 : arithmetic overflow exception */ | 
|---|
|  | 51 | &_cause_ukn,    /* 1101 : undefined exception */ | 
|---|
|  | 52 | &_cause_ukn,    /* 1110 : undefined exception */ | 
|---|
|  | 53 | &_cause_ukn,    /* 1111 : undefined exception */ | 
|---|
|  | 54 | }; | 
|---|
|  | 55 |  | 
|---|
| [228] | 56 | static const char * exc_type[] = { | 
|---|
| [199] | 57 | "strange unknown cause", | 
|---|
|  | 58 | "illegal read address", | 
|---|
|  | 59 | "illegal write address", | 
|---|
|  | 60 | "inst bus error", | 
|---|
|  | 61 | "data bus error", | 
|---|
|  | 62 | "breakpoint", | 
|---|
|  | 63 | "reserved instruction", | 
|---|
| [228] | 64 | "illegal coproc access", | 
|---|
| [199] | 65 | "arithmetic overflow", | 
|---|
| [158] | 66 | }; | 
|---|
|  | 67 |  | 
|---|
| [228] | 68 |  | 
|---|
| [238] | 69 | static void _display_cause(unsigned int type) | 
|---|
|  | 70 | { | 
|---|
| [218] | 71 | _get_lock(&_tty_put_lock); | 
|---|
| [199] | 72 | _puts("\n[GIET] Exception for task "); | 
|---|
| [238] | 73 | _putd(_get_context_slot(CTX_LTID_ID)); | 
|---|
| [199] | 74 | _puts(" on processor "); | 
|---|
| [228] | 75 | _putd(_procid()); | 
|---|
| [199] | 76 | _puts(" at cycle "); | 
|---|
| [228] | 77 | _putd(_proctime()); | 
|---|
| [199] | 78 | _puts("\n - type      : "); | 
|---|
| [228] | 79 | _puts((char *) exc_type[type]); | 
|---|
| [189] | 80 | _puts("\n - EPC       : "); | 
|---|
| [228] | 81 | _putx(_get_epc()); | 
|---|
| [189] | 82 | _puts("\n - BVAR      : "); | 
|---|
| [228] | 83 | _putx(_get_bvar()); | 
|---|
| [158] | 84 | _puts("\n"); | 
|---|
| [218] | 85 | _puts("...Task desactivated\n"); | 
|---|
|  | 86 | _release_lock(&_tty_put_lock); | 
|---|
| [199] | 87 |  | 
|---|
|  | 88 | // goes to sleeping state | 
|---|
| [238] | 89 | _set_context_slot(CTX_RUN_ID, 0); | 
|---|
| [228] | 90 |  | 
|---|
| [199] | 91 | // deschedule | 
|---|
|  | 92 | _ctx_switch(); | 
|---|
| [158] | 93 | } | 
|---|
|  | 94 |  | 
|---|
| [199] | 95 | static void _cause_ukn()  { _display_cause(0); } | 
|---|
|  | 96 | static void _cause_adel() { _display_cause(1); } | 
|---|
|  | 97 | static void _cause_ades() { _display_cause(2); } | 
|---|
|  | 98 | static void _cause_ibe()  { _display_cause(3); } | 
|---|
|  | 99 | static void _cause_dbe()  { _display_cause(4); } | 
|---|
|  | 100 | static void _cause_bp()   { _display_cause(5); } | 
|---|
|  | 101 | static void _cause_ri()   { _display_cause(6); } | 
|---|
|  | 102 | static void _cause_cpu()  { _display_cause(7); } | 
|---|
|  | 103 | static void _cause_ovf()  { _display_cause(8); } | 
|---|
| [158] | 104 |  | 
|---|
| [228] | 105 | // Local Variables: | 
|---|
|  | 106 | // tab-width: 4 | 
|---|
|  | 107 | // c-basic-offset: 4 | 
|---|
|  | 108 | // c-file-offsets:((innamespace . 0)(inline-open . 0)) | 
|---|
|  | 109 | // indent-tabs-mode: nil | 
|---|
|  | 110 | // End: | 
|---|
|  | 111 | // vim: filetype=c:expandtab:shiftwidth=4:tabstop=4:softtabstop=4 | 
|---|
|  | 112 |  | 
|---|