Ensamblador Del Procesador 8086
Enviado por manuel_w • 2 de Junio de 2013 • 3.828 Palabras (16 Páginas) • 313 Visitas
Algunas nociones sobre ensamblador del 8086
El 8086 es un procesador de 16 bits. Esto significa que trabaja con registros internos de este tamaño y que la amplitud del bus de datos de también de 16 bits. Sin embargo todas las instrucciones que usaremos aquí serán todavía funcionales cuando queramos adaptarnos a generaciones posteriores de procesadores, como el 80386, 486, Pentium, con tamaños de palabra mayores.
Conceptos de espacio de almacenamiento de datos:
Palabra 16 bits, Doble palabra, cuádruple palabra.
Almacenamiento: primero el byte menos significativo y luego el más significativo (en sentido creciente de las direcciones de memoria)
Página 256 bytes
Segmento 64K bytes
No es necesario que las direcciones se ajusten a palabra (ajuste de frontera) porque el procesador genera automáticamente las lecturas de memoria que necesite. Sin embargo sí es recomendable.
Espacio de memoria:
Decimos que un procesador trabaja con un tamaño de palabra N, porque sus registros tienen tamaño N y generalmente las transacciones de datos se hacen en bloques de N bits. Pese a esto el bus que comunica al procesador con el entorno no tiene que corresponder a estas restricciones. Generalmente el bus de datos va a seguir siendo de tamaño N, aunque puede ocurrir que su tamaño sea menor y una transacción haya que realizarla en dos fases (8088). En cuanto al bus de direcciones no está restringido a N líneas, de hecho interesa que sea lo mayor posible para que abarque el mayor espacio de direcciones posible.
La memoria en el 8086 está dividida en segmentos. Como el tamaño de los registros es de 16 bits, el mayor rango de direcciones que podemos señalar con ellos es de 64K bytes. Sin embargo el bus de direcciones tiene veinte bits abarcando un espacio de direcciones de 1M bytes. El modo de señalar una dirección entonces consiste en fijar una posición de memoria llamada base e indicar un desplazamiento a partir de esa dirección. Este desplazamiento puede ser como máximo de 64K bytes.
Así toda dirección tendrá dos partes, una que indica la dirección base y otra que indica el desplazamiento (siempre positivo) respecto a esa dirección. Los ejemplos que siguen corresponden todos a la dirección 1050h:
105:0=100:50=10:F50=1:1040=0:1050
A la izquierda del ':' figura el segmento y a la derecha el desplazamiento. El segmento (un valor de 16 bits) no es exactamente la dirección base (que ha de tener 20 bits), para ello hay que desplazarlo todavía 4 bits a la izquierda.(recuérdese que estamos trabajando en notación hexadecimal)
1050 + 0=1000+50=100+F50=10+1040=0+1050
Cuando un programa se va a ejecutar, primero tiene que fijar sus segmentos. Un programa trabaja con cuatro segmentos simultáneamente: el segmento de código, dos segmentos de datos y un segmento de pila. Estos segmentos de memoria, pueden ser disjuntos, o tener parcial o aún completo solapamiento. Las direcciones base de segmentos son siempre múltiplos de 16. Así, por ejemplo, el segmento 0 y el segmento 1 se solapan parcialmente, pero cada uno de ellos tiene dieciséis bytes particulares.
Recursos del procesador:
Registros.
Para poder programar en un procesador particular debemos conocer primero el conjunto de recursos que el procesador pone a disposición del programador: registros, interrupciones, espacio de memoria y entrada salida. Y luego el conjunto de instrucciones que nos permiten manipularlos para lograr nuestros fines.
En primer lugar se nos ofrecen cuatro registros de 16 bits de propósito general, aunque cada uno tiene asignadas labores más especializadas:
AX: Acumulador
BX: Base
CX: Contador
DX: Dato
Si se trabaja con datos de ocho bits, estos registros pueden ser vistos por las instrucciones como ocho registros de un byte cada uno
AH, AL
BH, BL
CH, CL
DH, DL
SP,BP
SI,DI
Se pueden utilizar como propósito general, aunque tienen una funcionalidad más definida. Son llamados registros de índice y sirven para mediatizar en accesos a memoria. SP y BP se utilizan en accesos al segmento de pila y SI y DI, en los accesos a segmentos de datos.
Para mantener la referencia a los segmentos con los que trabaja un proceso durante su ejecución existen cuatro registros:
CS: mantiene el segmento de código
DS: segmento de datos
ES: segmento de datos extra
SS: segmento de stack
Estos cuatro registros contienen la referencia al segmento correspondiente (desplazándolos cuatro bits a la izquierda la dirección base del segmento) Cualquier referencia a memoria utiliza estos registros de forma automática, aunque el usuario, puede especificar concretamente qué registros desea usar en transacciones determinadas.
CS:IP
DS:BX,SI,DI
SS:SP,BP
ES:BX,SI,DI
Flags, IP
El registro IP contiene la siguiente instrucción a ejecutar y el usuario no tiene ningún acceso a este registro, sin embargo con instrucciones de bifurcación está modificándolo implícitamente.
En cuanto al registro de flags, contiene una serie de señales que nos indican el estado del procesador en cualquier momento. Estas señales o banderas nos sirven para dirigir el control del proceso a partir de sucesos previos. Las banderas que se nos ofrecen son las siguientes:
de estado.
CF: de acarreo.
OF: de overflow
ZF: de resultado cero
SF: de resultado negativo
PF: paridad del resultado
AF: auxiliar (corrección en lógica decimal BCD)
de control:
DF: de dirección (en instrucciones múltiples)
IF: de interrupciones
TF: paso a paso.
Interrupciones:
El sistema de interrupciones para un programador consiste en un conjunto de posiciones de memoria comenzando en la dirección absoluta de memoria 0, que contienen, cada dos palabras, una dirección de salto a una rutina de atención a la interrupción. (la dirección 0 corresponde a la interrupción 0, la dirección 2 a la interrupción 1, etc). Cuando se invoca una interrupción, sea física, por algún dispositivo, o lógica, algún error de ejecución o invocación de programa, el mecanismo de atención toma de la dirección correspondiente que le indica el número de interrupción, la dirección destino del salto y obtiene de allí la siguiente instrucción a ejecutar. Para crear una rutina de atención a determinada interrupción, el programador tiene
...