

# TEMA 1 “Introducción a los computadores”

## 0. Introducción

**Computador u ordenador:** Máquina que procesa información de forma automática.

**Procesar:** Manipulaciones o Transformaciones que se aplican sobre la información (datos) para obtener la solución de un problema determinado.

**Tecnología:** Elementos físicos que constituyen un computador. Tipos:

- Tecnología Electrónica.
- Tecnología Mecánica.
- Tecnología Óptica.

**Estructuras:** Uniones lógicas de elementos tecnológicos que realizan una tarea conjunta.

## 1. Clasificación de los Computadores

**Computadores Digitales:** Están basados en tecnología electrónica. Utilizan el sistema binario de representación digital. Los dígitos binarios se representan con valores de tensión eléctrica. Las dos tensiones consideradas se denominan H (high) y L (low). La asignación de los valores 1 y 0 lógicos es arbitraria, aunque normalmente H suele asociarse a 1 y L a 0. Los bits se pueden asociar en grupos de varios bits para representar números, letras o cadenas de caracteres.

**Computadores Analógicos:** Trabajan con valores de tensión, cuyo rango está restringido (usualmente -10V .. +10 V). Se debe utilizar factores de escalado y requieren mucha precisión para la manipulación numérica.

### **Computadores Digitales VS Computadores Analógicos:**

Los Digitales poseen mayor capacidad y facilidad de manejo de la información. Tienen mayor precisión en la representación numérica. Mayor facilidad para aumentar el rango de representación. Mayor facilidad de empleo. Permiten la manipulación de datos e información no numérica. Sin embargo, los computadores analógicos son utilizados para ciertas aplicaciones específicas, debido al paralelismo y su alta velocidad de cálculo.

## Arquitectura de Von Neumann

En 1945, Von Neumann propuso un modelo de computación que ha constituido, incluso en la actualidad, la base de la arquitectura de los computadores digitales.

Está compuesto por 4 unidades:

- Unidad de Memoria Principal.
- Unidad de Entrada/Salida.
- Unidad Aritmético-Lógica.
- Unidad de Control

La CPU suele incluir:

- Unidad Aritmético-Lógica.
- Unidad de Control.



La arquitectura de Von Neumann está diseñada para procesar información:  
DATOS + PROCESAMIENTO.

La arquitectura de Von Neumann no especifica el tipo de dato con el que se trabaja.

- BCD.
- Byte.
- Word.
- Entero con/sin signo.
- Reales de mayor o menor precisión.

El tipo de procesamiento vendrá indicado por instrucciones:

- Aritméticas.
- Lógicas.
- Transferencia de datos.
- Control de flujo (saltos, bifurcaciones, etc.).
- Otras.

La secuencia de instrucciones se denomina programa. Tanto los datos como el programa se almacenarán en el bloque de Memoria Principal.

Tres conceptos:

- Instrucciones y datos almacenados en una misma memoria unificada.
- El contenido de memoria se direcciona por localidad: La memoria se accede por la posición que ocupa y no por el tipo de dato que almacena.
- La ejecución de las instrucciones es secuencial (tras la ejecución de una instrucción se ejecuta la que se encuentra en la siguiente posición del programa). Existen instrucciones que rompen esta secuencialidad.

### 3.1. Arquitectura de Von Neumann: Memoria Principal

Compuesta por un conjunto de celdas de almacenamiento agrupadas en bloques del mismo tamaño (palabra). El acceso a cada palabra tiene asociada a un número único, llamada dirección.

La Memoria Principal viene caracterizada por 2 parámetros: Tamaño de memoria (número de direcciones) y anchura de palabra (número de bits que componen cada palabra). Las operaciones posibles sobre la memoria son: Lectura y Escritura.

En la Arquitectura de Von Neumann: Los datos y las instrucciones se almacenan en la misma unidad de memoria principal.

### **3.2. Arquitectura de Von Neumann: Unidad Aritmético - Lógica**

La ALU posee una serie de microoperaciones que son capaces de tomar datos y aplicarles operaciones elementales. Para que la ALU sea efectiva, incorpora registros que almacenan los operandos y guardan el resultado de la operación.

Banco de Registros:

- Registros de propósito general.
- Registros específicos.
- Registros de control.
- Registros de estado.

El tamaño de los registros es uno de los factores que limita los tipos de datos con los que opera la computadora. Los datos se leen de memoria, se almacenan temporalmente en los registros.

### **3.3. Arquitectura de Von Neumann: Unidad de Control**

La Unidad de Control es la encargada de manejar todas las demás unidades de la computadora, de manera que trabajen coordinadamente para realizar tareas más complejas.

