01.05.2013 Views

Estructura de computadores

Estructura de computadores

Estructura de computadores

SHOW MORE
SHOW LESS

You also want an ePaper? Increase the reach of your titles

YUMPU automatically turns print PDFs into web optimized ePapers that Google loves.

CC-BY-SA • PID_00181526 41 La arquitectura CISCA<br />

SP ← SP + 4 ; 4 es el tamaño <strong>de</strong> la palabra <strong>de</strong> pila.<br />

PC ← MBR ; Restauramos el PC.<br />

MAR ← SP, read<br />

MBR ← Memoria<br />

SP ← SP + 4<br />

; '+', sumamos porque crece hacia direcciones bajas.<br />

Registro <strong>de</strong> estado ← MBR ; Restauramos el registro <strong>de</strong> estado.<br />

4.3.4. Operaciones <strong>de</strong> Entrada/Salida<br />

1) IN Ri, puerto<br />

Ri ← MBR ;En el registro MBR tendremos el dato leído <strong>de</strong>l puerto<br />

2) OUT puerto, Ri<br />

;en el ciclo <strong>de</strong> lectura <strong>de</strong>l operando fuente<br />

MBR ← Ri ;Ponemos el dato que tenemos en el registro especificado<br />

(Resolver modo <strong>de</strong> direccionamiento), write E/S<br />

Memoria ← MBR ;para almacenar como operando <strong>de</strong>stino<br />

4.3.5. Operaciones especiales<br />

1) NOP. No hay que hacer nada (hace un ciclo <strong>de</strong> no operación <strong>de</strong> la ALU).<br />

2) STI. Activa el bit IE <strong>de</strong>l registro <strong>de</strong> estado para habilitar las interrupciones.<br />

3) CLI. Desactiva el bit IE <strong>de</strong>l registro <strong>de</strong> estado para inhibir las interrupciones.<br />

4.4. Comprobación <strong>de</strong> interrupciones<br />

En esta fase se comprueba si se ha producido una interrupción (para ello, no<br />

hay que ejecutar ninguna microoperación); si no se ha producido ninguna<br />

interrupción, se continúa con la siguiente instrucción, y si se ha producido<br />

alguna, se <strong>de</strong>be hacer el cambio <strong>de</strong> contexto, don<strong>de</strong> hay que guardar cierta in-<br />

formación y poner en el PC la dirección <strong>de</strong> la rutina que da servicio a esta in-<br />

terrupción. Este proceso pue<strong>de</strong> variar mucho <strong>de</strong> una máquina a otra. Aquí solo<br />

presentamos la secuencia <strong>de</strong> microoperaciones para actualizar el PC cuando<br />

se produce el cambio <strong>de</strong> contexto.<br />

MBR ← Registro <strong>de</strong> Estado<br />

SP ← SP - 4<br />

MAR ← SP, write<br />

Memoria ← MBR ;Guardamos el registro <strong>de</strong> estado en la pila<br />

MBR ← PC<br />

SP ← SP - 4<br />

MAR ← SP, write<br />

Bit <strong>de</strong> interrupción (IF)<br />

Bit IF activo (IF=1): se ha producido<br />

una interrupción<br />

Bit IF activo (IF=0): no se ha<br />

producido una interrupción

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!