**2.1.** Demostrar por medio de una tabla de verdad, que la expresión lógica Cn⊕Cn-1 genera una señal denominada bandera de desbordamiento (overflow, V), para identificar errores que se generan al sumar números enteros con signo, en codificación complemento a 2.

# Solución:

El desbordamiento se produce al sumar dos números X, Y de n bits del mismo signo , positivo o negativo y el resultado tiene un signo distinto, negativo o positivo respectivamente. Por tanto la tabla de verdad para la función desbordamiento (*overflow*, V) será:

| X <sub>n-1</sub> | Y <sub>n-1</sub> | C <sub>n-1</sub> | S <sub>n-1</sub> | Cn | $C_n \oplus C_{n-1}$ | Overflow | V |
|------------------|------------------|------------------|------------------|----|----------------------|----------|---|
| 0(+)             | 0(+)             | 0                | 0(+)             | 0  | 0                    | No       | 0 |
| 0(+)             | 0(+)             | 1                | 1(-)             | 0  | 1                    | Si       | 1 |
| 0(+)             | 1(-)             | 0                | 1(-)             | 0  | 0                    | No       | 0 |
| 0(+)             | 1(-)             | 1                | 0(+)             | 1  | 0                    | No       | 0 |
| 1(-)             | 0(+)             | 0                | 1(-)             | 0  | 0                    | No       | 0 |
| 1(-)             | 0(+)             | 1                | 0(+)             | 1  | 0                    | No       | 0 |
| 1(-)             | 1(-)             | 0                | 0(+)             | 1  | 1                    | Si       | 1 |
| 1(-)             | 1(-)             | 1                | 1(-)             | 1  | 0                    | No       | 0 |

**2.2.** Además del resultado, la ALU genera un conjunto de bits que pueden ser utilizados por el sistema o por los usuarios para el control de las operaciones aritmético-lógicas desarrolladas. Entre estos los más conocidos son el bit o bandera de signo (N, N = '1' si el resultado es negativo), el bit o bandera de cero (Z, Z = '1' si el resultado es cero), el bit o bandera de acarreo (C, C = '1' si hay acarreo en la operación de suma entre los bits más significativos de ambos operandos), y el bit o bandera de desbordamiento u overflow (V, V = '1' si se supera la capacidad de representación del sistema). Utilizando números binarios de 8 bits con signo y representados en complemento a 2, realice las operaciones señaladas con dos operandos en decimal y compruebe en cada caso, el valor de estos cuatro bits, N, Z, C y V, señale en cada caso su significado.

a) 46 + 67

**b)** 112 - 89

c) 75 + 95

**d)** -34 - 97

## Solución:

a) 
$$46 + 67 = 113$$
 b)  $112 - 89 = 23$  c)  $75 + 95 = 170$  d)  $-34 - 97 = -131$   $0010 \ 11110_2$   $0100 \ 0011_2$   $1010 \ 0111_2$   $0101 \ 1111_2$   $0101 \ 1111_2$   $1001 \ 1111_2$   $1001 \ 1111_2$   $1101 \ 1110_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$   $1101 \ 1101_2$ 

**2.3.** Utilizando números binarios de 8 bits con signo y representados en complemento a 2, realice en el orden señalado por los paréntesis las operaciones indicadas. Para cada resultado parcial, compruebe si se produce un desbordamiento aritmético y calcule también la validez del resultado final. Analice los resultados obtenidos en relación con el valor de la bandera V del problema 2.1 y observe que, resultados parciales incorrectos, no suponen necesariamente que el resultado final lo sea.

a) (((((32+100)+70)+24)-62)-50). b) ((((43-12)+34)+75)-47) c) ((((15-77)-43)-38)+32)

# Solución:

