]> git.droids-corp.org - dpdk.git/commitdiff
pmdinfogen: fix endianness with cross-compilation
authorNeil Horman <nhorman@tuxdriver.com>
Fri, 18 Nov 2016 18:47:52 +0000 (13:47 -0500)
committerThomas Monjalon <thomas.monjalon@6wind.com>
Thu, 1 Dec 2016 15:11:51 +0000 (16:11 +0100)
pmdinfogen has a bug in which, during build, it pulls in rte_byteorder.h to
obtain the rte macros for byteswapping between the cpu byte order and big or
little endian.  Unfortunately, pmdinfogen is a tool that is only meant to be run
during the build of dpdk components, and so, it runs on the host.  In cross
compile environments however, the rte_byteorder.h is configured using a target
cpu, who's endianness may differ from that of the host, leading to improper
swapping.

The fix is to use host system defined byte swapping routines rather than the
dpdk provided routines.  Note that we are using non posix compliant routines, as
the posix compliant api only addresses 16 and 32 bit swaps, and we also need 64
bit swaps.  Those macros exist (via endian.h), but BSD and Linux put that header
in different locations so some ifdeffery is required.

Tested successfully by myself on Linux and BSD systems.

Fixes: 98b0fdb0ffc6 ("pmdinfogen: add buildtools and pmdinfogen utility")
Signed-off-by: Neil Horman <nhorman@tuxdriver.com>
Tested-by: Bruce Richardson <bruce.richardson@intel.com>
buildtools/pmdinfogen/pmdinfogen.h

index 1da2966f9b9d6a44a88a6e73daf352d8d88c0392..e9eabffb439208b6889f08d049227adb2e954a1f 100644 (file)
 #include <sys/types.h>
 #include <sys/stat.h>
 #include <sys/mman.h>
+#ifdef __linux__
+#include <endian.h>
+#else
+#include <sys/endian.h>
+#endif
 #include <fcntl.h>
 #include <unistd.h>
 #include <elf.h>
 #include <rte_config.h>
 #include <rte_pci.h>
-#include <rte_byteorder.h>
 
 /* On BSD-alike OSes elf.h defines these according to host's word size */
 #undef ELF_ST_BIND
@@ -75,9 +79,9 @@
 #define CONVERT_NATIVE(fend, width, x) ({ \
 typeof(x) ___x; \
 if ((fend) == ELFDATA2LSB) \
-       ___x = rte_le_to_cpu_##width(x); \
+       ___x = le##width##toh(x); \
 else \
-       ___x = rte_be_to_cpu_##width(x); \
+       ___x = be##width##toh(x); \
        ___x; \
 })