From: Thomas Petazzoni Date: Thu, 20 Feb 2014 21:42:40 +0000 (+0100) Subject: libv4l: fix build on AArch64 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=045651e253be4ec20abbff0cd2678b88509cbb20;p=buildroot.git libv4l: fix build on AArch64 AArch64 does not implement the SYS_open system call, but only the SYS_openat system call, as should be done for all modern architectures merged into the Linux kernel. This causes problems when building libv4l 0.8.9, which are fixed by integrating an upstream patch, available in a more recent version of libv4l. Backporting the patch is preferred over bumping libv4l, as libv4l has a fairly large number of reverse dependencies, and we don't want to break anything that close to the release. Note that this commit also renames the existing libv4l-largefile.patch to libv4l-01-largefile.patch in order to comply with the Buildroot patch naming scheme, and guarantee the order in which patches are applied. Fixes: http://autobuild.buildroot.org/results/ed6/ed66792e332ee0256a17f98cbe21dfcfe6e8743b/ Signed-off-by: Thomas Petazzoni Signed-off-by: Peter Korsgaard --- diff --git a/package/libv4l/libv4l-01-largefile.patch b/package/libv4l/libv4l-01-largefile.patch new file mode 100644 index 0000000000..9df8652adc --- /dev/null +++ b/package/libv4l/libv4l-01-largefile.patch @@ -0,0 +1,39 @@ +[PATCH] fixup lfs mismatch in preload libraries + +Ensure that the lfs variants are not transparently used instead of the !lfs +ones so both can be wrapped, independently of any custom CFLAGS/CPPFLAGS. + +Signed-off-by: Peter Korsgaard +--- + lib/libv4l1/v4l1compat.c | 3 +++ + lib/libv4l2/v4l2convert.c | 3 +++ + 2 files changed, 6 insertions(+) + +Index: v4l-utils-0.8.5/lib/libv4l1/v4l1compat.c +=================================================================== +--- v4l-utils-0.8.5.orig/lib/libv4l1/v4l1compat.c ++++ v4l-utils-0.8.5/lib/libv4l1/v4l1compat.c +@@ -19,6 +19,9 @@ + # Foundation, Inc., 51 Franklin Street, Suite 500, Boston, MA 02110-1335 USA + */ + ++/* ensure we see *64 variants and they aren't transparently used */ ++#undef _LARGEFILE_SOURCE ++#undef _FILE_OFFSET_BITS + #define _LARGEFILE64_SOURCE 1 + + #include +Index: v4l-utils-0.8.5/lib/libv4l2/v4l2convert.c +=================================================================== +--- v4l-utils-0.8.5.orig/lib/libv4l2/v4l2convert.c ++++ v4l-utils-0.8.5/lib/libv4l2/v4l2convert.c +@@ -20,6 +20,9 @@ + # Foundation, Inc., 51 Franklin Street, Suite 500, Boston, MA 02110-1335 USA + */ + ++/* ensure we see *64 variants and they aren't transparently used */ ++#undef _LARGEFILE_SOURCE ++#undef _FILE_OFFSET_BITS + #define _LARGEFILE64_SOURCE 1 + + #include diff --git a/package/libv4l/libv4l-02-use-openat-when-available.patch b/package/libv4l/libv4l-02-use-openat-when-available.patch new file mode 100644 index 0000000000..756733e3eb --- /dev/null +++ b/package/libv4l/libv4l-02-use-openat-when-available.patch @@ -0,0 +1,34 @@ +From: Riku Voipio +Date: Tue, 22 Jan 2013 15:37:22 +0000 (-0300) +Subject: v4l-utils: use openat when available +X-Git-Tag: v4l-utils-0.9.4~61 +X-Git-Url: http://git.linuxtv.org + +v4l-utils: use openat when available + +New architectures such as 64-Bit arm build kernels without legacy +system calls - Such as the the no-at system calls. Thus, use +SYS_openat whenever it is available. + +Signed-off-by: Riku Voipio +Signed-off-by: Mauro Carvalho Chehab +--- + +diff --git a/lib/libv4lconvert/libv4lsyscall-priv.h b/lib/libv4lconvert/libv4lsyscall-priv.h +index 2dac49a..cdd38bc 100644 +--- a/lib/libv4lconvert/libv4lsyscall-priv.h ++++ b/lib/libv4lconvert/libv4lsyscall-priv.h +@@ -72,8 +72,13 @@ typedef off_t __off_t; + + #ifndef CONFIG_SYS_WRAPPER + ++#ifdef SYS_openat ++#define SYS_OPEN(file, oflag, mode) \ ++ syscall(SYS_openat, AT_FDCWD, (const char *)(file), (int)(oflag), (mode_t)(mode)) ++#else + #define SYS_OPEN(file, oflag, mode) \ + syscall(SYS_open, (const char *)(file), (int)(oflag), (mode_t)(mode)) ++#endif + #define SYS_CLOSE(fd) \ + syscall(SYS_close, (int)(fd)) + #define SYS_IOCTL(fd, cmd, arg) \ diff --git a/package/libv4l/libv4l-largefile.patch b/package/libv4l/libv4l-largefile.patch deleted file mode 100644 index 9df8652adc..0000000000 --- a/package/libv4l/libv4l-largefile.patch +++ /dev/null @@ -1,39 +0,0 @@ -[PATCH] fixup lfs mismatch in preload libraries - -Ensure that the lfs variants are not transparently used instead of the !lfs -ones so both can be wrapped, independently of any custom CFLAGS/CPPFLAGS. - -Signed-off-by: Peter Korsgaard ---- - lib/libv4l1/v4l1compat.c | 3 +++ - lib/libv4l2/v4l2convert.c | 3 +++ - 2 files changed, 6 insertions(+) - -Index: v4l-utils-0.8.5/lib/libv4l1/v4l1compat.c -=================================================================== ---- v4l-utils-0.8.5.orig/lib/libv4l1/v4l1compat.c -+++ v4l-utils-0.8.5/lib/libv4l1/v4l1compat.c -@@ -19,6 +19,9 @@ - # Foundation, Inc., 51 Franklin Street, Suite 500, Boston, MA 02110-1335 USA - */ - -+/* ensure we see *64 variants and they aren't transparently used */ -+#undef _LARGEFILE_SOURCE -+#undef _FILE_OFFSET_BITS - #define _LARGEFILE64_SOURCE 1 - - #include -Index: v4l-utils-0.8.5/lib/libv4l2/v4l2convert.c -=================================================================== ---- v4l-utils-0.8.5.orig/lib/libv4l2/v4l2convert.c -+++ v4l-utils-0.8.5/lib/libv4l2/v4l2convert.c -@@ -20,6 +20,9 @@ - # Foundation, Inc., 51 Franklin Street, Suite 500, Boston, MA 02110-1335 USA - */ - -+/* ensure we see *64 variants and they aren't transparently used */ -+#undef _LARGEFILE_SOURCE -+#undef _FILE_OFFSET_BITS - #define _LARGEFILE64_SOURCE 1 - - #include