Sunteți pe pagina 1din 8

TAREA DE ARQUITECTURA DE COMPUTADORAS

Registro de bandera del 8086


Se utiliza para indicar al programa ciertas condiciones que han tenido lugar como resultado de la ltima operacin realizada. Cada uno de los bits del registro de banderas marca si se ha producido una de estas condiciones: con un valor 1 si se produjo o 0 si no tuvo lugar. Es por ello que a cada uno de los bits que conforman este registro se le llama bandera o en ingls Flag.

De este registro slo usaremos los bits 0, 2, 4, 6, 7, 8, 9, 10 y 11. Los bits 0,2, 4, 6,7 y 11son indicadores de condicin que reflejan los resultados de operaciones normalmente aritmticas o de comparacin en nuestro programa. Los bits 8, 9 y 10 son indicadores de control en los que puedo definir el funcionamiento del microprocesador. Estos flags pueden ser comprobados por instrucciones de salto condicional, lo que permite variar el flujo secuencial del programa segn se activen o no dichos flags. Las banderas contenidas en este registro son las siguientes: INDICADORES DE CONDICIN CF (Carry Flag) bandera de acarreo: Se pone a 1 cuando tras una operacin tengo acarreo; puede referirse a operaciones de 8 o 16 bits. PF (Parity Flag) bandera de paridad: Se pone a 1 cuando tras una operacin tengo un nmero par de 1 en el resultado. AF (Auxiliary Flag) bandera auxiliar: Se pone a 1 si se produce un acarreo entre los bits 7 y 8 trabajando con 16 bits o entre los bits 3 y 4 trabajando con 8 bits. Se utiliza para ajustes decimales en operaciones en BCD. ZF(Zero Flag) bandera de cero: Se pone a 1 cuando el resultado de la ltima operacin es cero, o cuando al comparar dos cadenas el resultado es de igualdad. SF (Sign Flag) bandera de signo: Se pone a 1 si el resultado es negativo, o cuando al comparar dos cadenas, el resultado es de no igualdad. OF (Overflow flag) bandera de desbordamiento: Se pone a 1 cuando el resultado de una operacin cambia el bit de signo de manera incorrecta, es decir, cuando el resultado no se puede almacenar en el destino.

TAREA DE ARQUITECTURA DE COMPUTADORAS INDICADORES DE CONTROL TF (Trace Flag) bandera de paso a paso: Cuando est bandera est a 1 obliga al 8086 a trabajar paso a paso generando una interrupcin interna tras la ejecucin de cada instruccin, es muy til para la depuracin de programas. IF (Interrupt Flag) bandera de interrupciones: Si se pone a 1 permite a la CPU que atienda las peticiones externas de interrupciones. DF (Direction Flag) bandera de direccin: Se utiliza para operaciones con cadenas. Si vale 1 la cadena se procesa de derecha a izquierda, es decir, de la direccin ms alta a la ms baja. Si vale 0 se procesa de izquierda a derecha.

Registro de bandera del 80386


Es un registro de 32 bits llamado EFlags. Los bits definidos y campos de bits controlan ciertas operaciones e indican el estado del 80386. Los 16 bits menos significativos (bits 15-0) llevan el nombre de Flags, que es ms til cuando se ejecuta cdigo de 8086 y 80286. La descripcin de los indicadores es la siguiente: VM (Virtual 8086 Mode, bit 17): Este bit provee el modo 8086 virtual dentro del modo protegido. Si se pone a 1 cuando el 80386 est en modo protegido, entrar al modo 8086 virtual, manejando los segmentos como lo hace el 8086, pero generando una excepcin 13 (Violacin general de proteccin) en instrucciones privilegiadas (aqullas que slo se pueden ejecutar en modo real o en el anillo 0). El bit VM slo puede ponerse a 1 en modo protegido mediante la instruccin IRET (ejecutando en nivel de privilegio cero) y por cambios de tarea en cualquier anillo. El bit VM no cambia con la instruccin POPFD. La instruccin PUSHFD siempre pone un cero en el bit correspondiente en la pila, aunque el modo 8086 virtual est activado. La imagen de EFlags puesta en la pila durante el procesamiento de una interrupcin o salvada en un Task State Segment durante cambios de tarea, contendr un uno en el bit 17 si el cdigo interrumpido estaba ejecutando una tarea tipo 8086 virtual. RF (Resume Flag, bit 16): Este indicador se utiliza junto con los registros de depuracin. Se verifica en las fronteras de instrucciones antes del procesamiento de los puntos de parada (breakpoints). Cuando RF vale 1, hace que se ignoren las faltas (hechos que ocasionan una excepcin) de depuracin. RF se pone automticamente a cero luego de ejecutar correctamente cualquier instruccin (no se sealan faltas) excepto las instrucciones IRET y POPF y en los cambios de tarea causados por la ejecucin de JMP, CALL e INT. Estas instrucciones ponen RF al valor especificado por la imagen almacenada en memoria. Por ejemplo, al final de la rutina de servicio de los puntos de parada, la instruccin IRET puede extraer de la pila una imagen de EFlags que tiene RF = 1 y resumir la ejecucin del programa en la direccin del punto de parada sin generar otra falta de punto de parada en el mismo lugar. NT (Nested Task, bit 14): Este indicador se aplica al modo protegido. NT se pone a uno para indicar que la ejecucin de la tarea est anidada dentro de otra tarea. Si est a uno, indica que el segmento de estado de la tarea (TSS) de la tarea anidada tiene un puntero vlido al TSS de la tarea previa. Este bit se pone a cero o uno mediante transferencias de

