1 On big-endian machines, a test case looking for the methods _L1D and _E1D
2 in the same scope would fail (see tests/misc/badcode.asl:184). The names
3 to be compared were being treated as 32-bit ints, and not strings. Hence,
4 the characters were re-ordered incorrectly, mismatching the assumptions
5 made in the remainder of the function.
7 diff -urN acpica-unix2-20130214/source/compiler/aslanalyze.c acpica-unix2-20130214-names/source/compiler/aslanalyze.c
8 --- acpica-unix2-20130214/source/compiler/aslanalyze.c 2013-03-21 17:31:25.803324990 -0600
9 +++ acpica-unix2-20130214-names/source/compiler/aslanalyze.c 2013-03-21 17:43:45.357616802 -0600
12 /* Need a null-terminated string version of NameSeg */
14 - ACPI_MOVE_32_TO_32 (Name, &Op->Asl.NameSeg);
15 + ACPI_MOVE_NAME (Name, &Op->Asl.NameSeg);
16 Name[ACPI_NAME_SIZE] = 0;
20 * We are now sure we have an _Lxx or _Exx.
21 * Create the target name that would cause collision (Flip E/L)
23 - ACPI_MOVE_32_TO_32 (Target, Name);
24 + ACPI_MOVE_NAME (Target, Name);
26 /* Inject opposite letter ("L" versus "E") */