Registro FLAGS

El registro FLAGS es el registro de estado en los microprocesadores Intel x86 que contiene el estado actual del procesador. Este registro es de 16 bits de ancho. Sus sucesores, los registros EFLAGS y RFLAGS, son de 32 bits y 64 bits de ancho, respectivamente. El más amplio de los registros mantiene la compatibilidad con sus predecesores más pequeños.

Los bits fijos en las posiciones de bit 1,3 y 5, y las banderas de acarreo (carry), paridad (parity), ajuste (adjust), cero (zero) y signo (sign) se heredan de una arquitectura aún anterior, la 8080.La bandera de ajuste solía denominarse bit de transporte auxiliar (auxiliary carry) en 8080 y bit de transporte (half-carry) en la arquitectura Zilog Z80.

BANDERAS

Registro FLAGS Intel x86[1]
Bit#AbreviaturaDescripciónCategoría
FLAGS (Banderas)
0CFBandera de acarreoEstado
1Reservado, siempre 1 en EFLAGS[2]
2PFBandera de paridadEstado
3Reservado
4AFBandera de ajusteEstado
5Reservado
6ZFBandera de ceroEstado
7SFBandera de signoEstado
8TFBandera de trampa (paso único)Control
9IFBandera de interrupción habilitadaControl
10DFBandera de direcciónControl
11OFBandera de desbordamientoEstado
12-13IOPLNivel de privilegio de E/S (Solo 286+), siempre 1 encima 8086 y 186Sistema
14NTBandera de tarea anidada (Solo 286+), siempre 1 en 8086 y 186Sistema
15Reservado, siempre 1 en 8086 y 186, siempre 0 en modelos más recientes.
EFLAGS
16RFBandera de resumen (Solo 386+)Sistema
17VMBandera de modo Virtual 8086 (Solo 386+)Sistema
18ACControl de alineación (Solo 486SX+ )Sistema
19VIFBandera de interrupción virtual (Pentium+)Sistema
20VIPInterrupción virtual pendiente (Pentium+)Sistema
21IDCapaz de utilizar instrucción CPUID (Pentium+)Sistema
22Reservado
23Reservado
24Reservado
25Reservado
26Reservado
27Reservado
28Reservado
29Reservado
30Reservado
31Reservado
RFLAGS
32-63Reservado

USO

Las instrucciones POPF, POPFD, y POPFQ lee del stack, los primeros 16, 32, y 64 bits del registro de banderas, respectivamente. POPFD fue introducido con la arquitectura i386 (Intel 80386) y POPFQ con la arquitectura x64 . En el modo 64-bit, PUSHF/POPF y PUSHFQ/POPFQ están disponible pero no PUSHFD/POPFD.[3]

El código assembler siguiente cambia la bandera de dirección (DF):

pushf; Desplaza las banderas actuales a la pilapop ax; Pone las banderas de la pila en el registro axpush ax; Desplaza de nuevo en la pila para el almacenajexor ax, 400h; Activar sólo la bandera DF, mantener el resto de las banderas.push ax; Desplaza de nuevo para añadir el nuevo valor a la pilapopf; Desplaza el nuevo registro FLAGS;... Código aquí...popf; Coloca las viejas banderas en su lugar

En software práctico, las instrucciones cld y stdson usadas para limpiar y configurar la bandera de dirección, respectivamente. Algunas instrucciones en lenguaje assembly utilizan el registro FLAGS. Las instrucciones de salto condicionales utilizan ciertas banderas para calcular. Por ejemplo, jz utiliza la bandera de cero, jc utiliza la bandera de acarreo y jo utiliza la bandera de desbordamiento. Otras instrucciones condicionales observan combinaciones de varias banderas.

Determinación de tipo de procesador

Probar si ciertos bits del registro FLAGS son cambiables permite determinar qué tipo de procesador está instalado. Por ejemplo, la bandera de alineación solo puede ser cambiada en el 486 y superiores, así que si pueda ser cambiado entonces el CPU es un 486 o más alto. Estos métodos de detección de procesadores no quedaron obsoletos por la instrucción CPUID introducida con el Intel Pentium, ya que CPUID no es implementado en estas antiguas CPUs.

Véase también

Referencias