# Examen final IC (Parte 1)

- Duración del examen: 2:30 horas.
- Los problemas tienen que resolverse en las HOJAS DE RESPUESTAS.
- No podéis utilizar calculadora, móvil, apuntes, etc.
- La solución del examen se publicará en Atenea mañana por la mañana.
- La revisión será el 29 de junio a las 12:00 en el aula D6-114. Las notas definitivas se publicarán en Atenea al día siguiente.

Para algunos de los ejercicios son útiles las figuras y tablas que se muestran en la hoja aparte La puntuación de las preguntas de esta parte del examen corresponde a 5 puntos de la nota final del examen.

### Pregunta 1) (0.2 puntos)

Cada fila de la tabla tiene 3 columnas con: el vector de 8 bits X escrito en hexadecimal, el valor que representa X interpretado como un número natural codificado en binario (Xu) y el valor que representa X interpretado como un número entero codificado en complemento a dos (X<sub>s</sub>). Completa las casillas que faltan.

| X (hexa) | Xu | Xs   |
|----------|----|------|
|          |    | -112 |
| 9D       |    |      |

### Pregunta 2) (0.4 puntos)

Dado el siguiente circuito combinacional, los valores de los vectores de 4 bits de entrada X e Y y el valor de la señal s, rellenad la tabla indicando el valor de las señales de salida a, b, c, d y Cmp, el valor del vector de 4 bits de la salida W y su interpretación como número natural (W<sub>u</sub>) y número entero (W<sub>s</sub>) para cada combinación de valores de entrada (cada fila de la tabla). El bloque LT realiza la comparación con signo A < B activando el bit de salida a 1 cuando es cierta.

| S | Х    | Υ    | а | b | С | d | Cmp | W (4 bits) | $W_{u}$ | Ws |
|---|------|------|---|---|---|---|-----|------------|---------|----|
| 1 | 1101 | 0111 |   |   |   |   |     |            |         |    |
| 0 | 1010 | 1001 |   |   |   |   |     |            |         |    |



## Pregunta 3) (0.4 puntos)

3.a) Dibuja el grafo de estados del siguiente circuito (no olvidéis la leyenda) sabiendo que el valor inicial de los biestables es q<sub>1</sub>=1 y  $q_0=1.$  (0,3 puntos)



|       | $q_1^+$ | $q_0^+$ |
|-------|---------|---------|
| M[0]  | 0       | 0       |
| M[1]  | 0       | 0       |
| M[2]  | 0       | 0       |
| M[3]  | 0       | 0       |
| M[4]  | 1       | 0       |
| M[5]  | 1       | 0       |
| M[6]  | 0       | 1       |
| M[7]  | 1       | 0       |
| M[8]  | 1       | 0       |
| M[9]  | 1       | 0       |
| M[10] | 1       | 0       |
| M[11] | 1       | 0       |
| M[12] | 1       | 1       |
| M[13] | 1       | 1       |
| M[14] | 1       | 0       |
| M[15] | 0       | 1       |

3.b) Si implementamos directamente la función q<sub>1</sub><sup>+</sup> en suma de minterms, ¿Cuántas puertas And y OR y de cuántas entradas hacen falta? (0,1 puntos)

## Pregunta 4) (0.2 puntos)

A partir del siguiente texto que describe el funcionamiento de un circuito lógico secuencial (CLS) de Moore, completa el grafo de estados que describe su funcionamiento. El grafo está incompleto y le faltan sólo algunos arcos.

El CLS a diseñar es un reconocedor de una secuencia con solapamiento con una entrada X y una salida W. La salida W vale 1 al ciclo siguiente de que la entrada haya recibido el último bit de la secuencia "0101". En cualquier otro caso la salida w vale 0.



#### Pregunta 5) (0.3 puntos)

Completad el siguiente cronograma de las señales del esquema lógico sabiendo que los tiempos de propagación de las puertas son:  $Tp_{(Not)}=10$ ,  $Tp_{(And-2)}=20$ ,  $Tp_{(Or-2)}=20$  u.t. Debéis operar adecuadamente con las zonas sombreadas (no se sabe el valor que tienen) y dibujar la señal sombreada cuando no se pueda saber si vale 0 o 1.





### Pregunta 6) (0.3 puntos)

El grafo de estados de Moore se implementa mediante el circuito secuencial con dos ROMs de la figura. Responded a los siguiente:



a) ¿Cuál es el contenido, en binario, de las direcciones 0x5 y 0xD de la ROM Q+?

ROM Q+ 
$$[0x5]$$
= , ROM Q+  $[0xD]$ =

b) ¿Cuál es el contenido, en binario, de las direcciones 0x1 y 0x3 de la ROM OUT?

ROM\_OUT 
$$[0x1]$$
= , ROM\_OUT  $[0x3]$ =

