Modos de Direccionamiento 1

MODOS DE DIRECCIONAMIENTO. Son los distintos modos de acceder a los datos en memoria por parte del procesador. Antes de

Views 87 Downloads 0 File size 57KB

Report DMCA / Copyright

DOWNLOAD FILE

Recommend stories

Citation preview

MODOS DE DIRECCIONAMIENTO. Son los distintos modos de acceder a los datos en memoria por parte del procesador. Antes de ver los modos de direccionamiento, echaremos un vistazo a la sintaxis general de las instrucciones, ya que pondremos alguna en los ejemplos: INSTRUCCIÓN

DESTINO, FUENTE

Donde destino indica dónde se deja el resultado de la operación en la que pueden participar (según casos) FUENTE e incluso el propio DESTINO. Hay instrucciones, sin embargo, que sólo tienen un operando, como la siguiente, e incluso ninguno: INSTRUCCIÓN

DESTINO

Como ejemplos, aunque no hemos visto aún las instrucciones utilizaremos un par de ellas:  

Copia o movimiento de datos (MOV) y Suma (ADD).

ORGANIZACIÓN DE DIRECCIONES: SEGMENTACIÓN. Como ya sabemos, los microprocesadores 8086 y compatibles poseen registros de un tamaño máximo de 16 bits que direccionarían hasta 64K; en cambio, la dirección se compone de 20 bits con capacidad para 1Mb, hay por tanto que recurrir a algún artificio para direccionar toda la memoria. Dicho artificio consiste en la segmentación: se trata de dividir la memoria en grupos de 64K. Cada grupo se asocia con un registro de segmento; el desplazamiento (offset) dentro de ese segmento lo proporciona otro registro de 16 bits. La dirección absoluta se calcula multiplicando por 16 el valor del registro de segmento y sumando el offset, obteniéndose una dirección efectiva de 20 bits. Esto equivale a concebir el mecanismo de generación de la dirección absoluta, como si se tratase de que los registros de segmento tuvieran 4 bits a 0 (imaginarios) a la derecha antes de sumarles el desplazamiento:

dirección = segmento * 16 + offset En la práctica, una dirección se indica con la notación (SEGMENTO: OFFSET); además, una misma dirección puede expresarse de más de una manera: por ejemplo, 3D00h:0300h es equivalente a 3D30:0000h. Es importante resaltar que no se puede acceder a más de 64 Kb en un segmento de datos. Por ello, en los procesadores 386 y superiores no se deben emplear registros de 32 bit para generar direcciones (bajo DOS), aunque para los cálculos pueden ser interesantes (no obstante, sí sería posible configurar estos procesadores para poder direccionar más memoria bajo DOS con los registros de 32 bits, aunque no resulta por lo general práctico).

MODOS DE DIRECCIONAMIENTO Una instrucción de 8088/8086 no solo contienen información sobre la operación particular a realizar, sino que también incluye las especificaciones para el tipo de operando a manipular, así como también la posición de estos operandos. El microprocesador determina el modo de direccionamiento que es aludido por la sintaxis de la instrucción. Son siete los modos mas importantes de direccionamiento.       

Direccionamiento inmediato Direccionamiento de registros Direccionamiento directo Direccionamiento indirecto de registros Direccionamiento relativo a base Direccionamiento indexado directo Direccionamiento indexado a base

DIRECCIONAMIENTO INMEDIATO El operando es una constante situada detrás del código de la instrucción. Sin embargo, como registro destino no se puede indicar uno de segmento (habrá que utilizar uno de datos como paso intermedio). ADD AX,0fffh El número hexadecimal 0fffh es la constante numérica que en el direccionamiento inmediato se le sumará al registro AX.

Al trabajar con ensambladores, se pueden definir símbolos constantes (ojo, no variables) y es más intuitivo: Dato EQU 0fffh; MOV AX, Dato

símbolo constante

Si se referencia a la dirección de memoria de una variable de la siguiente forma, también se trata de un caso de direccionamiento inmediato: Dato

DW 0fffh; ahora es una variable MOV AX,OFFSET dato ; AX = "dirección de memoria" de dato

Porque hay que tener en cuenta que cuando traduzcamos a números el símbolo podría quedar: 17F3:0A11 DW FFF MOV AX,0A11