Ésta toma instrucciones de la memoria principal, las decodifica y prepara las señales para las diferentes unidades funcionales y bloques que tendrá que generar en los diferentes ciclos en los que se descompone la misma.

Generará las señales necesarias para acceder y manejar:

- Memoria Principal (lectura o escritura).
- ALU (diversas operaciones), Banco de Registros (lectura o escritura).
- E/S (diversas operaciones).

Para poder llevar la cuenta de la instrucción del programa que se tendrá que ejecutar, necesita un registro apuntador, denominado genéricamente Contador de Programa.

### **3.4. Arquitectura de Von Neumann: Unidad de Entrada/Salida**

Un computador existe dentro de un mundo real y necesita tomar datos desde el exterior y debe mostrar resultados a los usuarios que lo utilizan.

La Unidad de E/S realiza las transferencias de información con los periféricos.

La Unidad de E/S es capaz de realizar cargas de información desde los discos externos (también llamados Memoria Secundaria) directamente a Memoria Principal.

Esto ocurre en la carga de programas y datos desde disco. También es la encargada de la visualización por pantalla, impresión por papel mediante la impresora, acceso a la red, etc.

### **3.5. Arquitectura de Von Neumann: Buses de Interconexión**

Las diversas unidades se interconectan entre sí mediante buses. Estos buses permiten transferir instrucciones y datos entre las distintas unidades.

En particular hay 3 buses:

- Bus de Direcciones.
- Bus de Datos.
- Bus de Control.

El interconexión de los buses es específico.

- Interconexión general (desde cualquier unidad o registro se puede llegar directamente a cualquier otra unidad o registro).
- Interconexión limitada (se permiten solo conexiones de algunas unidades funcionales o registros con otras unidades o registros específicos y no con todos).

### 3.6. Arquitectura de Von Neumann: CPU

La Unidad Central de Procesamiento (CPU) es el conjunto formado por la ALU, con sus registros internos y la Unidad de Control: Es el bloque encargado de la ejecución de las instrucciones.

También suele incluir la Unidad de E/S. Después de la aparición de los circuitos integrados, la CPU estaba formada por varios bloques, que terminaron siendo integrados en un único circuito denominado genéricamente Microprocesador.

La capacidad de la CPU viene medida por mucho factores:

- MIPS.
- MFLOPS.
- Frecuencia del procesador.

### 3.7. Programa cableado vs Funciones preprogramadas

Un determinado problema se puede resolver mediante una configuración de componentes lógicos básicos (puertas lógicas combinacionales).

Si el algoritmo o programa se implementa mediante puertas lógicas, se dice que tiene el programa *cableado*.

- No es modificable => Poca flexibilidad.
- Es rápido.
- Solución ad-hoc o muy específica.

Otra solución, construir un conjunto de funciones aritméticas y lógicas de propósito general mediante las que conforman el programa.

- Programas modificables => Alta flexibilidad.
- Lento.
- Solución de propósito general.

Dos enfoques:

- Programación en **Hardware**: Programación Cableada, dependen de los componentes y de cómo estén interconectados.
- Programación en **Software**: El Hardware tiene una determinada interconexión que permite ser utilizado de manera genérica.



El sistema es capaz de hacer una cierta cantidad de funciones (posee el hardware necesario para realizar varias operaciones aritmético-lógicas).

Mediante señales de control, el sistema puede seleccionar qué operación realizar.

¿Cómo proporcionar dichas señales de control?

- Secuencia de pasos.
- Cada paso efectúa alguna operación sobre los datos: señales que hay que activar y desactivar.
- Asociar un código único a cada conjunto de señales de control.
- Construir un bloque que active dichas señales.

Con el nuevo hardware obtenido, para cada programa sólo es necesario proporcionar una secuencia de códigos, en vez de cambiar la configuración de su conexión.

- Cada código es una instrucción.
- El hardware incluirá un bloque que interpretará cada instrucción y generará las señales de control.
- A este nuevo método de programación se le denomina software, que corresponde a una secuencia de instrucciones.

Estos módulos corresponden a la ALU y a la Unidad de Control.

### 3.8. Programas: Instrucciones y Datos

En la Memoria Principal se almacenan tanto instrucciones como datos. Es tarea del programador indicar cómo se debe tratar cada posición de memoria:

Posición de memoria, ¿contiene una instrucción o un dato?

Si es un dato, no hay que interpretarlo. Solo manejarlo conforme indiquen las instrucciones que hagan uso de él.

Si es una instrucción, hay que interpretarla y generar el conjunto de señales de control.

### 3.9. Diagrama de la Computadora Básica según la Arquitectura de Von Neumann



## Registros de Control en la Computadora Básica de Von Neumann