| a) 32 + 100 = 132;            | 132 + 70 = 202; 2         | 202 + 24 = 226;                  | 226 - 62 = 1              | 164; $164 - 50 = 114$ .       |                               |
|-------------------------------|---------------------------|----------------------------------|---------------------------|-------------------------------|-------------------------------|
| 0010 00002                    | 1000 010                  | 002 11                           | 00 10102                  | 1110 0010 <sub>2</sub>        | 1010 01002                    |
| <u>0110 0100</u> <sub>2</sub> | 0 <u>100 011</u>          | <u>10</u> <sub>2</sub> <u>00</u> | <u>01 1000</u> 2          | <u>1100 0010</u> <sub>2</sub> | <u>1100 1110</u> <sub>2</sub> |
| 1000 01002                    | 1100 101                  | 10 <sub>2</sub> 11               | 10 0010 <sub>2</sub>      | 1010 0100 <sub>2</sub>        | 0111 00102                    |
| <b>-124</b> <sub>10</sub>     | - 54                      | 410                              | <b>- 30</b> <sub>10</sub> | <b>- 92</b> <sub>10</sub>     | <b>+114</b> <sub>10</sub>     |
| 84 <sub>16</sub>              | CA                        | <b>4</b> <sub>16</sub>           | E2 <sub>16</sub>          | A4 <sub>16</sub>              | <b>72</b> <sub>16</sub>       |
| V1=1. Incorrecto              | V <sup>2</sup> =0. Correc | cto $V^3=0$ .                    | Correcto                  | V4=0. Correcto                | V5=1. Incorrecto              |

La solución final es correcta ya que los dos overflows habidos (V = 1), corresponden a signos contrarios (N = 1, N = 0).

```
b) 43 - 12 = 31; 31 + 34 = 65; 65 + 75 = 140; 140 - 47 = 93.
                                      0001 11112
          0010 10112
                                                                   0100 00012
                                                                                                1000 11002
         1111 0100<sub>2</sub>
                                      0010 00102
                                                                   0100 10112
                                                                                                1101 0001<sub>2</sub>
         0001 11112
                                      0100 00012
                                                                   1000 11002
                                                                                                0101 11012
                 + 31<sub>10</sub>
                                             + 6510
                                                                         - 116<sub>10</sub>
                                                                                                       + 9310
                   1F<sub>16</sub>
                                                41<sub>16</sub>
                                                                            8C<sub>16</sub>
                                                                                                        5D<sub>16</sub>
                                  V2=0. Correcto
     V<sup>1</sup>=0. Correcto
                                                             V<sup>3</sup>=1. Incorrecto
                                                                                         V4=1. Incorrecto
```

La solución final es correcta ya que los dos overflows habidos (V = 1), corresponden a signos contrarios (N = 1, N = 0).

```
c) 15 - 77 = -62; -62 - 43 = -105; -105 - 38 = -143; -143 + 32 = -111.
          0000 11112
                                         1100 00102
                                                                        1001 01112
                                                                                                       0111 00012
          1011 0011<sub>2</sub>
                                         11<u>01 0101</u><sub>2</sub>
                                                                        1<u>101 1010</u>2
                                                                                                       0010 00002
          1100 0010<sub>2</sub>
                                                                        0111 00012
                                                                                                       1001 00012
                                         1001 0111<sub>2</sub>
                   - 62<sub>10</sub>
                                                - 105<sub>10</sub>
                                                                              + 113<sub>10</sub>
                                                                                                              - 111<sub>10</sub>
                    C2<sub>16</sub>
                                                   9716
                                                                                  71<sub>16</sub>
                                                                                                                 9116
      V1=0. Correcto
                                     V<sup>2</sup>=0. Correcto
                                                                 V<sup>3</sup>=1. Incorrecto
                                                                                                 V4=1. Incorrecto
```

La solución final es correcta ya que los dos overflows habidos (V = 1), corresponden a signos contrarios (N = 0, N = 1).

**2.4.** Multiplicar las parejas de números con signo en complemento a 2 siguientes:

**a)** 010111<sub>2</sub> x 110110<sub>2</sub> **b)** 110011<sub>2</sub> x 101100<sub>2</sub>

**d)** 56<sub>10</sub> x (-67) 10 **e)** - 43<sub>10</sub> x (-113) 10 **f)** A4<sub>16</sub> x B8<sub>16</sub>.

**Nota:** Aplicando la propiedad de extensión de signo del complemento a 2, utilizar en todos los casos 8 bits para cada multiplicando.

c) 00111111<sub>2</sub>x 0011111<sub>2</sub>

# Solución:

