

# ARQUITECTURA DE COMPUTADORES

## 2º Grado en Ingeniería Informática

Curso 2011 – 2012

Página 1 de 2

### Relación de ejercicios

#### Tema 1: Introducción a la estructura/arquitectura de computadores

---

#### Ejercicio 1

Determinar la secuencia de microoperaciones necesarias para implementar las siguientes instrucciones en la Computadora Mejorada.

1. INC m: incrementa el contenido de la posición de memoria m.
2. DEC m: decrementa el contenido de la posición de memoria m.
3. LDA m: carga el acumulador con el contenido de la posición de memoria m.
4. JPC m: salta a la dirección de memoria PC + m.

#### Ejercicio 2

Se plantea introducir en la Computadora Mejorada el concepto de pila, que utilizará parte de la memoria principal. Explíquese:

1. Los cambios que se han de introducir en la estructura de la Computadora Mejorada.
2. La nueva secuencia de microoperaciones para la ejecución de la instrucción CSR m, que ya existía, y las que definen la nueva instrucción RET, de retorno de subrutina, que sustituye a JMPI m.

Nota: El registro puntero de pila (SP) debe apuntar siempre a la última posición ocupada de la pila.

#### Ejercicio 3

Asumiendo que se han realizado en la Computadora Mejorada los cambios que se proponen en el ejercicio anterior, determinar la secuencia de microoperaciones necesarias para implementar las instrucciones PSH y POP, destinadas a introducir en la pila y recuperar de la pila el contenido del acumulador respectivamente.

#### Ejercicio 4

Considérese la estructura de la Computadora Mejorada a la que se le han aplicado los siguientes cambios:

- a) El número de palabras en la memoria sigue siendo de 256, pero el ancho de palabra es de sólo 4 bits. Esto implica que las instrucciones podrán ocupar una posición de memoria (CRA, CTA, ITA, etc.) o tres (ADD, ADDI, STA, etc.)
- b) El registro GPR está formado por dos registros de 4 bits, GPR0 y GPR1, que actúan como uno solo de 8 bits para transferencia de direcciones al PC y al MAR. Ambos pueden leer o almacenar en memoria. Los datos, de 4 bits, deben almacenarse en el registro GPR menos significativo (GPR0). El sumador y el acumulador son también de 4 bits.
- c) El registro OPR puede escribirse directamente desde memoria.
- d) Se ha incorporado un registro puntero de pila (SP).

# ARQUITECTURA DE COMPUTADORES

## 2º Grado en Ingeniería Informática

Curso 2011 – 2012

Página 2 de 2

### Relación de ejercicios

#### Tema 1: Introducción a la estructura/arquitectura de computadores

- e) Las conexiones puntuales entre registros se han sustituido por un bus de 8 bits que conecta el PC, el MAR, el OPR, la memoria, y los registros GPR1 y GPR0.

La estructura se muestra a continuación:



Se pide lo siguiente:

1. Secuencia de microoperaciones de la que hay que dotar a la estructura para que ésta permita un funcionamiento similar a la de la Computadora Mejorada original.
2. Secuencia de microoperaciones del ciclo de búsqueda.
3. Secuencia de microoperaciones del ciclo de ejecución de las instrucciones ADD, ADDI, STA y JMP.
4. Secuencia de microoperaciones del ciclo de ejecución de las instrucciones DEC, INC y LDA del Ejercicio 1.
5. Secuencia de microoperaciones del ciclo de ejecución de las instrucciones PSH y POP del Ejercicio 3.

C.B

1) PC → MAR

2) M → GPR

PC + 1 → PC

3) GPR (OP) → GPR

Dato (16 bits)

OP(5b) | ARG(11b)



### Ejercicio 1

Determinar la secuencia de microoperaciones necesarias para implementar las siguientes instrucciones en la Computadora Mejorada.

1. INC m: incrementa el contenido de la posición de memoria m.
2. DEC m: decrementa el contenido de la posición de memoria m.
3. LDA m: carga el acumulador con el contenido de la posición de memoria m.
4. JPC m: salta a la dirección de memoria PC + m.

① INC | m ≡  $\begin{matrix} \text{INC} \\ \text{OP} \\ \boxed{\text{INC}} \end{matrix} \mid \boxed{mm}$

1) GPR (AD) → MAR apunta a la dirección

2) m → GPR leo

3) GPR + 1 → GPR incremento memoria

