configure.ac 6.85 KB
Newer Older
Niels Möller's avatar
Niels Möller committed
1
2
dnl -*- mode: shell-script; sh-indentation: 2; -*-

3
4
dnl Process this file with autoconf to produce a configure script.

Niels Möller's avatar
Niels Möller committed
5
AC_INIT([nettle], [1.13], [nettle-bugs@lists.lysator.liu.se])
6
AC_PREREQ(2.50)
7
8
9
10
AC_CONFIG_SRCDIR([arcfour.c])
# Needed to stop autoconf from looking for files in parent directories.
AC_CONFIG_AUX_DIR([.])

11
AC_CONFIG_HEADER([config.h])
12

Niels Möller's avatar
Niels Möller committed
13
SHLIBMAJOR=2
14
SHLIBMINOR=3
15

16
17
AC_CANONICAL_HOST

18
19
20
21
22
23
# Command line options
AC_ARG_WITH(include-path,
  AC_HELP_STRING([--with-include-path], [A colon-separated list of directories to search for include files]),,
  [with_include_path=''])

if test x$with_include_path != x ; then
24
  CPPFLAGS="$CPPFLAGS -I`echo $with_include_path | sed 's/:/ -I/g'`"
25
26
27
28
29
30
31
fi

AC_ARG_WITH(lib-path,
  AC_HELP_STRING([--with-lib-path], [A colon-separated list of directories to search for libraries]),,
  [with_lib_path=''])

if test x$with_lib_path != x ; then
32
  LDFLAGS="$LDFLAGS -L`echo $with_lib_path | sed 's/:/ -L/g'`"
33
34
fi

35
36
37
38
AC_ARG_ENABLE(public-key,
  AC_HELP_STRING([--disable-public-key], [Disable public key algorithms]),,
  [enable_public_key=yes])

39
AC_ARG_ENABLE(assembler,
40
41
  AC_HELP_STRING([--disable-assembler],[Disable assembler code]),,
  [enable_assembler=yes])
42

43
AC_ARG_ENABLE(shared,
44
  AC_HELP_STRING([--enable-shared], [Build a shared library]),,
45
46
  [enable_shared=no])

47
48
49
50
51
AC_ARG_ENABLE(pic,
  AC_HELP_STRING([--disable-pic],
  [Do not try to compile library files as position independent code]),,
  [enable_pic=yes])

52
53
54
55
AC_ARG_ENABLE(openssl,
  AC_HELP_STRING([--disable-openssl], [Do not include openssl glue in the benchmark program]),,
  [enable_openssl=yes])
  
56
57
58
59
60
LSH_RPATH_INIT([`echo $with_lib_path | sed 's/:/ /g'` \
    `echo $exec_prefix | sed "s@^NONE@$prefix/lib@g" | sed "s@^NONE@$ac_default_prefix/lib@g"` \
    /usr/local/lib /sw/local/lib /sw/lib \
    /usr/gnu/lib /opt/gnu/lib /sw/gnu/lib /usr/freeware/lib /usr/pkg/lib])

61
# Checks for programs.
Niels Möller's avatar
Niels Möller committed
62
AC_PROG_CC
63
64
65
66
67
68
69
70

# When $CC foo.c -o foo creates both foo and foo.exe, autoconf picks
# up the foo.exe and sets exeext to .exe. That is correct for cygwin,
# which has some kind of magic link from foo to foo.exe, but not for
# rntcl. A better check for the cygwin case would check if the
# contents of foo and foo.exe are equal; in the rntcl case, foo is a
# sh script, and foo.exe is a windows executable.

Niels Möller's avatar
Niels Möller committed
71
if test "x$CC" = xrntcl ; then
Niels Möller's avatar
Niels Möller committed
72
    AC_MSG_NOTICE([Compiling with rntcl; clearing EXEEXT])
73
74
    ac_exeext=''
    ac_cv_exeext=''
Niels Möller's avatar
Niels Möller committed
75
    EXEEXT=''
76
77
fi

Niels Möller's avatar
Niels Möller committed
78
AC_PROG_MAKE_SET
Niels Möller's avatar
Niels Möller committed
79
80
AC_PROG_RANLIB

