416465f
From 9fc0e46189feb926b13713422ea2722e273a31b5 Mon Sep 17 00:00:00 2001
249abc0
From: Al Stone <ahs3@redhat.com>
249abc0
Date: Mon, 19 Oct 2020 17:30:30 -0400
416465f
Subject: [PATCH 40/45] Support S3PT in a big-endian world
249abc0
249abc0
---
249abc0
 source/common/dmtbdump2.c  | 15 +++++++++------
249abc0
 source/compiler/dttable2.c |  4 +++-
249abc0
 2 files changed, 12 insertions(+), 7 deletions(-)
249abc0
fc3eef6
Index: acpica-unix2-20220331/source/common/dmtbdump2.c
38a008c
===================================================================
fc3eef6
--- acpica-unix2-20220331.orig/source/common/dmtbdump2.c
fc3eef6
+++ acpica-unix2-20220331/source/common/dmtbdump2.c
fc3eef6
@@ -2495,6 +2495,8 @@ AcpiDmDumpS3pt (
249abc0
     ACPI_FPDT_HEADER        *Subtable;
249abc0
     ACPI_DMTABLE_INFO       *InfoTable;
249abc0
     ACPI_TABLE_S3PT         *S3ptTable = ACPI_CAST_PTR (ACPI_TABLE_S3PT, Tables);
416465f
+    UINT32                  S3ptTableLength = AcpiUtReadUint32 (&S3ptTable->Length);
249abc0
+    UINT16                  SubtableType;
249abc0
 
249abc0
 
249abc0
     /* Main table */
fc3eef6
@@ -2506,19 +2508,20 @@ AcpiDmDumpS3pt (
249abc0
     }
249abc0
 
249abc0
     Subtable = ACPI_ADD_PTR (ACPI_FPDT_HEADER, S3ptTable, Offset);
249abc0
-    while (Offset < S3ptTable->Length)
249abc0
+    while (Offset < S3ptTableLength)
249abc0
     {
249abc0
         /* Common subtable header */
249abc0
 
249abc0
         AcpiOsPrintf ("\n");
249abc0
-        Status = AcpiDmDumpTable (S3ptTable->Length, Offset, Subtable,
249abc0
+        Status = AcpiDmDumpTable (S3ptTableLength, Offset, Subtable,
249abc0
             Subtable->Length, AcpiDmTableInfoS3ptHdr);
249abc0
         if (ACPI_FAILURE (Status))
249abc0
         {
249abc0
             return 0;
249abc0
         }
249abc0
 
249abc0
-        switch (Subtable->Type)
416465f
+        SubtableType = AcpiUtReadUint16 (&Subtable->Type);
249abc0
+        switch (SubtableType)
249abc0
         {
249abc0
         case ACPI_S3PT_TYPE_RESUME:
249abc0
 
fc3eef6
@@ -2533,7 +2536,7 @@ AcpiDmDumpS3pt (
249abc0
         default:
249abc0
 
249abc0
             AcpiOsPrintf ("\n**** Unknown S3PT subtable type 0x%X\n",
249abc0
-                Subtable->Type);
249abc0
+                SubtableType);
249abc0
 
249abc0
             /* Attempt to continue */
249abc0
 
fc3eef6
@@ -2546,7 +2549,7 @@ AcpiDmDumpS3pt (
249abc0
         }
249abc0
 
249abc0
         AcpiOsPrintf ("\n");
249abc0
-        Status = AcpiDmDumpTable (S3ptTable->Length, Offset, Subtable,
249abc0
+        Status = AcpiDmDumpTable (S3ptTableLength, Offset, Subtable,
249abc0
             Subtable->Length, InfoTable);
249abc0
         if (ACPI_FAILURE (Status))
249abc0
         {
fc3eef6
@@ -2560,7 +2563,7 @@ NextSubtable:
249abc0
         Subtable = ACPI_ADD_PTR (ACPI_FPDT_HEADER, Subtable, Subtable->Length);
249abc0
     }
249abc0
 
249abc0
-    return (S3ptTable->Length);
249abc0
+    return (S3ptTableLength);
249abc0
 }
249abc0
 
249abc0
 
fc3eef6
Index: acpica-unix2-20220331/source/compiler/dttable2.c
38a008c
===================================================================
fc3eef6
--- acpica-unix2-20220331.orig/source/compiler/dttable2.c
fc3eef6
+++ acpica-unix2-20220331/source/compiler/dttable2.c
fc3eef6
@@ -1803,6 +1803,7 @@ DtCompileS3pt (
249abc0
     DT_SUBTABLE             *ParentTable;
249abc0
     ACPI_DMTABLE_INFO       *InfoTable;
249abc0
     DT_FIELD                *SubtableStart;
249abc0
+    UINT16                  S3ptHeaderType;
249abc0
 
249abc0
 
249abc0
     Status = DtCompileTable (PFieldList, AcpiDmTableInfoS3pt,
fc3eef6
@@ -1830,7 +1831,8 @@ DtCompileS3pt (
249abc0
 
249abc0
         S3ptHeader = ACPI_CAST_PTR (ACPI_FPDT_HEADER, Subtable->Buffer);
249abc0
 
249abc0
-        switch (S3ptHeader->Type)
416465f
+        S3ptHeaderType = AcpiUtReadUint16 (&S3ptHeader->Type);
249abc0
+        switch (S3ptHeaderType)
249abc0
         {
249abc0
         case ACPI_S3PT_TYPE_RESUME:
249abc0