| a) 44440440       | b) 44404400       | 00044444          |
|-------------------|-------------------|-------------------|
| a) 11110110       | b) 11101100       | c) 00011111       |
| <u>x 00010111</u> | <u>x 11110011</u> | <u>x 00011111</u> |
| 1111111111110110  | 1111111111101100  | 00000000011111    |
| 111111111110110   | 111111111101100   | 00000000011111    |
| 11111111110110    | 111111101100      | 0000000011111     |
| 111111110110      | 11111101100       | 000000011111      |
| 1111111100011010  | 1111101100        | 00000011111       |
|                   | 000010100         | 0000001111000001  |
|                   | 000000100000100   |                   |
|                   |                   |                   |
| F6 x 17 = FF1A    | F3 x EC = 0104    | 1F x 1F = 03C1    |
| d)                | e)                | f)                |
| 00111000          | 11010101          | 10100100          |
| x 10111101        | x 10001111        | x 10111000        |
| 0000000000111000  | 11111111111010101 | 1111110100100     |
| 0000000111000     | 111111111010101   | 111110100100      |
| 000000111000      | 11111111010101    | 11110100100       |
| 000000111000      | 1111111010101     | 001011100         |
| 00000111000       | <b>0</b> 00101011 | 0001100111100000  |
| 111001000         | 0001001011111011  |                   |
| 1111000101011000  |                   |                   |
| 11110001011000    |                   |                   |
| 38 x BD = F158    | D5 x 8F = 12FB    | A4 x B8 = 19E0    |

**2.5.** Una ALU trabaja con números enteros con signo de 4 bits, en notación complemento a 2. Se pide, escribir una tabla donde se muestre el resultado de la división de cada uno de estos número por -2 {R = A/(-2)}.

# Solución:

| Nº | <b>A</b> <sub>3</sub> | A <sub>2</sub> | <b>A</b> <sub>1</sub> | A <sub>0</sub> | Nº/(-2) | R <sub>3</sub> | R <sub>2</sub> | R <sub>1</sub> | R <sub>0</sub> |
|----|-----------------------|----------------|-----------------------|----------------|---------|----------------|----------------|----------------|----------------|
| 0  | 0                     | 0              | 0                     | 0              | 0       | 0              | 0              | 0              | 0              |
| +1 | 0                     | 0              | 0                     | 1              | 0       | 0              | 0              | 0              | 0              |
| +2 | 0                     | 0              | 1                     | 0              | -1      | 1              | 1              | 1              | 1              |
| +3 | 0                     | 0              | 1                     | 1              | -1      | 1              | 1              | 1              | 1              |
| +4 | 0                     | 1              | 0                     | 0              | -2      | 1              | 1              | 1              | 0              |
| +5 | 0                     | 1              | 0                     | 1              | -2      | 1              | 1              | 1              | 0              |
| +6 | 0                     | 1              | 1                     | 0              | -3      | 1              | 1              | 0              | 1              |
| +7 | 0                     | 1              | 1                     | 1              | -3      | 1              | 1              | 0              | 1              |
| -8 | 1                     | 0              | 0                     | 0              | +4      | 0              | 1              | 0              | 0              |
| -7 | 1                     | 0              | 0                     | 1              | +3      | 0              | 0              | 1              | 1              |
| -6 | 1                     | 0              | 1                     | 0              | +3      | 0              | 0              | 1              | 1              |
| -5 | 1                     | 0              | 1                     | 1              | +2      | 0              | 0              | 1              | 0              |
| -4 | 1                     | 1              | 0                     | 0              | +2      | 0              | 0              | 1              | 0              |
| -3 | 1                     | 1              | 0                     | 1              | +1      | 0              | 0              | 0              | 1              |
| -2 | 1                     | 1              | 1                     | 0              | +1      | 0              | 0              | 0              | 1              |
| -1 | 1                     | 1              | 1                     | 1              | 0       | 0              | 0              | 0              | 0              |

**2.6.** Considerar la ALU y los registros que se muestran en la figura. Responder a las siguientes cuestiones escribiendo la(s) palabra(s) de control adecuada(s). Cada palabra de control debe especificarse de acuerdo con el formato  $C_4C_3C_2C_1C_0$ . Por ejemplo, la operación "A+B $\rightarrow$ A" se escribiría 10001.

 Sugerir dos métodos para llevar el registro A al valor cero.

