aboutsummaryrefslogtreecommitdiff
path: root/tests/testdata.h
diff options
context:
space:
mode:
authorDavid Gibson <david@gibson.dropbear.id.au>2007-09-17 15:42:36 +1000
committerJon Loeliger <jdl@freescale.com>2007-09-17 14:18:19 -0500
commit874ff219afd310902707bf7d2362af7285ba559e (patch)
tree2a415aaaccba9ad711f5cfe1f35e0588e377242a /tests/testdata.h
parentae1454b3111e4653895dbba18d594bd78c91d086 (diff)
downloaddtc-874ff219afd310902707bf7d2362af7285ba559e.zip
dtc-874ff219afd310902707bf7d2362af7285ba559e.tar.gz
dtc-874ff219afd310902707bf7d2362af7285ba559e.tar.bz2
libfdt: Consistently use big-endian property data in testcases
Flat device trees always have integers in their structure stored as big-endian. From this point of view, property values are bags-of-bytes and any endianness is up to users of the device tree to determine. The libfdt testcases which use properties with integer values, currently use native endian format for the architecture on which the testcases are run. This works ok for now, since both the creation and checking of the example device trees happen in the same endianness. This will become a problem, however, for tests of dtc which we want to add in the nearish future. dtc always uses big-endian format for 'cell' format data in properties; as it needs to in order to produce powerpc-usable device trees when hosted on a little-endian architecture. This patch, therefore, changes the libfdt testsuite to use big-endian format always for integer format data, in order to interoperate sanely with future dtc testcases. This also means that the example trees created by the testsuite should now be byte-for-byte identical regardless of dtc and libfdt's host platform, which is arguably an advantage. Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Diffstat (limited to 'tests/testdata.h')
-rw-r--r--tests/testdata.h15
1 files changed, 13 insertions, 2 deletions
diff --git a/tests/testdata.h b/tests/testdata.h
index 822c69a..15a4a35 100644
--- a/tests/testdata.h
+++ b/tests/testdata.h
@@ -1,5 +1,16 @@
-#define TEST_VALUE_1 0xdeadbeef
-#define TEST_VALUE_2 0xabcd1234
+#include <endian.h>
+
+#if __BYTE_ORDER == __BIG_ENDIAN
+#define cell_to_fdt(x) (x)
+#else
+/* We do this as a big hairy expression instead of using bswap_32()
+ * because we need it to work in asm as well as C. */
+#define cell_to_fdt(x) ((((x) >> 24) & 0xff) | (((x) >> 8) & 0xff00) \
+ | (((x) << 8) & 0xff0000) | (((x) << 24) & 0xff000000))
+#endif
+
+#define TEST_VALUE_1 cell_to_fdt(0xdeadbeef)
+#define TEST_VALUE_2 cell_to_fdt(0xabcd1234)
#define TEST_STRING_1 "hello world"