efi_selftest: simplify endian conversion for FDT test
authorHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Thu, 25 Nov 2021 17:55:09 +0000 (18:55 +0100)
committerHeinrich Schuchardt <heinrich.schuchardt@canonical.com>
Fri, 26 Nov 2021 20:30:59 +0000 (21:30 +0100)
UEFI code is always little-endian. Remove a superfluous test.

Remove a superfluous type conversion.

Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
lib/efi_selftest/efi_selftest_fdt.c

index eae9820..412ba28 100644 (file)
@@ -23,23 +23,24 @@ static const char *fdt;
 static const efi_guid_t fdt_guid = EFI_FDT_GUID;
 static const efi_guid_t acpi_guid = EFI_ACPI_TABLE_GUID;
 
-/*
- * Convert FDT value to host endianness.
+/**
+ * f2h() - convert FDT value to host endianness.
  *
- * @val                FDT value
- * @return     converted value
+ * UEFI code is always low endian. The FDT is big endian.
+ *
+ * @val:       FDT value
+ * Return:     converted value
  */
 static uint32_t f2h(fdt32_t val)
 {
        char *buf = (char *)&val;
        char i;
 
-#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
        /* Swap the bytes */
        i = buf[0]; buf[0] = buf[3]; buf[3] = i;
        i = buf[1]; buf[1] = buf[2]; buf[2] = i;
-#endif
-       return *(uint32_t *)buf;
+
+       return val;
 }
 
 /**