Diferencia entre revisiones de «Interrupciones y excepciones»
(→Tratamiento de interrupciones y excepciones) |
(→Tratamiento de interrupciones y excepciones) |
||
Línea 9: | Línea 9: | ||
1 La CPU termina la instrucción que esté ejecutando actualmente. | 1 La CPU termina la instrucción que esté ejecutando actualmente. | ||
2 Almacena el estado de la CPU en la pila. | 2 Almacena el estado de la CPU en la pila. | ||
+ | |||
3 La CPU pasa a modo supervisor. | 3 La CPU pasa a modo supervisor. | ||
+ | |||
4 Se determina la dirección del Subprograma de Servicio de Interrupciones (SSI). | 4 Se determina la dirección del Subprograma de Servicio de Interrupciones (SSI). | ||
+ | |||
5 Se salta al SSI y se ejecuta. | 5 Se salta al SSI y se ejecuta. | ||
+ | |||
6 Se retorna del SSI restaurando el estado de la CPU desde la pila, así como el modo de ejecución. | 6 Se retorna del SSI restaurando el estado de la CPU desde la pila, así como el modo de ejecución. | ||
+ | |||
7 La CPU continúa con la ejecución del siguiente programa que corresponda. | 7 La CPU continúa con la ejecución del siguiente programa que corresponda. | ||
Revisión del 12:20 19 ene 2013
Tipos de interrupciones y excepciones
Se llama interrupción a una alteración en la secuencia de ejecución de instrucciones. Las interrupciones pueden estar causadas por hardware, por una excepción o por una petición de interrupción por parte de algún proceso (interrupción software). Una excepción es una interrupción de la propia CPU cuando se intenta ejecutar una instrucción prohibida. La interrupción software, por otro lado, se produce cuando un proceso pide un recurso al SO mediante una llamada al sistema (open, write, read…).
Tratamiento de interrupciones y excepciones
Cuando una interrupción es causada por un componente hardware, su tratamiento es el siguiente: 1 La CPU termina la instrucción que esté ejecutando actualmente. 2 Almacena el estado de la CPU en la pila.
3 La CPU pasa a modo supervisor.
4 Se determina la dirección del Subprograma de Servicio de Interrupciones (SSI).
5 Se salta al SSI y se ejecuta.
6 Se retorna del SSI restaurando el estado de la CPU desde la pila, así como el modo de ejecución.
7 La CPU continúa con la ejecución del siguiente programa que corresponda.
Por otro lado, cuando la interrupción es causada por una instrucción de petición, el proceso es el mismo hasta el cuarto punto, a partir de ahí, difiere, ya que la CPU no siempre tiene por qué volver al mismo punto. Por último, en el caso de las excepciones, nunca se vuelve al mismo punto, ya que es donde se ha causado el error en cuestión. En éste caso se procede como antes, pero se llama al SSE (Subprograma de Servicio de Excepciones). En los sistemas operativos, existe una tabla de vectores de interrupción, en la cual, cada vector apunta a la dirección de memoria del gestor, que se encargará de tratar la interrupción del tipo que corresponda. Ésta tabla está separada de otra, que contiene los vectores de excepciones.