2016-01-30 09:17:05 +08:00
|
|
|
# -*- Mode: perl -*-
|
2015-05-18 08:54:28 +08:00
|
|
|
%targets=(
|
|
|
|
BASE => {
|
|
|
|
template => 1,
|
2016-01-30 09:17:05 +08:00
|
|
|
|
|
|
|
cflags => "",
|
|
|
|
defines => [],
|
|
|
|
debug_cflags => "",
|
|
|
|
debug_defines => [],
|
|
|
|
release_cflags => "",
|
|
|
|
release_defines => [],
|
|
|
|
thread_cflags => "",
|
|
|
|
thread_defines => [],
|
|
|
|
|
2016-01-30 02:45:51 +08:00
|
|
|
cpuid_asm_src => "mem_clr.c",
|
|
|
|
bn_asm_src => "bn_asm.c",
|
|
|
|
ec_asm_src => "",
|
|
|
|
des_asm_src => "des_enc.c fcrypt_b.c",
|
|
|
|
aes_asm_src => "aes_core.c aes_cbc.c",
|
|
|
|
bf_asm_src => "bf_enc.c",
|
|
|
|
md5_asm_src => "",
|
|
|
|
cast_asm_src => "c_enc.c",
|
|
|
|
rc4_asm_src => "rc4_enc.c rc4_skey.c",
|
|
|
|
rmd160_asm_src => "",
|
|
|
|
rc5_asm_src => "rc5_enc.c",
|
|
|
|
wp_asm_src => "wp_block.c",
|
|
|
|
cmll_asm_src => "camellia.c cmll_misc.c cmll_cbc.c",
|
|
|
|
modes_asm_src => "",
|
|
|
|
padlock_asm_src => "",
|
|
|
|
chacha_asm_src => "chacha_enc.c",
|
|
|
|
poly1305_asm_src => "",
|
2015-05-18 08:54:28 +08:00
|
|
|
|
|
|
|
unistd => "<unistd.h>",
|
2015-05-21 02:03:20 +08:00
|
|
|
shared_target => "",
|
|
|
|
shared_cflag => "",
|
|
|
|
shared_ldflag => "",
|
|
|
|
shared_extension => "",
|
Refactor config - @MK1MF_Builds out, general build scheme in
Time to get rid of @MK1MF_Builds and introduce a more flexible
'build_scheme' configuration key. Its value may be a string or an
array of strings, meaning we need to teach resolve_config how to
handle ARRAY referenses.
The build scheme is a word that selects a function to create the
appropriate result files for a certain configuration. Currently valid
build schemes aer "mk1mf" and "unixmake", the plan is however to add
at least one other for a more universal build scheme.
Incidently, this also adds the functions 'add' and 'add_before', which
can be used in a configuration, so instead of having to repeatedly
write a sub like this:
key1 => sub { join(" ", @_, "myvalues"); },
key2 => sub { join(" ", "myvalues", @_); },
one could write this:
key1 => add(" ", "myvalues"),
key2 => add_before(" ", "myvalues"),
The good point with 'add' and 'add_before' is that they handle
inheritances where the values are a misture of scalars and ARRAYs. If
there are any ARRAY to be found, the resulting value will be an ARRAY,
otherwise it will be a scalar with all the incoming valued joined
together with the separator given as first argument to add/add_before.
Reviewed-by: Rich Salz <rsalz@openssl.org>
2015-05-18 20:31:49 +08:00
|
|
|
build_scheme => "unixmake",
|
2016-01-30 02:45:51 +08:00
|
|
|
build_file => "Makefile",
|
2015-05-18 08:54:28 +08:00
|
|
|
},
|
|
|
|
|
|
|
|
x86_asm => {
|
|
|
|
template => 1,
|
2016-01-30 02:45:51 +08:00
|
|
|
cpuid_asm_src => "x86cpuid.s",
|
|
|
|
bn_asm_src => "bn-586.s co-586.s x86-mont.s x86-gf2m.s",
|
|
|
|
ec_asm_src => "ecp_nistz256.c ecp_nistz256-x86.s",
|
|
|
|
des_asm_src => "des-586.s crypt586.s",
|
|
|
|
aes_asm_src => "aes-586.s vpaes-x86.s aesni-x86.s",
|
|
|
|
bf_asm_src => "bf-586.s",
|
|
|
|
md5_asm_src => "md5-586.s",
|
|
|
|
cast_asm_src => "cast-586.s",
|
|
|
|
sha1_asm_src => "sha1-586.s sha256-586.s sha512-586.s",
|
|
|
|
rc4_asm_src => "rc4-586.s",
|
|
|
|
rmd160_asm_src => "rmd-586.s",
|
|
|
|
rc5_asm_src => "rc5-586.s",
|
|
|
|
wp_asm_src => "wp_block.c wp-mmx.s",
|
|
|
|
cmll_asm_src => "cmll-x86.s",
|
|
|
|
modes_asm_src => "ghash-x86.s",
|
|
|
|
padlock_asm_src => "e_padlock-x86.s",
|
2016-02-10 06:08:30 +08:00
|
|
|
chacha_asm_src => "chacha-x86.s",
|
|
|
|
poly1305_asm_src=> "poly1305-x86.s",
|
2015-05-18 08:54:28 +08:00
|
|
|
},
|
|
|
|
x86_elf_asm => {
|
|
|
|
template => 1,
|
|
|
|
inherit_from => [ "x86_asm" ],
|
|
|
|
perlasm_scheme => "elf"
|
|
|
|
},
|
|
|
|
x86_64_asm => {
|
|
|
|
template => 1,
|
2016-01-30 02:45:51 +08:00
|
|
|
cpuid_asm_src => "x86_64cpuid.s",
|
|
|
|
bn_asm_src => "asm/x86_64-gcc.c x86_64-mont.s x86_64-mont5.s x86_64-gf2m.s rsaz_exp.c rsaz-x86_64.s rsaz-avx2.s",
|
|
|
|
ec_asm_src => "ecp_nistz256.c ecp_nistz256-x86_64.s",
|
|
|
|
aes_asm_src => "aes-x86_64.s vpaes-x86_64.s bsaes-x86_64.s aesni-x86_64.s aesni-sha1-x86_64.s aesni-sha256-x86_64.s aesni-mb-x86_64.s",
|
|
|
|
md5_asm_src => "md5-x86_64.s",
|
|
|
|
sha1_asm_src => "sha1-x86_64.s sha256-x86_64.s sha512-x86_64.s sha1-mb-x86_64.s sha256-mb-x86_64.s",
|
|
|
|
rc4_asm_src => "rc4-x86_64.s rc4-md5-x86_64.s",
|
|
|
|
wp_asm_src => "wp-x86_64.s",
|
|
|
|
cmll_asm_src => "cmll-x86_64.s cmll_misc.c",
|
|
|
|
modes_asm_src => "ghash-x86_64.s aesni-gcm-x86_64.s",
|
|
|
|
padlock_asm_src => "e_padlock-x86_64.s",
|
2016-02-10 06:08:30 +08:00
|
|
|
chacha_asm_src => "chacha-x86_64.s",
|
|
|
|
poly1305_asm_src=> "poly1305-x86_64.s",
|
2015-05-18 08:54:28 +08:00
|
|
|
},
|
|
|
|
ia64_asm => {
|
|
|
|
template => 1,
|
2016-01-30 02:45:51 +08:00
|
|
|
cpuid_asm_src => "ia64cpuid.s",
|
|
|
|
bn_asm_src => "bn-ia64.s ia64-mont.s",
|
|
|
|
aes_asm_src => "aes_core.c aes_cbc.c aes-ia64.s",
|
|
|
|
md5_asm_src => "md5-ia64.s",
|
|
|
|
sha1_asm_src => "sha1-ia64.s sha256-ia64.s sha512-ia64.s",
|
2016-02-02 00:48:14 +08:00
|
|
|
rc4_asm_src => "rc4-ia64.s rc4_skey.c",
|
2016-01-30 02:45:51 +08:00
|
|
|
modes_asm_src => "ghash-ia64.s",
|
2015-05-18 08:54:28 +08:00
|
|
|
perlasm_scheme => "void"
|
|
|
|
},
|
|
|
|
sparcv9_asm => {
|
|
|
|
template => 1,
|
2016-02-02 00:48:14 +08:00
|
|
|
cpuid_asm_src => "sparcv9cap.c sparccpuid.S",
|
|
|
|
bn_asm_src => "asm/sparcv8plus.S sparcv9-mont.s sparcv9a-mont.s vis3-mont.s sparct4-mont.S sparcv9-gf2m.S",
|
|
|
|
ec_asm_src => "ecp_nistz256.c ecp_nistz256-sparcv9.S",
|
|
|
|
des_asm_src => "des_enc-sparc.S fcrypt_b.c dest4-sparcv9.s",
|
2016-01-30 02:45:51 +08:00
|
|
|
aes_asm_src => "aes_core.c aes_cbc.c aes-sparcv9.s aest4-sparcv9.s",
|
2016-02-02 00:48:14 +08:00
|
|
|
md5_asm_src => "md5-sparcv9.S",
|
|
|
|
sha1_asm_src => "sha1-sparcv9.S sha256-sparcv9.S sha512-sparcv9.S",
|
2016-01-30 02:45:51 +08:00
|
|
|
cmll_asm_src => "camellia.c cmll_misc.c cmll_cbc.c cmllt4-sparcv9.s",
|
|
|
|
modes_asm_src => "ghash-sparcv9.s",
|
|
|
|
poly1305_obj => "poly1305-sparcv9.S",
|
2015-05-18 08:54:28 +08:00
|
|
|
perlasm_scheme => "void"
|
|
|
|
},
|
|
|
|
sparcv8_asm => {
|
|
|
|
template => 1,
|
2016-01-30 02:45:51 +08:00
|
|
|
cpuid_asm_src => "",
|
2016-02-02 00:48:14 +08:00
|
|
|
bn_asm_src => "asm/sparcv8.S",
|
|
|
|
des_asm_src => "des_enc-sparc.S fcrypt_b.c",
|
2015-05-18 08:54:28 +08:00
|
|
|
perlasm_scheme => "void"
|
|
|
|
},
|
|
|
|
alpha_asm => {
|
|
|
|
template => 1,
|
2016-01-30 02:45:51 +08:00
|
|
|
cpuid_asm_src => "alphacpuid.s",
|
2016-02-02 00:48:14 +08:00
|
|
|
bn_asm_src => "bn_asm.c alpha-mont.s",
|
2016-01-30 02:45:51 +08:00
|
|
|
sha1_asm_src => "sha1-alpha.s",
|
|
|
|
modes_asm_src => "ghash-alpha.s",
|
2015-05-18 08:54:28 +08:00
|
|
|
perlasm_scheme => "void"
|
|
|
|
},
|
|
|
|
mips32_asm => {
|
|
|
|
template => 1,
|
2016-01-30 02:45:51 +08:00
|
|
|
bn_asm_src => "bn-mips.s mips-mont.s",
|
|
|
|
aes_asm_src => "aes_cbc.c aes-mips.S",
|
|
|
|
sha1_asm_src => "sha1-mips.S sha256-mips.S",
|
2015-05-18 08:54:28 +08:00
|
|
|
},
|
|
|
|
mips64_asm => {
|
|
|
|
inherit_from => [ "mips32_asm" ],
|
|
|
|
template => 1,
|
2016-01-30 02:45:51 +08:00
|
|
|
sha1_asm_src => add("sha512-mips.S")
|
2015-05-18 08:54:28 +08:00
|
|
|
},
|
|
|
|
s390x_asm => {
|
|
|
|
template => 1,
|
2016-02-02 00:48:14 +08:00
|
|
|
cpuid_asm_src => "s390xcap.c s390xcpuid.s",
|
|
|
|
bn_asm_src => "asm/s390x.S s390x-mont.S s390x-gf2m.s",
|
2016-01-30 02:45:51 +08:00
|
|
|
aes_asm_src => "aes-s390x.S aes-ctr.fake aes-xts.fake",
|
|
|
|
sha1_asm_src => "sha1-s390x.s sha256-s390x.s sha512-s390x.s",
|
|
|
|
rc4_asm_src => "rc4-s390x.s",
|
|
|
|
modes_asm_src => "ghash-s390x.s",
|
2016-02-01 06:05:17 +08:00
|
|
|
chacha_asm_src => "chacha-s390x.o",
|
|
|
|
poly1305_asm_src=> "poly1305-s390x.o",
|
2015-05-18 08:54:28 +08:00
|
|
|
},
|
|
|
|
armv4_asm => {
|
|
|
|
template => 1,
|
2016-02-02 00:48:14 +08:00
|
|
|
cpuid_asm_src => "armcap.c armv4cpuid.S",
|
|
|
|
bn_asm_src => "bn_asm.c armv4-mont.S armv4-gf2m.S",
|
|
|
|
ec_asm_src => "ecp_nistz256.c ecp_nistz256-armv4.S",
|
2016-01-30 02:45:51 +08:00
|
|
|
aes_asm_src => "aes_cbc.c aes-armv4.S bsaes-armv7.S aesv8-armx.S",
|
2016-02-02 00:48:14 +08:00
|
|
|
sha1_asm_src => "sha1-armv4-large.S sha256-armv4.S sha512-armv4.S",
|
|
|
|
modes_asm_src => "ghash-armv4.S ghashv8-armx.S",
|
2015-05-18 08:54:28 +08:00
|
|
|
perlasm_scheme => "void"
|
|
|
|
},
|
|
|
|
aarch64_asm => {
|
|
|
|
template => 1,
|
2016-02-02 00:48:14 +08:00
|
|
|
cpuid_asm_src => "armcap.c arm64cpuid.S mem_clr.c",
|
|
|
|
ec_asm_src => "ecp_nistz256.c ecp_nistz256-armv8.S",
|
|
|
|
bn_asm_src => "bn_asm.c armv8-mont.S",
|
|
|
|
aes_asm_src => "aes_core.c aes_cbc.c aesv8-armx.S vpaes-armv8.S",
|
|
|
|
sha1_asm_src => "sha1-armv8.S sha256-armv8.S sha512-armv8.S",
|
|
|
|
modes_asm_src => "ghashv8-armx.S",
|
2015-05-18 08:54:28 +08:00
|
|
|
},
|
|
|
|
parisc11_asm => {
|
|
|
|
template => 1,
|
2016-01-30 02:45:51 +08:00
|
|
|
cpuid_asm_src => "pariscid.s",
|
2016-02-02 00:48:14 +08:00
|
|
|
bn_asm_src => "bn_asm.c parisc-mont.s",
|
2016-01-30 02:45:51 +08:00
|
|
|
aes_asm_src => "aes_core.c aes_cbc.c aes-parisc.s",
|
|
|
|
sha1_asm_src => "sha1-parisc.s sha256-parisc.s sha512-parisc.s",
|
|
|
|
rc4_asm_src => "rc4-parisc.s",
|
|
|
|
modes_asm_src => "ghash-parisc.s",
|
2015-05-18 08:54:28 +08:00
|
|
|
perlasm_scheme => "32"
|
|
|
|
},
|
|
|
|
parisc20_64_asm => {
|
|
|
|
template => 1,
|
|
|
|
inherit_from => [ "parisc11_asm" ],
|
|
|
|
perlasm_scheme => "64",
|
|
|
|
},
|
|
|
|
ppc64_asm => {
|
|
|
|
template => 1,
|
2016-02-02 00:48:14 +08:00
|
|
|
cpuid_asm_src => "ppccpuid.s ppccap.c",
|
2016-01-30 02:45:51 +08:00
|
|
|
bn_asm_src => "bn-ppc.s ppc-mont.s ppc64-mont.s",
|
|
|
|
aes_asm_src => "aes_core.c aes_cbc.c aes-ppc.s vpaes-ppc.s aesp8-ppc.s",
|
|
|
|
sha1_asm_src => "sha1-ppc.s sha256-ppc.s sha512-ppc.s sha256p8-ppc.s sha512p8-ppc.s",
|
|
|
|
modes_asm_src => "ghashp8-ppc.s",
|
2015-05-18 08:54:28 +08:00
|
|
|
},
|
|
|
|
ppc32_asm => {
|
|
|
|
inherit_from => [ "ppc64_asm" ],
|
|
|
|
template => 1
|
|
|
|
},
|
|
|
|
);
|