/** @file | |
Main PAL API's defined in Intel Itanium Architecture Software Developer's Manual. | |
Copyright (c) 2006 - 2008, Intel Corporation | |
All rights reserved. This program and the accompanying materials | |
are licensed and made available under the terms and conditions of the BSD License | |
which accompanies this distribution. The full text of the license may be found at | |
http://opensource.org/licenses/bsd-license.php | |
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, | |
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. | |
**/ | |
#ifndef __PAL_API_H__ | |
#define __PAL_API_H__ | |
#define PAL_SUCCESS 0x0 | |
/// | |
/// CacheType of PAL_CACHE_FLUSH. | |
/// | |
#define PAL_CACHE_FLUSH_INSTRUCTION_ALL 1 | |
#define PAL_CACHE_FLUSH_DATA_ALL 2 | |
#define PAL_CACHE_FLUSH_ALL 3 | |
#define PAL_CACHE_FLUSH_SYNC_TO_DATA 4 | |
/// | |
/// Bitmask of Opearation of PAL_CACHE_FLUSH. | |
/// | |
#define PAL_CACHE_FLUSH_INVALIDATE_LINES BIT0 | |
#define PAL_CACHE_FLUSH_NO_INVALIDATE_LINES 0 | |
#define PAL_CACHE_FLUSH_POLL_INTERRUPT BIT1 | |
#define PAL_CACHE_FLUSH_NO_INTERRUPT 0 | |
/** | |
PAL Procedure - PAL_CACHE_FLUSH. | |
Flush the instruction or data caches. It is required by Itanium processors. | |
The PAL procedure supports the Static Registers calling | |
convention. It could be called at virtual mode and physical | |
mode. | |
@param Index Index of PAL_CACHE_FLUSH within the | |
list of PAL procedures. | |
@param CacheType Unsigned 64-bit integer indicating | |
which cache to flush. | |
@param Operation Formatted bit vector indicating the | |
operation of this call. | |
@param ProgressIndicator Unsigned 64-bit integer specifying | |
the starting position of the flush | |
operation. | |
@retval 2 Call completed without error, but a PMI | |
was taken during the execution of this | |
procedure. | |
@retval 1 Call has not completed flushing due to | |
a pending interrupt. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error | |
@return R9 Unsigned 64-bit integer specifying the vector | |
number of the pending interrupt. | |
@return R10 Unsigned 64-bit integer specifying the | |
starting position of the flush operation. | |
@return R11 Unsigned 64-bit integer specifying the vector | |
number of the pending interrupt. | |
**/ | |
#define PAL_CACHE_FLUSH 1 | |
/// | |
/// Attributes of PAL_CACHE_CONFIG_INFO1 | |
/// | |
#define PAL_CACHE_ATTR_WT 0 | |
#define PAL_CACHE_ATTR_WB 1 | |
/// | |
/// PAL_CACHE_CONFIG_INFO1.StoreHint | |
/// | |
#define PAL_CACHE_STORE_TEMPORAL 0 | |
#define PAL_CACHE_STORE_NONE_TEMPORAL 3 | |
/// | |
/// PAL_CACHE_CONFIG_INFO1.StoreHint | |
/// | |
#define PAL_CACHE_STORE_TEMPORAL_LVL_1 0 | |
#define PAL_CACHE_STORE_NONE_TEMPORAL_LVL_ALL 3 | |
/// | |
/// PAL_CACHE_CONFIG_INFO1.StoreHint | |
/// | |
#define PAL_CACHE_LOAD_TEMPORAL_LVL_1 0 | |
#define PAL_CACHE_LOAD_NONE_TEMPORAL_LVL_1 1 | |
#define PAL_CACHE_LOAD_NONE_TEMPORAL_LVL_ALL 3 | |
/// | |
/// Detail the characteristics of a given processor controlled | |
/// cache in the cache hierarchy. | |
/// | |
typedef struct { | |
UINT64 IsUnified : 1; | |
UINT64 Attributes : 2; | |
UINT64 Associativity:8; | |
UINT64 LineSize:8; | |
UINT64 Stride:8; | |
UINT64 StoreLatency:8; | |
UINT64 StoreHint:8; | |
UINT64 LoadHint:8; | |
} PAL_CACHE_INFO_RETURN1; | |
/// | |
/// Detail the characteristics of a given processor controlled | |
/// cache in the cache hierarchy. | |
/// | |
typedef struct { | |
UINT64 CacheSize:32; | |
UINT64 AliasBoundary:8; | |
UINT64 TagLsBits:8; | |
UINT64 TagMsBits:8; | |
} PAL_CACHE_INFO_RETURN2; | |
/** | |
PAL Procedure - PAL_CACHE_INFO. | |
Return detailed instruction or data cache information. It is | |
required by Itanium processors. The PAL procedure supports the Static | |
Registers calling convention. It could be called at virtual | |
mode and physical mode. | |
@param Index Index of PAL_CACHE_INFO within the list of | |
PAL procedures. | |
@param CacheLevel Unsigned 64-bit integer specifying the | |
level in the cache hierarchy for which | |
information is requested. This value must | |
be between 0 and one less than the value | |
returned in the cache_levels return value | |
from PAL_CACHE_SUMMARY. | |
@param CacheType Unsigned 64-bit integer with a value of 1 | |
for instruction cache and 2 for data or | |
unified cache. All other values are | |
reserved. | |
@param Reserved Should be 0. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error | |
@return R9 Detail the characteristics of a given | |
processor controlled cache in the cache | |
hierarchy. See PAL_CACHE_INFO_RETURN1. | |
@return R10 Detail the characteristics of a given | |
processor controlled cache in the cache | |
hierarchy. See PAL_CACHE_INFO_RETURN2. | |
@return R11 Reserved with 0. | |
**/ | |
#define PAL_CACHE_INFO 2 | |
/// | |
/// Level of PAL_CACHE_INIT. | |
/// | |
#define PAL_CACHE_INIT_ALL 0xffffffffffffffffULL | |
/// | |
/// CacheType | |
/// | |
#define PAL_CACHE_INIT_TYPE_INSTRUCTION 0x1 | |
#define PAL_CACHE_INIT_TYPE_DATA 0x2 | |
#define PAL_CACHE_INIT_TYPE_INSTRUCTION_AND_DATA 0x3 | |
/// | |
/// Restrict of PAL_CACHE_INIT. | |
/// | |
#define PAL_CACHE_INIT_NO_RESTRICT 0 | |
#define PAL_CACHE_INIT_RESTRICTED 1 | |
/** | |
PAL Procedure - PAL_CACHE_INIT. | |
Initialize the instruction or data caches. It is required by | |
Itanium processors. The PAL procedure supports the Static Registers calling | |
convention. It could be called at physical mode. | |
@param Index Index of PAL_CACHE_INIT within the list of PAL | |
procedures. | |
@param Level Unsigned 64-bit integer containing the level of | |
cache to initialize. If the cache level can be | |
initialized independently, only that level will | |
be initialized. Otherwise | |
implementation-dependent side-effects will | |
occur. | |
@param CacheType Unsigned 64-bit integer with a value of 1 to | |
initialize the instruction cache, 2 to | |
initialize the data cache, or 3 to | |
initialize both. All other values are | |
reserved. | |
@param Restrict Unsigned 64-bit integer with a value of 0 or | |
1. All other values are reserved. If | |
restrict is 1 and initializing the specified | |
level and cache_type of the cache would | |
cause side-effects, PAL_CACHE_INIT will | |
return -4 instead of initializing the cache. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -4 Call could not initialize the specified | |
level and cache_type of the cache without | |
side-effects and restrict was 1. | |
**/ | |
#define PAL_CACHE_INIT 3 | |
/// | |
/// PAL_CACHE_PROTECTION.Method. | |
/// | |
#define PAL_CACHE_PROTECTION_NONE_PROTECT 0 | |
#define PAL_CACHE_PROTECTION_ODD_PROTECT 1 | |
#define PAL_CACHE_PROTECTION_EVEN_PROTECT 2 | |
#define PAL_CACHE_PROTECTION_ECC_PROTECT 3 | |
/// | |
/// PAL_CACHE_PROTECTION.TagOrData. | |
/// | |
#define PAL_CACHE_PROTECTION_PROTECT_DATA 0 | |
#define PAL_CACHE_PROTECTION_PROTECT_TAG 1 | |
#define PAL_CACHE_PROTECTION_PROTECT_TAG_ANDTHEN_DATA 2 | |
#define PAL_CACHE_PROTECTION_PROTECT_DATA_ANDTHEN_TAG 3 | |
/// | |
/// 32-bit protection information structures. | |
/// | |
typedef struct { | |
UINT32 DataBits:8; | |
UINT32 TagProtLsb:6; | |
UINT32 TagProtMsb:6; | |
UINT32 ProtBits:6; | |
UINT32 Method:4; | |
UINT32 TagOrData:2; | |
} PAL_CACHE_PROTECTION; | |
/** | |
PAL Procedure - PAL_CACHE_PROT_INFO. | |
Return instruction or data cache protection information. It is | |
required by Itanium processors. The PAL procedure supports the Static | |
Registers calling convention. It could be called at physical | |
mode and Virtual mode. | |
@param Index Index of PAL_CACHE_PROT_INFO within the list of | |
PAL procedures. | |
@param CacheLevel Unsigned 64-bit integer specifying the level | |
in the cache hierarchy for which information | |
is requested. This value must be between 0 | |
and one less than the value returned in the | |
cache_levels return value from | |
PAL_CACHE_SUMMARY. | |
@param CacheType Unsigned 64-bit integer with a value of 1 | |
for instruction cache and 2 for data or | |
unified cache. All other values are | |
reserved. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Detail the characteristics of a given | |
processor controlled cache in the cache | |
hierarchy. See PAL_CACHE_PROTECTION[0..1]. | |
@return R10 Detail the characteristics of a given | |
processor controlled cache in the cache | |
hierarchy. See PAL_CACHE_PROTECTION[2..3]. | |
@return R11 Detail the characteristics of a given | |
processor controlled cache in the cache | |
hierarchy. See PAL_CACHE_PROTECTION[4..5]. | |
**/ | |
#define PAL_CACHE_PROT_INFO 38 | |
typedef struct { | |
UINT64 ThreadId : 16; ///< The thread identifier of the logical | |
///< processor for which information is being | |
///< returned. This value will be unique on a per core basis. | |
UINT64 Reserved1: 16; | |
UINT64 CoreId: 16; ///< The core identifier of the logical processor | |
///< for which information is being returned. | |
///< This value will be unique on a per physical | |
///< processor package basis. | |
UINT64 Reserved2: 16; | |
} PAL_PCOC_N_CACHE_INFO1; | |
typedef struct { | |
UINT64 LogicalAddress : 16; ///< Logical address: geographical address | |
///< of the logical processor for which | |
///< information is being returned. This is | |
///< the same value that is returned by the | |
///< PAL_FIXED_ADDR procedure when it is | |
///< called on the logical processor. | |
UINT64 Reserved1: 16; | |
UINT64 Reserved2: 32; | |
} PAL_PCOC_N_CACHE_INFO2; | |
/** | |
PAL Procedure - PAL_CACHE_SHARED_INFO. | |
Returns information on which logical processors share caches. | |
It is optional. The PAL procedure supports the Static | |
Registers calling convention. It could be called at physical | |
mode and Virtual mode. | |
@param Index Index of PAL_CACHE_SHARED_INFO within the list | |
of PAL procedures. | |
@param CacheLevel Unsigned 64-bit integer specifying the | |
level in the cache hierarchy for which | |
information is requested. This value must | |
be between 0 and one less than the value | |
returned in the cache_levels return value | |
from PAL_CACHE_SUMMARY. | |
@param CacheType Unsigned 64-bit integer with a value of 1 | |
for instruction cache and 2 for data or | |
unified cache. All other values are | |
reserved. | |
@param ProcNumber Unsigned 64-bit integer that specifies for | |
which logical processor information is | |
being requested. This input argument must | |
be zero for the first call to this | |
procedure and can be a maximum value of | |
one less than the number of logical | |
processors sharing this cache, which is | |
returned by the num_shared return value. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Unsigned integer that returns the number of | |
logical processors that share the processor | |
cache level and type, for which information was | |
requested. | |
@return R10 The format of PAL_PCOC_N_CACHE_INFO1. | |
@return R11 The format of PAL_PCOC_N_CACHE_INFO2. | |
**/ | |
#define PAL_CACHE_SHARED_INFO 43 | |
/** | |
PAL Procedure - PAL_CACHE_SUMMARY. | |
Return a summary of the cache hierarchy. It is required by | |
Itanium processors. The PAL procedure supports the Static Registers calling | |
convention. It could be called at physical mode and Virtual | |
mode. | |
@param Index Index of PAL_CACHE_SUMMARY within the list of | |
PAL procedures. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 CacheLevels Unsigned 64-bit integer denoting the | |
number of levels of cache | |
implemented by the processor. | |
Strictly, this is the number of | |
levels for which the cache | |
controller is integrated into the | |
processor (the cache SRAMs may be | |
external to the processor). | |
@return R10 UniqueCaches Unsigned 64-bit integer denoting the | |
number of unique caches implemented | |
by the processor. This has a maximum | |
of 2*cache_levels, but may be less | |
if any of the levels in the cache | |
hierarchy are unified caches or do | |
not have both instruction and data | |
caches. | |
**/ | |
#define PAL_CACHE_SUMMARY 4 | |
// | |
// Virtual Memory Attributes implemented by processor. | |
// | |
#define PAL_MEMORY_ATTR_WB 0 | |
#define PAL_MEMORY_ATTR_WC 6 | |
#define PAL_MEMORY_ATTR_UC 4 | |
#define PAL_MEMORY_ATTR_UCE 5 | |
#define PAL_MEMORY_ATTR_NATPAGE 7 | |
/** | |
PAL Procedure - PAL_MEM_ATTRIB. | |
Return a list of supported memory attributes.. It is required | |
by Itanium processors. The PAL procedure supports the Static Registers calling | |
convention. It could be called at physical mode and Virtual | |
mode. | |
@param Index Index of PAL_MEM_ATTRIB within the list of PAL | |
procedures. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Attributes 8-bit vector of memory attributes | |
implemented by processor. See Virtual | |
Memory Attributes above. | |
**/ | |
#define PAL_MEM_ATTRIB 5 | |
/** | |
PAL Procedure - PAL_PREFETCH_VISIBILITY. | |
Used in architected sequence to transition pages from a | |
cacheable, speculative attribute to an uncacheable attribute. | |
It is required by Itanium processors. The PAL procedure supports the Static | |
Registers calling convention. It could be called at physical | |
mode and Virtual mode. | |
@param Index Index of PAL_PREFETCH_VISIBILITY within the list | |
of PAL procedures. | |
@param TransitionType Unsigned integer specifying the type | |
of memory attribute transition that is | |
being performed. | |
@retval 1 Call completed without error; this | |
call is not necessary on remote | |
processors. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
**/ | |
#define PAL_PREFETCH_VISIBILITY 41 | |
/** | |
PAL Procedure - PAL_PTCE_INFO. | |
Return information needed for ptc.e instruction to purge | |
entire TC. It is required by Itanium processors. The PAL procedure supports | |
the Static Registers calling convention. It could be called at | |
physical mode and Virtual mode. | |
@param Index Index of PAL_PTCE_INFO within the list | |
of PAL procedures. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Unsigned 64-bit integer denoting the beginning | |
address to be used by the first PTCE instruction | |
in the purge loop. | |
@return R10 Two unsigned 32-bit integers denoting the loop | |
counts of the outer (loop 1) and inner (loop 2) | |
purge loops. count1 (loop 1) is contained in bits | |
63:32 of the parameter, and count2 (loop 2) is | |
contained in bits 31:0 of the parameter. | |
@return R11 Two unsigned 32-bit integers denoting the loop | |
strides of the outer (loop 1) and inner (loop 2) | |
purge loops. stride1 (loop 1) is contained in bits | |
63:32 of the parameter, and stride2 (loop 2) is | |
contained in bits 31:0 of the parameter. | |
**/ | |
#define PAL_PTCE_INFO 6 | |
typedef struct { | |
UINT64 NumberSets:8; ///< Unsigned 8-bit integer denoting the number | |
///< of hash sets for the specified level | |
///< (1=fully associative) | |
UINT64 NumberWays:8; ///< Unsigned 8-bit integer denoting the | |
///< associativity of the specified level | |
///< (1=direct). | |
UINT64 NumberEntries:16; ///< Unsigned 16-bit integer denoting the | |
///< number of entries in the specified TC. | |
UINT64 PageSizeIsOptimized:1; ///< Flag denoting whether the | |
///< specified level is optimized for | |
///< the region's preferred page size | |
///< (1=optimized) tc_pages indicates | |
///< which page sizes are usable by | |
///< this translation cache. | |
UINT64 TcIsUnified:1; ///< Flag denoting whether the specified TC is | |
///< unified (1=unified). | |
UINT64 EntriesReduction:1; ///< Flag denoting whether installed | |
///< translation registers will reduce | |
///< the number of entries within the | |
///< specified TC. | |
} PAL_TC_INFO; | |
/** | |
PAL Procedure - PAL_VM_INFO. | |
Return detailed information about virtual memory features | |
supported in the processor. It is required by Itanium processors. The PAL | |
procedure supports the Static Registers calling convention. It | |
could be called at physical mode and Virtual mode. | |
@param Index Index of PAL_VM_INFO within the list | |
of PAL procedures. | |
@param TcLevel Unsigned 64-bit integer specifying the level | |
in the TLB hierarchy for which information is | |
required. This value must be between 0 and one | |
less than the value returned in the | |
vm_info_1.num_tc_levels return value from | |
PAL_VM_SUMMARY. | |
@param TcType Unsigned 64-bit integer with a value of 1 for | |
instruction translation cache and 2 for data | |
or unified translation cache. All other values | |
are reserved. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 8-byte formatted value returning information | |
about the specified TC. See PAL_TC_INFO above. | |
@return R10 64-bit vector containing a bit for each page | |
size supported in the specified TC, where bit | |
position n indicates a page size of 2**n. | |
**/ | |
#define PAL_VM_INFO 7 | |
/** | |
PAL Procedure - PAL_VM_PAGE_SIZE. | |
Return virtual memory TC and hardware walker page sizes | |
supported in the processor. It is required by Itanium processors. The PAL | |
procedure supports the Static Registers calling convention. It | |
could be called at physical mode and Virtual mode. | |
@param Index Index of PAL_VM_PAGE_SIZE within the list | |
of PAL procedures. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 64-bit vector containing a bit for each | |
architected page size that is supported for | |
TLB insertions and region registers. | |
@return R10 64-bit vector containing a bit for each | |
architected page size supported for TLB purge | |
operations. | |
**/ | |
#define PAL_VM_PAGE_SIZE 34 | |
typedef struct { | |
UINT64 WalkerPresent:1; ///< 1-bit flag indicating whether a hardware | |
///< TLB walker is implemented (1 = walker | |
///< present). | |
UINT64 WidthOfPhysicalAddress: 7; ///< Unsigned 7-bit integer | |
///< denoting the number of bits of | |
///< physical address implemented. | |
UINT64 WidthOfKey:8; ///< Unsigned 8-bit integer denoting the number | |
///< of bits mplemented in the PKR.key field. | |
UINT64 MaxPkrIndex:8; ///< Unsigned 8-bit integer denoting the | |
///< maximum PKR index (number of PKRs-1). | |
UINT64 HashTagId:8; ///< Unsigned 8-bit integer which uniquely | |
///< identifies the processor hash and tag | |
///< algorithm. | |
UINT64 MaxDtrIndex:8; ///< Unsigned 8 bit integer denoting the | |
///< maximum data translation register index | |
///< (number of dtr entries - 1). | |
UINT64 MaxItrIndex:8; ///< Unsigned 8 bit integer denoting the | |
///< maximum instruction translation register | |
///< index (number of itr entries - 1). | |
UINT64 NumberOfUniqueTc:8; ///< Unsigned 8-bit integer denoting the | |
///< number of unique TCs implemented. | |
///< This is a maximum of | |
///< 2*num_tc_levels. | |
UINT64 NumberOfTcLevels:8; ///< Unsigned 8-bit integer denoting the | |
///< number of TC levels. | |
} PAL_VM_INFO1; | |
typedef struct { | |
UINT64 WidthOfVirtualAddress:8; ///< Unsigned 8-bit integer denoting | |
///< is the total number of virtual | |
///< address bits - 1. | |
UINT64 WidthOfRid:8; ///< Unsigned 8-bit integer denoting the number | |
///< of bits implemented in the RR.rid field. | |
UINT64 MaxPurgedTlbs:16; ///< Unsigned 16 bit integer denoting the | |
///< maximum number of concurrent outstanding | |
///< TLB purges allowed by the processor. A | |
///< value of 0 indicates one outstanding | |
///< purge allowed. A value of 216-1 | |
///< indicates no limit on outstanding | |
///< purges. All other values indicate the | |
///< actual number of concurrent outstanding | |
///< purges allowed. | |
UINT64 Reserved:32; | |
} PAL_VM_INFO2; | |
/** | |
PAL Procedure - PAL_VM_SUMMARY. | |
Return summary information about virtual memory features | |
supported in the processor. It is required by Itanium processors. The PAL | |
procedure supports the Static Registers calling convention. It | |
could be called at physical mode and Virtual mode. | |
@param Index Index of PAL_VM_SUMMARY within the list | |
of PAL procedures. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 8-byte formatted value returning global virtual | |
memory information. See PAL_VM_INFO1 above. | |
@return R10 8-byte formatted value returning global virtual | |
memory information. See PAL_VM_INFO2 above. | |
**/ | |
#define PAL_VM_SUMMARY 8 | |
// | |
// Bit mask of TR_valid flag. | |
// | |
#define PAL_TR_ACCESS_RIGHT_IS_VALID BIT0 | |
#define PAL_TR_PRIVILEGE_LEVEL_IS_VALID BIT1 | |
#define PAL_TR_DIRTY_IS_VALID BIT2 | |
#define PAL_TR_MEMORY_ATTR_IS_VALID BIT3 | |
/** | |
PAL Procedure - PAL_VM_TR_READ. | |
Read contents of a translation register. It is required by | |
Itanium processors. The PAL procedure supports the Stacked Register calling | |
convention. It could be called at physical mode. | |
@param Index Index of PAL_VM_TR_READ within the list | |
of PAL procedures. | |
@param RegNumber Unsigned 64-bit number denoting which TR to | |
read. | |
@param TrType Unsigned 64-bit number denoting whether to | |
read an ITR (0) or DTR (1). All other values | |
are reserved. | |
@param TrBuffer 64-bit pointer to the 32-byte memory buffer in | |
which translation data is returned. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Formatted bit vector denoting which fields are | |
valid. See TR_valid above. | |
**/ | |
#define PAL_VM_TR_READ 261 | |
// | |
// Bit Mask of Processor Bus Fesatures . | |
// | |
/** | |
When 0, bus data errors are detected and single bit errors are | |
corrected. When 1, no error detection or correction is done. | |
**/ | |
#define PAL_BUS_DISABLE_DATA_ERROR_SIGNALLING BIT63 | |
/** | |
When 0, bus address errors are signalled on the bus. When 1, | |
no bus errors are signalled on the bus. If Disable Bus Address | |
Error Checking is 1, this bit is ignored. | |
**/ | |
#define PAL_BUS_DISABLE_ADDRESS_ERROR_SIGNALLING BIT62 | |
/** | |
When 0, bus errors are detected, single bit errors are | |
corrected., and a CMCI or MCA is generated internally to the | |
processor. When 1, no bus address errors are detected or | |
corrected. | |
**/ | |
#define PAL_BUS_DISABLE_ADDRESS_ERROR_CHECK BIT61 | |
/** | |
When 0, bus protocol errors (BINIT#) are signaled by the | |
processor on the bus. When 1, bus protocol errors (BINIT#) are | |
not signaled on the bus. If Disable Bus Initialization Event | |
Checking is 1, this bit is ignored. | |
**/ | |
#define PAL_BUS_DISABLE_INITIALIZATION_EVENT_SIGNALLING BIT60 | |
/** | |
When 0, bus protocol errors (BINIT#) are detected and sampled | |
and an MCA is generated internally to the processor. When 1, | |
the processor will ignore bus protocol error conditions | |
(BINIT#). | |
**/ | |
#define PAL_BUS_DISABLE_INITIALIZATION_EVENT_CHECK BIT59 | |
/** | |
When 0, BERR# is signalled if a bus error is detected. When 1, | |
bus errors are not signalled on the bus. | |
**/ | |
#define PAL_BUS_DISABLE_ERROR_SIGNALLING BIT58 | |
/** | |
When 0, BERR# is signalled when internal processor requestor | |
initiated bus errors are detected. When 1, internal requester | |
bus errors are not signalled on the bus. | |
**/ | |
#define PAL_BUS_DISABLE__INTERNAL_ERROR_SIGNALLING BIT57 | |
/** | |
When 0, the processor takes an MCA if BERR# is asserted. When | |
1, the processor ignores the BERR# signal. | |
**/ | |
#define PAL_BUS_DISABLE_ERROR_CHECK BIT56 | |
/** | |
When 0, the processor asserts BINIT# if it detects a parity | |
error on the signals which identify the transactions to which | |
this is a response. When 1, the processor ignores parity on | |
these signals. | |
**/ | |
#define PAL_BUS_DISABLE_RSP_ERROR_CHECK BIT55 | |
/** | |
When 0, the in-order transaction queue is limited only by the | |
number of hardware entries. When 1, the processor's in-order | |
transactions queue is limited to one entry. | |
**/ | |
#define PAL_BUS_DISABLE_TRANSACTION_QUEUE BIT54 | |
/** | |
Enable a bus cache line replacement transaction when a cache | |
line in the exclusive state is replaced from the highest level | |
processor cache and is not present in the lower level processor | |
caches. When 0, no bus cache line replacement transaction will | |
be seen on the bus. When 1, bus cache line replacement | |
transactions will be seen on the bus when the above condition is | |
detected. | |
**/ | |
#define PAL_BUS_ENABLE_EXCLUSIVE_CACHE_LINE_REPLACEMENT BIT53 | |
/** | |
Enable a bus cache line replacement transaction when a cache | |
line in the shared or exclusive state is replaced from the | |
highest level processor cache and is not present in the lower | |
level processor caches. | |
When 0, no bus cache line replacement transaction will be seen | |
on the bus. When 1, bus cache line replacement transactions | |
will be seen on the bus when the above condition is detected. | |
**/ | |
#define PAL_BUS_ENABLE_SHARED_CACHE_LINE_REPLACEMENT BIT52 | |
/** | |
When 0, the data bus is configured at the 2x data transfer | |
rate.When 1, the data bus is configured at the 1x data | |
transfer rate, 30 Opt. Req. Disable Bus Lock Mask. When 0, the | |
processor executes locked transactions atomically. When 1, the | |
processor masks the bus lock signal and executes locked | |
transactions as a non-atomic series of transactions. | |
**/ | |
#define PAL_BUS_ENABLE_HALF_TRANSFER BIT30 | |
/** | |
When 0, the processor will deassert bus request when finished | |
with each transaction. When 1, the processor will continue to | |
assert bus request after it has finished, if it was the last | |
agent to own the bus and if there are no other pending | |
requests. | |
**/ | |
#define PAL_BUS_REQUEST_BUS_PARKING BIT29 | |
/** | |
PAL Procedure - PAL_BUS_GET_FEATURES. | |
Return configurable processor bus interface features and their | |
current settings. It is required by Itanium processors. The PAL procedure | |
supports the Stacked Register calling convention. It could be | |
called at physical mode. | |
@param Index Index of PAL_BUS_GET_FEATURES within the list | |
of PAL procedures. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 64-bit vector of features implemented. | |
(1=implemented, 0=not implemented) | |
@return R10 64-bit vector of current feature settings. | |
@return R11 64-bit vector of features controllable by | |
software. (1=controllable, 0= not controllable) | |
**/ | |
#define PAL_BUS_GET_FEATURES 9 | |
/** | |
PAL Procedure - PAL_BUS_SET_FEATURES. | |
Enable or disable configurable features in processor bus | |
interface. It is required by Itanium processors. The PAL procedure | |
supports the Static Registers calling convention. It could be | |
called at physical mode. | |
@param Index Index of PAL_BUS_SET_FEATURES within the list | |
of PAL procedures. | |
@param FeatureSelect 64-bit vector denoting desired state of | |
each feature (1=select, 0=non-select). | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
**/ | |
#define PAL_BUS_SET_FEATURES 10 | |
/** | |
PAL Procedure - PAL_DEBUG_INFO. | |
Return the number of instruction and data breakpoint | |
registers. It is required by Itanium processors. The | |
PAL procedure supports the Static Registers calling | |
convention. It could be called at physical mode and virtual | |
mode. | |
@param Index Index of PAL_DEBUG_INFO within the list of PAL | |
procedures. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Unsigned 64-bit integer denoting the number of | |
pairs of instruction debug registers implemented | |
by the processor. | |
@return R10 Unsigned 64-bit integer denoting the number of | |
pairs of data debug registers implemented by the | |
processor. | |
**/ | |
#define PAL_DEBUG_INFO 11 | |
/** | |
PAL Procedure - PAL_FIXED_ADDR. | |
Return the fixed component of a processor's directed address. | |
It is required by Itanium processors. The PAL | |
procedure supports the Static Registers calling convention. It | |
could be called at physical mode and virtual mode. | |
@param Index Index of PAL_FIXED_ADDR within the list of PAL | |
procedures. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Fixed geographical address of this processor. | |
**/ | |
#define PAL_FIXED_ADDR 12 | |
/** | |
PAL Procedure - PAL_FREQ_BASE. | |
Return the frequency of the output clock for use by the | |
platform, if generated by the processor. It is optinal. The | |
PAL procedure supports the Static Registers calling | |
convention. It could be called at physical mode and virtual | |
mode. | |
@param Index Index of PAL_FREQ_BASE within the list of PAL | |
procedures. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Base frequency of the platform if generated by the | |
processor chip. | |
**/ | |
#define PAL_FREQ_BASE 13 | |
/** | |
PAL Procedure - PAL_FREQ_RATIOS. | |
Return ratio of processor, bus, and interval time counter to | |
processor input clock or output clock for platform use, if | |
generated by the processor. It is required by Itanium processors. The PAL | |
procedure supports the Static Registers calling convention. It | |
could be called at physical mode and virtual mode. | |
@param Index Index of PAL_FREQ_RATIOS within the list of PAL | |
procedures. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Ratio of the processor frequency to the input | |
clock of the processor, if the platform clock is | |
generated externally or to the output clock to the | |
platform, if the platform clock is generated by | |
the processor. | |
@return R10 Ratio of the bus frequency to the input clock of | |
the processor, if the platform clock is generated | |
externally or to the output clock to the platform, | |
if the platform clock is generated by the | |
processor. | |
@return R11 Ratio of the interval timer counter rate to input | |
clock of the processor, if the platform clock is | |
generated externally or to the output clock to the | |
platform, if the platform clock is generated by | |
the processor. | |
**/ | |
#define PAL_FREQ_RATIOS 14 | |
typedef struct { | |
UINT64 NumberOfLogicalProcessors:16; ///< Total number of logical | |
///< processors on this physical | |
///< processor package that are | |
///< enabled. | |
UINT64 ThreadsPerCore:8; ///< Number of threads per core. | |
UINT64 Reserved1:8; | |
UINT64 CoresPerProcessor; ///< Total number of cores on this | |
///< physical processor package. | |
UINT64 Reserved2:8; | |
UINT64 PhysicalProcessorPackageId:8; ///< Physical processor package | |
///< identifier which was | |
///< assigned at reset by the | |
///< platform or bus | |
///< controller. This value may | |
///< or may not be unique | |
///< across the entire platform | |
///< since it depends on the | |
///< platform vendor's policy. | |
UINT64 Reserved3:8; | |
} PAL_LOGICAL_PROCESSPR_OVERVIEW; | |
typedef struct { | |
UINT64 ThreadId:16; ///< The thread identifier of the logical | |
///< processor for which information is being | |
///< returned. This value will be unique on a per | |
///< core basis. | |
UINT64 Reserved1:16; | |
UINT64 CoreId:16; ///< The core identifier of the logical processor | |
///< for which information is being returned. | |
///< This value will be unique on a per physical | |
///< processor package basis. | |
UINT64 Reserved2:16; | |
} PAL_LOGICAL_PROCESSORN_INFO1; | |
typedef struct { | |
UINT64 LogicalAddress:16; ///< Geographical address of the logical | |
///< processor for which information is being | |
///< returned. This is the same value that is | |
///< returned by the PAL_FIXED_ADDR procedure | |
///< when it is called on the logical processor. | |
UINT64 Reserved:48; | |
} PAL_LOGICAL_PROCESSORN_INFO2; | |
/** | |
PAL Procedure - PAL_LOGICAL_TO_PHYSICAL. | |
Return information on which logical processors map to a | |
physical processor die. It is optinal. The PAL procedure | |
supports the Static Registers calling convention. It could be | |
called at physical mode and virtual mode. | |
@param Index Index of PAL_LOGICAL_TO_PHYSICAL within the list of PAL | |
procedures. | |
@param ProcessorNumber Signed 64-bit integer that specifies | |
for which logical processor | |
information is being requested. When | |
this input argument is -1, information | |
is returned about the logical | |
processor on which the procedure call | |
is made. This input argument must be | |
in the range of 1 up to one less than | |
the number of logical processors | |
returned by num_log in the | |
log_overview return value. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 The format of PAL_LOGICAL_PROCESSPR_OVERVIEW. | |
@return R10 The format of PAL_LOGICAL_PROCESSORN_INFO1. | |
@return R11 The format of PAL_LOGICAL_PROCESSORN_INFO2. | |
**/ | |
#define PAL_LOGICAL_TO_PHYSICAL 42 | |
typedef struct { | |
UINT64 NumberOfPmcPairs:8; ///< Unsigned 8-bit number defining the | |
///< number of generic PMC/PMD pairs. | |
UINT64 WidthOfCounter:8; ///< Unsigned 8-bit number in the range | |
///< 0:60 defining the number of | |
///< implemented counter bits. | |
UINT64 TypeOfCycleCounting:8; ///< Unsigned 8-bit number defining the | |
///< event type for counting processor cycles. | |
UINT64 TypeOfRetiredInstructionBundle:8; ///< Retired Unsigned 8-bit | |
///< number defining the | |
///< event type for retired | |
///< instruction bundles. | |
UINT64 Reserved:32; | |
} PAL_PERFORMANCE_INFO; | |
/** | |
PAL Procedure - PAL_PERF_MON_INFO. | |
Return the number and type of performance monitors. It is | |
required by Itanium processors. The PAL procedure supports the Static | |
Registers calling convention. It could be called at physical | |
mode and virtual mode. | |
@param Index Index of PAL_PERF_MON_INFO within the list of | |
PAL procedures. | |
@param PerformanceBuffer An address to an 8-byte aligned | |
128-byte memory buffer. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Information about the performance monitors | |
implemented. See PAL_PERFORMANCE_INFO; | |
**/ | |
#define PAL_PERF_MON_INFO 15 | |
#define PAL_PLATFORM_ADDR_INTERRUPT_BLOCK_TOKEN 0x0 | |
#define PAL_PLATFORM_ADDR_IO_BLOCK_TOKEN 0x1 | |
/** | |
PAL Procedure - PAL_PLATFORM_ADDR. | |
Specify processor interrupt block address and I/O port space | |
address. It is required by Itanium processors. The PAL procedure supports the | |
Static Registers calling convention. It could be called at | |
physical mode and virtual mode. | |
@param Index Index of PAL_PLATFORM_ADDR within the list of | |
PAL procedures. | |
@param Type Unsigned 64-bit integer specifying the type of | |
block. 0 indicates that the processor interrupt | |
block pointer should be initialized. 1 indicates | |
that the processor I/O block pointer should be | |
initialized. | |
@param Address Unsigned 64-bit integer specifying the address | |
to which the processor I/O block or interrupt | |
block shall be set. The address must specify | |
an implemented physical address on the | |
processor model, bit 63 is ignored. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure. | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
**/ | |
#define PAL_PLATFORM_ADDR 16 | |
typedef struct { | |
UINT64 Reserved1:36; | |
UINT64 FaultInUndefinedIns:1; ///< Bit36, No Unimplemented | |
///< instruction address reported as | |
///< fault. Denotes how the processor | |
///< reports the detection of | |
///< unimplemented instruction | |
///< addresses. When 1, the processor | |
///< reports an Unimplemented | |
///< Instruction Address fault on the | |
///< unimplemented address; when 0, it | |
///< reports an Unimplemented | |
///< Instruction Address trap on the | |
///< previous instruction in program | |
///< order. This feature may only be | |
///< interrogated by | |
///< PAL_PROC_GET_FEATURES. It may not | |
///< be enabled or disabled by | |
///< PAL_PROC_SET_FEATURES. The | |
///< corresponding argument is ignored. | |
UINT64 NoPresentPmi:1; ///< Bit37, No INIT, PMI, and LINT pins | |
///< present. Denotes the absence of INIT, | |
///< PMI, LINT0 and LINT1 pins on the | |
///< processor. When 1, the pins are absent. | |
///< When 0, the pins are present. This | |
///< feature may only be interrogated by | |
///< PAL_PROC_GET_FEATURES. It may not be | |
///< enabled or disabled by | |
///< PAL_PROC_SET_FEATURES. The corresponding | |
///< argument is ignored. | |
UINT64 NoSimpleImpInUndefinedIns:1; ///< Bit38, No Simple | |
///< implementation of | |
///< unimplemented instruction | |
///< addresses. Denotes how an | |
///< unimplemented instruction | |
///< address is recorded in IIP | |
///< on an Unimplemented | |
///< Instruction Address trap or | |
///< fault. When 1, the full | |
///< unimplemented address is | |
///< recorded in IIP; when 0, the | |
///< address is sign extended | |
///< (virtual addresses) or zero | |
///< extended (physical | |
///< addresses). This feature may | |
///< only be interrogated by | |
///< PAL_PROC_GET_FEATURES. It | |
///< may not be enabled or | |
///< disabled by | |
///< PAL_PROC_SET_FEATURES. The | |
///< corresponding argument is | |
///< ignored. | |
UINT64 NoVariablePState:1; ///< Bit39, No Variable P-state | |
///< performance: A value of 1, indicates | |
///< that a processor implements | |
///< techniques to optimize performance | |
///< for the given P-state power budget | |
///< by dynamically varying the | |
///< frequency, such that maximum | |
///< performance is achieved for the | |
///< power budget. A value of 0, | |
///< indicates that P-states have no | |
///< frequency variation or very small | |
///< frequency variations for their given | |
///< power budget. This feature may only | |
///< be interrogated by | |
///< PAL_PROC_GET_FEATURES. it may not be | |
///< enabled or disabled by | |
///< PAL_PROC_SET_FEATURES. The | |
///< corresponding argument is ignored. | |
UINT64 NoVM:1; ///< Bit40, No Virtual Machine features implemented. | |
///< Denotes whether PSR.vm is implemented. This | |
///< feature may only be interrogated by | |
///< PAL_PROC_GET_FEATURES. It may not be enabled or | |
///< disabled by PAL_PROC_SET_FEATURES. The | |
///< corresponding argument is ignored. | |
UINT64 NoXipXpsrXfs:1; ///< Bit41, No XIP, XPSR, and XFS | |
///< implemented. Denotes whether XIP, XPSR, | |
///< and XFS are implemented for machine | |
///< check recovery. This feature may only be | |
///< interrogated by PAL_PROC_GET_FEATURES. | |
///< It may not be enabled or disabled by | |
///< PAL_PROC_SET_FEATURES. The corresponding | |
///< argument is ignored. | |
UINT64 NoXr1ThroughXr3:1; ///< Bit42, No XR1 through XR3 implemented. | |
///< Denotes whether XR1 XR3 are | |
///< implemented for machine check | |
///< recovery. This feature may only be | |
///< interrogated by PAL_PROC_GET_FEATURES. | |
///< It may not be enabled or disabled by | |
///< PAL_PROC_SET_FEATURES. The | |
///< corresponding argument is ignored. | |
UINT64 DisableDynamicPrediction:1; ///< Bit43, Disable Dynamic | |
///< Predicate Prediction. When | |
///< 0, the processor may predict | |
///< predicate results and | |
///< execute speculatively, but | |
///< may not commit results until | |
///< the actual predicates are | |
///< known. When 1, the processor | |
///< shall not execute predicated | |
///< instructions until the | |
///< actual predicates are known. | |
UINT64 DisableSpontaneousDeferral:1; ///< Bit44, Disable Spontaneous | |
///< Deferral. When 1, the | |
///< processor may optionally | |
///< defer speculative loads | |
///< that do not encounter any | |
///< exception conditions, but | |
///< that trigger other | |
///< implementation-dependent | |
///< conditions (e.g., cache | |
///< miss). When 0, spontaneous | |
///< deferral is disabled. | |
UINT64 DisableDynamicDataCachePrefetch:1; ///< Bit45, Disable Dynamic | |
///< Data Cache Prefetch. | |
///< When 0, the processor | |
///< may prefetch into the | |
///< caches any data which | |
///< has not been accessed | |
///< by instruction | |
///< execution, but which | |
///< is likely to be | |
///< accessed. When 1, no | |
///< data may be fetched | |
///< until it is needed for | |
///< instruction execution | |
///< or is fetched by an | |
///< lfetch instruction. | |
UINT64 DisableDynamicInsCachePrefetch:1; ///< Bit46, Disable | |
///< DynamicInstruction Cache | |
///< Prefetch. When 0, the | |
///< processor may prefetch | |
///< into the caches any | |
///< instruction which has | |
///< not been executed, but | |
///< whose execution is | |
///< likely. When 1, | |
///< instructions may not be | |
///< fetched until needed or | |
///< hinted for execution. | |
///< (Prefetch for a hinted | |
///< branch is allowed even | |
///< when dynamic instruction | |
///< cache prefetch is | |
///< disabled.) | |
UINT64 DisableBranchPrediction:1; ///< Bit47, Disable Dynamic branch | |
///< prediction. When 0, the | |
///< processor may predict branch | |
///< targets and speculatively | |
///< execute, but may not commit | |
///< results. When 1, the processor | |
///< must wait until branch targets | |
///< are known to execute. | |
UINT64 Reserved2:4; | |
UINT64 DisablePState:1; ///< Bit52, Disable P-states. When 1, the PAL | |
///< P-state procedures (PAL_PSTATE_INFO, | |
///< PAL_SET_PSTATE, PAL_GET_PSTATE) will | |
///< return with a status of -1 | |
///< (Unimplemented procedure). | |
UINT64 EnableMcaOnDataPoisoning:1; ///< Bit53, Enable MCA signaling | |
///< on data-poisoning event | |
///< detection. When 0, a CMCI | |
///< will be signaled on error | |
///< detection. When 1, an MCA | |
///< will be signaled on error | |
///< detection. If this feature | |
///< is not supported, then the | |
///< corresponding argument is | |
///< ignored when calling | |
///< PAL_PROC_SET_FEATURES. Note | |
///< that the functionality of | |
///< this bit is independent of | |
///< the setting in bit 60 | |
///< (Enable CMCI promotion), and | |
///< that the bit 60 setting does | |
///< not affect CMCI signaling | |
///< for data-poisoning related | |
///< events. Volume 2: Processor | |
///< Abstraction Layer 2:431 | |
///< PAL_PROC_GET_FEATURES | |
UINT64 EnableVmsw:1; ///< Bit54, Enable the use of the vmsw | |
///< instruction. When 0, the vmsw instruction | |
///< causes a Virtualization fault when | |
///< executed at the most privileged level. | |
///< When 1, this bit will enable normal | |
///< operation of the vmsw instruction. | |
UINT64 EnableEnvNotification:1; ///< Bit55, Enable external | |
///< notification when the processor | |
///< detects hardware errors caused | |
///< by environmental factors that | |
///< could cause loss of | |
///< deterministic behavior of the | |
///< processor. When 1, this bit will | |
///< enable external notification, | |
///< when 0 external notification is | |
///< not provided. The type of | |
///< external notification of these | |
///< errors is processor-dependent. A | |
///< loss of processor deterministic | |
///< behavior is considered to have | |
///< occurred if these | |
///< environmentally induced errors | |
///< cause the processor to deviate | |
///< from its normal execution and | |
///< eventually causes different | |
///< behavior which can be observed | |
///< at the processor bus pins. | |
///< Processor errors that do not | |
///< have this effects (i.e., | |
///< software induced machine checks) | |
///< may or may not be promoted | |
///< depending on the processor | |
///< implementation. | |
UINT64 DisableBinitWithTimeout:1; ///< Bit56, Disable a BINIT on | |
///< internal processor time-out. | |
///< When 0, the processor may | |
///< generate a BINIT on an | |
///< internal processor time-out. | |
///< When 1, the processor will not | |
///< generate a BINIT on an | |
///< internal processor time-out. | |
///< The event is silently ignored. | |
UINT64 DisableDPM:1; ///< Bit57, Disable Dynamic Power Management | |
///< (DPM). When 0, the hardware may reduce | |
///< power consumption by removing the clock | |
///< input from idle functional units. When 1, | |
///< all functional units will receive clock | |
///< input, even when idle. | |
UINT64 DisableCoherency:1; ///< Bit58, Disable Coherency. When 0, | |
///< the processor uses normal coherency | |
///< requests and responses. When 1, the | |
///< processor answers all requests as if | |
///< the line were not present. | |
UINT64 DisableCache:1; ///< Bit59, Disable Cache. When 0, the | |
///< processor performs cast outs on | |
///< cacheable pages and issues and responds | |
///< to coherency requests normally. When 1, | |
///< the processor performs a memory access | |
///< for each reference regardless of cache | |
///< contents and issues no coherence | |
///< requests and responds as if the line | |
///< were not present. Cache contents cannot | |
///< be relied upon when the cache is | |
///< disabled. WARNING: Semaphore | |
///< instructions may not be atomic or may | |
///< cause Unsupported Data Reference faults | |
///< if caches are disabled. | |
UINT64 EnableCmciPromotion:1; ///< Bit60, Enable CMCI promotion When | |
///< 1, Corrected Machine Check | |
///< Interrupts (CMCI) are promoted to | |
///< MCAs. They are also further | |
///< promoted to BERR if bit 39, Enable | |
///< MCA promotion, is also set and | |
///< they are promoted to BINIT if bit | |
///< 38, Enable MCA to BINIT promotion, | |
///< is also set. This bit has no | |
///< effect if MCA signalling is | |
///< disabled (see | |
///< PAL_BUS_GET/SET_FEATURES) | |
UINT64 EnableMcaToBinitPromotion:1; ///< Bit61, Enable MCA to BINIT | |
///< promotion. When 1, machine | |
///< check aborts (MCAs) are | |
///< promoted to the Bus | |
///< Initialization signal, and | |
///< the BINIT pin is assert on | |
///< each occurrence of an MCA. | |
///< Setting this bit has no | |
///< effect if BINIT signalling | |
///< is disabled. (See | |
///< PAL_BUS_GET/SET_FEATURES) | |
UINT64 EnableMcaPromotion:1; ///< Bit62, Enable MCA promotion. When | |
///< 1, machine check aborts (MCAs) are | |
///< promoted to the Bus Error signal, | |
///< and the BERR pin is assert on each | |
///< occurrence of an MCA. Setting this | |
///< bit has no effect if BERR | |
///< signalling is disabled. (See | |
///< PAL_BUS_GET/SET_FEATURES) | |
UINT64 EnableBerrPromotion:1; ///< Bit63. Enable BERR promotion. When | |
///< 1, the Bus Error (BERR) signal is | |
///< promoted to the Bus Initialization | |
///< (BINIT) signal, and the BINIT pin | |
///< is asserted on the occurrence of | |
///< each Bus Error. Setting this bit | |
///< has no effect if BINIT signalling | |
///< is disabled. (See | |
///< PAL_BUS_GET/SET_FEATURES) | |
} PAL_PROCESSOR_FEATURES; | |
/** | |
PAL Procedure - PAL_PROC_GET_FEATURES. | |
Return configurable processor features and their current | |
setting. It is required by Itanium processors. The PAL procedure supports the | |
Static Registers calling convention. It could be called at | |
physical mode and virtual mode. | |
@param Index Index of PAL_PROC_GET_FEATURES within the list of | |
PAL procedures. | |
@param Reserved Reserved parameter. | |
@param FeatureSet Feature set information is being requested | |
for. | |
@retval 1 Call completed without error; The | |
feature_set passed is not supported but a | |
feature_set of a larger value is supported. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -8 feature_set passed is beyond the maximum | |
feature_set supported | |
@return R9 64-bit vector of features implemented. See | |
PAL_PROCESSOR_FEATURES. | |
@return R10 64-bit vector of current feature settings. See | |
PAL_PROCESSOR_FEATURES. | |
@return R11 64-bit vector of features controllable by | |
software. | |
**/ | |
#define PAL_PROC_GET_FEATURES 17 | |
/** | |
PAL Procedure - PAL_PROC_SET_FEATURES. | |
Enable or disable configurable processor features. It is | |
required by Itanium processors. The PAL procedure supports the Static | |
Registers calling convention. It could be called at physical | |
mode. | |
@param Index Index of PAL_PROC_SET_FEATURES within the list of | |
PAL procedures. | |
@param FeatureSelect 64-bit vector denoting desired state of | |
each feature (1=select, 0=non-select). | |
@param FeatureSet Feature set to apply changes to. See | |
PAL_PROC_GET_FEATURES for more information | |
on feature sets. | |
@retval 1 Call completed without error; The | |
feature_set passed is not supported but a | |
feature_set of a larger value is supported | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -8 feature_set passed is beyond the maximum | |
feature_set supported | |
**/ | |
#define PAL_PROC_SET_FEATURES 18 | |
// | |
// Value of PAL_REGISTER_INFO.InfoRequest. | |
// | |
#define PAL_APPLICATION_REGISTER_IMPLEMENTED 0 | |
#define PAL_APPLICATION_REGISTER_READABLE 1 | |
#define PAL_CONTROL_REGISTER_IMPLEMENTED 2 | |
#define PAL_CONTROL_REGISTER_READABLE 3 | |
/** | |
PAL Procedure - PAL_REGISTER_INFO. | |
Return AR and CR register information. It is required by Itanium processors. | |
The PAL procedure supports the Static Registers calling | |
convention. It could be called at physical mode and virtual | |
mode. | |
@param Index Index of PAL_REGISTER_INFO within the list of | |
PAL procedures. | |
@param InfoRequest Unsigned 64-bit integer denoting what | |
register information is requested. See | |
PAL_REGISTER_INFO.InfoRequest above. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 64-bit vector denoting information for registers | |
0-63. Bit 0 is register 0, bit 63 is register 63. | |
@return R10 64-bit vector denoting information for registers | |
64-127. Bit 0 is register 64, bit 63 is register | |
127. | |
**/ | |
#define PAL_REGISTER_INFO 39 | |
/** | |
PAL Procedure - PAL_RSE_INFO. | |
Return RSE information. It is required by Itanium processors. The PAL | |
procedure supports the Static Registers calling convention. It | |
could be called at physical mode and virtual mode. | |
@param Index Index of PAL_RSE_INFO within the list of | |
PAL procedures. | |
@param InfoRequest Unsigned 64-bit integer denoting what | |
register information is requested. See | |
PAL_REGISTER_INFO.InfoRequest above. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Number of physical stacked general registers. | |
@return R10 RSE hints supported by processor. | |
**/ | |
#define PAL_RSE_INFO 19 | |
typedef struct { | |
UINT64 VersionOfPalB:16; ///< Is a 16-bit binary coded decimal (BCD) | |
///< number that provides identification | |
///< information about the PAL_B firmware. | |
UINT64 Reserved1:8; | |
UINT64 PalVendor:8; ///< Is an unsigned 8-bit integer indicating the | |
///< vendor of the PAL code. | |
UINT64 VersionOfPalA:16; ///< Is a 16-bit binary coded decimal (BCD) | |
///< number that provides identification | |
///< information about the PAL_A firmware. In | |
///< the split PAL_A model, this return value | |
///< is the version number of the | |
///< processor-specific PAL_A. The generic | |
///< PAL_A version is not returned by this | |
///< procedure in the split PAL_A model. | |
UINT64 Reserved2:16; | |
} PAL_VERSION_INFO; | |
/** | |
PAL Procedure - PAL_VERSION. | |
Return version of PAL code. It is required by Itanium processors. The PAL | |
procedure supports the Static Registers calling convention. It | |
could be called at physical mode and virtual mode. | |
@param Index Index of PAL_VERSION within the list of | |
PAL procedures. | |
@param InfoRequest Unsigned 64-bit integer denoting what | |
register information is requested. See | |
PAL_REGISTER_INFO.InfoRequest above. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 8-byte formatted value returning the minimum PAL | |
version needed for proper operation of the | |
processor. See PAL_VERSION_INFO above. | |
@return R10 8-byte formatted value returning the current PAL | |
version running on the processor. See | |
PAL_VERSION_INFO above. | |
**/ | |
#define PAL_VERSION 20 | |
// | |
// Vectors of PAL_MC_CLEAR_LOG.pending | |
// | |
#define PAL_MC_PENDING BIT0 | |
#define PAL_INIT_PENDING BIT1 | |
/** | |
PAL Procedure - PAL_MC_CLEAR_LOG. | |
Clear all error information from processor error logging | |
registers. It is required by Itanium processors. The PAL procedure supports | |
the Static Registers calling convention. It could be called at | |
physical mode and virtual mode. | |
@param Index Index of PAL_MC_CLEAR_LOG within the list of | |
PAL procedures. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 64-bit vector denoting whether an event is | |
pending. See PAL_MC_CLEAR_LOG.pending above. | |
**/ | |
#define PAL_MC_CLEAR_LOG 21 | |
/** | |
PAL Procedure - PAL_MC_DRAIN. | |
Ensure that all operations that could cause an MCA have | |
completed. It is required by Itanium processors. The PAL procedure supports | |
the Static Registers calling convention. It could be called at | |
physical mode and virtual mode. | |
@param Index Index of PAL_MC_DRAIN within the list of PAL | |
procedures. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
**/ | |
#define PAL_MC_DRAIN 22 | |
/** | |
PAL Procedure - PAL_MC_DYNAMIC_STATE. | |
Return Processor Dynamic State for logging by SAL. It is | |
optional. The PAL procedure supports the Static Registers | |
calling convention. It could be called at physical mode. | |
@param Index Index of PAL_MC_DYNAMIC_STATE within the list of PAL | |
procedures. | |
@param Offset Offset of the next 8 bytes of Dynamic Processor | |
State to return. (multiple of 8). | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure. | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Unsigned 64-bit integer denoting bytes of Dynamic | |
Processor State returned. | |
@return R10 Next 8 bytes of Dynamic Processor State. | |
**/ | |
#define PAL_MC_DYNAMIC_STATE 24 | |
// | |
// Values of PAL_MC_ERROR_INFO.InfoIndex. | |
// | |
#define PAL_PROCESSOR_ERROR_MAP 0 | |
#define PAL_PROCESSOR_STATE_PARAM 1 | |
#define PAL_STRUCTURE_SPECIFIC_ERROR 2 | |
typedef struct { | |
UINT64 CoreId:4; ///< Bit3:0, Processor core ID (default is 0 for | |
///< processors with a single core) | |
UINT64 ThreadId:4; ///< Bit7:4, Logical thread ID (default is 0 for | |
///< processors that execute a single thread) | |
UINT64 InfoOfInsCache:4; ///< Bit11:8, Error information is | |
///< available for 1st, 2nd, 3rd, and 4th | |
///< level instruction caches. | |
UINT64 InfoOfDataCache:4; ///< Bit15:12, Error information is | |
///< available for 1st, 2nd, 3rd, and 4th | |
///< level data/unified caches. | |
UINT64 InfoOfInsTlb:4; ///< Bit19:16 Error information is available | |
///< for 1st, 2nd, 3rd, and 4th level | |
///< instruction TLB. | |
UINT64 InfoOfDataTlb:4; ///< Bit23:20, Error information is available | |
///< for 1st, 2nd, 3rd, and 4th level | |
///< data/unified TLB | |
UINT64 InfoOfProcessorBus:4; ///< Bit27:24 Error information is | |
///< available for the 1st, 2nd, 3rd, | |
///< and 4th level processor bus | |
///< hierarchy. | |
UINT64 InfoOfRegisterFile:4; ///< Bit31:28 Error information is | |
///< available on register file | |
///< structures. | |
UINT64 InfoOfMicroArch:4; ///< Bit47:32, Error information is | |
///< available on micro-architectural | |
///< structures. | |
UINT64 Reserved:16; | |
} PAL_MC_ERROR_INFO_LEVEL_INDEX; | |
// | |
// Value of PAL_MC_ERROR_INFO.ErrorTypeIndex | |
// | |
#define PAL_ERR_INFO_BY_LEVEL_INDEX 0 | |
#define PAL_ERR_INFO_TARGET_ADDRESS 1 | |
#define PAL_ERR_INFO_REQUESTER_IDENTIFIER 2 | |
#define PAL_ERR_INFO_REPONSER_INDENTIFIER 3 | |
#define PAL_ERR_INFO_PRECISE_INSTRUCTION_POINTER 4 | |
typedef struct { | |
UINT64 Operation:4; ///< Bit3:0, Type of cache operation that caused | |
///< the machine check: 0 - unknown or internal | |
///< error 1 - load 2 - store 3 - instruction | |
///< fetch or instruction prefetch 4 - data | |
///< prefetch (both hardware and software) 5 - | |
///< snoop (coherency check) 6 - cast out | |
///< (explicit or implicit write-back of a cache | |
///< line) 7 - move in (cache line fill) | |
UINT64 FailedCacheLevel:2; ///< Bit5:4 Level of cache where the | |
///< error occurred. A value of 0 | |
///< indicates the first level of cache. | |
UINT64 Reserved1:2; | |
UINT64 FailedInDataPart:1; ///< Bit8, Failure located in the data part of the cache line. | |
UINT64 FailedInTagPart:1; ///< Bit9, Failure located in the tag part of the cache line. | |
UINT64 FailedInDataCache:1; ///< Bit10, Failure located in the data cache | |
UINT64 FailedInInsCache:1; ///< Bit11, Failure located in the | |
///< instruction cache. | |
UINT64 Mesi:3; ///< Bit14:12, 0 - cache line is invalid. 1 - cache | |
///< line is held shared. 2 - cache line is held | |
///< exclusive. 3 - cache line is modified. All other | |
///< values are reserved. | |
UINT64 MesiIsValid:1; ///< Bit15, The mesi field in the cache_check | |
///< parameter is valid. | |
UINT64 FailedWay:5; ///< Bit20:16, Failure located in the way of | |
///< the cache indicated by this value. | |
UINT64 WayIndexIsValid:1; ///< Bit21, The way and index field in the | |
///< cache_check parameter is valid. | |
UINT64 Reserved2:1; | |
UINT64 MultipleBitsError:1; ///< Bit23, A multiple-bit error was | |
///< detected, and data was poisoned for | |
///< the corresponding cache line during | |
///< castout. | |
UINT64 Reserved3:8; | |
UINT64 IndexOfCacheLineError:20; ///< Bit51:32, Index of the cache | |
///< line where the error occurred. | |
UINT64 Reserved4:2; | |
UINT64 InstructionSet:1; ///< Bit54, Instruction set. If this value | |
///< is set to zero, the instruction that | |
///< generated the machine check was an | |
///< Intel Itanium instruction. If this bit | |
///< is set to one, the instruction that | |
///< generated the machine check was IA-32 | |
///< instruction. | |
UINT64 InstructionSetIsValid:1; ///< Bit55, The is field in the | |
///< cache_check parameter is valid. | |
UINT64 PrivilegeLevel:2; ///< Bit57:56, Privilege level. The | |
///< privilege level of the instruction | |
///< bundle responsible for generating the | |
///< machine check. | |
UINT64 PrivilegeLevelIsValide:1; ///< Bit58, The pl field of the | |
///< cache_check parameter is | |
///< valid. | |
UINT64 McCorrected:1; ///< Bit59, Machine check corrected: This bit | |
///< is set to one to indicate that the machine | |
///< check has been corrected. | |
UINT64 TargetAddressIsValid:1; ///< Bit60, Target address is valid: | |
///< This bit is set to one to | |
///< indicate that a valid target | |
///< address has been logged. | |
UINT64 RequesterIdentifier:1; ///< Bit61, Requester identifier: This | |
///< bit is set to one to indicate that | |
///< a valid requester identifier has | |
///< been logged. | |
UINT64 ResponserIdentifier:1; ///< Bit62, Responder identifier: This | |
///< bit is set to one to indicate that | |
///< a valid responder identifier has | |
///< been logged. | |
UINT64 PreciseInsPointer:1; ///< Bit63, Precise instruction pointer. | |
///< This bit is set to one to indicate | |
///< that a valid precise instruction | |
///< pointer has been logged. | |
} PAL_CACHE_CHECK_INFO; | |
typedef struct { | |
UINT64 FailedSlot:8; ///< Bit7:0, Slot number of the translation | |
///< register where the failure occurred. | |
UINT64 FailedSlotIsValid:1; ///< Bit8, The tr_slot field in the | |
///< TLB_check parameter is valid. | |
UINT64 Reserved1 :1; | |
UINT64 TlbLevel:2; ///< Bit11:10, The level of the TLB where the | |
///< error occurred. A value of 0 indicates the | |
///< first level of TLB | |
UINT64 Reserved2 :4; | |
UINT64 FailedInDataTr:1; ///< Bit16, Error occurred in the data | |
///< translation registers. | |
UINT64 FailedInInsTr:1; ///< Bit17, Error occurred in the instruction | |
///< translation registers | |
UINT64 FailedInDataTc:1; ///< Bit18, Error occurred in data | |
///< translation cache. | |
UINT64 FailedInInsTc:1; ///< Bit19, Error occurred in the instruction | |
///< translation cache. | |
UINT64 FailedOperation:4; ///< Bit23:20, Type of cache operation that | |
///< caused the machine check: 0 - unknown | |
///< 1 - TLB access due to load instruction | |
///< 2 - TLB access due to store | |
///< instruction 3 - TLB access due to | |
///< instruction fetch or instruction | |
///< prefetch 4 - TLB access due to data | |
///< prefetch (both hardware and software) | |
///< 5 - TLB shoot down access 6 - TLB | |
///< probe instruction (probe, tpa) 7 - | |
///< move in (VHPT fill) 8 - purge (insert | |
///< operation that purges entries or a TLB | |
///< purge instruction) All other values | |
///< are reserved. | |
UINT64 Reserved3:30; | |
UINT64 InstructionSet:1; ///< Bit54, Instruction set. If this value | |
///< is set to zero, the instruction that | |
///< generated the machine check was an | |
///< Intel Itanium instruction. If this bit | |
///< is set to one, the instruction that | |
///< generated the machine check was IA-32 | |
///< instruction. | |
UINT64 InstructionSetIsValid:1; ///< Bit55, The is field in the | |
///< TLB_check parameter is valid. | |
UINT64 PrivelegeLevel:2; ///< Bit57:56, Privilege level. The | |
///< privilege level of the instruction | |
///< bundle responsible for generating the | |
///< machine check. | |
UINT64 PrivelegeLevelIsValid:1; ///< Bit58, The pl field of the | |
///< TLB_check parameter is valid. | |
UINT64 McCorrected:1; ///< Bit59, Machine check corrected: This bit | |
///< is set to one to indicate that the machine | |
///< check has been corrected. | |
UINT64 TargetAddressIsValid:1; ///< Bit60, Target address is valid: | |
///< This bit is set to one to | |
///< indicate that a valid target | |
///< address has been logged. | |
UINT64 RequesterIdentifier:1; ///< Bit61 Requester identifier: This | |
///< bit is set to one to indicate that | |
///< a valid requester identifier has | |
///< been logged. | |
UINT64 ResponserIdentifier:1; ///< Bit62, Responder identifier: This | |
///< bit is set to one to indicate that | |
///< a valid responder identifier has | |
///< been logged. | |
UINT64 PreciseInsPointer:1; ///< Bit63 Precise instruction pointer. | |
///< This bit is set to one to indicate | |
///< that a valid precise instruction | |
///< pointer has been logged. | |
} PAL_TLB_CHECK_INFO; | |
/** | |
PAL Procedure - PAL_MC_ERROR_INFO. | |
Return Processor Machine Check Information and Processor | |
Static State for logging by SAL. It is required by Itanium processors. The | |
PAL procedure supports the Static Registers calling | |
convention. It could be called at physical and virtual mode. | |
@param Index Index of PAL_MC_ERROR_INFO within the list of PAL | |
procedures. | |
@param InfoIndex Unsigned 64-bit integer identifying the | |
error information that is being requested. | |
See PAL_MC_ERROR_INFO.InfoIndex. | |
@param LevelIndex 8-byte formatted value identifying the | |
structure to return error information | |
on. See PAL_MC_ERROR_INFO_LEVEL_INDEX. | |
@param ErrorTypeIndex Unsigned 64-bit integer denoting the | |
type of error information that is | |
being requested for the structure | |
identified in LevelIndex. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -6 Argument was valid, but no error | |
information was available | |
@return R9 Error information returned. The format of this | |
value is dependant on the input values passed. | |
@return R10 If this value is zero, all the error information | |
specified by err_type_index has been returned. If | |
this value is one, more structure-specific error | |
information is available and the caller needs to | |
make this procedure call again with level_index | |
unchanged and err_type_index, incremented. | |
**/ | |
#define PAL_MC_ERROR_INFO 25 | |
/** | |
PAL Procedure - PAL_MC_EXPECTED. | |
Set/Reset Expected Machine Check Indicator. It is required by | |
Itanium processors. The PAL procedure supports the Static Registers calling | |
convention. It could be called at physical mode. | |
@param Index Index of PAL_MC_EXPECTED within the list of PAL | |
procedures. | |
@param Expected Unsigned integer with a value of 0 or 1 to | |
set or reset the hardware resource | |
PALE_CHECK examines for expected machine | |
checks. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Unsigned integer denoting whether a machine check | |
was previously expected. | |
**/ | |
#define PAL_MC_EXPECTED 23 | |
/** | |
PAL Procedure - PAL_MC_REGISTER_MEM. | |
Register min-state save area with PAL for machine checks and | |
inits. It is required by Itanium processors. The PAL procedure supports the | |
Static Registers calling convention. It could be called at | |
physical mode. | |
@param Index Index of PAL_MC_REGISTER_MEM within the list of PAL | |
procedures. | |
@param Address Physical address of the buffer to be | |
registered with PAL. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
**/ | |
#define PAL_MC_REGISTER_MEM 27 | |
/** | |
PAL Procedure - PAL_MC_RESUME. | |
Restore minimal architected state and return to interrupted | |
process. It is required by Itanium processors. The PAL procedure supports the | |
Static Registers calling convention. It could be called at | |
physical mode. | |
@param Index Index of PAL_MC_RESUME within the list of PAL | |
procedures. | |
@param SetCmci Unsigned 64 bit integer denoting whether to | |
set the CMC interrupt. A value of 0 indicates | |
not to set the interrupt, a value of 1 | |
indicated to set the interrupt, and all other | |
values are reserved. | |
@param SavePtr Physical address of min-state save area used | |
to used to restore processor state. | |
@param NewContext Unsigned 64-bit integer denoting whether | |
the caller is returning to a new context. | |
A value of 0 indicates the caller is | |
returning to the interrupted context, a | |
value of 1 indicates that the caller is | |
returning to a new context. | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
**/ | |
#define PAL_MC_RESUME 26 | |
/** | |
PAL Procedure - PAL_HALT. | |
Enter the low-power HALT state or an implementation-dependent | |
low-power state. It is optinal. The PAL procedure supports the | |
Static Registers calling convention. It could be called at | |
physical mode. | |
@param Index Index of PAL_HALT within the list of PAL | |
procedures. | |
@param HaltState Unsigned 64-bit integer denoting low power | |
state requested. | |
@param IoDetailPtr 8-byte aligned physical address pointer to | |
information on the type of I/O | |
(load/store) requested. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Value returned if a load instruction is requested | |
in the io_detail_ptr | |
**/ | |
#define PAL_HALT 28 | |
/** | |
PAL Procedure - PAL_HALT_INFO. | |
Return the low power capabilities of the processor. It is | |
required by Itanium processors. The PAL procedure supports the | |
Stacked Registers calling convention. It could be called at | |
physical and virtual mode. | |
@param Index Index of PAL_HALT_INFO within the list of PAL | |
procedures. | |
@param PowerBuffer 64-bit pointer to a 64-byte buffer aligned | |
on an 8-byte boundary. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
**/ | |
#define PAL_HALT_INFO 257 | |
/** | |
PAL Procedure - PAL_HALT_LIGHT. | |
Enter the low power LIGHT HALT state. It is required by | |
Itanium processors. The PAL procedure supports the Static Registers calling | |
convention. It could be called at physical and virtual mode. | |
@param Index Index of PAL_HALT_LIGHT within the list of PAL | |
procedures. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
**/ | |
#define PAL_HALT_LIGHT 29 | |
/** | |
PAL Procedure - PAL_CACHE_LINE_INIT. | |
Initialize tags and data of a cache line for processor | |
testing. It is required by Itanium processors. The PAL procedure supports the | |
Static Registers calling convention. It could be called at | |
physical and virtual mode. | |
@param Index Index of PAL_CACHE_LINE_INIT within the list of PAL | |
procedures. | |
@param Address Unsigned 64-bit integer value denoting the | |
physical address from which the physical page | |
number is to be generated. The address must be | |
an implemented physical address, bit 63 must | |
be zero. | |
@param DataValue 64-bit data value which is used to | |
initialize the cache line. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
**/ | |
#define PAL_CACHE_LINE_INIT 31 | |
/** | |
PAL Procedure - PAL_CACHE_READ. | |
Read tag and data of a cache line for diagnostic testing. It | |
is optional. The PAL procedure supports the | |
Satcked Registers calling convention. It could be called at | |
physical mode. | |
@param Index Index of PAL_CACHE_READ within the list of PAL | |
procedures. | |
@param LineId 8-byte formatted value describing where in the | |
cache to read the data. | |
@param Address 64-bit 8-byte aligned physical address from | |
which to read the data. The address must be an | |
implemented physical address on the processor | |
model with bit 63 set to zero. | |
@retval 1 The word at address was found in the | |
cache, but the line was invalid. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -5 The word at address was not found in the | |
cache. | |
@retval -7 The operation requested is not supported | |
for this cache_type and level. | |
@return R9 Right-justified value returned from the cache | |
line. | |
@return R10 The number of bits returned in data. | |
@return R11 The status of the cache line. | |
**/ | |
#define PAL_CACHE_READ 259 | |
/** | |
PAL Procedure - PAL_CACHE_WRITE. | |
Write tag and data of a cache for diagnostic testing. It is | |
optional. The PAL procedure supports the Satcked Registers | |
calling convention. It could be called at physical mode. | |
@param Index Index of PAL_CACHE_WRITE within the list of PAL | |
procedures. | |
@param LineId 8-byte formatted value describing where in the | |
cache to write the data. | |
@param Address 64-bit 8-byte aligned physical address at | |
which the data should be written. The address | |
must be an implemented physical address on the | |
processor model with bit 63 set to 0. | |
@param Data Unsigned 64-bit integer value to write into | |
the specified part of the cache. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -7 The operation requested is not supported | |
for this cache_type and level. | |
**/ | |
#define PAL_CACHE_WRITE 260 | |
/** | |
PAL Procedure - PAL_TEST_INFO. | |
Returns alignment and size requirements needed for the memory | |
buffer passed to the PAL_TEST_PROC procedure as well as | |
information on self-test control words for the processor self | |
tests. It is required by Itanium processors. The PAL procedure supports the | |
Static Registers calling convention. It could be called at | |
physical mode. | |
@param Index Index of PAL_TEST_INFO within the list of PAL | |
procedures. | |
@param TestPhase Unsigned integer that specifies which phase | |
of the processor self-test information is | |
being requested on. A value of 0 indicates | |
the phase two of the processor self-test and | |
a value of 1 indicates phase one of the | |
processor self-test. All other values are | |
reserved. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Unsigned 64-bit integer denoting the number of | |
bytes of main memory needed to perform the second | |
phase of processor self-test. | |
@return R10 Unsigned 64-bit integer denoting the alignment | |
required for the memory buffer. | |
@return R11 48-bit wide bit-field indicating if control of | |
the processor self-tests is supported and which | |
bits of the test_control field are defined for | |
use. | |
**/ | |
#define PAL_TEST_INFO 37 | |
typedef struct { | |
UINT64 BufferSize:56; ///< Indicates the size in bytes of the memory | |
///< buffer that is passed to this procedure. | |
///< BufferSize must be greater than or equal in | |
///< size to the bytes_needed return value from | |
///< PAL_TEST_INFO, otherwise this procedure will | |
///< return with an invalid argument return | |
///< value. | |
UINT64 TestPhase:8; ///< Defines which phase of the processor | |
///< self-tests are requested to be run. A value | |
///< of zero indicates to run phase two of the | |
///< processor self-tests. Phase two of the | |
///< processor self-tests are ones that require | |
///< external memory to execute correctly. A | |
///< value of one indicates to run phase one of | |
///< the processor self-tests. Phase one of the | |
///< processor self-tests are tests run during | |
///< PALE_RESET and do not depend on external | |
///< memory to run correctly. When the caller | |
///< requests to have phase one of the processor | |
///< self-test run via this procedure call, a | |
///< memory buffer may be needed to save and | |
///< restore state as required by the PAL calling | |
///< conventions. The procedure PAL_TEST_INFO | |
///< informs the caller about the requirements of | |
///< the memory buffer. | |
} PAL_TEST_INFO_INFO; | |
typedef struct { | |
UINT64 TestControl:47; ///< This is an ordered implementation-specific | |
///< control word that allows the user control | |
///< over the length and runtime of the | |
///< processor self-tests. This control word is | |
///< ordered from the longest running tests up | |
///< to the shortest running tests with bit 0 | |
///< controlling the longest running test. PAL | |
///< may not implement all 47-bits of the | |
///< test_control word. PAL communicates if a | |
///< bit provides control by placing a zero in | |
///< that bit. If a bit provides no control, | |
///< PAL will place a one in it. PAL will have | |
///< two sets of test_control bits for the two | |
///< phases of the processor self-test. PAL | |
///< provides information about implemented | |
///< test_control bits at the hand-off from PAL | |
///< to SAL for the firmware recovery check. | |
///< These test_control bits provide control | |
///< for phase one of processor self-test. It | |
///< also provides this information via the PAL | |
///< procedure call PAL_TEST_INFO for both the | |
///< phase one and phase two processor tests | |
///< depending on which information the caller | |
///< is requesting. PAL interprets these bits | |
///< as input parameters on two occasions. The | |
///< first time is when SAL passes control back | |
///< to PAL after the firmware recovery check. | |
///< The second time is when a call to | |
///< PAL_TEST_PROC is made. When PAL interprets | |
///< these bits it will only interpret | |
///< implemented test_control bits and will | |
///< ignore the values located in the | |
///< unimplemented test_control bits. PAL | |
///< interprets the implemented bits such that | |
///< if a bit contains a zero, this indicates | |
///< to run the test. If a bit contains a one, | |
///< this indicates to PAL to skip the test. If | |
///< the cs bit indicates that control is not | |
///< available, the test_control bits will be | |
///< ignored or generate an illegal argument in | |
///< procedure calls if the caller sets these | |
///< bits. | |
UINT64 ControlSupport:1; ///< This bit defines if an implementation | |
///< supports control of the PAL self-tests | |
///< via the self-test control word. If | |
///< this bit is 0, the implementation does | |
///< not support control of the processor | |
///< self-tests via the self-test control | |
///< word. If this bit is 1, the | |
///< implementation does support control of | |
///< the processor self-tests via the | |
///< self-test control word. If control is | |
///< not supported, GR37 will be ignored at | |
///< the hand-off between SAL and PAL after | |
///< the firmware recovery check and the | |
///< PAL procedures related to the | |
///< processor self-tests may return | |
///< illegal arguments if a user tries to | |
///< use the self-test control features. | |
UINT64 Reserved:16; | |
} PAL_SELF_TEST_CONTROL; | |
typedef struct { | |
UINT64 Attributes:8; ///< Specifies the memory attributes that are | |
///< allowed to be used with the memory buffer | |
///< passed to this procedure. The attributes | |
///< parameter is a vector where each bit | |
///< represents one of the virtual memory | |
///< attributes defined by the architecture.See | |
///< MEMORY_AATRIBUTES. The caller is required | |
///< to support the cacheable attribute for the | |
///< memory buffer, otherwise an invalid | |
///< argument will be returned. | |
UINT64 Reserved:8; | |
UINT64 TestControl:48; ///< Is the self-test control word | |
///< corresponding to the test_phase passed. | |
///< This test_control directs the coverage and | |
///< runtime of the processor self-tests | |
///< specified by the test_phase input | |
///< argument. Information on if this | |
///< feature is implemented and the number of | |
///< bits supported can be obtained by the | |
///< PAL_TEST_INFO procedure call. If this | |
///< feature is implemented by the processor, | |
///< the caller can selectively skip parts of | |
///< the processor self-test by setting | |
///< test_control bits to a one. If a bit has a | |
///< zero, this test will be run. The values in | |
///< the unimplemented bits are ignored. If | |
///< PAL_TEST_INFO indicated that the self-test | |
///< control word is not implemented, this | |
///< procedure will return with an invalid | |
///< argument status if the caller sets any of | |
///< the test_control bits. See | |
///< PAL_SELF_TEST_CONTROL. | |
} PAL_TEST_CONTROL; | |
/** | |
PAL Procedure - PAL_TEST_PROC. | |
Perform late processor self test. It is required by Itanium processors. The | |
PAL procedure supports the Static Registers calling | |
convention. It could be called at physical mode. | |
@param Index Index of PAL_TEST_PROC within the list of PAL | |
procedures. | |
@param TestAddress 64-bit physical address of main memory | |
area to be used by processor self-test. | |
The memory region passed must be | |
cacheable, bit 63 must be zero. | |
@param TestInfo Input argument specifying the size of the | |
memory buffer passed and the phase of the | |
processor self-test that should be run. See | |
PAL_TEST_INFO. | |
@param TestParam Input argument specifying the self-test | |
control word and the allowable memory | |
attributes that can be used with the memory | |
buffer. See PAL_TEST_CONTROL. | |
@retval 1 Call completed without error, but hardware | |
failures occurred during self-test. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Formatted 8-byte value denoting the state of the | |
processor after self-test | |
**/ | |
#define PAL_TEST_PROC 258 | |
typedef struct { | |
UINT32 NumberOfInterruptControllers; ///< Number of interrupt | |
///< controllers currently | |
///< enabled on the system. | |
UINT32 NumberOfProcessors; ///< Number of processors currently | |
///< enabled on the system. | |
} PAL_PLATFORM_INFO; | |
/** | |
PAL Procedure - PAL_COPY_INFO. | |
Return information needed to relocate PAL procedures and PAL | |
PMI code to memory. It is required by Itanium processors. The PAL procedure | |
supports the Static Registers calling convention. It could be | |
called at physical mode. | |
@param Index Index of PAL_COPY_INFO within the list of PAL | |
procedures. | |
@param CopyType Unsigned integer denoting type of procedures | |
for which copy information is requested. | |
@param PlatformInfo 8-byte formatted value describing the | |
number of processors and the number of | |
interrupt controllers currently enabled | |
on the system. See PAL_PLATFORM_INFO. | |
@param McaProcStateInfo Unsigned integer denoting the number | |
of bytes that SAL needs for the | |
min-state save area for each | |
processor. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Unsigned integer denoting the number of bytes of | |
PAL information that must be copied to main | |
memory. | |
@return R10 Unsigned integer denoting the starting alignment | |
of the data to be copied. | |
**/ | |
#define PAL_COPY_INFO 30 | |
/** | |
PAL Procedure - PAL_COPY_PAL. | |
Relocate PAL procedures and PAL PMI code to memory. It is | |
required by Itanium processors. The PAL procedure supports the Stacked | |
Registers calling convention. It could be called at physical | |
mode. | |
@param Index Index of PAL_COPY_PAL within the list of PAL | |
procedures. | |
@param TargetAddress Physical address of a memory buffer to | |
copy relocatable PAL procedures and PAL | |
PMI code. | |
@param AllocSize Unsigned integer denoting the size of the | |
buffer passed by SAL for the copy operation. | |
@param CopyOption Unsigned integer indicating whether | |
relocatable PAL code and PAL PMI code | |
should be copied from firmware address | |
space to main memory. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Unsigned integer denoting the offset of PAL_PROC | |
in the relocatable segment copied. | |
**/ | |
#define PAL_COPY_PAL 256 | |
/** | |
PAL Procedure - PAL_ENTER_IA_32_ENV. | |
Enter IA-32 System environment. It is optional. The PAL | |
procedure supports the Static Registers calling convention. | |
It could be called at physical mode. | |
Note: Since this is a special call, it does not follow the PAL | |
static register calling convention. GR28 contains the index of | |
PAL_ENTER_IA_32_ENV within the list of PAL procedures. All other | |
input arguments including GR29-GR31 are setup by SAL to values | |
as required by the IA-32 operating system defined in Table | |
11-67. The registers that are designated as preserved, scratch, | |
input arguments and procedure return values by the static | |
procedure calling convention are not followed by this call. For | |
instance, GR5 and GR6 need not be preserved since these are | |
regarded as scratch by the IA-32 operating system. Note: In an | |
MP system, this call must be COMPLETED on the first CPU to enter | |
the IA-32 System Environment (may or may not be the BSP) prior | |
to being called on the remaining processors in the MP system. | |
@param Index GR28 contains the index of the | |
PAL_ENTER_IA_32_ENV call within the list of PAL | |
procedures. | |
@retval The status is returned in GR4. | |
-1 - Un-implemented procedure 0 JMPE detected | |
at privilege level | |
0 - 1 SAL allocated buffer for IA-32 System | |
Environment operation is too small | |
2 - IA-32 Firmware Checksum Error | |
3 - SAL allocated buffer for IA-32 System | |
Environment operation is not properly aligned | |
4 - Error in SAL MP Info Table | |
5 - Error in SAL Memory Descriptor Table | |
6 - Error in SAL System Table | |
7 - Inconsistent IA-32 state | |
8 - IA-32 Firmware Internal Error | |
9 - IA-32 Soft Reset (Note: remaining register | |
state is undefined for this termination | |
reason) | |
10 - Machine Check Error | |
11 - Error in SAL I/O Intercept Table | |
12 - Processor exit due to other processor in | |
MP system terminating the IA32 system | |
environment. (Note: remaining register state | |
is undefined for this termination reason.) | |
13 - Itanium architecture-based state | |
corruption by either SAL PMI handler or I/O | |
Intercept callback function. | |
**/ | |
#define PAL_ENTER_IA_32_ENV 33 | |
/** | |
PAL Procedure - PAL_PMI_ENTRYPOINT. | |
Register PMI memory entrypoints with processor. It is required | |
by Itanium processors. The PAL procedure supports the Stacked Registers | |
calling convention. It could be called at physical mode. | |
@param Index Index of PAL_PMI_ENTRYPOINT within the list of | |
PAL procedures. | |
@param SalPmiEntry 256-byte aligned physical address of SAL | |
PMI entrypoint in memory. | |
@retval 0 Call completed without error | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
**/ | |
#define PAL_PMI_ENTRYPOINT 32 | |
/** | |
The ASCII brand identification string will be copied to the | |
address specified in the address input argument. The processor | |
brand identification string is defined to be a maximum of 128 | |
characters long; 127 bytes will contain characters and the 128th | |
byte is defined to be NULL (0). A processor may return less than | |
the 127 ASCII characters as long as the string is null | |
terminated. The string length will be placed in the brand_info | |
return argument. | |
**/ | |
#define PAL_BRAND_INFO_ID_REQUEST 0 | |
/** | |
PAL Procedure - PAL_BRAND_INFO. | |
Provides processor branding information. It is optional by | |
Itanium processors. The PAL procedure supports the Stacked Registers calling | |
convention. It could be called at physical and Virtual mode. | |
@param Index Index of PAL_BRAND_INFO within the list of PAL | |
procedures. | |
@param InfoRequest Unsigned 64-bit integer specifying the | |
information that is being requested. (See | |
PAL_BRAND_INFO_ID_REQUEST) | |
@param Address Unsigned 64-bit integer specifying the | |
address of the 128-byte block to which the | |
processor brand string shall be written. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -6 Input argument is not implemented. | |
@return R9 Brand information returned. The format of this | |
value is dependent on the input values passed. | |
**/ | |
#define PAL_BRAND_INFO 274 | |
/** | |
PAL Procedure - PAL_GET_HW_POLICY. | |
Returns the current hardware resource sharing policy of the | |
processor. It is optional by Itanium processors. The PAL procedure supports | |
the Static Registers calling convention. It could be called at | |
physical and Virtual mode. | |
@param Index Index of PAL_GET_HW_POLICY within the list of PAL | |
procedures. | |
@param ProcessorNumber Unsigned 64-bit integer that specifies | |
for which logical processor | |
information is being requested. This | |
input argument must be zero for the | |
first call to this procedure and can | |
be a maximum value of one less than | |
the number of logical processors | |
impacted by the hardware resource | |
sharing policy, which is returned by | |
the R10 return value. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -9 Call requires PAL memory buffer. | |
@return R9 Unsigned 64-bit integer representing the current | |
hardware resource sharing policy. | |
@return R10 Unsigned 64-bit integer that returns the number | |
of logical processors impacted by the policy | |
input argument. | |
@return R11 Unsigned 64-bit integer containing the logical | |
address of one of the logical processors | |
impacted by policy modification. | |
**/ | |
#define PAL_GET_HW_POLICY 48 | |
// | |
// Value of PAL_SET_HW_POLICY.Policy | |
// | |
#define PAL_SET_HW_POLICY_PERFORMANCE 0 | |
#define PAL_SET_HW_POLICY_FAIRNESS 1 | |
#define PAL_SET_HW_POLICY_HIGH_PRIORITY 2 | |
#define PAL_SET_HW_POLICY_EXCLUSIVE_HIGH_PRIORITY 3 | |
/** | |
PAL Procedure - PAL_SET_HW_POLICY. | |
Sets the current hardware resource sharing policy of the | |
processor. It is optional by Itanium processors. The PAL procedure supports | |
the Static Registers calling convention. It could be called at | |
physical and Virtual mode. | |
@param Index Index of PAL_SET_HW_POLICY within the list of PAL | |
procedures. | |
@param Policy Unsigned 64-bit integer specifying the hardware | |
resource sharing policy the caller is setting. | |
See Value of PAL_SET_HW_POLICY.Policy above. | |
@retval 1 Call completed successfully but could not | |
change the hardware policy since a | |
competing logical processor is set in | |
exclusive high priority. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -9 Call requires PAL memory buffer. | |
**/ | |
#define PAL_SET_HW_POLICY 49 | |
typedef struct { | |
UINT64 Mode:3; ///< Bit2:0, Indicates the mode of operation for this | |
///< procedure: 0 - Query mode 1 - Error inject mode | |
///< (err_inj should also be specified) 2 - Cancel | |
///< outstanding trigger. All other fields in | |
///< PAL_MC_ERROR_TYPE_INFO, | |
///< PAL_MC_ERROR_STRUCTURE_INFO and | |
///< PAL_MC_ERROR_DATA_BUFFER are ignored. All other | |
///< values are reserved. | |
UINT64 ErrorInjection:3; ///< Bit5:3, indicates the mode of error | |
///< injection: 0 - Error inject only (no | |
///< error consumption) 1 - Error inject | |
///< and consume All other values are | |
///< reserved. | |
UINT64 ErrorSeverity:2; ///< Bit7:6, indicates the severity desired | |
///< for error injection/query. Definitions | |
///< of the different error severity types | |
///< 0 - Corrected error 1 - Recoverable | |
///< error 2 - Fatal error 3 - Reserved | |
UINT64 ErrorStructure:5; ///< Bit12:8, Indicates the structure | |
///< identification for error | |
///< injection/query: 0 - Any structure | |
///< (cannot be used during query mode). | |
///< When selected, the structure type used | |
///< for error injection is determined by | |
///< PAL. 1 - Cache 2 - TLB 3 - Register | |
///< file 4 - Bus/System interconnect 5-15 | |
///< - Reserved 16-31 - Processor | |
///< specific error injection | |
///< capabilities.ErrorDataBuffer is used | |
///< to specify error types. Please refer | |
///< to the processor specific | |
///< documentation for additional details. | |
UINT64 StructureHierarchy:3; ///< Bit15:13, Indicates the structure | |
///< hierarchy for error | |
///< injection/query: 0 - Any level of | |
///< hierarchy (cannot be used during | |
///< query mode). When selected, the | |
///< structure hierarchy used for error | |
///< injection is determined by PAL. 1 | |
///< - Error structure hierarchy | |
///< level-1 2 - Error structure | |
///< hierarchy level-2 3 - Error | |
///< structure hierarchy level-3 4 - | |
///< Error structure hierarchy level-4 | |
///< All other values are reserved. | |
///< Reserved 63:16 Reserved | |
UINT64 Reserved:48; | |
} PAL_MC_ERROR_TYPE_INFO; | |
typedef struct { | |
UINT64 StructInfoIsValid:1; ///< Bit0 When 1, indicates that the | |
///< structure information fields | |
///< (c_t,cl_p,cl_id) are valid and | |
///< should be used for error injection. | |
///< When 0, the structure information | |
///< fields are ignored, and the values | |
///< of these fields used for error | |
///< injection are | |
///< implementation-specific. | |
UINT64 CacheType:2; ///< Bit2:1 Indicates which cache should be used | |
///< for error injection: 0 - Reserved 1 - | |
///< Instruction cache 2 - Data or unified cache | |
///< 3 - Reserved | |
UINT64 PortionOfCacheLine:3; ///< Bit5:3 Indicates the portion of the | |
///< cache line where the error should | |
///< be injected: 0 - Reserved 1 - Tag | |
///< 2 - Data 3 - mesi All other | |
///< values are reserved. | |
UINT64 Mechanism:3; ///< Bit8:6 Indicates which mechanism is used to | |
///< identify the cache line to be used for error | |
///< injection: 0 - Reserved 1 - Virtual address | |
///< provided in the inj_addr field of the buffer | |
///< pointed to by err_data_buffer should be used | |
///< to identify the cache line for error | |
///< injection. 2 - Physical address provided in | |
///< the inj_addr field of the buffer pointed to | |
///< by err_data_buffershould be used to identify | |
///< the cache line for error injection. 3 - way | |
///< and index fields provided in err_data_buffer | |
///< should be used to identify the cache line | |
///< for error injection. All other values are | |
///< reserved. | |
UINT64 DataPoisonOfCacheLine:1; ///< Bit9 When 1, indicates that a | |
///< multiple bit, non-correctable | |
///< error should be injected in the | |
///< cache line specified by cl_id. | |
///< If this injected error is not | |
///< consumed, it may eventually | |
///< cause a data-poisoning event | |
///< resulting in a corrected error | |
///< signal, when the associated | |
///< cache line is cast out (implicit | |
///< or explicit write-back of the | |
///< cache line). The error severity | |
///< specified by err_sev in | |
///< err_type_info must be set to 0 | |
///< (corrected error) when this bit | |
///< is set. | |
UINT64 Reserved1:22; | |
UINT64 TrigerInfoIsValid:1; ///< Bit32 When 1, indicates that the | |
///< trigger information fields (trigger, | |
///< trigger_pl) are valid and should be | |
///< used for error injection. When 0, | |
///< the trigger information fields are | |
///< ignored and error injection is | |
///< performed immediately. | |
UINT64 Triger:4; ///< Bit36:33 Indicates the operation type to be | |
///< used as the error trigger condition. The | |
///< address corresponding to the trigger is | |
///< specified in the trigger_addr field of the | |
///< buffer pointed to by err_data_buffer: 0 - | |
///< Instruction memory access. The trigger match | |
///< conditions for this operation type are similar | |
///< to the IBR address breakpoint match conditions | |
///< 1 - Data memory access. The trigger match | |
///< conditions for this operation type are similar | |
///< to the DBR address breakpoint match conditions | |
///< All other values are reserved. | |
UINT64 PrivilegeOfTriger:3; ///< Bit39:37 Indicates the privilege | |
///< level of the context during which | |
///< the error should be injected: 0 - | |
///< privilege level 0 1 - privilege | |
///< level 1 2 - privilege level 2 3 - | |
///< privilege level 3 All other values | |
///< are reserved. If the implementation | |
///< does not support privilege level | |
///< qualifier for triggers (i.e. if | |
///< trigger_pl is 0 in the capabilities | |
///< vector), this field is ignored and | |
///< triggers can be taken at any | |
///< privilege level. | |
UINT64 Reserved2:24; | |
} PAL_MC_ERROR_STRUCT_INFO; | |
/** | |
Buffer Pointed to by err_data_buffer - TLB | |
**/ | |
typedef struct { | |
UINT64 TrigerAddress; | |
UINT64 VirtualPageNumber:52; | |
UINT64 Reserved1:8; | |
UINT64 RegionId:24; | |
UINT64 Reserved2:40; | |
} PAL_MC_ERROR_DATA_BUFFER_TLB; | |
/** | |
PAL Procedure - PAL_MC_ERROR_INJECT. | |
Injects the requested processor error or returns information | |
on the supported injection capabilities for this particular | |
processor implementation. It is optional by Itanium processors. The PAL | |
procedure supports the Stacked Registers calling convention. | |
It could be called at physical and Virtual mode. | |
@param Index Index of PAL_MC_ERROR_INJECT within the list of PAL | |
procedures. | |
@param ErrorTypeInfo Unsigned 64-bit integer specifying the | |
first level error information which | |
identifies the error structure and | |
corresponding structure hierarchy, and | |
the error severity. | |
@param ErrorStructInfo Unsigned 64-bit integer identifying | |
the optional structure specific | |
information that provides the second | |
level details for the requested error. | |
@param ErrorDataBuffer 64-bit physical address of a buffer | |
providing additional parameters for | |
the requested error. The address of | |
this buffer must be 8-byte aligned. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -4 Call completed with error; the requested | |
error could not be injected due to failure in | |
locating the target location in the specified | |
structure. | |
@retval -5 Argument was valid, but requested error | |
injection capability is not supported. | |
@retval -9 Call requires PAL memory buffer. | |
@return R9 64-bit vector specifying the supported error | |
injection capabilities for the input argument | |
combination of struct_hier, err_struct and | |
err_sev fields in ErrorTypeInfo. | |
@return R10 64-bit vector specifying the architectural | |
resources that are used by the procedure. | |
**/ | |
#define PAL_MC_ERROR_INJECT 276 | |
// | |
// Types of PAL_GET_PSTATE.Type | |
// | |
#define PAL_GET_PSTATE_RECENT 0 | |
#define PAL_GET_PSTATE_AVERAGE_NEW_START 1 | |
#define PAL_GET_PSTATE_AVERAGE 2 | |
#define PAL_GET_PSTATE_NOW 3 | |
/** | |
PAL Procedure - PAL_GET_PSTATE. | |
Returns the performance index of the processor. It is optional | |
by Itanium processors. The PAL procedure supports the Stacked Registers | |
calling convention. It could be called at physical and Virtual | |
mode. | |
@param Index Index of PAL_GET_PSTATE within the list of PAL | |
procedures. | |
@param Type Type of performance_index value to be returned | |
by this procedure.See PAL_GET_PSTATE.Type above. | |
@retval 1 Call completed without error, but accuracy | |
of performance index has been impacted by a | |
thermal throttling event, or a | |
hardware-initiated event. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -9 Call requires PAL memory buffer. | |
@return R9 Unsigned integer denoting the processor | |
performance for the time duration since the last | |
PAL_GET_PSTATE procedure call was made. The | |
value returned is between 0 and 100, and is | |
relative to the performance index of the highest | |
available P-state. | |
**/ | |
#define PAL_GET_PSTATE 262 | |
/** | |
Layout of PAL_PSTATE_INFO.PStateBuffer | |
**/ | |
typedef struct { | |
UINT32 PerformanceIndex:7; | |
UINT32 Reserved1:5; | |
UINT32 TypicalPowerDissipation:20; | |
UINT32 TransitionLatency1; | |
UINT32 TransitionLatency2; | |
UINT32 Reserved2; | |
} PAL_PSTATE_INFO_BUFFER; | |
/** | |
PAL Procedure - PAL_PSTATE_INFO. | |
Returns information about the P-states supported by the | |
processor. It is optional by Itanium processors. The PAL procedure supports | |
the Static Registers calling convention. It could be called | |
at physical and Virtual mode. | |
@param Index Index of PAL_PSTATE_INFO within the list of PAL | |
procedures. | |
@param PStateBuffer 64-bit pointer to a 256-byte buffer | |
aligned on an 8-byte boundary. See | |
PAL_PSTATE_INFO_BUFFER above. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@return R9 Unsigned integer denoting the number of P-states | |
supported. The maximum value of this field is 16. | |
@return R10 Dependency domain information | |
**/ | |
#define PAL_PSTATE_INFO 44 | |
/** | |
PAL Procedure - PAL_SET_PSTATE. | |
To request a processor transition to a given P-state. It is | |
optional by Itanium processors. The PAL procedure supports the Stacked | |
Registers calling convention. It could be called at physical | |
and Virtual mode. | |
@param Index Index of PAL_SET_PSTATE within the list of PAL | |
procedures. | |
@param PState Unsigned integer denoting the processor | |
P-state being requested. | |
@param ForcePState Unsigned integer denoting whether the | |
P-state change should be forced for the | |
logical processor. | |
@retval 1 Call completed without error, but | |
transition request was not accepted | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -9 Call requires PAL memory buffer. | |
**/ | |
#define PAL_SET_PSTATE 263 | |
/** | |
PAL Procedure - PAL_SHUTDOWN. | |
Put the logical processor into a low power state which can be | |
exited only by a reset event. It is optional by Itanium processors. The PAL | |
procedure supports the Static Registers calling convention. It | |
could be called at physical mode. | |
@param Index Index of PAL_SHUTDOWN within the list of PAL | |
procedures. | |
@param NotifyPlatform 8-byte aligned physical address | |
pointer providing details on how to | |
optionally notify the platform that | |
the processor is entering a shutdown | |
state. | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -9 Call requires PAL memory buffer. | |
**/ | |
#define PAL_SHUTDOWN 45 | |
/** | |
Layout of PAL_MEMORY_BUFFER.ControlWord | |
**/ | |
typedef struct { | |
UINT64 Registration:1; | |
UINT64 ProbeInterrupt:1; | |
UINT64 Reserved:62; | |
} PAL_MEMORY_CONTROL_WORD; | |
/** | |
PAL Procedure - PAL_MEMORY_BUFFER. | |
Provides cacheable memory to PAL for exclusive use during | |
runtime. It is optional by Itanium processors. The PAL procedure supports the | |
Static Registers calling convention. It could be called at | |
physical mode. | |
@param Index Index of PAL_MEMORY_BUFFER within the list of PAL | |
procedures. | |
@param BaseAddress Physical address of the memory buffer | |
allocated for PAL use. | |
@param AllocSize Unsigned integer denoting the size of the | |
memory buffer. | |
@param ControlWord Formatted bit vector that provides control | |
options for this procedure. See | |
PAL_MEMORY_CONTROL_WORD above. | |
@retval 1 Call has not completed a buffer relocation | |
due to a pending interrupt | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -9 Call requires PAL memory buffer. | |
@return R9 Returns the minimum size of the memory buffer | |
required if the alloc_size input argument was | |
not large enough. | |
**/ | |
#define PAL_MEMORY_BUFFER 277 | |
/** | |
PAL Procedure - PAL_VP_CREATE. | |
Initializes a new vpd for the operation of a new virtual | |
processor in the virtual environment. It is optional by Itanium processors. | |
The PAL procedure supports the Stacked Registers calling | |
convention. It could be called at Virtual mode. | |
@param Index Index of PAL_VP_CREATE within the list of PAL | |
procedures. | |
@param Vpd 64-bit host virtual pointer to the Virtual | |
Processor Descriptor (VPD). | |
@param HostIva 64-bit host virtual pointer to the host IVT | |
for the virtual processor | |
@param OptionalHandler 64-bit non-zero host-virtual pointer | |
to an optional handler for | |
virtualization intercepts. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -9 Call requires PAL memory buffer. | |
**/ | |
#define PAL_VP_CREATE 265 | |
/** | |
Virtual Environment Information Parameter | |
**/ | |
typedef struct { | |
UINT64 Reserved1:8; | |
UINT64 Opcode:1; | |
UINT64 Reserved:53; | |
} PAL_VP_ENV_INFO_RETURN; | |
/** | |
PAL Procedure - PAL_VP_ENV_INFO. | |
Returns the parameters needed to enter a virtual environment. | |
It is optional by Itanium processors. The PAL procedure supports the Stacked | |
Registers calling convention. It could be called at Virtual | |
mode. | |
@param Index Index of PAL_VP_ENV_INFO within the list of PAL | |
procedures. | |
@param Vpd 64-bit host virtual pointer to the Virtual | |
Processor Descriptor (VPD). | |
@param HostIva 64-bit host virtual pointer to the host IVT | |
for the virtual processor | |
@param OptionalHandler 64-bit non-zero host-virtual pointer | |
to an optional handler for | |
virtualization intercepts. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -9 Call requires PAL memory buffer. | |
@return R9 Unsigned integer denoting the number of bytes | |
required by the PAL virtual environment buffer | |
during PAL_VP_INIT_ENV | |
@return R10 64-bit vector of virtual environment | |
information. See PAL_VP_ENV_INFO_RETURN. | |
**/ | |
#define PAL_VP_ENV_INFO 266 | |
/** | |
PAL Procedure - PAL_VP_EXIT_ENV. | |
Allows a logical processor to exit a virtual environment. | |
It is optional by Itanium processors. The PAL procedure supports the Stacked | |
Registers calling convention. It could be called at Virtual | |
mode. | |
@param Index Index of PAL_VP_EXIT_ENV within the list of PAL | |
procedures. | |
@param Iva Optional 64-bit host virtual pointer to the IVT | |
when this procedure is done | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -9 Call requires PAL memory buffer. | |
**/ | |
#define PAL_VP_EXIT_ENV 267 | |
/** | |
PAL Procedure - PAL_VP_INIT_ENV. | |
Allows a logical processor to enter a virtual environment. It | |
is optional by Itanium processors. The PAL procedure supports the Stacked | |
Registers calling convention. It could be called at Virtual | |
mode. | |
@param Index Index of PAL_VP_INIT_ENV within the list of PAL | |
procedures. | |
@param ConfigOptions 64-bit vector of global configuration | |
settings. | |
@param PhysicalBase Host physical base address of a block of | |
contiguous physical memory for the PAL | |
virtual environment buffer 1) This | |
memory area must be allocated by the VMM | |
and be 4K aligned. The first logical | |
processor to enter the environment will | |
initialize the physical block for | |
virtualization operations. | |
@param VirtualBase Host virtual base address of the | |
corresponding physical memory block for | |
the PAL virtual environment buffer : The | |
VMM must maintain the host virtual to host | |
physical data and instruction translations | |
in TRs for addresses within the allocated | |
address space. Logical processors in this | |
virtual environment will use this address | |
when transitioning to virtual mode | |
operations. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -9 Call requires PAL memory buffer. | |
@return R9 Virtualization Service Address - VSA specifies | |
the virtual base address of the PAL | |
virtualization services in this virtual | |
environment. | |
**/ | |
#define PAL_VP_INIT_ENV 268 | |
/** | |
PAL Procedure - PAL_VP_REGISTER. | |
Register a different host IVT and/or a different optional | |
virtualization intercept handler for the virtual processor | |
specified by vpd. It is optional by Itanium processors. The PAL procedure | |
supports the Stacked Registers calling convention. It could be | |
called at Virtual mode. | |
@param Index Index of PAL_VP_REGISTER within the list of PAL | |
procedures. | |
@param Vpd 64-bit host virtual pointer to the Virtual | |
Processor Descriptor (VPD) host_iva 64-bit host | |
virtual pointer to the host IVT for the virtual | |
processor | |
@param OptionalHandler 64-bit non-zero host-virtual pointer | |
to an optional handler for | |
virtualization intercepts. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -9 Call requires PAL memory buffer. | |
**/ | |
#define PAL_VP_REGISTER 269 | |
/** | |
PAL Procedure - PAL_VP_RESTORE. | |
Restores virtual processor state for the specified vpd on the | |
logical processor. It is optional by Itanium processors. The PAL procedure | |
supports the Stacked Registers calling convention. It could be | |
called at Virtual mode. | |
@param Index Index of PAL_VP_RESTORE within the list of PAL | |
procedures. | |
@param Vpd 64-bit host virtual pointer to the Virtual | |
Processor Descriptor (VPD) host_iva 64-bit host | |
virtual pointer to the host IVT for the virtual | |
processor | |
@param PalVector Vector specifies PAL procedure | |
implementation-specific state to be | |
restored. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -9 Call requires PAL memory buffer. | |
**/ | |
#define PAL_VP_RESTORE 270 | |
/** | |
PAL Procedure - PAL_VP_SAVE. | |
Saves virtual processor state for the specified vpd on the | |
logical processor. It is optional by Itanium processors. The PAL procedure | |
supports the Stacked Registers calling convention. It could be | |
called at Virtual mode. | |
@param Index Index of PAL_VP_SAVE within the list of PAL | |
procedures. | |
@param Vpd 64-bit host virtual pointer to the Virtual | |
Processor Descriptor (VPD) host_iva 64-bit host | |
virtual pointer to the host IVT for the virtual | |
processor | |
@param PalVector Vector specifies PAL procedure | |
implementation-specific state to be | |
restored. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -9 Call requires PAL memory buffer. | |
**/ | |
#define PAL_VP_SAVE 271 | |
/** | |
PAL Procedure - PAL_VP_TERMINATE. | |
Terminates operation for the specified virtual processor. It | |
is optional by Itanium processors. The PAL procedure supports the Stacked | |
Registers calling convention. It could be called at Virtual | |
mode. | |
@param Index Index of PAL_VP_TERMINATE within the list of PAL | |
procedures. | |
@param Vpd 64-bit host virtual pointer to the Virtual | |
Processor Descriptor (VPD) | |
@param Iva Optional 64-bit host virtual pointer to the IVT | |
when this procedure is done. | |
@retval 0 Call completed without error | |
@retval -1 Unimplemented procedure | |
@retval -2 Invalid argument | |
@retval -3 Call completed with error. | |
@retval -9 Call requires PAL memory buffer. | |
**/ | |
#define PAL_VP_TERMINATE 272 | |
#endif |