- **MBR** (Memory Buffer Register)  
Contiene el dato que se va a escribir en la memoria, o que se lee de ésta.
- **MAR** (Memory Address Register)  
Especifica la dirección de memoria de la palabra que se va a escribir o leer.
- **RBE/S** (Registro Buffer para Entrada/Salida)  
Semejante al MBR. Se utiliza para intercambiar datos entre E/S y la CPU.
- **RDE/S** (Registro Dirección para Entrada/Salida)  
Es similar al MAR. Especifica un dispositivo de E/S.
- **IR** (Instruction Register)  
Contiene el código de operación de la instrucción que se está ejecutando.
- **PC** (Program Counter)  
Contiene la dirección de memoria que contiene la siguiente instrucción.
- **Ac** (Accumulator)  
Almacena temporalmente los operandos y los resultados de las operaciones de la ALU.

### 4.1. Funcionamiento de la Computadora

La función básica de un computador es ejecutar un programa. Un programa es un conjunto de instrucciones almacenadas en memoria.

El proceso para ejecutar una instrucción se denomina **ciclo de instrucción**. Se compone de dos fases, denominadas **ciclo de búsqueda** y **ciclo de ejecución**.

- El ciclo de instrucción empieza con la búsqueda (lectura) de la instrucción de la memoria y termina con la ejecución de la misma.
- La ejecución de un programa consiste en la repetición del proceso anterior, es decir de múltiples ciclos de instrucción.



### 4.2. Ciclo de Búsqueda

El inicio de cada instrucción es igual siempre:

- Buscar en la memoria la siguiente instrucción.
- Traer la instrucción desde memoria a la Unidad de Control.
- Decodificar la instrucción.

El algoritmo que realiza el ciclo de búsqueda sería:

- 1) Transferir el contenido de PC a MAR.
- 2) Incrementar PC.
- 3) Enviar la dirección de MAR a la Memoria Principal. Leer la posición de memoria Memoria[MAR].
- 4) Poner el resultado en el bus de datos y transfiere de memoria a MBR.
- 5) Transferir de MBR a IR.





### 4.3. Ciclo de Ejecución

Cada instrucción se representa con un código binario único.

El código binario asociado suele estar compuesto por varios campos, que representan el código de operación (que especifica el tipo de operación) y el código de los operandos (que especifican los tipos de operandos de la operación).

La Unidad de Control interpreta el código de operación, que se puede clasificar en 4 grandes tipos:

- **Transferencia CPU-Memoria.**
- **Transferencia CPU-E/S.**
- **Procesamiento de Datos.**
- **Control.**

Una instrucción puede alterar el orden de ejecución de un programa, realizar saltos incondicionales, saltos condicionales, etc. Se pueden combinar varios tipos en una única instrucción.

### Formato de instrucción

El formato de instrucción se divide en dos campos:

- Código de Operación.
- Código de Operando.

Ejemplo: Supongamos que la palabra tiene un tamaño 16 bits. Utilizaremos 4 bits para el código de operación, por lo que es posible tener 16 códigos de instrucción diferentes. Quedarán libres 12 bits, por lo que se podrán direccionar  $2^{12} = 4096$  palabras (4K).



### Ejemplo de Ejecución

Programa:

- Suma el contenido de la palabra de memoria  $940_{16}$  con el contenido de la palabra de memoria  $941_{16}$ .
- Almacena el resultado en la posición  $941_{16}$ .

Sea el repertorio códigos instrucción:

- 0001 => Carga la posición de memoria en Ac.
- 0010 => Almacenar el Ac en la posición de memoria.
- 0101 => Sumar el contenido de la posición de memoria con el Ac.

El contenido de la memoria sería:

|     |      |          |
|-----|------|----------|
| 300 | 1940 | 0001 940 |
| 301 | 5941 | 0101 941 |
| 302 | 2941 | 0010 941 |
| --- |      |          |
| 940 | 0003 | 0003     |
| 941 | 0002 | 0002     |

### Ciclo de Búsqueda 1º:

- El programa comienza en la posición  $300_{16}$  (el contador de programa, PC, estará inicializado a  $300h$ ).
- Se transfiere el contenido de PC al MAR.
- Se accede a la posición de memoria indicada por MAR.
- Se almacena el dato de la memoria en el MBR.
- Se transfiere del MBR al registro IR.



### Ciclo de Ejecución 1º:

- La operación que se desea realizar tiene código 0001b (Carga una posición de memoria en Ac). La dirección viene indicada en los 12 bits inferiores de la instrucción.
- Carga MAR con los 12 bits inferiores de MBR (940h).
- Lee la posición de memoria indicada por MAR y el valor lo almacena en MBR.
- Carga el valor de MBR en Ac.
- Se incrementa PC en 1.



### Ciclo de Búsqueda 2º:

