Configurations: engage x86[_64] ChaCha20 and Poly1305 modules.
[openssl.git] / Configurations / 00-base-templates.conf
index 2ff2c2a3e96d8b8aa336383fa759a95e32ae6f0c..3cc078f8e6695d656f8ddd3f856392bfb889db88 100644 (file)
@@ -1,23 +1,23 @@
 %targets=(
     BASE => {
        template        => 1,
-       cpuid_obj       => "mem_clr.o",
-       bn_obj          => "bn_asm.o",
-       ec_obj          => "",
-       des_obj         => "des_enc.o fcrypt_b.o",
-       aes_obj         => "aes_core.o aes_cbc.o",
-       bf_obj          => "bf_enc.o",
-       md5_obj         => "",
-       cast_obj        => "c_enc.o",
-       rc4_obj         => "rc4_enc.o rc4_skey.o",
-       rmd160_obj      => "",
-       rc5_obj         => "rc5_enc.o",
-       wp_obj          => "wp_block.o",
-       cmll_obj        => "camellia.o cmll_misc.o cmll_cbc.o",
-       modes_obj       => "",
-       padlock_obj     => "",
-       chacha_obj      => "chacha_enc.o",
-       poly1305_obj    => "",
+       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        => "",
 
        unistd          => "<unistd.h>",
        shared_target   => "",
        shared_ldflag   => "",
        shared_extension        => "",
        build_scheme    => "unixmake",
+       build_file      => "Makefile",
     },
 
     x86_asm => {
        template        => 1,
-       cpuid_obj       => "x86cpuid.o",
-       bn_obj          => "bn-586.o co-586.o x86-mont.o x86-gf2m.o",
-       ec_obj          => "ecp_nistz256.o ecp_nistz256-x86.o",
-       des_obj         => "des-586.o crypt586.o",
-       aes_obj         => "aes-586.o vpaes-x86.o aesni-x86.o",
-       bf_obj          => "bf-586.o",
-       md5_obj         => "md5-586.o",
-       sha1_obj        => "sha1-586.o sha256-586.o sha512-586.o",
-       rc4_obj         => "rc4-586.o",
-       rmd160_obj      => "rmd-586.o",
-       rc5_obj         => "rc5-586.o",
-       wp_obj          => "wp_block.o wp-mmx.o",
-       cmll_obj        => "cmll-x86.o",
-       modes_obj       => "ghash-x86.o",
-       padlock_obj     => "e_padlock-x86.o"
+       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",
+       chacha_asm_src  => "chacha-x86.s",
+       poly1305_asm_src=> "poly1305-x86.s",
     },
     x86_elf_asm => {
        template        => 1,
     },
     x86_64_asm => {
        template        => 1,
-       cpuid_obj       => "x86_64cpuid.o",
-       bn_obj          => "x86_64-gcc.o x86_64-mont.o x86_64-mont5.o x86_64-gf2m.o rsaz_exp.o rsaz-x86_64.o rsaz-avx2.o",
-       ec_obj          => "ecp_nistz256.o ecp_nistz256-x86_64.o",
-       aes_obj         => "aes-x86_64.o vpaes-x86_64.o bsaes-x86_64.o aesni-x86_64.o aesni-sha1-x86_64.o aesni-sha256-x86_64.o aesni-mb-x86_64.o",
-       md5_obj         => "md5-x86_64.o",
-       sha1_obj        => "sha1-x86_64.o sha256-x86_64.o sha512-x86_64.o sha1-mb-x86_64.o sha256-mb-x86_64.o",
-       rc4_obj         => "rc4-x86_64.o rc4-md5-x86_64.o",
-       wp_obj          => "wp-x86_64.o",
-       cmll_obj        => "cmll-x86_64.o cmll_misc.o",
-       modes_obj       => "ghash-x86_64.o aesni-gcm-x86_64.o",
-       padlock_obj     => "e_padlock-x86_64.o"
+       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",
+       chacha_asm_src  => "chacha-x86_64.s",
+       poly1305_asm_src=> "poly1305-x86_64.s",
     },
     ia64_asm => {
        template        => 1,
-       cpuid_obj       => "ia64cpuid.o",
-       bn_obj          => "bn-ia64.o ia64-mont.o",
-       aes_obj         => "aes_core.o aes_cbc.o aes-ia64.o",
-       md5_obj         => "md5-ia64.o",
-       sha1_obj        => "sha1-ia64.o sha256-ia64.o sha512-ia64.o",
-       rc4_obj         => "rc4-ia64.o rc4_skey.o",
-       modes_obj       => "ghash-ia64.o",
+       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",
+       rc4_asm_src     => "rc4-ia64.s rc4_skey.c",
+       modes_asm_src   => "ghash-ia64.s",
        perlasm_scheme  => "void"
     },
     sparcv9_asm => {
        template        => 1,
-       cpuid_obj       => "sparcv9cap.o sparccpuid.o",
-       bn_obj          => "bn-sparcv9.o sparcv9-mont.o sparcv9a-mont.o vis3-mont.o sparct4-mont.o sparcv9-gf2m.o",
-        ec_obj          => "ecp_nistz256.o ecp_nistz256-sparcv9.o",
-       des_obj         => "des_enc-sparc.o fcrypt_b.o dest4-sparcv9.o",
-       aes_obj         => "aes_core.o aes_cbc.o aes-sparcv9.o aest4-sparcv9.o",
-       md5_obj         => "md5-sparcv9.o",
-       sha1_obj        => "sha1-sparcv9.o sha256-sparcv9.o sha512-sparcv9.o",
-       cmll_obj        => "camellia.o cmll_misc.o cmll_cbc.o cmllt4-sparcv9.o",
-       modes_obj       => "ghash-sparcv9.o",
+       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",
+       aes_asm_src     => "aes_core.c aes_cbc.c aes-sparcv9.s aest4-sparcv9.s",
+       md5_asm_src     => "md5-sparcv9.S",
+       sha1_asm_src    => "sha1-sparcv9.S sha256-sparcv9.S sha512-sparcv9.S",
+       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",
        perlasm_scheme  => "void"
     },
     sparcv8_asm => {
        template        => 1,
-       cpuid_obj       => "",
-       bn_obj          => "sparcv8.o",
-       des_obj         => "des_enc-sparc.o fcrypt_b.o",
+       cpuid_asm_src   => "",
+       bn_asm_src      => "asm/sparcv8.S",
+       des_asm_src     => "des_enc-sparc.S fcrypt_b.c",
        perlasm_scheme  => "void"
     },
     alpha_asm => {
        template        => 1,
-       cpuid_obj       => "alphacpuid.o",
-       bn_obj          => "bn_asm.o alpha-mont.o",
-       sha1_obj        => "sha1-alpha.o",
-       modes_obj       => "ghash-alpha.o",
+       cpuid_asm_src   => "alphacpuid.s",
+       bn_asm_src      => "bn_asm.c alpha-mont.s",
+       sha1_asm_src    => "sha1-alpha.s",
+       modes_asm_src   => "ghash-alpha.s",
        perlasm_scheme  => "void"
     },
     mips32_asm => {
        template        => 1,
-       bn_obj          => "bn-mips.o mips-mont.o",
-       aes_obj         => "aes_cbc.o aes-mips.o",
-       sha1_obj        => "sha1-mips.o sha256-mips.o",
+       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",
     },
     mips64_asm => {
        inherit_from    => [ "mips32_asm" ],
        template        => 1,
-       sha1_obj        => sub { join(" ", @_, "sha512-mips.o") }
+       sha1_asm_src    => add("sha512-mips.S")
     },
     s390x_asm => {
        template        => 1,
-       cpuid_obj       => "s390xcap.o s390xcpuid.o",
-       bn_obj          => "bn-s390x.o s390x-mont.o s390x-gf2m.o",
-       aes_obj         => "aes-s390x.o aes-ctr.o aes-xts.o",
-       sha1_obj        => "sha1-s390x.o sha256-s390x.o sha512-s390x.o",
-       rc4_obj         => "rc4-s390x.o",
-       modes_obj       => "ghash-s390x.o",
+       cpuid_asm_src   => "s390xcap.c s390xcpuid.s",
+       bn_asm_src      => "asm/s390x.S s390x-mont.S s390x-gf2m.s",
+       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",
+       chacha_asm_src  => "chacha-s390x.o",
+       poly1305_asm_src=> "poly1305-s390x.o",
     },
     armv4_asm => {
        template        => 1,
-       cpuid_obj       => "armcap.o armv4cpuid.o",
-       bn_obj          => "bn_asm.o armv4-mont.o armv4-gf2m.o",
-       ec_obj          => "ecp_nistz256.o ecp_nistz256-armv4.o",
-       aes_obj         => "aes_cbc.o aes-armv4.o bsaes-armv7.o aesv8-armx.o",
-       sha1_obj        => "sha1-armv4-large.o sha256-armv4.o sha512-armv4.o",
-       modes_obj       => "ghash-armv4.o ghashv8-armx.o",
+       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",
+       aes_asm_src     => "aes_cbc.c aes-armv4.S bsaes-armv7.S aesv8-armx.S",
+       sha1_asm_src    => "sha1-armv4-large.S sha256-armv4.S sha512-armv4.S",
+       modes_asm_src   => "ghash-armv4.S ghashv8-armx.S",
        perlasm_scheme  => "void"
     },
     aarch64_asm => {
        template        => 1,
-       cpuid_obj       => "armcap.o arm64cpuid.o mem_clr.o",
-       ec_obj          => "ecp_nistz256.o ecp_nistz256-armv8.o",
-       bn_obj          => "bn_asm.o armv8-mont.o",
-       aes_obj         => "aes_core.o aes_cbc.o aesv8-armx.o vpaes-armv8.o",
-       sha1_obj        => "sha1-armv8.o sha256-armv8.o sha512-armv8.o",
-       modes_obj       => "ghashv8-armx.o",
+       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",
     },
     parisc11_asm => {
        template        => 1,
-       cpuid_obj       => "pariscid.o",
-       bn_obj          => "bn_asm.o parisc-mont.o",
-       aes_obj         => "aes_core.o aes_cbc.o aes-parisc.o",
-       sha1_obj        => "sha1-parisc.o sha256-parisc.o sha512-parisc.o",
-       rc4_obj         => "rc4-parisc.o",
-       modes_obj       => "ghash-parisc.o",
+       cpuid_asm_src   => "pariscid.s",
+       bn_asm_src      => "bn_asm.c parisc-mont.s",
+       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",
        perlasm_scheme  => "32"
     },
     parisc20_64_asm => {
        template        => 1,
        inherit_from    => [ "parisc11_asm" ],
-       bn_obj          => sub { my $r=join(" ",@_); $r=~s/bn_asm/pa-risc2W/; $r; },
        perlasm_scheme  => "64",
     },
     ppc64_asm => {
        template        => 1,
-       cpuid_obj       => "ppccpuid.o ppccap.o",
-       bn_obj          => "bn-ppc.o ppc-mont.o ppc64-mont.o",
-       aes_obj         => "aes_core.o aes_cbc.o aes-ppc.o vpaes-ppc.o aesp8-ppc.o",
-       sha1_obj        => "sha1-ppc.o sha256-ppc.o sha512-ppc.o sha256p8-ppc.o sha512p8-ppc.o",
-       modes_obj       => "ghashp8-ppc.o",
+       cpuid_asm_src   => "ppccpuid.s ppccap.c",
+       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",
     },
     ppc32_asm => {
        inherit_from    => [ "ppc64_asm" ],