Configure revision 1.17 1 1.1 christos :
2 1.1 christos eval 'exec perl -S $0 ${1+"$@"}'
3 1.1 christos if $running_under_some_shell;
4 1.1 christos ##
5 1.1 christos ## Configure -- OpenSSL source tree configuration script
6 1.1 christos ##
7 1.1 christos
8 1.1 christos require 5.000;
9 1.1 christos use strict;
10 1.17 spz use File::Compare;
11 1.1 christos
12 1.1 christos # see INSTALL for instructions.
13 1.1 christos
14 1.3 christos my $usage="Usage: Configure [no-<cipher> ...] [enable-<cipher> ...] [experimental-<cipher> ...] [-Dxxx] [-lxxx] [-Lxxx] [-fxxx] [-Kxxx] [no-hw-xxx|no-hw] [[no-]threads] [[no-]shared] [[no-]zlib|zlib-dynamic] [no-asm] [no-dso] [no-krb5] [sctp] [386] [--prefix=DIR] [--openssldir=OPENSSLDIR] [--with-xxx[=vvv]] [--test-sanity] os/compiler[:flags]\n";
15 1.1 christos
16 1.1 christos # Options:
17 1.1 christos #
18 1.1 christos # --openssldir install OpenSSL in OPENSSLDIR (Default: DIR/ssl if the
19 1.1 christos # --prefix option is given; /usr/local/ssl otherwise)
20 1.1 christos # --prefix prefix for the OpenSSL include, lib and bin directories
21 1.1 christos # (Default: the OPENSSLDIR directory)
22 1.1 christos #
23 1.1 christos # --install_prefix Additional prefix for package builders (empty by
24 1.1 christos # default). This needn't be set in advance, you can
25 1.1 christos # just as well use "make INSTALL_PREFIX=/whatever install".
26 1.1 christos #
27 1.1 christos # --with-krb5-dir Declare where Kerberos 5 lives. The libraries are expected
28 1.1 christos # to live in the subdirectory lib/ and the header files in
29 1.1 christos # include/. A value is required.
30 1.1 christos # --with-krb5-lib Declare where the Kerberos 5 libraries live. A value is
31 1.1 christos # required.
32 1.1 christos # (Default: KRB5_DIR/lib)
33 1.1 christos # --with-krb5-include Declare where the Kerberos 5 header files live. A
34 1.1 christos # value is required.
35 1.1 christos # (Default: KRB5_DIR/include)
36 1.1 christos # --with-krb5-flavor Declare what flavor of Kerberos 5 is used. Currently
37 1.1 christos # supported values are "MIT" and "Heimdal". A value is required.
38 1.1 christos #
39 1.1 christos # --test-sanity Make a number of sanity checks on the data in this file.
40 1.1 christos # This is a debugging tool for OpenSSL developers.
41 1.1 christos #
42 1.1 christos # --cross-compile-prefix Add specified prefix to binutils components.
43 1.1 christos #
44 1.1 christos # no-hw-xxx do not compile support for specific crypto hardware.
45 1.1 christos # Generic OpenSSL-style methods relating to this support
46 1.1 christos # are always compiled but return NULL if the hardware
47 1.1 christos # support isn't compiled.
48 1.1 christos # no-hw do not compile support for any crypto hardware.
49 1.1 christos # [no-]threads [don't] try to create a library that is suitable for
50 1.1 christos # multithreaded applications (default is "threads" if we
51 1.1 christos # know how to do it)
52 1.1 christos # [no-]shared [don't] try to create shared libraries when supported.
53 1.1 christos # no-asm do not use assembler
54 1.1 christos # no-dso do not compile in any native shared-library methods. This
55 1.1 christos # will ensure that all methods just return NULL.
56 1.1 christos # no-krb5 do not compile in any KRB5 library or code.
57 1.1 christos # [no-]zlib [don't] compile support for zlib compression.
58 1.1 christos # zlib-dynamic Like "zlib", but the zlib library is expected to be a shared
59 1.1 christos # library and will be loaded in run-time by the OpenSSL library.
60 1.3 christos # sctp include SCTP support
61 1.15 christos # enable-weak-ssl-ciphers
62 1.15 christos # Enable EXPORT and LOW SSLv3 ciphers that are disabled by
63 1.15 christos # default. Note, weak SSLv2 ciphers are unconditionally
64 1.15 christos # disabled.
65 1.17 spz # 386 generate 80386 code in assembly modules
66 1.17 spz # no-sse2 disables IA-32 SSE2 code in assembly modules, the above
67 1.17 spz # mentioned '386' option implies this one
68 1.1 christos # no-<cipher> build without specified algorithm (rsa, idea, rc5, ...)
69 1.1 christos # -<xxx> +<xxx> compiler options are passed through
70 1.1 christos #
71 1.1 christos # DEBUG_SAFESTACK use type-safe stacks to enforce type-safety on stack items
72 1.1 christos # provided to stack calls. Generates unique stack functions for
73 1.1 christos # each possible stack type.
74 1.1 christos # DES_PTR use pointer lookup vs arrays in the DES in crypto/des/des_locl.h
75 1.1 christos # DES_RISC1 use different DES_ENCRYPT macro that helps reduce register
76 1.1 christos # dependancies but needs to more registers, good for RISC CPU's
77 1.1 christos # DES_RISC2 A different RISC variant.
78 1.1 christos # DES_UNROLL unroll the inner DES loop, sometimes helps, somtimes hinders.
79 1.1 christos # DES_INT use 'int' instead of 'long' for DES_LONG in crypto/des/des.h
80 1.1 christos # This is used on the DEC Alpha where long is 8 bytes
81 1.1 christos # and int is 4
82 1.1 christos # BN_LLONG use the type 'long long' in crypto/bn/bn.h
83 1.1 christos # MD2_CHAR use 'char' instead of 'int' for MD2_INT in crypto/md2/md2.h
84 1.1 christos # MD2_LONG use 'long' instead of 'int' for MD2_INT in crypto/md2/md2.h
85 1.1 christos # IDEA_SHORT use 'short' instead of 'int' for IDEA_INT in crypto/idea/idea.h
86 1.1 christos # IDEA_LONG use 'long' instead of 'int' for IDEA_INT in crypto/idea/idea.h
87 1.1 christos # RC2_SHORT use 'short' instead of 'int' for RC2_INT in crypto/rc2/rc2.h
88 1.1 christos # RC2_LONG use 'long' instead of 'int' for RC2_INT in crypto/rc2/rc2.h
89 1.1 christos # RC4_CHAR use 'char' instead of 'int' for RC4_INT in crypto/rc4/rc4.h
90 1.1 christos # RC4_LONG use 'long' instead of 'int' for RC4_INT in crypto/rc4/rc4.h
91 1.1 christos # RC4_INDEX define RC4_INDEX in crypto/rc4/rc4_locl.h. This turns on
92 1.1 christos # array lookups instead of pointer use.
93 1.1 christos # RC4_CHUNK enables code that handles data aligned at long (natural CPU
94 1.1 christos # word) boundary.
95 1.1 christos # RC4_CHUNK_LL enables code that handles data aligned at long long boundary
96 1.1 christos # (intended for 64-bit CPUs running 32-bit OS).
97 1.1 christos # BF_PTR use 'pointer arithmatic' for Blowfish (unsafe on Alpha).
98 1.1 christos # BF_PTR2 intel specific version (generic version is more efficient).
99 1.1 christos #
100 1.1 christos # Following are set automatically by this script
101 1.1 christos #
102 1.1 christos # MD5_ASM use some extra md5 assember,
103 1.1 christos # SHA1_ASM use some extra sha1 assember, must define L_ENDIAN for x86
104 1.1 christos # RMD160_ASM use some extra ripemd160 assember,
105 1.1 christos # SHA256_ASM sha256_block is implemented in assembler
106 1.1 christos # SHA512_ASM sha512_block is implemented in assembler
107 1.1 christos # AES_ASM ASE_[en|de]crypt is implemented in assembler
108 1.1 christos
109 1.1 christos # Minimum warning options... any contributions to OpenSSL should at least get
110 1.1 christos # past these.
111 1.1 christos
112 1.1 christos my $gcc_devteam_warn = "-Wall -pedantic -DPEDANTIC -Wno-long-long -Wsign-compare -Wmissing-prototypes -Wshadow -Wformat -Werror -DCRYPTO_MDEBUG_ALL -DCRYPTO_MDEBUG_ABORT -DREF_CHECK -DOPENSSL_NO_DEPRECATED";
113 1.1 christos
114 1.16 spz # TODO(openssl-team): fix problems and investigate if (at least) the following
115 1.16 spz # warnings can also be enabled:
116 1.16 spz # -Wconditional-uninitialized, -Wswitch-enum, -Wunused-macros,
117 1.16 spz # -Wmissing-field-initializers, -Wmissing-variable-declarations,
118 1.16 spz # -Wincompatible-pointer-types-discards-qualifiers, -Wcast-align,
119 1.16 spz # -Wunreachable-code -Wunused-parameter -Wlanguage-extension-token
120 1.16 spz # -Wextended-offsetof
121 1.16 spz my $clang_disabled_warnings = "-Wno-unused-parameter -Wno-missing-field-initializers -Wno-language-extension-token -Wno-extended-offsetof";
122 1.16 spz
123 1.16 spz # These are used in addition to $gcc_devteam_warn when the compiler is clang.
124 1.16 spz # TODO(openssl-team): fix problems and investigate if (at least) the
125 1.16 spz # following warnings can also be enabled: -Wconditional-uninitialized,
126 1.16 spz # -Wswitch-enum, -Wunused-macros, -Wmissing-field-initializers,
127 1.16 spz # -Wmissing-variable-declarations,
128 1.16 spz # -Wincompatible-pointer-types-discards-qualifiers, -Wcast-align,
129 1.16 spz # -Wunreachable-code -Wunused-parameter -Wlanguage-extension-token
130 1.16 spz # -Wextended-offsetof
131 1.16 spz my $clang_devteam_warn = "-Wno-unused-parameter -Wno-missing-field-initializers -Wno-language-extension-token -Wno-extended-offsetof -Qunused-arguments";
132 1.16 spz
133 1.14 christos # Warn that "make depend" should be run?
134 1.14 christos my $warn_make_depend = 0;
135 1.14 christos
136 1.2 spz my $strict_warnings = 0;
137 1.2 spz
138 1.1 christos my $x86_gcc_des="DES_PTR DES_RISC1 DES_UNROLL";
139 1.1 christos
140 1.1 christos # MD2_CHAR slags pentium pros
141 1.1 christos my $x86_gcc_opts="RC4_INDEX MD2_INT";
142 1.1 christos
143 1.1 christos # MODIFY THESE PARAMETERS IF YOU ARE GOING TO USE THE 'util/speed.sh SCRIPT
144 1.1 christos # Don't worry about these normally
145 1.1 christos
146 1.1 christos my $tcc="cc";
147 1.1 christos my $tflags="-fast -Xa";
148 1.1 christos my $tbn_mul="";
149 1.1 christos my $tlib="-lnsl -lsocket";
150 1.1 christos #$bits1="SIXTEEN_BIT ";
151 1.1 christos #$bits2="THIRTY_TWO_BIT ";
152 1.1 christos my $bits1="THIRTY_TWO_BIT ";
153 1.1 christos my $bits2="SIXTY_FOUR_BIT ";
154 1.1 christos
155 1.16 spz my $x86_asm="x86cpuid.o:bn-586.o co-586.o x86-mont.o x86-gf2m.o::des-586.o crypt586.o:aes-586.o vpaes-x86.o aesni-x86.o:bf-586.o:md5-586.o:sha1-586.o sha256-586.o sha512-586.o:cast-586.o:rc4-586.o:rmd-586.o:rc5-586.o:wp_block.o wp-mmx.o:cmll-x86.o:ghash-x86.o:";
156 1.1 christos
157 1.1 christos my $x86_elf_asm="$x86_asm:elf";
158 1.1 christos
159 1.16 spz my $x86_64_asm="x86_64cpuid.o:x86_64-gcc.o x86_64-mont.o x86_64-mont5.o x86_64-gf2m.o rsaz_exp.o rsaz-x86_64.o rsaz-avx2.o:ecp_nistz256.o ecp_nistz256-x86_64.o::aes-x86_64.o vpaes-x86_64.o bsaes-x86_64.o aesni-x86_64.o aesni-sha1-x86_64.o aesni-sha256-x86_64.o aesni-mb-x86_64.o::md5-x86_64.o:sha1-x86_64.o sha256-x86_64.o sha512-x86_64.o sha1-mb-x86_64.o sha256-mb-x86_64.o::rc4-x86_64.o rc4-md5-x86_64.o:::wp-x86_64.o:cmll-x86_64.o cmll_misc.o:ghash-x86_64.o aesni-gcm-x86_64.o:";
160 1.16 spz my $ia64_asm="ia64cpuid.o:bn-ia64.o ia64-mont.o:::aes_core.o aes_cbc.o aes-ia64.o::md5-ia64.o:sha1-ia64.o sha256-ia64.o sha512-ia64.o::rc4-ia64.o rc4_skey.o:::::ghash-ia64.o::void";
161 1.16 spz my $sparcv9_asm="sparcv9cap.o sparccpuid.o:bn-sparcv9.o sparcv9-mont.o sparcv9a-mont.o vis3-mont.o sparct4-mont.o sparcv9-gf2m.o::des_enc-sparc.o fcrypt_b.o dest4-sparcv9.o:aes_core.o aes_cbc.o aes-sparcv9.o aest4-sparcv9.o::md5-sparcv9.o:sha1-sparcv9.o sha256-sparcv9.o sha512-sparcv9.o::::::camellia.o cmll_misc.o cmll_cbc.o cmllt4-sparcv9.o:ghash-sparcv9.o::void";
162 1.16 spz my $sparcv8_asm=":sparcv8.o::des_enc-sparc.o fcrypt_b.o:::::::::::::void";
163 1.16 spz my $alpha_asm="alphacpuid.o:bn_asm.o alpha-mont.o::::::sha1-alpha.o:::::::ghash-alpha.o::void";
164 1.16 spz my $mips64_asm=":bn-mips.o mips-mont.o:::aes_cbc.o aes-mips.o:::sha1-mips.o sha256-mips.o sha512-mips.o::::::::";
165 1.16 spz my $mips32_asm=$mips64_asm; $mips32_asm =~ s/\s*sha512\-mips\.o//;
166 1.16 spz my $s390x_asm="s390xcap.o s390xcpuid.o:bn-s390x.o s390x-mont.o s390x-gf2m.o:::aes-s390x.o aes-ctr.o aes-xts.o:::sha1-s390x.o sha256-s390x.o sha512-s390x.o::rc4-s390x.o:::::ghash-s390x.o:";
167 1.16 spz my $armv4_asm="armcap.o armv4cpuid.o:bn_asm.o armv4-mont.o armv4-gf2m.o:::aes_cbc.o aes-armv4.o bsaes-armv7.o aesv8-armx.o:::sha1-armv4-large.o sha256-armv4.o sha512-armv4.o:::::::ghash-armv4.o ghashv8-armx.o::void";
168 1.16 spz my $aarch64_asm="armcap.o arm64cpuid.o mem_clr.o::::aes_core.o aes_cbc.o aesv8-armx.o:::sha1-armv8.o sha256-armv8.o sha512-armv8.o:::::::ghashv8-armx.o:";
169 1.16 spz my $parisc11_asm="pariscid.o:bn_asm.o parisc-mont.o:::aes_core.o aes_cbc.o aes-parisc.o:::sha1-parisc.o sha256-parisc.o sha512-parisc.o::rc4-parisc.o:::::ghash-parisc.o::32";
170 1.16 spz my $parisc20_asm="pariscid.o:pa-risc2W.o parisc-mont.o:::aes_core.o aes_cbc.o aes-parisc.o:::sha1-parisc.o sha256-parisc.o sha512-parisc.o::rc4-parisc.o:::::ghash-parisc.o::64";
171 1.16 spz my $ppc64_asm="ppccpuid.o ppccap.o:bn-ppc.o ppc-mont.o ppc64-mont.o:::aes_core.o aes_cbc.o aes-ppc.o vpaes-ppc.o aesp8-ppc.o:::sha1-ppc.o sha256-ppc.o sha512-ppc.o sha256p8-ppc.o sha512p8-ppc.o:::::::ghashp8-ppc.o:";
172 1.16 spz my $ppc32_asm=$ppc64_asm;
173 1.16 spz my $no_asm="::::::::::::::::void";
174 1.1 christos
175 1.1 christos # As for $BSDthreads. Idea is to maintain "collective" set of flags,
176 1.1 christos # which would cover all BSD flavors. -pthread applies to them all,
177 1.1 christos # but is treated differently. OpenBSD expands is as -D_POSIX_THREAD
178 1.1 christos # -lc_r, which is sufficient. FreeBSD 4.x expands it as -lc_r,
179 1.1 christos # which has to be accompanied by explicit -D_THREAD_SAFE and
180 1.1 christos # sometimes -D_REENTRANT. FreeBSD 5.x expands it as -lc_r, which
181 1.1 christos # seems to be sufficient?
182 1.1 christos my $BSDthreads="-pthread -D_THREAD_SAFE -D_REENTRANT";
183 1.1 christos
184 1.16 spz #config-string $cc : $cflags : $unistd : $thread_cflag : $sys_id : $lflags : $bn_ops : $cpuid_obj : $bn_obj : $ec_obj : $des_obj : $aes_obj : $bf_obj : $md5_obj : $sha1_obj : $cast_obj : $rc4_obj : $rmd160_obj : $rc5_obj : $wp_obj : $cmll_obj : $modes_obj : $engines_obj : $dso_scheme : $shared_target : $shared_cflag : $shared_ldflag : $shared_extension : $ranlib : $arflags : $multilib
185 1.1 christos
186 1.1 christos my %table=(
187 1.1 christos # File 'TABLE' (created by 'make TABLE') contains the data from this list,
188 1.1 christos # formatted for better readability.
189 1.1 christos
190 1.1 christos
191 1.1 christos #"b", "${tcc}:${tflags}::${tlib}:${bits1}:${tbn_mul}::",
192 1.1 christos #"bl-4c-2c", "${tcc}:${tflags}::${tlib}:${bits1}BN_LLONG RC4_CHAR MD2_CHAR:${tbn_mul}::",
193 1.1 christos #"bl-4c-ri", "${tcc}:${tflags}::${tlib}:${bits1}BN_LLONG RC4_CHAR RC4_INDEX:${tbn_mul}::",
194 1.1 christos #"b2-is-ri-dp", "${tcc}:${tflags}::${tlib}:${bits2}IDEA_SHORT RC4_INDEX DES_PTR:${tbn_mul}::",
195 1.1 christos
196 1.1 christos # Our development configs
197 1.1 christos "purify", "purify gcc:-g -DPURIFY -Wall::(unknown)::-lsocket -lnsl::::",
198 1.1 christos "debug", "gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DOPENSSL_NO_ASM -ggdb -g2 -Wformat -Wshadow -Wmissing-prototypes -Wmissing-declarations -Werror::(unknown)::-lefence::::",
199 1.3 christos "debug-ben", "gcc:$gcc_devteam_warn -DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DDEBUG_SAFESTACK -O2 -pipe::(unknown):::::",
200 1.1 christos "debug-ben-openbsd","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DPEDANTIC -DDEBUG_SAFESTACK -DOPENSSL_OPENBSD_DEV_CRYPTO -DOPENSSL_NO_ASM -O2 -pedantic -Wall -Wshadow -Werror -pipe::(unknown)::::",
201 1.1 christos "debug-ben-openbsd-debug","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DPEDANTIC -DDEBUG_SAFESTACK -DOPENSSL_OPENBSD_DEV_CRYPTO -DOPENSSL_NO_ASM -g3 -O2 -pedantic -Wall -Wshadow -Werror -pipe::(unknown)::::",
202 1.2 spz "debug-ben-debug", "gcc44:$gcc_devteam_warn -DBN_DEBUG -DCONF_DEBUG -DDEBUG_SAFESTACK -DDEBUG_UNUSED -g3 -O2 -pipe::(unknown)::::::",
203 1.4 christos "debug-ben-debug-64", "gcc:$gcc_devteam_warn -Wno-error=overlength-strings -DBN_DEBUG -DCONF_DEBUG -DDEBUG_SAFESTACK -DDEBUG_UNUSED -g3 -O3 -pipe::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
204 1.3 christos "debug-ben-macos", "cc:$gcc_devteam_warn -arch i386 -DBN_DEBUG -DCONF_DEBUG -DDEBUG_SAFESTACK -DDEBUG_UNUSED -DOPENSSL_THREADS -D_REENTRANT -DDSO_DLFCN -DHAVE_DLFCN_H -O3 -DL_ENDIAN -g3 -pipe::(unknown)::-Wl,-search_paths_first::::",
205 1.3 christos "debug-ben-macos-gcc46", "gcc-mp-4.6:$gcc_devteam_warn -Wconversion -DBN_DEBUG -DCONF_DEBUG -DDEBUG_SAFESTACK -DDEBUG_UNUSED -DOPENSSL_THREADS -D_REENTRANT -DDSO_DLFCN -DHAVE_DLFCN_H -O3 -DL_ENDIAN -g3 -pipe::(unknown)::::::",
206 1.16 spz "debug-ben-darwin64","cc:$gcc_devteam_warn -g -Wno-language-extension-token -Wno-extended-offsetof -arch x86_64 -O3 -DL_ENDIAN -Wall::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL:".eval{my $asm=$x86_64_asm;$asm=~s/rc4\-[^:]+//;$asm}.":macosx:dlfcn:darwin-shared:-fPIC -fno-common:-arch x86_64 -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
207 1.16 spz "debug-ben-debug-64-clang", "clang:$gcc_devteam_warn -Wno-error=overlength-strings -Wno-error=extended-offsetof -Qunused-arguments -DBN_DEBUG -DCONF_DEBUG -DDEBUG_SAFESTACK -DDEBUG_UNUSED -g3 -O3 -pipe::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
208 1.1 christos "debug-ben-no-opt", "gcc: -Wall -Wmissing-prototypes -Wstrict-prototypes -Wmissing-declarations -DDEBUG_SAFESTACK -DCRYPTO_MDEBUG -Werror -DL_ENDIAN -DTERMIOS -Wall -g3::(unknown)::::::",
209 1.1 christos "debug-ben-strict", "gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DCONST_STRICT -O2 -Wall -Wshadow -Werror -Wpointer-arith -Wcast-qual -Wwrite-strings -pipe::(unknown)::::::",
210 1.1 christos "debug-rse","cc:-DTERMIOS -DL_ENDIAN -pipe -O -g -ggdb3 -Wall::(unknown):::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}",
211 1.6 christos "debug-bodo", "gcc:$gcc_devteam_warn -Wno-error=overlength-strings -DBN_DEBUG -DBN_DEBUG_RAND -DCONF_DEBUG -DBIO_PAIR_DEBUG -m64 -DL_ENDIAN -DTERMIO -g -DMD32_REG_T=int::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
212 1.4 christos "debug-steve64", "gcc:$gcc_devteam_warn -m64 -DL_ENDIAN -DTERMIO -DCONF_DEBUG -DDEBUG_SAFESTACK -Wno-overlength-strings -g::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
213 1.16 spz "debug-steve32", "gcc:$gcc_devteam_warn -m32 -DL_ENDIAN -DCONF_DEBUG -DDEBUG_SAFESTACK -Wno-overlength-strings -g -pipe::-D_REENTRANT::-rdynamic -ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC:-m32:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
214 1.3 christos "debug-steve-opt", "gcc:$gcc_devteam_warn -m64 -O3 -DL_ENDIAN -DTERMIO -DCONF_DEBUG -DDEBUG_SAFESTACK -g::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
215 1.4 christos "debug-levitte-linux-elf","gcc:-DLEVITTE_DEBUG -DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DCRYPTO_MDEBUG -DL_ENDIAN -ggdb -g3 -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
216 1.4 christos "debug-levitte-linux-noasm","gcc:-DLEVITTE_DEBUG -DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DCRYPTO_MDEBUG -DOPENSSL_NO_ASM -DL_ENDIAN -ggdb -g3 -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
217 1.11 spz "debug-levitte-linux-elf-extreme","gcc:-DLEVITTE_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_DEBUG -DBN_DEBUG_RAND -DCRYPTO_MDEBUG -DENGINE_CONF_DEBUG -DL_ENDIAN -DPEDANTIC -ggdb -g3 -pedantic -ansi -Wall -W -Wundef -Wshadow -Wcast-align -Wstrict-prototypes -Wmissing-prototypes -Wno-long-long -Wundef -Wconversion -pipe::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
218 1.11 spz "debug-levitte-linux-noasm-extreme","gcc:-DLEVITTE_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_DEBUG -DBN_DEBUG_RAND -DCRYPTO_MDEBUG -DENGINE_CONF_DEBUG -DOPENSSL_NO_ASM -DL_ENDIAN -DPEDANTIC -ggdb -g3 -pedantic -ansi -Wall -W -Wundef -Wshadow -Wcast-align -Wstrict-prototypes -Wmissing-prototypes -Wno-long-long -Wundef -Wconversion -pipe::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
219 1.3 christos "debug-geoff32","gcc:-DBN_DEBUG -DBN_DEBUG_RAND -DBN_STRICT -DPURIFY -DOPENSSL_NO_DEPRECATED -DOPENSSL_NO_ASM -DOPENSSL_NO_INLINE_ASM -DL_ENDIAN -DTERMIO -DPEDANTIC -O1 -ggdb2 -Wall -Werror -Wundef -pedantic -Wshadow -Wpointer-arith -Wbad-function-cast -Wcast-align -Wsign-compare -Wmissing-prototypes -Wmissing-declarations -Wno-long-long::-D_REENTRANT::-ldl:BN_LLONG:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
220 1.3 christos "debug-geoff64","gcc:-DBN_DEBUG -DBN_DEBUG_RAND -DBN_STRICT -DPURIFY -DOPENSSL_NO_DEPRECATED -DOPENSSL_NO_ASM -DOPENSSL_NO_INLINE_ASM -DL_ENDIAN -DTERMIO -DPEDANTIC -O1 -ggdb2 -Wall -Werror -Wundef -pedantic -Wshadow -Wpointer-arith -Wbad-function-cast -Wcast-align -Wsign-compare -Wmissing-prototypes -Wmissing-declarations -Wno-long-long::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
221 1.11 spz "debug-linux-pentium","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DL_ENDIAN -g -mcpu=pentium -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn",
222 1.11 spz "debug-linux-ppro","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DL_ENDIAN -g -mcpu=pentiumpro -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn",
223 1.11 spz "debug-linux-elf","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DL_ENDIAN -g -march=i486 -Wall::-D_REENTRANT::-lefence -ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
224 1.11 spz "debug-linux-elf-noefence","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DL_ENDIAN -g -march=i486 -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
225 1.16 spz "debug-linux-ia32-aes", "gcc:-DAES_EXPERIMENTAL -DL_ENDIAN -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:x86cpuid.o:bn-586.o co-586.o x86-mont.o::des-586.o crypt586.o:aes_x86core.o aes_cbc.o aesni-x86.o:bf-586.o:md5-586.o:sha1-586.o sha256-586.o sha512-586.o:cast-586.o:rc4-586.o:rmd-586.o:rc5-586.o:wp_block.o wp-mmx.o::ghash-x86.o::elf:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
226 1.11 spz "debug-linux-generic32","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DCRYPTO_MDEBUG -g -Wall::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
227 1.16 spz "debug-linux-generic64","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DCRYPTO_MDEBUG -DTERMIO -g -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
228 1.11 spz "debug-linux-x86_64","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DCRYPTO_MDEBUG -m64 -DL_ENDIAN -g -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
229 1.1 christos "dist", "cc:-O::(unknown)::::::",
230 1.1 christos
231 1.1 christos # Basic configs that should work on any (32 and less bit) box
232 1.1 christos "gcc", "gcc:-O3::(unknown):::BN_LLONG:::",
233 1.1 christos "cc", "cc:-O::(unknown)::::::",
234 1.1 christos
235 1.1 christos ####VOS Configurations
236 1.3 christos "vos-gcc","gcc:-O3 -Wall -DOPENSSL_SYSNAME_VOS -D_POSIX_C_SOURCE=200112L -D_BSD -D_VOS_EXTENDED_NAMES -DB_ENDIAN::(unknown):VOS:-Wl,-map:BN_LLONG:${no_asm}:::::.so:",
237 1.3 christos "debug-vos-gcc","gcc:-O0 -g -Wall -DOPENSSL_SYSNAME_VOS -D_POSIX_C_SOURCE=200112L -D_BSD -D_VOS_EXTENDED_NAMES -DB_ENDIAN -DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DCRYPTO_MDEBUG::(unknown):VOS:-Wl,-map:BN_LLONG:${no_asm}:::::.so:",
238 1.1 christos
239 1.1 christos #### Solaris x86 with GNU C setups
240 1.1 christos # -DOPENSSL_NO_INLINE_ASM switches off inline assembler. We have to do it
241 1.1 christos # here because whenever GNU C instantiates an assembler template it
242 1.1 christos # surrounds it with #APP #NO_APP comment pair which (at least Solaris
243 1.1 christos # 7_x86) /usr/ccs/bin/as fails to assemble with "Illegal mnemonic"
244 1.1 christos # error message.
245 1.1 christos "solaris-x86-gcc","gcc:-O3 -fomit-frame-pointer -march=pentium -Wall -DL_ENDIAN -DOPENSSL_NO_INLINE_ASM::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:solaris-shared:-fPIC:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
246 1.1 christos # -shared -static-libgcc might appear controversial, but modules taken
247 1.1 christos # from static libgcc do not have relocations and linking them into our
248 1.1 christos # shared objects doesn't have any negative side-effects. On the contrary,
249 1.1 christos # doing so makes it possible to use gcc shared build with Sun C. Given
250 1.1 christos # that gcc generates faster code [thanks to inline assembler], I would
251 1.1 christos # actually recommend to consider using gcc shared build even with vendor
252 1.1 christos # compiler:-)
253 1.1 christos # <appro (a] fy.chalmers.se>
254 1.3 christos "solaris64-x86_64-gcc","gcc:-m64 -O3 -Wall -DL_ENDIAN::-D_REENTRANT::-lsocket -lnsl -ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:solaris-shared:-fPIC:-m64 -shared -static-libgcc:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/64",
255 1.1 christos
256 1.1 christos #### Solaris x86 with Sun C setups
257 1.16 spz "solaris-x86-cc","cc:-fast -xarch=generic -O -Xa::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_UNROLL BF_PTR:${no_asm}:dlfcn:solaris-shared:-KPIC:-G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
258 1.2 spz "solaris64-x86_64-cc","cc:-fast -xarch=amd64 -xstrconst -Xa -DL_ENDIAN::-D_REENTRANT::-lsocket -lnsl -ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:solaris-shared:-KPIC:-xarch=amd64 -G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/64",
259 1.1 christos
260 1.1 christos #### SPARC Solaris with GNU C setups
261 1.1 christos "solaris-sparcv7-gcc","gcc:-O3 -fomit-frame-pointer -Wall -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${no_asm}:dlfcn:solaris-shared:-fPIC:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
262 1.12 christos "solaris-sparcv8-gcc","gcc:-mcpu=v8 -O3 -fomit-frame-pointer -Wall -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${sparcv8_asm}:dlfcn:solaris-shared:-fPIC:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
263 1.1 christos # -m32 should be safe to add as long as driver recognizes -mcpu=ultrasparc
264 1.1 christos "solaris-sparcv9-gcc","gcc:-m32 -mcpu=ultrasparc -O3 -fomit-frame-pointer -Wall -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT:ULTRASPARC:-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${sparcv9_asm}:dlfcn:solaris-shared:-fPIC:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
265 1.1 christos "solaris64-sparcv9-gcc","gcc:-m64 -mcpu=ultrasparc -O3 -Wall -DB_ENDIAN::-D_REENTRANT:ULTRASPARC:-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_PTR DES_RISC1 DES_UNROLL BF_PTR:${sparcv9_asm}:dlfcn:solaris-shared:-fPIC:-m64 -shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/64",
266 1.1 christos ####
267 1.12 christos "debug-solaris-sparcv8-gcc","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG_ALL -O -g -mcpu=v8 -Wall -DB_ENDIAN::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${sparcv8_asm}:dlfcn:solaris-shared:-fPIC:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
268 1.1 christos "debug-solaris-sparcv9-gcc","gcc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG_ALL -DPEDANTIC -O -g -mcpu=ultrasparc -pedantic -ansi -Wall -Wshadow -Wno-long-long -D__EXTENSIONS__ -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT:ULTRASPARC:-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${sparcv9_asm}:dlfcn:solaris-shared:-fPIC:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
269 1.1 christos
270 1.1 christos #### SPARC Solaris with Sun C setups
271 1.1 christos # SC4.0 doesn't pass 'make test', upgrade to SC5.0 or SC4.2.
272 1.1 christos # SC4.2 is ok, better than gcc even on bn as long as you tell it -xarch=v8
273 1.1 christos # SC5.0 note: Compiler common patch 107357-01 or later is required!
274 1.1 christos "solaris-sparcv7-cc","cc:-xO5 -xstrconst -xdepend -Xa -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_RISC1 DES_UNROLL BF_PTR:${no_asm}:dlfcn:solaris-shared:-KPIC:-G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
275 1.1 christos "solaris-sparcv8-cc","cc:-xarch=v8 -xO5 -xstrconst -xdepend -Xa -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_RISC1 DES_UNROLL BF_PTR:${sparcv8_asm}:dlfcn:solaris-shared:-KPIC:-G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
276 1.1 christos "solaris-sparcv9-cc","cc:-xtarget=ultra -xarch=v8plus -xO5 -xstrconst -xdepend -Xa -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT:ULTRASPARC:-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK_LL DES_PTR DES_RISC1 DES_UNROLL BF_PTR:${sparcv9_asm}:dlfcn:solaris-shared:-KPIC:-G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
277 1.4 christos "solaris64-sparcv9-cc","cc:-xtarget=ultra -xarch=v9 -xO5 -xstrconst -xdepend -Xa -DB_ENDIAN::-D_REENTRANT:ULTRASPARC:-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_PTR DES_RISC1 DES_UNROLL BF_PTR:${sparcv9_asm}:dlfcn:solaris-shared:-KPIC:-xarch=v9 -G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/64",
278 1.1 christos ####
279 1.1 christos "debug-solaris-sparcv8-cc","cc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG_ALL -xarch=v8 -g -O -xstrconst -Xa -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_RISC1 DES_UNROLL BF_PTR:${sparcv8_asm}:dlfcn:solaris-shared:-KPIC:-G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
280 1.1 christos "debug-solaris-sparcv9-cc","cc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG_ALL -xtarget=ultra -xarch=v8plus -g -O -xstrconst -Xa -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT:ULTRASPARC:-lsocket -lnsl -ldl:BN_LLONG RC4_CHAR RC4_CHUNK_LL DES_PTR DES_RISC1 DES_UNROLL BF_PTR:${sparcv9_asm}:dlfcn:solaris-shared:-KPIC:-G -dy -z text:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
281 1.1 christos
282 1.1 christos #### SunOS configs, assuming sparc for the gcc one.
283 1.1 christos #"sunos-cc", "cc:-O4 -DNOPROTO -DNOCONST::(unknown):SUNOS::DES_UNROLL:${no_asm}::",
284 1.12 christos "sunos-gcc","gcc:-O3 -mcpu=v8 -Dssize_t=int::(unknown):SUNOS::BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL DES_PTR DES_RISC1:${no_asm}::",
285 1.1 christos
286 1.1 christos #### IRIX 5.x configs
287 1.1 christos # -mips2 flag is added by ./config when appropriate.
288 1.11 spz "irix-gcc","gcc:-O3 -DB_ENDIAN::(unknown):::BN_LLONG MD2_CHAR RC4_INDEX RC4_CHAR RC4_CHUNK DES_UNROLL DES_RISC2 DES_PTR BF_PTR:${mips32_asm}:o32:dlfcn:irix-shared:::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
289 1.11 spz "irix-cc", "cc:-O2 -use_readonly_const -DB_ENDIAN::(unknown):::BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_RISC2 DES_UNROLL BF_PTR:${mips32_asm}:o32:dlfcn:irix-shared:::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
290 1.1 christos #### IRIX 6.x configs
291 1.1 christos # Only N32 and N64 ABIs are supported. If you need O32 ABI build, invoke
292 1.1 christos # './Configure irix-cc -o32' manually.
293 1.11 spz "irix-mips3-gcc","gcc:-mabi=n32 -O3 -DB_ENDIAN -DBN_DIV3W::-D_SGI_MP_SOURCE:::MD2_CHAR RC4_INDEX RC4_CHAR RC4_CHUNK_LL DES_UNROLL DES_RISC2 DES_PTR BF_PTR SIXTY_FOUR_BIT:${mips64_asm}:n32:dlfcn:irix-shared::-mabi=n32:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::32",
294 1.11 spz "irix-mips3-cc", "cc:-n32 -mips3 -O2 -use_readonly_const -G0 -rdata_shared -DB_ENDIAN -DBN_DIV3W::-D_SGI_MP_SOURCE:::DES_PTR RC4_CHAR RC4_CHUNK_LL DES_RISC2 DES_UNROLL BF_PTR SIXTY_FOUR_BIT:${mips64_asm}:n32:dlfcn:irix-shared::-n32:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::32",
295 1.1 christos # N64 ABI builds.
296 1.11 spz "irix64-mips4-gcc","gcc:-mabi=64 -mips4 -O3 -DB_ENDIAN -DBN_DIV3W::-D_SGI_MP_SOURCE:::RC4_CHAR RC4_CHUNK DES_RISC2 DES_UNROLL SIXTY_FOUR_BIT_LONG:${mips64_asm}:64:dlfcn:irix-shared::-mabi=64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
297 1.11 spz "irix64-mips4-cc", "cc:-64 -mips4 -O2 -use_readonly_const -G0 -rdata_shared -DB_ENDIAN -DBN_DIV3W::-D_SGI_MP_SOURCE:::RC4_CHAR RC4_CHUNK DES_RISC2 DES_UNROLL SIXTY_FOUR_BIT_LONG:${mips64_asm}:64:dlfcn:irix-shared::-64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
298 1.1 christos
299 1.1 christos #### Unified HP-UX ANSI C configs.
300 1.1 christos # Special notes:
301 1.1 christos # - Originally we were optimizing at +O4 level. It should be noted
302 1.1 christos # that the only difference between +O3 and +O4 is global inter-
303 1.1 christos # procedural analysis. As it has to be performed during the link
304 1.1 christos # stage the compiler leaves behind certain pseudo-code in lib*.a
305 1.1 christos # which might be release or even patch level specific. Generating
306 1.1 christos # the machine code for and analyzing the *whole* program appears
307 1.1 christos # to be *extremely* memory demanding while the performance gain is
308 1.1 christos # actually questionable. The situation is intensified by the default
309 1.1 christos # HP-UX data set size limit (infamous 'maxdsiz' tunable) of 64MB
310 1.1 christos # which is way too low for +O4. In other words, doesn't +O3 make
311 1.1 christos # more sense?
312 1.1 christos # - Keep in mind that the HP compiler by default generates code
313 1.1 christos # suitable for execution on the host you're currently compiling at.
314 1.1 christos # If the toolkit is ment to be used on various PA-RISC processors
315 1.1 christos # consider './config +DAportable'.
316 1.1 christos # - +DD64 is chosen in favour of +DA2.0W because it's meant to be
317 1.1 christos # compatible with *future* releases.
318 1.1 christos # - If you run ./Configure hpux-parisc-[g]cc manually don't forget to
319 1.1 christos # pass -D_REENTRANT on HP-UX 10 and later.
320 1.1 christos # - -DMD32_XARRAY triggers workaround for compiler bug we ran into in
321 1.1 christos # 32-bit message digests. (For the moment of this writing) HP C
322 1.1 christos # doesn't seem to "digest" too many local variables (they make "him"
323 1.1 christos # chew forever:-). For more details look-up MD32_XARRAY comment in
324 1.1 christos # crypto/sha/sha_lcl.h.
325 1.1 christos # <appro (a] fy.chalmers.se>
326 1.1 christos #
327 1.1 christos # Since there is mention of this in shlib/hpux10-cc.sh
328 1.1 christos "hpux-parisc-cc-o4","cc:-Ae +O4 +ESlit -z -DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY::-D_REENTRANT::-ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1:${no_asm}:dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
329 1.1 christos "hpux-parisc-gcc","gcc:-O3 -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-Wl,+s -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1:${no_asm}:dl:hpux-shared:-fPIC:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
330 1.3 christos "hpux-parisc1_1-gcc","gcc:-O3 -DB_ENDIAN -DBN_DIV2W::-D_REENTRANT::-Wl,+s -ldld:BN_LLONG DES_PTR DES_UNROLL DES_RISC1:${parisc11_asm}:dl:hpux-shared:-fPIC:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/pa1.1",
331 1.3 christos "hpux-parisc2-gcc","gcc:-march=2.0 -O3 -DB_ENDIAN -D_REENTRANT::::-Wl,+s -ldld:SIXTY_FOUR_BIT RC4_CHAR RC4_CHUNK DES_PTR DES_UNROLL DES_RISC1:".eval{my $asm=$parisc20_asm;$asm=~s/2W\./2\./;$asm=~s/:64/:32/;$asm}.":dl:hpux-shared:-fPIC:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/pa20_32",
332 1.16 spz "hpux64-parisc2-gcc","gcc:-O3 -DB_ENDIAN -D_REENTRANT::::-ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT::pa-risc2W.o:::::::::::::::void:dlfcn:hpux-shared:-fpic:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/pa20_64",
333 1.1 christos
334 1.1 christos # More attempts at unified 10.X and 11.X targets for HP C compiler.
335 1.1 christos #
336 1.1 christos # Chris Ruemmler <ruemmler (a] cup.hp.com>
337 1.1 christos # Kevin Steves <ks (a] hp.se>
338 1.1 christos "hpux-parisc-cc","cc:+O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY::-D_REENTRANT::-Wl,+s -ldld:MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:${no_asm}:dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
339 1.3 christos "hpux-parisc1_1-cc","cc:+DA1.1 +O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DMD32_XARRAY::-D_REENTRANT::-Wl,+s -ldld:MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:${parisc11_asm}:dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/pa1.1",
340 1.3 christos "hpux-parisc2-cc","cc:+DA2.0 +DS2.0 +O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DMD32_XARRAY -D_REENTRANT::::-Wl,+s -ldld:SIXTY_FOUR_BIT MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:".eval{my $asm=$parisc20_asm;$asm=~s/2W\./2\./;$asm=~s/:64/:32/;$asm}.":dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/pa20_32",
341 1.3 christos "hpux64-parisc2-cc","cc:+DD64 +O3 +Optrs_strongly_typed -Ae +ESlit -DB_ENDIAN -DMD32_XARRAY -D_REENTRANT::::-ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX RC4_CHAR DES_UNROLL DES_RISC1 DES_INT:${parisc20_asm}:dlfcn:hpux-shared:+Z:+DD64 -b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/pa20_64",
342 1.1 christos
343 1.1 christos # HP/UX IA-64 targets
344 1.1 christos "hpux-ia64-cc","cc:-Ae +DD32 +O2 +Olit=all -z -DB_ENDIAN -D_REENTRANT::::-ldl:SIXTY_FOUR_BIT MD2_CHAR RC4_INDEX DES_UNROLL DES_RISC1 DES_INT:${ia64_asm}:dlfcn:hpux-shared:+Z:+DD32 -b:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/hpux32",
345 1.1 christos # Frank Geurts <frank.geurts (a] nl.abnamro.com> has patiently assisted with
346 1.1 christos # with debugging of the following config.
347 1.1 christos "hpux64-ia64-cc","cc:-Ae +DD64 +O3 +Olit=all -z -DB_ENDIAN -D_REENTRANT::::-ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX DES_UNROLL DES_RISC1 DES_INT:${ia64_asm}:dlfcn:hpux-shared:+Z:+DD64 -b:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/hpux64",
348 1.1 christos # GCC builds...
349 1.1 christos "hpux-ia64-gcc","gcc:-O3 -DB_ENDIAN -D_REENTRANT::::-ldl:SIXTY_FOUR_BIT MD2_CHAR RC4_INDEX DES_UNROLL DES_RISC1 DES_INT:${ia64_asm}:dlfcn:hpux-shared:-fpic:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/hpux32",
350 1.1 christos "hpux64-ia64-gcc","gcc:-mlp64 -O3 -DB_ENDIAN -D_REENTRANT::::-ldl:SIXTY_FOUR_BIT_LONG MD2_CHAR RC4_INDEX DES_UNROLL DES_RISC1 DES_INT:${ia64_asm}:dlfcn:hpux-shared:-fpic:-mlp64 -shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/hpux64",
351 1.1 christos
352 1.1 christos # Legacy HPUX 9.X configs...
353 1.1 christos "hpux-cc", "cc:-DB_ENDIAN -DBN_DIV2W -DMD32_XARRAY -Ae +ESlit +O2 -z::(unknown)::-Wl,+s -ldld:DES_PTR DES_UNROLL DES_RISC1:${no_asm}:dl:hpux-shared:+Z:-b:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
354 1.1 christos "hpux-gcc", "gcc:-DB_ENDIAN -DBN_DIV2W -O3::(unknown)::-Wl,+s -ldld:DES_PTR DES_UNROLL DES_RISC1:${no_asm}:dl:hpux-shared:-fPIC:-shared:.sl.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
355 1.1 christos
356 1.1 christos #### HP MPE/iX http://jazz.external.hp.com/src/openssl/
357 1.1 christos "MPE/iX-gcc", "gcc:-D_ENDIAN -DBN_DIV2W -O3 -D_POSIX_SOURCE -D_SOCKET_SOURCE -I/SYSLOG/PUB::(unknown):MPE:-L/SYSLOG/PUB -lsyslog -lsocket -lcurses:BN_LLONG DES_PTR DES_UNROLL DES_RISC1:::",
358 1.1 christos
359 1.1 christos # DEC Alpha OSF/1/Tru64 targets.
360 1.1 christos #
361 1.1 christos # "What's in a name? That which we call a rose
362 1.1 christos # By any other word would smell as sweet."
363 1.1 christos #
364 1.1 christos # - William Shakespeare, "Romeo & Juliet", Act II, scene II.
365 1.1 christos #
366 1.1 christos # For gcc, the following gave a %50 speedup on a 164 over the 'DES_INT' version
367 1.1 christos #
368 1.1 christos "osf1-alpha-gcc", "gcc:-O3::(unknown):::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_UNROLL DES_RISC1:${alpha_asm}:dlfcn:alpha-osf1-shared:::.so",
369 1.1 christos "osf1-alpha-cc", "cc:-std1 -tune host -O4 -readonly_strings::(unknown):::SIXTY_FOUR_BIT_LONG RC4_CHUNK:${alpha_asm}:dlfcn:alpha-osf1-shared:::.so",
370 1.1 christos "tru64-alpha-cc", "cc:-std1 -tune host -fast -readonly_strings::-pthread:::SIXTY_FOUR_BIT_LONG RC4_CHUNK:${alpha_asm}:dlfcn:alpha-osf1-shared::-msym:.so",
371 1.1 christos
372 1.1 christos ####
373 1.1 christos #### Variety of LINUX:-)
374 1.1 christos ####
375 1.1 christos # *-generic* is endian-neutral target, but ./config is free to
376 1.1 christos # throw in -D[BL]_ENDIAN, whichever appropriate...
377 1.11 spz "linux-generic32","gcc:-O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
378 1.11 spz "linux-ppc", "gcc:-DB_ENDIAN -O3 -Wall::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_RISC1 DES_UNROLL:${ppc32_asm}:linux32:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
379 1.16 spz
380 1.16 spz #######################################################################
381 1.16 spz # Note that -march is not among compiler options in below linux-armv4
382 1.16 spz # target line. Not specifying one is intentional to give you choice to:
383 1.16 spz #
384 1.16 spz # a) rely on your compiler default by not specifying one;
385 1.16 spz # b) specify your target platform explicitly for optimal performance,
386 1.16 spz # e.g. -march=armv6 or -march=armv7-a;
387 1.16 spz # c) build "universal" binary that targets *range* of platforms by
388 1.16 spz # specifying minimum and maximum supported architecture;
389 1.16 spz #
390 1.16 spz # As for c) option. It actually makes no sense to specify maximum to be
391 1.16 spz # less than ARMv7, because it's the least requirement for run-time
392 1.16 spz # switch between platform-specific code paths. And without run-time
393 1.16 spz # switch performance would be equivalent to one for minimum. Secondly,
394 1.16 spz # there are some natural limitations that you'd have to accept and
395 1.16 spz # respect. Most notably you can *not* build "universal" binary for
396 1.16 spz # big-endian platform. This is because ARMv7 processor always picks
397 1.16 spz # instructions in little-endian order. Another similar limitation is
398 1.16 spz # that -mthumb can't "cross" -march=armv6t2 boundary, because that's
399 1.16 spz # where it became Thumb-2. Well, this limitation is a bit artificial,
400 1.16 spz # because it's not really impossible, but it's deemed too tricky to
401 1.16 spz # support. And of course you have to be sure that your binutils are
402 1.16 spz # actually up to the task of handling maximum target platform. With all
403 1.16 spz # this in mind here is an example of how to configure "universal" build:
404 1.16 spz #
405 1.16 spz # ./Configure linux-armv4 -march=armv6 -D__ARM_MAX_ARCH__=8
406 1.16 spz #
407 1.16 spz "linux-armv4", "gcc: -O3 -Wall::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${armv4_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
408 1.16 spz "linux-aarch64","gcc: -O3 -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${aarch64_asm}:linux64:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
409 1.16 spz # Configure script adds minimally required -march for assembly support,
410 1.16 spz # if no -march was specified at command line. mips32 and mips64 below
411 1.16 spz # refer to contemporary MIPS Architecture specifications, MIPS32 and
412 1.16 spz # MIPS64, rather than to kernel bitness.
413 1.16 spz "linux-mips32", "gcc:-mabi=32 -O3 -Wall -DBN_DIV3W::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${mips32_asm}:o32:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
414 1.16 spz "linux-mips64", "gcc:-mabi=n32 -O3 -Wall -DBN_DIV3W::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${mips64_asm}:n32:dlfcn:linux-shared:-fPIC:-mabi=n32:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::32",
415 1.16 spz "linux64-mips64", "gcc:-mabi=64 -O3 -Wall -DBN_DIV3W::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${mips64_asm}:64:dlfcn:linux-shared:-fPIC:-mabi=64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
416 1.1 christos #### IA-32 targets...
417 1.16 spz "linux-ia32-icc", "icc:-DL_ENDIAN -O2::-D_REENTRANT::-ldl -no_cpprt:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-KPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
418 1.11 spz "linux-elf", "gcc:-DL_ENDIAN -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
419 1.11 spz "linux-aout", "gcc:-DL_ENDIAN -O3 -fomit-frame-pointer -march=i486 -Wall::(unknown):::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_asm}:a.out",
420 1.1 christos ####
421 1.11 spz "linux-generic64","gcc:-O3 -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
422 1.11 spz "linux-ppc64", "gcc:-m64 -DB_ENDIAN -O3 -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_RISC1 DES_UNROLL:${ppc64_asm}:linux64:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
423 1.16 spz "linux-ppc64le","gcc:-m64 -DL_ENDIAN -O3 -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_RISC1 DES_UNROLL:$ppc64_asm:linux64le:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::",
424 1.16 spz "linux-ia64", "gcc:-DL_ENDIAN -DTERMIO -O3 -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_UNROLL DES_INT:${ia64_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
425 1.16 spz "linux-ia64-icc","icc:-DL_ENDIAN -O2 -Wall::-D_REENTRANT::-ldl -no_cpprt:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_RISC1 DES_INT:${ia64_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
426 1.11 spz "linux-x86_64", "gcc:-m64 -DL_ENDIAN -O3 -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
427 1.16 spz "linux-x86_64-clang", "clang: -m64 -DL_ENDIAN -O3 -Wall -Wextra $clang_disabled_warnings -Qunused-arguments::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
428 1.16 spz "debug-linux-x86_64-clang", "clang: -DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DCRYPTO_MDEBUG -m64 -DL_ENDIAN -g -Wall -Wextra $clang_disabled_warnings -Qunused-arguments::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
429 1.16 spz "linux-x86_64-icc", "icc:-DL_ENDIAN -O2::-D_REENTRANT::-ldl -no_cpprt:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
430 1.16 spz "linux-x32", "gcc:-mx32 -DL_ENDIAN -O3 -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT RC4_CHUNK_LL DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:linux-shared:-fPIC:-mx32:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::x32",
431 1.11 spz "linux64-s390x", "gcc:-m64 -DB_ENDIAN -O3 -Wall::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL:${s390x_asm}:64:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
432 1.3 christos #### So called "highgprs" target for z/Architecture CPUs
433 1.3 christos # "Highgprs" is kernel feature first implemented in Linux 2.6.32, see
434 1.3 christos # /proc/cpuinfo. The idea is to preserve most significant bits of
435 1.3 christos # general purpose registers not only upon 32-bit process context
436 1.3 christos # switch, but even on asynchronous signal delivery to such process.
437 1.3 christos # This makes it possible to deploy 64-bit instructions even in legacy
438 1.3 christos # application context and achieve better [or should we say adequate]
439 1.3 christos # performance. The build is binary compatible with linux-generic32,
440 1.3 christos # and the idea is to be able to install the resulting libcrypto.so
441 1.3 christos # alongside generic one, e.g. as /lib/highgprs/libcrypto.so.x.y, for
442 1.3 christos # ldconfig and run-time linker to autodiscover. Unfortunately it
443 1.3 christos # doesn't work just yet, because of couple of bugs in glibc
444 1.3 christos # sysdeps/s390/dl-procinfo.c affecting ldconfig and ld.so.1...
445 1.11 spz "linux32-s390x", "gcc:-m31 -Wa,-mzarch -DB_ENDIAN -O3 -Wall::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL:".eval{my $asm=$s390x_asm;$asm=~s/bn\-s390x\.o/bn_asm.o/;$asm}.":31:dlfcn:linux-shared:-fPIC:-m31:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::/highgprs",
446 1.1 christos #### SPARC Linux setups
447 1.1 christos # Ray Miller <ray.miller (a] computing-services.oxford.ac.uk> has patiently
448 1.1 christos # assisted with debugging of following two configs.
449 1.12 christos "linux-sparcv8","gcc:-mcpu=v8 -DB_ENDIAN -O3 -fomit-frame-pointer -Wall -DBN_DIV2W::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${sparcv8_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
450 1.1 christos # it's a real mess with -mcpu=ultrasparc option under Linux, but
451 1.1 christos # -Wa,-Av8plus should do the trick no matter what.
452 1.11 spz "linux-sparcv9","gcc:-m32 -mcpu=ultrasparc -DB_ENDIAN -O3 -fomit-frame-pointer -Wall -Wa,-Av8plus -DBN_DIV2W::-D_REENTRANT:ULTRASPARC:-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${sparcv9_asm}:dlfcn:linux-shared:-fPIC:-m32:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
453 1.1 christos # GCC 3.1 is a requirement
454 1.11 spz "linux64-sparcv9","gcc:-m64 -mcpu=ultrasparc -DB_ENDIAN -O3 -fomit-frame-pointer -Wall::-D_REENTRANT:ULTRASPARC:-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_PTR DES_RISC1 DES_UNROLL BF_PTR:${sparcv9_asm}:dlfcn:linux-shared:-fPIC:-m64:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):::64",
455 1.1 christos #### Alpha Linux with GNU C and Compaq C setups
456 1.1 christos # Special notes:
457 1.1 christos # - linux-alpha+bwx-gcc is ment to be used from ./config only. If you
458 1.1 christos # ought to run './Configure linux-alpha+bwx-gcc' manually, do
459 1.1 christos # complement the command line with -mcpu=ev56, -mcpu=ev6 or whatever
460 1.1 christos # which is appropriate.
461 1.1 christos # - If you use ccc keep in mind that -fast implies -arch host and the
462 1.1 christos # compiler is free to issue instructions which gonna make elder CPU
463 1.1 christos # choke. If you wish to build "blended" toolkit, add -arch generic
464 1.1 christos # *after* -fast and invoke './Configure linux-alpha-ccc' manually.
465 1.1 christos #
466 1.1 christos # <appro (a] fy.chalmers.se>
467 1.1 christos #
468 1.11 spz "linux-alpha-gcc","gcc:-O3 -DL_ENDIAN::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_RISC1 DES_UNROLL:${alpha_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
469 1.11 spz "linux-alpha+bwx-gcc","gcc:-O3 -DL_ENDIAN::-D_REENTRANT::-ldl:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_RISC1 DES_UNROLL:${alpha_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
470 1.11 spz "linux-alpha-ccc","ccc:-fast -readonly_strings -DL_ENDIAN::-D_REENTRANT:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_PTR DES_RISC1 DES_UNROLL:${alpha_asm}",
471 1.11 spz "linux-alpha+bwx-ccc","ccc:-fast -readonly_strings -DL_ENDIAN::-D_REENTRANT:::SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_INT DES_PTR DES_RISC1 DES_UNROLL:${alpha_asm}",
472 1.1 christos
473 1.11 spz # Android: linux-* but without pointers to headers and libs.
474 1.3 christos "android","gcc:-mandroid -I\$(ANDROID_DEV)/include -B\$(ANDROID_DEV)/lib -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${no_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
475 1.3 christos "android-x86","gcc:-mandroid -I\$(ANDROID_DEV)/include -B\$(ANDROID_DEV)/lib -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:".eval{my $asm=${x86_elf_asm};$asm=~s/:elf/:android/;$asm}.":dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
476 1.3 christos "android-armv7","gcc:-march=armv7-a -mandroid -I\$(ANDROID_DEV)/include -B\$(ANDROID_DEV)/lib -O3 -fomit-frame-pointer -Wall::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${armv4_asm}:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
477 1.16 spz "android-mips","gcc:-mandroid -I\$(ANDROID_DEV)/include -B\$(ANDROID_DEV)/lib -O3 -Wall::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${mips32_asm}:o32:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
478 1.3 christos
479 1.1 christos #### *BSD [do see comment about ${BSDthreads} above!]
480 1.11 spz "BSD-generic32","gcc:-O3 -fomit-frame-pointer -Wall::${BSDthreads}:::BN_LLONG RC2_CHAR RC4_INDEX DES_INT DES_UNROLL:${no_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
481 1.11 spz "BSD-x86", "gcc:-DL_ENDIAN -O3 -fomit-frame-pointer -Wall::${BSDthreads}:::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_asm}:a.out:dlfcn:bsd-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
482 1.11 spz "BSD-x86-elf", "gcc:-DL_ENDIAN -O3 -fomit-frame-pointer -Wall::${BSDthreads}:::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:bsd-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
483 1.11 spz "debug-BSD-x86-elf", "gcc:-DL_ENDIAN -O3 -Wall -g::${BSDthreads}:::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:bsd-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
484 1.12 christos "BSD-sparcv8", "gcc:-DB_ENDIAN -O3 -mcpu=v8 -Wall::${BSDthreads}:::BN_LLONG RC2_CHAR RC4_INDEX DES_INT DES_UNROLL:${sparcv8_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
485 1.1 christos
486 1.11 spz "BSD-generic64","gcc:-O3 -Wall::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${no_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
487 1.1 christos # -DMD32_REG_T=int doesn't actually belong in sparc64 target, it
488 1.1 christos # simply *happens* to work around a compiler bug in gcc 3.3.3,
489 1.1 christos # triggered by RIPEMD160 code.
490 1.11 spz "BSD-sparc64", "gcc:-DB_ENDIAN -O3 -DMD32_REG_T=int -Wall::${BSDthreads}:::BN_LLONG RC2_CHAR RC4_CHUNK DES_INT DES_PTR DES_RISC2 BF_PTR:${sparcv9_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
491 1.11 spz "BSD-ia64", "gcc:-DL_ENDIAN -O3 -Wall::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_UNROLL DES_INT:${ia64_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
492 1.16 spz "BSD-x86_64", "cc:-DL_ENDIAN -O3 -Wall::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
493 1.1 christos
494 1.1 christos "bsdi-elf-gcc", "gcc:-DPERL5 -DL_ENDIAN -fomit-frame-pointer -O3 -march=i486 -Wall::(unknown)::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
495 1.1 christos
496 1.1 christos "nextstep", "cc:-O -Wall:<libc.h>:(unknown):::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:::",
497 1.1 christos "nextstep3.3", "cc:-O3 -Wall:<libc.h>:(unknown):::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:::",
498 1.1 christos
499 1.1 christos # NCR MP-RAS UNIX ver 02.03.01
500 1.1 christos "ncr-scde","cc:-O6 -Xa -Hoff=BEHAVED -686 -Hwide -Hiw::(unknown)::-lsocket -lnsl -lc89:${x86_gcc_des} ${x86_gcc_opts}:::",
501 1.1 christos
502 1.1 christos # QNX
503 1.1 christos "qnx4", "cc:-DL_ENDIAN -DTERMIO::(unknown):::${x86_gcc_des} ${x86_gcc_opts}:",
504 1.11 spz "QNX6", "gcc:::::-lsocket::${no_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
505 1.11 spz "QNX6-i386", "gcc:-DL_ENDIAN -O2 -Wall::::-lsocket:${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
506 1.1 christos
507 1.1 christos # BeOS
508 1.1 christos "beos-x86-r5", "gcc:-DL_ENDIAN -DTERMIOS -O3 -fomit-frame-pointer -mcpu=pentium -Wall::-D_REENTRANT:BEOS:-lbe -lnet:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:beos:beos-shared:-fPIC -DPIC:-shared:.so",
509 1.1 christos "beos-x86-bone", "gcc:-DL_ENDIAN -DTERMIOS -O3 -fomit-frame-pointer -mcpu=pentium -Wall::-D_REENTRANT:BEOS:-lbe -lbind -lsocket:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:beos:beos-shared:-fPIC:-shared:.so",
510 1.1 christos
511 1.1 christos #### SCO/Caldera targets.
512 1.1 christos #
513 1.1 christos # Originally we had like unixware-*, unixware-*-pentium, unixware-*-p6, etc.
514 1.1 christos # Now we only have blended unixware-* as it's the only one used by ./config.
515 1.1 christos # If you want to optimize for particular microarchitecture, bypass ./config
516 1.1 christos # and './Configure unixware-7 -Kpentium_pro' or whatever appropriate.
517 1.1 christos # Note that not all targets include assembler support. Mostly because of
518 1.1 christos # lack of motivation to support out-of-date platforms with out-of-date
519 1.1 christos # compiler drivers and assemblers. Tim Rice <tim (a] multitalents.net> has
520 1.1 christos # patiently assisted to debug most of it.
521 1.1 christos #
522 1.1 christos # UnixWare 2.0x fails destest with -O.
523 1.1 christos "unixware-2.0","cc:-DFILIO_H -DNO_STRINGS_H::-Kthread::-lsocket -lnsl -lresolv -lx:${x86_gcc_des} ${x86_gcc_opts}:::",
524 1.1 christos "unixware-2.1","cc:-O -DFILIO_H::-Kthread::-lsocket -lnsl -lresolv -lx:${x86_gcc_des} ${x86_gcc_opts}:::",
525 1.16 spz "unixware-7","cc:-O -DFILIO_H -Kalloca::-Kthread::-lsocket -lnsl:BN_LLONG MD2_CHAR RC4_INDEX ${x86_gcc_des}:${x86_elf_asm}-1:dlfcn:svr5-shared:-Kpic::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
526 1.16 spz "unixware-7-gcc","gcc:-DL_ENDIAN -DFILIO_H -O3 -fomit-frame-pointer -march=pentium -Wall::-D_REENTRANT::-lsocket -lnsl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}-1:dlfcn:gnu-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
527 1.1 christos # SCO 5 - Ben Laurie <ben (a] algroup.co.uk> says the -O breaks the SCO cc.
528 1.16 spz "sco5-cc", "cc:-belf::(unknown)::-lsocket -lnsl:${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}-1:dlfcn:svr3-shared:-Kpic::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
529 1.16 spz "sco5-gcc", "gcc:-O3 -fomit-frame-pointer::(unknown)::-lsocket -lnsl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}-1:dlfcn:svr3-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
530 1.1 christos
531 1.1 christos #### IBM's AIX.
532 1.1 christos "aix3-cc", "cc:-O -DB_ENDIAN -qmaxmem=16384::(unknown):AIX::BN_LLONG RC4_CHAR:::",
533 1.1 christos "aix-gcc", "gcc:-O -DB_ENDIAN::-pthread:AIX::BN_LLONG RC4_CHAR:${ppc32_asm}:aix32:dlfcn:aix-shared::-shared -Wl,-G:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)::-X32",
534 1.1 christos "aix64-gcc","gcc:-maix64 -O -DB_ENDIAN::-pthread:AIX::SIXTY_FOUR_BIT_LONG RC4_CHAR:${ppc64_asm}:aix64:dlfcn:aix-shared::-maix64 -shared -Wl,-G:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)::-X64",
535 1.1 christos # Below targets assume AIX 5. Idea is to effectively disregard $OBJECT_MODE
536 1.1 christos # at build time. $OBJECT_MODE is respected at ./config stage!
537 1.4 christos "aix-cc", "cc:-q32 -O -DB_ENDIAN -qmaxmem=16384 -qro -qroconst::-qthreaded -D_THREAD_SAFE:AIX::BN_LLONG RC4_CHAR:${ppc32_asm}:aix32:dlfcn:aix-shared::-q32 -G:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)::-X 32",
538 1.4 christos "aix64-cc", "cc:-q64 -O -DB_ENDIAN -qmaxmem=16384 -qro -qroconst::-qthreaded -D_THREAD_SAFE:AIX::SIXTY_FOUR_BIT_LONG RC4_CHAR:${ppc64_asm}:aix64:dlfcn:aix-shared::-q64 -G:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)::-X 64",
539 1.1 christos
540 1.1 christos #
541 1.1 christos # Cray T90 and similar (SDSC)
542 1.1 christos # It's Big-endian, but the algorithms work properly when B_ENDIAN is NOT
543 1.1 christos # defined. The T90 ints and longs are 8 bytes long, and apparently the
544 1.1 christos # B_ENDIAN code assumes 4 byte ints. Fortunately, the non-B_ENDIAN and
545 1.1 christos # non L_ENDIAN code aligns the bytes in each word correctly.
546 1.1 christos #
547 1.1 christos # The BIT_FIELD_LIMITS define is to avoid two fatal compiler errors:
548 1.1 christos #'Taking the address of a bit field is not allowed. '
549 1.1 christos #'An expression with bit field exists as the operand of "sizeof" '
550 1.1 christos # (written by Wayne Schroeder <schroede (a] SDSC.EDU>)
551 1.1 christos #
552 1.1 christos # j90 is considered the base machine type for unicos machines,
553 1.1 christos # so this configuration is now called "cray-j90" ...
554 1.1 christos "cray-j90", "cc: -DBIT_FIELD_LIMITS -DTERMIOS::(unknown):CRAY::SIXTY_FOUR_BIT_LONG DES_INT:::",
555 1.1 christos
556 1.1 christos #
557 1.1 christos # Cray T3E (Research Center Juelich, beckman (a] acl.lanl.gov)
558 1.1 christos #
559 1.1 christos # The BIT_FIELD_LIMITS define was written for the C90 (it seems). I added
560 1.1 christos # another use. Basically, the problem is that the T3E uses some bit fields
561 1.1 christos # for some st_addr stuff, and then sizeof and address-of fails
562 1.1 christos # I could not use the ams/alpha.o option because the Cray assembler, 'cam'
563 1.1 christos # did not like it.
564 1.1 christos "cray-t3e", "cc: -DBIT_FIELD_LIMITS -DTERMIOS::(unknown):CRAY::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT:::",
565 1.1 christos
566 1.1 christos # DGUX, 88100.
567 1.1 christos "dgux-R3-gcc", "gcc:-O3 -fomit-frame-pointer::(unknown):::RC4_INDEX DES_UNROLL:::",
568 1.1 christos "dgux-R4-gcc", "gcc:-O3 -fomit-frame-pointer::(unknown)::-lnsl -lsocket:RC4_INDEX DES_UNROLL:::",
569 1.1 christos "dgux-R4-x86-gcc", "gcc:-O3 -fomit-frame-pointer -DL_ENDIAN::(unknown)::-lnsl -lsocket:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}",
570 1.1 christos
571 1.1 christos # Sinix/ReliantUNIX RM400
572 1.1 christos # NOTE: The CDS++ Compiler up to V2.0Bsomething has the IRIX_CC_BUG optimizer problem. Better use -g */
573 1.1 christos "ReliantUNIX","cc:-KPIC -g -DTERMIOS -DB_ENDIAN::-Kthread:SNI:-lsocket -lnsl -lc -L/usr/ucblib -lucb:BN_LLONG DES_PTR DES_RISC2 DES_UNROLL BF_PTR:${no_asm}:dlfcn:reliantunix-shared:::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)",
574 1.1 christos "SINIX","cc:-O::(unknown):SNI:-lsocket -lnsl -lc -L/usr/ucblib -lucb:RC4_INDEX RC4_CHAR:::",
575 1.1 christos "SINIX-N","/usr/ucb/cc:-O2 -misaligned::(unknown)::-lucb:RC4_INDEX RC4_CHAR:::",
576 1.1 christos
577 1.1 christos # SIEMENS BS2000/OSD: an EBCDIC-based mainframe
578 1.11 spz "BS2000-OSD","c89:-O -XLLML -XLLMK -XL -DB_ENDIAN -DCHARSET_EBCDIC::(unknown)::-lsocket -lnsl:THIRTY_TWO_BIT DES_PTR DES_UNROLL MD2_CHAR RC4_INDEX RC4_CHAR BF_PTR:::",
579 1.1 christos
580 1.1 christos # OS/390 Unix an EBCDIC-based Unix system on IBM mainframe
581 1.1 christos # You need to compile using the c89.sh wrapper in the tools directory, because the
582 1.1 christos # IBM compiler does not like the -L switch after any object modules.
583 1.1 christos #
584 1.1 christos "OS390-Unix","c89.sh:-O -DB_ENDIAN -DCHARSET_EBCDIC -DNO_SYS_PARAM_H -D_ALL_SOURCE::(unknown):::THIRTY_TWO_BIT DES_PTR DES_UNROLL MD2_CHAR RC4_INDEX RC4_CHAR BF_PTR:::",
585 1.1 christos
586 1.1 christos # Visual C targets
587 1.1 christos #
588 1.1 christos # Win64 targets, WIN64I denotes IA-64 and WIN64A - AMD64
589 1.16 spz "VC-WIN64I","cl:-W3 -Gs0 -Gy -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -DUNICODE -D_UNICODE -D_CRT_SECURE_NO_DEPRECATE:::WIN64I::SIXTY_FOUR_BIT RC4_CHUNK_LL DES_INT EXPORT_VAR_AS_FN:ia64cpuid.o:ia64.o ia64-mont.o:::aes_core.o aes_cbc.o aes-ia64.o::md5-ia64.o:sha1-ia64.o sha256-ia64.o sha512-ia64.o:::::::ghash-ia64.o::ias:win32",
590 1.3 christos "VC-WIN64A","cl:-W3 -Gs0 -Gy -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -DUNICODE -D_UNICODE -D_CRT_SECURE_NO_DEPRECATE:::WIN64A::SIXTY_FOUR_BIT RC4_CHUNK_LL DES_INT EXPORT_VAR_AS_FN:".eval{my $asm=$x86_64_asm;$asm=~s/x86_64-gcc\.o/bn_asm.o/;$asm}.":auto:win32",
591 1.16 spz "debug-VC-WIN64I","cl:-W3 -Gs0 -Gy -Zi -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -DUNICODE -D_UNICODE -D_CRT_SECURE_NO_DEPRECATE:::WIN64I::SIXTY_FOUR_BIT RC4_CHUNK_LL DES_INT EXPORT_VAR_AS_FN:ia64cpuid.o:ia64.o:::aes_core.o aes_cbc.o aes-ia64.o::md5-ia64.o:sha1-ia64.o sha256-ia64.o sha512-ia64.o:::::::ghash-ia64.o::ias:win32",
592 1.3 christos "debug-VC-WIN64A","cl:-W3 -Gs0 -Gy -Zi -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -DUNICODE -D_UNICODE -D_CRT_SECURE_NO_DEPRECATE:::WIN64A::SIXTY_FOUR_BIT RC4_CHUNK_LL DES_INT EXPORT_VAR_AS_FN:".eval{my $asm=$x86_64_asm;$asm=~s/x86_64-gcc\.o/bn_asm.o/;$asm}.":auto:win32",
593 1.1 christos # x86 Win32 target defaults to ANSI API, if you want UNICODE, complement
594 1.1 christos # 'perl Configure VC-WIN32' with '-DUNICODE -D_UNICODE'
595 1.3 christos "VC-WIN32","cl:-W3 -Gs0 -GF -Gy -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -D_CRT_SECURE_NO_DEPRECATE:::WIN32::BN_LLONG RC4_INDEX EXPORT_VAR_AS_FN ${x86_gcc_opts}:${x86_asm}:win32n:win32",
596 1.1 christos # Unified CE target
597 1.7 christos "debug-VC-WIN32","cl:-W3 -Gs0 -GF -Gy -Zi -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -D_CRT_SECURE_NO_DEPRECATE:::WIN32::BN_LLONG RC4_INDEX EXPORT_VAR_AS_FN ${x86_gcc_opts}:${x86_asm}:win32n:win32",
598 1.1 christos "VC-CE","cl::::WINCE::BN_LLONG RC4_INDEX EXPORT_VAR_AS_FN ${x86_gcc_opts}:${no_asm}:win32",
599 1.1 christos
600 1.1 christos # Borland C++ 4.5
601 1.1 christos "BC-32","bcc32::::WIN32::BN_LLONG DES_PTR RC4_INDEX EXPORT_VAR_AS_FN:${no_asm}:win32",
602 1.1 christos
603 1.1 christos # MinGW
604 1.2 spz "mingw", "gcc:-mno-cygwin -DL_ENDIAN -DWIN32_LEAN_AND_MEAN -fomit-frame-pointer -O3 -march=i486 -Wall::-D_MT:MINGW32:-lws2_32 -lgdi32 -lcrypt32:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts} EXPORT_VAR_AS_FN:${x86_asm}:coff:win32:cygwin-shared:-D_WINDLL -DOPENSSL_USE_APPLINK:-mno-cygwin:.dll.a",
605 1.1 christos # As for OPENSSL_USE_APPLINK. Applink makes it possible to use .dll
606 1.1 christos # compiled with one compiler with application compiled with another
607 1.1 christos # compiler. It's possible to engage Applink support in mingw64 build,
608 1.1 christos # but it's not done, because till mingw64 supports structured exception
609 1.1 christos # handling, one can't seriously consider its binaries for using with
610 1.1 christos # non-mingw64 run-time environment. And as mingw64 is always consistent
611 1.1 christos # with itself, Applink is never engaged and can as well be omitted.
612 1.2 spz "mingw64", "gcc:-mno-cygwin -DL_ENDIAN -O3 -Wall -DWIN32_LEAN_AND_MEAN -DUNICODE -D_UNICODE::-D_MT:MINGW64:-lws2_32 -lgdi32 -lcrypt32:SIXTY_FOUR_BIT RC4_CHUNK_LL DES_INT EXPORT_VAR_AS_FN:${x86_64_asm}:mingw64:win32:cygwin-shared:-D_WINDLL:-mno-cygwin:.dll.a",
613 1.1 christos
614 1.1 christos # UWIN
615 1.1 christos "UWIN", "cc:-DTERMIOS -DL_ENDIAN -O -Wall:::UWIN::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${no_asm}:win32",
616 1.1 christos
617 1.1 christos # Cygwin
618 1.16 spz "Cygwin", "gcc:-DTERMIOS -DL_ENDIAN -fomit-frame-pointer -O3 -march=i486 -Wall:::CYGWIN::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_asm}:coff:dlfcn:cygwin-shared:-D_WINDLL:-shared:.dll.a",
619 1.16 spz "Cygwin-x86_64", "gcc:-DTERMIOS -DL_ENDIAN -O3 -Wall:::CYGWIN::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:mingw64:dlfcn:cygwin-shared:-D_WINDLL:-shared:.dll.a",
620 1.1 christos
621 1.1 christos # NetWare from David Ward (dsward (a] novell.com)
622 1.1 christos # requires either MetroWerks NLM development tools, or gcc / nlmconv
623 1.1 christos # NetWare defaults socket bio to WinSock sockets. However,
624 1.1 christos # the builds can be configured to use BSD sockets instead.
625 1.1 christos # netware-clib => legacy CLib c-runtime support
626 1.1 christos "netware-clib", "mwccnlm::::::${x86_gcc_opts}::",
627 1.1 christos "netware-clib-bsdsock", "mwccnlm::::::${x86_gcc_opts}::",
628 1.1 christos "netware-clib-gcc", "i586-netware-gcc:-nostdinc -I/ndk/nwsdk/include/nlm -I/ndk/ws295sdk/include -DL_ENDIAN -DNETWARE_CLIB -DOPENSSL_SYSNAME_NETWARE -O2 -Wall:::::${x86_gcc_opts}::",
629 1.1 christos "netware-clib-bsdsock-gcc", "i586-netware-gcc:-nostdinc -I/ndk/nwsdk/include/nlm -DNETWARE_BSDSOCK -DNETDB_USE_INTERNET -DL_ENDIAN -DNETWARE_CLIB -DOPENSSL_SYSNAME_NETWARE -O2 -Wall:::::${x86_gcc_opts}::",
630 1.1 christos # netware-libc => LibC/NKS support
631 1.1 christos "netware-libc", "mwccnlm::::::BN_LLONG ${x86_gcc_opts}::",
632 1.1 christos "netware-libc-bsdsock", "mwccnlm::::::BN_LLONG ${x86_gcc_opts}::",
633 1.1 christos "netware-libc-gcc", "i586-netware-gcc:-nostdinc -I/ndk/libc/include -I/ndk/libc/include/winsock -DL_ENDIAN -DNETWARE_LIBC -DOPENSSL_SYSNAME_NETWARE -DTERMIO -O2 -Wall:::::BN_LLONG ${x86_gcc_opts}::",
634 1.1 christos "netware-libc-bsdsock-gcc", "i586-netware-gcc:-nostdinc -I/ndk/libc/include -DNETWARE_BSDSOCK -DL_ENDIAN -DNETWARE_LIBC -DOPENSSL_SYSNAME_NETWARE -DTERMIO -O2 -Wall:::::BN_LLONG ${x86_gcc_opts}::",
635 1.1 christos
636 1.1 christos # DJGPP
637 1.11 spz "DJGPP", "gcc:-I/dev/env/WATT_ROOT/inc -DTERMIO -DL_ENDIAN -fomit-frame-pointer -O2 -Wall:::MSDOS:-L/dev/env/WATT_ROOT/lib -lwatt:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_asm}:a.out:",
638 1.1 christos
639 1.1 christos # Ultrix from Bernhard Simon <simon (a] zid.tuwien.ac.at>
640 1.1 christos "ultrix-cc","cc:-std1 -O -Olimit 2500 -DL_ENDIAN::(unknown):::::::",
641 1.1 christos "ultrix-gcc","gcc:-O3 -DL_ENDIAN::(unknown):::BN_LLONG::::",
642 1.1 christos # K&R C is no longer supported; you need gcc on old Ultrix installations
643 1.1 christos ##"ultrix","cc:-O2 -DNOPROTO -DNOCONST -DL_ENDIAN::(unknown):::::::",
644 1.1 christos
645 1.1 christos ##### MacOS X (a.k.a. Rhapsody or Darwin) setup
646 1.1 christos "rhapsody-ppc-cc","cc:-O3 -DB_ENDIAN::(unknown):MACOSX_RHAPSODY::BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${no_asm}::",
647 1.2 spz "darwin-ppc-cc","cc:-arch ppc -O3 -DB_ENDIAN -Wa,-force_cpusubtype_ALL::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${ppc32_asm}:osx32:dlfcn:darwin-shared:-fPIC -fno-common:-arch ppc -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
648 1.1 christos "darwin64-ppc-cc","cc:-arch ppc64 -O3 -DB_ENDIAN::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:SIXTY_FOUR_BIT_LONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${ppc64_asm}:osx64:dlfcn:darwin-shared:-fPIC -fno-common:-arch ppc64 -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
649 1.3 christos "darwin-i386-cc","cc:-arch i386 -O3 -fomit-frame-pointer -DL_ENDIAN::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:BN_LLONG RC4_INT RC4_CHUNK DES_UNROLL BF_PTR:".eval{my $asm=$x86_asm;$asm=~s/cast\-586\.o//;$asm}.":macosx:dlfcn:darwin-shared:-fPIC -fno-common:-arch i386 -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
650 1.1 christos "debug-darwin-i386-cc","cc:-arch i386 -g3 -DL_ENDIAN::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:BN_LLONG RC4_INT RC4_CHUNK DES_UNROLL BF_PTR:${x86_asm}:macosx:dlfcn:darwin-shared:-fPIC -fno-common:-arch i386 -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
651 1.16 spz "darwin64-x86_64-cc","cc:-arch x86_64 -O3 -DL_ENDIAN -Wall::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:".eval{my $asm=$x86_64_asm;$asm=~s/rc4\-[^:]+//;$asm}.":macosx:dlfcn:darwin-shared:-fPIC -fno-common:-arch x86_64 -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
652 1.16 spz "debug-darwin64-x86_64-cc","cc:-arch x86_64 -ggdb -g2 -O0 -DL_ENDIAN -Wall::-D_REENTRANT:MACOSX:-Wl,-search_paths_first%:SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:".eval{my $asm=$x86_64_asm;$asm=~s/rc4\-[^:]+//;$asm}.":macosx:dlfcn:darwin-shared:-fPIC -fno-common:-arch x86_64 -dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
653 1.1 christos "debug-darwin-ppc-cc","cc:-DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DCRYPTO_MDEBUG -DB_ENDIAN -g -Wall -O::-D_REENTRANT:MACOSX::BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${ppc32_asm}:osx32:dlfcn:darwin-shared:-fPIC:-dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
654 1.3 christos # iPhoneOS/iOS
655 1.3 christos "iphoneos-cross","llvm-gcc:-O3 -isysroot \$(CROSS_TOP)/SDKs/\$(CROSS_SDK) -fomit-frame-pointer -fno-common::-D_REENTRANT:iOS:-Wl,-search_paths_first%:BN_LLONG RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:${no_asm}:dlfcn:darwin-shared:-fPIC -fno-common:-dynamiclib:.\$(SHLIB_MAJOR).\$(SHLIB_MINOR).dylib",
656 1.1 christos
657 1.1 christos ##### A/UX
658 1.1 christos "aux3-gcc","gcc:-O2 -DTERMIO::(unknown):AUX:-lbsd:RC4_CHAR RC4_CHUNK DES_UNROLL BF_PTR:::",
659 1.1 christos
660 1.1 christos ##### Sony NEWS-OS 4.x
661 1.1 christos "newsos4-gcc","gcc:-O -DB_ENDIAN::(unknown):NEWS4:-lmld -liberty:BN_LLONG RC4_CHAR RC4_CHUNK DES_PTR DES_RISC1 DES_UNROLL BF_PTR::::",
662 1.1 christos
663 1.1 christos ##### GNU Hurd
664 1.11 spz "hurd-x86", "gcc:-DL_ENDIAN -O3 -fomit-frame-pointer -march=i486 -Wall::-D_REENTRANT::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:linux-shared:-fPIC",
665 1.1 christos
666 1.1 christos ##### OS/2 EMX
667 1.1 christos "OS2-EMX", "gcc::::::::",
668 1.1 christos
669 1.1 christos ##### VxWorks for various targets
670 1.3 christos "vxworks-ppc60x","ccppc:-D_REENTRANT -mrtp -mhard-float -mstrict-align -fno-implicit-fp -DPPC32_fp60x -O2 -fstrength-reduce -fno-builtin -fno-strict-aliasing -Wall -DCPU=PPC32 -DTOOL_FAMILY=gnu -DTOOL=gnu -I\$(WIND_BASE)/target/usr/h -I\$(WIND_BASE)/target/usr/h/wrn/coreip:::VXWORKS:-Wl,--defsym,__wrs_rtp_base=0xe0000000 -L \$(WIND_BASE)/target/usr/lib/ppc/PPC32/common:::::",
671 1.3 christos "vxworks-ppcgen","ccppc:-D_REENTRANT -mrtp -msoft-float -mstrict-align -O1 -fno-builtin -fno-strict-aliasing -Wall -DCPU=PPC32 -DTOOL_FAMILY=gnu -DTOOL=gnu -I\$(WIND_BASE)/target/usr/h -I\$(WIND_BASE)/target/usr/h/wrn/coreip:::VXWORKS:-Wl,--defsym,__wrs_rtp_base=0xe0000000 -L \$(WIND_BASE)/target/usr/lib/ppc/PPC32/sfcommon:::::",
672 1.1 christos "vxworks-ppc405","ccppc:-g -msoft-float -mlongcall -DCPU=PPC405 -I\$(WIND_BASE)/target/h:::VXWORKS:-r:::::",
673 1.1 christos "vxworks-ppc750","ccppc:-ansi -nostdinc -DPPC750 -D_REENTRANT -fvolatile -fno-builtin -fno-for-scope -fsigned-char -Wall -msoft-float -mlongcall -DCPU=PPC604 -I\$(WIND_BASE)/target/h \$(DEBUG_FLAG):::VXWORKS:-r:::::",
674 1.1 christos "vxworks-ppc750-debug","ccppc:-ansi -nostdinc -DPPC750 -D_REENTRANT -fvolatile -fno-builtin -fno-for-scope -fsigned-char -Wall -msoft-float -mlongcall -DCPU=PPC604 -I\$(WIND_BASE)/target/h -DBN_DEBUG -DREF_CHECK -DCONF_DEBUG -DBN_CTX_DEBUG -DCRYPTO_MDEBUG -DPEDANTIC -DDEBUG_SAFESTACK -DDEBUG -g:::VXWORKS:-r:::::",
675 1.1 christos "vxworks-ppc860","ccppc:-nostdinc -msoft-float -DCPU=PPC860 -DNO_STRINGS_H -I\$(WIND_BASE)/target/h:::VXWORKS:-r:::::",
676 1.3 christos "vxworks-simlinux","ccpentium:-B\$(WIND_BASE)/host/\$(WIND_HOST_TYPE)/lib/gcc-lib/ -D_VSB_CONFIG_FILE=\"\$(WIND_BASE)/target/lib/h/config/vsbConfig.h\" -DL_ENDIAN -DCPU=SIMLINUX -DTOOL_FAMILY=gnu -DTOOL=gnu -fno-builtin -fno-defer-pop -DNO_STRINGS_H -I\$(WIND_BASE)/target/h -I\$(WIND_BASE)/target/h/wrn/coreip -DOPENSSL_NO_HW_PADLOCK:::VXWORKS:-r::${no_asm}::::::ranlibpentium:",
677 1.3 christos "vxworks-mips","ccmips:-mrtp -mips2 -O -G 0 -B\$(WIND_BASE)/host/\$(WIND_HOST_TYPE)/lib/gcc-lib/ -D_VSB_CONFIG_FILE=\"\$(WIND_BASE)/target/lib/h/config/vsbConfig.h\" -DCPU=MIPS32 -msoft-float -mno-branch-likely -DTOOL_FAMILY=gnu -DTOOL=gnu -fno-builtin -fno-defer-pop -DNO_STRINGS_H -I\$(WIND_BASE)/target/usr/h -I\$(WIND_BASE)/target/h/wrn/coreip::-D_REENTRANT:VXWORKS:-Wl,--defsym,__wrs_rtp_base=0xe0000000 -L \$(WIND_BASE)/target/usr/lib/mips/MIPSI32/sfcommon::${mips32_asm}:o32::::::ranlibmips:",
678 1.1 christos
679 1.1 christos ##### Compaq Non-Stop Kernel (Tandem)
680 1.1 christos "tandem-c89","c89:-Ww -D__TANDEM -D_XOPEN_SOURCE -D_XOPEN_SOURCE_EXTENDED=1 -D_TANDEM_SOURCE -DB_ENDIAN::(unknown):::THIRTY_TWO_BIT:::",
681 1.1 christos
682 1.1 christos # uClinux
683 1.3 christos "uClinux-dist","$ENV{'CC'}:\$(CFLAGS)::-D_REENTRANT::\$(LDFLAGS) \$(LDLIBS):BN_LLONG:${no_asm}:$ENV{'LIBSSL_dlfcn'}:linux-shared:-fPIC:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):$ENV{'RANLIB'}::",
684 1.3 christos "uClinux-dist64","$ENV{'CC'}:\$(CFLAGS)::-D_REENTRANT::\$(LDFLAGS) \$(LDLIBS):SIXTY_FOUR_BIT_LONG:${no_asm}:$ENV{'LIBSSL_dlfcn'}:linux-shared:-fPIC:-shared:.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR):$ENV{'RANLIB'}::",
685 1.1 christos
686 1.1 christos );
687 1.1 christos
688 1.1 christos my @MK1MF_Builds=qw(VC-WIN64I VC-WIN64A
689 1.2 spz debug-VC-WIN64I debug-VC-WIN64A
690 1.1 christos VC-NT VC-CE VC-WIN32 debug-VC-WIN32
691 1.1 christos BC-32
692 1.1 christos netware-clib netware-clib-bsdsock
693 1.1 christos netware-libc netware-libc-bsdsock);
694 1.1 christos
695 1.1 christos my $idx = 0;
696 1.1 christos my $idx_cc = $idx++;
697 1.1 christos my $idx_cflags = $idx++;
698 1.1 christos my $idx_unistd = $idx++;
699 1.1 christos my $idx_thread_cflag = $idx++;
700 1.1 christos my $idx_sys_id = $idx++;
701 1.1 christos my $idx_lflags = $idx++;
702 1.1 christos my $idx_bn_ops = $idx++;
703 1.1 christos my $idx_cpuid_obj = $idx++;
704 1.1 christos my $idx_bn_obj = $idx++;
705 1.16 spz my $idx_ec_obj = $idx++;
706 1.1 christos my $idx_des_obj = $idx++;
707 1.1 christos my $idx_aes_obj = $idx++;
708 1.1 christos my $idx_bf_obj = $idx++;
709 1.1 christos my $idx_md5_obj = $idx++;
710 1.1 christos my $idx_sha1_obj = $idx++;
711 1.1 christos my $idx_cast_obj = $idx++;
712 1.1 christos my $idx_rc4_obj = $idx++;
713 1.1 christos my $idx_rmd160_obj = $idx++;
714 1.1 christos my $idx_rc5_obj = $idx++;
715 1.1 christos my $idx_wp_obj = $idx++;
716 1.1 christos my $idx_cmll_obj = $idx++;
717 1.3 christos my $idx_modes_obj = $idx++;
718 1.3 christos my $idx_engines_obj = $idx++;
719 1.1 christos my $idx_perlasm_scheme = $idx++;
720 1.1 christos my $idx_dso_scheme = $idx++;
721 1.1 christos my $idx_shared_target = $idx++;
722 1.1 christos my $idx_shared_cflag = $idx++;
723 1.1 christos my $idx_shared_ldflag = $idx++;
724 1.1 christos my $idx_shared_extension = $idx++;
725 1.1 christos my $idx_ranlib = $idx++;
726 1.1 christos my $idx_arflags = $idx++;
727 1.1 christos my $idx_multilib = $idx++;
728 1.1 christos
729 1.1 christos my $prefix="";
730 1.2 spz my $libdir="";
731 1.1 christos my $openssldir="";
732 1.1 christos my $exe_ext="";
733 1.2 spz my $install_prefix= "$ENV{'INSTALL_PREFIX'}";
734 1.1 christos my $cross_compile_prefix="";
735 1.3 christos my $fipsdir="/usr/local/ssl/fips-2.0";
736 1.2 spz my $fipslibdir="";
737 1.2 spz my $baseaddr="0xFB00000";
738 1.1 christos my $no_threads=0;
739 1.1 christos my $threads=0;
740 1.1 christos my $no_shared=0; # but "no-shared" is default
741 1.1 christos my $zlib=1; # but "no-zlib" is default
742 1.1 christos my $no_krb5=0; # but "no-krb5" is implied unless "--with-krb5-..." is used
743 1.1 christos my $no_rfc3779=1; # but "no-rfc3779" is default
744 1.1 christos my $no_asm=0;
745 1.1 christos my $no_dso=0;
746 1.1 christos my $no_gmp=0;
747 1.1 christos my @skip=();
748 1.1 christos my $Makefile="Makefile";
749 1.1 christos my $des_locl="crypto/des/des_locl.h";
750 1.1 christos my $des ="crypto/des/des.h";
751 1.1 christos my $bn ="crypto/bn/bn.h";
752 1.1 christos my $md2 ="crypto/md2/md2.h";
753 1.1 christos my $rc4 ="crypto/rc4/rc4.h";
754 1.1 christos my $rc4_locl="crypto/rc4/rc4_locl.h";
755 1.1 christos my $idea ="crypto/idea/idea.h";
756 1.1 christos my $rc2 ="crypto/rc2/rc2.h";
757 1.1 christos my $bf ="crypto/bf/bf_locl.h";
758 1.1 christos my $bn_asm ="bn_asm.o";
759 1.1 christos my $des_enc="des_enc.o fcrypt_b.o";
760 1.1 christos my $aes_enc="aes_core.o aes_cbc.o";
761 1.1 christos my $bf_enc ="bf_enc.o";
762 1.1 christos my $cast_enc="c_enc.o";
763 1.1 christos my $rc4_enc="rc4_enc.o rc4_skey.o";
764 1.1 christos my $rc5_enc="rc5_enc.o";
765 1.1 christos my $md5_obj="";
766 1.1 christos my $sha1_obj="";
767 1.1 christos my $rmd160_obj="";
768 1.1 christos my $cmll_enc="camellia.o cmll_misc.o cmll_cbc.o";
769 1.1 christos my $processor="";
770 1.1 christos my $default_ranlib;
771 1.1 christos my $perl;
772 1.2 spz my $fips=0;
773 1.1 christos
774 1.3 christos if (exists $ENV{FIPSDIR})
775 1.3 christos {
776 1.3 christos $fipsdir = $ENV{FIPSDIR};
777 1.3 christos $fipsdir =~ s/\/$//;
778 1.3 christos }
779 1.1 christos
780 1.1 christos # All of the following is disabled by default (RC5 was enabled before 0.9.8):
781 1.1 christos
782 1.1 christos my %disabled = ( # "what" => "comment" [or special keyword "experimental"]
783 1.3 christos "ec_nistp_64_gcc_128" => "default",
784 1.1 christos "gmp" => "default",
785 1.3 christos "jpake" => "experimental",
786 1.16 spz "libunbound" => "experimental",
787 1.3 christos "md2" => "default",
788 1.3 christos "rc5" => "default",
789 1.1 christos "rfc3779" => "default",
790 1.15 christos "sctp" => "default",
791 1.3 christos "shared" => "default",
792 1.16 spz "ssl-trace" => "default",
793 1.15 christos "ssl2" => "default",
794 1.1 christos "store" => "experimental",
795 1.8 spz "unit-test" => "default",
796 1.15 christos "weak-ssl-ciphers" => "default",
797 1.3 christos "zlib" => "default",
798 1.3 christos "zlib-dynamic" => "default"
799 1.3 christos );
800 1.1 christos my @experimental = ();
801 1.1 christos
802 1.1 christos # This is what $depflags will look like with the above defaults
803 1.1 christos # (we need this to see if we should advise the user to run "make depend"):
804 1.16 spz my $default_depflags = " -DOPENSSL_NO_EC_NISTP_64_GCC_128 -DOPENSSL_NO_GMP -DOPENSSL_NO_JPAKE -DOPENSSL_NO_LIBUNBOUND -DOPENSSL_NO_MD2 -DOPENSSL_NO_RC5 -DOPENSSL_NO_RFC3779 -DOPENSSL_NO_SCTP -DOPENSSL_NO_SSL_TRACE -DOPENSSL_NO_SSL2 -DOPENSSL_NO_STORE -DOPENSSL_NO_UNIT_TEST -DOPENSSL_NO_WEAK_SSL_CIPHERS";
805 1.1 christos
806 1.1 christos # Explicit "no-..." options will be collected in %disabled along with the defaults.
807 1.1 christos # To remove something from %disabled, use "enable-foo" (unless it's experimental).
808 1.1 christos # For symmetry, "disable-foo" is a synonym for "no-foo".
809 1.1 christos
810 1.1 christos # For features called "experimental" here, a more explicit "experimental-foo" is needed to enable.
811 1.1 christos # We will collect such requests in @experimental.
812 1.1 christos # To avoid accidental use of experimental features, applications will have to use -DOPENSSL_EXPERIMENTAL_FOO.
813 1.1 christos
814 1.1 christos
815 1.1 christos my $no_sse2=0;
816 1.1 christos
817 1.1 christos &usage if ($#ARGV < 0);
818 1.1 christos
819 1.1 christos my $flags;
820 1.1 christos my $depflags;
821 1.1 christos my $openssl_experimental_defines;
822 1.1 christos my $openssl_algorithm_defines;
823 1.1 christos my $openssl_thread_defines;
824 1.1 christos my $openssl_sys_defines="";
825 1.1 christos my $openssl_other_defines;
826 1.1 christos my $libs;
827 1.1 christos my $libkrb5="";
828 1.1 christos my $target;
829 1.1 christos my $options;
830 1.1 christos my $symlink;
831 1.1 christos my $make_depend=0;
832 1.1 christos my %withargs=();
833 1.1 christos
834 1.1 christos my @argvcopy=@ARGV;
835 1.1 christos my $argvstring="";
836 1.1 christos my $argv_unprocessed=1;
837 1.1 christos
838 1.1 christos while($argv_unprocessed)
839 1.1 christos {
840 1.1 christos $flags="";
841 1.1 christos $depflags="";
842 1.1 christos $openssl_experimental_defines="";
843 1.1 christos $openssl_algorithm_defines="";
844 1.1 christos $openssl_thread_defines="";
845 1.1 christos $openssl_sys_defines="";
846 1.1 christos $openssl_other_defines="";
847 1.1 christos $libs="";
848 1.1 christos $target="";
849 1.1 christos $options="";
850 1.1 christos $symlink=1;
851 1.1 christos
852 1.1 christos $argv_unprocessed=0;
853 1.1 christos $argvstring=join(' ',@argvcopy);
854 1.1 christos
855 1.1 christos PROCESS_ARGS:
856 1.1 christos foreach (@argvcopy)
857 1.1 christos {
858 1.1 christos s /^-no-/no-/; # some people just can't read the instructions
859 1.1 christos
860 1.1 christos # rewrite some options in "enable-..." form
861 1.1 christos s /^-?-?shared$/enable-shared/;
862 1.3 christos s /^sctp$/enable-sctp/;
863 1.1 christos s /^threads$/enable-threads/;
864 1.1 christos s /^zlib$/enable-zlib/;
865 1.1 christos s /^zlib-dynamic$/enable-zlib-dynamic/;
866 1.1 christos
867 1.1 christos if (/^no-(.+)$/ || /^disable-(.+)$/)
868 1.1 christos {
869 1.1 christos if (!($disabled{$1} eq "experimental"))
870 1.1 christos {
871 1.1 christos if ($1 eq "ssl")
872 1.1 christos {
873 1.1 christos $disabled{"ssl2"} = "option(ssl)";
874 1.1 christos $disabled{"ssl3"} = "option(ssl)";
875 1.1 christos }
876 1.1 christos elsif ($1 eq "tls")
877 1.1 christos {
878 1.1 christos $disabled{"tls1"} = "option(tls)"
879 1.1 christos }
880 1.10 spz elsif ($1 eq "ssl3-method")
881 1.10 spz {
882 1.10 spz $disabled{"ssl3-method"} = "option(ssl)";
883 1.10 spz $disabled{"ssl3"} = "option(ssl)";
884 1.10 spz }
885 1.1 christos else
886 1.1 christos {
887 1.1 christos $disabled{$1} = "option";
888 1.1 christos }
889 1.1 christos }
890 1.1 christos }
891 1.1 christos elsif (/^enable-(.+)$/ || /^experimental-(.+)$/)
892 1.1 christos {
893 1.1 christos my $algo = $1;
894 1.1 christos if ($disabled{$algo} eq "experimental")
895 1.1 christos {
896 1.1 christos die "You are requesting an experimental feature; please say 'experimental-$algo' if you are sure\n"
897 1.1 christos unless (/^experimental-/);
898 1.1 christos push @experimental, $algo;
899 1.1 christos }
900 1.1 christos delete $disabled{$algo};
901 1.1 christos
902 1.1 christos $threads = 1 if ($algo eq "threads");
903 1.1 christos }
904 1.1 christos elsif (/^--test-sanity$/)
905 1.1 christos {
906 1.1 christos exit(&test_sanity());
907 1.1 christos }
908 1.2 spz elsif (/^--strict-warnings/)
909 1.2 spz {
910 1.2 spz $strict_warnings = 1;
911 1.2 spz }
912 1.1 christos elsif (/^reconfigure/ || /^reconf/)
913 1.1 christos {
914 1.1 christos if (open(IN,"<$Makefile"))
915 1.1 christos {
916 1.1 christos while (<IN>)
917 1.1 christos {
918 1.1 christos chomp;
919 1.1 christos if (/^CONFIGURE_ARGS=(.*)/)
920 1.1 christos {
921 1.1 christos $argvstring=$1;
922 1.1 christos @argvcopy=split(' ',$argvstring);
923 1.1 christos die "Incorrect data to reconfigure, please do a normal configuration\n"
924 1.1 christos if (grep(/^reconf/,@argvcopy));
925 1.1 christos print "Reconfiguring with: $argvstring\n";
926 1.1 christos $argv_unprocessed=1;
927 1.1 christos close(IN);
928 1.1 christos last PROCESS_ARGS;
929 1.1 christos }
930 1.1 christos }
931 1.1 christos close(IN);
932 1.1 christos }
933 1.1 christos die "Insufficient data to reconfigure, please do a normal configuration\n";
934 1.1 christos }
935 1.1 christos elsif (/^386$/)
936 1.1 christos { $processor=386; }
937 1.2 spz elsif (/^fips$/)
938 1.2 spz {
939 1.2 spz $fips=1;
940 1.3 christos }
941 1.1 christos elsif (/^rsaref$/)
942 1.1 christos {
943 1.1 christos # No RSAref support any more since it's not needed.
944 1.1 christos # The check for the option is there so scripts aren't
945 1.1 christos # broken
946 1.1 christos }
947 1.1 christos elsif (/^[-+]/)
948 1.1 christos {
949 1.16 spz if (/^--prefix=(.*)$/)
950 1.1 christos {
951 1.1 christos $prefix=$1;
952 1.1 christos }
953 1.2 spz elsif (/^--libdir=(.*)$/)
954 1.2 spz {
955 1.2 spz $libdir=$1;
956 1.2 spz }
957 1.1 christos elsif (/^--openssldir=(.*)$/)
958 1.1 christos {
959 1.1 christos $openssldir=$1;
960 1.1 christos }
961 1.1 christos elsif (/^--install.prefix=(.*)$/)
962 1.1 christos {
963 1.1 christos $install_prefix=$1;
964 1.1 christos }
965 1.1 christos elsif (/^--with-krb5-(dir|lib|include|flavor)=(.*)$/)
966 1.1 christos {
967 1.1 christos $withargs{"krb5-".$1}=$2;
968 1.1 christos }
969 1.1 christos elsif (/^--with-zlib-lib=(.*)$/)
970 1.1 christos {
971 1.1 christos $withargs{"zlib-lib"}=$1;
972 1.1 christos }
973 1.1 christos elsif (/^--with-zlib-include=(.*)$/)
974 1.1 christos {
975 1.1 christos $withargs{"zlib-include"}="-I$1";
976 1.1 christos }
977 1.2 spz elsif (/^--with-fipsdir=(.*)$/)
978 1.2 spz {
979 1.3 christos $fipsdir="$1";
980 1.2 spz }
981 1.2 spz elsif (/^--with-fipslibdir=(.*)$/)
982 1.2 spz {
983 1.3 christos $fipslibdir="$1";
984 1.2 spz }
985 1.2 spz elsif (/^--with-baseaddr=(.*)$/)
986 1.2 spz {
987 1.2 spz $baseaddr="$1";
988 1.2 spz }
989 1.1 christos elsif (/^--cross-compile-prefix=(.*)$/)
990 1.1 christos {
991 1.1 christos $cross_compile_prefix=$1;
992 1.1 christos }
993 1.16 spz elsif (/^-[lL](.*)$/ or /^-Wl,/)
994 1.16 spz {
995 1.16 spz $libs.=$_." ";
996 1.16 spz }
997 1.16 spz else # common if (/^[-+]/), just pass down...
998 1.1 christos {
999 1.16 spz $_ =~ s/%([0-9a-f]{1,2})/chr(hex($1))/gei;
1000 1.16 spz $flags.=$_." ";
1001 1.1 christos }
1002 1.1 christos }
1003 1.1 christos elsif ($_ =~ /^([^:]+):(.+)$/)
1004 1.1 christos {
1005 1.1 christos eval "\$table{\$1} = \"$2\""; # allow $xxx constructs in the string
1006 1.1 christos $target=$1;
1007 1.1 christos }
1008 1.1 christos else
1009 1.1 christos {
1010 1.1 christos die "target already defined - $target (offending arg: $_)\n" if ($target ne "");
1011 1.1 christos $target=$_;
1012 1.1 christos }
1013 1.1 christos
1014 1.1 christos unless ($_ eq $target || /^no-/ || /^disable-/)
1015 1.1 christos {
1016 1.1 christos # "no-..." follows later after implied disactivations
1017 1.1 christos # have been derived. (Don't take this too seroiusly,
1018 1.1 christos # we really only write OPTIONS to the Makefile out of
1019 1.1 christos # nostalgia.)
1020 1.1 christos
1021 1.1 christos if ($options eq "")
1022 1.1 christos { $options = $_; }
1023 1.1 christos else
1024 1.1 christos { $options .= " ".$_; }
1025 1.1 christos }
1026 1.1 christos }
1027 1.1 christos }
1028 1.1 christos
1029 1.1 christos
1030 1.1 christos
1031 1.1 christos if ($processor eq "386")
1032 1.1 christos {
1033 1.1 christos $disabled{"sse2"} = "forced";
1034 1.1 christos }
1035 1.1 christos
1036 1.1 christos if (!defined($withargs{"krb5-flavor"}) || $withargs{"krb5-flavor"} eq "")
1037 1.1 christos {
1038 1.1 christos $disabled{"krb5"} = "krb5-flavor not specified";
1039 1.1 christos }
1040 1.1 christos
1041 1.1 christos if (!defined($disabled{"zlib-dynamic"}))
1042 1.1 christos {
1043 1.1 christos # "zlib-dynamic" was specifically enabled, so enable "zlib"
1044 1.1 christos delete $disabled{"zlib"};
1045 1.1 christos }
1046 1.1 christos
1047 1.1 christos if (defined($disabled{"rijndael"}))
1048 1.1 christos {
1049 1.1 christos $disabled{"aes"} = "forced";
1050 1.1 christos }
1051 1.1 christos if (defined($disabled{"des"}))
1052 1.1 christos {
1053 1.1 christos $disabled{"mdc2"} = "forced";
1054 1.1 christos }
1055 1.1 christos if (defined($disabled{"ec"}))
1056 1.1 christos {
1057 1.1 christos $disabled{"ecdsa"} = "forced";
1058 1.1 christos $disabled{"ecdh"} = "forced";
1059 1.1 christos }
1060 1.1 christos
1061 1.1 christos # SSL 2.0 requires MD5 and RSA
1062 1.1 christos if (defined($disabled{"md5"}) || defined($disabled{"rsa"}))
1063 1.1 christos {
1064 1.1 christos $disabled{"ssl2"} = "forced";
1065 1.1 christos }
1066 1.1 christos
1067 1.2 spz if ($fips && $fipslibdir eq "")
1068 1.2 spz {
1069 1.3 christos $fipslibdir = $fipsdir . "/lib/";
1070 1.3 christos }
1071 1.3 christos
1072 1.3 christos # RSAX ENGINE sets default non-FIPS RSA method.
1073 1.3 christos if ($fips)
1074 1.3 christos {
1075 1.3 christos $disabled{"rsax"} = "forced";
1076 1.2 spz }
1077 1.2 spz
1078 1.1 christos # SSL 3.0 and TLS requires MD5 and SHA and either RSA or DSA+DH
1079 1.1 christos if (defined($disabled{"md5"}) || defined($disabled{"sha"})
1080 1.1 christos || (defined($disabled{"rsa"})
1081 1.1 christos && (defined($disabled{"dsa"}) || defined($disabled{"dh"}))))
1082 1.1 christos {
1083 1.1 christos $disabled{"ssl3"} = "forced";
1084 1.1 christos $disabled{"tls1"} = "forced";
1085 1.1 christos }
1086 1.1 christos
1087 1.1 christos if (defined($disabled{"ec"}) || defined($disabled{"dsa"})
1088 1.1 christos || defined($disabled{"dh"}))
1089 1.1 christos {
1090 1.1 christos $disabled{"gost"} = "forced";
1091 1.1 christos }
1092 1.1 christos
1093 1.3 christos # SRP and HEARTBEATS require TLSEXT
1094 1.2 spz if (defined($disabled{"tlsext"}))
1095 1.2 spz {
1096 1.2 spz $disabled{"srp"} = "forced";
1097 1.3 christos $disabled{"heartbeats"} = "forced";
1098 1.2 spz }
1099 1.2 spz
1100 1.1 christos if ($target eq "TABLE") {
1101 1.1 christos foreach $target (sort keys %table) {
1102 1.1 christos print_table_entry($target);
1103 1.1 christos }
1104 1.1 christos exit 0;
1105 1.1 christos }
1106 1.1 christos
1107 1.1 christos if ($target eq "LIST") {
1108 1.1 christos foreach (sort keys %table) {
1109 1.1 christos print;
1110 1.1 christos print "\n";
1111 1.1 christos }
1112 1.1 christos exit 0;
1113 1.1 christos }
1114 1.1 christos
1115 1.1 christos if ($target =~ m/^CygWin32(-.*)$/) {
1116 1.1 christos $target = "Cygwin".$1;
1117 1.1 christos }
1118 1.1 christos
1119 1.1 christos print "Configuring for $target\n";
1120 1.1 christos
1121 1.1 christos &usage if (!defined($table{$target}));
1122 1.1 christos
1123 1.1 christos
1124 1.1 christos foreach (sort (keys %disabled))
1125 1.1 christos {
1126 1.1 christos $options .= " no-$_";
1127 1.1 christos
1128 1.1 christos printf " no-%-12s %-10s", $_, "[$disabled{$_}]";
1129 1.1 christos
1130 1.1 christos if (/^dso$/)
1131 1.1 christos { $no_dso = 1; }
1132 1.1 christos elsif (/^threads$/)
1133 1.1 christos { $no_threads = 1; }
1134 1.1 christos elsif (/^shared$/)
1135 1.1 christos { $no_shared = 1; }
1136 1.1 christos elsif (/^zlib$/)
1137 1.1 christos { $zlib = 0; }
1138 1.1 christos elsif (/^static-engine$/)
1139 1.1 christos { }
1140 1.1 christos elsif (/^zlib-dynamic$/)
1141 1.1 christos { }
1142 1.1 christos elsif (/^symlinks$/)
1143 1.1 christos { $symlink = 0; }
1144 1.1 christos elsif (/^sse2$/)
1145 1.1 christos { $no_sse2 = 1; }
1146 1.1 christos else
1147 1.1 christos {
1148 1.1 christos my ($ALGO, $algo);
1149 1.2 spz ($ALGO = $algo = $_) =~ tr/[\-a-z]/[_A-Z]/;
1150 1.1 christos
1151 1.1 christos if (/^asm$/ || /^err$/ || /^hw$/ || /^hw-/)
1152 1.1 christos {
1153 1.1 christos $openssl_other_defines .= "#define OPENSSL_NO_$ALGO\n";
1154 1.1 christos print " OPENSSL_NO_$ALGO";
1155 1.1 christos
1156 1.1 christos if (/^err$/) { $flags .= "-DOPENSSL_NO_ERR "; }
1157 1.1 christos elsif (/^asm$/) { $no_asm = 1; }
1158 1.1 christos }
1159 1.1 christos else
1160 1.1 christos {
1161 1.1 christos $openssl_algorithm_defines .= "#define OPENSSL_NO_$ALGO\n";
1162 1.1 christos print " OPENSSL_NO_$ALGO";
1163 1.1 christos
1164 1.1 christos if (/^krb5$/)
1165 1.1 christos { $no_krb5 = 1; }
1166 1.1 christos else
1167 1.1 christos {
1168 1.1 christos push @skip, $algo;
1169 1.3 christos # fix-up crypto/directory name(s)
1170 1.3 christos @skip[$#skip]="whrlpool" if $algo eq "whirlpool";
1171 1.1 christos print " (skip dir)";
1172 1.1 christos
1173 1.1 christos $depflags .= " -DOPENSSL_NO_$ALGO";
1174 1.1 christos }
1175 1.1 christos }
1176 1.1 christos }
1177 1.1 christos
1178 1.1 christos print "\n";
1179 1.1 christos }
1180 1.1 christos
1181 1.1 christos my $exp_cflags = "";
1182 1.1 christos foreach (sort @experimental)
1183 1.1 christos {
1184 1.1 christos my $ALGO;
1185 1.1 christos ($ALGO = $_) =~ tr/[a-z]/[A-Z]/;
1186 1.1 christos
1187 1.1 christos # opensslconf.h will set OPENSSL_NO_... unless OPENSSL_EXPERIMENTAL_... is defined
1188 1.1 christos $openssl_experimental_defines .= "#define OPENSSL_NO_$ALGO\n";
1189 1.1 christos $exp_cflags .= " -DOPENSSL_EXPERIMENTAL_$ALGO";
1190 1.1 christos }
1191 1.1 christos
1192 1.1 christos my $IsMK1MF=scalar grep /^$target$/,@MK1MF_Builds;
1193 1.1 christos
1194 1.1 christos $exe_ext=".exe" if ($target eq "Cygwin" || $target eq "DJGPP" || $target =~ /^mingw/);
1195 1.1 christos $exe_ext=".nlm" if ($target =~ /netware/);
1196 1.1 christos $exe_ext=".pm" if ($target =~ /vos/);
1197 1.1 christos $openssldir="/usr/local/ssl" if ($openssldir eq "" and $prefix eq "");
1198 1.1 christos $prefix=$openssldir if $prefix eq "";
1199 1.1 christos
1200 1.1 christos $default_ranlib= &which("ranlib") or $default_ranlib="true";
1201 1.1 christos $perl=$ENV{'PERL'} or $perl=&which("perl5") or $perl=&which("perl")
1202 1.1 christos or $perl="perl";
1203 1.2 spz my $make = $ENV{'MAKE'} || "make";
1204 1.2 spz
1205 1.2 spz $cross_compile_prefix=$ENV{'CROSS_COMPILE'} if $cross_compile_prefix eq "";
1206 1.1 christos
1207 1.1 christos chop $openssldir if $openssldir =~ /\/$/;
1208 1.1 christos chop $prefix if $prefix =~ /.\/$/;
1209 1.1 christos
1210 1.1 christos $openssldir=$prefix . "/ssl" if $openssldir eq "";
1211 1.1 christos $openssldir=$prefix . "/" . $openssldir if $openssldir !~ /(^\/|^[a-zA-Z]:[\\\/])/;
1212 1.1 christos
1213 1.1 christos
1214 1.1 christos print "IsMK1MF=$IsMK1MF\n";
1215 1.1 christos
1216 1.1 christos my @fields = split(/\s*:\s*/,$table{$target} . ":" x 30 , -1);
1217 1.1 christos my $cc = $fields[$idx_cc];
1218 1.1 christos # Allow environment CC to override compiler...
1219 1.1 christos if($ENV{CC}) {
1220 1.1 christos $cc = $ENV{CC};
1221 1.1 christos }
1222 1.16 spz
1223 1.1 christos my $cflags = $fields[$idx_cflags];
1224 1.1 christos my $unistd = $fields[$idx_unistd];
1225 1.1 christos my $thread_cflag = $fields[$idx_thread_cflag];
1226 1.1 christos my $sys_id = $fields[$idx_sys_id];
1227 1.1 christos my $lflags = $fields[$idx_lflags];
1228 1.1 christos my $bn_ops = $fields[$idx_bn_ops];
1229 1.1 christos my $cpuid_obj = $fields[$idx_cpuid_obj];
1230 1.1 christos my $bn_obj = $fields[$idx_bn_obj];
1231 1.16 spz my $ec_obj = $fields[$idx_ec_obj];
1232 1.1 christos my $des_obj = $fields[$idx_des_obj];
1233 1.1 christos my $aes_obj = $fields[$idx_aes_obj];
1234 1.1 christos my $bf_obj = $fields[$idx_bf_obj];
1235 1.1 christos my $md5_obj = $fields[$idx_md5_obj];
1236 1.1 christos my $sha1_obj = $fields[$idx_sha1_obj];
1237 1.1 christos my $cast_obj = $fields[$idx_cast_obj];
1238 1.1 christos my $rc4_obj = $fields[$idx_rc4_obj];
1239 1.1 christos my $rmd160_obj = $fields[$idx_rmd160_obj];
1240 1.1 christos my $rc5_obj = $fields[$idx_rc5_obj];
1241 1.1 christos my $wp_obj = $fields[$idx_wp_obj];
1242 1.1 christos my $cmll_obj = $fields[$idx_cmll_obj];
1243 1.3 christos my $modes_obj = $fields[$idx_modes_obj];
1244 1.3 christos my $engines_obj = $fields[$idx_engines_obj];
1245 1.1 christos my $perlasm_scheme = $fields[$idx_perlasm_scheme];
1246 1.1 christos my $dso_scheme = $fields[$idx_dso_scheme];
1247 1.1 christos my $shared_target = $fields[$idx_shared_target];
1248 1.1 christos my $shared_cflag = $fields[$idx_shared_cflag];
1249 1.1 christos my $shared_ldflag = $fields[$idx_shared_ldflag];
1250 1.1 christos my $shared_extension = $fields[$idx_shared_extension];
1251 1.2 spz my $ranlib = $ENV{'RANLIB'} || $fields[$idx_ranlib];
1252 1.2 spz my $ar = $ENV{'AR'} || "ar";
1253 1.1 christos my $arflags = $fields[$idx_arflags];
1254 1.16 spz my $windres = $ENV{'RC'} || $ENV{'WINDRES'} || "windres";
1255 1.1 christos my $multilib = $fields[$idx_multilib];
1256 1.1 christos
1257 1.2 spz # if $prefix/lib$multilib is not an existing directory, then
1258 1.2 spz # assume that it's not searched by linker automatically, in
1259 1.2 spz # which case adding $multilib suffix causes more grief than
1260 1.2 spz # we're ready to tolerate, so don't...
1261 1.2 spz $multilib="" if !-d "$prefix/lib$multilib";
1262 1.2 spz
1263 1.2 spz $libdir="lib$multilib" if $libdir eq "";
1264 1.2 spz
1265 1.1 christos $cflags = "$cflags$exp_cflags";
1266 1.1 christos
1267 1.1 christos # '%' in $lflags is used to split flags to "pre-" and post-flags
1268 1.1 christos my ($prelflags,$postlflags)=split('%',$lflags);
1269 1.1 christos if (defined($postlflags)) { $lflags=$postlflags; }
1270 1.1 christos else { $lflags=$prelflags; undef $prelflags; }
1271 1.1 christos
1272 1.2 spz if ($target =~ /^mingw/ && `$cc --target-help 2>&1` !~ m/\-mno\-cygwin/m)
1273 1.2 spz {
1274 1.2 spz $cflags =~ s/\-mno\-cygwin\s*//;
1275 1.2 spz $shared_ldflag =~ s/\-mno\-cygwin\s*//;
1276 1.2 spz }
1277 1.2 spz
1278 1.16 spz if ($target =~ /linux.*\-mips/ && !$no_asm && $flags !~ /\-m(ips|arch=)/) {
1279 1.16 spz # minimally required architecture flags for assembly modules
1280 1.16 spz $cflags="-mips2 $cflags" if ($target =~ /mips32/);
1281 1.16 spz $cflags="-mips3 $cflags" if ($target =~ /mips64/);
1282 1.16 spz }
1283 1.16 spz
1284 1.1 christos my $no_shared_warn=0;
1285 1.1 christos my $no_user_cflags=0;
1286 1.1 christos
1287 1.1 christos if ($flags ne "") { $cflags="$flags$cflags"; }
1288 1.1 christos else { $no_user_cflags=1; }
1289 1.1 christos
1290 1.1 christos # Kerberos settings. The flavor must be provided from outside, either through
1291 1.1 christos # the script "config" or manually.
1292 1.1 christos if (!$no_krb5)
1293 1.1 christos {
1294 1.1 christos my ($lresolv, $lpath, $lext);
1295 1.1 christos if ($withargs{"krb5-flavor"} =~ /^[Hh]eimdal$/)
1296 1.1 christos {
1297 1.1 christos die "Sorry, Heimdal is currently not supported\n";
1298 1.1 christos }
1299 1.1 christos ##### HACK to force use of Heimdal.
1300 1.1 christos ##### WARNING: Since we don't really have adequate support for Heimdal,
1301 1.1 christos ##### using this will break the build. You'll have to make
1302 1.1 christos ##### changes to the source, and if you do, please send
1303 1.1 christos ##### patches to openssl-dev (a] openssl.org
1304 1.1 christos if ($withargs{"krb5-flavor"} =~ /^force-[Hh]eimdal$/)
1305 1.1 christos {
1306 1.1 christos warn "Heimdal isn't really supported. Your build WILL break\n";
1307 1.1 christos warn "If you fix the problems, please send a patch to openssl-dev\@openssl.org\n";
1308 1.1 christos $withargs{"krb5-dir"} = "/usr/heimdal"
1309 1.1 christos if $withargs{"krb5-dir"} eq "";
1310 1.1 christos $withargs{"krb5-lib"} = "-L".$withargs{"krb5-dir"}.
1311 1.1 christos "/lib -lgssapi -lkrb5 -lcom_err"
1312 1.1 christos if $withargs{"krb5-lib"} eq "" && !$IsMK1MF;
1313 1.1 christos $cflags="-DKRB5_HEIMDAL $cflags";
1314 1.1 christos }
1315 1.1 christos if ($withargs{"krb5-flavor"} =~ /^[Mm][Ii][Tt]/)
1316 1.1 christos {
1317 1.1 christos $withargs{"krb5-dir"} = "/usr/kerberos"
1318 1.1 christos if $withargs{"krb5-dir"} eq "";
1319 1.1 christos $withargs{"krb5-lib"} = "-L".$withargs{"krb5-dir"}.
1320 1.1 christos "/lib -lgssapi_krb5 -lkrb5 -lcom_err -lk5crypto"
1321 1.1 christos if $withargs{"krb5-lib"} eq "" && !$IsMK1MF;
1322 1.1 christos $cflags="-DKRB5_MIT $cflags";
1323 1.1 christos $withargs{"krb5-flavor"} =~ s/^[Mm][Ii][Tt][._-]*//;
1324 1.1 christos if ($withargs{"krb5-flavor"} =~ /^1[._-]*[01]/)
1325 1.1 christos {
1326 1.1 christos $cflags="-DKRB5_MIT_OLD11 $cflags";
1327 1.1 christos }
1328 1.1 christos }
1329 1.1 christos LRESOLV:
1330 1.1 christos foreach $lpath ("/lib", "/usr/lib")
1331 1.1 christos {
1332 1.1 christos foreach $lext ("a", "so")
1333 1.1 christos {
1334 1.1 christos $lresolv = "$lpath/libresolv.$lext";
1335 1.1 christos last LRESOLV if (-r "$lresolv");
1336 1.1 christos $lresolv = "";
1337 1.1 christos }
1338 1.1 christos }
1339 1.1 christos $withargs{"krb5-lib"} .= " -lresolv"
1340 1.1 christos if ("$lresolv" ne "");
1341 1.1 christos $withargs{"krb5-include"} = "-I".$withargs{"krb5-dir"}."/include"
1342 1.1 christos if $withargs{"krb5-include"} eq "" &&
1343 1.1 christos $withargs{"krb5-dir"} ne "";
1344 1.1 christos }
1345 1.1 christos
1346 1.1 christos # The DSO code currently always implements all functions so that no
1347 1.1 christos # applications will have to worry about that from a compilation point
1348 1.1 christos # of view. However, the "method"s may return zero unless that platform
1349 1.1 christos # has support compiled in for them. Currently each method is enabled
1350 1.1 christos # by a define "DSO_<name>" ... we translate the "dso_scheme" config
1351 1.1 christos # string entry into using the following logic;
1352 1.1 christos my $dso_cflags;
1353 1.1 christos if (!$no_dso && $dso_scheme ne "")
1354 1.1 christos {
1355 1.1 christos $dso_scheme =~ tr/[a-z]/[A-Z]/;
1356 1.1 christos if ($dso_scheme eq "DLFCN")
1357 1.1 christos {
1358 1.1 christos $dso_cflags = "-DDSO_DLFCN -DHAVE_DLFCN_H";
1359 1.1 christos }
1360 1.1 christos elsif ($dso_scheme eq "DLFCN_NO_H")
1361 1.1 christos {
1362 1.1 christos $dso_cflags = "-DDSO_DLFCN";
1363 1.1 christos }
1364 1.1 christos else
1365 1.1 christos {
1366 1.1 christos $dso_cflags = "-DDSO_$dso_scheme";
1367 1.1 christos }
1368 1.1 christos $cflags = "$dso_cflags $cflags";
1369 1.1 christos }
1370 1.1 christos
1371 1.1 christos my $thread_cflags;
1372 1.1 christos my $thread_defines;
1373 1.1 christos if ($thread_cflag ne "(unknown)" && !$no_threads)
1374 1.1 christos {
1375 1.1 christos # If we know how to do it, support threads by default.
1376 1.1 christos $threads = 1;
1377 1.1 christos }
1378 1.1 christos if ($thread_cflag eq "(unknown)" && $threads)
1379 1.1 christos {
1380 1.1 christos # If the user asked for "threads", [s]he is also expected to
1381 1.1 christos # provide any system-dependent compiler options that are
1382 1.1 christos # necessary.
1383 1.1 christos if ($no_user_cflags)
1384 1.1 christos {
1385 1.1 christos print "You asked for multi-threading support, but didn't\n";
1386 1.1 christos print "provide any system-specific compiler options\n";
1387 1.1 christos exit(1);
1388 1.1 christos }
1389 1.1 christos $thread_cflags="-DOPENSSL_THREADS $cflags" ;
1390 1.1 christos $thread_defines .= "#define OPENSSL_THREADS\n";
1391 1.1 christos }
1392 1.1 christos else
1393 1.1 christos {
1394 1.1 christos $thread_cflags="-DOPENSSL_THREADS $thread_cflag $cflags";
1395 1.1 christos $thread_defines .= "#define OPENSSL_THREADS\n";
1396 1.1 christos # my $def;
1397 1.1 christos # foreach $def (split ' ',$thread_cflag)
1398 1.1 christos # {
1399 1.1 christos # if ($def =~ s/^-D// && $def !~ /^_/)
1400 1.1 christos # {
1401 1.1 christos # $thread_defines .= "#define $def\n";
1402 1.1 christos # }
1403 1.1 christos # }
1404 1.1 christos }
1405 1.1 christos
1406 1.1 christos $lflags="$libs$lflags" if ($libs ne "");
1407 1.1 christos
1408 1.1 christos if ($no_asm)
1409 1.1 christos {
1410 1.16 spz $cpuid_obj=$bn_obj=$ec_obj=
1411 1.1 christos $des_obj=$aes_obj=$bf_obj=$cast_obj=$rc4_obj=$rc5_obj=$cmll_obj=
1412 1.3 christos $modes_obj=$sha1_obj=$md5_obj=$rmd160_obj=$wp_obj=$engines_obj="";
1413 1.1 christos }
1414 1.1 christos
1415 1.1 christos if (!$no_shared)
1416 1.1 christos {
1417 1.1 christos $cast_obj=""; # CAST assembler is not PIC
1418 1.1 christos }
1419 1.1 christos
1420 1.1 christos if ($threads)
1421 1.1 christos {
1422 1.1 christos $cflags=$thread_cflags;
1423 1.1 christos $openssl_thread_defines .= $thread_defines;
1424 1.1 christos }
1425 1.1 christos
1426 1.1 christos if ($zlib)
1427 1.1 christos {
1428 1.1 christos $cflags = "-DZLIB $cflags";
1429 1.1 christos if (defined($disabled{"zlib-dynamic"}))
1430 1.1 christos {
1431 1.1 christos if (defined($withargs{"zlib-lib"}))
1432 1.1 christos {
1433 1.1 christos $lflags = "$lflags -L" . $withargs{"zlib-lib"} . " -lz";
1434 1.1 christos }
1435 1.1 christos else
1436 1.1 christos {
1437 1.1 christos $lflags = "$lflags -lz";
1438 1.1 christos }
1439 1.1 christos }
1440 1.1 christos else
1441 1.1 christos {
1442 1.1 christos $cflags = "-DZLIB_SHARED $cflags";
1443 1.1 christos }
1444 1.1 christos }
1445 1.1 christos
1446 1.1 christos # You will find shlib_mark1 and shlib_mark2 explained in Makefile.org
1447 1.1 christos my $shared_mark = "";
1448 1.1 christos if ($shared_target eq "")
1449 1.1 christos {
1450 1.1 christos $no_shared_warn = 1 if !$no_shared;
1451 1.1 christos $no_shared = 1;
1452 1.1 christos }
1453 1.1 christos if (!$no_shared)
1454 1.1 christos {
1455 1.1 christos if ($shared_cflag ne "")
1456 1.1 christos {
1457 1.1 christos $cflags = "$shared_cflag -DOPENSSL_PIC $cflags";
1458 1.1 christos }
1459 1.1 christos }
1460 1.1 christos
1461 1.1 christos if (!$IsMK1MF)
1462 1.1 christos {
1463 1.1 christos # add {no-}static-engine to options to allow mkdef.pl to work without extra arguments
1464 1.1 christos if ($no_shared)
1465 1.1 christos {
1466 1.1 christos $openssl_other_defines.="#define OPENSSL_NO_DYNAMIC_ENGINE\n";
1467 1.1 christos $options.=" static-engine";
1468 1.1 christos }
1469 1.1 christos else
1470 1.1 christos {
1471 1.1 christos $openssl_other_defines.="#define OPENSSL_NO_STATIC_ENGINE\n";
1472 1.1 christos $options.=" no-static-engine";
1473 1.1 christos }
1474 1.1 christos }
1475 1.1 christos
1476 1.3 christos $cpuid_obj.=" uplink.o uplink-x86.o" if ($cflags =~ /\-DOPENSSL_USE_APPLINK/);
1477 1.1 christos
1478 1.1 christos #
1479 1.1 christos # Platform fix-ups
1480 1.1 christos #
1481 1.1 christos if ($target =~ /\-icc$/) # Intel C compiler
1482 1.1 christos {
1483 1.1 christos my $iccver=0;
1484 1.1 christos if (open(FD,"$cc -V 2>&1 |"))
1485 1.1 christos {
1486 1.1 christos while(<FD>) { $iccver=$1 if (/Version ([0-9]+)\./); }
1487 1.1 christos close(FD);
1488 1.1 christos }
1489 1.1 christos if ($iccver>=8)
1490 1.1 christos {
1491 1.16 spz $cflags=~s/\-KPIC/-fPIC/;
1492 1.1 christos # Eliminate unnecessary dependency from libirc.a. This is
1493 1.1 christos # essential for shared library support, as otherwise
1494 1.1 christos # apps/openssl can end up in endless loop upon startup...
1495 1.1 christos $cflags.=" -Dmemcpy=__builtin_memcpy -Dmemset=__builtin_memset";
1496 1.1 christos }
1497 1.1 christos if ($iccver>=9)
1498 1.1 christos {
1499 1.16 spz $lflags.=" -i-static";
1500 1.16 spz $lflags=~s/\-no_cpprt/-no-cpprt/;
1501 1.1 christos }
1502 1.1 christos if ($iccver>=10)
1503 1.1 christos {
1504 1.16 spz $lflags=~s/\-i\-static/-static-intel/;
1505 1.16 spz }
1506 1.16 spz if ($iccver>=11)
1507 1.16 spz {
1508 1.16 spz $cflags.=" -no-intel-extensions"; # disable Cilk
1509 1.16 spz $lflags=~s/\-no\-cpprt/-no-cxxlib/;
1510 1.1 christos }
1511 1.1 christos }
1512 1.1 christos
1513 1.1 christos # Unlike other OSes (like Solaris, Linux, Tru64, IRIX) BSD run-time
1514 1.1 christos # linkers (tested OpenBSD, NetBSD and FreeBSD) "demand" RPATH set on
1515 1.1 christos # .so objects. Apparently application RPATH is not global and does
1516 1.1 christos # not apply to .so linked with other .so. Problem manifests itself
1517 1.1 christos # when libssl.so fails to load libcrypto.so. One can argue that we
1518 1.1 christos # should engrave this into Makefile.shared rules or into BSD-* config
1519 1.1 christos # lines above. Meanwhile let's try to be cautious and pass -rpath to
1520 1.1 christos # linker only when --prefix is not /usr.
1521 1.1 christos if ($target =~ /^BSD\-/)
1522 1.1 christos {
1523 1.14 christos $shared_ldflag.=" -Wl,-rpath,\$\$(LIBRPATH)" if ($prefix !~ m|^/usr[/]*$|);
1524 1.1 christos }
1525 1.1 christos
1526 1.1 christos if ($sys_id ne "")
1527 1.1 christos {
1528 1.1 christos #$cflags="-DOPENSSL_SYSNAME_$sys_id $cflags";
1529 1.1 christos $openssl_sys_defines="#define OPENSSL_SYSNAME_$sys_id\n";
1530 1.1 christos }
1531 1.1 christos
1532 1.1 christos if ($ranlib eq "")
1533 1.1 christos {
1534 1.1 christos $ranlib = $default_ranlib;
1535 1.1 christos }
1536 1.1 christos
1537 1.1 christos #my ($bn1)=split(/\s+/,$bn_obj);
1538 1.1 christos #$bn1 = "" unless defined $bn1;
1539 1.1 christos #$bn1=$bn_asm unless ($bn1 =~ /\.o$/);
1540 1.1 christos #$bn_obj="$bn1";
1541 1.1 christos
1542 1.1 christos $cpuid_obj="" if ($processor eq "386");
1543 1.1 christos
1544 1.1 christos $bn_obj = $bn_asm unless $bn_obj ne "";
1545 1.1 christos # bn-586 is the only one implementing bn_*_part_words
1546 1.1 christos $cflags.=" -DOPENSSL_BN_ASM_PART_WORDS" if ($bn_obj =~ /bn-586/);
1547 1.1 christos $cflags.=" -DOPENSSL_IA32_SSE2" if (!$no_sse2 && $bn_obj =~ /86/);
1548 1.1 christos
1549 1.1 christos $cflags.=" -DOPENSSL_BN_ASM_MONT" if ($bn_obj =~ /-mont/);
1550 1.3 christos $cflags.=" -DOPENSSL_BN_ASM_MONT5" if ($bn_obj =~ /-mont5/);
1551 1.3 christos $cflags.=" -DOPENSSL_BN_ASM_GF2m" if ($bn_obj =~ /-gf2m/);
1552 1.1 christos
1553 1.2 spz if ($fips)
1554 1.2 spz {
1555 1.2 spz $openssl_other_defines.="#define OPENSSL_FIPS\n";
1556 1.3 christos $cflags .= " -I\$(FIPSDIR)/include";
1557 1.2 spz }
1558 1.2 spz
1559 1.1 christos $cpuid_obj="mem_clr.o" unless ($cpuid_obj =~ /\.o$/);
1560 1.1 christos $des_obj=$des_enc unless ($des_obj =~ /\.o$/);
1561 1.1 christos $bf_obj=$bf_enc unless ($bf_obj =~ /\.o$/);
1562 1.1 christos $cast_obj=$cast_enc unless ($cast_obj =~ /\.o$/);
1563 1.1 christos $rc5_obj=$rc5_enc unless ($rc5_obj =~ /\.o$/);
1564 1.16 spz if ($rc4_obj =~ /\.o$/)
1565 1.16 spz {
1566 1.16 spz $cflags.=" -DRC4_ASM";
1567 1.16 spz }
1568 1.16 spz else
1569 1.16 spz {
1570 1.16 spz $rc4_obj=$rc4_enc;
1571 1.16 spz }
1572 1.1 christos if ($sha1_obj =~ /\.o$/)
1573 1.1 christos {
1574 1.1 christos # $sha1_obj=$sha1_enc;
1575 1.1 christos $cflags.=" -DSHA1_ASM" if ($sha1_obj =~ /sx86/ || $sha1_obj =~ /sha1/);
1576 1.1 christos $cflags.=" -DSHA256_ASM" if ($sha1_obj =~ /sha256/);
1577 1.1 christos $cflags.=" -DSHA512_ASM" if ($sha1_obj =~ /sha512/);
1578 1.1 christos if ($sha1_obj =~ /sse2/)
1579 1.1 christos { if ($no_sse2)
1580 1.1 christos { $sha1_obj =~ s/\S*sse2\S+//; }
1581 1.1 christos elsif ($cflags !~ /OPENSSL_IA32_SSE2/)
1582 1.1 christos { $cflags.=" -DOPENSSL_IA32_SSE2"; }
1583 1.1 christos }
1584 1.1 christos }
1585 1.1 christos if ($md5_obj =~ /\.o$/)
1586 1.1 christos {
1587 1.1 christos # $md5_obj=$md5_enc;
1588 1.1 christos $cflags.=" -DMD5_ASM";
1589 1.1 christos }
1590 1.1 christos if ($rmd160_obj =~ /\.o$/)
1591 1.1 christos {
1592 1.1 christos # $rmd160_obj=$rmd160_enc;
1593 1.1 christos $cflags.=" -DRMD160_ASM";
1594 1.1 christos }
1595 1.1 christos if ($aes_obj =~ /\.o$/)
1596 1.1 christos {
1597 1.16 spz $cflags.=" -DAES_ASM" if ($aes_obj =~ m/\baes\-/);;
1598 1.3 christos # aes-ctr.o is not a real file, only indication that assembler
1599 1.3 christos # module implements AES_ctr32_encrypt...
1600 1.3 christos $cflags.=" -DAES_CTR_ASM" if ($aes_obj =~ s/\s*aes\-ctr\.o//);
1601 1.3 christos # aes-xts.o indicates presense of AES_xts_[en|de]crypt...
1602 1.3 christos $cflags.=" -DAES_XTS_ASM" if ($aes_obj =~ s/\s*aes\-xts\.o//);
1603 1.3 christos $aes_obj =~ s/\s*(vpaes|aesni)\-x86\.o//g if ($no_sse2);
1604 1.3 christos $cflags.=" -DVPAES_ASM" if ($aes_obj =~ m/vpaes/);
1605 1.3 christos $cflags.=" -DBSAES_ASM" if ($aes_obj =~ m/bsaes/);
1606 1.1 christos }
1607 1.1 christos else {
1608 1.1 christos $aes_obj=$aes_enc;
1609 1.1 christos }
1610 1.1 christos $wp_obj="" if ($wp_obj =~ /mmx/ && $processor eq "386");
1611 1.3 christos if ($wp_obj =~ /\.o$/ && !$disabled{"whirlpool"})
1612 1.1 christos {
1613 1.1 christos $cflags.=" -DWHIRLPOOL_ASM";
1614 1.1 christos }
1615 1.1 christos else {
1616 1.1 christos $wp_obj="wp_block.o";
1617 1.1 christos }
1618 1.1 christos $cmll_obj=$cmll_enc unless ($cmll_obj =~ /.o$/);
1619 1.16 spz if ($modes_obj =~ /ghash\-/)
1620 1.3 christos {
1621 1.3 christos $cflags.=" -DGHASH_ASM";
1622 1.3 christos }
1623 1.16 spz if ($ec_obj =~ /ecp_nistz256/)
1624 1.16 spz {
1625 1.16 spz $cflags.=" -DECP_NISTZ256_ASM";
1626 1.16 spz }
1627 1.1 christos
1628 1.1 christos # "Stringify" the C flags string. This permits it to be made part of a string
1629 1.1 christos # and works as well on command lines.
1630 1.1 christos $cflags =~ s/([\\\"])/\\\1/g;
1631 1.1 christos
1632 1.1 christos my $version = "unknown";
1633 1.1 christos my $version_num = "unknown";
1634 1.1 christos my $major = "unknown";
1635 1.1 christos my $minor = "unknown";
1636 1.1 christos my $shlib_version_number = "unknown";
1637 1.1 christos my $shlib_version_history = "unknown";
1638 1.1 christos my $shlib_major = "unknown";
1639 1.1 christos my $shlib_minor = "unknown";
1640 1.1 christos
1641 1.1 christos open(IN,'<crypto/opensslv.h') || die "unable to read opensslv.h:$!\n";
1642 1.1 christos while (<IN>)
1643 1.1 christos {
1644 1.1 christos $version=$1 if /OPENSSL.VERSION.TEXT.*OpenSSL (\S+) /;
1645 1.1 christos $version_num=$1 if /OPENSSL.VERSION.NUMBER.*0x(\S+)/;
1646 1.1 christos $shlib_version_number=$1 if /SHLIB_VERSION_NUMBER *"([^"]+)"/;
1647 1.1 christos $shlib_version_history=$1 if /SHLIB_VERSION_HISTORY *"([^"]*)"/;
1648 1.1 christos }
1649 1.1 christos close(IN);
1650 1.1 christos if ($shlib_version_history ne "") { $shlib_version_history .= ":"; }
1651 1.1 christos
1652 1.1 christos if ($version =~ /(^[0-9]*)\.([0-9\.]*)/)
1653 1.1 christos {
1654 1.1 christos $major=$1;
1655 1.1 christos $minor=$2;
1656 1.1 christos }
1657 1.1 christos
1658 1.1 christos if ($shlib_version_number =~ /(^[0-9]*)\.([0-9\.]*)/)
1659 1.1 christos {
1660 1.1 christos $shlib_major=$1;
1661 1.1 christos $shlib_minor=$2;
1662 1.1 christos }
1663 1.1 christos
1664 1.16 spz my $ecc = $cc;
1665 1.16 spz $ecc = "clang" if `$cc --version 2>&1` =~ /clang/;
1666 1.16 spz
1667 1.2 spz if ($strict_warnings)
1668 1.2 spz {
1669 1.2 spz my $wopt;
1670 1.13 christos die "ERROR --strict-warnings requires gcc or clang" unless ($ecc =~ /gcc$/ or $ecc =~ /clang$/);
1671 1.2 spz foreach $wopt (split /\s+/, $gcc_devteam_warn)
1672 1.2 spz {
1673 1.13 christos $cflags .= " $wopt" unless ($cflags =~ /(^|\s)$wopt(\s|$)/)
1674 1.13 christos }
1675 1.13 christos if ($ecc eq "clang")
1676 1.13 christos {
1677 1.13 christos foreach $wopt (split /\s+/, $clang_devteam_warn)
1678 1.13 christos {
1679 1.13 christos $cflags .= " $wopt" unless ($cflags =~ /(^|\s)$wopt(\s|$)/)
1680 1.13 christos }
1681 1.2 spz }
1682 1.2 spz }
1683 1.2 spz
1684 1.1 christos open(IN,'<Makefile.org') || die "unable to read Makefile.org:$!\n";
1685 1.1 christos unlink("$Makefile.new") || die "unable to remove old $Makefile.new:$!\n" if -e "$Makefile.new";
1686 1.1 christos open(OUT,">$Makefile.new") || die "unable to create $Makefile.new:$!\n";
1687 1.1 christos print OUT "### Generated automatically from Makefile.org by Configure.\n\n";
1688 1.1 christos my $sdirs=0;
1689 1.1 christos while (<IN>)
1690 1.1 christos {
1691 1.1 christos chomp;
1692 1.1 christos $sdirs = 1 if /^SDIRS=/;
1693 1.1 christos if ($sdirs) {
1694 1.1 christos my $dir;
1695 1.1 christos foreach $dir (@skip) {
1696 1.1 christos s/(\s)$dir /$1/;
1697 1.1 christos s/\s$dir$//;
1698 1.1 christos }
1699 1.1 christos }
1700 1.1 christos $sdirs = 0 unless /\\$/;
1701 1.1 christos s/engines // if (/^DIRS=/ && $disabled{"engine"});
1702 1.1 christos s/ccgost// if (/^ENGDIRS=/ && $disabled{"gost"});
1703 1.1 christos s/^VERSION=.*/VERSION=$version/;
1704 1.1 christos s/^MAJOR=.*/MAJOR=$major/;
1705 1.1 christos s/^MINOR=.*/MINOR=$minor/;
1706 1.1 christos s/^SHLIB_VERSION_NUMBER=.*/SHLIB_VERSION_NUMBER=$shlib_version_number/;
1707 1.1 christos s/^SHLIB_VERSION_HISTORY=.*/SHLIB_VERSION_HISTORY=$shlib_version_history/;
1708 1.1 christos s/^SHLIB_MAJOR=.*/SHLIB_MAJOR=$shlib_major/;
1709 1.1 christos s/^SHLIB_MINOR=.*/SHLIB_MINOR=$shlib_minor/;
1710 1.1 christos s/^SHLIB_EXT=.*/SHLIB_EXT=$shared_extension/;
1711 1.1 christos s/^INSTALLTOP=.*$/INSTALLTOP=$prefix/;
1712 1.1 christos s/^MULTILIB=.*$/MULTILIB=$multilib/;
1713 1.1 christos s/^OPENSSLDIR=.*$/OPENSSLDIR=$openssldir/;
1714 1.2 spz s/^LIBDIR=.*$/LIBDIR=$libdir/;
1715 1.1 christos s/^INSTALL_PREFIX=.*$/INSTALL_PREFIX=$install_prefix/;
1716 1.1 christos s/^PLATFORM=.*$/PLATFORM=$target/;
1717 1.1 christos s/^OPTIONS=.*$/OPTIONS=$options/;
1718 1.1 christos s/^CONFIGURE_ARGS=.*$/CONFIGURE_ARGS=$argvstring/;
1719 1.1 christos if ($cross_compile_prefix)
1720 1.1 christos {
1721 1.2 spz s/^CC=.*$/CROSS_COMPILE= $cross_compile_prefix\nCC= \$\(CROSS_COMPILE\)$cc/;
1722 1.2 spz s/^AR=\s*/AR= \$\(CROSS_COMPILE\)/;
1723 1.2 spz s/^NM=\s*/NM= \$\(CROSS_COMPILE\)/;
1724 1.2 spz s/^RANLIB=\s*/RANLIB= \$\(CROSS_COMPILE\)/;
1725 1.16 spz s/^RC=\s*/RC= \$\(CROSS_COMPILE\)/;
1726 1.2 spz s/^MAKEDEPPROG=.*$/MAKEDEPPROG= \$\(CROSS_COMPILE\)$cc/ if $cc eq "gcc";
1727 1.1 christos }
1728 1.1 christos else {
1729 1.1 christos s/^CC=.*$/CC= $cc/;
1730 1.2 spz s/^AR=\s*ar/AR= $ar/;
1731 1.1 christos s/^RANLIB=.*/RANLIB= $ranlib/;
1732 1.16 spz s/^RC=.*/RC= $windres/;
1733 1.1 christos s/^MAKEDEPPROG=.*$/MAKEDEPPROG= $cc/ if $cc eq "gcc";
1734 1.16 spz s/^MAKEDEPPROG=.*$/MAKEDEPPROG= $cc/ if $ecc eq "gcc" || $ecc eq "clang";
1735 1.1 christos }
1736 1.1 christos s/^CFLAG=.*$/CFLAG= $cflags/;
1737 1.1 christos s/^DEPFLAG=.*$/DEPFLAG=$depflags/;
1738 1.1 christos s/^PEX_LIBS=.*$/PEX_LIBS= $prelflags/;
1739 1.1 christos s/^EX_LIBS=.*$/EX_LIBS= $lflags/;
1740 1.1 christos s/^EXE_EXT=.*$/EXE_EXT= $exe_ext/;
1741 1.1 christos s/^CPUID_OBJ=.*$/CPUID_OBJ= $cpuid_obj/;
1742 1.1 christos s/^BN_ASM=.*$/BN_ASM= $bn_obj/;
1743 1.16 spz s/^EC_ASM=.*$/EC_ASM= $ec_obj/;
1744 1.1 christos s/^DES_ENC=.*$/DES_ENC= $des_obj/;
1745 1.1 christos s/^AES_ENC=.*$/AES_ENC= $aes_obj/;
1746 1.1 christos s/^BF_ENC=.*$/BF_ENC= $bf_obj/;
1747 1.1 christos s/^CAST_ENC=.*$/CAST_ENC= $cast_obj/;
1748 1.1 christos s/^RC4_ENC=.*$/RC4_ENC= $rc4_obj/;
1749 1.1 christos s/^RC5_ENC=.*$/RC5_ENC= $rc5_obj/;
1750 1.1 christos s/^MD5_ASM_OBJ=.*$/MD5_ASM_OBJ= $md5_obj/;
1751 1.1 christos s/^SHA1_ASM_OBJ=.*$/SHA1_ASM_OBJ= $sha1_obj/;
1752 1.1 christos s/^RMD160_ASM_OBJ=.*$/RMD160_ASM_OBJ= $rmd160_obj/;
1753 1.1 christos s/^WP_ASM_OBJ=.*$/WP_ASM_OBJ= $wp_obj/;
1754 1.1 christos s/^CMLL_ENC=.*$/CMLL_ENC= $cmll_obj/;
1755 1.3 christos s/^MODES_ASM_OBJ.=*$/MODES_ASM_OBJ= $modes_obj/;
1756 1.3 christos s/^ENGINES_ASM_OBJ.=*$/ENGINES_ASM_OBJ= $engines_obj/;
1757 1.1 christos s/^PERLASM_SCHEME=.*$/PERLASM_SCHEME= $perlasm_scheme/;
1758 1.1 christos s/^PROCESSOR=.*/PROCESSOR= $processor/;
1759 1.1 christos s/^ARFLAGS=.*/ARFLAGS= $arflags/;
1760 1.1 christos s/^PERL=.*/PERL= $perl/;
1761 1.1 christos s/^KRB5_INCLUDES=.*/KRB5_INCLUDES=$withargs{"krb5-include"}/;
1762 1.1 christos s/^LIBKRB5=.*/LIBKRB5=$withargs{"krb5-lib"}/;
1763 1.1 christos s/^LIBZLIB=.*/LIBZLIB=$withargs{"zlib-lib"}/;
1764 1.1 christos s/^ZLIB_INCLUDE=.*/ZLIB_INCLUDE=$withargs{"zlib-include"}/;
1765 1.2 spz
1766 1.2 spz s/^FIPSDIR=.*/FIPSDIR=$fipsdir/;
1767 1.2 spz s/^FIPSLIBDIR=.*/FIPSLIBDIR=$fipslibdir/;
1768 1.2 spz s/^FIPSCANLIB=.*/FIPSCANLIB=libcrypto/ if $fips;
1769 1.2 spz s/^BASEADDR=.*/BASEADDR=$baseaddr/;
1770 1.2 spz
1771 1.1 christos s/^SHLIB_TARGET=.*/SHLIB_TARGET=$shared_target/;
1772 1.1 christos s/^SHLIB_MARK=.*/SHLIB_MARK=$shared_mark/;
1773 1.1 christos s/^SHARED_LIBS=.*/SHARED_LIBS=\$(SHARED_CRYPTO) \$(SHARED_SSL)/ if (!$no_shared);
1774 1.1 christos if ($shared_extension ne "" && $shared_extension =~ /^\.s([ol])\.[^\.]*$/)
1775 1.1 christos {
1776 1.1 christos my $sotmp = $1;
1777 1.1 christos s/^SHARED_LIBS_LINK_EXTS=.*/SHARED_LIBS_LINK_EXTS=.s$sotmp/;
1778 1.1 christos }
1779 1.1 christos elsif ($shared_extension ne "" && $shared_extension =~ /^\.[^\.]*\.dylib$/)
1780 1.1 christos {
1781 1.1 christos s/^SHARED_LIBS_LINK_EXTS=.*/SHARED_LIBS_LINK_EXTS=.dylib/;
1782 1.1 christos }
1783 1.1 christos elsif ($shared_extension ne "" && $shared_extension =~ /^\.s([ol])\.[^\.]*\.[^\.]*$/)
1784 1.1 christos {
1785 1.1 christos my $sotmp = $1;
1786 1.1 christos s/^SHARED_LIBS_LINK_EXTS=.*/SHARED_LIBS_LINK_EXTS=.s$sotmp.\$(SHLIB_MAJOR) .s$sotmp/;
1787 1.1 christos }
1788 1.1 christos elsif ($shared_extension ne "" && $shared_extension =~ /^\.[^\.]*\.[^\.]*\.dylib$/)
1789 1.1 christos {
1790 1.1 christos s/^SHARED_LIBS_LINK_EXTS=.*/SHARED_LIBS_LINK_EXTS=.\$(SHLIB_MAJOR).dylib .dylib/;
1791 1.1 christos }
1792 1.1 christos s/^SHARED_LDFLAGS=.*/SHARED_LDFLAGS=$shared_ldflag/;
1793 1.1 christos print OUT $_."\n";
1794 1.1 christos }
1795 1.1 christos close(IN);
1796 1.1 christos close(OUT);
1797 1.17 spz if ((compare($Makefile, "$Makefile.new"))
1798 1.17 spz or file_newer('Configure', $Makefile)
1799 1.17 spz or file_newer('config', $Makefile)
1800 1.17 spz or file_newer('Makefile.org', $Makefile))
1801 1.17 spz {
1802 1.17 spz rename($Makefile,"$Makefile.bak") || die "unable to rename $Makefile\n" if -e $Makefile;
1803 1.17 spz rename("$Makefile.new",$Makefile) || die "unable to rename $Makefile.new\n";
1804 1.17 spz }
1805 1.17 spz else
1806 1.17 spz { unlink("$Makefile.new"); }
1807 1.1 christos
1808 1.1 christos print "CC =$cc\n";
1809 1.1 christos print "CFLAG =$cflags\n";
1810 1.1 christos print "EX_LIBS =$lflags\n";
1811 1.1 christos print "CPUID_OBJ =$cpuid_obj\n";
1812 1.1 christos print "BN_ASM =$bn_obj\n";
1813 1.16 spz print "EC_ASM =$ec_obj\n";
1814 1.1 christos print "DES_ENC =$des_obj\n";
1815 1.1 christos print "AES_ENC =$aes_obj\n";
1816 1.1 christos print "BF_ENC =$bf_obj\n";
1817 1.1 christos print "CAST_ENC =$cast_obj\n";
1818 1.1 christos print "RC4_ENC =$rc4_obj\n";
1819 1.1 christos print "RC5_ENC =$rc5_obj\n";
1820 1.1 christos print "MD5_OBJ_ASM =$md5_obj\n";
1821 1.1 christos print "SHA1_OBJ_ASM =$sha1_obj\n";
1822 1.1 christos print "RMD160_OBJ_ASM=$rmd160_obj\n";
1823 1.3 christos print "CMLL_ENC =$cmll_obj\n";
1824 1.3 christos print "MODES_OBJ =$modes_obj\n";
1825 1.3 christos print "ENGINES_OBJ =$engines_obj\n";
1826 1.1 christos print "PROCESSOR =$processor\n";
1827 1.1 christos print "RANLIB =$ranlib\n";
1828 1.1 christos print "ARFLAGS =$arflags\n";
1829 1.1 christos print "PERL =$perl\n";
1830 1.1 christos print "KRB5_INCLUDES =",$withargs{"krb5-include"},"\n"
1831 1.1 christos if $withargs{"krb5-include"} ne "";
1832 1.1 christos
1833 1.1 christos my $des_ptr=0;
1834 1.1 christos my $des_risc1=0;
1835 1.1 christos my $des_risc2=0;
1836 1.1 christos my $des_unroll=0;
1837 1.1 christos my $bn_ll=0;
1838 1.1 christos my $def_int=2;
1839 1.1 christos my $rc4_int=$def_int;
1840 1.1 christos my $md2_int=$def_int;
1841 1.1 christos my $idea_int=$def_int;
1842 1.1 christos my $rc2_int=$def_int;
1843 1.1 christos my $rc4_idx=0;
1844 1.1 christos my $rc4_chunk=0;
1845 1.1 christos my $bf_ptr=0;
1846 1.1 christos my @type=("char","short","int","long");
1847 1.1 christos my ($b64l,$b64,$b32,$b16,$b8)=(0,0,1,0,0);
1848 1.1 christos my $export_var_as_fn=0;
1849 1.1 christos
1850 1.1 christos my $des_int;
1851 1.1 christos
1852 1.1 christos foreach (sort split(/\s+/,$bn_ops))
1853 1.1 christos {
1854 1.1 christos $des_ptr=1 if /DES_PTR/;
1855 1.1 christos $des_risc1=1 if /DES_RISC1/;
1856 1.1 christos $des_risc2=1 if /DES_RISC2/;
1857 1.1 christos $des_unroll=1 if /DES_UNROLL/;
1858 1.1 christos $des_int=1 if /DES_INT/;
1859 1.1 christos $bn_ll=1 if /BN_LLONG/;
1860 1.1 christos $rc4_int=0 if /RC4_CHAR/;
1861 1.1 christos $rc4_int=3 if /RC4_LONG/;
1862 1.1 christos $rc4_idx=1 if /RC4_INDEX/;
1863 1.1 christos $rc4_chunk=1 if /RC4_CHUNK/;
1864 1.1 christos $rc4_chunk=2 if /RC4_CHUNK_LL/;
1865 1.1 christos $md2_int=0 if /MD2_CHAR/;
1866 1.1 christos $md2_int=3 if /MD2_LONG/;
1867 1.1 christos $idea_int=1 if /IDEA_SHORT/;
1868 1.1 christos $idea_int=3 if /IDEA_LONG/;
1869 1.1 christos $rc2_int=1 if /RC2_SHORT/;
1870 1.1 christos $rc2_int=3 if /RC2_LONG/;
1871 1.1 christos $bf_ptr=1 if $_ eq "BF_PTR";
1872 1.1 christos $bf_ptr=2 if $_ eq "BF_PTR2";
1873 1.1 christos ($b64l,$b64,$b32,$b16,$b8)=(0,1,0,0,0) if /SIXTY_FOUR_BIT/;
1874 1.1 christos ($b64l,$b64,$b32,$b16,$b8)=(1,0,0,0,0) if /SIXTY_FOUR_BIT_LONG/;
1875 1.1 christos ($b64l,$b64,$b32,$b16,$b8)=(0,0,1,0,0) if /THIRTY_TWO_BIT/;
1876 1.1 christos ($b64l,$b64,$b32,$b16,$b8)=(0,0,0,1,0) if /SIXTEEN_BIT/;
1877 1.1 christos ($b64l,$b64,$b32,$b16,$b8)=(0,0,0,0,1) if /EIGHT_BIT/;
1878 1.1 christos $export_var_as_fn=1 if /EXPORT_VAR_AS_FN/;
1879 1.1 christos }
1880 1.1 christos
1881 1.1 christos open(IN,'<crypto/opensslconf.h.in') || die "unable to read crypto/opensslconf.h.in:$!\n";
1882 1.1 christos unlink("crypto/opensslconf.h.new") || die "unable to remove old crypto/opensslconf.h.new:$!\n" if -e "crypto/opensslconf.h.new";
1883 1.1 christos open(OUT,'>crypto/opensslconf.h.new') || die "unable to create crypto/opensslconf.h.new:$!\n";
1884 1.1 christos print OUT "/* opensslconf.h */\n";
1885 1.1 christos print OUT "/* WARNING: Generated automatically from opensslconf.h.in by Configure. */\n\n";
1886 1.1 christos
1887 1.9 spz print OUT "#ifdef __cplusplus\n";
1888 1.9 spz print OUT "extern \"C\" {\n";
1889 1.9 spz print OUT "#endif\n";
1890 1.1 christos print OUT "/* OpenSSL was configured with the following options: */\n";
1891 1.1 christos my $openssl_algorithm_defines_trans = $openssl_algorithm_defines;
1892 1.1 christos $openssl_experimental_defines =~ s/^\s*#\s*define\s+OPENSSL_NO_(.*)/#ifndef OPENSSL_EXPERIMENTAL_$1\n# ifndef OPENSSL_NO_$1\n# define OPENSSL_NO_$1\n# endif\n#endif/mg;
1893 1.1 christos $openssl_algorithm_defines_trans =~ s/^\s*#\s*define\s+OPENSSL_(.*)/# if defined(OPENSSL_$1) \&\& !defined($1)\n# define $1\n# endif/mg;
1894 1.1 christos $openssl_algorithm_defines =~ s/^\s*#\s*define\s+(.*)/#ifndef $1\n# define $1\n#endif/mg;
1895 1.1 christos $openssl_algorithm_defines = " /* no ciphers excluded */\n" if $openssl_algorithm_defines eq "";
1896 1.1 christos $openssl_thread_defines =~ s/^\s*#\s*define\s+(.*)/#ifndef $1\n# define $1\n#endif/mg;
1897 1.1 christos $openssl_sys_defines =~ s/^\s*#\s*define\s+(.*)/#ifndef $1\n# define $1\n#endif/mg;
1898 1.1 christos $openssl_other_defines =~ s/^\s*#\s*define\s+(.*)/#ifndef $1\n# define $1\n#endif/mg;
1899 1.1 christos print OUT $openssl_sys_defines;
1900 1.1 christos print OUT "#ifndef OPENSSL_DOING_MAKEDEPEND\n\n";
1901 1.1 christos print OUT $openssl_experimental_defines;
1902 1.1 christos print OUT "\n";
1903 1.1 christos print OUT $openssl_algorithm_defines;
1904 1.1 christos print OUT "\n#endif /* OPENSSL_DOING_MAKEDEPEND */\n\n";
1905 1.1 christos print OUT $openssl_thread_defines;
1906 1.1 christos print OUT $openssl_other_defines,"\n";
1907 1.1 christos
1908 1.1 christos print OUT "/* The OPENSSL_NO_* macros are also defined as NO_* if the application\n";
1909 1.1 christos print OUT " asks for it. This is a transient feature that is provided for those\n";
1910 1.1 christos print OUT " who haven't had the time to do the appropriate changes in their\n";
1911 1.1 christos print OUT " applications. */\n";
1912 1.1 christos print OUT "#ifdef OPENSSL_ALGORITHM_DEFINES\n";
1913 1.1 christos print OUT $openssl_algorithm_defines_trans;
1914 1.1 christos print OUT "#endif\n\n";
1915 1.1 christos
1916 1.1 christos print OUT "#define OPENSSL_CPUID_OBJ\n\n" if ($cpuid_obj ne "mem_clr.o");
1917 1.1 christos
1918 1.1 christos while (<IN>)
1919 1.1 christos {
1920 1.1 christos if (/^#define\s+OPENSSLDIR/)
1921 1.1 christos {
1922 1.1 christos my $foo = $openssldir;
1923 1.1 christos $foo =~ s/\\/\\\\/g;
1924 1.1 christos print OUT "#define OPENSSLDIR \"$foo\"\n";
1925 1.1 christos }
1926 1.1 christos elsif (/^#define\s+ENGINESDIR/)
1927 1.1 christos {
1928 1.2 spz my $foo = "$prefix/$libdir/engines";
1929 1.1 christos $foo =~ s/\\/\\\\/g;
1930 1.1 christos print OUT "#define ENGINESDIR \"$foo\"\n";
1931 1.1 christos }
1932 1.1 christos elsif (/^#((define)|(undef))\s+OPENSSL_EXPORT_VAR_AS_FUNCTION/)
1933 1.1 christos { printf OUT "#undef OPENSSL_EXPORT_VAR_AS_FUNCTION\n"
1934 1.1 christos if $export_var_as_fn;
1935 1.1 christos printf OUT "#%s OPENSSL_EXPORT_VAR_AS_FUNCTION\n",
1936 1.1 christos ($export_var_as_fn)?"define":"undef"; }
1937 1.1 christos elsif (/^#define\s+OPENSSL_UNISTD/)
1938 1.1 christos {
1939 1.1 christos $unistd = "<unistd.h>" if $unistd eq "";
1940 1.1 christos print OUT "#define OPENSSL_UNISTD $unistd\n";
1941 1.1 christos }
1942 1.1 christos elsif (/^#((define)|(undef))\s+SIXTY_FOUR_BIT_LONG/)
1943 1.1 christos { printf OUT "#%s SIXTY_FOUR_BIT_LONG\n",($b64l)?"define":"undef"; }
1944 1.1 christos elsif (/^#((define)|(undef))\s+SIXTY_FOUR_BIT/)
1945 1.1 christos { printf OUT "#%s SIXTY_FOUR_BIT\n",($b64)?"define":"undef"; }
1946 1.1 christos elsif (/^#((define)|(undef))\s+THIRTY_TWO_BIT/)
1947 1.1 christos { printf OUT "#%s THIRTY_TWO_BIT\n",($b32)?"define":"undef"; }
1948 1.1 christos elsif (/^#((define)|(undef))\s+SIXTEEN_BIT/)
1949 1.1 christos { printf OUT "#%s SIXTEEN_BIT\n",($b16)?"define":"undef"; }
1950 1.1 christos elsif (/^#((define)|(undef))\s+EIGHT_BIT/)
1951 1.1 christos { printf OUT "#%s EIGHT_BIT\n",($b8)?"define":"undef"; }
1952 1.1 christos elsif (/^#((define)|(undef))\s+BN_LLONG\s*$/)
1953 1.1 christos { printf OUT "#%s BN_LLONG\n",($bn_ll)?"define":"undef"; }
1954 1.1 christos elsif (/^\#define\s+DES_LONG\s+.*/)
1955 1.1 christos { printf OUT "#define DES_LONG unsigned %s\n",
1956 1.1 christos ($des_int)?'int':'long'; }
1957 1.1 christos elsif (/^\#(define|undef)\s+DES_PTR/)
1958 1.1 christos { printf OUT "#%s DES_PTR\n",($des_ptr)?'define':'undef'; }
1959 1.1 christos elsif (/^\#(define|undef)\s+DES_RISC1/)
1960 1.1 christos { printf OUT "#%s DES_RISC1\n",($des_risc1)?'define':'undef'; }
1961 1.1 christos elsif (/^\#(define|undef)\s+DES_RISC2/)
1962 1.1 christos { printf OUT "#%s DES_RISC2\n",($des_risc2)?'define':'undef'; }
1963 1.1 christos elsif (/^\#(define|undef)\s+DES_UNROLL/)
1964 1.1 christos { printf OUT "#%s DES_UNROLL\n",($des_unroll)?'define':'undef'; }
1965 1.1 christos elsif (/^#define\s+RC4_INT\s/)
1966 1.1 christos { printf OUT "#define RC4_INT unsigned %s\n",$type[$rc4_int]; }
1967 1.1 christos elsif (/^#undef\s+RC4_CHUNK/)
1968 1.1 christos {
1969 1.1 christos printf OUT "#undef RC4_CHUNK\n" if $rc4_chunk==0;
1970 1.1 christos printf OUT "#define RC4_CHUNK unsigned long\n" if $rc4_chunk==1;
1971 1.1 christos printf OUT "#define RC4_CHUNK unsigned long long\n" if $rc4_chunk==2;
1972 1.1 christos }
1973 1.1 christos elsif (/^#((define)|(undef))\s+RC4_INDEX/)
1974 1.1 christos { printf OUT "#%s RC4_INDEX\n",($rc4_idx)?"define":"undef"; }
1975 1.1 christos elsif (/^#(define|undef)\s+I386_ONLY/)
1976 1.1 christos { printf OUT "#%s I386_ONLY\n", ($processor eq "386")?
1977 1.1 christos "define":"undef"; }
1978 1.1 christos elsif (/^#define\s+MD2_INT\s/)
1979 1.1 christos { printf OUT "#define MD2_INT unsigned %s\n",$type[$md2_int]; }
1980 1.1 christos elsif (/^#define\s+IDEA_INT\s/)
1981 1.1 christos {printf OUT "#define IDEA_INT unsigned %s\n",$type[$idea_int];}
1982 1.1 christos elsif (/^#define\s+RC2_INT\s/)
1983 1.1 christos {printf OUT "#define RC2_INT unsigned %s\n",$type[$rc2_int];}
1984 1.1 christos elsif (/^#(define|undef)\s+BF_PTR/)
1985 1.1 christos {
1986 1.1 christos printf OUT "#undef BF_PTR\n" if $bf_ptr == 0;
1987 1.1 christos printf OUT "#define BF_PTR\n" if $bf_ptr == 1;
1988 1.1 christos printf OUT "#define BF_PTR2\n" if $bf_ptr == 2;
1989 1.1 christos }
1990 1.1 christos else
1991 1.1 christos { print OUT $_; }
1992 1.1 christos }
1993 1.1 christos close(IN);
1994 1.9 spz print OUT "#ifdef __cplusplus\n";
1995 1.9 spz print OUT "}\n";
1996 1.9 spz print OUT "#endif\n";
1997 1.1 christos close(OUT);
1998 1.17 spz if (compare("crypto/opensslconf.h.new","crypto/opensslconf.h"))
1999 1.17 spz {
2000 1.17 spz rename("crypto/opensslconf.h","crypto/opensslconf.h.bak") || die "unable to rename crypto/opensslconf.h\n" if -e "crypto/opensslconf.h";
2001 1.17 spz rename("crypto/opensslconf.h.new","crypto/opensslconf.h") || die "unable to rename crypto/opensslconf.h.new\n";
2002 1.17 spz }
2003 1.17 spz else
2004 1.17 spz { unlink("crypto/opensslconf.h.new"); }
2005 1.1 christos
2006 1.1 christos # Fix the date
2007 1.1 christos
2008 1.1 christos print "SIXTY_FOUR_BIT_LONG mode\n" if $b64l;
2009 1.1 christos print "SIXTY_FOUR_BIT mode\n" if $b64;
2010 1.1 christos print "THIRTY_TWO_BIT mode\n" if $b32;
2011 1.1 christos print "SIXTEEN_BIT mode\n" if $b16;
2012 1.1 christos print "EIGHT_BIT mode\n" if $b8;
2013 1.1 christos print "DES_PTR used\n" if $des_ptr;
2014 1.1 christos print "DES_RISC1 used\n" if $des_risc1;
2015 1.1 christos print "DES_RISC2 used\n" if $des_risc2;
2016 1.1 christos print "DES_UNROLL used\n" if $des_unroll;
2017 1.1 christos print "DES_INT used\n" if $des_int;
2018 1.1 christos print "BN_LLONG mode\n" if $bn_ll;
2019 1.1 christos print "RC4 uses u$type[$rc4_int]\n" if $rc4_int != $def_int;
2020 1.1 christos print "RC4_INDEX mode\n" if $rc4_idx;
2021 1.1 christos print "RC4_CHUNK is undefined\n" if $rc4_chunk==0;
2022 1.1 christos print "RC4_CHUNK is unsigned long\n" if $rc4_chunk==1;
2023 1.1 christos print "RC4_CHUNK is unsigned long long\n" if $rc4_chunk==2;
2024 1.1 christos print "MD2 uses u$type[$md2_int]\n" if $md2_int != $def_int;
2025 1.1 christos print "IDEA uses u$type[$idea_int]\n" if $idea_int != $def_int;
2026 1.1 christos print "RC2 uses u$type[$rc2_int]\n" if $rc2_int != $def_int;
2027 1.1 christos print "BF_PTR used\n" if $bf_ptr == 1;
2028 1.1 christos print "BF_PTR2 used\n" if $bf_ptr == 2;
2029 1.1 christos
2030 1.1 christos if($IsMK1MF) {
2031 1.1 christos open (OUT,">crypto/buildinf.h") || die "Can't open buildinf.h";
2032 1.1 christos printf OUT <<EOF;
2033 1.1 christos #ifndef MK1MF_BUILD
2034 1.1 christos /* auto-generated by Configure for crypto/cversion.c:
2035 1.1 christos * for Unix builds, crypto/Makefile.ssl generates functional definitions;
2036 1.1 christos * Windows builds (and other mk1mf builds) compile cversion.c with
2037 1.1 christos * -DMK1MF_BUILD and use definitions added to this file by util/mk1mf.pl. */
2038 1.1 christos #error "Windows builds (PLATFORM=$target) use mk1mf.pl-created Makefiles"
2039 1.1 christos #endif
2040 1.1 christos EOF
2041 1.1 christos close(OUT);
2042 1.1 christos } else {
2043 1.2 spz my $make_command = "$make PERL=\'$perl\'";
2044 1.1 christos my $make_targets = "";
2045 1.1 christos $make_targets .= " links" if $symlink;
2046 1.1 christos $make_targets .= " depend" if $depflags ne $default_depflags && $make_depend;
2047 1.1 christos $make_targets .= " gentests" if $symlink;
2048 1.1 christos (system $make_command.$make_targets) == 0 or exit $?
2049 1.1 christos if $make_targets ne "";
2050 1.1 christos if ( $perl =~ m@^/@) {
2051 1.2 spz &dofile("tools/c_rehash",$perl,'^#!/', '#!%s','^my \$dir;$', 'my $dir = "' . $openssldir . '";', '^my \$prefix;$', 'my $prefix = "' . $prefix . '";');
2052 1.1 christos &dofile("apps/CA.pl",$perl,'^#!/', '#!%s');
2053 1.1 christos } else {
2054 1.1 christos # No path for Perl known ...
2055 1.2 spz &dofile("tools/c_rehash",'/usr/local/bin/perl','^#!/', '#!%s','^my \$dir;$', 'my $dir = "' . $openssldir . '";', '^my \$prefix;$', 'my $prefix = "' . $prefix . '";');
2056 1.1 christos &dofile("apps/CA.pl",'/usr/local/bin/perl','^#!/', '#!%s');
2057 1.1 christos }
2058 1.1 christos if ($depflags ne $default_depflags && !$make_depend) {
2059 1.14 christos $warn_make_depend++;
2060 1.14 christos }
2061 1.1 christos }
2062 1.1 christos
2063 1.1 christos # create the ms/version32.rc file if needed
2064 1.1 christos if ($IsMK1MF && ($target !~ /^netware/)) {
2065 1.1 christos my ($v1, $v2, $v3, $v4);
2066 1.1 christos if ($version_num =~ /(^[0-9a-f]{1})([0-9a-f]{2})([0-9a-f]{2})([0-9a-f]{2})/i) {
2067 1.1 christos $v1=hex $1;
2068 1.1 christos $v2=hex $2;
2069 1.1 christos $v3=hex $3;
2070 1.1 christos $v4=hex $4;
2071 1.1 christos }
2072 1.1 christos open (OUT,">ms/version32.rc") || die "Can't open ms/version32.rc";
2073 1.1 christos print OUT <<EOF;
2074 1.1 christos #include <winver.h>
2075 1.1 christos
2076 1.1 christos LANGUAGE 0x09,0x01
2077 1.1 christos
2078 1.1 christos 1 VERSIONINFO
2079 1.1 christos FILEVERSION $v1,$v2,$v3,$v4
2080 1.1 christos PRODUCTVERSION $v1,$v2,$v3,$v4
2081 1.1 christos FILEFLAGSMASK 0x3fL
2082 1.1 christos #ifdef _DEBUG
2083 1.1 christos FILEFLAGS 0x01L
2084 1.1 christos #else
2085 1.1 christos FILEFLAGS 0x00L
2086 1.1 christos #endif
2087 1.1 christos FILEOS VOS__WINDOWS32
2088 1.1 christos FILETYPE VFT_DLL
2089 1.1 christos FILESUBTYPE 0x0L
2090 1.1 christos BEGIN
2091 1.1 christos BLOCK "StringFileInfo"
2092 1.1 christos BEGIN
2093 1.1 christos BLOCK "040904b0"
2094 1.1 christos BEGIN
2095 1.1 christos // Required:
2096 1.1 christos VALUE "CompanyName", "The OpenSSL Project, http://www.openssl.org/\\0"
2097 1.1 christos VALUE "FileDescription", "OpenSSL Shared Library\\0"
2098 1.1 christos VALUE "FileVersion", "$version\\0"
2099 1.1 christos #if defined(CRYPTO)
2100 1.1 christos VALUE "InternalName", "libeay32\\0"
2101 1.1 christos VALUE "OriginalFilename", "libeay32.dll\\0"
2102 1.1 christos #elif defined(SSL)
2103 1.1 christos VALUE "InternalName", "ssleay32\\0"
2104 1.1 christos VALUE "OriginalFilename", "ssleay32.dll\\0"
2105 1.1 christos #endif
2106 1.1 christos VALUE "ProductName", "The OpenSSL Toolkit\\0"
2107 1.1 christos VALUE "ProductVersion", "$version\\0"
2108 1.1 christos // Optional:
2109 1.1 christos //VALUE "Comments", "\\0"
2110 1.16 spz VALUE "LegalCopyright", "Copyright 1998-2005 The OpenSSL Project. Copyright 1995-1998 Eric A. Young, Tim J. Hudson. All rights reserved.\\0"
2111 1.1 christos //VALUE "LegalTrademarks", "\\0"
2112 1.1 christos //VALUE "PrivateBuild", "\\0"
2113 1.1 christos //VALUE "SpecialBuild", "\\0"
2114 1.1 christos END
2115 1.1 christos END
2116 1.1 christos BLOCK "VarFileInfo"
2117 1.1 christos BEGIN
2118 1.1 christos VALUE "Translation", 0x409, 0x4b0
2119 1.1 christos END
2120 1.1 christos END
2121 1.1 christos EOF
2122 1.1 christos close(OUT);
2123 1.1 christos }
2124 1.1 christos
2125 1.1 christos print <<EOF;
2126 1.1 christos
2127 1.1 christos Configured for $target.
2128 1.1 christos EOF
2129 1.1 christos
2130 1.1 christos print <<\EOF if (!$no_threads && !$threads);
2131 1.1 christos
2132 1.1 christos The library could not be configured for supporting multi-threaded
2133 1.1 christos applications as the compiler options required on this system are not known.
2134 1.1 christos See file INSTALL for details if you need multi-threading.
2135 1.1 christos EOF
2136 1.1 christos
2137 1.1 christos print <<\EOF if ($no_shared_warn);
2138 1.1 christos
2139 1.14 christos You gave the option 'shared', which is not supported on this platform, so
2140 1.14 christos we will pretend you gave the option 'no-shared'. If you know how to implement
2141 1.14 christos shared libraries, please let us know (but please first make sure you have
2142 1.14 christos tried with a current version of OpenSSL).
2143 1.14 christos EOF
2144 1.14 christos
2145 1.14 christos print <<EOF if ($warn_make_depend);
2146 1.14 christos
2147 1.14 christos *** Because of configuration changes, you MUST do the following before
2148 1.14 christos *** building:
2149 1.14 christos
2150 1.14 christos make depend
2151 1.1 christos EOF
2152 1.1 christos
2153 1.1 christos exit(0);
2154 1.1 christos
2155 1.1 christos sub usage
2156 1.1 christos {
2157 1.1 christos print STDERR $usage;
2158 1.1 christos print STDERR "\npick os/compiler from:\n";
2159 1.1 christos my $j=0;
2160 1.1 christos my $i;
2161 1.1 christos my $k=0;
2162 1.1 christos foreach $i (sort keys %table)
2163 1.1 christos {
2164 1.1 christos next if $i =~ /^debug/;
2165 1.1 christos $k += length($i) + 1;
2166 1.1 christos if ($k > 78)
2167 1.1 christos {
2168 1.1 christos print STDERR "\n";
2169 1.1 christos $k=length($i);
2170 1.1 christos }
2171 1.1 christos print STDERR $i . " ";
2172 1.1 christos }
2173 1.1 christos foreach $i (sort keys %table)
2174 1.1 christos {
2175 1.1 christos next if $i !~ /^debug/;
2176 1.1 christos $k += length($i) + 1;
2177 1.1 christos if ($k > 78)
2178 1.1 christos {
2179 1.1 christos print STDERR "\n";
2180 1.1 christos $k=length($i);
2181 1.1 christos }
2182 1.1 christos print STDERR $i . " ";
2183 1.1 christos }
2184 1.1 christos print STDERR "\n\nNOTE: If in doubt, on Unix-ish systems use './config'.\n";
2185 1.1 christos exit(1);
2186 1.1 christos }
2187 1.1 christos
2188 1.1 christos sub which
2189 1.1 christos {
2190 1.1 christos my($name)=@_;
2191 1.1 christos my $path;
2192 1.1 christos foreach $path (split /:/, $ENV{PATH})
2193 1.1 christos {
2194 1.1 christos if (-f "$path/$name$exe_ext" and -x _)
2195 1.1 christos {
2196 1.1 christos return "$path/$name$exe_ext" unless ($name eq "perl" and
2197 1.1 christos system("$path/$name$exe_ext -e " . '\'exit($]<5.0);\''));
2198 1.1 christos }
2199 1.1 christos }
2200 1.1 christos }
2201 1.1 christos
2202 1.1 christos sub dofile
2203 1.1 christos {
2204 1.1 christos my $f; my $p; my %m; my @a; my $k; my $ff;
2205 1.1 christos ($f,$p,%m)=@_;
2206 1.1 christos
2207 1.1 christos open(IN,"<$f.in") || open(IN,"<$f") || die "unable to open $f:$!\n";
2208 1.1 christos @a=<IN>;
2209 1.1 christos close(IN);
2210 1.1 christos foreach $k (keys %m)
2211 1.1 christos {
2212 1.1 christos grep(/$k/ && ($_=sprintf($m{$k}."\n",$p)),@a);
2213 1.1 christos }
2214 1.1 christos open(OUT,">$f.new") || die "unable to open $f.new:$!\n";
2215 1.1 christos print OUT @a;
2216 1.1 christos close(OUT);
2217 1.1 christos rename($f,"$f.bak") || die "unable to rename $f\n" if -e $f;
2218 1.1 christos rename("$f.new",$f) || die "unable to rename $f.new\n";
2219 1.1 christos }
2220 1.1 christos
2221 1.1 christos sub print_table_entry
2222 1.1 christos {
2223 1.1 christos my $target = shift;
2224 1.1 christos
2225 1.16 spz my ($cc, $cflags, $unistd, $thread_cflag, $sys_id, $lflags,
2226 1.16 spz $bn_ops, $cpuid_obj, $bn_obj, $ec_obj, $des_obj, $aes_obj, $bf_obj,
2227 1.16 spz $md5_obj, $sha1_obj, $cast_obj, $rc4_obj, $rmd160_obj,
2228 1.16 spz $rc5_obj, $wp_obj, $cmll_obj, $modes_obj, $engines_obj,
2229 1.16 spz $perlasm_scheme, $dso_scheme, $shared_target, $shared_cflag,
2230 1.16 spz $shared_ldflag, $shared_extension, $ranlib, $arflags, $multilib)=
2231 1.1 christos split(/\s*:\s*/,$table{$target} . ":" x 30 , -1);
2232 1.1 christos
2233 1.1 christos print <<EOF
2234 1.1 christos
2235 1.1 christos *** $target
2236 1.1 christos \$cc = $cc
2237 1.1 christos \$cflags = $cflags
2238 1.1 christos \$unistd = $unistd
2239 1.1 christos \$thread_cflag = $thread_cflag
2240 1.1 christos \$sys_id = $sys_id
2241 1.1 christos \$lflags = $lflags
2242 1.1 christos \$bn_ops = $bn_ops
2243 1.1 christos \$cpuid_obj = $cpuid_obj
2244 1.1 christos \$bn_obj = $bn_obj
2245 1.16 spz \$ec_obj = $ec_obj
2246 1.1 christos \$des_obj = $des_obj
2247 1.1 christos \$aes_obj = $aes_obj
2248 1.1 christos \$bf_obj = $bf_obj
2249 1.1 christos \$md5_obj = $md5_obj
2250 1.1 christos \$sha1_obj = $sha1_obj
2251 1.1 christos \$cast_obj = $cast_obj
2252 1.1 christos \$rc4_obj = $rc4_obj
2253 1.1 christos \$rmd160_obj = $rmd160_obj
2254 1.1 christos \$rc5_obj = $rc5_obj
2255 1.1 christos \$wp_obj = $wp_obj
2256 1.1 christos \$cmll_obj = $cmll_obj
2257 1.3 christos \$modes_obj = $modes_obj
2258 1.3 christos \$engines_obj = $engines_obj
2259 1.1 christos \$perlasm_scheme = $perlasm_scheme
2260 1.1 christos \$dso_scheme = $dso_scheme
2261 1.1 christos \$shared_target= $shared_target
2262 1.1 christos \$shared_cflag = $shared_cflag
2263 1.1 christos \$shared_ldflag = $shared_ldflag
2264 1.1 christos \$shared_extension = $shared_extension
2265 1.1 christos \$ranlib = $ranlib
2266 1.1 christos \$arflags = $arflags
2267 1.1 christos \$multilib = $multilib
2268 1.1 christos EOF
2269 1.1 christos }
2270 1.1 christos
2271 1.1 christos sub test_sanity
2272 1.1 christos {
2273 1.1 christos my $errorcnt = 0;
2274 1.1 christos
2275 1.1 christos print STDERR "=" x 70, "\n";
2276 1.1 christos print STDERR "=== SANITY TESTING!\n";
2277 1.1 christos print STDERR "=== No configuration will be done, all other arguments will be ignored!\n";
2278 1.1 christos print STDERR "=" x 70, "\n";
2279 1.1 christos
2280 1.1 christos foreach $target (sort keys %table)
2281 1.1 christos {
2282 1.1 christos @fields = split(/\s*:\s*/,$table{$target} . ":" x 30 , -1);
2283 1.1 christos
2284 1.1 christos if ($fields[$idx_dso_scheme-1] =~ /^(beos|dl|dlfcn|win32|vms)$/)
2285 1.1 christos {
2286 1.1 christos $errorcnt++;
2287 1.1 christos print STDERR "SANITY ERROR: '$target' has the dso_scheme [$idx_dso_scheme] values\n";
2288 1.1 christos print STDERR " in the previous field\n";
2289 1.1 christos }
2290 1.1 christos elsif ($fields[$idx_dso_scheme+1] =~ /^(beos|dl|dlfcn|win32|vms)$/)
2291 1.1 christos {
2292 1.1 christos $errorcnt++;
2293 1.1 christos print STDERR "SANITY ERROR: '$target' has the dso_scheme [$idx_dso_scheme] values\n";
2294 1.1 christos print STDERR " in the following field\n";
2295 1.1 christos }
2296 1.1 christos elsif ($fields[$idx_dso_scheme] !~ /^(beos|dl|dlfcn|win32|vms|)$/)
2297 1.1 christos {
2298 1.1 christos $errorcnt++;
2299 1.1 christos print STDERR "SANITY ERROR: '$target' has the dso_scheme [$idx_dso_scheme] field = ",$fields[$idx_dso_scheme],"\n";
2300 1.1 christos print STDERR " valid values are 'beos', 'dl', 'dlfcn', 'win32' and 'vms'\n";
2301 1.1 christos }
2302 1.1 christos }
2303 1.1 christos print STDERR "No sanity errors detected!\n" if $errorcnt == 0;
2304 1.1 christos return $errorcnt;
2305 1.1 christos }
2306 1.17 spz
2307 1.17 spz sub file_newer
2308 1.17 spz {
2309 1.17 spz my ($file1, $file2) = @_;
2310 1.17 spz return (stat($file1))[9] > (stat($file2))[9]
2311 1.17 spz }
2312