c) ¿Cuáles son las direcciones, en binario, y sus contenidos, en binario, de la ROM\_Q+ que implementan el arco del grafo que va del estado q<sub>1</sub>q<sub>0</sub>=11 al estado q<sub>1</sub>q<sub>0</sub>=00? Si se necesitan más de 4 posiciones de la ROM\_Q+ escribe solo las 4 primeras. Si sobran, dejadlas en blanco.

$$ROM Q + [] = , ROM Q + [] = , ROM$$

#### Pregunta 7) (0.3 puntos)

El siguiente circuito secuencial está inmerso en un sistema más complejo. Se sabe que la entrada In se estabiliza pasadas 80 u.t. desde la llegada del flanco ascendente de reloj y la salida Out tiene que estar estable 40 u.t. antes de la llegada del flanco ascendente de reloj. Deseamos calcular el tiempo de ciclo mínimo del sistema suponiendo que el camino crítico pasa por este circuito. Los bloques C1, C2, C3 y C4 son circuitos combinacionales cuya implementación interna desconocemos.



Los tiempos de propagación de los bloques combinacionales que hay en este circuito son los siguientes ( $TCi_{n-m}$  indica el tiempo de propagación del bloque Ci desde la entrada n a la salida m medido en u.t.):

|     |    |     |    | T <sub>C3</sub>          |    |     |    |     |    |
|-----|----|-----|----|--------------------------|----|-----|----|-----|----|
| a-b | 60 | e-h | 70 | i-k<br>i-m<br>j-k<br>j-m | 10 | n-p | 50 | q-s | 90 |
| a-c | 10 | f-h | 50 | i-m                      | 30 | о-р | 50 | r-s | 20 |
| a-d | 70 | g-h | 20 | j-k                      | 20 |     |    |     |    |
|     |    |     |    | j-m                      | 50 |     |    |     |    |

El tiempo de propagación de cualquier biestable del sistema es de 100 u.t.

**7.a)** Escribid **todos los caminos críticos** que haya listando la secuencia de bloques que los forman e indicando la entrada y salida de cada bloque por la que pasa el camino. (0.2 puntos)

7.b) ¿Cuál es el tiempo de ciclo mínimo del sistema? (0.1 puntos)

Examen final IC-17-18-Q2

#### Pregunta 8) (0.4 puntos)

| а | b | С | W |
|---|---|---|---|
| 0 | 0 | 0 | Х |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 0 | Χ |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |
|   |   |   |   |

Dada la tabla de verdad correspondiente a una función que calcula w, responde a las siguientes preguntas.

**8.a)** Dibujad el mapa de Karnaugh marcando claramente las agrupaciones de unos adecuadas para obtener la expresión mínima en suma de productos de la función w. Escribid la expresión mínima en suma de productos de w. (0.2 puntos)

**8.b)** Si implementamos directamente la expresión en suma de minterms de la función w considerando las x como 0, ¿Cuántas puertas And y OR y de cuántas entradas hacen falta? (0.1 puntos)

8.c) Si implementamos la función w con una ROM. ¿Cuántas palabras y cuántos bits por palabra tiene la ROM? (0.1 puntos)

#### Pregunta 9) (0.5 puntos)

- 9.a) Escribid la fórmula que da el valor de un número natural en función de los 4 dígitos que lo representan en el sistema convencional en base 5. (0.1 puntos)
- 9.b) Escribid la fórmula que da el valor de un número entero en función de los n bits en complemento a dos que lo representan. (0.1 puntos)
- 9.c) Expresad el rango de los números enteros que se pueden representar en el sistema convencional en base 3 para el caso de un vector X de 4 dígitos. (0.1 puntos)
- 9.d) ¿Cuál es el número mínimo de bits necesarios para representar los siguientes números enteros en complemento a dos? (0.2 puntos)

-24: 48: 1:

## Pregunta 10) (1 punto)

A partir de la descripción de la funcionalidad del procesador de propósito específico (PPE) que se da a continuación, diseña una implementación formada por una unidad de proceso y una unidad de control, ambas de propósito específico. Para la unidad de proceso (UP) haz un diseño ad-hoc usando los bloques combinacionales y secuenciales vistos en clase. Especifica la unidad de control (UC) mediante un grafo de estados de Moore.

El PPE a diseñar debe realizar indefinidamente la siguiente operación. En el ciclo en que la señal de entrada Inicio vale 1, simultáneamente por la entrada X llega un dato y en el ciclo siguiente llega otro dato más. Al ciclo siguiente de la llegada del último dato, durante un ciclo la salida Fin vale 1 y por la salida W sale el resultado de la siguiente operación:

```
if (Inicio(c) == 1) {
    if (X(c)>=0) {
        W(c+2) = 3*(X(c) + X(c+1));
    } else {
        W(c+2) = X(c)/2 - X(c+1)/4;
    }
    Fin(c+2) = 1;
}
```