81
if test "x$ac_cv_prog_cc_stdc" = xno ; then
Niels Möller's avatar
Niels Möller committed
82
83
  AC_ERROR([the C compiler doesn't handle ANSI-C])
fi
84

85
86
87
88
AC_PROG_INSTALL

LSH_DEPENDENCY_TRACKING

89
# Select assembler code
90
asm_path=
91
92
case "$host" in
  [i?86*-*-* | k[5-8]*-*-* | pentium*-*-* | athlon-*-*])
93
    asm_path=x86
94
95
    ;;
  *sparc*-*-*)
96
    asm_path=sparc
97
    ;;
98
99
100
  *)
    enable_assembler=no
    ;;
101
102
esac

103
# echo "enable_assembler: $enable_assembler, asm_path: $asm_path"
104

105
if test "x$enable_assembler" = xyes ; then
106
  if test -n "$asm_path"; then
Niels Möller's avatar
Niels Möller committed
107
    AC_MSG_NOTICE([Looking for assembler files in $asm_path/.])
108
    found=no
109
    for tmp_f in aes.asm aes-encrypt.asm aes-decrypt.asm \
110
		 arcfour-crypt.asm sha1-compress.asm machine.m4; do
111
112
#       echo "Looking for $srcdir/$asm_path/$tmp_f"
      if test -f "$srcdir/$asm_path/$tmp_f"; then
113
#        echo found
114
        found=yes
115
        AC_CONFIG_LINKS($tmp_f:$asm_path/$tmp_f)
116
117
118
119
120
121
122
123
124
      fi
    done
    if test "$found" = no; then
      enable_assembler=no
      AC_MSG_WARN([No assembler files found.])
    fi
  fi
fi

125
126
127
LSH_CCPIC

SHLIBCFLAGS="$CCPIC"
128
129
130
131
132
133

case `uname -sr` in
  CYGWIN*)
    SHLIBFORLINK='cygnettle-$(SHLIBMAJOR)-$(SHLIBMINOR).dll'
    SHLIBSONAME=''
    SHLIBFILE='libnettle.dll.a'
134
135
    SHLIBLINK='$(CC) $(LDFLAGS) -shared -Wl,--out-implib=$(SHLIBFILE) -Wl,--export-all-symbols -Wl,--enable-auto-import -Wl,--whole-archive'
    SHLIBLIBS='-Wl,--no-whole-archive $(LIBS)'
136
137
138
139
140
141
    ;;
  *)
    SHLIBFORLINK=libnettle.so
    SHLIBSONAME='$(SHLIBFORLINK).$(SHLIBMAJOR)'
    SHLIBFILE='$(SHLIBSONAME).$(SHLIBMINOR)'
    SHLIBLINK='$(CC) $(LDFLAGS) -shared -Wl,-soname=$(SHLIBSONAME)'
Niels Möller's avatar
Niels Möller committed
142
143
    # FIXME: It might make some sense to link with -lgmp
    SHLIBLIBS=''
144
145
    ;;
esac
146
147
148
149

if test "x$enable_shared" = xyes ; then
  SHLIBTARGET='$(SHLIBFORLINK)'
  SHLIBINSTALL=install-shared
150
151
152
else
  SHLIBTARGET=''
  SHLIBINSTALL=''
153
154
fi

155
156
157
158
if test "x$enable_pic" = xyes; then
  CCPIC_MAYBE="$CCPIC"
else
  CCPIC_MAYBE=''
159
fi
160
AC_SUBST([CCPIC_MAYBE])
161

162
LSH_MAKE_CONDITIONAL([ENABLE_ASM], [test x$enable_assembler = xyes])
163

164
AC_SUBST(SHLIBCFLAGS)
165
166
AC_SUBST(SHLIBMAJOR)
AC_SUBST(SHLIBMINOR)
167
168
169
170
AC_SUBST(SHLIBFORLINK)
AC_SUBST(SHLIBSONAME)
AC_SUBST(SHLIBFILE)
AC_SUBST(SHLIBLINK)
171
172
AC_SUBST(SHLIBTARGET)
AC_SUBST(SHLIBINSTALL)
Niels Möller's avatar
Niels Möller committed
173
174
AC_SUBST(SHLIBLIBS)

Niels Möller's avatar
Niels Möller committed
175
AC_PATH_PROG(M4, m4, m4)
176