TAREA DE ARQUITECTURA DE COMPUTADORAS control a otras tareas. La instruccin IRET verifica el valor de NT para determinar si debe realizar un retorno dentro de la misma tarea o si debe hacer un cambio de tarea. Un POPF o IRET afectar el valor de este indicador de acuerdo a la imagen que estaba en la pila, en cualquier nivel de privilegio. IOPL (Input/Output Privilege Level, bits 13-12): Este campo de dos bits se aplica al modo protegido. IOPL indica el CPL (Current Privilege Level) numricamente mximo (esto es, con menor nivel de privilegio) permitido para realizar instrucciones de entrada/salida sin generar una excepcin 13 (Violacin general de proteccin) o consultar el mapa de bits de permiso de E/S (este mapa est ubicado en el segmento de estado de tarea (TSS) con el nuevo formato que provee el 80386). Adems indica el mximo valor de CPL que permite el cambio del indicador IF (indicador de habilitacin del pin INTR) cuando se ejecuta POPF e IRET. Estas dos ltimas instrucciones slo pueden alterar IOPL cuando CPL = 0. Los cambios de tarea siempre alteran el campo IOPL, cuando la nueva imagen de los indicadores se carga desde el TSS de la nueva tarea. OF (Overflow flag, bit 11): Si vale 1, hubo un desborde en una operacin aritmtica con signo, esto es, un dgito significativo se perdi debido a que tamao del resultado es mayor que el tamao del destino. DF (Direction Flag, bit 10): Define si ESI y/o EDI se autoincrementan (DF = 0) o autodecrementan (DF = 1) durante instrucciones de cadena. IF (INTR enable Flag, bit 9): Si vale 1, permite el reconocimiento de interrupciones externas sealadas en el pin INTR. Cuando vale cero, las interrupciones externas sealadas en el pin INTR no se reconocen. IOPL indica el mximo valor de CPL que permite la alteracin del indicador IF cuando se ponen nuevos valores en EFlags desde la pila. TF (Trap enable Flag, bit 8): Controla la generacin de la excepcin 1 cuando se ejecuta cdigo paso a paso. Cuando TF = 1, el 80386 genera una excepcin 1 despus que se ejecuta la instruccin en curso. Cuando TF = 0, la excepcin 1 slo puede ocurrir como resultado de las direcciones de punto de parada cargadas en los registros de depuracin (DR0-DR3). SF (Sign Flag, bit 7): Se pone a 1 si el bit ms significativo del resultado de una operacin aritmtica o lgica vale 1 y se pone a cero en caso contrario. Para operaciones de 8, 16, 32 bits, el indicador SF refleja el estado de los bits 7, 15 y 31 respectivamente. ZF (Zero Flag, bit 6): Se pone a 1 si todos los bits del resultado valen cero, en caso contrario se pone a cero. AF (Auxiliary carry Flag, bit 4): Se usa para simplificar la adicin y sustraccin de cantidades BCD empaquetados. AF se pone a 1 si hubo un prstamo o acarreo del bit 3 al 4. De otra manera el indicador se pone a cero. PF (Parity Flag, bit 2): se pone a uno si los ocho bits menos significativos del resultado tienen un nmero par de unos (paridad par), y se pone a cero en caso de paridad impar (cantidad impar de unos). El indicador PF es funcin de los ocho bits menos significativos del resultado, independientemente del tamao de las operaciones. CF (Carry Flag, bit 0): Se pone a uno si hubo arrastre (suma) o prstamo (resta) del bit ms significativo del resultado.

