f3595dd
diff -Naur acpica-unix2-20200214.orig/source/components/namespace/nsutils.c acpica-unix2-20200214/source/components/namespace/nsutils.c
f3595dd
--- acpica-unix2-20200214.orig/source/components/namespace/nsutils.c	2020-02-14 10:33:55.000000000 -0700
f3595dd
+++ acpica-unix2-20200214/source/components/namespace/nsutils.c	2020-02-26 10:25:43.477022167 -0700
f3595dd
@@ -363,6 +363,15 @@
f3595dd
 
f3595dd
         /* Move on the next segment */
f3595dd
 
f3595dd
+	{
f3595dd
+	    /* Make sure the name segment reflects endian-ness first */
f3595dd
+
f3595dd
+	    UINT32 Tmp32 = 0;
f3595dd
+
f3595dd
+	    memcpy(&Tmp32, Result, ACPI_NAMESEG_SIZE);
f3595dd
+	    ACPI_MOVE_32_TO_32(Result, &Tmp32);
f3595dd
+	}
f3595dd
+
f3595dd
         ExternalName++;
f3595dd
         Result += ACPI_NAMESEG_SIZE;
f3595dd
     }
a4c3787
diff -Naur acpica-unix2-20200214.orig/source/common/dmtbdump2.c acpica-unix2-20200214/source/common/dmtbdump2.c
a4c3787
--- acpica-unix2-20200214.orig/source/common/dmtbdump2.c	2020-02-26 11:44:13.732967820 -0700
a4c3787
+++ acpica-unix2-20200214/source/common/dmtbdump2.c	2020-02-26 12:38:44.286849954 -0700
b549117
@@ -1685,6 +1685,8 @@
a4c3787
     UINT32                  Offset = sizeof (ACPI_TABLE_FPDT);
a4c3787
     ACPI_DMTABLE_INFO       *InfoTable;
a4c3787
     UINT32                  i;
a4c3787
+    UINT32                  TableLen;
a4c3787
+    UINT32                  NumPrivRes;
a4c3787
 
a4c3787
 
a4c3787
     /* There is no main table (other than the standard ACPI header) */
b549117
@@ -1692,7 +1694,8 @@
a4c3787
     /* Subtables */
a4c3787
 
a4c3787
     Offset = sizeof (ACPI_TABLE_HEADER);
a4c3787
-    while (Offset < Table->Length)
a4c3787
+    ACPI_MOVE_32_TO_32(&TableLen, &Table->Length);
a4c3787
+    while (Offset < TableLen)
a4c3787
     {
a4c3787
         AcpiOsPrintf ("\n");
a4c3787
 
b549117
@@ -1704,7 +1707,7 @@
a4c3787
             AcpiOsPrintf ("Invalid subtable length\n");
a4c3787
             return;
a4c3787
         }
a4c3787
-        Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
a4c3787
+        Status = AcpiDmDumpTable (TableLen, Offset, Subtable,
a4c3787
             Subtable->Length, AcpiDmTableInfoPpttHdr);
a4c3787
         if (ACPI_FAILURE (Status))
a4c3787
         {
b549117
@@ -1746,7 +1749,7 @@
a4c3787
             AcpiOsPrintf ("Invalid subtable length\n");
a4c3787
             return;
a4c3787
         }