177
# Checks for typedefs, structures, and compiler characteristics.
Niels Möller's avatar
Niels Möller committed
178
AC_C_CONST
Niels Möller's avatar
Niels Möller committed
179
180
181
182
183
AC_C_INLINE
AC_TYPE_UID_T
AC_TYPE_SIZE_T
AC_HEADER_TIME

184
185
186
187
AC_CHECK_HEADERS([openssl/blowfish.h openssl/des.h openssl/cast.h],,
[enable_openssl=no
 break])

Niels Möller's avatar
Niels Möller committed
188
LSH_FUNC_ALLOCA
Niels Möller's avatar
Niels Möller committed
189

Niels Möller's avatar
Niels Möller committed
190
# Needed by the supplied memcmp.c
Niels Möller's avatar
Niels Möller committed
191
AC_C_BIGENDIAN
Niels Möller's avatar
Niels Möller committed
192
193
AC_REPLACE_FUNCS(memxor)

Niels Möller's avatar
Niels Möller committed
194
LSH_GCC_ATTRIBUTES
Niels Möller's avatar
Niels Möller committed
195

196
197
198
# According to Simon Josefsson, looking for uint32_t and friends in
# sys/types.h is needed on some systems, in particular cygwin.
AX_CREATE_STDINT_H([nettle-types.h], [sys/types.h])
199

200
201
202
203
# Checks for libraries
AC_CHECK_LIB(gmp, __gmpz_getlimbn,,
    [AC_MSG_WARN(
[GNU MP not found, or not 3.1 or up, see http://www.swox.com/gmp.
204
205
206
207
208
Support for public key algorithms will be unavailable.])]
    enable_public_key=no)

if test "x$enable_public_key" = xyes ; then
  AC_DEFINE(WITH_PUBLIC_KEY)
209
  RSA_EXAMPLES='rsa-keygen$(EXEEXT) rsa-sign$(EXEEXT) rsa-verify$(EXEEXT) rsa-encrypt$(EXEEXT) rsa-decrypt$(EXEEXT)'
210
211
else
  RSA_EXAMPLES=""
212
213
214
fi

AH_TEMPLATE([WITH_PUBLIC_KEY], [Define to enable public key features])
215
AC_SUBST(RSA_EXAMPLES)
216

217
218
# Add -R flags needed to run programs linked with gmp
LSH_RPATH_FIX
219

220
221
OPENSSL_LIBFLAGS=''

222
# Check for openssl's libcrypto (used only for benchmarking)
223
224
225
226
227
228
229
230
231
232
233
234
if test x$enable_openssl = xyes ; then
  AC_CHECK_LIB(crypto, BF_ecb_encrypt,
    [OPENSSL_LIBFLAGS='-lcrypto'],
    [enable_openssl=no])
fi

AH_TEMPLATE([WITH_OPENSSL],
	    [Define if you have openssl's libcrypto (used for benchmarking)])

if test x$enable_openssl = xyes ; then
  AC_DEFINE(WITH_OPENSSL)
fi
235
236

AC_SUBST(OPENSSL_LIBFLAGS)
237

Niels Möller's avatar
Niels Möller committed
238
239
# Set these flags *last*, or else the test programs won't compile
if test x$GCC = xyes ; then
240
241
242
243
244
245
246
247
248
  # Using -ggdb3 makes (some versions of) Redhat's gcc-2.96 dump core
  if "$CC" --version | grep '^2\.96$' 1>/dev/null 2>&1; then
    true
  else
    CFLAGS="$CFLAGS -ggdb3"
  fi
  CFLAGS="$CFLAGS -Wall -W \
  -Wmissing-prototypes -Wmissing-declarations -Wstrict-prototypes \
  -Wpointer-arith -Wbad-function-cast -Wnested-externs"
Niels Möller's avatar
Niels Möller committed
249
250
251

# Don't enable -Wcast-align as it results in tons of warnings in the
# DES code. And when using stdio.
252
253
# Don't enable -Waggregate-return, as that causes warnings for glibc
# inttypes.h.
Niels Möller's avatar
Niels Möller committed
254
fi
Niels Möller's avatar
Niels Möller committed
255

256
257
258
259
AC_CONFIG_FILES([config.make config.m4 Makefile])
AC_CONFIG_FILES([tools/Makefile testsuite/Makefile examples/Makefile])

AC_OUTPUT
260