- El programa continúa en la posición  $301h$  (PC contendrá  $301h$ ).
- Se transfiere el contenido de PC al MAR.
- Se accede a la posición de memoria indicada por MAR.
- Se almacena el dato de la memoria en el MBR.
- Se transfiere del MBR al registro IR.



### Ciclo de Ejecución 2º:

- La operación que se desea realizar tiene código 0101b (Sumar el contenido de Ac con una dirección de memoria).
- Carga MAR con los 12 bits inferiores de MBR (941h).
- Lee la posición de memoria indicada por MAR y el valor lo almacena en MBR.
- Suma el valor de MBR y el valor de Ac y lo almacena en Ac.
- Se incrementa PC en 1.



### Ciclo de Búsqueda 3º:

- El programa continúa en la posición 302h (PC contendrá 302h).
- Se transfiere el contenido de PC al MAR.
- Se accede a la posición de memoria indicada por MAR.
- Se almacena el dato de la memoria en el MBR.
- Se transfiere del MBR al registro IR.



### Ciclo de Ejecución 3º:

- La operación que se desea realizar tiene código 0010b (Almacenar el contenido de Ac en una dirección de memoria).
- Carga MAR con los 12 bits inferiores de MBR (941h).
- Transfiere el valor de Ac a MBR.
- Almacena en la posición de memoria indicada por MAR el valor que hay en MBR.
- Se incrementa PC en 1.



## 5. Lenguajes de programación

**Programación a bajo nivel:** Programación en ensamblador.

- Cada instrucción es un mnemónico (nombre simbólico).
- Próximo al lenguaje máquina.
- El programa traductor/compilador se denomina ensamblador.
- Cada computador tiene un lenguaje ensamblador diferente.

**Programación a alto nivel:** Programación en lenguajes de alto nivel.

- Instrucciones complejas.
- Tipos de datos compuestos.
- Programación más cercana al pensamiento humano y más alejado de la máquina.
- La sintaxis y los elementos (tipos de datos, operandos, operadores, sentencias) son independientes del computador en el que se ejecuta => Portabilidad a nivel de código fuente.

### 5.1. Arquitectura y Organización

**Arquitectura de un Computador:** Son las características del sistema que ve un programador que trabaje en lenguaje ensamblador.

Características:

- Juego de instrucciones del computador.
- Tipos y formatos de operandos.
- Mapa de memoria y de E/S.
- Modelo de Ejecución.

Clasificación según los mapas de memoria y de E/S:

- Arquitectura de Von Neumann.
- Arquitectura Harvard.

**Organización de un Computador:** También denominado **estructura interna**. Se refiere a las unidades que tiene el computador y a la forma que se conectan entre sí para determinar una arquitectura específica.

Características transparentes al programador:

- Señales de Control.
- Interfaces.
- Computadora/Periféricos.
- Tecnología.

### 5.2. Niveles de Estudio del Computador

Un Computador se puede estudiar desde varios puntos de vista. Descripciones más habituales:

- Niveles estructurales de Bell y Newell.
- Nivel de interpretación de Levy.
- Niveles conceptuales de Blaauw.

#### 5.2.1. Niveles estructurales de Bell y Newell

Se basa en la naturaleza jerárquica de un computador.

Se divide el computador en niveles estructurales, cada uno de los cuales se compone de bloques o componentes que se construyen con bloques o componentes de un nivel inferior.

Un diseñador o analista solo necesita estudiar un nivel particular en un momento dado. En cada nivel, solo interesa su estructura y su función.

Bell y Newell dividen el estudio del computador en 5 niveles:

- Nivel de componentes.
- Nivel de circuito electrónico.
- Nivel de circuito digital.
- Nivel de transferencia entre registros (RTL Register Transfer Logic).
- Nivel de Intercambio MemoriaProcesador (PMS Processor Memory Switch).

| Nivel                | Primitivas                                                              | Reglas de Combinación                                        | Elementos Complejos                                                     |
|----------------------|-------------------------------------------------------------------------|--------------------------------------------------------------|-------------------------------------------------------------------------|
| Componentes          | Semiconductor, metal, óxido                                             | Electrónica, Física del estado Sólido                        | Diodo, transistor, resistencia, condensador                             |
| Circuito Electrónico | Diodo, transistor, resistencia, condensador                             | Leyes de Kirchoff, características de transferencia          | Puertas Lógicas, Biestables                                             |
| Circuito Digital     | Puertas Lógicas, Biestables                                             | Álgebra de Boole, Minimización, Teoría de autómatas          | Multiplexores, Decodificadores, Registros de desplazamiento, contadores |
| RTL                  | Multiplexores, Decodificadores, Registros de desplazamiento, contadores | Lenguajes de transferencia entre registros, micropogramación | Memoria, ALU, Unidad de Control                                         |
| PMS                  | Memoria, ALU, Unidad de Control                                         | Estructura, Organización y Arquitectura de Computadores      | Ordenador                                                               |

