From de4eb1da2ae01bf93733502d328511de97e7f318 Mon Sep 17 00:00:00 2001 From: vprabhal Date: Tue, 10 Jul 2007 23:28:28 +0000 Subject: [PATCH] copied the PalCallLib.h from the new MdePkg git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@3185 6f19259b-4bc3-4df7-8a09-765794883524 --- OldMdePkg/Include/Library/PalCallLib.h | 4005 +++++++++++++++++++++++- 1 file changed, 3999 insertions(+), 6 deletions(-) diff --git a/OldMdePkg/Include/Library/PalCallLib.h b/OldMdePkg/Include/Library/PalCallLib.h index 8deb55a5bc..aefaebf55b 100644 --- a/OldMdePkg/Include/Library/PalCallLib.h +++ b/OldMdePkg/Include/Library/PalCallLib.h @@ -1,10 +1,11 @@ /** @file PAL Call Services - Copyright (c) 2006, 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 + Copyright (c) 2006 -2007, 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, @@ -17,11 +18,4003 @@ #ifndef __PAL_CALL_LIB_H__ #define __PAL_CALL_LIB_H__ +// +// 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 + -#include // -// PAL_CALL_RETURN +// Bitmask of Opearation of PAL_CACHE_FLUSH. +// +#define PAL_CACHE_FLUSH_INVIDED_LINES BIT0 +#define PAL_CACHE_FLUSH_PROBE_INTERRUPT BIT1 + +/** + + PAL Procedure - PAL_CACHE_FLUSH. + + Flush the instruction or data caches. It is required by IPF. + 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. + + @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. + + @return Status 2 - Call completed without error, but a PMI + was taken during the execution of this + procedure. + + @return Status 1 - Call has not completed flushing due to + a pending interrupt. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error + +**/ +#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 IPF. 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. + + + @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. + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error + +**/ +#define PAL_CACHE_INFO 2 + + + +// +// Level of PAL_CACHE_INIT. +// +#define PAL_CACHE_INIT_ALL 0xffffffffffffffffULL + +// +// 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 + IPF. 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. + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -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 IPF. 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. + + @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]. + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#define PAL_CACHE_PROT_INFO 38 + +/** + + @param ThreadId The thread identifier of the logical + processor for which information is being + returned. This value will be unique on a per + core basis. + + @param CoreId 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. + +**/ +typedef struct { + UINT64 ThreadId : 16; + UINT64 Reserved1: 16; + UINT64 CoreId: 16; + UINT64 Reserved2: 16; +} PAL_PCOC_N_CACHE_INFO1; + +/** + + @param LogicalAddress 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. + +**/ +typedef struct { + UINT64 LogicalAddress : 16; + 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. + + @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. + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#define PAL_CACHE_SHARED_INFO 43 + + +/** + + PAL Procedure - PAL_CACHE_SUMMARY. + + Return a summary of the cache hierarchy. It is required by + IPF. 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. + + + @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. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#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 IPF. 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. + + + @return R9 Attributes 8-bit vector of memory attributes + implemented by processor. See Virtual + Memory Attributes above. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ + +#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 IPF. 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. + + @return Status 1 Call completed without error; this + call is not necessary on remote + processors. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -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 IPF. 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. + + @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. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#define PAL_PTCE_INFO 6 + + + +/** + + @param NumberSets Unsigned 8-bit integer denoting the number + of hash sets for the specified level + (1=fully associative) + + @param NumberWays Unsigned 8-bit integer denoting the + associativity of the specified level + (1=direct). + + @param NumberEntries Unsigned 16-bit integer denoting the + number of entries in the specified TC. + + + @param PageSizeIsOptimized 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. + + @param TcIsUnified Flag denoting whether the specified TC is + unified (1=unified). + + @param EntriesReduction Flag denoting whether installed + translation registers will reduce + the number of entries within the + specified TC. + +**/ +typedef struct { + UINT64 NumberSets:8; + UINT64 NumberWays:8; + UINT64 NumberEntries:16; + UINT64 PageSizeIsOptimized:1; + UINT64 TcIsUnified:1; + UINT64 EntriesReduction:1; +} PAL_TC_INFO; + +/** + + PAL Procedure - PAL_VM_INFO. + + Return detailed information about virtual memory features + supported in the processor. It is required by IPF. 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. + + @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. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#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 IPF. 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. + + + @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. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#define PAL_VM_PAGE_SIZE 34 + +/** + + @param WalkerPresent 1-bit flag indicating whether a hardware + TLB walker is implemented (1 = walker + present). + + @param WidthOfPhysicalAddress Unsigned 7-bit integer + denoting the number of bits of + physical address implemented. + + @param WidthOfKey Unsigned 8-bit integer denoting the number + of bits mplemented in the PKR.key field. + + @param MaxPkrIndex Unsigned 8-bit integer denoting the + maximum PKR index (number of PKRs-1). + + @param HashTagId Unsigned 8-bit integer which uniquely + identifies the processor hash and tag + algorithm. + + @param MaxDtrIndex Unsigned 8 bit integer denoting the + maximum data translation register index + (number of dtr entries - 1). + + @param MaxItrIndex Unsigned 8 bit integer denoting the + maximum instruction translation register + index (number of itr entries - 1). + + @param NumberOfUniqueTc Unsigned 8-bit integer denoting the + number of unique TCs implemented. + This is a maximum of + 2*num_tc_levels. + + @param NumberOfTcLevels Unsigned 8-bit integer denoting the + number of TC levels. + +**/ +typedef struct { + UINT64 WalkerPresent:1; + UINT64 WidthOfPhysicalAddress: 7; + UINT64 WidthOfKey:8; + UINT64 MaxPkrIndex:8; + UINT64 HashTagId:8; + UINT64 MaxDtrIndex:8; + UINT64 MaxItrIndex:8; + UINT64 NumberOfUniqueTc:8; + UINT64 NumberOfTcLevels:8; +} PAL_VM_INFO1; + +/** + + @param WidthOfVirtualAddress Unsigned 8-bit integer denoting + is the total number of virtual + address bits - 1. + + @param WidthOfRid Unsigned 8-bit integer denoting the number + of bits implemented in the RR.rid field. + + @param MaxPurgedTlbs 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. + +**/ +typedef struct { + UINT64 WidthOfVirtualAddress:8; + UINT64 WidthOfRid:8; + UINT64 MaxPurgedTlbs:16; + 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 IPF. 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. + + + @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. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#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 + IPF. 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. + + @return R9 Formatted bit vector denoting which fields are + valid. See TR_valid above. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#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 IPF. 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. + + @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) + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#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 IPF. It is required by IPF. 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). + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -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 IPF. It is required by IPF. 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. + + @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. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#define PAL_DEBUG_INFO 11 + +/** + + PAL Procedure - PAL_FIXED_ADDR. + + Return the fixed component of a processorĄ¯s directed address. + It is required by IPF. It is required by IPF. 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. + + @return R9 Fixed geographical address of this processor. + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#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. + + @return R9 Base frequency of the platform if generated by the + processor chip. + + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#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 IPF. 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. + + @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. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#define PAL_FREQ_RATIOS 14 + +/** + + @param NumberOfLogicalProcessors Total number of logical + processors on this physical + processor package that are + enabled. + + @param ThreadsPerCore Number of threads per core. + + @param CoresPerProcessor Total number of cores on this + physical processor package. + + @param PhysicalProcessorPackageId 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. +**/ +typedef struct { + UINT64 NumberOfLogicalProcessors:16; + UINT64 ThreadsPerCore:8; + UINT64 Reserved1:8; + UINT64 CoresPerProcessor; + UINT64 Reserved2:8; + UINT64 PhysicalProcessorPackageId:8; + UINT64 Reserved3:8; +} PAL_LOGICAL_PROCESSPR_OVERVIEW; + +/** + + @param ThreadId The thread identifier of the logical + processor for which information is being + returned. This value will be unique on a per + core basis. + + @param CoreId 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. + +**/ +typedef struct { + UINT64 ThreadId:16; + UINT64 Reserved1:16; + UINT64 CoreId:16; + UINT64 Reserved2:16; +} PAL_LOGICAL_PROCESSORN_INFO1; + + +/** + + @param LogicalAddress 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. + + +**/ +typedef struct { + UINT64 LogicalAddress:16; + 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. + + + @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. + + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#define PAL_LOGICAL_TO_PHYSICAL 42 + + +/** + + @param NumberOfPmcPairs Unsigned 8-bit number defining the + number of generic PMC/PMD pairs. + + @param WidthOfCounter Unsigned 8-bit number in the range + 0:60 defining the number of + implemented counter bits. + + @param TypeOfCycleCounting Unsigned 8-bit number defining the + event type for counting processor + cycles. + + + @param TypeOfRetiredInstructionBundle Retired Unsigned 8-bit + number defining the + event type for retired + instruction bundles. + +**/ +typedef struct { + UINT64 NumberOfPmcPairs:8; + UINT64 WidthOfCounter:8; + UINT64 TypeOfCycleCounting:8; + UINT64 TypeOfRetiredInstructionBundle:8; + UINT64 Reserved:32; +} PAL_PERFORMANCE_INFO; + +/** + + PAL Procedure - PAL_PERF_MON_INFO. + + Return the number and type of performance monitors. It is + required by IPF. 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. + + + @return R9 Information about the performance monitors + implemented. See PAL_PERFORMANCE_INFO; + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#define PAL_PERF_MON_INFO 15 + +/** + + PAL Procedure - PAL_PLATFORM_ADDR. + + Specify processor interrupt block address and I/O port space + address. It is required by IPF. 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. + + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure. + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#define PAL_PLATFORM_ADDR 16 + + +/** + + @param EnableBerrPromotion 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) + + @param EnableMcaPromotion 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) + + @param EnableMcaToBinitPromotion 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) + + @param EnableCmciPromotion 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) + + @param DisableCache 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. + + @param DisableCoherency 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. + + @param DisableDPM 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. + + @param DisableBinitWithTimeout 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. + + + @param EnableEnvNotification 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. + + @param EnableVmsw 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. + + @param EnableMcaOnDataPoisoning 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 + + @param DisablePState 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). + + @param DisableBranchPrediction 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. + + @param DisableDynamicInsCachePrefetch 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.) + + @param DisableDynamicDataCachePrefetch 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. + + @param DisableSpontaneousDeferral 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. + + @param DisableDynamicPrediction 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. + + @param NoXr1ThroughXr3 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. + + @param NoXipXpsrXfs 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. + + @param NoVM 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. + + @param NoVariablePState 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. + + + @param NoSimpleImpInUndefinedIns 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. + + @param NoPresentPmi 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. + + @param FaultInUndefinedIns 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. + +**/ +typedef struct { + UINT64 Reserved1:36; + UINT64 FaultInUndefinedIns:1; + UINT64 NoPresentPmi:1; + UINT64 NoSimpleImpInUndefinedIns:1; + UINT64 NoVariablePState:1; + UINT64 NoVM:1; + UINT64 NoXipXpsrXfs:1; + UINT64 NoXr1ThroughXr3:1; + UINT64 DisableDynamicPrediction:1; + UINT64 DisableSpontaneousDeferral:1; + UINT64 DisableDynamicDataCachePrefetch:1; + UINT64 DisableDynamicInsCachePrefetch:1; + UINT64 DisableBranchPrediction:1; + UINT64 Reserved2:4; + UINT64 DisablePState:1; + UINT64 EnableMcaOnDataPoisoning:1; + UINT64 EnableVmsw:1; + UINT64 EnableEnvNotification:1; + UINT64 DisableBinitWithTimeout:1; + UINT64 DisableDPM:1; + UINT64 DisableCoherency:1; + UINT64 DisableCache:1; + UINT64 EnableCmciPromotion:1; + UINT64 EnableMcaToBinitPromotion:1; + UINT64 EnableMcaPromotion:1; + UINT64 EnableBerrPromotion:1; +} PAL_PROCESSOR_FEATURES; + +/** + + PAL Procedure - PAL_PROC_GET_FEATURES. + + Return configurable processor features and their current + setting. It is required by IPF. 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. + + + @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. + + @return Status 1 - Call completed without error; The + feature_set passed is not supported but a + feature_set of a larger value is supported. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -8 - feature_set passed is beyond the maximum + feature_set supported + +**/ +#define PAL_PROC_GET_FEATURES 17 + + +/** + + PAL Procedure - PAL_PROC_SET_FEATURES. + + Enable or disable configurable processor features. It is + required by IPF. 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. + + + + @return Status 1 - Call completed without error; The + feature_set passed is not supported but a + feature_set of a larger value is supported + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -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 IPF. + 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. + + @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. + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + +**/ +#define PAL_REGISTER_INFO 39 + +/** + + PAL Procedure - PAL_RSE_INFO. + + Return RSE information. It is required by IPF. 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. + + @return R9 Number of physical stacked general registers. + + @return R10 RSE hints supported by processor. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + +**/ +#define PAL_RSE_INFO 19 + +/** + + @param VersionOfPalB Is a 16-bit binary coded decimal (BCD) + number that provides identification + information about the PAL_B firmware. + + @param PalVendor Is an unsigned 8-bit integer indicating the + vendor of the PAL code. + + @param VersionOfPalB 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. + +**/ +typedef struct { + UINT64 VersionOfPalB:16; + UINT64 Reserved1:8; + UINT64 PalVendor:8; + UINT64 VersionOfPalA:16; + UINT64 Reserved2:16; +} PAL_VERSION_INFO; + +/** + + PAL Procedure - PAL_VERSION. + + Return version of PAL code. It is required by IPF. 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. + + @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. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + +**/ +#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 IPF. 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. + + + @return R9 64-bit vector denoting whether an event is + pending. See PAL_MC_CLEAR_LOG.pending above. + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + +**/ +#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 IPF. 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. + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -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). + + @return R9 Unsigned 64-bit integer denoting bytes of Dynamic + Processor State returned. + + @return R10 Next 8 bytes of Dynamic Processor State. + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure. + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + +**/ +#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 + +/** + + @param CoreId Bit3:0, Processor core ID (default is 0 for + processors with a single core) + + @param ThreadId Bit7:4, Logical thread ID (default is 0 for + processors that execute a single thread) + + @param InfoOfInsCache Bit11:8, Error information is + available for 1st, 2nd, 3rd, and 4th + level instruction caches. + + @param InfoOfDataCache Bit15:12, Error information is + available for 1st, 2nd, 3rd, and 4th + level data/unified caches. + + @param InfoOfInsTlb Bit19:16 Error information is available + for 1st, 2nd, 3rd, and 4th level + instruction TLB. + + @param InfoOfDataTlb Bit23:20, Error information is available + for 1st, 2nd, 3rd, and 4th level + data/unified TLB + + @param InfoOfProcessorBus Bit27:24 Error information is + available for the 1st, 2nd, 3rd, + and 4th level processor bus + hierarchy. + + @param InfoOfRegisterFile Bit31:28 Error information is + available on register file + structures. + + @param InfoOfMicroArch Bit47:32, Error information is + available on micro-architectural + structures. + +**/ +typedef struct { + UINT64 CoreId:4; + UINT64 ThreadId:4; + UINT64 InfoOfInsCache:4; + UINT64 InfoOfDataCache:4; + UINT64 InfoOfInsTlb:4; + UINT64 InfoOfDataTlb:4; + UINT64 InfoOfProcessorBus:4; + UINT64 InfoOfRegisterFile:4; + UINT64 InfoOfMicroArch:4; + 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 + +/** + + @param Operation 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) + + @param FailedCacheLevel Bit5:4 Level of cache where the + error occurred. A value of 0 + indicates the first level of cache. + + @param FailedInDataPart Bit8, Failure located in the data + part of the cache line. + + @param FailedInTagPart Bit9, Failure located in the tag part + of the cache line. + + @param FailedInDataCache Bit10, Failure located in the data + cache + + @param FailedInInsCache Bit11, Failure located in the + instruction cache. + + + @param Mesi 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. + + @param MesiIsValid Bit15, The mesi field in the cache_check + parameter is valid. + + @param FailedWay Bit20:16, Failure located in the way of + the cache indicated by this value. + + @param WayIndexIsValid Bit21, The way and index field in the + cache_check parameter is valid. + + @param MultipleBitsError Bit23, A multiple-bit error was + detected, and data was poisoned for + the corresponding cache line during + castout. + + @param IndexOfCacheLineError Bit51:32, Index of the cache + line where the error occurred. + + @param InstructionSet 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. + + @param InstructionSetIsValid Bit55, The is field in the + cache_check parameter is valid. + + @param PrivilegeLevel Bit57:56, Privilege level. The + privilege level of the instruction + bundle responsible for generating the + machine check. + + @param PrivilegeLevelIsValide Bit58, The pl field of the + cache_check parameter is + valid. + + @param McCorrected Bit59, Machine check corrected: This bit + is set to one to indicate that the machine + check has been corrected. + + @param TargetAddressIsValid Bit60, Target address is valid: + This bit is set to one to + indicate that a valid target + address has been logged. + + @param RequesterIdentifier Bit61, Requester identifier: This + bit is set to one to indicate that + a valid requester identifier has + been logged. + + @param ResponserIdentifier Bit62, Responder identifier: This + bit is set to one to indicate that + a valid responder identifier has + been logged. + + @param PreciseInsPointer Bit63, Precise instruction pointer. + This bit is set to one to indicate + that a valid precise instruction + pointer has been logged. + +**/ +typedef struct { + UINT64 Operation:4; + UINT64 FailedCacheLevel:2; + UINT64 Reserved1:2; + UINT64 FailedInDataPart:1; + UINT64 FailedInTagPart:1; + UINT64 FailedInDataCache:1; + UINT64 FailedInInsCache:1; + UINT64 Mesi:3; + UINT64 MesiIsValid:1; + UINT64 FailedWay:5; + UINT64 WayIndexIsValid:1; + + UINT64 Reserved2:1; + UINT64 MultipleBitsError:1; + UINT64 Reserved3:8; + UINT64 IndexOfCacheLineError:20; + UINT64 Reserved4:2; + UINT64 InstructionSet:1; + UINT64 InstructionSetIsValid:1; + + UINT64 PrivilegeLevel:2; + UINT64 PrivilegeLevelIsValide:1; + + UINT64 McCorrected:1; + + UINT64 TargetAddressIsValid:1; + UINT64 RequesterIdentifier:1; + UINT64 ResponserIdentifier:1; + UINT64 PreciseInsPointer:1; + +} PAL_CACHE_CHECK_INFO; + +/** + + @param FailedSlot Bit7:0, Slot number of the translation + register where the failure occurred. + + @param FailedSlotIsValid Bit8, The tr_slot field in the + TLB_check parameter is valid. + + @param TlbLevel Bit11:10, The level of the TLB where the + error occurred. A value of 0 indicates the + first level of TLB + + @param FailedInDataTr Bit16, Error occurred in the data + translation registers. + + @param FailedInInsTr Bit17, Error occurred in the instruction + translation registers + + @param FailedInDataTc Bit18, Error occurred in data + translation cache. + + @param FailedInInsTc Bit19, Error occurred in the instruction + translation cache. + + @param FailedOperation 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. + + @param InstructionSet 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. + + @param InstructionSetIsValid Bit55, The is field in the + TLB_check parameter is valid. + + @param PrivelegeLevel Bit57:56, Privilege level. The + privilege level of the instruction + bundle responsible for generating the + machine check. + + @param PrivelegeLevelIsValid Bit58, The pl field of the + TLB_check parameter is valid. + + @param McCorrected Bit59, Machine check corrected: This bit + is set to one to indicate that the machine + check has been corrected. + + @param TargetAddressIsValid Bit60, Target address is valid: + This bit is set to one to + indicate that a valid target + address has been logged. + + @param RequesterIdentifier Bit61 Requester identifier: This + bit is set to one to indicate that + a valid requester identifier has + been logged. + + @param ResponserIdentifier Bit62, Responder identifier: This + bit is set to one to indicate that + a valid responder identifier has + been logged. + + @param PreciseInsPointer Bit63 Precise instruction pointer. + This bit is set to one to indicate + that a valid precise instruction + pointer has been logged. +**/ +typedef struct { + UINT64 FailedSlot:8; + UINT64 FailedSlotIsValid:1; + UINT64 Reserved1 :1; + UINT64 TlbLevel:2; + UINT64 Reserved2 :4; + UINT64 FailedInDataTr:1; + UINT64 FailedInInsTr:1; + UINT64 FailedInDataTc:1; + UINT64 FailedInInsTc:1; + UINT64 FailedOperation:4; + UINT64 Reserved3:30; + UINT64 InstructionSet:1; + UINT64 InstructionSetIsValid:1; + UINT64 PrivelegeLevel:2; + UINT64 PrivelegeLevelIsValid:1; + UINT64 McCorrected:1; + UINT64 TargetAddressIsValid:1; + UINT64 RequesterIdentifier:1; + UINT64 ResponserIdentifier:1; + UINT64 PreciseInsPointer:1; +} 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 IPF. 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. + + + @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. + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -6 - Argument was valid, but no error + information was available + + +**/ +#define PAL_MC_ERROR_INFO 25 + +/** + + PAL Procedure - PAL_MC_EXPECTED. + + Set/Reset Expected Machine Check Indicator. It is required by + IPF. 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. + + + @return R9 Unsigned integer denoting whether a machine check + was previously expected. + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#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 IPF. 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. + + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -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 IPF. 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. + + + + @return Status -2 - Invalid argument + + @return Status -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. + + + @return R9 Value returned if a load instruction is requested + in the io_detail_ptr + + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#define PAL_HALT 28 + + +/** + + PAL Procedure - PAL_HALT_INFO. + + Return the low power capabilities of the processor. It is + required by IPF. 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. + + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -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 + IPF. 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. + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -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 IPF. 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. + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -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. + + @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. + + + + @return Status 1 - The word at address was found in the + cache, but the line was invalid. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -5 - The word at address was not found in the + cache. + + @return Status -7 - The operation requested is not supported + for this cache_type and level. + +**/ +#define PAL_CACHE_READ 259 + + +/** + + 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. + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + + @return Status -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 IPF. 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. + + @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. + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + +**/ +#define PAL_TEST_INFO 37 + +/** + + @param BufferSize 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. + + @param TestPhase 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. + +**/ +typedef struct { + UINT64 BufferSize:56; + UINT64 TestPhase:8; +} PAL_TEST_INFO_INFO; + +/** + + @param TestControl 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. + + @param ControlSupport 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. + +**/ +typedef struct { + UINT64 TestControl:47; + UINT64 ControlSupport:1; + UINT64 Reserved:16; +} PAL_SELF_TEST_CONTROL; + +/** + + @param Attributes 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. + + + @param TestControl 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. +**/ +typedef struct { + UINT64 Attributes:8; + UINT64 Reserved:8; + UINT64 TestControl:48; +} PAL_TEST_CONTROL; + +/** + + PAL Procedure - PAL_TEST_PROC. + + Perform late processor self test. It is required by IPF. 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. + + @return R9 Formatted 8-byte value denoting the state of the + processor after self-test + + + + @return Status 1 - Call completed without error, but hardware + failures occurred during self-test. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + +**/ +#define PAL_TEST_PROC 258 + +/** + + @param NumberOfInterruptControllers Number of interrupt + controllers currently + enabled on the system. + + @param NumberOfProcessors Number of processors currently + enabled on the system. + +**/ +typedef struct { + UINT32 NumberOfInterruptControllers; + UINT32 NumberOfProcessors; +} 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 IPF. 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. + + + + @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. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + +**/ +#define PAL_COPY_INFO 30 + +/** + + PAL Procedure - PAL_COPY_PAL. + + Relocate PAL procedures and PAL PMI code to memory. It is + required by IPF. 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. + + + @return R9 Unsigned integer denoting the offset of PAL_PROC + in the relocatable segment copied. + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + +**/ +#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. + + + @return Status 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 IPF. 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. + + + @return Status 0 - Call completed without error + + @return Status -2 - Invalid argument + + @return Status -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 + IPF. 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. + + + @reture R9 Brand information returned. The format of this + value is dependent on the input values passed. + + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -6 - Input argument is not implemented. + +**/ +#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 IPF. 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. + + + @reture 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. + + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -9 - Call requires PAL memory buffer. + +**/ +#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 IPF. 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. + + + @return Status 1 - Call completed successfully but could not + change the hardware policy since a + competing logical processor is set in + exclusive high priority. + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -9 - Call requires PAL memory buffer. + +**/ +#define PAL_SET_HW_POLICY 49 + + +/** + + @param Mode Bit2:0, Indicates the mode of operation for this + procedure: 0 - Query mode 1 ¨C 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. + + @param ErrorInjection 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. + + + @param ErrorSeverity 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 + + + @param ErrorStructure 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. + + @param StructureHierarchy 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 + +**/ +typedef struct { + UINT64 Mode:3; + UINT64 ErrorInjection:3; + UINT64 ErrorSeverity:2; + UINT64 ErrorStructure:5; + UINT64 StructureHierarchy:3; + UINT64 Reserved:48; +} PAL_MC_ERROR_TYPE_INFO; + +/** + + @param StructInfoIsValid 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. + + @param CacheType Bit2:1 Indicates which cache should be used + for error injection: 0 - Reserved 1 - + Instruction cache 2 - Data or unified cache + 3 - Reserved + + + @param PortionOfCacheLine 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. + + @param Mechanism 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. + + @param DataPoisonOfCacheLine 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. + + + @param TrigerInfoIsValid 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. + + @param Triger 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. + + @param PrivilegeOfTriger 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. + +**/ +typedef struct { + UINT64 StructInfoIsValid:1; + UINT64 CacheType:2; + UINT64 PortionOfCacheLine:3; + UINT64 Mechanism:3; + UINT64 DataPoisonOfCacheLine:1; + UINT64 Reserved1:22; + UINT64 TrigerInfoIsValid:1; + UINT64 Triger:4; + UINT64 PrivilegeOfTriger:3; + UINT64 Reserved2:24; +} PAL_MC_ERROR_STRUCT_INFO; + +/** + + Buffer Pointed to by err_data_buffer ¨C 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 IPF. 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. + + @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. + + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -4 - Call completed with error; the requested + error could not be injected due to failure in + locating the target location in the specified + structure. + + @return Status -5 - Argument was valid, but requested error + injection capability is not supported. + + @return Status -9 - Call requires PAL memory buffer. + +**/ +#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 IPF. 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. + + + @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. + + @return Status 1 - Call completed without error, but accuracy + of performance index has been impacted by a + thermal throttling event, or a + hardware-initiated event. + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -9 - Call requires PAL memory buffer. + +**/ +#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 IPF. 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. + + + @return R9 Unsigned integer denoting the number of P-states + supported. The maximum value of this field is 16. + + @return R10 Dependency domain information + + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + +**/ +#define PAL_PSTATE_INFO 44 + + +/** + + PAL Procedure - PAL_SET_PSTATE. + + To request a processor transition to a given P-state. It is + optional by IPF. 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. + + + + + + @return Status 1 - Call completed without error, but + transition request was not accepted + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -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 IPF. 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. + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -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 IPF. 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. + + @return R9 Returns the minimum size of the memory buffer + required if the alloc_size input argument was + not large enough. + + @return Status 1 - Call has not completed a buffer relocation + due to a pending interrupt + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -9 - Call requires PAL memory buffer. + +**/ +#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 IPF. + 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. + + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -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 IPF. 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. + @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. + + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -9 - Call requires PAL memory buffer. + +**/ +#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 IPF. 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 + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -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 IPF. 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. + + @return R9 Virtualization Service Address ¨C VSA specifies + the virtual base address of the PAL + virtualization services in this virtual + environment. + + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -9 - Call requires PAL memory buffer. + +**/ +#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 IPF. 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. + + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -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 IPF. 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. + + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -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 IPF. 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. + + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -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 IPF. 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. + + @return Status 0 - Call completed without error + + @return Status -1 - Unimplemented procedure + + @return Status -2 - Invalid argument + + @return Status -3 - Call completed with error. + + @return Status -9 - Call requires PAL memory buffer. + +**/ +#define PAL_VP_TERMINATE 272 /** Makes a PAL procedure call.