a4c3787
-        Status = AcpiDmDumpTable (Table->Length, Offset, Subtable,
a4c3787
+        Status = AcpiDmDumpTable (TableLen, Offset, Subtable,
a4c3787
             Subtable->Length, InfoTable);
a4c3787
         if (ACPI_FAILURE (Status))
a4c3787
         {
b549117
@@ -1762,15 +1765,16 @@
a4c3787
 
a4c3787
             /* Dump SMBIOS handles */
a4c3787
 
a4c3787
+	    ACPI_MOVE_32_TO_32(&NumPrivRes, &PpttProcessor->NumberOfPrivResources);
a4c3787
             if ((UINT8)(Subtable->Length - SubtableOffset) <
a4c3787
-                (UINT8)(PpttProcessor->NumberOfPrivResources * 4))
a4c3787
+                (UINT8)(NumPrivRes * 4))
a4c3787
             {
a4c3787
                 AcpiOsPrintf ("Invalid private resource number\n");
a4c3787
                 return;
a4c3787
             }
a4c3787
-            for (i = 0; i < PpttProcessor->NumberOfPrivResources; i++)
a4c3787
+            for (i = 0; i < NumPrivRes; i++)
a4c3787
             {
a4c3787
-                Status = AcpiDmDumpTable (Table->Length, Offset + SubtableOffset,
a4c3787
+                Status = AcpiDmDumpTable (TableLen, Offset + SubtableOffset,
a4c3787
                     ACPI_ADD_PTR (ACPI_SUBTABLE_HEADER, Subtable, SubtableOffset),
a4c3787
                     4, AcpiDmTableInfoPptt0a);
a4c3787
                 if (ACPI_FAILURE (Status))
a4c3787
diff -Naur acpica-unix2-20200214.orig/source/compiler/dttable2.c acpica-unix2-20200214/source/compiler/dttable2.c
a4c3787
--- acpica-unix2-20200214.orig/source/compiler/dttable2.c	2020-02-26 11:44:13.726967769 -0700
a4c3787
+++ acpica-unix2-20200214/source/compiler/dttable2.c	2020-02-26 12:39:03.671014890 -0700
a4c3787
@@ -1087,9 +1087,11 @@
a4c3787
                 Subtable->Buffer, sizeof (ACPI_SUBTABLE_HEADER));
a4c3787
             if (PpttProcessor)
a4c3787
             {
a4c3787
+		UINT32 NumPrivRes;
a4c3787
+
a4c3787
                 /* Compile initiator proximity domain list */
a4c3787
 
a4c3787
-                PpttProcessor->NumberOfPrivResources = 0;
a4c3787
+                NumPrivRes = 0;
a4c3787
                 while (*PFieldList)
a4c3787
                 {
a4c3787
                     Status = DtCompileTable (PFieldList,
a4c3787
@@ -1105,8 +1107,9 @@
a4c3787
 
a4c3787
                     DtInsertSubtable (ParentTable, Subtable);
a4c3787
                     PpttHeader->Length += (UINT8)(Subtable->Length);
a4c3787
-                    PpttProcessor->NumberOfPrivResources++;
a4c3787
+                    NumPrivRes++;
a4c3787
                 }
a4c3787
+		ACPI_MOVE_32_TO_32(&PpttProcessor->NumberOfPrivResources, &NumPrivRes);
a4c3787
             }
a4c3787
             break;
a4c3787
 
2652e3e
diff -Naur acpica-unix2-20200214.orig/source/compiler/aslload.c acpica-unix2-20200214/source/compiler/aslload.c
2652e3e
--- acpica-unix2-20200214.orig/source/compiler/aslload.c	2020-02-14 10:33:53.000000000 -0700
2652e3e
+++ acpica-unix2-20200214/source/compiler/aslload.c	2020-02-27 13:25:19.308413494 -0700
2652e3e
@@ -175,13 +175,17 @@
2652e3e
     ACPI_NAMESPACE_NODE     *Node;
2652e3e
     ACPI_STATUS             Status;
2652e3e
     char                    *ExternalPath;
2652e3e
+    char                    TmpPath[ACPI_NAMESEG_SIZE];
2652e3e
 
2652e3e
 
2652e3e
     SourceRegion = UtGetArg (Op, 0);
2652e3e
     if (SourceRegion)
2652e3e
     {
2652e3e
-        Status = AcpiNsLookup (WalkState->ScopeInfo,
2652e3e
-            SourceRegion->Asl.Value.String, AmlType, ACPI_IMODE_EXECUTE,
2652e3e
+	char TmpName[ACPI_NAMESEG_SIZE];
2652e3e
+
2652e3e
+        ACPI_MOVE_32_TO_32(TmpName, SourceRegion->Asl.Value.String);
2652e3e
+        Status = AcpiNsLookup (WalkState->ScopeInfo, TmpName,
2652e3e
+            AmlType, ACPI_IMODE_EXECUTE,
2652e3e
             ACPI_NS_SEARCH_PARENT | ACPI_NS_DONT_OPEN_SCOPE, NULL, &Node);
2652e3e
         if (Status == AE_NOT_FOUND)
2652e3e
         {
2652e3e
@@ -232,8 +236,9 @@
2652e3e
 
2652e3e
         default:
2652e3e
 
2652e3e
+	    ACPI_MOVE_32_TO_32(TmpPath, Child->Asl.Value.String);
2652e3e
             Status = AcpiNsLookup (WalkState->ScopeInfo,
2652e3e
-                Child->Asl.Value.String,
2652e3e
+                TmpPath,
2652e3e
                 ACPI_TYPE_LOCAL_REGION_FIELD,
2652e3e
                 ACPI_IMODE_LOAD_PASS1,
2652e3e
                 ACPI_NS_NO_UPSEARCH | ACPI_NS_DONT_OPEN_SCOPE |