### 5.2.2. Niveles de Interpretación de Levy

La clasificación de Levy se hace desde un punto de vista funcional. Cada nivel se considera como un intérprete que recibe unas instrucciones de un cierto tipo y actúa de acuerdo a ellas:

- Nivel de lógica digital.
- Nivel de microinstrucciones (Firmware).
- Nivel de instrucciones de máquina.
- Nivel de sistema operativo (Conjunto de programas para la explotación del computador).
- Nivel de código objeto (Traducción (lenguaje ensamblador)).
- Nivel de lenguaje de alto nivel (Compilación y enlazado).
- Nivel de paquetes de programas de aplicación.

El nivel de código objeto puede traspasar el nivel de sistema operativo e interaccionar directamente con el segundo nivel.



### 5.2.3. Niveles Conceptuales de Blaauw

Se definen 3 niveles conceptuales:

- **Arquitectura.**
  - Comportamiento funcional del computador, tal y como aparece para el programador en ensamblador.
  - Conjunto de instrucciones máquina y representaciones usadas por el compilador para manejar la información.
  - Es el ¿QUÉ HACE?
- **Configuración.**
  - Organización interna del computador a nivel de transferencia entre registros y de flujo de información.
  - Muchas configuraciones diferentes pueden responder a una única arquitectura, pero hay que buscar la más productiva y rápida.
  - Es el ¿CÓMO LO HACE?
- **Realización.**
  - Es la forma en que la configuración se plasma con elementos físicos concretos.
  - Una misma configuración admite múltiples realizaciones.
  - Es el ¿QUIÉN LO HACE?

## 6. Computadora Mejorada



- **Componentes y Operaciones de Control**

| Componente                            | Operación     | Explicación                                                                         |
|---------------------------------------|---------------|-------------------------------------------------------------------------------------|
| Memoria                               | GPR->M        | Escribe en contenido de GPR en el lugar direccionado por MAR.                       |
| Contador de Programa (PC)             | PC+1->PC      | Incrementar el contenido de PC                                                      |
|                                       | GPR(AD)->PC   | Transmite los 8 bits inferiores de GPR al PC                                        |
| Registro Direcciones de Memoria (MAR) | PC->MAR       | Transmite el contenido del PC al MAR                                                |
|                                       | GPR(AD)->MAR  | Transmite los 8 bits inferiores de GPR al MAR                                       |
| Registro de Operación (OPR)           | GPR(OP)->OPR  | Transmite los 4 bits superiores de GPR al OPR                                       |
| Registro de Propósito General (GPR)   | M->GPR        | Transmite la palabra direccionada por MAR al GPR                                    |
|                                       | Acc->GPR      | Transmite el contenido de Acc al GPR                                                |
|                                       | PC->GPR(AD)   | Transmite el contenido del PC al GPR, poniendo los 4 bits superiores a 0.           |
|                                       | GPR+1->GPR    | Incrementa el GPR                                                                   |
| ALU (Acumulador)                      | GPR+Acc->Acc  | Suma el contenido del Acumulador con el contenido del GPR, deja el resultado en Acc |
|                                       | 0->Acc        | Limpia Acc                                                                          |
|                                       | ROR F,Acc     | Desplazamiento cíclico hacia la derecha del Acc junto a F                           |
|                                       | ROL F,Acc     | Desplazamiento cíclico hacia la izquierda del Acc junto a F                         |
|                                       | NOT(Acc)->Acc | Complementa el Acc                                                                  |
|                                       | Acc+1->Acc    | Incrementa Acc                                                                      |
| ALU (Registro F)                      | 0->F          | Pone a "0" el registro F                                                            |
|                                       | NOT(F)->F     | Complementa F                                                                       |

- **Codificación de las Instrucciones**

- Tamaño de las palabras en memoria => 12 bits.
- Repertorio de 16 instrucciones => 4 bits de operación.
- Memoria de 8 bits de direccionamiento => 256 palabras.
- Estructura de codificación:



- **Operандos y Direccionamiento de Memoria:**

- **Modo Implícito:** No se indica ningún operando, porque la propia instrucción ya indica sobre qué componente actuará (Ej. CRA).



- **Modo Inmediato:** La instrucción contiene en el campo de operando el valor directo codificado sobre el que se actúa (menor tamaño).



- **Direccionamiento directo:** La instrucción contiene codificada en el campo de operando una posición de memoria, que contiene el valor sobre el que se desea actuar.



- **Direccionamiento indirecto:** La instrucción contiene codificada en el campo de operando una posición de memoria que contiene la dirección de memoria del valor sobre el que se desea operar.



