

## **Exámenes**

# (ETC) P13 - Test de sesión (curso 20/21)

Volver a la Lista de Exámenes

Parte 1 de 1 - 10.0 Puntos

Preguntas 1 de 5

2.0 Puntos

MIPS - Registro de estado (\$12)



Bits de máscara de interrupción (Interrupt Mask IM) IM=0 Enmascarada IM=1 Desenmascarada Bits KU: KernelUser (0: Kernel – 1: User)

Bits IE: Interrupt Enable (0: Deshabilitadas - 1: habilitadas)

Completa las siguientes instrucciones de un fragmento de código de inicialización del manejador de excepciones. Dicho fragmento debe habilitar sólo la INT5, habilitar las interrupciones en el procesador y activar el modo usuario:

li \$t0, 0x 🗶

🗶 \$t0, \$12

Respuesta correcta: 2003, mtc0

Preguntas 2 de 5

2.0 Puntos

## MIPS - Registro de estado (\$12)



Bits de máscara de interrupción (Interrupt Mask IM) IM=0 Enmascarada IM=1 Desenmascarada Bits KU: KernelUser (0: Kernel – 1: User) Bits IE: Interrupt Enable (0: Deshabilitadas – 1: habilitadas)

Completa las siguientes instrucciones de un fragmento de código que habilita las interrupciones generales, la INTO e INT3 (mediante la ori ) y deshabilita la INT1 (con la instrucción andi ) dejando el resto sin modificar:

★ \$t0, \$12
ori \$t0, \$t0, 0x ★
andi \$t0, \$t0, 0x ★
\$ \$t0, \$12

Respuesta correcta: mfc0, 0901|901, FDFF|fdff, mtc0

Preguntas 3 de 5

2.0 Puntos

## MIPS - Registro de causa (\$13)



Completa las siguientes instrucciones de un fragmento de código del manejador de excepciones para que cuando la causa de la excepción sea la interrupción 3 salte a la etiqueta int3, que cuando la causa de la excepción sea una instrucción syscall (código 8) salte a la etiqueta sysfun y que en cualquier otro caso salte a la etiqueta retexc.

**Respuesta correcta:** mfc0, 3C|003C|03C|03c|003c|03c, int, 20|020|0020, 2000, bne Preguntas 4 de 5

2.0 Puntos

## [33] La interfaz del teclado del PCSpim es la siguiente:

## Interfaz del teclado (DB = 0xFFFF0000, Int0)

| Nombre         | Dirección | Acceso | Estructura |
|----------------|-----------|--------|------------|
| Estado/órdenes | DB        | LE     | (,E,R      |
| Datos          | DB+4      | L      | COD        |

#### Registro de órdenes y estado (Lectura/escritura. Dirección = Base)

- R (bit 0, sólo lectura). Indicador de dispositivo preparado: R = 1 cada vez que se pulsa una tecla
- Cancelación (hacer R = 0) : es necesario realizar un acceso de lectura en el registro de datos.
- E: (bit 1, lectura/escritura). Habilitación de la interrupción (mientras E = 1, el valor R = 1 activa la línea de interrupción del dispositivo)

Registro de datos (Sólo lectura. Dirección = Base + 4)

• COD (bits 7...0). Código ASCII de la tecla pulsada. Leer de este registro provoca que R = 0.

Considere que el inicio del sistema ha habilitado completamente la interrupción del teclado y que el manejador contiene el siguiente tratamiento para la int0:

## Indique qué afirmaciones de las siguientes son correctas:

| X | Este tratamiento de la interrupción no cancela correctamente la interrupción              |
|---|-------------------------------------------------------------------------------------------|
|   | El código cancela el bit R.                                                               |
|   | La interrupción iint0 no funciona correctamente pues no accede a la interfaz del teclado. |

✓ El manejador sólo atenderá la primera interrupción del teclado porque el tratamiento la inhabilita.

 $\textbf{Respuesta correcta:}\ \mathsf{B}, \mathsf{D}$ 

Preguntas 5 de 5

2.0 Puntos

#### La interfaz del reloj del PCSpim es la siguiente:

# Interfaz del reloj (DB = 0xFFFF0010, Int2) Nombre Dirección Acceso Estructura Estado/órdenes DB LE ..., R,E

Registro de órdenes y estado (Lectura/escritura. Dirección = Base)

- R (bit 1, lectura/escritura). Indicador de dispositivo preparado: R = 1 a cada segundo.
- Cancelación (R = 0): se escribirá en bit R un 0.
- E: (bit 0, lectura/escritura). Habilitación de la interrupción (mientras E = 1, el valor R = 1 activa la línea de interrupción del dispositivo)

Considere que el inicio del sistema ha habilitado completamente la interrupción del reloj. Complete la rutina de servicio del reloj, en el manejador de excepciones, para cancelar la interrupción int2, pero que el reloj pueda seguir interrumpiendo con posterioridad.

```
int2: la $t0, ★<u>0xffff0000</u>
li $t1, ★<u>0x1</u>
sb $t1, ✓<u>0</u> ($t0)
b retexc
```

Respuesta correcta: 0xFFFF0010|0xffff0010, 0x01, 0

- PoliformaT
- <u>UPV</u>
- Powered by Sakai
- Copyright 2003-2021 The Sakai Foundation. All rights reserved. Portions of Sakai are copyrighted by other parties as described in the Acknowledgments screen.