3:288
Volume 3: Pseudo-Code Functions
Intel
®
Itanium
®
Architecture Software Developer’s Manual Rev. 2.3
spontaneous_deferral(paddr, size,
border, mattr, otype, hint, *defer)
Implementation-dependent routine which optionally forces
*defer
to TRUE if all of
the following are true: spontaneous deferral is enabled, spontaneous deferral is
permitted by the programming model, and the processor determines it would be
advantageous to defer the speculative load (e.g., based on a miss in some particular
level of cache).
spontaneous_deferral_enabled()
Implementation-dependent routine which returns TRUE or FALSE, depending on
whether spontaneous deferral of speculative loads is enabled or disabled in the
processor.
tlb_access_key(vaddr, itype)
This function returns, in bits 31:8, the access key from the TLB for the entry
corresponding to
vaddr
and
itype
; bits 63:32 and 7:0 return 0. If
vaddr
is an
unimplemented virtual address, or a matching present translation is not found, the
value 1 is returned.
tlb_broadcast_purge(rid, vaddr, size,
type)
Sends a broadcast purge DTC and ITC transaction to other processors in the
multiprocessor coherency domain, where the region identifier (
rid
), virtual address
(
vaddr
) and page size (
size
) specify the translation entry to purge. The operation
waits until all processors that receive the purge have completed the purge operation.
The purge type (
type
) specifies whether the ALAT on other processors should also
be purged in conjunction with the TC.
tlb_enter_privileged_code()
This function determines the new privilege level for epc from the TLB entry for the
page containing this instruction. If the page containing the epc instruction has
execute-only page access rights and the privilege level assigned to the page is higher
than (numerically less than) the current privilege level, then the current privilege level
is set to the privilege level field in the translation for the page containing the epc
instruction.
tlb_grant_permission(vaddr, type, pl)
Returns a boolean indicating if read, write access is granted for the specified virtual
memory address (
vaddr
) and privilege level (
pl
). The access type (
type
) specifies
either read or write. The following faults are checked::
• Data Nested TLB fault
• Alternate Data TLB fault
• VHPT Data fault
• Data TLB fault
• Data Page Not Present fault
• Data NaT Page Consumption fault
• Data Key Miss fault
If a fault is generated, this function does not return.
tlb_insert_data(slot, pte0, pte1, vaddr, rid,
tr)
Inserts an entry into the DTLB, at the specified
slot
number.
pte0
,
pte1
compose
the translation.
vaddr
and
rid
specify the virtual address and region identifier for the
translation. If
tr
is true the entry is placed in the TR section, otherwise the TC
section.
tlb_insert_inst(slot, pte0, pte1, vaddr, rid,
tr)
Inserts an entry into the ITLB, at the specified
slot
number.
pte0
,
pte1
compose
the translation.
vaddr
and
rid
specify the virtual address and region identifier for the
translation. If
tr
is true, the entry is placed in the TR section, otherwise the TC
section.
tlb_may_purge_dtc_entries(rid, vaddr,
size)
May locally purge DTC entries that match the specified virtual address (
vaddr
),
region identifier (
rid
) and page size (
size
). May also invalidate entries that partially
overlap the parameters. The extent of purging is implementation dependent. If the
purge size is not supported, an implementation may generate a machine check abort
or over purge the translation cache up to and including removal of all entries from the
translation cache.
Table 3-1.
Pseudo-code Functions (Continued)
Function
Operation
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 ...