UefiCpuPkg/MtrrLib: Correct typo to change vector to vertex

The patch only change the comments and variable name so
doesn't impact the functionality.

Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Ruiyu Ni <ruiyu.ni@intel.com>
Reviewed-by: Eric Dong <eric.dong@intel.com>
Cc: Star Zeng <star.zeng@intel.com>
This commit is contained in:
Ruiyu Ni 2018-01-09 10:57:25 +08:00
parent cee85c48e9
commit 3143144ba5
1 changed files with 95 additions and 95 deletions

View File

@ -32,8 +32,8 @@
#define SCRATCH_BUFFER_SIZE (4 * SIZE_4KB) #define SCRATCH_BUFFER_SIZE (4 * SIZE_4KB)
#define MTRR_LIB_ASSERT_ALIGNED(B, L) ASSERT ((B & ~(L - 1)) == B); #define MTRR_LIB_ASSERT_ALIGNED(B, L) ASSERT ((B & ~(L - 1)) == B);
#define M(x,y) ((x) * VectorCount + (y)) #define M(x,y) ((x) * VertexCount + (y))
#define O(x,y) ((y) * VectorCount + (x)) #define O(x,y) ((y) * VertexCount + (x))
// //
// Context to save and restore when MTRRs are programmed // Context to save and restore when MTRRs are programmed
@ -1142,21 +1142,21 @@ MtrrLibGetNumberOfTypes (
} }
/** /**
Calculate the least MTRR number from vector Start to Stop and update Calculate the least MTRR number from vertex Start to Stop and update
the Previous of all vectors from Start to Stop is updated to reflect the Previous of all vertices from Start to Stop is updated to reflect
how the memory range is covered by MTRR. how the memory range is covered by MTRR.
@param VectorCount The count of vectors in the graph. @param VertexCount The count of vertices in the graph.
@param Vector Array holding all vectors. @param Vertices Array holding all vertices.
@param Weight 2-dimention array holding weights between vectors. @param Weight 2-dimention array holding weights between vertices.
@param Start Start vector. @param Start Start vertex.
@param Stop Stop vector. @param Stop Stop vertex.
@param IncludeOptional TRUE to count the optional weight. @param IncludeOptional TRUE to count the optional weight.
**/ **/
VOID VOID
MtrrLibCalculateLeastMtrrs ( MtrrLibCalculateLeastMtrrs (
IN UINT16 VectorCount, IN UINT16 VertexCount,
IN MTRR_LIB_ADDRESS *Vector, IN MTRR_LIB_ADDRESS *Vertices,
IN OUT CONST UINT8 *Weight, IN OUT CONST UINT8 *Weight,
IN UINT16 Start, IN UINT16 Start,
IN UINT16 Stop, IN UINT16 Stop,
@ -1170,52 +1170,52 @@ MtrrLibCalculateLeastMtrrs (
UINT8 Optional; UINT8 Optional;
for (Index = Start; Index <= Stop; Index++) { for (Index = Start; Index <= Stop; Index++) {
Vector[Index].Visited = FALSE; Vertices[Index].Visited = FALSE;
Vector[Index].Previous = VectorCount; Vertices[Index].Previous = VertexCount;
Mandatory = Weight[M(Start,Index)]; Mandatory = Weight[M(Start,Index)];
Vector[Index].Weight = Mandatory; Vertices[Index].Weight = Mandatory;
if (Mandatory != MAX_WEIGHT) { if (Mandatory != MAX_WEIGHT) {
Optional = IncludeOptional ? Weight[O(Start, Index)] : 0; Optional = IncludeOptional ? Weight[O(Start, Index)] : 0;
Vector[Index].Weight += Optional; Vertices[Index].Weight += Optional;
ASSERT (Vector[Index].Weight >= Optional); ASSERT (Vertices[Index].Weight >= Optional);
} }
} }
MinI = Start; MinI = Start;
MinWeight = 0; MinWeight = 0;
while (!Vector[Stop].Visited) { while (!Vertices[Stop].Visited) {
// //
// Update the weight from the shortest vector to other unvisited vectors // Update the weight from the shortest vertex to other unvisited vertices
// //
for (Index = Start + 1; Index <= Stop; Index++) { for (Index = Start + 1; Index <= Stop; Index++) {
if (!Vector[Index].Visited) { if (!Vertices[Index].Visited) {
Mandatory = Weight[M(MinI, Index)]; Mandatory = Weight[M(MinI, Index)];
if (Mandatory != MAX_WEIGHT) { if (Mandatory != MAX_WEIGHT) {
Optional = IncludeOptional ? Weight[O(MinI, Index)] : 0; Optional = IncludeOptional ? Weight[O(MinI, Index)] : 0;
if (MinWeight + Mandatory + Optional <= Vector[Index].Weight) { if (MinWeight + Mandatory + Optional <= Vertices[Index].Weight) {
Vector[Index].Weight = MinWeight + Mandatory + Optional; Vertices[Index].Weight = MinWeight + Mandatory + Optional;
Vector[Index].Previous = MinI; // Previous is Start based. Vertices[Index].Previous = MinI; // Previous is Start based.
} }
} }
} }
} }
// //
// Find the shortest vector from Start // Find the shortest vertex from Start
// //
MinI = VectorCount; MinI = VertexCount;
MinWeight = MAX_WEIGHT; MinWeight = MAX_WEIGHT;
for (Index = Start + 1; Index <= Stop; Index++) { for (Index = Start + 1; Index <= Stop; Index++) {
if (!Vector[Index].Visited && MinWeight > Vector[Index].Weight) { if (!Vertices[Index].Visited && MinWeight > Vertices[Index].Weight) {
MinI = Index; MinI = Index;
MinWeight = Vector[Index].Weight; MinWeight = Vertices[Index].Weight;
} }
} }
// //
// Mark the shortest vector from Start as visited // Mark the shortest vertex from Start as visited
// //
Vector[MinI].Visited = TRUE; Vertices[MinI].Visited = TRUE;
} }
} }
@ -1288,17 +1288,17 @@ MtrrLibIsPowerOfTwo (
} }
/** /**
Calculate the subtractive path from vector Start to Stop. Calculate the subtractive path from vertex Start to Stop.
@param DefaultType Default memory type. @param DefaultType Default memory type.
@param A0 Alignment to use when base address is 0. @param A0 Alignment to use when base address is 0.
@param Ranges Array holding memory type settings for all memory regions. @param Ranges Array holding memory type settings for all memory regions.
@param RangeCount The count of memory ranges the array holds. @param RangeCount The count of memory ranges the array holds.
@param VectorCount The count of vectors in the graph. @param VertexCount The count of vertices in the graph.
@param Vector Array holding all vectors. @param Vertices Array holding all vertices.
@param Weight 2-dimention array holding weights between vectors. @param Weight 2-dimention array holding weights between vertices.
@param Start Start vector. @param Start Start vertex.
@param Stop Stop vector. @param Stop Stop vertex.
@param Types Type bit mask of memory range from Start to Stop. @param Types Type bit mask of memory range from Start to Stop.
@param TypeCount Number of different memory types from Start to Stop. @param TypeCount Number of different memory types from Start to Stop.
@param Mtrrs Array holding all MTRR settings. @param Mtrrs Array holding all MTRR settings.
@ -1315,8 +1315,8 @@ MtrrLibCalculateSubtractivePath (
IN UINT64 A0, IN UINT64 A0,
IN CONST MTRR_MEMORY_RANGE *Ranges, IN CONST MTRR_MEMORY_RANGE *Ranges,
IN UINTN RangeCount, IN UINTN RangeCount,
IN UINT16 VectorCount, IN UINT16 VertexCount,
IN MTRR_LIB_ADDRESS *Vector, IN MTRR_LIB_ADDRESS *Vertices,
IN OUT UINT8 *Weight, IN OUT UINT8 *Weight,
IN UINT16 Start, IN UINT16 Start,
IN UINT16 Stop, IN UINT16 Stop,
@ -1342,8 +1342,8 @@ MtrrLibCalculateSubtractivePath (
MTRR_MEMORY_CACHE_TYPE LowestType; MTRR_MEMORY_CACHE_TYPE LowestType;
MTRR_MEMORY_CACHE_TYPE LowestPrecedentType; MTRR_MEMORY_CACHE_TYPE LowestPrecedentType;
Base = Vector[Start].Address; Base = Vertices[Start].Address;
Length = Vector[Stop].Address - Base; Length = Vertices[Stop].Address - Base;
LowestType = MtrrLibLowestType (Types); LowestType = MtrrLibLowestType (Types);
@ -1404,18 +1404,18 @@ MtrrLibCalculateSubtractivePath (
// We might use positive or subtractive, depending on which way uses less MTRR // We might use positive or subtractive, depending on which way uses less MTRR
// //
for (SubStart = Start; SubStart <= Stop; SubStart++) { for (SubStart = Start; SubStart <= Stop; SubStart++) {
if (Vector[SubStart].Address == HBase) { if (Vertices[SubStart].Address == HBase) {
break; break;
} }
} }
for (SubStop = SubStart; SubStop <= Stop; SubStop++) { for (SubStop = SubStart; SubStop <= Stop; SubStop++) {
if (Vector[SubStop].Address == HBase + HLength) { if (Vertices[SubStop].Address == HBase + HLength) {
break; break;
} }
} }
ASSERT (Vector[SubStart].Address == HBase); ASSERT (Vertices[SubStart].Address == HBase);
ASSERT (Vector[SubStop].Address == HBase + HLength); ASSERT (Vertices[SubStop].Address == HBase + HLength);
if ((TypeCount == 2) || (SubStart == SubStop - 1)) { if ((TypeCount == 2) || (SubStart == SubStop - 1)) {
// //
@ -1429,7 +1429,7 @@ MtrrLibCalculateSubtractivePath (
while (SubStart != SubStop) { while (SubStart != SubStop) {
Status = MtrrLibAppendVariableMtrr ( Status = MtrrLibAppendVariableMtrr (
Mtrrs, MtrrCapacity, MtrrCount, Mtrrs, MtrrCapacity, MtrrCount,
Vector[SubStart].Address, Vector[SubStart].Length, (MTRR_MEMORY_CACHE_TYPE) Vector[SubStart].Type Vertices[SubStart].Address, Vertices[SubStart].Length, (MTRR_MEMORY_CACHE_TYPE) Vertices[SubStart].Type
); );
if (RETURN_ERROR (Status)) { if (RETURN_ERROR (Status)) {
return Status; return Status;
@ -1439,21 +1439,21 @@ MtrrLibCalculateSubtractivePath (
} }
} else { } else {
ASSERT (TypeCount == 3); ASSERT (TypeCount == 3);
MtrrLibCalculateLeastMtrrs (VectorCount, Vector, Weight, SubStart, SubStop, TRUE); MtrrLibCalculateLeastMtrrs (VertexCount, Vertices, Weight, SubStart, SubStop, TRUE);
if (Mtrrs == NULL) { if (Mtrrs == NULL) {
Weight[M (Start, Stop)] += Vector[SubStop].Weight; Weight[M (Start, Stop)] += Vertices[SubStop].Weight;
} else { } else {
// When we need to collect the optimal path from SubStart to SubStop // When we need to collect the optimal path from SubStart to SubStop
while (SubStop != SubStart) { while (SubStop != SubStart) {
Cur = SubStop; Cur = SubStop;
Pre = Vector[Cur].Previous; Pre = Vertices[Cur].Previous;
SubStop = Pre; SubStop = Pre;
if (Weight[M (Pre, Cur)] != 0) { if (Weight[M (Pre, Cur)] != 0) {
Status = MtrrLibAppendVariableMtrr ( Status = MtrrLibAppendVariableMtrr (
Mtrrs, MtrrCapacity, MtrrCount, Mtrrs, MtrrCapacity, MtrrCount,
Vector[Pre].Address, Vector[Cur].Address - Vector[Pre].Address, LowestPrecedentType Vertices[Pre].Address, Vertices[Cur].Address - Vertices[Pre].Address, LowestPrecedentType
); );
if (RETURN_ERROR (Status)) { if (RETURN_ERROR (Status)) {
return Status; return Status;
@ -1463,7 +1463,7 @@ MtrrLibCalculateSubtractivePath (
Status = MtrrLibCalculateSubtractivePath ( Status = MtrrLibCalculateSubtractivePath (
DefaultType, A0, DefaultType, A0,
Ranges, RangeCount, Ranges, RangeCount,
VectorCount, Vector, Weight, VertexCount, Vertices, Weight,
Pre, Cur, PrecedentTypes, 2, Pre, Cur, PrecedentTypes, 2,
Mtrrs, MtrrCapacity, MtrrCount Mtrrs, MtrrCapacity, MtrrCount
); );
@ -1526,10 +1526,10 @@ MtrrLibCalculateMtrrs (
UINT64 Length; UINT64 Length;
UINT64 Alignment; UINT64 Alignment;
UINT64 SubLength; UINT64 SubLength;
MTRR_LIB_ADDRESS *Vector; MTRR_LIB_ADDRESS *Vertices;
UINT8 *Weight; UINT8 *Weight;
UINT32 VectorIndex; UINT32 VertexIndex;
UINT32 VectorCount; UINT32 VertexCount;
UINTN RequiredScratchSize; UINTN RequiredScratchSize;
UINT8 TypeCount; UINT8 TypeCount;
UINT16 Start; UINT16 Start;
@ -1542,10 +1542,10 @@ MtrrLibCalculateMtrrs (
MTRR_LIB_ASSERT_ALIGNED (Base0, Base1 - Base0); MTRR_LIB_ASSERT_ALIGNED (Base0, Base1 - Base0);
// //
// Count the number of vectors. // Count the number of vertices.
// //
Vector = (MTRR_LIB_ADDRESS*)Scratch; Vertices = (MTRR_LIB_ADDRESS*)Scratch;
for (VectorIndex = 0, Index = 0; Index < RangeCount; Index++) { for (VertexIndex = 0, Index = 0; Index < RangeCount; Index++) {
Base = Ranges[Index].BaseAddress; Base = Ranges[Index].BaseAddress;
Length = Ranges[Index].Length; Length = Ranges[Index].Length;
while (Length != 0) { while (Length != 0) {
@ -1554,44 +1554,44 @@ MtrrLibCalculateMtrrs (
if (SubLength > Length) { if (SubLength > Length) {
SubLength = GetPowerOfTwo64 (Length); SubLength = GetPowerOfTwo64 (Length);
} }
if (VectorIndex < *ScratchSize / sizeof (*Vector)) { if (VertexIndex < *ScratchSize / sizeof (*Vertices)) {
Vector[VectorIndex].Address = Base; Vertices[VertexIndex].Address = Base;
Vector[VectorIndex].Alignment = Alignment; Vertices[VertexIndex].Alignment = Alignment;
Vector[VectorIndex].Type = Ranges[Index].Type; Vertices[VertexIndex].Type = Ranges[Index].Type;
Vector[VectorIndex].Length = SubLength; Vertices[VertexIndex].Length = SubLength;
} }
Base += SubLength; Base += SubLength;
Length -= SubLength; Length -= SubLength;
VectorIndex++; VertexIndex++;
} }
} }
// //
// Vector[VectorIndex] = Base1, so whole vector count is (VectorIndex + 1). // Vertices[VertexIndex] = Base1, so whole vertex count is (VertexIndex + 1).
// //
VectorCount = VectorIndex + 1; VertexCount = VertexIndex + 1;
DEBUG (( DEBUG ((
DEBUG_CACHE, " VectorCount (%016lx - %016lx) = %d\n", DEBUG_CACHE, " Count of vertices (%016llx - %016llx) = %d\n",
Ranges[0].BaseAddress, Ranges[RangeCount - 1].BaseAddress + Ranges[RangeCount - 1].Length, VectorCount Ranges[0].BaseAddress, Ranges[RangeCount - 1].BaseAddress + Ranges[RangeCount - 1].Length, VertexCount
)); ));
ASSERT (VectorCount < MAX_UINT16); ASSERT (VertexCount < MAX_UINT16);
RequiredScratchSize = VectorCount * sizeof (*Vector) + VectorCount * VectorCount * sizeof (*Weight); RequiredScratchSize = VertexCount * sizeof (*Vertices) + VertexCount * VertexCount * sizeof (*Weight);
if (*ScratchSize < RequiredScratchSize) { if (*ScratchSize < RequiredScratchSize) {
*ScratchSize = RequiredScratchSize; *ScratchSize = RequiredScratchSize;
return RETURN_BUFFER_TOO_SMALL; return RETURN_BUFFER_TOO_SMALL;
} }
Vector[VectorCount - 1].Address = Base1; Vertices[VertexCount - 1].Address = Base1;
Weight = (UINT8 *) &Vector[VectorCount]; Weight = (UINT8 *) &Vertices[VertexCount];
for (VectorIndex = 0; VectorIndex < VectorCount; VectorIndex++) { for (VertexIndex = 0; VertexIndex < VertexCount; VertexIndex++) {
// //
// Set optional weight between vertices and self->self to 0 // Set optional weight between vertices and self->self to 0
// //
SetMem (&Weight[M(VectorIndex, 0)], VectorIndex + 1, 0); SetMem (&Weight[M(VertexIndex, 0)], VertexIndex + 1, 0);
// //
// Set mandatory weight between vectors to MAX_WEIGHT // Set mandatory weight between vertices to MAX_WEIGHT
// //
SetMem (&Weight[M (VectorIndex, VectorIndex + 1)], VectorCount - VectorIndex - 1, MAX_WEIGHT); SetMem (&Weight[M (VertexIndex, VertexIndex + 1)], VertexCount - VertexIndex - 1, MAX_WEIGHT);
// Final result looks like: // Final result looks like:
// 00 FF FF FF // 00 FF FF FF
@ -1603,22 +1603,22 @@ MtrrLibCalculateMtrrs (
// //
// Set mandatory weight and optional weight for adjacent vertices // Set mandatory weight and optional weight for adjacent vertices
// //
for (VectorIndex = 0; VectorIndex < VectorCount - 1; VectorIndex++) { for (VertexIndex = 0; VertexIndex < VertexCount - 1; VertexIndex++) {
if (Vector[VectorIndex].Type != DefaultType) { if (Vertices[VertexIndex].Type != DefaultType) {
Weight[M (VectorIndex, VectorIndex + 1)] = 1; Weight[M (VertexIndex, VertexIndex + 1)] = 1;
Weight[O (VectorIndex, VectorIndex + 1)] = 0; Weight[O (VertexIndex, VertexIndex + 1)] = 0;
} else { } else {
Weight[M (VectorIndex, VectorIndex + 1)] = 0; Weight[M (VertexIndex, VertexIndex + 1)] = 0;
Weight[O (VectorIndex, VectorIndex + 1)] = 1; Weight[O (VertexIndex, VertexIndex + 1)] = 1;
} }
} }
for (TypeCount = 2; TypeCount <= 3; TypeCount++) { for (TypeCount = 2; TypeCount <= 3; TypeCount++) {
for (Start = 0; Start < VectorCount; Start++) { for (Start = 0; Start < VertexCount; Start++) {
for (Stop = Start + 2; Stop < VectorCount; Stop++) { for (Stop = Start + 2; Stop < VertexCount; Stop++) {
ASSERT (Vector[Stop].Address > Vector[Start].Address); ASSERT (Vertices[Stop].Address > Vertices[Start].Address);
Length = Vector[Stop].Address - Vector[Start].Address; Length = Vertices[Stop].Address - Vertices[Start].Address;
if (Length > Vector[Start].Alignment) { if (Length > Vertices[Start].Alignment) {
// //
// Pickup a new Start when [Start, Stop) cannot be described by one MTRR. // Pickup a new Start when [Start, Stop) cannot be described by one MTRR.
// //
@ -1626,7 +1626,7 @@ MtrrLibCalculateMtrrs (
} }
if ((Weight[M(Start, Stop)] == MAX_WEIGHT) && MtrrLibIsPowerOfTwo (Length)) { if ((Weight[M(Start, Stop)] == MAX_WEIGHT) && MtrrLibIsPowerOfTwo (Length)) {
if (MtrrLibGetNumberOfTypes ( if (MtrrLibGetNumberOfTypes (
Ranges, RangeCount, Vector[Start].Address, Vector[Stop].Address - Vector[Start].Address, &Type Ranges, RangeCount, Vertices[Start].Address, Vertices[Stop].Address - Vertices[Start].Address, &Type
) == TypeCount) { ) == TypeCount) {
// //
// Update the Weight[Start, Stop] using subtractive path. // Update the Weight[Start, Stop] using subtractive path.
@ -1634,7 +1634,7 @@ MtrrLibCalculateMtrrs (
MtrrLibCalculateSubtractivePath ( MtrrLibCalculateSubtractivePath (
DefaultType, A0, DefaultType, A0,
Ranges, RangeCount, Ranges, RangeCount,
(UINT16)VectorCount, Vector, Weight, (UINT16)VertexCount, Vertices, Weight,
Start, Stop, Type, TypeCount, Start, Stop, Type, TypeCount,
NULL, 0, NULL NULL, 0, NULL
); );
@ -1651,17 +1651,17 @@ MtrrLibCalculateMtrrs (
} }
Status = RETURN_SUCCESS; Status = RETURN_SUCCESS;
MtrrLibCalculateLeastMtrrs ((UINT16) VectorCount, Vector, Weight, 0, (UINT16) VectorCount - 1, FALSE); MtrrLibCalculateLeastMtrrs ((UINT16) VertexCount, Vertices, Weight, 0, (UINT16) VertexCount - 1, FALSE);
Stop = (UINT16) VectorCount - 1; Stop = (UINT16) VertexCount - 1;
while (Stop != 0) { while (Stop != 0) {
Start = Vector[Stop].Previous; Start = Vertices[Stop].Previous;
TypeCount = MAX_UINT8; TypeCount = MAX_UINT8;
Type = 0; Type = 0;
if (Weight[M(Start, Stop)] != 0) { if (Weight[M(Start, Stop)] != 0) {
TypeCount = MtrrLibGetNumberOfTypes (Ranges, RangeCount, Vector[Start].Address, Vector[Stop].Address - Vector[Start].Address, &Type); TypeCount = MtrrLibGetNumberOfTypes (Ranges, RangeCount, Vertices[Start].Address, Vertices[Stop].Address - Vertices[Start].Address, &Type);
Status = MtrrLibAppendVariableMtrr ( Status = MtrrLibAppendVariableMtrr (
Mtrrs, MtrrCapacity, MtrrCount, Mtrrs, MtrrCapacity, MtrrCount,
Vector[Start].Address, Vector[Stop].Address - Vector[Start].Address, Vertices[Start].Address, Vertices[Stop].Address - Vertices[Start].Address,
MtrrLibLowestType (Type) MtrrLibLowestType (Type)
); );
if (RETURN_ERROR (Status)) { if (RETURN_ERROR (Status)) {
@ -1675,13 +1675,13 @@ MtrrLibCalculateMtrrs (
// //
if (TypeCount == MAX_UINT8) { if (TypeCount == MAX_UINT8) {
TypeCount = MtrrLibGetNumberOfTypes ( TypeCount = MtrrLibGetNumberOfTypes (
Ranges, RangeCount, Vector[Start].Address, Vector[Stop].Address - Vector[Start].Address, &Type Ranges, RangeCount, Vertices[Start].Address, Vertices[Stop].Address - Vertices[Start].Address, &Type
); );
} }
Status = MtrrLibCalculateSubtractivePath ( Status = MtrrLibCalculateSubtractivePath (
DefaultType, A0, DefaultType, A0,
Ranges, RangeCount, Ranges, RangeCount,
(UINT16) VectorCount, Vector, Weight, Start, Stop, (UINT16) VertexCount, Vertices, Weight, Start, Stop,
Type, TypeCount, Type, TypeCount,
Mtrrs, MtrrCapacity, MtrrCount Mtrrs, MtrrCapacity, MtrrCount
); );