En el resto de ciclos el valor de la señal W no importa. En el ciclo que Fin vale 1 y los siguientes, hay que comprobar si Inicio vale 1, lo que indica que comienza una nueva secuencia. Si en algún momento durante la recepción de los datos la señal Inicio vuelve a valer 1 se debe abortar el proceso y volver a procesar una nueva secuencia. Todos los buses son de 8 bits y los valores son números **enteros**. En el diseño no hace falta tener en cuenta si durante las operaciones se producen desbordamientos (carrys, borrows y overflows).

10.a) Rellena el siguiente cronograma. Escribe la secuencia de valores para Fin y W para los ciclos del 4 al 14. Cuando el valor de la señal W no importe indícalo con XX. (0.2 puntos)

| Ciclo  | 00   | 01   | 02   | 03   | 04   | 05   | 06   | 07   | 08   | 09   | 10   | 11   | 12   | 13   | 14   |
|--------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| X      | 0x03 | 0x02 | 0x04 | 0xFA | 0x44 | 0x06 | 0x01 | 0xFC | 0xF8 | 0x21 | 0x03 | 0xFE | 0x9E | 0x67 | 0x1B |
| Inicio | 1    | 0    | 1    | 0    | 0    | 0    | 0    | 1    | 0    | 1    | 0    | 0    | 1    | 1    | 0    |
| Fin    | 0    | 0    | 1    | 0    |      |      |      |      |      |      |      |      |      |      |      |
| W      | XX   | XX   | 0x0F | XX   |      |      |      |      |      |      |      |      |      |      |      |

10.b) Dibuja el circuito de la unidad de proceso (UP) usando los bloques de la documentación de la asignatura. Dibuja también el grafo de estados de la unidad de control (UC) correspondiente. (0.8 puntos)

#### Pregunta 11) (0.3 puntos)

Completa la siguiente tabla ensamblando las instrucciones en ensamblador SISA o desensamblando las instrucciones en lenguaje máquina según sea necesario. Indica poniendo NA en la casilla aquellos casos en los que la instrucción no corresponda al lenguaje SISA. Indicad qué cambios se producen en el estado del computador SISC Von Neumann después de ejecutar cada una de las instrucciones de la tabla suponiendo que antes de ejecutarse cada una de ellas el PC vale 0xCAFE, el contenido de todos los registros es 0xFOFA, el byte contenido en todas las direcciones pares de la memoria es 0x24 y el de todas las impares es 0x91 y el contenido de todos los puertos de entrada es 1 y el de los de salida es 2. Utilizad la notación MEMb[0x...]=0x... para indicar cualquier cambio en la memoria y PORTIN[0x...]=0x... para los puertos de entrada y PORTOUT[0x...]=0x... para los de salida.

| Lenguaje máquina SISA | Lenguaje ensamblador SISA | Cambios en el estado del computador |
|-----------------------|---------------------------|-------------------------------------|
| 0x21C6                |                           |                                     |
|                       | STB 3(R5), R4             |                                     |
| 0xADFE                |                           |                                     |

## Pregunta 12) (0.3 puntos)

Indica el valor que debe tener cada uno de los bits de la palabra de control de la UPG (sin subsistema de I/O ni memoria, ver anexo) para que realice, durante un ciclo, la acción concreta especificada mediante el mnemotécnico. Indicad con x las casillas cuyo valor **no importe** para la ejecución de la instrucción. En caso de que no se pueda realizar la acción tachar toda la línea de señales.

| Mnemotécnico               | @A | @B | Rb/N | ОР | F | In/Alu | @D | WrD | N<br>(hexa) |
|----------------------------|----|----|------|----|---|--------|----|-----|-------------|
| SHL R4, R5, R6             |    |    |      |    |   |        |    |     |             |
| MOVEI R3, 0x07C9           |    |    |      |    |   |        |    |     |             |
| OUT R7 // CMPLTUI -, R7, 9 |    |    |      |    |   |        |    |     |             |

## Pregunta 13) (0.4 puntos)

Completad el fragmento de grafo de estados de la UC de **propósito específico** para que junto con la UPG formen un procesador que realice la funcionalidad descrita mediante el siguiente código en C (el código no tiene que hacer algo útil). Indicad los arcos que faltan, las etiquetas de los arcos (z, !z, o nada) y completad las casillas de cada palabra de control que se especifica con mnemotécnicos a la derecha de cada nodo del grafo. En las comparaciones, hay que interpretar los datos como valores **naturales**.

```
while (R2>76) {
    if (R1<0>==1) {
        R0=R1-43;
    } else {
        R0=xor(R1,R0)+5
    }
    R2=R2/2
}
R5=R6*4;
```

Nota: la función xor realiza la xor bit a bit de los dos parámetros

