blob: 4e0e34298c76d4c413e5cd278f6e19b0f4d6e5e8 [file] [log] [blame]
Richard Levittede17db92015-11-24 14:06:45 +01001#! /usr/bin/env perl
Jacob Bandes-Storchf4d8f032015-11-23 21:44:58 -08002# -*- mode: perl; -*-
Richard Levittede17db92015-11-24 14:06:45 +01003
Ralf S. Engelschalla4ed5531999-02-25 08:48:52 +00004## Configure -- OpenSSL source tree configuration script
Ben Laurie1641cb61998-12-28 17:08:48 +00005
Richard Levitte9f519ad2016-03-14 10:03:14 +01006require 5.10.0;
Ben Laurie1641cb61998-12-28 17:08:48 +00007use strict;
Rich Salzf09e7ca2015-02-24 17:40:22 -05008use File::Basename;
Richard Levitte85152ca2016-02-02 19:47:05 +01009use File::Spec::Functions qw/:DEFAULT abs2rel rel2abs/;
Richard Levittedca99382016-02-08 16:27:15 +010010use File::Path qw/mkpath/;
Ben Laurie1641cb61998-12-28 17:08:48 +000011
Ulf Möller22a4f961999-04-19 13:54:11 +000012# see INSTALL for instructions.
Ulf Möller462ba4f1999-04-24 22:59:36 +000013
Rich Salze4ef2e22016-02-10 11:10:39 -050014my $usage="Usage: Configure [no-<cipher> ...] [enable-<cipher> ...] [-Dxxx] [-lxxx] [-Lxxx] [-fxxx] [-Kxxx] [no-hw-xxx|no-hw] [[no-]threads] [[no-]shared] [[no-]zlib|zlib-dynamic] [no-asm] [no-dso] [no-egd] [sctp] [386] [--prefix=DIR] [--openssldir=OPENSSLDIR] [--with-xxx[=vvv]] [--config=FILE] os/compiler[:flags]\n";
Ulf Möller462ba4f1999-04-24 22:59:36 +000015
Ulf Möller434c5dd1999-04-19 15:19:58 +000016# Options:
Bodo Möllere5f30451999-04-29 21:52:08 +000017#
Rich Salzf09e7ca2015-02-24 17:40:22 -050018# --config add the given configuration file, which will be read after
19# any "Configurations*" files that are found in the same
20# directory as this script.
Richard Levitted74dfaf2016-01-20 18:11:51 +010021# --prefix prefix for the OpenSSL installation, which includes the
22# directories bin, lib, include, share/man, share/doc/openssl
23# This becomes the value of INSTALLTOP in Makefile
24# (Default: /usr/local)
25# --openssldir OpenSSL data area, such as openssl.cnf, certificates and keys.
26# If it's a relative directory, it will be added on the directory
27# given with --prefix.
28# This becomes the value of OPENSSLDIR in Makefile and in C.
29# (Default: PREFIX/ssl)
Bodo Möllere5f30451999-04-29 21:52:08 +000030#
Andy Polyakovcbfb39d2006-10-21 13:38:16 +000031# --cross-compile-prefix Add specified prefix to binutils components.
32#
Viktor Dukhovni98186eb2016-01-04 23:00:33 -050033# --api One of 0.9.8, 1.0.0 or 1.1.0. Do not compile support for
34# interfaces deprecated as of the specified OpenSSL version.
35#
Richard Levitte5270e702000-10-26 21:07:28 +000036# no-hw-xxx do not compile support for specific crypto hardware.
37# Generic OpenSSL-style methods relating to this support
38# are always compiled but return NULL if the hardware
39# support isn't compiled.
40# no-hw do not compile support for any crypto hardware.
Bodo Möller5f8d5c91999-04-29 16:10:09 +000041# [no-]threads [don't] try to create a library that is suitable for
42# multithreaded applications (default is "threads" if we
43# know how to do it)
Richard Levittefcc6a1c2000-08-02 04:19:50 +000044# [no-]shared [don't] try to create shared libraries when supported.
Richard Levitteae482422016-02-22 02:09:11 +010045# [no-]pic [don't] try to build position independent code when supported.
Richard Levitte45b71ab2016-02-22 15:57:25 +010046# If disabled, it also disables shared and dynamic-engine.
Ulf Möllera7239791999-04-19 14:55:56 +000047# no-asm do not use assembler
Geoff Thorpebc2aada2000-04-06 07:09:45 +000048# no-dso do not compile in any native shared-library methods. This
49# will ensure that all methods just return NULL.
Benjamin Kaduk0423f812016-01-12 18:02:16 -060050# no-egd do not compile support for the entropy-gathering daemon APIs
Richard Levittee452de92001-07-12 09:11:14 +000051# [no-]zlib [don't] compile support for zlib compression.
52# zlib-dynamic Like "zlib", but the zlib library is expected to be a shared
53# library and will be loaded in run-time by the OpenSSL library.
Dr. Stephen Henson7e159e02011-12-25 14:45:15 +000054# sctp include SCTP support
Ulf Möller22a4f961999-04-19 13:54:11 +000055# 386 generate 80386 code
Matt Caswell8b1a5af2016-03-03 15:40:51 +000056# enable-weak-ssl-ciphers
57# Enable weak ciphers that are disabled by default. This currently
58# only includes RC4 based ciphers.
Andy Polyakovd0590fe2004-07-18 16:19:34 +000059# no-sse2 disables IA-32 SSE2 code, above option implies no-sse2
Ulf Möller79df9d61999-04-27 03:19:12 +000060# no-<cipher> build without specified algorithm (rsa, idea, rc5, ...)
Felix Laurie von Massenbachfce0ba52014-05-26 17:19:28 +010061# -<xxx> +<xxx> compiler options are passed through
Geoff Thorpee41c8d62000-06-01 05:13:52 +000062#
63# DEBUG_SAFESTACK use type-safe stacks to enforce type-safety on stack items
64# provided to stack calls. Generates unique stack functions for
65# each possible stack type.
Ralf S. Engelschalld02b48c1998-12-21 10:52:47 +000066# BN_LLONG use the type 'long long' in crypto/bn/bn.h
Ralf S. Engelschalld02b48c1998-12-21 10:52:47 +000067# RC4_CHAR use 'char' instead of 'int' for RC4_INT in crypto/rc4/rc4.h
Andy Polyakovd0590fe2004-07-18 16:19:34 +000068# Following are set automatically by this script
69#
Rich Salze771eea2016-04-04 16:11:43 -040070# MD5_ASM use some extra md5 assember,
71# SHA1_ASM use some extra sha1 assember, must define L_ENDIAN for x86
72# RMD160_ASM use some extra ripemd160 assember,
Andy Polyakovd0590fe2004-07-18 16:19:34 +000073# SHA256_ASM sha256_block is implemented in assembler
74# SHA512_ASM sha512_block is implemented in assembler
75# AES_ASM ASE_[en|de]crypt is implemented in assembler
Ralf S. Engelschalld02b48c1998-12-21 10:52:47 +000076
Dr. Stephen Henson363bd0b2009-01-11 15:56:32 +000077# Minimum warning options... any contributions to OpenSSL should at least get
Felix Laurie von Massenbachfce0ba52014-05-26 17:19:28 +010078# past these.
Dr. Stephen Henson363bd0b2009-01-11 15:56:32 +000079
Andy Polyakov463a7b82016-04-06 12:47:35 +020080# DEBUG_UNUSED enables __owur (warn unused result) checks.
81my $gcc_devteam_warn = "-DDEBUG_UNUSED"
82 # -DPEDANTIC complements -pedantic and is meant to mask code that
83 # is not strictly standard-compliant and/or implementation-specifc,
84 # e.g. inline assembly, disregards to alignment requirements, such
85 # that -pedantic would complain about. Incidentally -DPEDANTIC has
86 # to be used even in sanitized builds, because sanitizer too is
87 # supposed to and does take notice of non-standard behaviour. Then
88 # -pedantic with pre-C9x compiler would also complain about 'long
89 # long' not being supported. As 64-bit algorithms are common now,
90 # it grew impossible to resolve this without sizeable additional
91 # code, so we just tell compiler to be pedantic about everything
92 # but 'long long' type.
93 . " -DPEDANTIC -pedantic -Wno-long-long"
Rich Salz8bccbce2016-02-13 12:27:11 -050094 . " -Wall"
Rich Salz8bccbce2016-02-13 12:27:11 -050095 . " -Wsign-compare"
96 . " -Wmissing-prototypes"
97 . " -Wshadow"
98 . " -Wformat"
99 . " -Wtype-limits"
100 . " -Werror"
101 ;
Dr. Stephen Henson363bd0b2009-01-11 15:56:32 +0000102
Ben Laurie190c8c62015-04-19 14:10:54 +0100103# These are used in addition to $gcc_devteam_warn when the compiler is clang.
104# TODO(openssl-team): fix problems and investigate if (at least) the
Ben Laurie480405e2015-08-02 02:45:44 +0100105# following warnings can also be enabled:
Rich Salz8bccbce2016-02-13 12:27:11 -0500106# -Wswitch-enum
Rich Salz8bccbce2016-02-13 12:27:11 -0500107# -Wcast-align
108# -Wunreachable-code
Rich Salza773b522016-02-13 22:33:56 -0500109# -Wlanguage-extension-token -- no, we use asm()
110# -Wunused-macros -- no, too tricky for BN and _XOPEN_SOURCE etc
111# -Wextended-offsetof -- no, needed in CMS ASN1 code
Rich Salz8bccbce2016-02-13 12:27:11 -0500112my $clang_devteam_warn = ""
113 . " -Qunused-arguments"
114 . " -Wextra"
115 . " -Wno-unused-parameter"
116 . " -Wno-missing-field-initializers"
117 . " -Wno-language-extension-token"
118 . " -Wno-extended-offsetof"
119 . " -Wconditional-uninitialized"
120 . " -Wincompatible-pointer-types-discards-qualifiers"
121 . " -Wmissing-variable-declarations"
122 ;
Emilia Kaspercb2bc052015-01-05 13:46:26 +0100123
Richard Levitteef8ca6b2016-02-14 12:16:52 +0100124# This adds backtrace information to the memory leak info. Is only used
125# when crypto-mdebug-backtrace is enabled.
126my $memleak_devteam_backtrace = "-rdynamic";
Richard Levittea1d3f3d2015-12-02 18:44:26 +0100127
Dr. Stephen Henson0c28f272009-09-09 16:31:32 +0000128my $strict_warnings = 0;
129
Andy Polyakovb7efa562005-01-24 14:38:14 +0000130# As for $BSDthreads. Idea is to maintain "collective" set of flags,
Felix Laurie von Massenbachfce0ba52014-05-26 17:19:28 +0100131# which would cover all BSD flavors. -pthread applies to them all,
Andy Polyakovb7efa562005-01-24 14:38:14 +0000132# but is treated differently. OpenBSD expands is as -D_POSIX_THREAD
133# -lc_r, which is sufficient. FreeBSD 4.x expands it as -lc_r,
134# which has to be accompanied by explicit -D_THREAD_SAFE and
135# sometimes -D_REENTRANT. FreeBSD 5.x expands it as -lc_r, which
136# seems to be sufficient?
Richard Levitte9c62a272016-02-27 16:51:34 +0100137our $BSDthreads="-pthread -D_THREAD_SAFE -D_REENTRANT";
Ralf S. Engelschalld02b48c1998-12-21 10:52:47 +0000138
Viktor Dukhovni98186eb2016-01-04 23:00:33 -0500139#
140# API compability name to version number mapping.
141#
142my $maxapi = "1.1.0"; # API for "no-deprecated" builds
143my $apitable = {
144 "1.1.0" => "0x10100000L",
145 "1.0.0" => "0x10000000L",
146 "0.9.8" => "0x00908000L",
147};
148
Richard Levitte9e0724a2015-05-18 02:54:28 +0200149our %table = ();
Richard Levitte291e94d2015-05-18 22:35:23 +0200150our %config = ();
Richard Levitte98fdbce2016-02-27 11:37:33 +0100151our %withargs = ();
Ralf S. Engelschalld02b48c1998-12-21 10:52:47 +0000152
Richard Levittebd5192b2015-05-18 02:57:24 +0200153# Forward declarations ###############################################
Andy Polyakov7ead0c82015-03-16 22:33:36 +0100154
Richard Levittebd5192b2015-05-18 02:57:24 +0200155# read_config(filename)
156#
157# Reads a configuration file and populates %table with the contents
158# (which the configuration file places in %targets).
159sub read_config;
Andy Polyakov7ead0c82015-03-16 22:33:36 +0100160
Richard Levittebd5192b2015-05-18 02:57:24 +0200161# resolve_config(target)
162#
Rich Salze771eea2016-04-04 16:11:43 -0400163# Resolves all the late evalutations, inheritances and so on for the
Richard Levittebd5192b2015-05-18 02:57:24 +0200164# chosen target and any target it inherits from.
165sub resolve_config;
Richard Levitteaaf878c2015-03-06 02:00:21 +0100166
Rich Salzf09e7ca2015-02-24 17:40:22 -0500167
Richard Levitte107b5792015-05-20 20:03:20 +0200168# Information collection #############################################
169
Richard Levitte9fe2bb72016-01-29 19:45:51 +0100170# Unified build supports separate build dir
Richard Levitteec182ef2016-02-09 10:15:13 +0100171my $srcdir = catdir(absolutedir(dirname($0))); # catdir ensures local syntax
172my $blddir = catdir(absolutedir(".")); # catdir ensures local syntax
Richard Levitte9fe2bb72016-01-29 19:45:51 +0100173my $dofile = abs2rel(catfile($srcdir, "util/dofile.pl"));
174
175$config{sourcedir} = abs2rel($srcdir);
176$config{builddir} = abs2rel($blddir);
177
Richard Levitte107b5792015-05-20 20:03:20 +0200178# Collect version numbers
179$config{version} = "unknown";
180$config{version_num} = "unknown";
181$config{shlib_version_number} = "unknown";
182$config{shlib_version_history} = "unknown";
183
184collect_information(
Richard Levitte9fe2bb72016-01-29 19:45:51 +0100185 collect_from_file(catfile($srcdir,'include/openssl/opensslv.h')),
Richard Levitte107b5792015-05-20 20:03:20 +0200186 qr/OPENSSL.VERSION.TEXT.*OpenSSL (\S+) / => sub { $config{version} = $1; },
187 qr/OPENSSL.VERSION.NUMBER.*(0x\S+)/ => sub { $config{version_num}=$1 },
188 qr/SHLIB_VERSION_NUMBER *"([^"]+)"/ => sub { $config{shlib_version_number}=$1 },
189 qr/SHLIB_VERSION_HISTORY *"([^"]*)"/ => sub { $config{shlib_version_history}=$1 }
190 );
191if ($config{shlib_version_history} ne "") { $config{shlib_version_history} .= ":"; }
192
193($config{major}, $config{minor})
194 = ($config{version} =~ /^([0-9]+)\.([0-9\.]+)/);
195($config{shlib_major}, $config{shlib_minor})
196 = ($config{shlib_version_number} =~ /^([0-9]+)\.([0-9\.]+)/);
197die "erroneous version information in opensslv.h: ",
198 "$config{major}, $config{minor}, $config{shlib_major}, $config{shlib_minor}\n"
199 if ($config{major} eq "" || $config{minor} eq ""
200 || $config{shlib_major} eq "" || $config{shlib_minor} eq "");
201
202# Collect target configurations
203
Richard Levitte85152ca2016-02-02 19:47:05 +0100204my $pattern = catfile(dirname($0), "Configurations", "*.conf");
Richard Levitte97a0cc52015-03-11 10:22:50 +0100205foreach (sort glob($pattern) ) {
Rich Salzf09e7ca2015-02-24 17:40:22 -0500206 &read_config($_);
207}
208
Richard Levitte291e94d2015-05-18 22:35:23 +0200209
Richard Levitte107b5792015-05-20 20:03:20 +0200210print "Configuring OpenSSL version $config{version} (0x$config{version_num})\n";
211
Richard Levitte291e94d2015-05-18 22:35:23 +0200212$config{prefix}="";
213$config{openssldir}="";
Richard Levitte7d130f62015-05-19 01:40:54 +0200214$config{processor}="";
Richard Levitte107b5792015-05-20 20:03:20 +0200215$config{libdir}="";
Richard Levitte642a6132015-12-27 02:27:30 +0100216$config{cross_compile_prefix}="";
Richard Levitte107b5792015-05-20 20:03:20 +0200217$config{fipslibdir}="/usr/local/ssl/fips-2.0/lib/";
Dr. Stephen Henson1ab2f7f2011-01-26 12:31:30 +0000218my $nofipscanistercheck=0;
Richard Levitte107b5792015-05-20 20:03:20 +0200219$config{baseaddr}="0xFB00000";
Richard Levitte9c62a272016-02-27 16:51:34 +0100220my $auto_threads=1; # enable threads automatically? true by default
Bodo Möller03964792001-03-09 13:04:06 +0000221my $default_ranlib;
Richard Levitte107b5792015-05-20 20:03:20 +0200222$config{fips}=0;
223
224# Top level directories to build
225$config{dirs} = [ "crypto", "ssl", "engines", "apps", "test", "tools" ];
226# crypto/ subdirectories to build
227$config{sdirs} = [
228 "objects",
Bill Cox2d0b4412016-03-09 23:08:31 +0100229 "md2", "md4", "md5", "sha", "mdc2", "hmac", "ripemd", "whrlpool", "poly1305", "blake2",
Richard Levitte107b5792015-05-20 20:03:20 +0200230 "des", "aes", "rc2", "rc4", "rc5", "idea", "bf", "cast", "camellia", "seed", "chacha", "modes",
231 "bn", "ec", "rsa", "dsa", "dh", "dso", "engine",
232 "buffer", "bio", "stack", "lhash", "rand", "err",
233 "evp", "asn1", "pem", "x509", "x509v3", "conf", "txt_db", "pkcs7", "pkcs12", "comp", "ocsp", "ui",
Rich Salzdba31772016-02-14 00:17:59 -0500234 "cms", "ts", "srp", "cmac", "ct", "async", "kdf"
Richard Levitte107b5792015-05-20 20:03:20 +0200235 ];
Ulf Möller99aab161999-04-01 12:34:33 +0000236
Viktor Dukhovni6b01bed2016-01-18 13:10:21 -0500237# Known TLS and DTLS protocols
238my @tls = qw(ssl3 tls1 tls1_1 tls1_2);
239my @dtls = qw(dtls1 dtls1_2);
240
Rich Salze771eea2016-04-04 16:11:43 -0400241# Explicitelly known options that are possible to disable. They can
Richard Levitte8b527be2015-10-22 17:09:14 +0200242# be regexps, and will be used like this: /^no-${option}$/
243# For developers: keep it sorted alphabetically
244
245my @disablables = (
246 "aes",
Emilia Kasperc91a0a82016-03-14 12:21:44 +0100247 "afalgeng",
Richard Levitte8b527be2015-10-22 17:09:14 +0200248 "asm",
Todd Short52739e42016-02-04 11:41:25 -0500249 "async",
Matt Caswellb184e3e2016-02-09 11:26:14 +0000250 "autoalginit",
Matt Caswell498abff2016-02-09 09:39:07 +0000251 "autoerrinit",
Richard Levitte8b527be2015-10-22 17:09:14 +0200252 "bf",
Bill Cox2d0b4412016-03-09 23:08:31 +0100253 "blake2",
Richard Levitte8b527be2015-10-22 17:09:14 +0200254 "camellia",
255 "capieng",
256 "cast",
Andy Polyakov48f14842015-12-09 23:02:11 +0100257 "chacha",
Richard Levitte8b527be2015-10-22 17:09:14 +0200258 "cmac",
259 "cms",
260 "comp",
Mat3e45d392016-01-09 23:55:57 +0100261 "crypto-mdebug",
Richard Levitteef8ca6b2016-02-14 12:16:52 +0100262 "crypto-mdebug-backtrace",
Richard Levitte8b527be2015-10-22 17:09:14 +0200263 "ct",
264 "deprecated",
265 "des",
266 "dgram",
267 "dh",
268 "dsa",
269 "dso",
Kurt Roeckxa5ecdc62015-12-12 11:12:22 +0100270 "dtls",
Richard Levitte343ec2b2016-02-19 22:08:37 +0100271 "dynamic-engine",
Richard Levitte8b527be2015-10-22 17:09:14 +0200272 "ec",
273 "ec2m",
Viktor Dukhovni6b01bed2016-01-18 13:10:21 -0500274 "ecdh",
275 "ecdsa",
Richard Levitte8b527be2015-10-22 17:09:14 +0200276 "ec_nistp_64_gcc_128",
Richard Levitteb31feae2016-02-03 21:08:17 +0100277 "egd",
Richard Levitte8b527be2015-10-22 17:09:14 +0200278 "engine",
Rich Salz1288f262016-02-17 13:33:51 -0500279 "err",
David Woodhouse02f71142015-07-30 11:45:25 +0100280 "filenames",
Matt Caswell168c3b72016-03-21 15:04:08 +0000281 "gost",
Richard Levitte8b527be2015-10-22 17:09:14 +0200282 "heartbeats",
283 "hmac",
284 "hw(-.+)?",
285 "idea",
Richard Levitte09aa2632016-03-09 01:14:29 +0100286 "makedepend",
Richard Levitte8b527be2015-10-22 17:09:14 +0200287 "md2",
288 "md4",
289 "md5",
290 "mdc2",
Matt Caswellfa22f982016-03-07 23:26:32 +0000291 "multiblock",
Richard Levitte8b527be2015-10-22 17:09:14 +0200292 "nextprotoneg",
293 "ocb",
294 "ocsp",
Richard Levitteae482422016-02-22 02:09:11 +0100295 "pic",
Andy Polyakov48f14842015-12-09 23:02:11 +0100296 "poly1305",
Richard Levitte8b527be2015-10-22 17:09:14 +0200297 "posix-io",
298 "psk",
299 "rc2",
300 "rc4",
301 "rc5",
302 "rdrand",
303 "rfc3779",
Rich Salz1288f262016-02-17 13:33:51 -0500304 "ripemd",
Richard Levitte8b527be2015-10-22 17:09:14 +0200305 "rmd160",
306 "rsa",
307 "scrypt",
308 "sct",
309 "sctp",
310 "seed",
311 "sha",
312 "shared",
313 "sock",
314 "srp",
315 "srtp",
316 "sse2",
317 "ssl",
Richard Levitte8b527be2015-10-22 17:09:14 +0200318 "ssl-trace",
319 "static-engine",
320 "stdio",
Richard Levitte8b527be2015-10-22 17:09:14 +0200321 "threads",
322 "tls",
Rich Salz1288f262016-02-17 13:33:51 -0500323 "ts",
324 "ui",
Richard Levitte8b527be2015-10-22 17:09:14 +0200325 "unit-test",
326 "whirlpool",
Matt Caswell8b1a5af2016-03-03 15:40:51 +0000327 "weak-ssl-ciphers",
Richard Levitte8b527be2015-10-22 17:09:14 +0200328 "zlib",
329 "zlib-dynamic",
330 );
Viktor Dukhovni6b01bed2016-01-18 13:10:21 -0500331foreach my $proto ((@tls, @dtls))
332 {
333 push(@disablables, $proto);
334 push(@disablables, "$proto-method");
335 }
Richard Levitte8b527be2015-10-22 17:09:14 +0200336
Richard Levittee80381e2016-02-22 10:42:53 +0100337my @deprecated_disablables = (
338 "ssl2",
339 );
340
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000341# All of the following is disabled by default (RC5 was enabled before 0.9.8):
342
Richard Levitte9e04edf2016-02-22 13:45:46 +0100343our %disabled = ( # "what" => "comment"
344 "ec_nistp_64_gcc_128" => "default",
Matt Caswell8b1a5af2016-03-03 15:40:51 +0000345 "egd" => "default",
346 "md2" => "default",
347 "rc5" => "default",
348 "sctp" => "default",
349 "shared" => "default",
350 "ssl-trace" => "default",
Kurt Roeckx9829b5a2016-03-03 22:45:57 +0100351 "ssl3" => "default",
352 "ssl3-method" => "default",
Matt Caswell8b1a5af2016-03-03 15:40:51 +0000353 "unit-test" => "default",
354 "weak-ssl-ciphers" => "default",
355 "zlib" => "default",
356 "zlib-dynamic" => "default",
357 "crypto-mdebug" => "default",
358 "heartbeats" => "default",
Richard Levitte9e04edf2016-02-22 13:45:46 +0100359 );
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000360
Richard Levittec569e202015-05-18 11:03:47 +0200361# Note: => pair form used for aesthetics, not to truly make a hash table
362my @disable_cascades = (
363 # "what" => [ "cascade", ... ]
Richard Levitte7d130f62015-05-19 01:40:54 +0200364 sub { $config{processor} eq "386" }
Richard Levittec569e202015-05-18 11:03:47 +0200365 => [ "sse2" ],
366 "ssl" => [ "ssl3" ],
367 "ssl3-method" => [ "ssl3" ],
368 "zlib" => [ "zlib-dynamic" ],
Richard Levittec569e202015-05-18 11:03:47 +0200369 "des" => [ "mdc2" ],
Richard Levitte9e4d6fb2016-01-23 22:58:51 +0100370 "ec" => [ "ecdsa", "ecdh" ],
Richard Levittec569e202015-05-18 11:03:47 +0200371
Ben Laurie3fd4d212016-03-17 18:17:03 +0000372 "dgram" => [ "dtls", "sctp" ],
Ben Laurie686c86a2016-03-27 12:28:23 +0100373 "sock" => [ "sctp" ],
Richard Levittec569e202015-05-18 11:03:47 +0200374 "dtls" => [ @dtls ],
375
376 # SSL 3.0, (D)TLS 1.0 and TLS 1.1 require MD5 and SHA
377 "md5" => [ "ssl", "tls1", "tls1_1", "dtls1" ],
378 "sha" => [ "ssl", "tls1", "tls1_1", "dtls1" ],
379
380 # Additionally, SSL 3.0 requires either RSA or DSA+DH
381 sub { $disabled{rsa}
382 && ($disabled{dsa} || $disabled{dh}); }
383 => [ "ssl" ],
384
385 # (D)TLS 1.0 and TLS 1.1 also require either RSA or DSA+DH
386 # or ECDSA + ECDH. (D)TLS 1.2 has this requirement as well.
387 # (XXX: We don't support PSK-only builds).
388 sub { $disabled{rsa}
389 && ($disabled{dsa} || $disabled{dh})
390 && ($disabled{ecdsa} || $disabled{ecdh}); }
391 => [ "tls1", "tls1_1", "tls1_2",
392 "dtls1", "dtls1_2" ],
393
394 "tls" => [ @tls ],
395
396 # SRP and HEARTBEATS require TLSEXT
397 "tlsext" => [ "srp", "heartbeats" ],
Richard Levitteef8ca6b2016-02-14 12:16:52 +0100398
399 "crypto-mdebug" => [ "crypto-mdebug-backtrace" ],
Richard Levitte343ec2b2016-02-19 22:08:37 +0100400
401 # Without DSO, we can't load dynamic engines, so don't build them dynamic
402 "dso" => [ "dynamic-engine" ],
Richard Levitteae482422016-02-22 02:09:11 +0100403
404 # Without position independent code, there can be no shared libraries or DSOs
Richard Levitte00698062016-03-11 12:58:15 +0100405 "pic" => [ "shared" ],
406 "shared" => [ "dynamic-engine" ],
Emilia Kasperc91a0a82016-03-14 12:21:44 +0100407 "engine" => [ "afalgeng" ],
Ben Laurieb8ce6dd2016-03-22 10:40:13 +0000408 "comp" => [ "zlib" ],
Ben Laurie686c86a2016-03-27 12:28:23 +0100409 sub { !$disabled{"unit-test"} } => [ "heartbeats" ],
Richard Levittec569e202015-05-18 11:03:47 +0200410 );
411
412# Avoid protocol support holes. Also disable all versions below N, if version
413# N is disabled while N+1 is enabled.
414#
415my @list = (reverse @tls);
416while ((my $first, my $second) = (shift @list, shift @list)) {
417 last unless @list;
418 push @disable_cascades, ( sub { !$disabled{$first} && $disabled{$second} }
419 => [ @list ] );
420 unshift @list, $second;
421}
422my @list = (reverse @dtls);
423while ((my $first, my $second) = (shift @list, shift @list)) {
424 last unless @list;
425 push @disable_cascades, ( sub { !$disabled{$first} && $disabled{$second} }
426 => [ @list ] );
427 unshift @list, $second;
428}
429
Bodo Möller7a762192008-12-02 01:21:39 +0000430# Explicit "no-..." options will be collected in %disabled along with the defaults.
Rich Salze4ef2e22016-02-10 11:10:39 -0500431# To remove something from %disabled, use "enable-foo".
Bodo Möller7a762192008-12-02 01:21:39 +0000432# For symmetry, "disable-foo" is a synonym for "no-foo".
433
Richard Levittee737d7b2016-02-11 15:22:27 +0100434my @generated_headers = (
435 "include/openssl/opensslconf.h",
Richard Levittee987f9f2016-02-15 17:20:15 +0100436 "crypto/include/internal/bn_conf.h",
437 "crypto/include/internal/dso_conf.h"
Richard Levittee737d7b2016-02-11 15:22:27 +0100438 );
439
440my @generated_by_make_headers = (
441 "crypto/buildinf.h"
442 );
443
Bodo Möllerab185b62005-03-13 19:46:58 +0000444
Andy Polyakovd0590fe2004-07-18 16:19:34 +0000445my $no_sse2=0;
Richard Levitteb6e4dac2001-11-27 11:48:30 +0000446
Ulf Möller462ba4f1999-04-24 22:59:36 +0000447&usage if ($#ARGV < 0);
Ralf S. Engelschalld02b48c1998-12-21 10:52:47 +0000448
Richard Levittebcb19772016-01-30 02:17:05 +0100449my $user_cflags="";
450my @user_defines=();
Richard Levitte7d130f62015-05-19 01:40:54 +0200451$config{openssl_api_defines}=[];
452$config{openssl_algorithm_defines}=[];
453$config{openssl_thread_defines}=[];
454$config{openssl_sys_defines}=[];
455$config{openssl_other_defines}=[];
Richard Levittefe052642015-05-18 03:33:55 +0200456my $libs="";
457my $target="";
Richard Levitte3fa04f02016-01-12 00:17:12 +0100458$config{options}="";
Richard Levitte8864f0d2016-03-02 19:13:26 +0100459$config{build_type} = "release";
Richard Levittec59cb512000-08-17 10:23:45 +0000460
Richard Levittedc3365f2016-03-07 20:41:39 +0100461my $classic = 0;
462
Richard Levittec59cb512000-08-17 10:23:45 +0000463my @argvcopy=@ARGV;
Richard Levittec59cb512000-08-17 10:23:45 +0000464
Richard Levittefe052642015-05-18 03:33:55 +0200465if (grep /^reconf(igure)?$/, @argvcopy) {
Richard Levitte642a6132015-12-27 02:27:30 +0100466 if (-f "./configdata.pm") {
467 my $file = "./configdata.pm";
468 unless (my $return = do $file) {
469 die "couldn't parse $file: $@" if $@;
470 die "couldn't do $file: $!" unless defined $return;
471 die "couldn't run $file" unless $return;
Richard Levittefe052642015-05-18 03:33:55 +0200472 }
Richard Levitte642a6132015-12-27 02:27:30 +0100473
474 @argvcopy = defined($configdata::config{perlargv}) ?
475 @{$configdata::config{perlargv}} : ();
476 die "Incorrect data to reconfigure, please do a normal configuration\n"
477 if (grep(/^reconf/,@argvcopy));
478 $ENV{CROSS_COMPILE} = $configdata::config{cross_compile_prefix}
479 if defined($configdata::config{cross_compile_prefix});
480 $ENV{CROSS_COMPILE} = $configdata::config{cc}
481 if defined($configdata::config{cc});
482
Richard Levittefe052642015-05-18 03:33:55 +0200483 print "Reconfiguring with: ", join(" ",@argvcopy), "\n";
484 print " CROSS_COMPILE = ",$ENV{CROSS_COMPILE},"\n"
485 if $ENV{CROSS_COMPILE};
486 print " CC = ",$ENV{CC},"\n" if $ENV{CC};
Richard Levitte642a6132015-12-27 02:27:30 +0100487 } elsif (open IN, "<Makefile") {
488 #
489 # THIS SECTION IS TEMPORARY, it helps transitioning from Makefile
490 # centered information gathering the reading configdata.pm
491 #
492 while (<IN>) {
Richard Levitte04f171c2016-02-12 12:10:27 +0100493 s|\R$||;
Richard Levitte642a6132015-12-27 02:27:30 +0100494 if (/^CONFIGURE_ARGS=\s*(.*)\s*/) {
495 # Older form, we split the string and hope for the best
496 @argvcopy = split /\s+/, $_;
497 die "Incorrect data to reconfigure, please do a normal configuration\n"
498 if (grep(/^reconf/,@argvcopy));
499 } elsif (/^CROSS_COMPILE=\s*(.*)/) {
500 $ENV{CROSS_COMPILE}=$1;
501 } elsif (/^CC=\s*(?:\$\(CROSS_COMPILE\))?(.*?)$/) {
502 $ENV{CC}=$1;
503 }
504 }
505 #
506 # END OF TEMPORARY SECTION
507 #
Richard Levittefe052642015-05-18 03:33:55 +0200508 } else {
509 die "Insufficient data to reconfigure, please do a normal configuration\n";
510 }
511}
512
Richard Levitte642a6132015-12-27 02:27:30 +0100513$config{perlargv} = [ @argvcopy ];
Richard Levittefe052642015-05-18 03:33:55 +0200514
515my %unsupported_options = ();
Richard Levittee80381e2016-02-22 10:42:53 +0100516my %deprecated_options = ();
Richard Levittefe052642015-05-18 03:33:55 +0200517foreach (@argvcopy)
Ralf S. Engelschalld02b48c1998-12-21 10:52:47 +0000518 {
Richard Levitte7c55e222016-02-16 16:07:05 +0100519 # VMS is a case insensitive environment, and depending on settings
520 # out of our control, we may receive options uppercased. Let's
521 # downcase at least the part before any equal sign.
522 if ($^O eq "VMS")
523 {
524 s/^([^=]*)/lc($1)/e;
525 }
Richard Levittefe052642015-05-18 03:33:55 +0200526 s /^-no-/no-/; # some people just can't read the instructions
Richard Levittec59cb512000-08-17 10:23:45 +0000527
Richard Levittefe052642015-05-18 03:33:55 +0200528 # rewrite some options in "enable-..." form
529 s /^-?-?shared$/enable-shared/;
530 s /^sctp$/enable-sctp/;
531 s /^threads$/enable-threads/;
532 s /^zlib$/enable-zlib/;
533 s /^zlib-dynamic$/enable-zlib-dynamic/;
Richard Levittec59cb512000-08-17 10:23:45 +0000534
Rich Salze4ef2e22016-02-10 11:10:39 -0500535 if (/^(no|disable|enable)-(.+)$/)
Ulf Möllerf5d7a031999-04-27 01:14:46 +0000536 {
Richard Levittefe052642015-05-18 03:33:55 +0200537 my $word = $2;
Richard Levittee80381e2016-02-22 10:42:53 +0100538 if (grep { $word =~ /^${_}$/ } @deprecated_disablables)
539 {
540 $deprecated_options{$_} = 1;
541 next;
542 }
543 elsif (!grep { $word =~ /^${_}$/ } @disablables)
Richard Levitte8b527be2015-10-22 17:09:14 +0200544 {
Richard Levittefe052642015-05-18 03:33:55 +0200545 $unsupported_options{$_} = 1;
546 next;
Richard Levitte8b527be2015-10-22 17:09:14 +0200547 }
Richard Levittefe052642015-05-18 03:33:55 +0200548 }
549 if (/^no-(.+)$/ || /^disable-(.+)$/)
550 {
Rich Salze4ef2e22016-02-10 11:10:39 -0500551 foreach my $proto ((@tls, @dtls))
552 {
553 if ($1 eq "$proto-method")
554 {
555 $disabled{"$proto"} = "option($proto-method)";
556 last;
557 }
558 }
559 if ($1 eq "dtls")
560 {
561 foreach my $proto (@dtls)
562 {
563 $disabled{$proto} = "option(dtls)";
564 }
Kurt Roeckxc5c77002016-03-28 00:31:23 +0200565 $disabled{"dtls"} = "option(dtls)";
Rich Salze4ef2e22016-02-10 11:10:39 -0500566 }
567 elsif ($1 eq "ssl")
568 {
569 # Last one of its kind
570 $disabled{"ssl3"} = "option(ssl)";
571 }
572 elsif ($1 eq "tls")
573 {
574 # XXX: Tests will fail if all SSL/TLS
575 # protocols are disabled.
576 foreach my $proto (@tls)
577 {
578 $disabled{$proto} = "option(tls)";
579 }
580 }
Richard Levitte343ec2b2016-02-19 22:08:37 +0100581 elsif ($1 eq "static-engine")
582 {
Richard Levitte19ab5792016-02-22 02:06:05 +0100583 delete $disabled{"dynamic-engine"};
Richard Levitte343ec2b2016-02-19 22:08:37 +0100584 }
585 elsif ($1 eq "dynamic-engine")
586 {
Richard Levitte19ab5792016-02-22 02:06:05 +0100587 $disabled{"dynamic-engine"} = "option";
Richard Levitte343ec2b2016-02-19 22:08:37 +0100588 }
Rich Salze4ef2e22016-02-10 11:10:39 -0500589 else
590 {
591 $disabled{$1} = "option";
592 }
Richard Levitte9c62a272016-02-27 16:51:34 +0100593 # No longer an automatic choice
594 $auto_threads = 0 if ($1 eq "threads");
Bodo Möllerfbabb751999-07-09 12:00:34 +0000595 }
Rich Salze4ef2e22016-02-10 11:10:39 -0500596 elsif (/^enable-(.+)$/)
Richard Levittefe052642015-05-18 03:33:55 +0200597 {
Richard Levitte343ec2b2016-02-19 22:08:37 +0100598 if ($1 eq "static-engine")
599 {
Richard Levitte19ab5792016-02-22 02:06:05 +0100600 $disabled{"dynamic-engine"} = "option";
Richard Levitte343ec2b2016-02-19 22:08:37 +0100601 }
602 elsif ($1 eq "dynamic-engine")
603 {
Richard Levitte19ab5792016-02-22 02:06:05 +0100604 delete $disabled{"dynamic-engine"};
Richard Levitte343ec2b2016-02-19 22:08:37 +0100605 }
Richard Levitte25004db2016-03-03 10:07:29 +0100606 elsif ($1 eq "zlib-dynamic")
607 {
608 delete $disabled{"zlib"};
609 }
Richard Levittefe052642015-05-18 03:33:55 +0200610 my $algo = $1;
Richard Levittefe052642015-05-18 03:33:55 +0200611 delete $disabled{$algo};
612
Richard Levitte9c62a272016-02-27 16:51:34 +0100613 # No longer an automatic choice
614 $auto_threads = 0 if ($1 eq "threads");
Richard Levittefe052642015-05-18 03:33:55 +0200615 }
616 elsif (/^--strict-warnings$/)
617 {
618 $strict_warnings = 1;
619 }
620 elsif (/^--debug$/)
621 {
Richard Levitte8864f0d2016-03-02 19:13:26 +0100622 $config{build_type} = "debug";
Richard Levittefe052642015-05-18 03:33:55 +0200623 }
624 elsif (/^--release$/)
625 {
Richard Levitte8864f0d2016-03-02 19:13:26 +0100626 $config{build_type} = "release";
Richard Levittefe052642015-05-18 03:33:55 +0200627 }
628 elsif (/^386$/)
Richard Levitte7d130f62015-05-19 01:40:54 +0200629 { $config{processor}=386; }
Richard Levittefe052642015-05-18 03:33:55 +0200630 elsif (/^fips$/)
631 {
Richard Levitte107b5792015-05-20 20:03:20 +0200632 $config{fips}=1;
Richard Levittefe052642015-05-18 03:33:55 +0200633 }
634 elsif (/^rsaref$/)
635 {
636 # No RSAref support any more since it's not needed.
637 # The check for the option is there so scripts aren't
638 # broken
639 }
640 elsif (/^nofipscanistercheck$/)
641 {
Richard Levitte107b5792015-05-20 20:03:20 +0200642 $config{fips} = 1;
Richard Levittefe052642015-05-18 03:33:55 +0200643 $nofipscanistercheck = 1;
644 }
645 elsif (/^[-+]/)
646 {
Richard Levittedc3365f2016-03-07 20:41:39 +0100647 if (/^--classic$/)
648 {
649 $classic=1;
650 }
651 elsif (/^--prefix=(.*)$/)
Richard Levittefe052642015-05-18 03:33:55 +0200652 {
Richard Levitte291e94d2015-05-18 22:35:23 +0200653 $config{prefix}=$1;
Richard Levitte5482dac2016-01-30 02:57:19 +0100654 die "Directory given with --prefix MUST be absolute\n"
655 unless file_name_is_absolute($config{prefix});
Richard Levittefe052642015-05-18 03:33:55 +0200656 }
657 elsif (/^--api=(.*)$/)
658 {
Richard Levitte107b5792015-05-20 20:03:20 +0200659 $config{api}=$1;
Richard Levittefe052642015-05-18 03:33:55 +0200660 }
661 elsif (/^--libdir=(.*)$/)
662 {
Richard Levitte107b5792015-05-20 20:03:20 +0200663 $config{libdir}=$1;
Richard Levittefe052642015-05-18 03:33:55 +0200664 }
665 elsif (/^--openssldir=(.*)$/)
666 {
Richard Levitte291e94d2015-05-18 22:35:23 +0200667 $config{openssldir}=$1;
Richard Levittefe052642015-05-18 03:33:55 +0200668 }
Richard Levittefe052642015-05-18 03:33:55 +0200669 elsif (/^--with-zlib-lib=(.*)$/)
670 {
Michael Lee20a58192016-02-03 11:31:40 -0500671 $withargs{zlib_lib}=$1;
Richard Levittefe052642015-05-18 03:33:55 +0200672 }
673 elsif (/^--with-zlib-include=(.*)$/)
674 {
Richard Levitteda430a52016-04-12 16:35:32 +0200675 $withargs{zlib_include}=$1;
Richard Levittefe052642015-05-18 03:33:55 +0200676 }
677 elsif (/^--with-fipslibdir=(.*)$/)
678 {
Richard Levitte107b5792015-05-20 20:03:20 +0200679 $config{fipslibdir}="$1/";
Richard Levittefe052642015-05-18 03:33:55 +0200680 }
681 elsif (/^--with-baseaddr=(.*)$/)
682 {
Richard Levitte107b5792015-05-20 20:03:20 +0200683 $config{baseaddr}="$1";
Richard Levittefe052642015-05-18 03:33:55 +0200684 }
685 elsif (/^--cross-compile-prefix=(.*)$/)
686 {
Richard Levitte642a6132015-12-27 02:27:30 +0100687 $config{cross_compile_prefix}=$1;
Richard Levittefe052642015-05-18 03:33:55 +0200688 }
689 elsif (/^--config=(.*)$/)
690 {
691 read_config $1;
692 }
693 elsif (/^-[lL](.*)$/ or /^-Wl,/)
694 {
695 $libs.=$_." ";
696 }
Richard Levittebcb19772016-01-30 02:17:05 +0100697 elsif (/^-D(.*)$/)
698 {
699 push @user_defines, $1;
700 }
Richard Levittefe052642015-05-18 03:33:55 +0200701 else # common if (/^[-+]/), just pass down...
702 {
703 $_ =~ s/%([0-9a-f]{1,2})/chr(hex($1))/gei;
Rich Salz2b91ec72016-02-12 14:40:33 -0500704 $user_cflags.=" ".$_;
Richard Levittefe052642015-05-18 03:33:55 +0200705 }
706 }
Richard Levittefe052642015-05-18 03:33:55 +0200707 else
708 {
709 die "target already defined - $target (offending arg: $_)\n" if ($target ne "");
710 $target=$_;
711 }
712 unless ($_ eq $target || /^no-/ || /^disable-/)
713 {
714 # "no-..." follows later after implied disactivations
Rich Salze771eea2016-04-04 16:11:43 -0400715 # have been derived. (Don't take this too seroiusly,
Richard Levittefe052642015-05-18 03:33:55 +0200716 # we really only write OPTIONS to the Makefile out of
717 # nostalgia.)
718
Richard Levitte3fa04f02016-01-12 00:17:12 +0100719 if ($config{options} eq "")
720 { $config{options} = $_; }
Richard Levittefe052642015-05-18 03:33:55 +0200721 else
Richard Levitte3fa04f02016-01-12 00:17:12 +0100722 { $config{options} .= " ".$_; }
Richard Levittefe052642015-05-18 03:33:55 +0200723 }
Richard Levitte489eb742015-10-22 17:33:47 +0200724
Richard Levitte107b5792015-05-20 20:03:20 +0200725 if (defined($config{api}) && !exists $apitable->{$config{api}}) {
726 die "***** Unsupported api compatibility level: $config{api}\n",
Viktor Dukhovni98186eb2016-01-04 23:00:33 -0500727 }
728
Richard Levittee80381e2016-02-22 10:42:53 +0100729 if (keys %deprecated_options)
730 {
731 warn "***** Deprecated options: ",
732 join(", ", keys %deprecated_options), "\n";
733 }
Richard Levitte489eb742015-10-22 17:33:47 +0200734 if (keys %unsupported_options)
735 {
736 die "***** Unsupported options: ",
737 join(", ", keys %unsupported_options), "\n";
738 }
Bodo Möllerfbabb751999-07-09 12:00:34 +0000739 }
Richard Levitteb6e4dac2001-11-27 11:48:30 +0000740
Richard Levitte107b5792015-05-20 20:03:20 +0200741if ($config{fips})
Richard Levitteb6e4dac2001-11-27 11:48:30 +0000742 {
Richard Levittec569e202015-05-18 11:03:47 +0200743 delete $disabled{"shared"} if ($disabled{"shared"} =~ /^default/);
Richard Levitteb6e4dac2001-11-27 11:48:30 +0000744 }
Richard Levitte107b5792015-05-20 20:03:20 +0200745else
746 {
747 @{$config{dirs}} = grep !/^fips$/, @{$config{dirs}};
748 }
Richard Levitteb6e4dac2001-11-27 11:48:30 +0000749
Richard Levittec569e202015-05-18 11:03:47 +0200750my @tocheckfor = (keys %disabled);
751while (@tocheckfor) {
752 my %new_tocheckfor = ();
753 my @cascade_copy = (@disable_cascades);
754 while (@cascade_copy) {
755 my ($test, $descendents) = (shift @cascade_copy, shift @cascade_copy);
756 if (ref($test) eq "CODE" ? $test->() : defined($disabled{$test})) {
Richard Levitte2110feb2016-04-06 15:02:57 +0200757 foreach(grep { !defined($disabled{$_}) } @$descendents) {
Richard Levitte01d99972016-03-14 10:02:13 +0100758 $new_tocheckfor{$_} = 1; $disabled{$_} = "forced";
Richard Levitte2110feb2016-04-06 15:02:57 +0200759 }
Richard Levitteb6e4dac2001-11-27 11:48:30 +0000760 }
Richard Levittec569e202015-05-18 11:03:47 +0200761 }
762 @tocheckfor = (keys %new_tocheckfor);
763}
Ben Laurieedc032b2011-03-12 17:01:19 +0000764
Bodo Möller436a3761999-05-28 23:18:51 +0000765if ($target eq "TABLE") {
Richard Levitte00ae96c2015-05-18 12:53:38 +0200766 foreach (sort keys %table) {
767 print_table_entry($_, "TABLE");
768 }
769 exit 0;
Bodo Möller436a3761999-05-28 23:18:51 +0000770}
771
Ulf Möller10a926c2000-02-21 00:55:45 +0000772if ($target eq "LIST") {
Richard Levitte00ae96c2015-05-18 12:53:38 +0200773 foreach (sort keys %table) {
774 print $_,"\n" unless $table{$_}->{template};
775 }
776 exit 0;
Ulf Möller10a926c2000-02-21 00:55:45 +0000777}
778
Richard Levitteaaf878c2015-03-06 02:00:21 +0100779if ($target eq "HASH") {
Richard Levitte00ae96c2015-05-18 12:53:38 +0200780 print "%table = (\n";
781 foreach (sort keys %table) {
782 print_table_entry($_, "HASH");
783 }
784 exit 0;
Richard Levitteaaf878c2015-03-06 02:00:21 +0100785}
786
Richard Levitte00ae96c2015-05-18 12:53:38 +0200787# Backward compatibility?
Richard Levitte49e04542002-02-14 12:28:24 +0000788if ($target =~ m/^CygWin32(-.*)$/) {
Richard Levitte00ae96c2015-05-18 12:53:38 +0200789 $target = "Cygwin".$1;
Richard Levitte49e04542002-02-14 12:28:24 +0000790}
791
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000792foreach (sort (keys %disabled))
793 {
Richard Levitte3fa04f02016-01-12 00:17:12 +0100794 $config{options} .= " no-$_";
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000795
796 printf " no-%-12s %-10s", $_, "[$disabled{$_}]";
797
798 if (/^dso$/)
Richard Levitte721f9052016-02-22 14:12:35 +0100799 { }
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000800 elsif (/^threads$/)
Richard Levitte22bfe052016-02-22 14:03:23 +0100801 { }
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000802 elsif (/^shared$/)
Richard Levitte84af1ba2016-02-22 13:52:46 +0100803 { }
Richard Levitteae482422016-02-22 02:09:11 +0100804 elsif (/^pic$/)
805 { }
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000806 elsif (/^zlib$/)
Richard Levitte36a30902016-02-22 14:04:45 +0100807 { }
Richard Levitte19ab5792016-02-22 02:06:05 +0100808 elsif (/^dynamic-engine$/)
Dr. Stephen Hensonfbf002b2005-11-06 17:58:26 +0000809 { }
Richard Levitte09aa2632016-03-09 01:14:29 +0100810 elsif (/^makedepend$/)
811 { }
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000812 elsif (/^zlib-dynamic$/)
813 { }
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000814 elsif (/^sse2$/)
815 { $no_sse2 = 1; }
Richard Levitte107b5792015-05-20 20:03:20 +0200816 elsif (/^engine$/)
Rich Salz1288f262016-02-17 13:33:51 -0500817 {
818 @{$config{dirs}} = grep !/^engines$/, @{$config{dirs}};
819 @{$config{sdirs}} = grep !/^engine$/, @{$config{sdirs}};
820 push @{$config{openssl_other_defines}}, "OPENSSL_NO_ENGINE";
821 }
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000822 else
823 {
824 my ($ALGO, $algo);
Richard Levitte30fafde2011-03-25 09:29:46 +0000825 ($ALGO = $algo = $_) =~ tr/[\-a-z]/[_A-Z]/;
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000826
Matt Caswell316fae22016-02-18 16:54:16 +0000827 if (/^asm$/ || /^err$/ || /^hw$/ || /^hw-/ || /^async$/
Matt Caswell498abff2016-02-09 09:39:07 +0000828 || /^autoalginit/ || /^autoerrinit/)
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000829 {
Richard Levitte7d130f62015-05-19 01:40:54 +0200830 push @{$config{openssl_other_defines}}, "OPENSSL_NO_$ALGO";
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000831 print " OPENSSL_NO_$ALGO";
Felix Laurie von Massenbachfce0ba52014-05-26 17:19:28 +0100832
Richard Levittebcb19772016-01-30 02:17:05 +0100833 if (/^err$/) { push @user_defines, "OPENSSL_NO_ERR"; }
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000834 }
835 else
836 {
Andy Polyakov2a4af942015-01-24 16:46:54 +0100837 ($ALGO,$algo) = ("RMD160","rmd160") if ($algo eq "ripemd");
838
Richard Levitte7d130f62015-05-19 01:40:54 +0200839 push @{$config{openssl_algorithm_defines}}, "OPENSSL_NO_$ALGO";
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000840 print " OPENSSL_NO_$ALGO";
841
Matt Caswelle36827f2015-05-12 12:14:13 +0100842 # fix-up crypto/directory name(s)
Richard Levitte107b5792015-05-20 20:03:20 +0200843 $algo="whrlpool" if $algo eq "whirlpool";
844 $algo="ripemd" if $algo eq "rmd160";
845 @{$config{sdirs}} = grep { $_ ne $algo} @{$config{sdirs}};
Andy Polyakov2a4af942015-01-24 16:46:54 +0100846
Matt Caswelle36827f2015-05-12 12:14:13 +0100847 print " (skip dir)";
Bodo Möllerc9a112f2005-02-22 10:29:51 +0000848 }
849 }
850
851 print "\n";
852 }
853
Richard Levitte9e0724a2015-05-18 02:54:28 +0200854print "Configuring for $target\n";
855
856# Support for legacy targets having a name starting with 'debug-'
857my ($d, $t) = $target =~ m/^(debug-)?(.*)$/;
858if ($d) {
Richard Levitte8864f0d2016-03-02 19:13:26 +0100859 $config{build_type} = "debug";
Richard Levitte9e0724a2015-05-18 02:54:28 +0200860
861 # If we do not find debug-foo in the table, the target is set to foo.
862 if (!$table{$target}) {
863 $target = $t;
864 }
865}
Richard Levitte291e94d2015-05-18 22:35:23 +0200866$config{target} = $target;
Richard Levitte79302212016-02-27 10:23:15 +0100867my %target = resolve_config($target);
Richard Levitte9e0724a2015-05-18 02:54:28 +0200868
869&usage if (!%target || $target{template});
870
Richard Levitted2b22212016-02-27 11:25:33 +0100871%target = ( %{$table{DEFAULTS}}, %target );
Richard Levitte79302212016-02-27 10:23:15 +0100872
Richard Levitte107b5792015-05-20 20:03:20 +0200873$target{exe_extension}="";
Richard Levittef99f91f2016-02-15 22:13:41 +0100874$target{exe_extension}=".exe" if ($config{target} eq "DJGPP"
875 || $config{target} =~ /^(?:Cygwin|mingw)/);
Richard Levitte107b5792015-05-20 20:03:20 +0200876$target{exe_extension}=".pm" if ($config{target} =~ /vos/);
Ulf Möller462ba4f1999-04-24 22:59:36 +0000877
Richard Levittee987f9f2016-02-15 17:20:15 +0100878($target{shared_extension_simple}=$target{shared_extension})
879 =~ s|\.\$\(SHLIB_MAJOR\)\.\$\(SHLIB_MINOR\)||;
880$target{dso_extension}=$target{shared_extension_simple};
881($target{shared_import_extension}=$target{shared_extension_simple}.".a")
882 if ($config{target} =~ /^(?:Cygwin|mingw)/);
883
884
Richard Levitte642a6132015-12-27 02:27:30 +0100885$config{cross_compile_prefix} = $ENV{'CROSS_COMPILE'}
886 if $config{cross_compile_prefix} eq "";
Dr. Stephen Hensonf99f41c2009-10-07 16:41:14 +0000887
Richard Levitteb0a1e8b2016-03-02 12:22:15 +0100888# Allow overriding the names of some tools. USE WITH CARE
Richard Levitte59028212016-03-31 09:27:15 +0200889$config{perl} = $ENV{'PERL'} || ($^O ne "VMS" ? $^X : "perl");
Richard Levitteb0a1e8b2016-03-02 12:22:15 +0100890$target{cc} = $ENV{'CC'} || $target{cc} || "cc";
891$target{ranlib} = $ENV{'RANLIB'} || $target{ranlib} || which("ranlib") || "true";
892$target{ar} = $ENV{'AR'} || $target{ar} || "ar";
893$target{nm} = $ENV{'NM'} || $target{nm} || "nm";
Richard Levitteaaf878c2015-03-06 02:00:21 +0100894
Richard Levittebcb19772016-01-30 02:17:05 +0100895# For cflags, lflags, plib_lflags, ex_libs and defines, add the debug_
896# or release_ attributes.
Richard Levitteaaf878c2015-03-06 02:00:21 +0100897# Do it in such a way that no spurious space is appended (hence the grep).
Richard Levitte2952b9b2016-03-02 10:57:05 +0100898$config{defines} = [];
899$config{cflags} = "";
900$config{ex_libs} = "";
901$config{shared_ldflag} = "";
Richard Levitteaaf878c2015-03-06 02:00:21 +0100902
Richard Levitte291e94d2015-05-18 22:35:23 +0200903# Make sure build_scheme is consistent.
904$target{build_scheme} = [ $target{build_scheme} ]
905 if ref($target{build_scheme}) ne "ARRAY";
Richard Levitted0d046e2002-01-27 15:52:37 +0000906
Richard Levittedc3365f2016-03-07 20:41:39 +0100907###### TO BE REMOVED WHEN CLASSIC BUILD IS REMOVED
908######
909###### If the user has chosen --classic, we give it to them.
910###### If they try that with an out-of-source config, we complain.
911if ($target{build_scheme}->[0] eq "unified" && $classic) {
912 die "Can't perform a classic build out of source tree\n"
913 if $srcdir ne $blddir;
914
915 $target{build_scheme} = { unix => [ "unixmake" ],
Richard Levitte014267f2016-03-17 18:38:05 +0100916 windows => undef,
Richard Levittedc3365f2016-03-07 20:41:39 +0100917 VMS => undef } -> {$target{build_scheme}->[1]};
918
919 die "Classic mode unavailable on this platform\n"
920 unless defined($target{build_scheme});
921}
922
Richard Levitteddf18472016-01-30 00:57:33 +0100923my ($builder, $builder_platform, @builder_opts) =
924 @{$target{build_scheme}};
925
Richard Levitte488e2b02016-04-01 16:03:46 +0200926push @{$config{defines}}, "NDEBUG" if $config{build_type} eq "release";
927
Richard Levitte68ab5592016-02-05 15:14:45 +0100928if ($target =~ /^mingw/ && `$target{cc} --target-help 2>&1` =~ m/-mno-cygwin/m)
Andy Polyakovcbecd292010-11-30 22:18:02 +0000929 {
Richard Levitte68ab5592016-02-05 15:14:45 +0100930 $config{cflags} .= " -mno-cygwin";
Richard Levitte2952b9b2016-03-02 10:57:05 +0100931 $config{shared_ldflag} .= " -mno-cygwin";
Andy Polyakovcbecd292010-11-30 22:18:02 +0000932 }
933
Richard Levitte00b0d662016-02-22 14:10:45 +0100934if ($target =~ /linux.*-mips/ && !$disabled{asm} && $user_cflags !~ /-m(ips|arch=)/) {
Andy Polyakov63d88342012-09-15 11:21:50 +0000935 # minimally required architecture flags for assembly modules
Richard Levitte107b5792015-05-20 20:03:20 +0200936 $config{cflags}="-mips2 $config{cflags}" if ($target =~ /mips32/);
937 $config{cflags}="-mips3 $config{cflags}" if ($target =~ /mips64/);
Andy Polyakov63d88342012-09-15 11:21:50 +0000938}
939
Richard Levitte2964ba82003-01-11 11:40:39 +0000940my $no_shared_warn=0;
Andy Polyakov14bcdb02005-01-24 15:58:25 +0000941my $no_user_cflags=0;
Richard Levittebcb19772016-01-30 02:17:05 +0100942my $no_user_defines=0;
Richard Levitte2964ba82003-01-11 11:40:39 +0000943
Geoff Thorpebc2aada2000-04-06 07:09:45 +0000944# The DSO code currently always implements all functions so that no
945# applications will have to worry about that from a compilation point
946# of view. However, the "method"s may return zero unless that platform
947# has support compiled in for them. Currently each method is enabled
948# by a define "DSO_<name>" ... we translate the "dso_scheme" config
949# string entry into using the following logic;
Richard Levitte721f9052016-02-22 14:12:35 +0100950if (!$disabled{dso} && $target{dso_scheme} ne "")
Geoff Thorpebc2aada2000-04-06 07:09:45 +0000951 {
Richard Levitte291e94d2015-05-18 22:35:23 +0200952 $target{dso_scheme} =~ tr/[a-z]/[A-Z]/;
953 if ($target{dso_scheme} eq "DLFCN")
Geoff Thorpebc2aada2000-04-06 07:09:45 +0000954 {
Richard Levitte2952b9b2016-03-02 10:57:05 +0100955 unshift @{$config{defines}}, "DSO_DLFCN", "HAVE_DLFCN_H";
Geoff Thorpebc2aada2000-04-06 07:09:45 +0000956 }
Richard Levitte291e94d2015-05-18 22:35:23 +0200957 elsif ($target{dso_scheme} eq "DLFCN_NO_H")
Geoff Thorpebc2aada2000-04-06 07:09:45 +0000958 {
Richard Levitte2952b9b2016-03-02 10:57:05 +0100959 unshift @{$config{defines}}, "DSO_DLFCN";
Geoff Thorpebc2aada2000-04-06 07:09:45 +0000960 }
961 else
962 {
Richard Levitte2952b9b2016-03-02 10:57:05 +0100963 unshift @{$config{defines}}, "DSO_$target{dso_scheme}";
Geoff Thorpebc2aada2000-04-06 07:09:45 +0000964 }
965 }
Geoff Thorpe9ec01262000-04-04 22:32:19 +0000966
Richard Levitte1740c162016-01-29 18:07:37 +0100967$config{ex_libs}="$libs$config{ex_libs}" if ($libs ne "");
Ralf S. Engelschalld02b48c1998-12-21 10:52:47 +0000968
Richard Levitte00b0d662016-02-22 14:10:45 +0100969if ($disabled{asm})
Ralf S. Engelschalldfeab061998-12-21 11:00:56 +0000970 {
Richard Levitte2952b9b2016-03-02 10:57:05 +0100971 if ($config{fips})
972 {
973 @{$config{defines}} = grep !/^[BL]_ENDIAN$/, @{$config{defines}};
974 @{$target{defines}} = grep !/^[BL]_ENDIAN$/, @{$target{defines}};
975 }
Ralf S. Engelschalldfeab061998-12-21 11:00:56 +0000976 }
Andy Polyakov6f7ac8e2002-12-13 17:56:14 +0000977
Richard Levitte9c62a272016-02-27 16:51:34 +0100978# If threads aren't disabled, check how possible they are
979unless ($disabled{threads}) {
980 if ($auto_threads) {
981 # Enabled by default, disable it forcibly if unavailable
982 if ($target{thread_scheme} eq "(unknown)") {
983 $disabled{threads} = "unavailable";
984 }
985 } else {
Rich Salze771eea2016-04-04 16:11:43 -0400986 # The user chose to enable threads explicitely, let's see
Richard Levitte9c62a272016-02-27 16:51:34 +0100987 # if there's a chance that's possible
988 if ($target{thread_scheme} eq "(unknown)") {
989 # If the user asked for "threads" and we don't have internal
990 # knowledge how to do it, [s]he is expected to provide any
991 # system-dependent compiler options that are necessary. We
992 # can't truly check that the given options are correct, but
993 # we expect the user to know what [s]He is doing.
994 if ($no_user_cflags && $no_user_defines) {
995 die "You asked for multi-threading support, but didn't\n"
996 ,"provide any system-specific compiler options\n";
997 }
998 }
999 }
1000}
1001
1002# If threads still aren't disabled, add a C macro to ensure the source
1003# code knows about it. Any other flag is taken care of by the configs.
1004unless($disabled{threads}) {
1005 foreach (("defines", "openssl_thread_defines")) {
1006 push @{$config{$_}}, "OPENSSL_THREADS";
1007 }
1008}
Richard Levittee452de92001-07-12 09:11:14 +00001009
Viktor Dukhovni98186eb2016-01-04 23:00:33 -05001010# With "deprecated" disable all deprecated features.
1011if (defined($disabled{"deprecated"})) {
Richard Levitte107b5792015-05-20 20:03:20 +02001012 $config{api} = $maxapi;
Viktor Dukhovni98186eb2016-01-04 23:00:33 -05001013}
Matt Caswell07c4c142014-12-17 13:17:26 +00001014
Richard Levitte291e94d2015-05-18 22:35:23 +02001015if ($target{shared_target} eq "")
Andy Polyakov6f7ac8e2002-12-13 17:56:14 +00001016 {
Richard Levitteae482422016-02-22 02:09:11 +01001017 $no_shared_warn = 1
Richard Levitte84af1ba2016-02-22 13:52:46 +01001018 if ((!$disabled{shared} || !$disabled{"dynamic-engine"})
Richard Levitteae482422016-02-22 02:09:11 +01001019 && !$config{fips});
Richard Levitte84af1ba2016-02-22 13:52:46 +01001020 $disabled{shared} = "no-shared-target";
Richard Levitteae482422016-02-22 02:09:11 +01001021 $disabled{pic} = $disabled{shared} = $disabled{"dynamic-engine"} =
1022 "no-shared-target";
Andy Polyakov6f7ac8e2002-12-13 17:56:14 +00001023 }
Richard Levitteb436a982000-07-21 15:08:53 +00001024
Richard Levitte19ab5792016-02-22 02:06:05 +01001025if ($disabled{"dynamic-engine"}) {
Richard Levitte343ec2b2016-02-19 22:08:37 +01001026 push @{$config{defines}}, "OPENSSL_NO_DYNAMIC_ENGINE";
1027 $config{dynamic_engines} = 0;
Richard Levitte19ab5792016-02-22 02:06:05 +01001028} else {
1029 push @{$config{defines}}, "OPENSSL_NO_STATIC_ENGINE";
1030 $config{dynamic_engines} = 1;
Richard Levitte343ec2b2016-02-19 22:08:37 +01001031}
Richard Levitteecd45312002-10-11 18:06:08 +00001032
Andy Polyakovc313e322007-09-16 12:23:47 +00001033#
1034# Platform fix-ups
1035#
Richard Levitteae482422016-02-22 02:09:11 +01001036
1037# This saves the build files from having to check
1038if ($disabled{pic})
1039 {
1040 $target{shared_cflag} = $target{shared_ldflag} =
1041 $target{shared_rcflag} = "";
1042 }
Richard Levitte4f160392016-02-21 20:52:39 +01001043else
1044 {
1045 push @{$config{defines}}, "OPENSSL_PIC";
1046 }
Richard Levitteae482422016-02-22 02:09:11 +01001047
Richard Levitte291e94d2015-05-18 22:35:23 +02001048if ($target{sys_id} ne "")
Richard Levittecf1b7d92001-02-19 16:06:34 +00001049 {
Richard Levitte642a6132015-12-27 02:27:30 +01001050 push @{$config{openssl_sys_defines}}, "OPENSSL_SYS_$target{sys_id}";
Richard Levittecf1b7d92001-02-19 16:06:34 +00001051 }
1052
Richard Levitte00b0d662016-02-22 14:10:45 +01001053unless ($disabled{asm}) {
Richard Levitted2b22212016-02-27 11:25:33 +01001054 $target{cpuid_asm_src}=$table{DEFAULTS}->{cpuid_asm_src} if ($config{processor} eq "386");
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001055 $target{bn_asm_src} =~ s/\w+-gf2m.c// if (defined($disabled{ec2m}));
Andy Polyakovf8c469d2004-08-02 22:41:19 +00001056
Richard Levitte9e0724a2015-05-18 02:54:28 +02001057 # bn-586 is the only one implementing bn_*_part_words
Richard Levittebcb19772016-01-30 02:17:05 +01001058 push @{$config{defines}}, "OPENSSL_BN_ASM_PART_WORDS" if ($target{bn_asm_src} =~ /bn-586/);
1059 push @{$config{defines}}, "OPENSSL_IA32_SSE2" if (!$no_sse2 && $target{bn_asm_src} =~ /86/);
Ralf S. Engelschalldfeab061998-12-21 11:00:56 +00001060
Richard Levittebcb19772016-01-30 02:17:05 +01001061 push @{$config{defines}}, "OPENSSL_BN_ASM_MONT" if ($target{bn_asm_src} =~ /-mont/);
1062 push @{$config{defines}}, "OPENSSL_BN_ASM_MONT5" if ($target{bn_asm_src} =~ /-mont5/);
1063 push @{$config{defines}}, "OPENSSL_BN_ASM_GF2m" if ($target{bn_asm_src} =~ /-gf2m/);
Andy Polyakov5ac7bde2005-10-07 14:18:06 +00001064
Richard Levitte107b5792015-05-20 20:03:20 +02001065 if ($config{fips}) {
Richard Levitte7d130f62015-05-19 01:40:54 +02001066 push @{$config{openssl_other_defines}}, "OPENSSL_FIPS";
Richard Levitte9e0724a2015-05-18 02:54:28 +02001067 }
Dr. Stephen Henson1ab2f7f2011-01-26 12:31:30 +00001068
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001069 if ($target{sha1_asm_src}) {
Richard Levittebcb19772016-01-30 02:17:05 +01001070 push @{$config{defines}}, "SHA1_ASM" if ($target{sha1_asm_src} =~ /sx86/ || $target{sha1_asm_src} =~ /sha1/);
1071 push @{$config{defines}}, "SHA256_ASM" if ($target{sha1_asm_src} =~ /sha256/);
1072 push @{$config{defines}}, "SHA512_ASM" if ($target{sha1_asm_src} =~ /sha512/);
Richard Levitte9e0724a2015-05-18 02:54:28 +02001073 }
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001074 if ($target{md5_asm_src}) {
Richard Levittebcb19772016-01-30 02:17:05 +01001075 push @{$config{defines}}, "MD5_ASM";
Richard Levitte9e0724a2015-05-18 02:54:28 +02001076 }
Richard Levitted2b22212016-02-27 11:25:33 +01001077 $target{cast_asm_src}=$table{DEFAULTS}->{cast_asm_src} unless $disabled{pic}; # CAST assembler is not PIC
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001078 if ($target{rmd160_asm_src}) {
Richard Levittebcb19772016-01-30 02:17:05 +01001079 push @{$config{defines}}, "RMD160_ASM";
Richard Levitte9e0724a2015-05-18 02:54:28 +02001080 }
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001081 if ($target{aes_asm_src}) {
Richard Levittebcb19772016-01-30 02:17:05 +01001082 push @{$config{defines}}, "AES_ASM" if ($target{aes_asm_src} =~ m/\baes-/);;
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001083 # aes-ctr.fake is not a real file, only indication that assembler
Andy Polyakov874a3752010-07-09 12:21:52 +00001084 # module implements AES_ctr32_encrypt...
Richard Levittebcb19772016-01-30 02:17:05 +01001085 push @{$config{defines}}, "AES_CTR_ASM" if ($target{aes_asm_src} =~ s/\s*aes-ctr\.fake//);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001086 # aes-xts.fake indicates presence of AES_xts_[en|de]crypt...
Richard Levittebcb19772016-01-30 02:17:05 +01001087 push @{$config{defines}}, "AES_XTS_ASM" if ($target{aes_asm_src} =~ s/\s*aes-xts\.fake//);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001088 $target{aes_asm_src} =~ s/\s*(vpaes|aesni)-x86\.s//g if ($no_sse2);
Richard Levittebcb19772016-01-30 02:17:05 +01001089 push @{$config{defines}}, "VPAES_ASM" if ($target{aes_asm_src} =~ m/vpaes/);
1090 push @{$config{defines}}, "BSAES_ASM" if ($target{aes_asm_src} =~ m/bsaes/);
Richard Levitte9e0724a2015-05-18 02:54:28 +02001091 }
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001092 if ($target{wp_asm_src} =~ /mmx/) {
Andy Polyakov46d4d862016-01-29 14:23:24 +01001093 if ($config{processor} eq "386") {
Richard Levitted2b22212016-02-27 11:25:33 +01001094 $target{wp_asm_src}=$table{DEFAULTS}->{wp_asm_src};
Andy Polyakov46d4d862016-01-29 14:23:24 +01001095 } elsif (!$disabled{"whirlpool"}) {
Richard Levitte2952b9b2016-03-02 10:57:05 +01001096 push @{$config{defines}}, "WHIRLPOOL_ASM";
Andy Polyakov46d4d862016-01-29 14:23:24 +01001097 }
Richard Levitte9e0724a2015-05-18 02:54:28 +02001098 }
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001099 if ($target{modes_asm_src} =~ /ghash-/) {
Richard Levittebcb19772016-01-30 02:17:05 +01001100 push @{$config{defines}}, "GHASH_ASM";
Richard Levitte9e0724a2015-05-18 02:54:28 +02001101 }
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001102 if ($target{ec_asm_src} =~ /ecp_nistz256/) {
Richard Levittebcb19772016-01-30 02:17:05 +01001103 push @{$config{defines}}, "ECP_NISTZ256_ASM";
Richard Levitte9e0724a2015-05-18 02:54:28 +02001104 }
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001105 if ($target{poly1305_asm_src} ne "") {
Richard Levittebcb19772016-01-30 02:17:05 +01001106 push @{$config{defines}}, "POLY1305_ASM";
Richard Levitte9e0724a2015-05-18 02:54:28 +02001107 }
1108}
Ralf S. Engelschalld02b48c1998-12-21 10:52:47 +00001109
Richard Levitte8ed40b82016-01-27 19:03:13 +01001110my $ecc = $target{cc};
Richard Levitte09aa2632016-03-09 01:14:29 +01001111if ($^O ne "VMS" && !$disabled{makedepend}) {
Richard Levittea583fc42016-02-16 16:08:06 +01001112 # Is the compiler gcc or clang? $ecc is used below to see if
1113 # error-checking can be turned on.
1114 my $ccpcc = "$config{cross_compile_prefix}$target{cc}";
Andy Polyakovd0db7ee2016-03-11 12:33:59 +01001115 open(PIPE, "$ccpcc --version 2>&1 |");
1116 my $lines = 2;
Richard Levittea583fc42016-02-16 16:08:06 +01001117 while ( <PIPE> ) {
Richard Levitte30752dd2016-03-08 17:16:16 +01001118 # Find the version number and save the major.
1119 m|(?:.*)\b(\d+)\.\d+\.\d+\b(?:.*)|;
Richard Levitte39affe12016-03-10 19:33:11 +01001120 my $compiler_major = $1;
Richard Levitte30752dd2016-03-08 17:16:16 +01001121 # We know that GNU C version 3 and up as well as all clang
1122 # versions support dependency generation
Richard Levitte39affe12016-03-10 19:33:11 +01001123 $config{makedepprog} = $ccpcc
Andy Polyakovd0db7ee2016-03-11 12:33:59 +01001124 if (/clang/ || (/gcc/ && $compiler_major > 3));
Richard Levittea583fc42016-02-16 16:08:06 +01001125 $ecc = "clang" if /clang/;
1126 $ecc = "gcc" if /gcc/;
Andy Polyakovd0db7ee2016-03-11 12:33:59 +01001127 last if ($config{makedepprog} || !$lines--);
Richard Levittea583fc42016-02-16 16:08:06 +01001128 }
1129 close(PIPE);
Richard Levitte09aa2632016-03-09 01:14:29 +01001130
Andy Polyakovd0db7ee2016-03-11 12:33:59 +01001131 $config{makedepprog} = which('makedepend') unless $config{makedepprog};
Richard Levitte09aa2632016-03-09 01:14:29 +01001132 $disabled{makedepend} = "unavailable" unless $config{makedepprog};
Rich Salzf1f07a22016-01-29 19:50:28 -05001133}
Richard Levitte8ed40b82016-01-27 19:03:13 +01001134
Richard Levitte7d130f62015-05-19 01:40:54 +02001135
Richard Levitte09aa2632016-03-09 01:14:29 +01001136
Richard Levitte7d130f62015-05-19 01:40:54 +02001137# Deal with bn_ops ###################################################
1138
Richard Levitte7d130f62015-05-19 01:40:54 +02001139$config{bn_ll} =0;
Richard Levitte7d130f62015-05-19 01:40:54 +02001140$config{export_var_as_fn} =0;
1141my $def_int="unsigned int";
1142$config{rc4_int} =$def_int;
Rich Salzb4f35e52016-01-23 13:23:25 -05001143($config{b64l},$config{b64},$config{b32})=(0,0,1);
Richard Levitte7d130f62015-05-19 01:40:54 +02001144
Rich Salz94af0cd2016-01-28 10:13:21 -05001145my $count = 0;
Richard Levitte7d130f62015-05-19 01:40:54 +02001146foreach (sort split(/\s+/,$target{bn_ops})) {
Rich Salz94af0cd2016-01-28 10:13:21 -05001147 $count++ if /SIXTY_FOUR_BIT|SIXTY_FOUR_BIT_LONG|THIRTY_TWO_BIT/;
1148 $config{export_var_as_fn}=1 if $_ eq 'EXPORT_VAR_AS_FN';
1149 $config{bn_ll}=1 if $_ eq 'BN_LLONG';
1150 $config{rc4_int}="unsigned char" if $_ eq 'RC4_CHAR';
1151 ($config{b64l},$config{b64},$config{b32})
1152 =(0,1,0) if $_ eq 'SIXTY_FOUR_BIT';
1153 ($config{b64l},$config{b64},$config{b32})
1154 =(1,0,0) if $_ eq 'SIXTY_FOUR_BIT_LONG';
1155 ($config{b64l},$config{b64},$config{b32})
1156 =(0,0,1) if $_ eq 'THIRTY_TWO_BIT';
Richard Levitte7d130f62015-05-19 01:40:54 +02001157}
Rich Salz94af0cd2016-01-28 10:13:21 -05001158die "Exactly one of SIXTY_FOUR_BIT|SIXTY_FOUR_BIT_LONG|THIRTY_TWO_BIT can be set in bn_ops\n"
1159 if $count > 1;
Richard Levitte7d130f62015-05-19 01:40:54 +02001160
1161
1162# Hack cflags for better warnings (dev option) #######################
1163
Richard Levitte1ed0c662002-05-30 18:06:35 +00001164# "Stringify" the C flags string. This permits it to be made part of a string
1165# and works as well on command lines.
Richard Levitte01d99972016-03-14 10:02:13 +01001166$config{cflags} =~ s/([\\\"])/\\$1/g;
Richard Levitte1ed0c662002-05-30 18:06:35 +00001167
Richard Levitte107b5792015-05-20 20:03:20 +02001168if (defined($config{api})) {
1169 $config{openssl_api_defines} = [ "OPENSSL_MIN_API=".$apitable->{$config{api}} ];
Richard Levittebcb19772016-01-30 02:17:05 +01001170 my $apiflag = sprintf("OPENSSL_API_COMPAT=%s", $apitable->{$config{api}});
Richard Levittebcb19772016-01-30 02:17:05 +01001171 push @{$config{defines}}, $apiflag;
Viktor Dukhovni98186eb2016-01-04 23:00:33 -05001172}
1173
Dr. Stephen Henson0c28f272009-09-09 16:31:32 +00001174if ($strict_warnings)
1175 {
1176 my $wopt;
Rich Salzf1f07a22016-01-29 19:50:28 -05001177 die "ERROR --strict-warnings requires gcc or clang"
1178 unless $ecc eq 'gcc' || $ecc eq 'clang';
Dr. Stephen Henson0c28f272009-09-09 16:31:32 +00001179 foreach $wopt (split /\s+/, $gcc_devteam_warn)
1180 {
Richard Levitted918f9c2016-02-16 23:27:13 +01001181 $config{cflags} .= " $wopt" unless ($config{cflags} =~ /(?:^|\s)$wopt(?:\s|$)/)
Dr. Stephen Henson0c28f272009-09-09 16:31:32 +00001182 }
Ben Laurie190c8c62015-04-19 14:10:54 +01001183 if ($ecc eq "clang")
1184 {
1185 foreach $wopt (split /\s+/, $clang_devteam_warn)
1186 {
Richard Levitted918f9c2016-02-16 23:27:13 +01001187 $config{cflags} .= " $wopt" unless ($config{cflags} =~ /(?:^|\s)$wopt(?:\s|$)/)
Ben Laurie190c8c62015-04-19 14:10:54 +01001188 }
1189 }
Richard Levitteef8ca6b2016-02-14 12:16:52 +01001190 }
1191
1192unless ($disabled{"crypto-mdebug-backtrace"})
1193 {
1194 foreach my $wopt (split /\s+/, $memleak_devteam_backtrace)
Richard Levittea1d3f3d2015-12-02 18:44:26 +01001195 {
Richard Levitted918f9c2016-02-16 23:27:13 +01001196 $config{cflags} .= " $wopt" unless ($config{cflags} =~ /(?:^|\s)$wopt(?:\s|$)/)
Richard Levitteef8ca6b2016-02-14 12:16:52 +01001197 }
1198 if ($target =~ /^BSD-/)
1199 {
1200 $config{ex_libs} .= " -lexecinfo";
Richard Levitte291e94d2015-05-18 22:35:23 +02001201 }
Dr. Stephen Henson0c28f272009-09-09 16:31:32 +00001202 }
1203
Richard Levitte63994092016-02-13 13:02:35 +01001204if ($user_cflags ne "") { $config{cflags}="$config{cflags}$user_cflags"; }
1205else { $no_user_cflags=1; }
1206if (@user_defines) { $config{defines}=[ @{$config{defines}}, @user_defines ]; }
1207else { $no_user_defines=1; }
1208
1209# ALL MODIFICATIONS TO %config and %target MUST BE DONE FROM HERE ON
1210
Emilia Kasperc91a0a82016-03-14 12:21:44 +01001211unless ($disabled{afalgeng}) {
1212 $config{afalgeng}="";
Richard Levitte79fff392016-03-09 09:04:01 +01001213 if ($target =~ m/^linux/) {
1214 my $minver = 4*10000 + 1*100 + 0;
1215 if ($config{cross_compile_prefix} eq "") {
1216 my $verstr = `uname -r`;
1217 my ($ma, $mi1, $mi2) = split("\\.", $verstr);
1218 ($mi2) = $mi2 =~ /(\d+)/;
1219 my $ver = $ma*10000 + $mi1*100 + $mi2;
1220 if ($ver < $minver) {
Emilia Kasperc91a0a82016-03-14 12:21:44 +01001221 $disabled{afalgeng} = "too-old-kernel";
Richard Levitte79fff392016-03-09 09:04:01 +01001222 } else {
1223 push @{$config{engdirs}}, "afalg";
1224 }
Matt Caswell68dc37c2016-03-16 10:08:53 +00001225 } else {
1226 $disabled{afalgeng} = "cross-compiling";
clucey6cba4a62016-02-23 08:01:01 +00001227 }
Richard Levitte79fff392016-03-09 09:04:01 +01001228 } else {
Emilia Kasperc91a0a82016-03-14 12:21:44 +01001229 $disabled{afalgeng} = "not-linux";
clucey7f458a42016-02-17 13:38:36 +00001230 }
1231}
Matt Caswell8da00a32016-02-29 13:36:47 +00001232
Emilia Kasperc91a0a82016-03-14 12:21:44 +01001233push @{$config{openssl_other_defines}}, "OPENSSL_NO_AFALGENG" if ($disabled{afalgeng});
clucey7f458a42016-02-17 13:38:36 +00001234
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001235# If we use the unified build, collect information from build.info files
1236my %unified_info = ();
1237
Richard Levitte2b6b6062016-03-10 00:04:04 +01001238my $buildinfo_debug = defined($ENV{CONFIGURE_DEBUG_BUILDINFO});
Richard Levitteddf18472016-01-30 00:57:33 +01001239if ($builder eq "unified") {
1240 # Store the name of the template file we will build the build file from
1241 # in %config. This may be useful for the build file itself.
1242 my $build_file_template =
1243 catfile($srcdir, "Configurations",
1244 $builder_platform."-".$target{build_file}.".tmpl");
1245 $build_file_template =
1246 catfile($srcdir, "Configurations", $target{build_file}.".tmpl")
1247 if (! -f $build_file_template);
1248 $config{build_file_template} = $build_file_template;
1249
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001250 use lib catdir(dirname(__FILE__),"util");
1251 use with_fallback qw(Text::Template);
1252
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001253 sub cleandir {
Richard Levitte2e963842016-02-10 02:00:37 +01001254 my $base = shift;
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001255 my $dir = shift;
Richard Levitte2e963842016-02-10 02:00:37 +01001256 my $relativeto = shift || ".";
1257
1258 $dir = catdir($base,$dir) unless isabsolute($dir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001259
Richard Levitteec182ef2016-02-09 10:15:13 +01001260 # Make sure the directories we're building in exists
1261 mkpath($dir);
1262
Richard Levitte2e963842016-02-10 02:00:37 +01001263 my $res = abs2rel(absolutedir($dir), rel2abs($relativeto));
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001264 #print STDERR "DEBUG[cleandir]: $dir , $base => $res\n";
1265 return $res;
1266 }
1267
1268 sub cleanfile {
Richard Levitte2e963842016-02-10 02:00:37 +01001269 my $base = shift;
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001270 my $file = shift;
Richard Levitte2e963842016-02-10 02:00:37 +01001271 my $relativeto = shift || ".";
1272
1273 $file = catfile($base,$file) unless isabsolute($file);
1274
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001275 my $d = dirname($file);
1276 my $f = basename($file);
1277
Richard Levitteec182ef2016-02-09 10:15:13 +01001278 # Make sure the directories we're building in exists
1279 mkpath($d);
1280
Richard Levitte2e963842016-02-10 02:00:37 +01001281 my $res = abs2rel(catfile(absolutedir($d), $f), rel2abs($relativeto));
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001282 #print STDERR "DEBUG[cleanfile]: $d , $f => $res\n";
1283 return $res;
1284 }
1285
1286 my @build_infos = ( [ ".", "build.info" ] );
1287 foreach (@{$config{dirs}}) {
1288 push @build_infos, [ $_, "build.info" ]
1289 if (-f catfile($srcdir, $_, "build.info"));
1290 }
1291 foreach (@{$config{sdirs}}) {
1292 push @build_infos, [ catdir("crypto", $_), "build.info" ]
1293 if (-f catfile($srcdir, "crypto", $_, "build.info"));
1294 }
1295 foreach (@{$config{engdirs}}) {
1296 push @build_infos, [ catdir("engines", $_), "build.info" ]
1297 if (-f catfile($srcdir, "engines", $_, "build.info"));
1298 }
1299
Richard Levitte2e0956b2016-02-28 01:13:17 +01001300 $config{build_infos} = [ ];
1301
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001302 foreach (@build_infos) {
1303 my $sourced = catdir($srcdir, $_->[0]);
1304 my $buildd = catdir($blddir, $_->[0]);
1305
Richard Levittedca99382016-02-08 16:27:15 +01001306 mkpath($buildd);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001307
1308 my $f = $_->[1];
1309 # The basic things we're trying to build
1310 my @programs = ();
1311 my @libraries = ();
1312 my @engines = ();
1313 my @scripts = ();
1314 my @extra = ();
Richard Levitte8a679462016-03-07 14:50:37 +01001315 my @overrides = ();
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001316 my @intermediates = ();
1317 my @rawlines = ();
1318
1319 my %ordinals = ();
1320 my %sources = ();
Richard Levitte2a08d1a2016-03-29 16:45:03 +02001321 my %shared_sources = ();
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001322 my %includes = ();
1323 my %depends = ();
1324 my %renames = ();
1325 my %sharednames = ();
Richard Levitteae4c7452016-03-07 14:37:00 +01001326 my %generate = ();
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001327
Richard Levitte2e0956b2016-02-28 01:13:17 +01001328 push @{$config{build_infos}}, catfile(abs2rel($sourced, $blddir), $f);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001329 my $template = Text::Template->new(TYPE => 'FILE',
1330 SOURCE => catfile($sourced, $f));
1331 die "Something went wrong with $sourced/$f: $!\n" unless $template;
1332 my @text =
1333 split /^/m,
1334 $template->fill_in(HASH => { config => \%config,
1335 target => \%target,
Richard Levitte9e04edf2016-02-22 13:45:46 +01001336 disabled => \%disabled,
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001337 builddir => abs2rel($buildd, $blddir),
1338 sourcedir => abs2rel($sourced, $blddir),
1339 buildtop => abs2rel($blddir, $blddir),
1340 sourcetop => abs2rel($srcdir, $blddir) },
1341 DELIMITERS => [ "{-", "-}" ]);
1342
1343 # The top item of this stack has the following values
1344 # -2 positive already run and we found ELSE (following ELSIF should fail)
1345 # -1 positive already run (skip until ENDIF)
1346 # 0 negatives so far (if we're at a condition, check it)
1347 # 1 last was positive (don't skip lines until next ELSE, ELSIF or ENDIF)
1348 # 2 positive ELSE (following ELSIF should fail)
1349 my @skip = ();
1350 collect_information(
1351 collect_from_array([ @text ],
1352 qr/\\$/ => sub { my $l1 = shift; my $l2 = shift;
1353 $l1 =~ s/\\$//; $l1.$l2 }),
1354 # Info we're looking for
1355 qr/^\s*IF\[((?:\\.|[^\\\]])*)\]\s*$/
Richard Levitte635bd402016-03-09 14:33:37 +01001356 => sub {
Richard Levittec5798e02016-03-09 23:58:44 +01001357 if (! @skip || $skip[$#skip] > 0) {
Richard Levitte635bd402016-03-09 14:33:37 +01001358 push @skip, !! $1;
1359 } else {
1360 push @skip, -1;
1361 }
1362 },
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001363 qr/^\s*ELSIF\[((?:\\.|[^\\\]])*)\]\s*$/
1364 => sub { die "ELSIF out of scope" if ! @skip;
1365 die "ELSIF following ELSE" if abs($skip[$#skip]) == 2;
1366 $skip[$#skip] = -1 if $skip[$#skip] != 0;
1367 $skip[$#skip] = !! $1
1368 if $skip[$#skip] == 0; },
1369 qr/^\s*ELSE\s*$/
1370 => sub { die "ELSE out of scope" if ! @skip;
1371 $skip[$#skip] = -2 if $skip[$#skip] != 0;
1372 $skip[$#skip] = 2 if $skip[$#skip] == 0; },
1373 qr/^\s*ENDIF\s*$/
1374 => sub { die "ENDIF out of scope" if ! @skip;
1375 pop @skip; },
1376 qr/^\s*PROGRAMS\s*=\s*(.*)\s*$/
1377 => sub { push @programs, split(/\s+/, $1)
1378 if !@skip || $skip[$#skip] > 0 },
1379 qr/^\s*LIBS\s*=\s*(.*)\s*$/
1380 => sub { push @libraries, split(/\s+/, $1)
1381 if !@skip || $skip[$#skip] > 0 },
1382 qr/^\s*ENGINES\s*=\s*(.*)\s*$/
1383 => sub { push @engines, split(/\s+/, $1)
1384 if !@skip || $skip[$#skip] > 0 },
1385 qr/^\s*SCRIPTS\s*=\s*(.*)\s*$/
1386 => sub { push @scripts, split(/\s+/, $1)
1387 if !@skip || $skip[$#skip] > 0 },
1388 qr/^\s*EXTRA\s*=\s*(.*)\s*$/
1389 => sub { push @extra, split(/\s+/, $1)
1390 if !@skip || $skip[$#skip] > 0 },
Richard Levitte8a679462016-03-07 14:50:37 +01001391 qr/^\s*OVERRIDES\s*=\s*(.*)\s*$/
1392 => sub { push @overrides, split(/\s+/, $1)
1393 if !@skip || $skip[$#skip] > 0 },
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001394
1395 qr/^\s*ORDINALS\[((?:\\.|[^\\\]])+)\]\s*=\s*(.*)\s*$/,
1396 => sub { push @{$ordinals{$1}}, split(/\s+/, $2)
1397 if !@skip || $skip[$#skip] > 0 },
1398 qr/^\s*SOURCE\[((?:\\.|[^\\\]])+)\]\s*=\s*(.*)\s*$/
1399 => sub { push @{$sources{$1}}, split(/\s+/, $2)
1400 if !@skip || $skip[$#skip] > 0 },
Richard Levitte2a08d1a2016-03-29 16:45:03 +02001401 qr/^\s*SHARED_SOURCE\[((?:\\.|[^\\\]])+)\]\s*=\s*(.*)\s*$/
1402 => sub { push @{$shared_sources{$1}}, split(/\s+/, $2)
1403 if !@skip || $skip[$#skip] > 0 },
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001404 qr/^\s*INCLUDE\[((?:\\.|[^\\\]])+)\]\s*=\s*(.*)\s*$/
1405 => sub { push @{$includes{$1}}, split(/\s+/, $2)
1406 if !@skip || $skip[$#skip] > 0 },
1407 qr/^\s*DEPEND\[((?:\\.|[^\\\]])+)\]\s*=\s*(.*)\s*$/
1408 => sub { push @{$depends{$1}}, split(/\s+/, $2)
1409 if !@skip || $skip[$#skip] > 0 },
Richard Levitteae4c7452016-03-07 14:37:00 +01001410 qr/^\s*GENERATE\[((?:\\.|[^\\\]])+)\]\s*=\s*(.*)\s*$/
1411 => sub { push @{$generate{$1}}, $2
1412 if !@skip || $skip[$#skip] > 0 },
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001413 qr/^\s*RENAME\[((?:\\.|[^\\\]])+)\]\s*=\s*(.*)\s*$/
1414 => sub { push @{$renames{$1}}, split(/\s+/, $2)
1415 if !@skip || $skip[$#skip] > 0 },
1416 qr/^\s*SHARED_NAME\[((?:\\.|[^\\\]])+)\]\s*=\s*(.*)\s*$/
1417 => sub { push @{$sharednames{$1}}, split(/\s+/, $2)
1418 if !@skip || $skip[$#skip] > 0 },
1419 qr/^\s*BEGINRAW\[((?:\\.|[^\\\]])+)\]\s*$/
1420 => sub {
1421 my $lineiterator = shift;
1422 my $target_kind = $1;
1423 while (defined $lineiterator->()) {
Richard Levitte04f171c2016-02-12 12:10:27 +01001424 s|\R$||;
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001425 if (/^\s*ENDRAW\[((?:\\.|[^\\\]])+)\]\s*$/) {
1426 die "ENDRAW doesn't match BEGINRAW"
1427 if $1 ne $target_kind;
1428 last;
1429 }
1430 next if @skip && $skip[$#skip] <= 0;
1431 push @rawlines, $_
1432 if ($target_kind eq $target{build_file}
Richard Levitteddf18472016-01-30 00:57:33 +01001433 || $target_kind eq $target{build_file}."(".$builder_platform.")");
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001434 }
1435 },
1436 qr/^(?:#.*|\s*)$/ => sub { },
Richard Levitte2b6b6062016-03-10 00:04:04 +01001437 "OTHERWISE" => sub { die "Something wrong with this line:\n$_\nat $sourced/$f" },
1438 "BEFORE" => sub {
1439 if ($buildinfo_debug) {
1440 print STDERR "DEBUG: Parsing ",join(" ", @_),"\n";
1441 print STDERR "DEBUG: ... before parsing, skip stack is ",join(" ", map { int($_) } @skip),"\n";
1442 }
1443 },
1444 "AFTER" => sub {
1445 if ($buildinfo_debug) {
1446 print STDERR "DEBUG: .... after parsing, skip stack is ",join(" ", map { int($_) } @skip),"\n";
1447 }
1448 },
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001449 );
1450 die "runaway IF?" if (@skip);
1451
1452 foreach (keys %renames) {
1453 die "$_ renamed to more than one thing: "
1454 ,join(" ", @{$renames{$_}}),"\n"
1455 if scalar @{$renames{$_}} > 1;
Richard Levitte2e963842016-02-10 02:00:37 +01001456 my $dest = cleanfile($buildd, $_, $blddir);
1457 my $to = cleanfile($buildd, $renames{$_}->[0], $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001458 die "$dest renamed to more than one thing: "
1459 ,$unified_info{rename}->{$dest}, $to
1460 unless !defined($unified_info{rename}->{$dest})
1461 or $unified_info{rename}->{$dest} eq $to;
1462 $unified_info{rename}->{$dest} = $to;
1463 }
1464
1465 foreach (@programs) {
Richard Levitte2e963842016-02-10 02:00:37 +01001466 my $program = cleanfile($buildd, $_, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001467 if ($unified_info{rename}->{$program}) {
1468 $program = $unified_info{rename}->{$program};
1469 }
1470 $unified_info{programs}->{$program} = 1;
1471 }
1472
1473 foreach (@libraries) {
Richard Levitte2e963842016-02-10 02:00:37 +01001474 my $library = cleanfile($buildd, $_, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001475 if ($unified_info{rename}->{$library}) {
1476 $library = $unified_info{rename}->{$library};
1477 }
1478 $unified_info{libraries}->{$library} = 1;
1479 }
1480
Richard Levitte343ec2b2016-02-19 22:08:37 +01001481 die <<"EOF" if scalar @engines and !$config{dynamic_engines};
Richard Levitte19ab5792016-02-22 02:06:05 +01001482ENGINES can only be used if configured with 'dynamic-engine'.
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001483This is usually a fault in a build.info file.
1484EOF
1485 foreach (@engines) {
Richard Levitte2e963842016-02-10 02:00:37 +01001486 my $library = cleanfile($buildd, $_, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001487 if ($unified_info{rename}->{$library}) {
1488 $library = $unified_info{rename}->{$library};
1489 }
1490 $unified_info{engines}->{$library} = 1;
1491 }
1492
1493 foreach (@scripts) {
Richard Levitte2e963842016-02-10 02:00:37 +01001494 my $script = cleanfile($buildd, $_, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001495 if ($unified_info{rename}->{$script}) {
1496 $script = $unified_info{rename}->{$script};
1497 }
1498 $unified_info{scripts}->{$script} = 1;
1499 }
1500
1501 foreach (@extra) {
Richard Levitte2e963842016-02-10 02:00:37 +01001502 my $extra = cleanfile($buildd, $_, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001503 $unified_info{extra}->{$extra} = 1;
1504 }
1505
Richard Levitte8a679462016-03-07 14:50:37 +01001506 foreach (@overrides) {
1507 my $override = cleanfile($buildd, $_, $blddir);
1508 $unified_info{overrides}->{$override} = 1;
1509 }
1510
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001511 push @{$unified_info{rawlines}}, @rawlines;
1512
Richard Levitte84af1ba2016-02-22 13:52:46 +01001513 unless ($disabled{shared}) {
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001514 # Check sharednames.
1515 foreach (keys %sharednames) {
Richard Levitte2e963842016-02-10 02:00:37 +01001516 my $dest = cleanfile($buildd, $_, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001517 if ($unified_info{rename}->{$dest}) {
1518 $dest = $unified_info{rename}->{$dest};
1519 }
1520 die "shared_name for $dest with multiple values: "
1521 ,join(" ", @{$sharednames{$_}}),"\n"
1522 if scalar @{$sharednames{$_}} > 1;
Richard Levitte2e963842016-02-10 02:00:37 +01001523 my $to = cleanfile($buildd, $sharednames{$_}->[0], $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001524 die "shared_name found for a library $dest that isn't defined\n"
1525 unless $unified_info{libraries}->{$dest};
1526 die "shared_name for $dest with multiple values: "
1527 ,$unified_info{sharednames}->{$dest}, ", ", $to
1528 unless !defined($unified_info{sharednames}->{$dest})
1529 or $unified_info{sharednames}->{$dest} eq $to;
1530 $unified_info{sharednames}->{$dest} = $to;
1531 }
1532
1533 # Additionally, we set up sharednames for libraries that don't
1534 # have any, as themselves.
1535 foreach (keys %{$unified_info{libraries}}) {
1536 if (!defined $unified_info{sharednames}->{$_}) {
1537 $unified_info{sharednames}->{$_} = $_
1538 }
1539 }
1540 }
1541
1542 foreach (keys %ordinals) {
1543 my $dest = $_;
Richard Levitte2e963842016-02-10 02:00:37 +01001544 my $ddest = cleanfile($buildd, $_, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001545 if ($unified_info{rename}->{$ddest}) {
1546 $ddest = $unified_info{rename}->{$ddest};
1547 }
1548 foreach (@{$ordinals{$dest}}) {
1549 my %known_ordinals =
1550 (
1551 crypto =>
Richard Levitte6928b612016-03-03 12:42:01 +01001552 cleanfile($sourced, catfile("util", "libcrypto.num"), $blddir),
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001553 ssl =>
Richard Levitte6928b612016-03-03 12:42:01 +01001554 cleanfile($sourced, catfile("util", "libssl.num"), $blddir)
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001555 );
1556 my $o = $known_ordinals{$_};
1557 die "Ordinals for $ddest defined more than once\n"
1558 if $unified_info{ordinals}->{$ddest};
1559 $unified_info{ordinals}->{$ddest} = [ $_, $o ];
1560 }
1561 }
1562
1563 foreach (keys %sources) {
1564 my $dest = $_;
Richard Levitte2e963842016-02-10 02:00:37 +01001565 my $ddest = cleanfile($buildd, $_, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001566 if ($unified_info{rename}->{$ddest}) {
1567 $ddest = $unified_info{rename}->{$ddest};
1568 }
1569 foreach (@{$sources{$dest}}) {
Richard Levitte2e963842016-02-10 02:00:37 +01001570 my $s = cleanfile($sourced, $_, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001571
1572 # If it isn't in the source tree, we assume it's generated
1573 # in the build tree
1574 if (! -f $s) {
Richard Levitte2e963842016-02-10 02:00:37 +01001575 $s = cleanfile($buildd, $_, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001576 }
1577 # We recognise C and asm files
1578 if ($s =~ /\.[csS]\b$/) {
1579 (my $o = $_) =~ s/\.[csS]\b$/.o/;
Richard Levitte2e963842016-02-10 02:00:37 +01001580 $o = cleanfile($buildd, $o, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001581 $unified_info{sources}->{$ddest}->{$o} = 1;
1582 $unified_info{sources}->{$o}->{$s} = 1;
1583 } else {
1584 $unified_info{sources}->{$ddest}->{$s} = 1;
1585 }
1586 }
1587 }
1588
Richard Levitte2a08d1a2016-03-29 16:45:03 +02001589 foreach (keys %shared_sources) {
1590 my $dest = $_;
1591 my $ddest = cleanfile($buildd, $_, $blddir);
1592 if ($unified_info{rename}->{$ddest}) {
1593 $ddest = $unified_info{rename}->{$ddest};
1594 }
1595 foreach (@{$shared_sources{$dest}}) {
1596 my $s = cleanfile($sourced, $_, $blddir);
1597
1598 # If it isn't in the source tree, we assume it's generated
1599 # in the build tree
1600 if (! -f $s) {
1601 $s = cleanfile($buildd, $_, $blddir);
1602 }
1603 # We recognise C and asm files
1604 if ($s =~ /\.[csS]\b$/) {
1605 (my $o = $_) =~ s/\.[csS]\b$/.o/;
1606 $o = cleanfile($buildd, $o, $blddir);
1607 $unified_info{shared_sources}->{$ddest}->{$o} = 1;
1608 $unified_info{sources}->{$o}->{$s} = 1;
1609 } else {
1610 die "unrecognised source file type for shared library: $s\n";
1611 }
1612 }
1613 }
1614
Richard Levitteae4c7452016-03-07 14:37:00 +01001615 foreach (keys %generate) {
1616 my $dest = $_;
1617 my $ddest = cleanfile($buildd, $_, $blddir);
1618 if ($unified_info{rename}->{$ddest}) {
1619 $ddest = $unified_info{rename}->{$ddest};
1620 }
1621 die "more than one generator for $dest: "
1622 ,join(" ", @{$generate{$_}}),"\n"
1623 if scalar @{$generate{$_}} > 1;
1624 my @generator = split /\s+/, $generate{$dest}->[0];
1625 $generator[0] = cleanfile($sourced, $generator[0], $blddir),
1626 $unified_info{generate}->{$ddest} = [ @generator ];
1627 }
1628
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001629 foreach (keys %depends) {
1630 my $dest = $_;
Richard Levitte2e963842016-02-10 02:00:37 +01001631 my $ddest = cleanfile($buildd, $_, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001632 if ($unified_info{rename}->{$ddest}) {
1633 $ddest = $unified_info{rename}->{$ddest};
1634 }
1635 foreach (@{$depends{$dest}}) {
Richard Levitte2e963842016-02-10 02:00:37 +01001636 my $d = cleanfile($sourced, $_, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001637
Richard Levittee737d7b2016-02-11 15:22:27 +01001638 # If we know it's generated, or assume it is because we can't
1639 # find it in the source tree, we set file we depend on to be
1640 # in the build tree rather than the source tree, and assume
1641 # and that there are lines to build it in a BEGINRAW..ENDRAW
1642 # section or in the Makefile template.
1643 if (! -f $d
Richard Levitteda1f2102016-03-19 01:29:01 +01001644 || (grep { $d eq $_ }
1645 map { cleanfile($srcdir, $_, $blddir) }
1646 (@generated_headers, @generated_by_make_headers))) {
Richard Levitte2e963842016-02-10 02:00:37 +01001647 $d = cleanfile($buildd, $_, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001648 }
1649 # Take note if the file to depend on is being renamed
1650 if ($unified_info{rename}->{$d}) {
1651 $d = $unified_info{rename}->{$d};
1652 }
1653 $unified_info{depends}->{$ddest}->{$d} = 1;
1654 # If we depend on a header file, let's make sure it
1655 # can get included
1656 if ($d =~ /\.h$/) {
1657 my $i = dirname($d);
1658 push @{$unified_info{includes}->{$ddest}}, $i
1659 unless grep { $_ eq $i } @{$unified_info{includes}->{$ddest}};
1660 }
1661 }
1662 }
1663
1664 foreach (keys %includes) {
1665 my $dest = $_;
Richard Levitte2e963842016-02-10 02:00:37 +01001666 my $ddest = cleanfile($buildd, $_, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001667 if ($unified_info{rename}->{$ddest}) {
1668 $ddest = $unified_info{rename}->{$ddest};
1669 }
1670 foreach (@{$includes{$dest}}) {
Richard Levitte2e963842016-02-10 02:00:37 +01001671 my $i = cleandir($sourced, $_, $blddir);
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001672 push @{$unified_info{includes}->{$ddest}}, $i
1673 unless grep { $_ eq $i } @{$unified_info{includes}->{$ddest}};
1674 }
1675 }
1676 }
1677
1678 ### Make unified_info a bit more efficient
1679 # One level structures
Richard Levitte8a679462016-03-07 14:50:37 +01001680 foreach (("programs", "libraries", "engines", "scripts", "extra", "overrides")) {
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001681 $unified_info{$_} = [ sort keys %{$unified_info{$_}} ];
1682 }
1683 # Two level structures
Richard Levitte2a08d1a2016-03-29 16:45:03 +02001684 foreach my $l1 (("sources", "shared_sources", "ldadd", "depends")) {
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001685 foreach my $l2 (sort keys %{$unified_info{$l1}}) {
1686 $unified_info{$l1}->{$l2} =
1687 [ sort keys %{$unified_info{$l1}->{$l2}} ];
1688 }
1689 }
1690}
1691
1692# For the schemes that need it, we provide the old *_obj configs
1693# from the *_asm_obj ones
Richard Levitte3a55c922016-02-18 18:43:56 +01001694foreach (grep /_(asm|aux)_src$/, keys %target) {
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001695 my $src = $_;
Richard Levitte3a55c922016-02-18 18:43:56 +01001696 (my $obj = $_) =~ s/_(asm|aux)_src$/_obj/;
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001697 ($target{$obj} = $target{$src}) =~ s/\.[csS]\b/.o/g;
1698}
1699
Richard Levitte291e94d2015-05-18 22:35:23 +02001700# Write down our configuration where it fits #########################
1701
1702open(OUT,">configdata.pm") || die "unable to create configdata.pm: $!\n";
1703print OUT <<"EOF";
1704package configdata;
1705
1706use strict;
1707use warnings;
1708
1709use Exporter;
1710#use vars qw(\@ISA \@EXPORT);
1711our \@ISA = qw(Exporter);
Richard Levitte3850f8c2016-03-19 00:41:14 +01001712our \@EXPORT = qw(\%config \%target \%disabled \%withargs \%unified_info \@disablables);
Richard Levitte291e94d2015-05-18 22:35:23 +02001713
1714EOF
1715print OUT "our %config = (\n";
1716foreach (sort keys %config) {
1717 if (ref($config{$_}) eq "ARRAY") {
1718 print OUT " ", $_, " => [ ", join(", ",
1719 map { quotify("perl", $_) }
1720 @{$config{$_}}), " ],\n";
1721 } else {
1722 print OUT " ", $_, " => ", quotify("perl", $config{$_}), ",\n"
1723 }
1724}
1725print OUT <<"EOF";
1726);
1727
1728EOF
1729print OUT "our %target = (\n";
1730foreach (sort keys %target) {
1731 if (ref($target{$_}) eq "ARRAY") {
1732 print OUT " ", $_, " => [ ", join(", ",
1733 map { quotify("perl", $_) }
1734 @{$target{$_}}), " ],\n";
1735 } else {
1736 print OUT " ", $_, " => ", quotify("perl", $target{$_}), ",\n"
1737 }
1738}
1739print OUT <<"EOF";
1740);
1741
Richard Levitte107b5792015-05-20 20:03:20 +02001742EOF
Richard Levitte96d2d7b2016-01-26 02:09:33 +01001743print OUT "our \%available_protocols = (\n";
1744print OUT " tls => [ ", join(", ", map { quotify("perl", $_) } @tls), " ],\n";
1745print OUT " dtls => [ ", join(", ", map { quotify("perl", $_) } @dtls), " ],\n";
1746print OUT <<"EOF";
1747);
1748
1749EOF
Richard Levitte3850f8c2016-03-19 00:41:14 +01001750print OUT "our \@disablables = (\n";
1751foreach (@disablables) {
1752 print OUT " ", quotify("perl", $_), ",\n";
1753}
1754print OUT <<"EOF";
1755);
1756
1757EOF
Richard Levitte96d2d7b2016-01-26 02:09:33 +01001758print OUT "our \%disabled = (\n";
1759foreach (sort keys %disabled) {
1760 print OUT " ", quotify("perl", $_), " => ", quotify("perl", $disabled{$_}), ",\n";
1761}
1762print OUT <<"EOF";
1763);
1764
1765EOF
Richard Levitte107b5792015-05-20 20:03:20 +02001766print OUT "our %withargs = (\n";
1767foreach (sort keys %withargs) {
1768 if (ref($withargs{$_}) eq "ARRAY") {
1769 print OUT " ", $_, " => [ ", join(", ",
1770 map { quotify("perl", $_) }
1771 @{$withargs{$_}}), " ],\n";
1772 } else {
1773 print OUT " ", $_, " => ", quotify("perl", $withargs{$_}), ",\n"
1774 }
1775}
1776print OUT <<"EOF";
1777);
1778
Richard Levitte291e94d2015-05-18 22:35:23 +02001779EOF
Richard Levitteddf18472016-01-30 00:57:33 +01001780if ($builder eq "unified") {
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001781 my $recurse;
1782 $recurse = sub {
1783 my $indent = shift;
1784 foreach (@_) {
1785 if (ref $_ eq "ARRAY") {
1786 print OUT " "x$indent, "[\n";
1787 foreach (@$_) {
1788 $recurse->($indent + 4, $_);
1789 }
1790 print OUT " "x$indent, "],\n";
1791 } elsif (ref $_ eq "HASH") {
1792 my %h = %$_;
1793 print OUT " "x$indent, "{\n";
1794 foreach (sort keys %h) {
1795 if (ref $h{$_} eq "") {
1796 print OUT " "x($indent + 4), quotify("perl", $_), " => ", quotify("perl", $h{$_}), ",\n";
1797 } else {
1798 print OUT " "x($indent + 4), quotify("perl", $_), " =>\n";
1799 $recurse->($indent + 8, $h{$_});
1800 }
1801 }
1802 print OUT " "x$indent, "},\n";
1803 } else {
1804 print OUT " "x$indent, quotify("perl", $_), ",\n";
1805 }
1806 }
1807 };
1808 print OUT "our %unified_info = (\n";
1809 foreach (sort keys %unified_info) {
1810 if (ref $unified_info{$_} eq "") {
1811 print OUT " "x4, quotify("perl", $_), " => ", quotify("perl", $unified_info{$_}), ",\n";
1812 } else {
1813 print OUT " "x4, quotify("perl", $_), " =>\n";
1814 $recurse->(8, $unified_info{$_});
1815 }
1816 }
1817 print OUT <<"EOF";
1818);
1819
1820EOF
1821}
1822print OUT "1;\n";
Richard Levitte291e94d2015-05-18 22:35:23 +02001823close(OUT);
1824
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001825
Richard Levitte291e94d2015-05-18 22:35:23 +02001826print "CC =$target{cc}\n";
Richard Levitte2952b9b2016-03-02 10:57:05 +01001827print "CFLAG =$target{cflags} $config{cflags}\n";
Richard Levitte63ee71292016-03-04 15:41:42 +01001828print "SHARED_CFLAG =$target{shared_cflag}\n";
Richard Levitte2952b9b2016-03-02 10:57:05 +01001829print "DEFINES =",join(" ", @{$target{defines}}, @{$config{defines}}),"\n";
Richard Levitte940a09b2016-02-27 11:42:13 +01001830print "LFLAG =$target{lflags}\n";
1831print "PLIB_LFLAG =$target{plib_lflags}\n";
Richard Levitte2952b9b2016-03-02 10:57:05 +01001832print "EX_LIBS =$target{ex_libs} $config{ex_libs}\n";
Richard Levitteb7569672016-03-02 09:34:26 +01001833print "APPS_OBJ =$target{apps_obj}\n";
Richard Levitte291e94d2015-05-18 22:35:23 +02001834print "CPUID_OBJ =$target{cpuid_obj}\n";
Richard Levitteb7569672016-03-02 09:34:26 +01001835print "UPLINK_OBJ =$target{uplink_obj}\n";
Richard Levitte291e94d2015-05-18 22:35:23 +02001836print "BN_ASM =$target{bn_obj}\n";
1837print "EC_ASM =$target{ec_obj}\n";
1838print "DES_ENC =$target{des_obj}\n";
1839print "AES_ENC =$target{aes_obj}\n";
1840print "BF_ENC =$target{bf_obj}\n";
1841print "CAST_ENC =$target{cast_obj}\n";
1842print "RC4_ENC =$target{rc4_obj}\n";
1843print "RC5_ENC =$target{rc5_obj}\n";
1844print "MD5_OBJ_ASM =$target{md5_obj}\n";
1845print "SHA1_OBJ_ASM =$target{sha1_obj}\n";
1846print "RMD160_OBJ_ASM=$target{rmd160_obj}\n";
1847print "CMLL_ENC =$target{cmll_obj}\n";
1848print "MODES_OBJ =$target{modes_obj}\n";
Richard Levittef0bd4682016-01-25 21:51:22 +01001849print "PADLOCK_OBJ =$target{padlock_obj}\n";
Richard Levitte291e94d2015-05-18 22:35:23 +02001850print "CHACHA_ENC =$target{chacha_obj}\n";
1851print "POLY1305_OBJ =$target{poly1305_obj}\n";
Bill Cox2d0b4412016-03-09 23:08:31 +01001852print "BLAKE2_OBJ =$target{blake2_obj}\n";
Richard Levitte7d130f62015-05-19 01:40:54 +02001853print "PROCESSOR =$config{processor}\n";
Richard Levitte291e94d2015-05-18 22:35:23 +02001854print "RANLIB =$target{ranlib}\n";
1855print "ARFLAGS =$target{arflags}\n";
1856print "PERL =$config{perl}\n";
Richard Levittef0bd4682016-01-25 21:51:22 +01001857print "\n";
Richard Levitte7d130f62015-05-19 01:40:54 +02001858print "SIXTY_FOUR_BIT_LONG mode\n" if $config{b64l};
1859print "SIXTY_FOUR_BIT mode\n" if $config{b64};
1860print "THIRTY_TWO_BIT mode\n" if $config{b32};
Richard Levitte7d130f62015-05-19 01:40:54 +02001861print "BN_LLONG mode\n" if $config{bn_ll};
Richard Levitte01d99972016-03-14 10:02:13 +01001862print "RC4 uses $config{rc4_int}\n" if $config{rc4_int} ne $def_int;
Ben Lauriecba50681999-03-07 14:05:36 +00001863
Richard Levittee737d7b2016-02-11 15:22:27 +01001864for (@generated_headers) {
1865 mkpath(catdir($blddir, dirname($_)));
1866 run_dofile(catfile($blddir, $_),
1867 catfile($srcdir, $_.".in"));
Richard Levittef0bd4682016-01-25 21:51:22 +01001868}
1869
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001870###
1871### When the old "unixmake" scheme goes away, so does this function
1872###
1873sub build_Makefile {
1874 run_dofile("Makefile","Makefile.in");
1875
1876 # Copy all Makefile.in to Makefile (except top-level)
1877 use File::Find;
1878 use IO::File;
1879 find(
1880 {
1881 preprocess => sub {
1882 grep(!/^\./, @_);
1883 },
1884 wanted => sub {
1885 return if ($_ ne "Makefile.in" || $File::Find::dir eq ".");
1886 my $in = IO::File->new($_, "r") or
1887 die sprintf "Error reading Makefile.in in %s: !$\n",
1888 $File::Find::dir;
1889 my $out = IO::File->new("Makefile", "w") or
1890 die sprintf "Error writing Makefile in %s: !$\n",
1891 $File::Find::dir;
1892 print $out "# Generated from $_, do not edit\n";
1893 while (my $line = <$in>) { print $out $line }
1894 $in->close() or
1895 die sprintf "Error reading Makefile.in in %s: !$\n",
1896 $File::Find::dir;
1897 $out->close() or
1898 die sprintf "Error writing Makefile in %s: !$\n",
1899 $File::Find::dir;
1900 },
Richard Levittefb36ca12016-01-31 11:51:07 +01001901 },
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001902 ".");
1903}
Rich Salzd10dac12016-01-12 16:25:30 -05001904
Richard Levitte88087412015-05-18 14:31:49 +02001905my %builders = (
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001906 unified => sub {
Richard Levitteddf18472016-01-30 00:57:33 +01001907 run_dofile(catfile($blddir, $target{build_file}),
1908 $config{build_file_template},
1909 catfile($srcdir, "Configurations", "common.tmpl"));
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001910 },
Richard Levitte88087412015-05-18 14:31:49 +02001911 unixmake => sub {
Richard Levitte9fe2bb72016-01-29 19:45:51 +01001912 build_Makefile();
1913
1914 run_dofile("util/domd", "util/domd.in");
1915 chmod 0755, "util/domd";
Richard Levitte88087412015-05-18 14:31:49 +02001916 },
Richard Levitte88087412015-05-18 14:31:49 +02001917 );
1918
Richard Levitteddf18472016-01-30 00:57:33 +01001919$builders{$builder}->($builder_platform, @builder_opts);
Felix Laurie von Massenbachfce0ba52014-05-26 17:19:28 +01001920
Richard Levitte76ffb432015-05-18 02:46:21 +02001921print <<"EOF";
Bodo Möller63d3f441999-09-09 20:21:10 +00001922
Ulf Möller89ec98e2000-02-01 01:35:29 +00001923Configured for $target.
Bodo Möller63d3f441999-09-09 20:21:10 +00001924EOF
Bodo Möller5f8d5c91999-04-29 16:10:09 +00001925
Richard Levitte9c62a272016-02-27 16:51:34 +01001926print <<"EOF" if ($disabled{threads} eq "unavailable");
Bodo Möller5f8d5c91999-04-29 16:10:09 +00001927
1928The library could not be configured for supporting multi-threaded
1929applications as the compiler options required on this system are not known.
Bodo Möllerff1b7e01999-06-26 21:25:01 +00001930See file INSTALL for details if you need multi-threading.
Bodo Möllerec577821999-04-23 22:13:45 +00001931EOF
1932
Richard Levitte76ffb432015-05-18 02:46:21 +02001933print <<"EOF" if ($no_shared_warn);
Richard Levitte2964ba82003-01-11 11:40:39 +00001934
Richard Levitteae482422016-02-22 02:09:11 +01001935The options 'shared', 'pic' and 'dynamic-engine' aren't supported on this
1936platform, so we will pretend you gave the option 'no-pic', which also disables
1937'shared' and 'dynamic-engine'. If you know how to implement shared libraries
1938or position independent code, please let us know (but please first make sure
1939you have tried with a current version of OpenSSL).
Rich Salz2e31ef02015-12-10 12:31:01 -05001940EOF
1941
Ralf S. Engelschalld02b48c1998-12-21 10:52:47 +00001942exit(0);
1943
Richard Levittebd5192b2015-05-18 02:57:24 +02001944######################################################################
1945#
1946# Helpers and utility functions
1947#
1948
1949# Configuration file reading #########################################
1950
Richard Levitte1f2e1cd2016-03-17 09:09:31 +01001951# Note: All of the helper functions are for lazy evaluation. They all
1952# return a CODE ref, which will return the intended value when evaluated.
1953# Thus, whenever there's mention of a returned value, it's about that
1954# intended value.
1955
Richard Levittebd5192b2015-05-18 02:57:24 +02001956# Helper function to implement conditional inheritance depending on the
Richard Levitte00b0d662016-02-22 14:10:45 +01001957# value of $disabled{asm}. Used in inherit_from values as follows:
Richard Levittebd5192b2015-05-18 02:57:24 +02001958#
1959# inherit_from => [ "template", asm("asm_tmpl") ]
1960#
1961sub asm {
1962 my @x = @_;
1963 sub {
Richard Levitte00b0d662016-02-22 14:10:45 +01001964 $disabled{asm} ? () : @x;
Richard Levittebd5192b2015-05-18 02:57:24 +02001965 }
1966}
1967
Richard Levitte1f2e1cd2016-03-17 09:09:31 +01001968# Helper function to implement conditional value variants, with a default
1969# plus additional values based on the value of $config{build_type}.
1970# Arguments are given in hash table form:
1971#
1972# picker(default => "Basic string: ",
1973# debug => "debug",
1974# release => "release")
1975#
1976# When configuring with --debug, the resulting string will be
1977# "Basic string: debug", and when not, it will be "Basic string: release"
1978#
1979# This can be used to create variants of sets of flags according to the
1980# build type:
1981#
1982# cflags => picker(default => "-Wall",
1983# debug => "-g -O0",
1984# release => "-O3")
1985#
1986sub picker {
1987 my %opts = @_;
1988 return sub { add($opts{default} || (),
1989 $opts{$config{build_type}} || ())->(); }
1990}
1991
1992# Helper function to combine several values of different types into one.
1993# This is useful if you want to combine a string with the result of a
1994# lazy function, such as:
1995#
1996# cflags => combine("-Wall", sub { $disabled{zlib} ? () : "-DZLIB" })
1997#
1998sub combine {
1999 my @stuff = @_;
2000 return sub { add(@stuff)->(); }
2001}
2002
2003# Helper function to implement conditional values depending on the value
2004# of $disabled{threads}. Can be used as follows:
2005#
2006# cflags => combine("-Wall", threads("-pthread"))
2007#
2008sub threads {
2009 my @flags = @_;
2010 return sub { add($disabled{threads} ? () : @flags)->(); }
2011}
2012
2013
2014
Richard Levitte9c62a272016-02-27 16:51:34 +01002015our $add_called = 0;
Richard Levitte88087412015-05-18 14:31:49 +02002016# Helper function to implement adding values to already existing configuration
2017# values. It handles elements that are ARRAYs, CODEs and scalars
2018sub _add {
2019 my $separator = shift;
2020
Richard Levittebcb19772016-01-30 02:17:05 +01002021 # If there's any ARRAY in the collection of values OR the separator
2022 # is undef, we will return an ARRAY of combined values, otherwise a
2023 # string of joined values with $separator as the separator.
2024 my $found_array = !defined($separator);
Richard Levitte88087412015-05-18 14:31:49 +02002025
2026 my @values =
2027 map {
Richard Levitteb0b92a52016-02-27 11:08:21 +01002028 my $res = $_;
2029 while (ref($res) eq "CODE") {
2030 $res = $res->();
2031 }
2032 if (defined($res)) {
2033 if (ref($res) eq "ARRAY") {
2034 $found_array = 1;
2035 @$res;
2036 } else {
2037 $res;
2038 }
Richard Levitte88087412015-05-18 14:31:49 +02002039 } else {
Richard Levitteb0b92a52016-02-27 11:08:21 +01002040 ();
Richard Levitte88087412015-05-18 14:31:49 +02002041 }
2042 } (@_);
2043
Richard Levitte9c62a272016-02-27 16:51:34 +01002044 $add_called = 1;
2045
Richard Levitte88087412015-05-18 14:31:49 +02002046 if ($found_array) {
2047 [ @values ];
2048 } else {
Richard Levitteb0b92a52016-02-27 11:08:21 +01002049 join($separator, grep { defined($_) && $_ ne "" } @values);
Richard Levitte88087412015-05-18 14:31:49 +02002050 }
2051}
2052sub add_before {
Richard Levittebdcd83e2016-02-25 00:17:59 +01002053 my $separator = " ";
2054 if (ref($_[$#_]) eq "HASH") {
2055 my $opts = pop;
2056 $separator = $opts->{separator};
2057 }
Richard Levitte88087412015-05-18 14:31:49 +02002058 my @x = @_;
2059 sub { _add($separator, @x, @_) };
2060}
2061sub add {
Richard Levittebdcd83e2016-02-25 00:17:59 +01002062 my $separator = " ";
2063 if (ref($_[$#_]) eq "HASH") {
2064 my $opts = pop;
2065 $separator = $opts->{separator};
2066 }
Richard Levitte88087412015-05-18 14:31:49 +02002067 my @x = @_;
2068 sub { _add($separator, @_, @x) };
2069}
2070
Richard Levittebd5192b2015-05-18 02:57:24 +02002071# configuration reader, evaluates the input file as a perl script and expects
2072# it to fill %targets with target configurations. Those are then added to
2073# %table.
2074sub read_config {
2075 my $fname = shift;
2076 open(CONFFILE, "< $fname")
2077 or die "Can't open configuration file '$fname'!\n";
2078 my $x = $/;
2079 undef $/;
2080 my $content = <CONFFILE>;
2081 $/ = $x;
2082 close(CONFFILE);
2083 my %targets = ();
2084 {
2085 local %table = %::table; # Protect %table from tampering
2086
2087 eval $content;
2088 warn $@ if $@;
2089 }
2090
2091 # For each target, check that it's configured with a hash table.
2092 foreach (keys %targets) {
2093 if (ref($targets{$_}) ne "HASH") {
2094 if (ref($targets{$_}) eq "") {
2095 warn "Deprecated target configuration for $_, ignoring...\n";
2096 } else {
2097 warn "Misconfigured target configuration for $_ (should be a hash table), ignoring...\n";
2098 }
2099 delete $targets{$_};
2100 }
2101 }
2102
2103 %table = (%table, %targets);
2104
2105}
2106
Rich Salze771eea2016-04-04 16:11:43 -04002107# configuration resolver. Will only resolve all the lazy evalutation
2108# codeblocks for the chozen target and all those it inherits from,
Richard Levittebd5192b2015-05-18 02:57:24 +02002109# recursively
2110sub resolve_config {
2111 my $target = shift;
2112 my @breadcrumbs = @_;
2113
Richard Levittec4718842016-03-09 17:18:07 +01002114# my $extra_checks = defined($ENV{CONFIGURE_EXTRA_CHECKS});
Richard Levitte9c62a272016-02-27 16:51:34 +01002115
Richard Levittebd5192b2015-05-18 02:57:24 +02002116 if (grep { $_ eq $target } @breadcrumbs) {
2117 die "inherit_from loop! target backtrace:\n "
2118 ,$target,"\n ",join("\n ", @breadcrumbs),"\n";
2119 }
2120
2121 if (!defined($table{$target})) {
2122 warn "Warning! target $target doesn't exist!\n";
2123 return ();
2124 }
2125 # Recurse through all inheritances. They will be resolved on the
2126 # fly, so when this operation is done, they will all just be a
2127 # bunch of attributes with string values.
2128 # What we get here, though, are keys with references to lists of
2129 # the combined values of them all. We will deal with lists after
2130 # this stage is done.
2131 my %combined_inheritance = ();
2132 if ($table{$target}->{inherit_from}) {
2133 my @inherit_from =
2134 map { ref($_) eq "CODE" ? $_->() : $_ } @{$table{$target}->{inherit_from}};
2135 foreach (@inherit_from) {
2136 my %inherited_config = resolve_config($_, $target, @breadcrumbs);
2137
2138 # 'template' is a marker that's considered private to
2139 # the config that had it.
2140 delete $inherited_config{template};
2141
Richard Levitte2110feb2016-04-06 15:02:57 +02002142 foreach (keys %inherited_config) {
Richard Levittebd5192b2015-05-18 02:57:24 +02002143 if (!$combined_inheritance{$_}) {
2144 $combined_inheritance{$_} = [];
2145 }
2146 push @{$combined_inheritance{$_}}, $inherited_config{$_};
Richard Levitte2110feb2016-04-06 15:02:57 +02002147 }
Richard Levittebd5192b2015-05-18 02:57:24 +02002148 }
2149 }
2150
2151 # We won't need inherit_from in this target any more, since we've
2152 # resolved all the inheritances that lead to this
2153 delete $table{$target}->{inherit_from};
2154
2155 # Now is the time to deal with those lists. Here's the place to
2156 # decide what shall be done with those lists, all based on the
2157 # values of the target we're currently dealing with.
2158 # - If a value is a coderef, it will be executed with the list of
2159 # inherited values as arguments.
2160 # - If the corresponding key doesn't have a value at all or is the
Rich Salze771eea2016-04-04 16:11:43 -04002161 # emoty string, the inherited value list will be run through the
Richard Levittebd5192b2015-05-18 02:57:24 +02002162 # default combiner (below), and the result becomes this target's
2163 # value.
2164 # - Otherwise, this target's value is assumed to be a string that
2165 # will simply override the inherited list of values.
Richard Levittea26d8be2016-02-26 12:25:13 +01002166 my $default_combiner = add();
Richard Levittebd5192b2015-05-18 02:57:24 +02002167
2168 my %all_keys =
2169 map { $_ => 1 } (keys %combined_inheritance,
2170 keys %{$table{$target}});
Richard Levitteb0b92a52016-02-27 11:08:21 +01002171
2172 sub process_values {
2173 my $object = shift;
2174 my $inherited = shift; # Always a [ list ]
2175 my $target = shift;
2176 my $entry = shift;
2177
Richard Levitte9c62a272016-02-27 16:51:34 +01002178 $add_called = 0;
2179
Richard Levitteb0b92a52016-02-27 11:08:21 +01002180 while(ref($object) eq "CODE") {
2181 $object = $object->(@$inherited);
2182 }
2183 if (!defined($object)) {
2184 return ();
2185 }
2186 elsif (ref($object) eq "ARRAY") {
Richard Levitte9c62a272016-02-27 16:51:34 +01002187 local $add_called; # To make sure recursive calls don't affect it
Richard Levitteb0b92a52016-02-27 11:08:21 +01002188 return [ map { process_values($_, $inherited, $target, $entry) }
2189 @$object ];
2190 } elsif (ref($object) eq "") {
2191 return $object;
2192 } else {
2193 die "cannot handle reference type ",ref($object)
2194 ," found in target ",$target," -> ",$entry,"\n";
2195 }
2196 }
2197
Richard Levittebd5192b2015-05-18 02:57:24 +02002198 foreach (sort keys %all_keys) {
Richard Levitte9c62a272016-02-27 16:51:34 +01002199 my $previous = $combined_inheritance{$_};
Richard Levittebd5192b2015-05-18 02:57:24 +02002200
2201 # Current target doesn't have a value for the current key?
2202 # Assign it the default combiner, the rest of this loop body
2203 # will handle it just like any other coderef.
2204 if (!exists $table{$target}->{$_}) {
2205 $table{$target}->{$_} = $default_combiner;
2206 }
2207
Richard Levitteb0b92a52016-02-27 11:08:21 +01002208 $table{$target}->{$_} = process_values($table{$target}->{$_},
2209 $combined_inheritance{$_},
2210 $target, $_);
2211 unless(defined($table{$target}->{$_})) {
2212 delete $table{$target}->{$_};
2213 }
Richard Levittec4718842016-03-09 17:18:07 +01002214# if ($extra_checks &&
2215# $previous && !($add_called || $previous ~~ $table{$target}->{$_})) {
2216# warn "$_ got replaced in $target\n";
2217# }
Richard Levittebd5192b2015-05-18 02:57:24 +02002218 }
2219
2220 # Finally done, return the result.
2221 return %{$table{$target}};
2222}
2223
Ulf Möller462ba4f1999-04-24 22:59:36 +00002224sub usage
Ralf S. Engelschalld02b48c1998-12-21 10:52:47 +00002225 {
Ulf Möller462ba4f1999-04-24 22:59:36 +00002226 print STDERR $usage;
Ulf Möller10a926c2000-02-21 00:55:45 +00002227 print STDERR "\npick os/compiler from:\n";
Ben Laurie1641cb61998-12-28 17:08:48 +00002228 my $j=0;
Ben Laurie6457ad11999-02-07 18:22:15 +00002229 my $i;
Ulf Möller10a926c2000-02-21 00:55:45 +00002230 my $k=0;
Ben Laurie6457ad11999-02-07 18:22:15 +00002231 foreach $i (sort keys %table)
Ralf S. Engelschalld02b48c1998-12-21 10:52:47 +00002232 {
Richard Levittebd5192b2015-05-18 02:57:24 +02002233 next if $table{$i}->{template};
Ulf Möller462ba4f1999-04-24 22:59:36 +00002234 next if $i =~ /^debug/;
Ulf Möller10a926c2000-02-21 00:55:45 +00002235 $k += length($i) + 1;
2236 if ($k > 78)
2237 {
2238 print STDERR "\n";
2239 $k=length($i);
2240 }
2241 print STDERR $i . " ";
Ulf Möller462ba4f1999-04-24 22:59:36 +00002242 }
2243 foreach $i (sort keys %table)
2244 {
Richard Levittebd5192b2015-05-18 02:57:24 +02002245 next if $table{$i}->{template};
Ulf Möller462ba4f1999-04-24 22:59:36 +00002246 next if $i !~ /^debug/;
Ulf Möller10a926c2000-02-21 00:55:45 +00002247 $k += length($i) + 1;
2248 if ($k > 78)
2249 {
2250 print STDERR "\n";
2251 $k=length($i);
2252 }
2253 print STDERR $i . " ";
Ralf S. Engelschalld02b48c1998-12-21 10:52:47 +00002254 }
Ulf Möller10a926c2000-02-21 00:55:45 +00002255 print STDERR "\n\nNOTE: If in doubt, on Unix-ish systems use './config'.\n";
Ulf Möller462ba4f1999-04-24 22:59:36 +00002256 exit(1);
Ralf S. Engelschalld02b48c1998-12-21 10:52:47 +00002257 }
2258
Richard Levitte01d99972016-03-14 10:02:13 +01002259sub run_dofile
Richard Levitte107b5792015-05-20 20:03:20 +02002260{
Richard Levitte107b5792015-05-20 20:03:20 +02002261 my $out = shift;
Richard Levitte9fe2bb72016-01-29 19:45:51 +01002262 my @templates = @_;
Richard Levitte107b5792015-05-20 20:03:20 +02002263
Rich Salzced2c2c2016-01-29 13:29:45 -05002264 unlink $out || warn "Can't remove $out, $!"
2265 if -f $out;
Richard Levitte9fe2bb72016-01-29 19:45:51 +01002266 foreach (@templates) {
2267 die "Can't open $_, $!" unless -f $_;
2268 }
2269 my $cmd = "$config{perl} \"-I.\" \"-Mconfigdata\" $dofile -o\"Configure\" \"".join("\" \"",@templates)."\" > \"$out.new\"";
2270 #print STDERR "DEBUG[run_dofile]: \$cmd = $cmd\n";
2271 system($cmd);
Richard Levitte107b5792015-05-20 20:03:20 +02002272 exit 1 if $? != 0;
2273 rename("$out.new", $out) || die "Can't rename $out.new, $!";
2274}
2275
Richard Levitte00ae96c2015-05-18 12:53:38 +02002276# Configuration printer ##############################################
2277
2278sub print_table_entry
2279{
2280 my $target = shift;
2281 my %target = resolve_config($target);
2282 my $type = shift;
2283
2284 # Don't print the templates
2285 return if $target{template};
2286
2287 my @sequence = (
Richard Levittef0bd4682016-01-25 21:51:22 +01002288 "sys_id",
Richard Levitte00ae96c2015-05-18 12:53:38 +02002289 "cc",
2290 "cflags",
Richard Levittebcb19772016-01-30 02:17:05 +01002291 "defines",
Richard Levittef0bd4682016-01-25 21:51:22 +01002292 "unistd",
2293 "ld",
Richard Levitte00ae96c2015-05-18 12:53:38 +02002294 "lflags",
Richard Levittec86ddbe2016-02-05 11:47:14 +01002295 "plib_lflags",
Richard Levitte1740c162016-01-29 18:07:37 +01002296 "ex_libs",
Richard Levitte00ae96c2015-05-18 12:53:38 +02002297 "bn_ops",
2298 "cpuid_obj",
2299 "bn_obj",
2300 "ec_obj",
2301 "des_obj",
2302 "aes_obj",
2303 "bf_obj",
2304 "md5_obj",
2305 "sha1_obj",
2306 "cast_obj",
2307 "rc4_obj",
2308 "rmd160_obj",
2309 "rc5_obj",
2310 "wp_obj",
2311 "cmll_obj",
2312 "modes_obj",
Richard Levittef0bd4682016-01-25 21:51:22 +01002313 "padlock_obj",
Richard Levitte9c62a272016-02-27 16:51:34 +01002314 "thread_scheme",
Richard Levitte00ae96c2015-05-18 12:53:38 +02002315 "perlasm_scheme",
2316 "dso_scheme",
2317 "shared_target",
2318 "shared_cflag",
2319 "shared_ldflag",
Richard Levitte64c443e2016-02-05 15:17:33 +01002320 "shared_rcflag",
Richard Levitte00ae96c2015-05-18 12:53:38 +02002321 "shared_extension",
Richard Levittee987f9f2016-02-15 17:20:15 +01002322 "shared_extension_simple",
2323 "shared_import_extension",
2324 "dso_extension",
Richard Levittef0bd4682016-01-25 21:51:22 +01002325 "obj_extension",
2326 "exe_extension",
Richard Levitte00ae96c2015-05-18 12:53:38 +02002327 "ranlib",
Richard Levittef0bd4682016-01-25 21:51:22 +01002328 "ar",
Richard Levitte00ae96c2015-05-18 12:53:38 +02002329 "arflags",
2330 "multilib",
Richard Levittef0bd4682016-01-25 21:51:22 +01002331 "build_scheme",
Richard Levitte00ae96c2015-05-18 12:53:38 +02002332 );
2333
2334 if ($type eq "TABLE") {
2335 print "\n";
2336 print "*** $target\n";
Richard Levittecb212f22016-02-24 01:32:51 +01002337 foreach (@sequence) {
2338 if (ref($target{$_}) eq "ARRAY") {
2339 printf "\$%-12s = %s\n", $_, join(" ", @{$target{$_}});
2340 } else {
2341 printf "\$%-12s = %s\n", $_, $target{$_};
2342 }
2343 }
Richard Levitte00ae96c2015-05-18 12:53:38 +02002344 } elsif ($type eq "HASH") {
2345 my $largest =
2346 length((sort { length($a) <=> length($b) } @sequence)[-1]);
2347 print " '$target' => {\n";
2348 foreach (@sequence) {
2349 if ($target{$_}) {
Richard Levittecb212f22016-02-24 01:32:51 +01002350 if (ref($target{$_}) eq "ARRAY") {
2351 print " '",$_,"'"," " x ($largest - length($_))," => [ ",join(", ", map { "'$_'" } @{$target{$_}})," ],\n";
2352 } else {
2353 print " '",$_,"'"," " x ($largest - length($_))," => '",$target{$_},"',\n";
2354 }
Richard Levitte00ae96c2015-05-18 12:53:38 +02002355 }
2356 }
2357 print " },\n";
2358 }
2359}
2360
2361# Utility routines ###################################################
2362
Richard Levitte2e963842016-02-10 02:00:37 +01002363# On VMS, if the given file is a logical name, File::Spec::Functions
2364# will consider it an absolute path. There are cases when we want a
2365# purely syntactic check without checking the environment.
2366sub isabsolute {
2367 my $file = shift;
2368
2369 # On non-platforms, we just use file_name_is_absolute().
2370 return file_name_is_absolute($file) unless $^O eq "VMS";
2371
2372 # If the file spec includes a device or a directpry spec,
2373 # file_name_is_absolute() is perfectly safe.
2374 return file_name_is_absolute($file) if $file =~ m|[:\[]|;
2375
2376 # Here, we know the given file spec isn't absolute
2377 return 0;
2378}
2379
Richard Levitteec182ef2016-02-09 10:15:13 +01002380# Makes a directory absolute and cleans out /../ in paths like foo/../bar
2381# On some platforms, this uses rel2abs(), while on others, realpath() is used.
2382# realpath() requires that at least all path components except the last is an
2383# existing directory. On VMS, the last component of the directory spec must
2384# exist.
2385sub absolutedir {
2386 my $dir = shift;
2387
2388 # realpath() is quite buggy on VMS. It uses LIB$FID_TO_NAME, which
2389 # will return the volume name for the device, no matter what. Also,
2390 # it will return an incorrect directory spec if the argument is a
2391 # directory that doesn't exist.
2392 if ($^O eq "VMS") {
2393 return rel2abs($dir);
2394 }
2395
2396 # We use realpath() on Unix, since no other will properly clean out
2397 # a directory spec.
2398 use Cwd qw/realpath/;
2399
2400 return realpath($dir);
2401}
2402
Ulf Möller99aab161999-04-01 12:34:33 +00002403sub which
2404 {
2405 my($name)=@_;
2406 my $path;
2407 foreach $path (split /:/, $ENV{PATH})
2408 {
Richard Levitte09aa2632016-03-09 01:14:29 +01002409 my $fullpath = "$path/$name$target{exe_extension}";
2410 if (-f $fullpath and -x $fullpath)
Ulf Möller99aab161999-04-01 12:34:33 +00002411 {
Richard Levitte09aa2632016-03-09 01:14:29 +01002412 return $fullpath
2413 unless ($name eq "perl" and
2414 system("$fullpath -e " . '\'exit($]<5.0);\''));
Ulf Möller99aab161999-04-01 12:34:33 +00002415 }
2416 }
2417 }
2418
Richard Levittefe052642015-05-18 03:33:55 +02002419sub quotify {
2420 my %processors = (
2421 perl => sub { my $x = shift;
2422 $x =~ s/([\\\$\@"])/\\$1/g;
2423 return '"'.$x.'"'; },
2424 );
2425 my $for = shift;
2426 my $processor =
2427 defined($processors{$for}) ? $processors{$for} : sub { shift; };
2428
Richard Levitte2110feb2016-04-06 15:02:57 +02002429 return map { $processor->($_); } @_;
Richard Levittefe052642015-05-18 03:33:55 +02002430}
Richard Levitte107b5792015-05-20 20:03:20 +02002431
Richard Levitte9fe2bb72016-01-29 19:45:51 +01002432# collect_from_file($filename, $line_concat_cond_re, $line_concat)
2433# $filename is a file name to read from
2434# $line_concat_cond_re is a regexp detecting a line continuation ending
2435# $line_concat is a CODEref that takes care of concatenating two lines
2436sub collect_from_file {
2437 my $filename = shift;
2438 my $line_concat_cond_re = shift;
2439 my $line_concat = shift;
2440
2441 open my $fh, $filename || die "unable to read $filename: $!\n";
2442 return sub {
2443 my $saved_line = "";
2444 $_ = "";
2445 while (<$fh>) {
Richard Levitte04f171c2016-02-12 12:10:27 +01002446 s|\R$||;
Richard Levitte9fe2bb72016-01-29 19:45:51 +01002447 if (defined $line_concat) {
2448 $_ = $line_concat->($saved_line, $_);
2449 $saved_line = "";
2450 }
2451 if (defined $line_concat_cond_re && /$line_concat_cond_re/) {
2452 $saved_line = $_;
2453 next;
2454 }
2455 return $_;
2456 }
2457 die "$filename ending with continuation line\n" if $_;
2458 close $fh;
2459 return undef;
2460 }
2461}
2462
2463# collect_from_array($array, $line_concat_cond_re, $line_concat)
2464# $array is an ARRAYref of lines
2465# $line_concat_cond_re is a regexp detecting a line continuation ending
2466# $line_concat is a CODEref that takes care of concatenating two lines
2467sub collect_from_array {
2468 my $array = shift;
2469 my $line_concat_cond_re = shift;
2470 my $line_concat = shift;
2471 my @array = (@$array);
2472
2473 return sub {
2474 my $saved_line = "";
2475 $_ = "";
2476 while (defined($_ = shift @array)) {
Richard Levitte04f171c2016-02-12 12:10:27 +01002477 s|\R$||;
Richard Levitte9fe2bb72016-01-29 19:45:51 +01002478 if (defined $line_concat) {
2479 $_ = $line_concat->($saved_line, $_);
2480 $saved_line = "";
2481 }
2482 if (defined $line_concat_cond_re && /$line_concat_cond_re/) {
2483 $saved_line = $_;
2484 next;
2485 }
2486 return $_;
2487 }
2488 die "input text ending with continuation line\n" if $_;
2489 return undef;
2490 }
2491}
2492
2493# collect_information($lineiterator, $line_continue, $regexp => $CODEref, ...)
2494# $lineiterator is a CODEref that delivers one line at a time.
Richard Levitte107b5792015-05-20 20:03:20 +02002495# All following arguments are regex/CODEref pairs, where the regexp detects a
2496# line and the CODEref does something with the result of the regexp.
2497sub collect_information {
Richard Levitte9fe2bb72016-01-29 19:45:51 +01002498 my $lineiterator = shift;
Richard Levitte107b5792015-05-20 20:03:20 +02002499 my %collectors = @_;
2500
Richard Levitte9fe2bb72016-01-29 19:45:51 +01002501 while(defined($_ = $lineiterator->())) {
Richard Levitte04f171c2016-02-12 12:10:27 +01002502 s|\R$||;
Richard Levitte9fe2bb72016-01-29 19:45:51 +01002503 my $found = 0;
Richard Levitte2b6b6062016-03-10 00:04:04 +01002504 if ($collectors{"BEFORE"}) {
2505 $collectors{"BEFORE"}->($_);
2506 }
Richard Levitte9fe2bb72016-01-29 19:45:51 +01002507 foreach my $re (keys %collectors) {
Richard Levitte2b6b6062016-03-10 00:04:04 +01002508 if ($re !~ /^OTHERWISE|BEFORE|AFTER$/ && /$re/) {
Richard Levitte9fe2bb72016-01-29 19:45:51 +01002509 $collectors{$re}->($lineiterator);
2510 $found = 1;
2511 };
2512 }
2513 if ($collectors{"OTHERWISE"}) {
2514 $collectors{"OTHERWISE"}->($lineiterator, $_)
2515 unless $found || !defined $collectors{"OTHERWISE"};
2516 }
Richard Levitte2b6b6062016-03-10 00:04:04 +01002517 if ($collectors{"AFTER"}) {
2518 $collectors{"AFTER"}->($_);
2519 }
Richard Levitte107b5792015-05-20 20:03:20 +02002520 }
Richard Levitte107b5792015-05-20 20:03:20 +02002521}