1 From fc392c939b9a18959482f588aff0afc29dd6d30a Mon Sep 17 00:00:00 2001
2 From: Romain Naour <romain.naour@openwide.fr>
3 Date: Fri, 23 Jan 2015 22:20:18 +0100
4 Subject: [PATCH 6/6] unix/configure: borrow the LFS test from autotools.
6 Infozip's LFS check can't work for cross-compilation
7 since it try to run a target's binary on the host system.
9 Instead, use to LFS test used by autotools which is a
11 (see autotools/lib/autoconf/specific.m4)
13 Reported-by: Richard Genoud <richard.genoud@gmail.com>
14 Signed-off-by: Romain Naour <romain.naour@openwide.fr>
16 unix/configure | 51 ++++++++++++++++++---------------------------------
17 1 file changed, 18 insertions(+), 33 deletions(-)
19 diff --git a/unix/configure b/unix/configure
20 index 7bfc9eb..588f269 100644
23 @@ -237,9 +237,8 @@ _EOF_
24 $CC $CFLAGS -c conftest.c >/dev/null 2>/dev/null
25 [ $? -ne 0 ] && CFLAGS="${CFLAGS} -DNO_OFF_T"
27 -# Now we set the 64-bit file environment and check the size of off_t
29 -# Revised 8/12/2004 EG
30 +# LFS check borrowed from autotools sources
31 +# lib/autoconf/specific.m4
33 echo Check for Large File Support
34 cat > conftest.c << _EOF_
35 @@ -247,24 +246,22 @@ cat > conftest.c << _EOF_
36 # define _LARGEFILE64_SOURCE
37 # define _FILE_OFFSET_BITS 64 /* select default interface as 64 bit */
38 # define _LARGE_FILES /* some OSes need this for 64-bit off_t */
40 #include <sys/types.h>
41 -#include <sys/stat.h>
45 + /* Check that off_t can represent 2**63 - 1 correctly.
46 + We can't simply define LARGE_OFF_T to be 9223372036854775807,
47 + since some C++ compilers masquerading as C compilers
48 + incorrectly reject 9223372036854775807. */
49 +#define LARGE_OFF_T (((off_t) 1 << 62) - 1 + ((off_t) 1 << 62))
50 + int off_t_is_large[(LARGE_OFF_T % 2147483629 == 721
51 + && LARGE_OFF_T % 2147483647 == 1)
58 - /* see if have 64-bit off_t */
59 - if (sizeof(offset) < 8)
61 - printf(" off_t is %d bytes\n", sizeof(off_t));
62 - /* see if have 64-bit stat */
63 - if (sizeof(s.st_size) < 8) {
64 - printf(" s.st_size is %d bytes\n", sizeof(s.st_size));
74 @@ -272,22 +269,10 @@ $CC -o conftest conftest.c >/dev/null 2>/dev/null
76 echo -- no Large File Support
81 - if [ $r -eq 1 ]; then
82 - echo -- no Large File Support - no 64-bit off_t
83 - elif [ $r -eq 2 ]; then
84 - echo -- no Large File Support - no 64-bit stat
85 - elif [ $r -eq 3 ]; then
86 - echo -- yes we have Large File Support!
87 - CFLAGS="${CFLAGS} -DLARGE_FILE_SUPPORT"
89 - echo -- no Large File Support - conftest returned $r
91 + echo -- yes we have Large File Support!
92 + CFLAGS="${CFLAGS} -DLARGE_FILE_SUPPORT"
96 # Check for wide char for Unicode support