TAREA DE ARQUITECTURA DE COMPUTADORAS

TAREA DE ARQUITECTURA DE COMPUTADORAS

REGISTROS DEL PROCESADOR


Los registros del procesador se emplean para controlar instrucciones en ejecucin, manejar direccionamiento de memoria y proporcionar capacidad aritmtica. Los registros son direccionables por medio de un nombre. Los bits por convencin, se numeran de derecha a izquierda, como en: ... 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Los registros internos del procesador se pueden clasificar en 6 tipos diferentes Registros de segmento Registros de propsito general Registros de apuntadores Registros de banderas Registros de Puntero de instruccin Registros de Pila

a) Registros de segmento Un registro de segmento tiene 16 bits de longitud y facilita un rea de memoria para direccionamiento conocida como el segmento actual. Registro CS. El DOS almacena la direccin inicial del segmento de cdigo de un programa en el registro CS. Esta direccin de segmento, ms un valor de desplazamiento en el registro apuntador de instruccin (IP), indica la direccin de una instruccin que es buscada para su ejecucin. Registro DS. La direccin inicial de un segmento de datos de programa es almacenada en el registro DS. En trminos sencillos, esta direccin, ms un valor de desplazamiento en una instruccin, genera una referencia a la localidad de un byte especifico en el segmento de datos. Registro SS. El registro SS permite la colocacin en memoria de una pila, para almacenamiento temporal de direcciones y datos. El DOS almacena la direccin de inicio del segmento de pila de un programa en el registro SS. Esta direccin de segmento, ms un valor de desplazamiento en el registro del apuntador de pila (SP), indica la palabra actual en la pila que est siendo direccionada. Registros ES. Algunas operaciones con cadenas de caracteres (datos de caracteres) utilizan el registro extra de segmento para manejar el direccionamiento de memoria. En este contexto, el registro ES est asociado con el registro DI (ndice). Un programa que requiere el uso del registro ES puede inicializarlo con una direccin de segmento apropiada. Registros FS y GS. Son registros extra de segmento en los procesadores 80386 y posteriores.

TAREA DE ARQUITECTURA DE COMPUTADORAS b) Registros de propsito general. Los registros de propsito general AX, BX, CX y DX son los caballos de batalla del sistema. Son nicos en el sentido de que se puede direccionarlos como una palabra o como una parte de un byte. El ltimo byte de la izquierda es la parte "alta", y el ltimo byte de la derecha es la parte "baja". Por ejemplo, el registro CX consta de una parte CH (alta) y una parte Cl (baja), y usted puede referirse a cualquier parte por su nombre. Registro AX. El registro AX, el acumulador principal, es utilizado para operaciones que implican entrada/salida y la mayor parte de la aritmtica. Por ejemplo, las instrucciones para multiplicar, dividir y traducir suponen el uso del AX. Tambin, algunas operaciones generan cdigo ms eficiente si se refieren al AX en lugar de a los otros registros. Registro BX. El BX es conocido como el registro base ya que es el nico registro de propsito general que puede ser ndice para direccionamiento indexado. Tambin es comn emplear el BX para clculos. Registro DX. El DX es conocido como l registro de datos. Algunas operaciones de entrada/salida requieren uso, y las operaciones de multiplicacin y divisin con cifras grandes suponen al DX y al AX trabajando juntos.

c) Registro de Apuntador de Instrucciones. El registro apuntador de instrucciones (IP) de 16 bits contiene el desplazamiento de direccin de la siguiente instruccin que se ejecuta. El IP est asociado con el registro CS en el sentido de que el IP indica la instruccin actual dentro del segmento de cdigo que se est ejecutando actualmente. Los procesadores 80386 y posteriores tienen un IP ampliado de 32 bits, llamado EIP. En el ejemplo siguiente, el registro CS contiene 25A4[0]H y el IP contiene 412H. Para encontrar la siguiente instruccin que ser ejecutada, el procesador combina las direcciones en el CS y el IP: Segmento de direccin en el registro CS: 25A40H Desplazamiento de direccin en el registro IP: + 412H Direccin de la siguiente instruccin: 25E52H