## 6.1. Computadora Mejorada: Ciclo de Búsqueda (FETCH)

Captar la siguiente instrucción, decodificarla y preparar el sistema para la captación de la siguiente instrucción, tras el ciclo de ejecución. Secuencia de Microoperaciones:

| Ciclo | Operación          | Explicación                                                                                                                                                            |
|-------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | PC->MAR            | Transfiere la dirección de memoria de la siguiente instrucción (PC) al MAR.                                                                                            |
| 2     | M->GPR<br>PC+1->PC | Leo el contenido de la memoria al que apunta MAR (que contiene la codificación de la siguiente instrucción). Incremento el PC para apuntar a la siguiente instrucción. |
| 3     | GPR(OP)->OPR       | Transfiero los 4 bits superiores de GPR (que contienen el campo de operación) al registro OPR para su decodificación                                                   |





## 6.2. Computadora Mejorada: Instrucciones

Instrucciones Monociclo sin Operando.

- **Instrucciones que coinciden con microoperaciones:**

- **CRA (Clear Accumulator) : 0 -> Acc.**



- **CTA (ComplementT Accumulator) : NOT(Acc) -> Acc.**



- **ITA (IncremenT Accumulator) : Acc+1 -> Acc.**



- **ROR (ROtation Right) : ROR F,Acc.**



- **ROL (ROtation Left) : ROL F,Acc.**



- **CRF (Clear “F” ) : 0 -> F.**



- **CTF (Complement “F” ) : NOT(F) ->F.**



- **SFZ** (Skip next instruction if “F” is Zero) :  $PC+1 \rightarrow PC$ , si  $F=0$ .



- **Instrucciones con Operando:**

- Instrucciones Aritméticas:

- **ADD d** (ADDition): Suma Directa con el Acumulador. Suma el contenido actual del acumulador con el valor que se encuentra en la dirección de memoria especificada en el campo de operando.

Secuencia de Microoperaciones:

| Ciclo | Operación                 | Explicación                                                                                                                                   |
|-------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | $GPR(AD) \rightarrow MAR$ | Transfiere la dirección de memoria donde está el valor desde el campo de operando (que se encuentra en los 8 bits inferiores del GPR) al MAR. |
| 2     | $M \rightarrow GPR$       | Lee desde la memoria la dirección que se encontraba en el campo de operando y el valor se deposita en GPR                                     |
| 3     | $GPR+Acc \rightarrow Acc$ | Sumamos el contenido de GPR (nuevo valor) con el contenido de Acc y lo dejamos en Acc.                                                        |





- **ADDI d (ADDition Indirect):** Suma Indirecta con el Acumulador. Suma el contenido actual del acumulador con el valor que se encuentra en la dirección de memoria especificada en el campo de operando.
- Secuencia de Microoperaciones:

| Ciclo | Operación    | Explicación                                                                                                                                                                                  |
|-------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | GPR(AD)->MAR | Transfiere la dirección de memoria donde está la dirección de memoria que almacena el valor desde el campo de operando (que se encuentra en los 8 bits inferiores del GPR) al MAR.           |
| 2     | M->GPR       | Lee desde la memoria la dirección que se encontraba en el campo de operando y la dirección de memoria se deposita en GPR                                                                     |
| 3     | GPR(AD)->MAR | Transfiere la nueva dirección de memoria donde está el valor desde el campo de operando (que se encuentra en los 8 bits inferiores del GPR) al MAR. (Los 4 bits superiores son descartables) |
| 4     | M->GPR       | Lee desde la memoria la dirección que se encontraba en el campo de operando y el valor se deposita en GPR                                                                                    |
| 5     | GPR+Acc->Acc | Sumamos el contenido de GPR (nuevo valor) con el contenido de Acc y lo dejamos en Acc.                                                                                                       |





- Instrucciones de Transferencia:
    - **STA d** (STore Accumulator): Almacenamiento Directo del Acumulador en Memoria. Almacena el contenido actual del acumulador en la dirección de memoria especificada en el campo de operando.
- Secuencia de Microoperaciones:

| Ciclo | Operación    | Explicación                                                                                                                                   |
|-------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | GPR(AD)->MAR | Transfiere la dirección de memoria donde está el valor desde el campo de operando (que se encuentra en los 8 bits inferiores del GPR) al MAR. |
| 2     | Acc->GPR     | Copia el valor almacenado en Acc al registro GPR                                                                                              |
| 3     | GPR->M       | Almacenamos el valor que hay en el GPR en la posición de memoria que se indica en MAR.                                                        |



- Instrucciones de Control de Flujo:

- **JMP d** (JuMP). Salto directo en el flujo de ejecución del programa. La siguiente instrucción que se ejecutará es la que se encuentra en la dirección de memoria especificada en el campo de operando.
- Secuencia de Microoperaciones:

| Ciclo | Operación   | Explicación                                                                                |
|-------|-------------|--------------------------------------------------------------------------------------------|
| 1     | GPR(AD)->PC | Transferir la posición de memoria indicada en los 8 bits menos significativos de GPR a PC. |



- **CSR d** (Call SubRoutine). Llamada a subrutina. Almacena la dirección de retorno (PC+1) en la posición de memoria indicada en el campo de operando (d) y bifurca a la posición de memoria siguiente a ésta (d+1). Secuencia de Microoperaciones:

| Ciclo | Operación                  | Explicación                                                                                                                                                                        |
|-------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | GPR(AD)->MAR               | Transfiere la dirección de memoria donde está la dirección de memoria que almacena el valor desde el campo de operando (que se encuentra en los 8 bits inferiores del GPR) al MAR. |
| 2     | GPR(AD)->PC<br>PC->GPR(AD) | Intercambia PC y los 8 bits menos significativos de GPR. (Los 4 bits superiores de GPR pasan a valer 0).                                                                           |
| 3     | GPR(AD)->M                 | Transfiere el GPR a memoria. En GPR está el PC incrementado, que será la dirección de retorno, y se almacena en la dirección de memoria indicada en el operando.                   |
| 4     | PC+1->PC                   | Se incrementa en 1 el PC para ir a la siguiente dirección de memoria de la indicada en el campo del operando. (Se podría hacer simultáneamente en el ciclo anterior).              |





- **JMPI d (JuMP Indirect ).** Salto indirecto en el flujo de ejecución del programa. La siguiente instrucción que se ejecutará es la que se encuentra en la dirección de memoria cuya dirección de memoria viene especificada en el campo de operando.

Secuencia de Microoperaciones:

| Ciclo | Operación    | Explicación                                                                                                                              |
|-------|--------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | GPR(AD)->MAR | Transmitir la dirección indicada en el campo de operando al MAR.                                                                         |
| 2     | M->GPR(AD)   | Leer el contenido de memoria al que apunta el MAR (que contiene la posición de memoria de la siguiente instrucción que se va a ejecutar) |
| 3     | GPR(AD)->PC  | Transferir la posición de memoria indicada en los 8 bits menos significativos de GPR a PC.                                               |



- Instrucciones Mixtas (Aritmética/Transferencia/Control de Flujo):
    - **ISZ d** (Increment memory and Skip next instruction if Zero).
   
Incrementa el contenido de una posición de memoria y si, al incrementar, dicho valor es 0, se salta la siguiente instrucción.
- Secuencia de Microoperaciones:

| Ciclo | Operación         | Explicación                                                                                                                                                                        |
|-------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | GPR(AD)->MAR      | Transfiere la dirección de memoria donde está la dirección de memoria que almacena el valor desde el campo de operando (que se encuentra en los 8 bits inferiores del GPR) al MAR. |
| 2     | M->GPR            | Lee desde la memoria la dirección que se encontraba en el campo de operando y la dirección de memoria se deposita en GPR                                                           |
| 3     | GPR+1->GPR        | Incrementamos GPR                                                                                                                                                                  |
| 4     | GPR->M            | Almacenamos el valor GPR incrementado en la misma posición de memoria.                                                                                                             |
| 5     | PC+1->PC (si Z=1) | Si GPR = 0, entonces Z=1, e incrementamos en ese caso PC; en caso contrario, no hacemos nada.                                                                                      |





- **Otras Instrucciones:**
  - HLT (HaLT ).

### 6.3. Computadora Mejorada: Programas

**Programa que implementa 2+3-5 y el resultado se almacenará en memoria en una variable “resultado”.**

- Se definirán 4 variables: op1 = 2; op2 = 3; op3 = 5; resultado=0;

| Dirección | Etiqueta  | Instrucción Simbólica/ | Instrucción | Explicación                                                       |
|-----------|-----------|------------------------|-------------|-------------------------------------------------------------------|
| 0         |           | CRA                    | CRA         | Limpiamos el Acc (Acc = 0)                                        |
| 1         |           | ADD op3                | ADD A       | Cargamos el valor 5 (variable op3, dirección de memoria A)        |
| 2         |           | CTA                    | CTA         | Complementamos (con estas 2 instrucciones hacemos el)             |
| 3         |           | ITA                    | ITA         | Incrementamos (complemento a 2, el negativo del 5)                |
| 4         |           | ADD op1                | ADD 8       | Sumamos el valor 2 (variable op1, dirección de mem. 8)            |
| 5         |           | ADD op2                | ADD 9       | Sumamos el valor 3 (variable op2, dirección de mem. 9)            |
| 6         |           | STA resultado          | STA B       | Almacena el resultado en la variable “resultado” (dir. memoria B) |
| 7         |           | HLT                    | HLT         | Para el programa                                                  |
| 8         | op1       | 0002                   |             |                                                                   |
| 9         | op2       | 0003                   |             |                                                                   |
| A         | op3       | 0005                   |             |                                                                   |
| B         | resultado | 0000                   |             |                                                                   |

