Lenguaje ensamblador pendiente

download Lenguaje ensamblador pendiente

of 7

description

automatas

Transcript of Lenguaje ensamblador pendiente

Lenguaje ensamblador Como ocupar registros en lenguaje ensamblador:

MODOS DE DIRECCIONAMIENTO Y GENERACIN DEL CDIGO OBJETO

Generacin de la direccin de la instruccin.

Todos los registros internos del 8086/8088 son de 16 bits. El bus de direccin es de 20 bits, por lo que se usa ms de un registro interno para generar la direccin de 20 bits.

Los 2 registros usados para la direccin de la instruccin son el IP y el CS. Se combinan en una forma especial para generar la direccin de 20 bits.

Direccin de 20 bits = 1610 * CS + IP

Por ejemplo: Si los registros CS e IP contienen los valores:

CS = 1000HIP = 0414 H

La direccin de 20 bits es:

1610 * 1000H + 0414H = 10000H + 0414H = 10414H

Esta es la direccin en memoria desde la cual la nueva instruccin debe buscarse.

Al registro IP se le refiere como offset, el registro CS * 1610 apunta a la direccin de inicio o segmento en memoria desde el cual se calcula el offset. La Figura A muestra grficamente cmo se calcula la direccin de 20 bits.

Bus de direccin Del sistema+Direccin de 20 bits

FIGURA A. Clculo de la direccin de 20 bits

Cada direccin generada por el 8086/8088 usa uno de los 4 registros de segmento. Este registro de segmento es recorrido 4 bits hacia la izquierda antes de ser sumado al offset.

La instruccin del CPU especifica cules registros internos se usan para generar el offset.

Vamos a ver los diferentes modos de direccionamiento tomando como ejemplo la instruccin MOV.

Instruccin MOV

Transfiere un byte desde el operando fuente al operando destino. Tiene el siguiente formato:

MOVdestino, fuente

Direccionamiento Inmediato

El operando fuente aparece en la instruccin. Un ejemplo, es el que mueve un valor constante a un registro interno.

MOVAX, 568

Direccionamiento a Registro

Indica que el operando a ser usado est contenido en uno de los registros internos de propsito general del CPU. En el caso de los registros AX, BX, CX o DX los registros pueden ser de 8 a 16 bits

Ejemplos:

MOVAX, BX; AX BX

MOVAL, BL; AL BL

Cuando usamos direccionamiento a registro, el CPU realiza las operaciones internamente, es decir, no se genera direccin de 20 bits para especificar el operando fuente.

Direccionamiento Directo

Especifica en la instruccin la localidad de memoria que contiene al operando. En este tipo de direccionamiento, se forma una direccin de 20 bits.

Ejemplo:

MOVCX, COUNT

El valor de COUNT es una constante. Es usada como el valor offset en el clculo de ladireccin de 20 bits

El 8086/8088 siempre usa un registro de segmento cuando calcula una direccin fsica.

Cul registro se debe usar para esta instruccin? Respuesta:DS

En la Figura B, se muestra el clculo de la direccin desde la cual se tomar el dato que se carga en CX.

DIRECCIN DEL SISTEMA DE 20 BITSDS*16COUNT = CONSTANTE+

Cuando accedamos datos, el registro DS se usa con un offfset para calcular la direccin de 20 bits, ste es el segmento por omisin. Puede ser invalidado por usar un prefijo de segmento en la instruccin.Ejemplo:

MOVCX, ES: COUNT

FIGURA B. Uso del segmento de datos y una constante para desplazamiento

Este es el segmento por omisin que se usa. Sin embargo, cualquiera de los 4 segmentos puede usarse. Esto se efecta especificando el registro apropiado en la instruccin.

Por ejemplo, suponga que deseamos usar el registro ES en lugar del DS:

MOVCX, ES: COUNT

Bibliografawww.ittux.edu.mx/sites/.../MICROCOMPUTADORAS_AL_DETALLE.p.Registros de la CPU [1]https://es.wikibooks.org/wiki/Programaci%C3%B3n_en_lenguaje_ensamblador/Primeros_conceptos