d) Sugerir una secuencia de control que intercambie los contenidos de los registros A y B. La interpretación de los distintos puntos de control se resume en la tabla adjunta.

| $C_1C_0$ | →R | →S | $C_3C_2$ | F       | C <sub>4</sub> | ACCION            |
|----------|----|----|----------|---------|----------------|-------------------|
| 00       | Α  | Α  | 00       | R + S   | 0              | $F \rightarrow B$ |
| 01       | Α  | В  | 01       | R – S   | 1              | $F \rightarrow A$ |
| 10       | В  | Α  | 10       | R AND S |                |                   |
| 11       | В  | В  | 11       | R XOR S |                |                   |



# Solución:

| FUNCION                            | OPERACIONES                      | C4 | C3 | C2 | C1 | C0 |
|------------------------------------|----------------------------------|----|----|----|----|----|
| a1) $0 \Rightarrow R_A$            | $R_A \oplus R_A \Rightarrow R_A$ | 1  | 1  | 1  | 0  | 0  |
| a2) 0 ⇒ R <sub>A</sub>             | $R_A - R_A \Rightarrow R_A$      | 1  | 0  | 1  | 0  | 0  |
| b1) R <sub>A</sub> ⇔R <sub>B</sub> | $R_A + R_B \Rightarrow R_B$      | 0  | 0  | 0  | 0  | 1  |
|                                    | $R_B - R_A \Rightarrow R_A$      | 1  | 0  | 1  | 1  | 0  |
|                                    | $R_B - R_A \Rightarrow R_B$      | 0  | 0  | 1  | 1  | 0  |
| b2) R <sub>A</sub> ⇔R <sub>B</sub> | $R_A \oplus R_B \Rightarrow R_A$ | 1  | 1  | 1  | 0  | 1  |
|                                    | $R_A \oplus R_B \Rightarrow R_B$ | 0  | 1  | 1  | 0  | 1  |
|                                    | $R_A \oplus R_B \Rightarrow R_A$ | 1  | 1  | 1  | 0  | 1  |

**2.7.** Utilizando la ALU de la figura, indique las operaciones a realizar en la ALU para que las salidas representen el módulo del resultado de la diferencia (X - Y), en donde X e Y son números positivos de 4 bits en complemento a 2.

| S <sub>1</sub> S <sub>0</sub> | Operación                   |
|-------------------------------|-----------------------------|
| 0 0                           | F = AND(A,B)                |
| 0 1                           | F = /A + C <sub>IN</sub>    |
| 1 0                           | $F = A + B + C_{IN}$        |
| 11                            | F= A + /B + C <sub>IN</sub> |



# Solución:

$$|X - Y| = |X - Y|$$
, si  $X \ge Y$ .  $|X - Y| = |Y - X| = -(X - Y)$ , si  $X < Y$ .

Asociando las entradas X e Y a las entradas A y B y tomando C<sub>IN</sub> = '1' =>

El programa sería: El control sería:

- Restar A – B - Activar  $S_1 S_0 = 1.1$  // se ejecuta  $F = A + C2(B) \Rightarrow (X - Y)$ 

- Si  $C_{OUT} = '1' (X \ge Y)$  - F = |X - Y|

- Si C<sub>OUT</sub> = '0' (X < Y) - y por tanto se debe invertir el valor de F para obtener (Y - X).

2.- Con F = A y  $C_{IN}$  = '1'. Activando  $S_1$   $S_0$  = 0 1, se ejecuta F = /A + 1 => C2(A) => (Y - X)

**2.8.** Diseñar en VHDL un circuito *Barrel Shift*, para números de 32 bits y un máximo de 31 desplazamientos, tanto a la izquierda como a la derecha.

## Solución:

```
-- Desplazador de barril parametizable
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
entity Desplazador is
          generic (n: integer := 4); -- n: 16,8,4,2,1
  Port ( sright : in STD_LOGIC;
       data_in : in STD_LOGIC_VECTOR (31 downto 0);
       data_out: out STD_LOGIC_VECTOR (31 downto 0);
       enable: in STD LOGIC);
end Desplazador;
architecture generica of Desplazador is
signal ceros: std_logic_vector (n-1 downto 0);
          ceros <= (others => '0');
          process (enable, data_in, sright)
          begin
                     if enable = '1' then
                                if sright = '1' then data_out <= ceros & data_in(31 downto n);
                                else data_out <= data_in(31-n downto 0) & ceros;
                                end if:
                     else data_out <= data_in;
                     end if;
          end process;
end generica;
```

```
-- Barrel Shift
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
entity Barrel is
  Port ( despl : in STD_LOGIC_VECTOR (4 downto 0);
data_in : in STD_LOGIC_VECTOR (31 downto 0);
       data_out : out STD_LOGIC_VECTOR (31 downto 0);
       sright: in STD_LOGIC;
       enable : in std_logic);
end Barrel:
architecture Behavioral of Barrel is
COMPONENT Desplazador
  generic (n: integer);
          PORT(
     sright: IN std_logic;
     data_in: IN std_logic_vector(31 downto 0);
      data_out : OUT std_logic_vector(31 downto 0);
      enable: IN std_logic
);
END COMPONENT;
signal habilitar: std_logic_vector (4 downto 0);
signal dieciseis: std_logic_vector (31 downto 0);
signal ocho: std_logic_vector (31 downto 0);
signal cuatro: std_logic_vector (31 downto 0);
signal dos: std_logic_vector (31 downto 0);
habilitar <= (4 => enable and despl(4), 3 => enable and despl(3), 2 => enable and despl(2),
                                                   1 \Rightarrow enable and despl(1), 0 \Rightarrow enable and despl(0));
u16: desplazador
                    generic map (n => 16)
                    PORT MAP (sright => sright, data_in => data_in, data_out => dieciseis, enable => habilitar(4));
u8: desplazador
                    generic map (n => 8)
```

```
PORT MAP (sright => sright, data_in => dieciseis, data_out => ocho, enable => habilitar(3));

u4: desplazador

generic map (n => 4)
PORT MAP (sright => sright, data_in => ocho, data_out => cuatro, enable => habilitar(2));

u2: desplazador

generic map (n => 2)
PORT MAP (sright => sright, data_in => cuatro, data_out => dos, enable => habilitar(1));

u1: desplazador

u1: desplazador

generic map (n => 1)
PORT MAP (sright => sright, data_in => dos, data_out => data_out, enable => habilitar(0));

end Behavioral;
```

```
-- Simulador para el Barrel Shift
LIBRARY ieee:
USE ieee.std_logic_1164.ALL;
USE ieee.std_logic_unsigned.all;
USE ieee.numeric_std.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
ENTITY Barrel_TB IS
END Barrel TB;
ARCHITECTURE behavior OF Barrel_TB IS
   COMPONENT Barrel
  PORT(
     despl: IN std_logic_vector(4 downto 0);
     data_in: IN std_logic_vector(31 downto 0);
     data_out : OUT std_logic_vector(31 downto 0);
     sright: IN std_logic;
          enable: IN std_logic
  END COMPONENT:
  signal despl : std_logic_vector(4 downto 0) := (others => '0');
  signal data_in : std_logic_vector(31 downto 0) := (others => '0');
  signal sright : std_logic := '0';
  signal enable : std_logic := '0';
          --Outputs
  signal data_out : std_logic_vector(31 downto 0);
BEGIN
          -- Instantiate the Unit Under Test (UUT)
  uut: Barrel PORT MAP (
      despl => despl,
      data_in => data_in,
      data_out => data_out,
      sright => sright,
      enable => enable
 -- Stimulus process
 stim_proc: process
 begin
          enable <= '1';
                    sright <= '1';
 -- Desplazamiento a la derecha.
                    data_in \le x"80000000";
                   for i in 0 to 31 loop
                             despl <= conv_std_logic_vector (i,5);</pre>
                             wait for 10 ns;
   end loop;
-- Desplazamiento a la izquierda.
                    sright <= '0';
                    data_in \le x"00000001";
                    for i in 0 to 31 loop
                             despl <= conv_std_logic_vector (i,5);</pre>
                             wait for 10 ns;
   end loop;
  end process;
END;
```

