![Intel ITANIUM ARCHITECTURE - SOFTWARE DEVELOPERS VOLUME 3 REV 2.3 Manual Download Page 494](http://html.mh-extra.com/html/intel/itanium-architecture-software-developers-volume-3-rev-2-3/itanium-architecture-software-developers-volume-3-rev-2-3_manual_2073404494.webp)
2:246
Volume 2, Part 1: Itanium
®
Architecture-based Operating System Interaction Model with IA-32 Applications
10.3.3
IA-32 System Registers
IA-32 system registers such as CR3, CR2, debug registers, performance counters.
IA-32 control registers do not affect execution of Itanium instructions. All IA-32
privileged instructions that access prior IA-32 system registers are intercepted.
10.3.3.1
IA-32 Control Registers
IA-32 control registers CR0 and CR4 are mapped into the Itanium application register
CFLG (AR27). IA-32 control bits, shown in
, only control execution of the
IA-32 instruction set. Additional CR0 bits are defined in CFLG to control virtualization of
IA-32 code (namely the IO and IF bits) as shown in
. CFLG is readable by
Itanium architecture-based code at all privilege levels but can only be written at
privilege level 0, otherwise a Privileged Register fault is generated. When Itanium
architecture-based software loads this application register (AR24), a Reserved
Register/Field fault will be raised if a non-zero value is written into bits listed as
reserved.
• State in italics is virtualized. This state has no impact on a IA-32 or Itanium
instruction set execution
.
• State in bold only affects IA-32 instruction set execution, Itanium instruction
execution is not affected.
EFLAG.vif
19
IA-32 Virtual Interrupt Flag. See VME extensions in the
Intel
®
64 and IA-32
Architectures Software Developer’s Manual
for details. Affects execution of POPF,
PUSHF, CLI and STI. This bit is supported in both the IA-32 and Intel Itanium System
Environments. A IA-32 Code Fetch fault (GPFault(0)) is generated on every IA-32
instruction (including the target of
rfi
and
br.ia
), if the following condition is true:
EFLAG.vip & EFLAG.vif & CFLG.pe & PSR.cpl==3 & (CFLG.pvi | (EFLAG.vm &
CFLG.vme))
EFLAG.vip
20
IA-32 Virtual Interrupt Pending. See VME extensions in the
Intel
®
64 and IA-32
Architectures Software Developer’s Manual
for programming details. Affects
execution of POPF, PUSHF, CLI and STI. This bit is supported in both the IA-32 and
Intel Itanium System Environments.
EFLAG.id
21
IA-32 Identifier bit, can be written and read by IA-32 instructions, indicates IA-32
CPUID instruction is supported. This bit is supported in both the IA-32 and Intel
Itanium System Environments.
63:22
This field is reserved for IA-32 instructions – reads return zeros and non-zero writes
causes IA_32_Exception (General Protection) faults. For Itanium instructions, the
implementation can either raise Reserved Register/Field fault on non-zero writes and
return zero on reads, or write the value (no Reserved Register/Field fault), and return
the last value written on reads.
a. On entry into the IA-32 instruction set all bits may be read by subsequent IA-32 instructions, after exit from the
IA-32 instruction set these bits represent the results of all prior IA-32 instructions. None of the EFLAG bits
alter the behavior of Itanium instruction set execution.
Figure 10-3. Control Flag Register (CFLG, AR27)
31 30 29 28272625242322212019 18 17 16 1514131211
10
9
8
7
6
5
4
3
2
1
0
PGCD NW
ignored (set to 0)
AM ig WP
ignored (set to 0)
II
IF
IO NE ET TS EM MP PE
63 62 61 60595857565554535251 50 49 48 4746454443
42
41
40
39
38
37
36 35 34 33
32
reserved (set to 0)
MMXEX FXSR PCEPGEMCE PAEPSEDETSDPVIVME
Table 10-3.
IA-32 EFLAG Field Definition (Continued)
EFLAG
a
Bits
Description
Summary of Contents for ITANIUM ARCHITECTURE - SOFTWARE DEVELOPERS VOLUME 3 REV 2.3
Page 1: ......
Page 11: ...x Intel Itanium Architecture Software Developer s Manual Rev 2 3 ...
Page 13: ...1 2 Intel Itanium Architecture Software Developer s Manual Rev 2 3 ...
Page 33: ...1 22 Volume 1 Part 1 Introduction to the Intel Itanium Architecture ...
Page 57: ...1 46 Volume 1 Part 1 Execution Environment ...
Page 147: ...1 136 Intel Itanium Architecture Software Developer s Manual Rev 2 3 ...
Page 149: ...1 138 Volume 1 Part 2 About the Optimization Guide ...
Page 191: ...1 180 Volume 1 Part 2 Predication Control Flow and Instruction Stream ...
Page 230: ......
Page 248: ...236 Intel Itanium Architecture Software Developer s Manual Rev 2 3 ...
Page 250: ...2 2 Intel Itanium Architecture Software Developer s Manual Rev 2 3 ...
Page 264: ...2 16 Volume 2 Part 1 Intel Itanium System Environment ...
Page 380: ...2 132 Volume 2 Part 1 Interruptions ...
Page 398: ...2 150 Volume 2 Part 1 Register Stack Engine ...
Page 486: ...2 238 Volume 2 Part 1 IA 32 Interruption Vector Descriptions ...
Page 750: ...2 502 Intel Itanium Architecture Software Developer s Manual Rev 2 3 ...
Page 754: ...2 506 Volume 2 Part 2 About the System Programmer s Guide ...
Page 796: ...2 548 Volume 2 Part 2 Interruptions and Serialization ...
Page 808: ...2 560 Volume 2 Part 2 Context Management ...
Page 842: ...2 594 Volume 2 Part 2 Floating point System Software ...
Page 850: ...2 602 Volume 2 Part 2 IA 32 Application Support ...
Page 862: ...2 614 Volume 2 Part 2 External Interrupt Architecture ...
Page 870: ...2 622 Volume 2 Part 2 Performance Monitoring Support ...
Page 891: ......
Page 1099: ...3 200 Volume 3 Instruction Reference padd Interruptions Illegal Operation fault ...
Page 1295: ...3 396 Volume 3 Resource and Dependency Semantics ...
Page 1296: ......
Page 1302: ...402 Intel Itanium Architecture Software Developer s Manual Rev 2 3 ...
Page 1494: ...4 192 Volume 4 Base IA 32 Instruction Reference FWAIT Wait See entry for WAIT ...
Page 1647: ...Volume 4 Base IA 32 Instruction Reference 4 345 ROL ROR Rotate See entry for RCL RCR ROL ROR ...
Page 1884: ...4 582 Volume 4 IA 32 SSE Instruction Reference ...
Page 1885: ...Index Intel Itanium Architecture Software Developer s Manual Rev 2 3 Index ...
Page 1886: ...Index Intel Itanium Architecture Software Developer s Manual Rev 2 3 ...
Page 1898: ...INDEX Index 12 Index for Volumes 1 2 3 and 4 ...