**Programa que calcula la suma de un vector de 3 valores, el resultado final en el Acumulador.**

- Variables: vector = 1,2,3; indice = 3; puntero = &(vector).

| Dirección | Etiqueta | Instrucción Simbólica/ | Instrucción | Explicación                                                         |
|-----------|----------|------------------------|-------------|---------------------------------------------------------------------|
| 0         |          | CRA                    | CRA         | Limpiamos el Acc (Acc = 0)                                          |
| 1         |          | ADD indice             | ADD E       | Cargamos el valor 3 (variable indice, posición Eh)                  |
| 2         |          | CTA                    | CTA         | Complementamos (con estas 2 instrucciones hacemos el)               |
| 3         |          | ITA                    | ITA         | Incrementamos (complemento a 2, el negativo del 3)                  |
| 4         |          | STA indice             | STA E       | Guardamos el 3 en negativo en indice (posición Eh)                  |
| 5         |          | CRA                    | CRA         | Limpiamos el Acc (Acc = 0)                                          |
| 6         | bucle    | ADDI puntero           | ADDI F      | Sumamos el valor al que apunta puntero (posición Fh)                |
| 7         |          | ISZ puntero            | ISZ F       | Incremento el puntero, apunto al siguiente valor del vector.        |
| 8         |          | ISZ indice             | ISZ E       | Incremento el indice; si es cero, me salto la siguiente instrucción |
| 9         |          | JMP bucle              | JMP 6       | Saltar a procesar el siguiente elemento (posición 6h)               |
| A         | fin      | HLT                    | HLT         | Para el programa                                                    |
| B         | vector   | 1                      |             |                                                                     |
| C         |          | 2                      |             |                                                                     |
| D         |          | 3                      |             |                                                                     |
| E         | indice   | 3                      |             |                                                                     |
| F         | puntero  | B                      |             |                                                                     |

### 6.4. Ampliaciones en la Computadora Mejorada

**Limitaciones:**

- Número muy limitado de microoperaciones.
- Número limitado de instrucciones.
- No tiene Pila.
- Registros adicionales y con mayor funcionalidad.
- Registros de mayor tamaño.
- Más bits de estatus.
- Unidades de control con contadores de bucle.

### 6.5. Pila

**Implementación sistema LIFO (Last In, First Out):**

- Utilización de un registro que almacena la dirección de memoria donde se colocó el último valor almacenado. (Apunta a una dirección ocupada).
- La memoria pila se utiliza en pasos descendentes (desde las posiciones más altas de la memoria hacia las más bajas de la memoria) => Evitar colisionar con el espacio de programa, que suele estar en las direcciones bajas de la memoria.

### Registro SP:

- SP se utiliza como registro similar al PC, para almacenar la dirección de memoria del último dato introducido en la memoria pila.
- Para acceder a la memoria pila hay que pasar el contenido de SP al MAR: SP->MAR.
- SP puede ser incrementado o decrementado.



## 6.6. Push

Introducir un elemento en la pila (Push):

- Inicialmente SP “apunta” a la última posición de memoria ocupada.



- Decrementamos la posición (“apuntando” a una dirección “libre”).



- Almacenamos en la nueva posición “libre” el elemento de GPR, pasando SP a apuntar ahora a una posición “ocupada”.



## 6.7. Pop

Sacar el último elemento de la pila (Pop):

- Inicialmente SP “apunta” a la última posición de memoria ocupada.



- Leemos de la posición de memoria a la que apunta SP, guardamos el valor en GPR. Dicha posición, pasa a estar “libre”.



- Incrementamos la posición del SP (“apuntando” “ocupada”).



## 6.8. Unidad de Control con Contador de Bucles

Para la ejecución repetitiva de microoperaciones, se introduce un contador SC (Sequence Counter).

- Microoperaciones:
  - “SC-1->SC”: Decrementar el contador.
  - “Load SC”: Carga paralelo.
- Salidas:
  - “ZSC” : Es 1 cuando el contador alcanza 0. En otro caso, vale 0.
- Microprogramación:
  - El valor de carga paralelo se introduce solapado en el campo de dirección de bifurcación.
- Cableado:
  - El valor de carga paralelo se introduce cableando el valor bit a bit.