Blame 0035-Support-PMTT-in-a-big-endian-world.patch

edb6c78
From b55af37d2419fc5ea630774f49b4ed9b724451b3 Mon Sep 17 00:00:00 2001
edb6c78
From: Al Stone <ahs3@redhat.com>
edb6c78
Date: Mon, 28 Sep 2020 18:37:04 -0600
edb6c78
Subject: [PATCH 35/40] Support PMTT in a big-endian world
edb6c78
edb6c78
Signed-off-by: Al Stone <ahs3@redhat.com>
edb6c78
---
edb6c78
 source/common/dmtbdump2.c  | 66 +++++++++++++++++++++-----------------
edb6c78
 source/compiler/dttable2.c |  5 ++-
edb6c78
 2 files changed, 41 insertions(+), 30 deletions(-)
edb6c78
edb6c78
Index: acpica-unix2-20200925/source/common/dmtbdump2.c
edb6c78
===================================================================
edb6c78
--- acpica-unix2-20200925.orig/source/common/dmtbdump2.c
edb6c78
+++ acpica-unix2-20200925/source/common/dmtbdump2.c
edb6c78
@@ -1442,17 +1442,21 @@ AcpiDmDumpPmtt (
edb6c78
     ACPI_PMTT_HEADER        *MemSubtable;
edb6c78
     ACPI_PMTT_HEADER        *DimmSubtable;
edb6c78
     ACPI_PMTT_DOMAIN        *DomainArray;
edb6c78
-    UINT32                  Length = Table->Length;
edb6c78
+    UINT32                  TableLength = AcpiUtReadUint32(&Table->Length);
edb6c78
     UINT32                  Offset = sizeof (ACPI_TABLE_PMTT);
edb6c78
     UINT32                  MemOffset;
edb6c78
     UINT32                  DimmOffset;
edb6c78
     UINT32                  DomainOffset;
edb6c78
     UINT32                  DomainCount;
edb6c78
+    UINT16                  SubtableLength;
edb6c78
+    UINT16                  MemSubtableLength;
edb6c78
+    UINT16                  DimmSubtableLength;
edb6c78
+    UINT16                  Tmp16;
edb6c78
 
edb6c78
 
edb6c78
     /* Main table */
edb6c78
 
edb6c78
-    Status = AcpiDmDumpTable (Length, 0, Table, 0, AcpiDmTableInfoPmtt);
edb6c78
+    Status = AcpiDmDumpTable (TableLength, 0, Table, 0, AcpiDmTableInfoPmtt);
edb6c78
     if (ACPI_FAILURE (Status))
edb6c78
     {
edb6c78
         return;
edb6c78
@@ -1461,13 +1465,14 @@ AcpiDmDumpPmtt (
edb6c78
     /* Subtables */
edb6c78
 
edb6c78
     Subtable = ACPI_ADD_PTR (ACPI_PMTT_HEADER, Table, Offset);
edb6c78
-    while (Offset < Table->Length)
edb6c78
+    while (Offset < TableLength)
edb6c78
     {
edb6c78
         /* Common subtable header */
edb6c78
 
edb6c78
         AcpiOsPrintf ("\n");
edb6c78
-        Status = AcpiDmDumpTable (Length, Offset, Subtable,
edb6c78
-            Subtable->Length, AcpiDmTableInfoPmttHdr);
edb6c78
+	SubtableLength = AcpiUtReadUint16(&Subtable->Length);
edb6c78
+        Status = AcpiDmDumpTable (TableLength, Offset, Subtable,
edb6c78
+            SubtableLength, AcpiDmTableInfoPmttHdr);
edb6c78
         if (ACPI_FAILURE (Status))
edb6c78
         {
edb6c78
             return;
edb6c78
@@ -1485,8 +1490,8 @@ AcpiDmDumpPmtt (
edb6c78
 
edb6c78
         /* Dump the fixed-length portion of the subtable */
edb6c78
 
edb6c78
-        Status = AcpiDmDumpTable (Length, Offset, Subtable,
edb6c78
-            Subtable->Length, AcpiDmTableInfoPmtt0);
edb6c78
+        Status = AcpiDmDumpTable (TableLength, Offset, Subtable,
edb6c78
+            SubtableLength, AcpiDmTableInfoPmtt0);
edb6c78
         if (ACPI_FAILURE (Status))
edb6c78
         {
edb6c78
             return;
edb6c78
@@ -1498,15 +1503,16 @@ AcpiDmDumpPmtt (
edb6c78
         MemSubtable = ACPI_ADD_PTR (ACPI_PMTT_HEADER, Subtable,
edb6c78
             sizeof (ACPI_PMTT_SOCKET));
edb6c78
 
edb6c78
-        while (((Offset + MemOffset) < Table->Length) &&
edb6c78
-            (MemOffset < Subtable->Length))
edb6c78
+        while (((Offset + MemOffset) < TableLength) &&
edb6c78
+            (MemOffset < SubtableLength))
edb6c78
         {
edb6c78
             /* Common subtable header */
edb6c78
 
edb6c78
             AcpiOsPrintf ("\n");
edb6c78
-            Status = AcpiDmDumpTable (Length,
edb6c78
+	    MemSubtableLength = AcpiUtReadUint16(&MemSubtable->Length);
edb6c78
+            Status = AcpiDmDumpTable (TableLength,
edb6c78
                 Offset + MemOffset, MemSubtable,
edb6c78
-                MemSubtable->Length, AcpiDmTableInfoPmttHdr);
edb6c78
+                MemSubtableLength, AcpiDmTableInfoPmttHdr);
edb6c78
             if (ACPI_FAILURE (Status))
edb6c78
             {
edb6c78
                 return;
edb6c78
@@ -1524,9 +1530,9 @@ AcpiDmDumpPmtt (
edb6c78
 
edb6c78
             /* Dump the fixed-length portion of the controller subtable */
edb6c78
 
edb6c78
-            Status = AcpiDmDumpTable (Length,
edb6c78
+            Status = AcpiDmDumpTable (TableLength,
edb6c78
                 Offset + MemOffset, MemSubtable,
edb6c78
-                MemSubtable->Length, AcpiDmTableInfoPmtt1);
edb6c78
+                MemSubtableLength, AcpiDmTableInfoPmtt1);
edb6c78
             if (ACPI_FAILURE (Status))
edb6c78
             {
edb6c78
                 return;
edb6c78
@@ -1534,16 +1540,17 @@ AcpiDmDumpPmtt (
edb6c78
 
edb6c78
             /* Walk the variable count of proximity domains */
edb6c78
 
edb6c78
-            DomainCount = ((ACPI_PMTT_CONTROLLER *) MemSubtable)->DomainCount;
edb6c78
+            Tmp16 = ((ACPI_PMTT_CONTROLLER *) MemSubtable)->DomainCount;
edb6c78
+            DomainCount = AcpiUtReadUint16(&Tmp16);
edb6c78
             DomainOffset = sizeof (ACPI_PMTT_CONTROLLER);
edb6c78
             DomainArray = ACPI_ADD_PTR (ACPI_PMTT_DOMAIN, MemSubtable,
edb6c78
                 sizeof (ACPI_PMTT_CONTROLLER));
edb6c78
 
edb6c78
-            while (((Offset + MemOffset + DomainOffset) < Table->Length) &&
edb6c78
-                ((MemOffset + DomainOffset) < Subtable->Length) &&
edb6c78
+            while (((Offset + MemOffset + DomainOffset) < TableLength) &&
edb6c78
+                ((MemOffset + DomainOffset) < SubtableLength) &&
edb6c78
                 DomainCount)
edb6c78
             {
edb6c78
-                Status = AcpiDmDumpTable (Length,
edb6c78
+                Status = AcpiDmDumpTable (TableLength,
edb6c78
                     Offset + MemOffset + DomainOffset, DomainArray,
edb6c78
                     sizeof (ACPI_PMTT_DOMAIN), AcpiDmTableInfoPmtt1a);
edb6c78
                 if (ACPI_FAILURE (Status))
edb6c78
@@ -1568,15 +1575,16 @@ AcpiDmDumpPmtt (
edb6c78
             DimmSubtable = ACPI_ADD_PTR (ACPI_PMTT_HEADER, MemSubtable,
edb6c78
                 DomainOffset);
edb6c78
 
edb6c78
-            while (((Offset + MemOffset + DimmOffset) < Table->Length) &&
edb6c78
-                (DimmOffset < MemSubtable->Length))
edb6c78
+            while (((Offset + MemOffset + DimmOffset) < TableLength) &&
edb6c78
+                (DimmOffset < MemSubtableLength))
edb6c78
             {
edb6c78
                 /* Common subtable header */
edb6c78
 
edb6c78
                 AcpiOsPrintf ("\n");
edb6c78
-                Status = AcpiDmDumpTable (Length,
edb6c78
+		DimmSubtableLength = AcpiUtReadUint16(&DimmSubtable->Length);
edb6c78
+                Status = AcpiDmDumpTable (TableLength,
edb6c78
                     Offset + MemOffset + DimmOffset, DimmSubtable,
edb6c78
-                    DimmSubtable->Length, AcpiDmTableInfoPmttHdr);
edb6c78
+                    DimmSubtableLength, AcpiDmTableInfoPmttHdr);
edb6c78
                 if (ACPI_FAILURE (Status))
edb6c78
                 {
edb6c78
                     return;
edb6c78
@@ -1594,9 +1602,9 @@ AcpiDmDumpPmtt (
edb6c78
 
edb6c78
                 /* Dump the fixed-length DIMM subtable */
edb6c78
 
edb6c78
-                Status = AcpiDmDumpTable (Length,
edb6c78
+                Status = AcpiDmDumpTable (TableLength,
edb6c78
                     Offset + MemOffset + DimmOffset, DimmSubtable,
edb6c78
-                    DimmSubtable->Length, AcpiDmTableInfoPmtt2);
edb6c78
+                    DimmSubtableLength, AcpiDmTableInfoPmtt2);
edb6c78
                 if (ACPI_FAILURE (Status))
edb6c78
                 {
edb6c78
                     return;
edb6c78
@@ -1604,23 +1612,23 @@ AcpiDmDumpPmtt (
edb6c78
 
edb6c78
                 /* Point to next DIMM subtable */
edb6c78
 
edb6c78
-                DimmOffset += DimmSubtable->Length;
edb6c78
+                DimmOffset += DimmSubtableLength;
edb6c78
                 DimmSubtable = ACPI_ADD_PTR (ACPI_PMTT_HEADER,
edb6c78
-                    DimmSubtable, DimmSubtable->Length);
edb6c78
+                    DimmSubtable, DimmSubtableLength);
edb6c78
             }
edb6c78
 
edb6c78
             /* Point to next Controller subtable */
edb6c78
 
edb6c78
-            MemOffset += MemSubtable->Length;
edb6c78
+            MemOffset += MemSubtableLength;
edb6c78
             MemSubtable = ACPI_ADD_PTR (ACPI_PMTT_HEADER,
edb6c78
-                MemSubtable, MemSubtable->Length);
edb6c78
+                MemSubtable, MemSubtableLength);
edb6c78
         }
edb6c78
 
edb6c78
         /* Point to next Socket subtable */
edb6c78
 
edb6c78
-        Offset += Subtable->Length;
edb6c78
+        Offset += SubtableLength;
edb6c78
         Subtable = ACPI_ADD_PTR (ACPI_PMTT_HEADER,
edb6c78
-            Subtable, Subtable->Length);
edb6c78
+            Subtable, SubtableLength);
edb6c78
     }
edb6c78
 }
edb6c78
 
edb6c78
Index: acpica-unix2-20200925/source/compiler/dttable2.c
edb6c78
===================================================================
edb6c78
--- acpica-unix2-20200925.orig/source/compiler/dttable2.c
edb6c78
+++ acpica-unix2-20200925/source/compiler/dttable2.c
edb6c78
@@ -885,6 +885,7 @@ DtCompilePmtt (
edb6c78
     ACPI_PMTT_HEADER        *PmttHeader;
edb6c78
     ACPI_PMTT_CONTROLLER    *PmttController;
edb6c78
     UINT16                  DomainCount;
edb6c78
+    UINT16                  Length;
edb6c78
     UINT8                   PrevType = ACPI_PMTT_TYPE_SOCKET;
edb6c78
 
edb6c78
 
edb6c78
@@ -929,6 +930,8 @@ DtCompilePmtt (
edb6c78
         DtInsertSubtable (ParentTable, Subtable);
edb6c78
         DtPushSubtable (Subtable);
edb6c78
 
edb6c78
+	Length = AcpiUtReadUint16(&PmttHeader->Length);
edb6c78
+	PmttHeader->Length = Length;
edb6c78
         switch (PmttHeader->Type)
edb6c78
         {
edb6c78
         case ACPI_PMTT_TYPE_SOCKET:
edb6c78
@@ -962,7 +965,7 @@ DtCompilePmtt (
edb6c78
 
edb6c78
             PmttController = ACPI_CAST_PTR (ACPI_PMTT_CONTROLLER,
edb6c78
                 (Subtable->Buffer - sizeof (ACPI_PMTT_HEADER)));
edb6c78
-            DomainCount = PmttController->DomainCount;
edb6c78
+            DomainCount = AcpiUtReadUint16(&PmttController->DomainCount);
edb6c78
 
edb6c78
             while (DomainCount)
edb6c78
             {