4) GPR → m vuelve a memoria

## ② DEC | m

- 1) GPR(AD) → MAR ;  
 $\emptyset \rightarrow ACC$
- 2)  $m \rightarrow GPR$   
 $\overline{ACC} \rightarrow ACC \rightarrow \begin{cases} \cancel{ACC+1 \rightarrow ACC} \\ \overline{ACC} \rightarrow ACC \\ \cancel{ACC+1 \rightarrow ACC} \end{cases}$
- 3)  $ACC + GPR \rightarrow ACC$
- 4)  $ACC \rightarrow GPR$
- 5)  $GPR \rightarrow M$

## ③ LDA | m

- 1) GPR(AD) → MAR ;  
 $\emptyset \rightarrow ACC$
- 2)  $m \rightarrow GPR$
- 3)  $GPR + ACC \rightarrow ACC$

## ④ JPC | m

- 1)  $\emptyset \rightarrow ACC$
- 2)  $GPR + ACC \rightarrow ACC$
- 3)  $PC \rightarrow GPR$
- 4)  $GPR + ACC \rightarrow ACC$
- 5)  $ACC \rightarrow GPR$
- 6)  $GPR(AD) \rightarrow PC$

## Ejercicio 2

Se plantea introducir en la Computadora Mejorada el concepto de pila, que utilizará parte de la memoria principal. Explíquese:

1. Los cambios que se han de introducir en la estructura de la Computadora Mejorada.
2. La nueva secuencia de microoperaciones para la ejecución de la instrucción CSR m, que ya existía, y las que definen la nueva instrucción RET, de retorno de subrutina, que sustituye a JMPI m.

Nota: El registro puntero de pila (SP) debe apuntar siempre a la última posición ocupada de la pila.

1 SP solo recorre la pila y tiene conexión con MAR



2 CSR (dir) {  
1. PC apila  
2. PC  $\leftarrow$  dir}

1)  $SP - 1 \rightarrow SP$

2)  $SP \rightarrow MAR$

$GPR (AD) \rightarrow PC$

$PC \rightarrow GPR (AD)$

} Solo se puede hacer con GPR y PC

3)  $GPR \rightarrow M$

RET

1)  $SP \rightarrow MAR$

2)  $M \rightarrow GPR$

$SP + 1 \rightarrow SP$

3)  $GPR (AD) \rightarrow PC$

### Ejercicio 3

Asumiendo que se han realizado en la Computadora Mejorada los cambios que se proponen en el ejercicio anterior, determinar la secuencia de microoperaciones necesarias para implementar las instrucciones PSH y POP, destinadas a introducir en la pila y recuperar de la pila el contenido del acumulador respectivamente.

PSH

1)  $SP - 1 \rightarrow SP$

$ACC \rightarrow GPR$

2)  $SP \rightarrow MAR$

3)  $GPR \rightarrow M$

POP

1)  $SP \rightarrow MAR$

$\emptyset \rightarrow ACC$

2)  $M \rightarrow GPR$

$SP + 1 \rightarrow SP$

3)  $GPR + ACC \rightarrow ACC$

#### Ejercicio 4

Considérese la estructura de la Computadora Mejorada a la que se le han aplicado los siguientes cambios:

- El número de palabras en la memoria sigue siendo de 256, pero el ancho de palabra es de sólo 4 bits. Esto implica que las instrucciones podrán ocupar una posición de memoria (CRA, CTA, ITA, etc.) o tres (ADD, ADDI, STA, etc.)
- El registro GPR está formado por dos registros de 4 bits, GPR0 y GPR1, que actúan como uno solo de 8 bits para transferencia de direcciones al PC y al MAR. Ambos pueden leer o almacenar en memoria. Los datos, de 4 bits, deben almacenarse en el registro GPR menos significativo (GPR0). El sumador y el acumulador son también de 4 bits.
- El registro OPR puede escribirse directamente desde memoria.
- Se ha incorporado un registro puntero de pila (SP).
- Las conexiones puntuales entre registros se han sustituido por un bus de 8 bits que conecta el PC, el MAR, el OPR, la memoria, y los registros GPR1 y GPR0.

La estructura se muestra a continuación:



Se pide lo siguiente:

1. Secuencia de microoperaciones de la que hay que dotar a la estructura para que ésta permita un funcionamiento similar a la de la Computadora Mejorada original.
2. Secuencia de microoperaciones del ciclo de búsqueda.
3. Secuencia de microoperaciones del ciclo de ejecución de las instrucciones ADD, ADDI, STA y JMP.
4. Secuencia de microoperaciones del ciclo de ejecución de las instrucciones DEC, INC y LDA del Ejercicio 1.
5. Secuencia de microoperaciones del ciclo de ejecución de las instrucciones PSH y POP del Ejercicio 3.

CB

- 1) PC → MAR
- 2) M → GPR1
- PC + 1 → PC

ADD d

- 1) PC → MAR
- 2) M → GPR1
- PC + 1 → PC
- 3) PC → MAR
- 4) M → GPRØ
- PC + 1 → PC
- 5) GPR → MAR
- 6) M → GPRØ
- 7) ACC + GPRØ → ACC

## ADDI d

- 1) PC → MAR
- 2) M → GPR1  
PC + 1 → PC
- 3) PC → MAR
- 4) M → GPRØ  
PC + 1 → PC
- 5) GPR → MAR
- 6) M → GPR1  
MAR + 1 → MAR \*
- 7) M → GPRØ
- 8) GPR → MAR
- 9) M → GPRØ
- 10) ACC + GPRØ → ACC

## STA

- 1) PC → MAR
- 2) M → GPR1  
PC + 1 → PC
- 3) PC → MAR
- 4) M → GPRØ  
PC + 1 → PC
- 5) GPR → MAR
- 6) ACC → GPRØ
- 7) GPRØ → M

## JMP

- 1) PC  $\rightarrow$  MAR
- 2) h  $\rightarrow$  GPR1
- PC + 1  $\rightarrow$  PC

- 3) PC  $\rightarrow$  MAR
- 4) h  $\rightarrow$  GPR0
- PC + 1  $\rightarrow$  PC

- 5) GPR  $\rightarrow$  PC

## DEC

- 1) SP - 1  $\rightarrow$  SP
- ACC  $\rightarrow$  GPR0

- 2) SP  $\rightarrow$  MAR

- 3) GPR0  $\rightarrow$  h

- 4) PC  $\rightarrow$  MAR

0  $\rightarrow$  ACC

- 5) h  $\rightarrow$  GPR1

PC + 1  $\rightarrow$  PC

ACC + 1  $\rightarrow$  ACC

- 6) PC  $\rightarrow$  MAR

$\overline{ACC} \rightarrow ACC$

- 7) h  $\rightarrow$  GPR0

PC + 1  $\rightarrow$  PC

- 8) GPR  $\rightarrow$  MAR

- 9) GPR0 + ACC  $\rightarrow$  ACC

- 10) ACC  $\rightarrow$  GPR0

- 11) GPR0  $\rightarrow$  h

- 12) SP  $\rightarrow$  MAR

- 13) h  $\rightarrow$  GPR0

SP + 1  $\rightarrow$  SP

- 14) GPR0 + ACC  $\rightarrow$  ACC

## INC

1) SP - 1 → SP  
ACC → GPR $\emptyset$

2) SP → MAR

3) GPR $\emptyset$  → h

4) PC → MAR

0 → ACC

5) h → GPR1

PC + 1 → PC

ACC + 1 → ACC

6) PC → MAR

7) h → GPR $\emptyset$

PC + 1 → PC

8) GPR → MAR

9) GPR $\emptyset$  + ACC → ACC

10) ACC → GPR $\emptyset$

11) GPR $\emptyset$  → h

12) SP → MAR

13) h → GPR $\emptyset$

SP + 1 → SP

14) GPR $\emptyset$  + ACC → ACC

## LDA

- 1)  $PC \rightarrow MAR$   
 $O \rightarrow ACC$
- 2)  $M \rightarrow GPR1$   
 $PC+1 \rightarrow PC$
- 3)  $PC \rightarrow MAR$
- 4)  $M \rightarrow GPRO$   
 $PC+1 \rightarrow PC$
- 5)  $GPRO + ACC \rightarrow ACC$

## PSH

- 1)  $SP-1 \rightarrow SP$
- 2)  $SP \rightarrow MAR$
- 3)  $ACC \rightarrow GPRO$
- 4)  $GPRO \rightarrow M$

## POP

- 1)  $SP \rightarrow MAR$   
 $O \rightarrow ACC$
- 2)  $M \rightarrow GPRO$
- 3)  $GPRO + ACC \rightarrow ACC$