SimpleOS

LXR

Navigation



Site hébergé par : enix

The LXR Cross Referencer for SOS

source navigation ]
diff markup ]
identifier search ]
general search ]
 
 
Article:1 ] [ 2 ] [ 3 ] [ 4 ] [ 5 ] [ 6 ] [ 6.5 ] [ 7 ] [ 7.5 ] [ 8 ] [ 9 ] [ 9.5 ]

Diff markup

Differences between /hwcore/exception.c (Article 2) and /hwcore/exception.c (Article 5)


001 /* Copyright (C) 2004  David Decotigny            001 /* Copyright (C) 2004  David Decotigny
002    Copyright (C) 1999  Free Software Foundatio    002    Copyright (C) 1999  Free Software Foundation, Inc.
003                                                   003 
004    This program is free software; you can redi    004    This program is free software; you can redistribute it and/or
005    modify it under the terms of the GNU Genera    005    modify it under the terms of the GNU General Public License
006    as published by the Free Software Foundatio    006    as published by the Free Software Foundation; either version 2
007    of the License, or (at your option) any lat    007    of the License, or (at your option) any later version.
008                                                   008    
009    This program is distributed in the hope tha    009    This program is distributed in the hope that it will be useful,
010    but WITHOUT ANY WARRANTY; without even the     010    but WITHOUT ANY WARRANTY; without even the implied warranty of
011    MERCHANTABILITY or FITNESS FOR A PARTICULAR    011    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
012    GNU General Public License for more details    012    GNU General Public License for more details.
013                                                   013    
014    You should have received a copy of the GNU     014    You should have received a copy of the GNU General Public License
015    along with this program; if not, write to t    015    along with this program; if not, write to the Free Software
016    Foundation, Inc., 59 Temple Place - Suite 3    016    Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
017    USA.                                           017    USA. 
018 */                                                018 */
019 #include "idt.h"                                  019 #include "idt.h"
020 #include "irq.h"                                  020 #include "irq.h"
021                                                   021 
022 #include "exception.h"                            022 #include "exception.h"
023                                                   023 
024 /* array of exception wrappers, defined in exc    024 /* array of exception wrappers, defined in exception_wrappers.S */
025 extern sos_vaddr_t sos_exception_wrapper_array    025 extern sos_vaddr_t sos_exception_wrapper_array[SOS_EXCEPT_NUM];
026                                                   026 
027 /* arrays of exception handlers, shared with e    027 /* arrays of exception handlers, shared with exception_wrappers.S */
028 sos_exception_handler_t sos_exception_handler_    028 sos_exception_handler_t sos_exception_handler_array[SOS_EXCEPT_NUM] =
029   { NULL, };                                      029   { NULL, };
030                                                   030 
031 sos_ret_t sos_exceptions_setup(void)              031 sos_ret_t sos_exceptions_setup(void)
032 {                                                 032 {
033   return SOS_OK;                               !! 033   /* We inidicate that the double fault exception handler is defined,
                                                   >> 034      and give its address. this handler is a do-nothing handler (see
                                                   >> 035      exception_wrappers.S), and it can NOT be overriden by the
                                                   >> 036      functions below */
                                                   >> 037   return sos_idt_set_handler(SOS_EXCEPT_BASE + SOS_EXCEPT_DOUBLE_FAULT,
                                                   >> 038                             (sos_vaddr_t) sos_exception_wrapper_array[SOS_EXCEPT_DOUBLE_FAULT],
                                                   >> 039                             0 /* CPL0 routine */);
034 }                                                 040 }
035                                                   041 
036                                                   042 
037 sos_ret_t sos_exception_set_routine(int except    043 sos_ret_t sos_exception_set_routine(int exception_number,
038                                     sos_except    044                                     sos_exception_handler_t routine)
039 {                                                 045 {
040   sos_ret_t retval;                               046   sos_ret_t retval;
041   sos_ui32_t flags;                               047   sos_ui32_t flags;
042                                                   048   
043   if ((exception_number < 0) || (exception_num    049   if ((exception_number < 0) || (exception_number >= SOS_EXCEPT_NUM))
044     return -SOS_EINVAL;                           050     return -SOS_EINVAL;
045                                                   051 
046   /* Double fault not supported */                052   /* Double fault not supported */
047   if (exception_number == SOS_EXCEPT_DOUBLE_FA    053   if (exception_number == SOS_EXCEPT_DOUBLE_FAULT)
048     return -SOS_ENOSUP;                           054     return -SOS_ENOSUP;
049                                                   055   
050   sos_disable_IRQs(flags);                        056   sos_disable_IRQs(flags);
051                                                   057 
052   retval = SOS_OK;                                058   retval = SOS_OK;
053                                                   059 
054   /* Set the exception routine to be called by    060   /* Set the exception routine to be called by the exception wrapper */
055   sos_exception_handler_array[exception_number    061   sos_exception_handler_array[exception_number] = routine;
056                                                   062 
057   /* If the exception is to be enabled, update    063   /* If the exception is to be enabled, update the IDT with the exception
058      wrapper */                                   064      wrapper */
059   if (routine != NULL)                            065   if (routine != NULL)
060     retval                                        066     retval
061       = sos_idt_set_handler(SOS_EXCEPT_BASE +     067       = sos_idt_set_handler(SOS_EXCEPT_BASE + exception_number,
062                             (sos_vaddr_t) sos_    068                             (sos_vaddr_t) sos_exception_wrapper_array[exception_number],
063                             0 /* CPL0 routine     069                             0 /* CPL0 routine */);
064   else /* Disable the IDT entry */                070   else /* Disable the IDT entry */
065     retval                                        071     retval
066       = sos_idt_set_handler(SOS_EXCEPT_BASE +     072       = sos_idt_set_handler(SOS_EXCEPT_BASE + exception_number,
067                             (sos_vaddr_t)NULL     073                             (sos_vaddr_t)NULL /* No routine => disable IDTE */,
068                             0 /* don't care */    074                             0 /* don't care */);
069                                                   075 
070   sos_restore_IRQs(flags);                        076   sos_restore_IRQs(flags);
071   return retval;                                  077   return retval;
072 }                                                 078 }
073                                                   079 
074                                                   080 
075 sos_exception_handler_t sos_exception_get_rout    081 sos_exception_handler_t sos_exception_get_routine(int exception_number)
076 {                                                 082 {
077   if ((exception_number < 0) || (exception_num    083   if ((exception_number < 0) || (exception_number >= SOS_EXCEPT_NUM))
078     return NULL;                                  084     return NULL;
079                                                   085 
080   /* Double fault not supported */                086   /* Double fault not supported */
081   if (exception_number == SOS_EXCEPT_DOUBLE_FA    087   if (exception_number == SOS_EXCEPT_DOUBLE_FAULT)
082     return NULL;                                  088     return NULL;
083                                                   089   
084   /* Expected to be atomic */                     090   /* Expected to be atomic */
085   return sos_exception_handler_array[exception    091   return sos_exception_handler_array[exception_number];
086 }                                                 092 }
                                                      

source navigation ] diff markup ] identifier search ] general search ]