d) Registros Apuntadores. Los registros SP (apuntador de la pila) Y BP (apuntador de base) estn asociados con el registro SS y permiten al sistema accesar datos en el segmento de la pila. Registro SP. El apuntador de la pila de 16 bits est asociado con el registro SS y proporciona un valor de desplazamiento que se refiere a la palabra actual que est siendo procesada en la pila. Los procesadores 80386 y posteriores tienen un apuntador de pila de 32 bits, el registro ESP. El sistema maneja de forma automtica estos registros.

En el ejemplo siguiente, el registro SS contiene la direccin de segmento 27B3[0]H y el SP el desplazamiento 312H. Para encontrar la palabra actual que est siendo procesada en la pila, la computadora combina las direcciones en el SS y el SP:

TAREA DE ARQUITECTURA DE COMPUTADORAS

Registro BP. El BP de 16 bits facilita la referencia de parmetros, los cuales son datos y direcciones transmitidos va pila. Los procesadores 80386 y posteriores tienen un BP ampliado de 32 bits llamado el registro EBP.

e) Registros ndice. Los registros SI y DI estn disponibles para direccionamiento indexado y para sumas y restas. Registro SI. El registro ndice fuente de 16 bits es requerido por algunas operaciones con cadenas (de caracteres). En este contexto, el SI est asociado con el registro DS. Los procesadores 80386 y posteriores permiten el uso de un registro ampliado de 32 bits, el ESI. Registro DI. El registro ndice destino tambin es requerido por algunas operaciones con cadenas de caracteres. En este contexto, el DI est asociado con el registro ES. Los procesadores 80386 y posteriores permiten el uso de un registro ampliado de 32 bits, el EDI.

f)

Registro de Banderas.

De los 16 bits del registro de banderas, nueve son comunes a toda la familia de procesadores 8086, y sirven para indicar el estado actual de la mquina y el resultado del procesamiento. Muchas instrucciones que piden comparaciones y aritmtica cambian el estado de las banderas, algunas cuyas instrucciones pueden realizar pruebas para determinar la accin subsecuente. En resumen, los bits de las banderas comunes son como sigue: OF (Overflow, desbordamiento). Indica desbordamiento de un bit de orden alto (ms a la izquierda) despus de una operacin aritmtica. DF (direccin). Designa la direccin hacia la izquierda o hacia la derecha para mover o comparar cadenas de caracteres. IF (interrupcin). Indica que una interrupcin externa, como la entrada desde el teclado, sea procesada o ignorada. TF (trampa). Permite la operacin del procesador en modo de un paso. Los programas depuradores, como el DEBUG, activan esta bandera de manera que usted pueda avanzar en la ejecucin de una sola instruccin a un tiempo, para examinar el efecto de esa instruccin sobre los registros de memoria. SF (signo). Contiene el signo resultante de una operacin aritmtica (0 = positivo y 1 = negativo). ZF (cero). Indica el resultado de una operacin aritmtica o de comparacin (0 = resultado diferente de cero y 1 = resultado igual a cero). AF (acarreo auxiliar). Contiene un acarreo externo del bit 3 en un dato de 8 bits para aritmtica especializada. PF (paridad). Indica paridad par o impar de una operacin en datos de 8 bits de bajo orden (mas a la derecha). CF (acarreo). Contiene el acarreo de orden ms alto (mas a la izquierda) despus de una operacin aritmtica; tambin lleva el contenido del ultimo bit en una operacin de corrimiento o de rotacin. Las banderas estn en el registro de banderas en las siguientes posiciones:

TAREA DE ARQUITECTURA DE COMPUTADORAS Las banderas ms importantes para la programacin en ensamblador son O, S, Z y C, para operaciones de comparacin y aritmticas, y D para operaciones de cadenas de caracteres. Los procesadores 80286 y posteriores tienen algunas banderas usadas para propsitos internos, en especial las que afectan al modo protegido. Los procesadores 80286 y posteriores tienen un registro extendido de banderas conocido como Eflags.

g) Registros de PILA La pila es un rea de memoria importante y por ello tiene, en vez de uno, dos registros que se usan como desplazamiento (offset) para apuntar a su contenido. Se usan como complemento al registro y son: -SP- Stack Pointer: Se traduce como puntero de pila y es el que se reserva el procesador para uso propio en instrucciones de manipulado de pila. Por lo general, el programador no debe alterar su contenido. -BP- Base pointer: Se usa como registro auxiliar. El programador puede usarlo para su provecho. Claro que estos nombres y tipos de registros son estndar, ya que cada fabricante puede utilizar otros registro que reemplacen a estos o los auxilien, aun as, los fabricantes que usan otros registro tienen la misma funcin que los anteriormente mencionados.

S-ar putea să vă placă și