DIRECCIONAMIENTO DE REGISTROS Los operandos, necesariamente de igual tamaño, están contenidos en los registros indicados en la instrucción: MOV DX,AX MOV AH,AL Este puede ser un valor de 8 o 16 bits, el microprocesador interpreta la longitud del operando por el nombre del registro.

DIRECCIONAMIENTO DIRECTO El operando está situado en la dirección indicada en la instrucción, relativa al segmento que se trate: MOV AX,[57D1h] MOV AX,ES:[429Ch]

Esta sintaxis (quitando la 'h' de hexadecimal) sería la que admite el programa DEBUG (realmente habría que poner, en el segundo caso, ES: en una línea y el MOV en otra). Al trabajar con ensambladores, las variables en memoria se pueden referenciar con etiquetas simbólicas: MOV AX,dato MOV AX,ES:dato dato

DW 1234h

; variable del programa

En el primer ejemplo se transfiere a AX el valor contenido en la dirección apuntada por la etiqueta dato sobre el segmento de datos (DS) que se asume por defecto; en el segundo ejemplo se indica de forma explícita el segmento tratándose del segmento ES. La dirección efectiva se calcula de la forma ya vista con anterioridad: Registro de 8segmento * 16 + desplazamiento_de_dato (este desplazamiento depende de la posición al ensamblar el programa).

DIRECCIONAMIENTO INDIRECTO DE REGISTROS: El operando se encuentra en una dirección señalada por un registro de segmento*16 más un registro base (BX/BP) o índice (SI/DI). (Nota: BP actúa por defecto con SS). MOV AX,[BP] MOV ES:[DI],AX

; AX = [SS*16+BP] ; [ES*16+DI] = AX

RELATIVO DE BASE La dirección de un operando se obtiene de la suma del numero y el contenido de un registro base (el BX o el BP), relativo al segmento seleccionado. El modo relativo a base es mas usado frecuentemente para acceder a estructuras de datos complejas.

INDIRECTO INDEXADO DIRECTO El operando se encuentra en una dirección determinada por la suma de un registro de segmento*16, un registro de índice, SI o DI y un desplazamiento de 8 ó 16 bits. Ejemplos: MOV AX,[DI+DESP] ADD [SI+DESP],BX

ó ó

MOV AX,desp[DI] ADD desp[SI],BX

INDIRECTO CON BASE E ÍNDICE O INDEXADO A BASE: El operando se encuentra en una dirección especificada por la suma de un registro de segmento*16, uno de base, uno de índice y opcionalmente un desplazamiento de 8 ó 16 bits: MOV AX,ES:[BX+DI+DESP] MOV CS:[BX+SI+DESP],CX

ó ó

MOV AX,ES:desp[BX][DI] MOV CS:desp[BX][SI],CX

Combinaciones de registros de segmento y desplazamiento. Como se ve en los modos de direccionamiento, hay casos en los que se indica explícitamente el registro de segmento a usar para acceder a los datos. Existen unos segmentos asociados por defecto a los registros de desplazamiento (IP, SP, BP, BX, DI, SI); sólo es necesario declarar el segmento cuando no coincide con el asignado por defecto. En ese caso, el ensamblador genera un byte adicional (a modo de prefijo) para indicar cuál es el segmento referenciado. La siguiente tabla relaciona las posibles combinaciones de los registros de segmento y los de desplazamiento: CS IP Sí SP No BP con prefijo BX con prefijo SI con prefijo DI con prefijo

SS No Sí por defecto con prefijo con prefijo con prefijo

DS No No con prefijo por defecto por defecto por defecto

ES No No con prefijo con prefijo con prefijo con prefijo(1)

(1) También por defecto en el manejo de cadenas.

Los 386 y superiores admiten otros modos de direccionamiento más sofisticados, que se verán en el próximo capítulo, después de conocer todas las instrucciones del 8086. Por ahora, con todos estos modos se puede considerar que hay más que suficiente. De hecho, algunos se utilizan en muy contadas ocasiones.

Instrucciones de 8086 y 8088

INSTRUCCIONES DE TRANSFERENCIA DE DATOS (No afectan flags) MOV dest,src Copia el contenido del operando fuente (src) en el destino (dest). Operación: dest