2.9. Se tiene la arquitectura de la figura con un banco de dos registros (R0 y R1) de 8 bits y una ALU de 8 bits que realiza cuatro operaciones (ver tabla). La señal de control ALUOp, de 2 bits, sirve para elegir la operación a realizar. Las señales de control Rs1, Rs2 y Rd sirven para indicar cuáles son los 2 registros utilizados en la ALU (Rs1 para Op1 y Rs2 para Op2) y cuál es el registro escrito (Rd para Result). En todas ellas, '0' indica el registro R0 y '1' indica el registro R1.La operación SLT pone la salida a 1 (número entero 1) si Op1 < Op2 y a 0 (número entero 0) en caso contrario, considerando que los operandos tienen signo y están en complemento a 2.



| ALUOp | Operación            |  |  |
|-------|----------------------|--|--|
| 00    | Result=Op1+Op2       |  |  |
| 01    | Result=NAND(Op1,Op2) |  |  |
| 10    | Result=XOR(Op1,Op2)  |  |  |
| 11    | Result=SLT(Op1,Op2)  |  |  |

La palabra de control es de 5 bits, (ALUOp,Rs1,Rs2,Rd). Por ejemplo, si la palabra de control es "00011" se realizará la operación R1 <= R0 + R1;

a. Indique la palabra de control para conseguir que R0 quede a 0.

```
ALUOp,Rs1,Rs2,Rd => 10000 => R0 = XOR (R0, R0). 

también => 10110 => R0 = XOR (R1, R1). 

también => 11000 => R0 = SLT (R0, R0). 

también => 11110 => R0 = SLT (R1, R1).
```

**b.** Indique la palabra de control para conseguir que R1 reciba NOT(R0)

```
ALUOp,Rs1,Rs2,Rd => 01001 => R1= NAND (R0, R0).
```

**c.** Si inicialmente R0=0x08 y R1=0xFF, indique a qué queda el registro R1 tras realizar la siguiente secuencia de instrucciones: 1. "00010" y 2. "11101"

```
00010 \Rightarrow R0 = R0 + R1 = 0x07

11101 \Rightarrow Si R1 < R0, then R1 = 0x01, else R1 = 0x00.

R1 = 0x01
```

**d.** Si inicialmente R0=0xFE y R1=0x05, indique a qué queda el registro R1 tras realizar la siguiente secuencia de instrucciones: 1. "11011" y 2. "10011"

```
11011 => Si R0 < R1, then R1 = 0x01, else R1 = 0x00.
10011 => R1 = XOR (R0, R1)
```

R1 = 0xFF

**2.10.** En el circuito de la figura se muestra la arquitectura de un cierto sistema digital en el que se distinguen elementos combinacionales ya conocidos como multiplexores, decodificadores y una unidad aritmético lógica (ALU), y elementos secuenciales como un conjunto de 32 registros, en el que como es habitual, el registro R0 es de sólo lectura y su valor es siempre 0. Considere que todos los registros son de 32 bits y salvo R<sub>0</sub> con valores desconocidos. En la figura se identifican cuatro señales de control con distinto tamaño en bits, R<sub>D</sub>, R<sub>X</sub>, R<sub>Y</sub> y ALU<sub>FUN</sub>.



La operación SLT de la ALU, como se ha visto en clase, pone un '1' en el registro destino si el valor de la entrada X es menor que el de la entrada Y.

A la vista del esquema facilitado, se pide:

a) Señale, justificando necesariamente la respuesta, el tamaño en bits y la función de la señal de control "R<sub>D</sub>".

" $R_D$ " es la señal de entrada de un decodificador 5-32, por tanto es una señal de 5 bits,  $2^5$  = 32. Su función en el circuito es seleccionar, habilitar para escritura el registro destino, un único registro entre los 32 posibles. Cuando  $R_D$  = "00000", el REG-0 no se habilita.

b) Señale, justificando necesariamente la respuesta, el tamaño en bits y la función de la señal de control "Rx".

" $R_X$ " es la señal de control de un multiplexor 32-1. Por tanto es una señal 5 bits,  $2^5$  = 32. Su función en el circuito es seleccionar, elegir entre los 32 posibles registros, el registro desde donde se lee el operando X de acceso a la ALU.

