416465f
From ce811b4c38b9a09533ee8bafa22813f6e43c023d Mon Sep 17 00:00:00 2001
edb6c78
From: Al Stone <ahs3@redhat.com>
edb6c78
Date: Fri, 18 Sep 2020 16:41:02 -0600
416465f
Subject: [PATCH 09/45] Support ASF! tables in a big-endian world
edb6c78
edb6c78
Read the table length properly and it all works right for big-endian.
edb6c78
edb6c78
Signed-off-by: Al Stone <ahs3@redhat.com>
edb6c78
---
edb6c78
 source/common/dmtbdump1.c | 10 ++++++----
edb6c78
 1 file changed, 6 insertions(+), 4 deletions(-)
edb6c78
fc3eef6
Index: acpica-unix2-20220331/source/common/dmtbdump1.c
edb6c78
===================================================================
fc3eef6
--- acpica-unix2-20220331.orig/source/common/dmtbdump1.c
fc3eef6
+++ acpica-unix2-20220331/source/common/dmtbdump1.c
fc3eef6
@@ -358,16 +358,18 @@ AcpiDmDumpAsf (
edb6c78
     UINT32                  DataOffset = 0;
edb6c78
     UINT32                  i;
edb6c78
     UINT8                   Type;
edb6c78
+    UINT32                  TableLength;
edb6c78
 
edb6c78
 
edb6c78
     /* No main table, only subtables */
edb6c78
 
edb6c78
     Subtable = ACPI_ADD_PTR (ACPI_ASF_INFO, Table, Offset);
edb6c78
-    while (Offset < Table->Length)
416465f
+    TableLength = AcpiUtReadUint32 (&Table->Length);
edb6c78
+    while (Offset < TableLength)
edb6c78
     {
edb6c78
         /* Common subtable header */
edb6c78
 
edb6c78
-        Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
edb6c78
+        Status = AcpiDmDumpTable (TableLength, Offset, Subtable,
edb6c78
             Subtable->Header.Length, AcpiDmTableInfoAsfHdr);
edb6c78
         if (ACPI_FAILURE (Status))
edb6c78
         {
fc3eef6
@@ -425,7 +427,7 @@ AcpiDmDumpAsf (
edb6c78
             return;
edb6c78
         }
edb6c78
 
edb6c78
-        Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
edb6c78
+        Status = AcpiDmDumpTable (TableLength, Offset, Subtable,
edb6c78
             Subtable->Header.Length, InfoTable);
edb6c78
         if (ACPI_FAILURE (Status))
edb6c78
         {
fc3eef6
@@ -442,7 +444,7 @@ AcpiDmDumpAsf (
edb6c78
             for (i = 0; i < DataCount; i++)
edb6c78
             {
edb6c78
                 AcpiOsPrintf ("\n");
edb6c78
-                Status = AcpiDmDumpTable (Table->Length, DataOffset,
edb6c78
+                Status = AcpiDmDumpTable (TableLength, DataOffset,
edb6c78
                     DataTable, DataLength, DataInfoTable);
edb6c78
                 if (ACPI_FAILURE (Status))
edb6c78
                 {