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