Blame SOURCES/0020-Support-RSDT-RSD-PTR-in-a-big-endian-world.patch

214d7a
From 198abe6e9fcb03676513146bf2f9b8ccc49e5827 Mon Sep 17 00:00:00 2001
214d7a
From: Al Stone <ahs3@redhat.com>
214d7a
Date: Wed, 23 Sep 2020 12:11:46 -0600
214d7a
Subject: [PATCH 20/45] Support RSDT ('RSD PTR') in a big-endian world
214d7a
214d7a
Signed-off-by: Al Stone <ahs3@redhat.com>
214d7a
---
214d7a
 source/common/dmtbdump.c | 5 +++--
214d7a
 1 file changed, 3 insertions(+), 2 deletions(-)
214d7a
214d7a
Index: acpica-unix2-20210604/source/common/dmtbdump.c
214d7a
===================================================================
214d7a
--- acpica-unix2-20210604.orig/source/common/dmtbdump.c
214d7a
+++ acpica-unix2-20210604/source/common/dmtbdump.c
214d7a
@@ -282,6 +282,7 @@ AcpiDmDumpRsdt (
214d7a
     UINT32                  Entries;
214d7a
     UINT32                  Offset;
214d7a
     UINT32                  i;
214d7a
+    UINT32                  TableLength = AcpiUtReadUint32 (&Table->Length);
214d7a
 
214d7a
 
214d7a
     /* Point to start of table pointer array */
214d7a
@@ -291,12 +292,12 @@ AcpiDmDumpRsdt (
214d7a
 
214d7a
     /* RSDT uses 32-bit pointers */
214d7a
 
214d7a
-    Entries = (Table->Length - sizeof (ACPI_TABLE_HEADER)) / sizeof (UINT32);
214d7a
+    Entries = (TableLength - sizeof (ACPI_TABLE_HEADER)) / sizeof (UINT32);
214d7a
 
214d7a
     for (i = 0; i < Entries; i++)
214d7a
     {
214d7a
         AcpiDmLineHeader2 (Offset, sizeof (UINT32), "ACPI Table Address", i);
214d7a
-        AcpiOsPrintf ("%8.8X\n", Array[i]);
214d7a
+        AcpiOsPrintf ("%8.8X\n", AcpiUtReadUint32 (&Array[i]));
214d7a
         Offset += sizeof (UINT32);
214d7a
     }
214d7a
 }