c) Describa un algoritmo como desee y asócielo a la palabra o palabras de control correspondientes para su ejecución para conseguir que R<sub>5</sub> <= 0xFFFFFFF.</p>

```
La operación sólo necesita una única instrucción. Palabra de control: R_D, R_X, R_Y, ALU_{FUN} R_5 <= NOT R_0 00101, 00000, XXXXX, 11
```

**d)** Diseñe un algoritmo y escriba la palabra o palabras de control necesarias para su ejecución para calcular la operación R<sub>4</sub> <= Complemento a 2 de R<sub>3</sub>.

```
\label{eq:local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_local_
```

**NOTA:** Para <u>considerar válida una palabra de control</u>, debe señalar la secuencia de bits que corresponda en el orden de las variables R<sub>D</sub>, R<sub>X</sub>, R<sub>Y</sub>, ALU<sub>FUN</sub>. Utilice una coma para separar cada señal.

**2.11.** En el circuito de la figura se muestra la arquitectura básica de un sistema microprocesador, con un banco de 8 registros de 16 bits y una ALU capaz de realizar 8 operaciones distintas. Los 8 registros se denominan R0 a R7. El registro R0 es constante e igual a 0, el registro R1 también es constante e igual a 1, y el registro R2 también es constante e igual a 2. El resto de registros, R3 a R7, son variables y de propósito general.

Los bits de control Rs1 y Rs2 indican, respectivamente, qué registros irán a Op1 y Op2 de la ALU, mientras que los bits de control Rd indican qué registro recibirá el valor de la salida de la ALU, Resul. Por su parte, la operación realizada en la ALU se decide mediante los bits de control ALUFun. En el caso de los desplazamientos, Op1 es el operando desplazado y Op2 indica en cuántas posiciones hay que desplazarlo.

| ALUFun | Operación           |
|--------|---------------------|
| 000    | Resul = Op1 + Op2   |
| 001    | Resul = Op1 - Op2   |
| 010    | Resul = Op1 NOR Op2 |
| 011    | Resul = Op1 XOR Op2 |
| 100    | Resul = Op1 AND Op2 |
| 101    | Resul = Op1 SLL Op2 |
| 110    | Resul = Op1 SRL Op2 |
| 111    | Resul = Op1 SRA Op2 |



#### Se pide:

**a.** Dadas las instrucciones en código máquina de la tabla adjunta, se pide, traducir este código a la "Instrucción ensamblador" correspondiente y calcular el valor de los registros destinos del código dado. El estado inicial de los registros es desconocido, pero las instrucciones indicadas se ejecutan en el orden señalado.

| ALUFun, Rd, Rs1, Rs2 | Instrucción ensamblador |
|----------------------|-------------------------|
| 001, 011, 000, 001   | R3 = R0 – R1            |
| 011, 100, 001, 010   | R4 = R1 XOR R2          |
| 101, 101, 001, 010   | R5 = R1 SLL R2          |
| 110, 110, 011, 010   | R6 = R3 SRL R2          |
| 111, 111, 011, 010   | R7 = R3 SRA R2          |

| Registro | Valor final |
|----------|-------------|
| R3       | 0xFFFF      |
| R4       | 0x0003      |
| R5       | 0x0004      |
| R6       | 0x3FFF      |
| R7       | 0xFFFF      |

b. Sin tener en cuenta los valores de los registros de las operaciones anteriores, ahora se quiere realizar la operación R4 = 7·R3. Al no existir dicha operación en este micro, se realizará a través de una serie de instrucciones. Se pide el código ensamblador así como el código máquina que realizan la operación solicitada. Se valorará, por este orden, utilizar el mínimo número de instrucciones posible y no modificar el contenido de los registros no implicados en la operación (o el mínimo número de registros).

| Instrucción ensamblador | ALUFun, Rd, Rs1, Rs2 | Comentarios (opcionales) |
|-------------------------|----------------------|--------------------------|
| R4 = R1 + R2            | 000, 100, 001, 010   | R4 = 3                   |
| R4 = R3 SLL R4          | 101, 100, 011, 100   | R4 = 8·R3                |
| R4 = R4 - R3            | 001, 100, 100, 011   | R4 = 7·R3                |