\r
#include "PiSmmCore.h"\r
\r
-LIST_ENTRY mSmmPoolLists[MAX_POOL_INDEX];\r
+LIST_ENTRY mSmmPoolLists[SmmPoolTypeMax][MAX_POOL_INDEX];\r
//\r
// To cache the SMRAM base since when Loading modules At fixed address feature is enabled, \r
// all module is assigned an offset relative the SMRAM base in build time.\r
//\r
GLOBAL_REMOVE_IF_UNREFERENCED EFI_PHYSICAL_ADDRESS gLoadModuleAtFixAddressSmramBase = 0;\r
\r
+/**\r
+ Convert a UEFI memory type to SMM pool type.\r
+\r
+ @param[in] MemoryType Type of pool to allocate.\r
+\r
+ @return SMM pool type\r
+**/\r
+SMM_POOL_TYPE\r
+UefiMemoryTypeToSmmPoolType (\r
+ IN EFI_MEMORY_TYPE MemoryType\r
+ )\r
+{\r
+ ASSERT ((MemoryType == EfiRuntimeServicesCode) || (MemoryType == EfiRuntimeServicesData));\r
+ switch (MemoryType) {\r
+ case EfiRuntimeServicesCode:\r
+ return SmmPoolTypeCode;\r
+ case EfiRuntimeServicesData:\r
+ return SmmPoolTypeData;\r
+ default:\r
+ return SmmPoolTypeMax;\r
+ }\r
+}\r
+\r
+\r
/**\r
Called to initialize the memory service.\r
\r
)\r
{\r
UINTN Index;\r
- UINT64 SmmCodeSize;\r
- UINTN CurrentSmramRangesIndex;\r
- UINT64 MaxSize;\r
+ UINT64 SmmCodeSize;\r
+ UINTN CurrentSmramRangesIndex;\r
+ UINT64 MaxSize;\r
+ UINTN SmmPoolTypeIndex;\r
\r
//\r
// Initialize Pool list\r
//\r
- for (Index = ARRAY_SIZE (mSmmPoolLists); Index > 0;) {\r
- InitializeListHead (&mSmmPoolLists[--Index]);\r
+ for (SmmPoolTypeIndex = 0; SmmPoolTypeIndex < SmmPoolTypeMax; SmmPoolTypeIndex++) {\r
+ for (Index = 0; Index < ARRAY_SIZE (mSmmPoolLists[SmmPoolTypeIndex]); Index++) {\r
+ InitializeListHead (&mSmmPoolLists[SmmPoolTypeIndex][Index]);\r
+ }\r
}\r
CurrentSmramRangesIndex = 0;\r
//\r
/**\r
Internal Function. Allocate a pool by specified PoolIndex.\r
\r
+ @param PoolType Type of pool to allocate.\r
@param PoolIndex Index which indicate the Pool size.\r
@param FreePoolHdr The returned Free pool.\r
\r
**/\r
EFI_STATUS\r
InternalAllocPoolByIndex (\r
+ IN EFI_MEMORY_TYPE PoolType,\r
IN UINTN PoolIndex,\r
OUT FREE_POOL_HEADER **FreePoolHdr\r
)\r
EFI_STATUS Status;\r
FREE_POOL_HEADER *Hdr;\r
EFI_PHYSICAL_ADDRESS Address;\r
+ SMM_POOL_TYPE SmmPoolType;\r
+\r
+ SmmPoolType = UefiMemoryTypeToSmmPoolType(PoolType);\r
\r
ASSERT (PoolIndex <= MAX_POOL_INDEX);\r
Status = EFI_SUCCESS;\r
Hdr = NULL;\r
if (PoolIndex == MAX_POOL_INDEX) {\r
- Status = SmmInternalAllocatePages (AllocateAnyPages, EfiRuntimeServicesData, EFI_SIZE_TO_PAGES (MAX_POOL_SIZE << 1), &Address);\r
+ Status = SmmInternalAllocatePages (AllocateAnyPages, PoolType, EFI_SIZE_TO_PAGES (MAX_POOL_SIZE << 1), &Address);\r
if (EFI_ERROR (Status)) {\r
return EFI_OUT_OF_RESOURCES;\r
}\r
Hdr = (FREE_POOL_HEADER *) (UINTN) Address;\r
- } else if (!IsListEmpty (&mSmmPoolLists[PoolIndex])) {\r
- Hdr = BASE_CR (GetFirstNode (&mSmmPoolLists[PoolIndex]), FREE_POOL_HEADER, Link);\r
+ } else if (!IsListEmpty (&mSmmPoolLists[SmmPoolType][PoolIndex])) {\r
+ Hdr = BASE_CR (GetFirstNode (&mSmmPoolLists[SmmPoolType][PoolIndex]), FREE_POOL_HEADER, Link);\r
RemoveEntryList (&Hdr->Link);\r
} else {\r
- Status = InternalAllocPoolByIndex (PoolIndex + 1, &Hdr);\r
+ Status = InternalAllocPoolByIndex (PoolType, PoolIndex + 1, &Hdr);\r
if (!EFI_ERROR (Status)) {\r
Hdr->Header.Size >>= 1;\r
Hdr->Header.Available = TRUE;\r
- InsertHeadList (&mSmmPoolLists[PoolIndex], &Hdr->Link);\r
+ Hdr->Header.Type = PoolType;\r
+ InsertHeadList (&mSmmPoolLists[SmmPoolType][PoolIndex], &Hdr->Link);\r
Hdr = (FREE_POOL_HEADER*)((UINT8*)Hdr + Hdr->Header.Size);\r
}\r
}\r
if (!EFI_ERROR (Status)) {\r
Hdr->Header.Size = MIN_POOL_SIZE << PoolIndex;\r
Hdr->Header.Available = FALSE;\r
+ Hdr->Header.Type = PoolType;\r
}\r
\r
*FreePoolHdr = Hdr;\r
IN FREE_POOL_HEADER *FreePoolHdr\r
)\r
{\r
- UINTN PoolIndex;\r
+ UINTN PoolIndex;\r
+ SMM_POOL_TYPE SmmPoolType;\r
\r
ASSERT ((FreePoolHdr->Header.Size & (FreePoolHdr->Header.Size - 1)) == 0);\r
ASSERT (((UINTN)FreePoolHdr & (FreePoolHdr->Header.Size - 1)) == 0);\r
ASSERT (FreePoolHdr->Header.Size >= MIN_POOL_SIZE);\r
\r
+ SmmPoolType = UefiMemoryTypeToSmmPoolType(FreePoolHdr->Header.Type);\r
+\r
PoolIndex = (UINTN) (HighBitSet32 ((UINT32)FreePoolHdr->Header.Size) - MIN_POOL_SHIFT);\r
FreePoolHdr->Header.Available = TRUE;\r
ASSERT (PoolIndex < MAX_POOL_INDEX);\r
- InsertHeadList (&mSmmPoolLists[PoolIndex], &FreePoolHdr->Link);\r
+ InsertHeadList (&mSmmPoolLists[SmmPoolType][PoolIndex], &FreePoolHdr->Link);\r
return EFI_SUCCESS;\r
}\r
\r
PoolHdr = (POOL_HEADER*)(UINTN)Address;\r
PoolHdr->Size = EFI_PAGES_TO_SIZE (Size);\r
PoolHdr->Available = FALSE;\r
+ PoolHdr->Type = PoolType;\r
*Buffer = PoolHdr + 1;\r
return Status;\r
}\r
PoolIndex++;\r
}\r
\r
- Status = InternalAllocPoolByIndex (PoolIndex, &FreePoolHdr);\r
+ Status = InternalAllocPoolByIndex (PoolType, PoolIndex, &FreePoolHdr);\r
if (!EFI_ERROR(Status)) {\r
*Buffer = &FreePoolHdr->Header + 1;\r
}\r
FREE_POOL_HEADER *Pool;\r
UINTN PoolListIndex;\r
UINTN Index;\r
+ UINTN SmmPoolTypeIndex;\r
\r
ContextData = GetSmramProfileContext ();\r
if (ContextData == NULL) {\r
Node = Node->BackLink) {\r
Index++;\r
}\r
- for (PoolListIndex = 0; PoolListIndex < MAX_POOL_INDEX; PoolListIndex++) {\r
- FreePoolList = &mSmmPoolLists[PoolListIndex];\r
- for (Node = FreePoolList->BackLink;\r
- Node != FreePoolList;\r
- Node = Node->BackLink) {\r
- Pool = BASE_CR (Node, FREE_POOL_HEADER, Link);\r
- if (Pool->Header.Available) {\r
- Index++;\r
+ for (SmmPoolTypeIndex = 0; SmmPoolTypeIndex < SmmPoolTypeMax; SmmPoolTypeIndex++) {\r
+ for (PoolListIndex = 0; PoolListIndex < MAX_POOL_INDEX; PoolListIndex++) {\r
+ FreePoolList = &mSmmPoolLists[SmmPoolTypeIndex][PoolListIndex];\r
+ for (Node = FreePoolList->BackLink;\r
+ Node != FreePoolList;\r
+ Node = Node->BackLink) {\r
+ Pool = BASE_CR (Node, FREE_POOL_HEADER, Link);\r
+ if (Pool->Header.Available) {\r
+ Index++;\r
+ }\r
}\r
}\r
}\r
\r
-\r
TotalSize += (sizeof (MEMORY_PROFILE_FREE_MEMORY) + Index * sizeof (MEMORY_PROFILE_DESCRIPTOR));\r
TotalSize += (sizeof (MEMORY_PROFILE_MEMORY_RANGE) + mFullSmramRangeCount * sizeof (MEMORY_PROFILE_DESCRIPTOR));\r
\r
UINT64 RemainingSize;\r
UINTN PdbSize;\r
UINTN ActionStringSize;\r
+ UINTN SmmPoolTypeIndex;\r
\r
ContextData = GetSmramProfileContext ();\r
if (ContextData == NULL) {\r
Node = Node->BackLink) {\r
Index++;\r
}\r
- for (PoolListIndex = 0; PoolListIndex < MAX_POOL_INDEX; PoolListIndex++) {\r
- FreePoolList = &mSmmPoolLists[MAX_POOL_INDEX - PoolListIndex - 1];\r
- for (Node = FreePoolList->BackLink;\r
- Node != FreePoolList;\r
- Node = Node->BackLink) {\r
- Pool = BASE_CR (Node, FREE_POOL_HEADER, Link);\r
- if (Pool->Header.Available) {\r
- Index++;\r
+ for (SmmPoolTypeIndex = 0; SmmPoolTypeIndex < SmmPoolTypeMax; SmmPoolTypeIndex++) {\r
+ for (PoolListIndex = 0; PoolListIndex < MAX_POOL_INDEX; PoolListIndex++) {\r
+ FreePoolList = &mSmmPoolLists[SmmPoolTypeIndex][MAX_POOL_INDEX - PoolListIndex - 1];\r
+ for (Node = FreePoolList->BackLink;\r
+ Node != FreePoolList;\r
+ Node = Node->BackLink) {\r
+ Pool = BASE_CR (Node, FREE_POOL_HEADER, Link);\r
+ if (Pool->Header.Available) {\r
+ Index++;\r
+ }\r
}\r
}\r
}\r
}\r
Offset += sizeof (MEMORY_PROFILE_DESCRIPTOR);\r
}\r
- for (PoolListIndex = 0; PoolListIndex < MAX_POOL_INDEX; PoolListIndex++) {\r
- FreePoolList = &mSmmPoolLists[MAX_POOL_INDEX - PoolListIndex - 1];\r
- for (Node = FreePoolList->BackLink;\r
- Node != FreePoolList;\r
- Node = Node->BackLink) {\r
- Pool = BASE_CR (Node, FREE_POOL_HEADER, Link);\r
- if (Pool->Header.Available) {\r
- if (*ProfileOffset < (Offset + sizeof (MEMORY_PROFILE_DESCRIPTOR))) {\r
- if (RemainingSize >= sizeof (MEMORY_PROFILE_DESCRIPTOR)) {\r
- MemoryProfileDescriptor = ProfileBuffer;\r
- MemoryProfileDescriptor->Header.Signature = MEMORY_PROFILE_DESCRIPTOR_SIGNATURE;\r
- MemoryProfileDescriptor->Header.Length = sizeof (MEMORY_PROFILE_DESCRIPTOR);\r
- MemoryProfileDescriptor->Header.Revision = MEMORY_PROFILE_DESCRIPTOR_REVISION;\r
- MemoryProfileDescriptor->Address = (PHYSICAL_ADDRESS) (UINTN) Pool;\r
- MemoryProfileDescriptor->Size = Pool->Header.Size;\r
-\r
- RemainingSize -= sizeof (MEMORY_PROFILE_DESCRIPTOR);\r
- ProfileBuffer = (UINT8 *) ProfileBuffer + sizeof (MEMORY_PROFILE_DESCRIPTOR);\r
- } else {\r
- goto Done;\r
+ for (SmmPoolTypeIndex = 0; SmmPoolTypeIndex < SmmPoolTypeMax; SmmPoolTypeIndex++) {\r
+ for (PoolListIndex = 0; PoolListIndex < MAX_POOL_INDEX; PoolListIndex++) {\r
+ FreePoolList = &mSmmPoolLists[SmmPoolTypeIndex][MAX_POOL_INDEX - PoolListIndex - 1];\r
+ for (Node = FreePoolList->BackLink;\r
+ Node != FreePoolList;\r
+ Node = Node->BackLink) {\r
+ Pool = BASE_CR (Node, FREE_POOL_HEADER, Link);\r
+ if (Pool->Header.Available) {\r
+ if (*ProfileOffset < (Offset + sizeof (MEMORY_PROFILE_DESCRIPTOR))) {\r
+ if (RemainingSize >= sizeof (MEMORY_PROFILE_DESCRIPTOR)) {\r
+ MemoryProfileDescriptor = ProfileBuffer;\r
+ MemoryProfileDescriptor->Header.Signature = MEMORY_PROFILE_DESCRIPTOR_SIGNATURE;\r
+ MemoryProfileDescriptor->Header.Length = sizeof (MEMORY_PROFILE_DESCRIPTOR);\r
+ MemoryProfileDescriptor->Header.Revision = MEMORY_PROFILE_DESCRIPTOR_REVISION;\r
+ MemoryProfileDescriptor->Address = (PHYSICAL_ADDRESS) (UINTN) Pool;\r
+ MemoryProfileDescriptor->Size = Pool->Header.Size;\r
+\r
+ RemainingSize -= sizeof (MEMORY_PROFILE_DESCRIPTOR);\r
+ ProfileBuffer = (UINT8 *) ProfileBuffer + sizeof (MEMORY_PROFILE_DESCRIPTOR);\r
+ } else {\r
+ goto Done;\r
+ }\r
}\r
+ Offset += sizeof (MEMORY_PROFILE_DESCRIPTOR);\r
}\r
- Offset += sizeof (MEMORY_PROFILE_DESCRIPTOR);\r
}\r
}\r
}\r
UINTN PoolListIndex;\r
MEMORY_PROFILE_CONTEXT_DATA *ContextData;\r
BOOLEAN SmramProfileGettingStatus;\r
+ UINTN SmmPoolTypeIndex;\r
\r
ContextData = GetSmramProfileContext ();\r
if (ContextData == NULL) {\r
SmramProfileGettingStatus = mSmramProfileGettingStatus;\r
mSmramProfileGettingStatus = TRUE;\r
\r
- DEBUG ((EFI_D_INFO, "======= SmramProfile begin =======\n"));\r
-\r
- for (PoolListIndex = 0; PoolListIndex < MAX_POOL_INDEX; PoolListIndex++) {\r
- DEBUG ((EFI_D_INFO, "FreePoolList (%d):\n", PoolListIndex));\r
- FreePoolList = &mSmmPoolLists[PoolListIndex];\r
- for (Node = FreePoolList->BackLink, Index = 0;\r
- Node != FreePoolList;\r
- Node = Node->BackLink, Index++) {\r
- Pool = BASE_CR (Node, FREE_POOL_HEADER, Link);\r
- DEBUG ((EFI_D_INFO, " Index - 0x%x\n", Index));\r
- DEBUG ((EFI_D_INFO, " PhysicalStart - 0x%016lx\n", (PHYSICAL_ADDRESS) (UINTN) Pool));\r
- DEBUG ((EFI_D_INFO, " Size - 0x%08x\n", Pool->Header.Size));\r
- DEBUG ((EFI_D_INFO, " Available - 0x%02x\n", Pool->Header.Available));\r
+ DEBUG ((DEBUG_INFO, "======= SmramProfile begin =======\n"));\r
+\r
+ for (SmmPoolTypeIndex = 0; SmmPoolTypeIndex < SmmPoolTypeMax; SmmPoolTypeIndex++) {\r
+ for (PoolListIndex = 0; PoolListIndex < MAX_POOL_INDEX; PoolListIndex++) {\r
+ DEBUG ((DEBUG_INFO, "FreePoolList(%d)(%d):\n", SmmPoolTypeIndex, PoolListIndex));\r
+ FreePoolList = &mSmmPoolLists[SmmPoolTypeIndex][PoolListIndex];\r
+ for (Node = FreePoolList->BackLink, Index = 0;\r
+ Node != FreePoolList;\r
+ Node = Node->BackLink, Index++) {\r
+ Pool = BASE_CR (Node, FREE_POOL_HEADER, Link);\r
+ DEBUG ((DEBUG_INFO, " Index - 0x%x\n", Index));\r
+ DEBUG ((DEBUG_INFO, " PhysicalStart - 0x%016lx\n", (PHYSICAL_ADDRESS) (UINTN) Pool));\r
+ DEBUG ((DEBUG_INFO, " Size - 0x%08x\n", Pool->Header.Size));\r
+ DEBUG ((DEBUG_INFO, " Available - 0x%02x\n", Pool->Header.Available));\r
+ }\r
}\r
}\r
\r
- DEBUG ((EFI_D_INFO, "======= SmramProfile end =======\n"));\r
+ DEBUG ((DEBUG_INFO, "======= SmramProfile end =======\n"));\r
\r
mSmramProfileGettingStatus = SmramProfileGettingStatus;\r
}\r