Fix the max psk len for TLSv1.3
[openssl.git] / Configurations / 00-base-templates.conf
1 # -*- Mode: perl -*-
2 my %targets=(
3     DEFAULTS => {
4         template        => 1,
5
6         cflags          => "",
7         cppflags        => "",
8         lflags          => "",
9         defines         => [],
10         includes        => [],
11         lib_cflags      => "",
12         lib_cppflags    => "",
13         lib_defines     => [],
14         thread_scheme   => "(unknown)", # Assume we don't know
15         thread_defines  => [],
16
17         apps_aux_src    => "",
18         apps_init_src   => "",
19         cpuid_asm_src   => "mem_clr.c",
20         uplink_aux_src  => "",
21         bn_asm_src      => "bn_asm.c",
22         ec_asm_src      => "",
23         des_asm_src     => "des_enc.c fcrypt_b.c",
24         aes_asm_src     => "aes_core.c aes_cbc.c",
25         bf_asm_src      => "bf_enc.c",
26         md5_asm_src     => "",
27         cast_asm_src    => "c_enc.c",
28         rc4_asm_src     => "rc4_enc.c rc4_skey.c",
29         rmd160_asm_src  => "",
30         rc5_asm_src     => "rc5_enc.c",
31         wp_asm_src      => "wp_block.c",
32         cmll_asm_src    => "camellia.c cmll_misc.c cmll_cbc.c",
33         modes_asm_src   => "",
34         padlock_asm_src => "",
35         chacha_asm_src  => "chacha_enc.c",
36         poly1305_asm_src        => "",
37         keccak1600_asm_src      => "keccak1600.c",
38
39         unistd          => "<unistd.h>",
40         shared_target   => "",
41         shared_cflag    => "",
42         shared_defines  => [],
43         shared_ldflag   => "",
44         shared_rcflag   => "",
45         shared_extension        => "",
46
47         #### Defaults for the benefit of the config targets who don't inherit
48         #### a BASE and assume Unixly defaults
49         #### THESE WILL DISAPPEAR IN OpenSSL 1.2
50         build_scheme    => [ "unified", "unix" ],
51         build_file      => "Makefile",
52
53         AR              => "ar",
54         ARFLAGS         => "r",
55         CC              => "cc",
56         HASHBANGPERL    => "/usr/bin/env perl",
57         RANLIB          => sub { which("$config{cross_compile_prefix}ranlib")
58                                      ? "ranlib" : "" },
59         RC              => "windres",
60
61         #### THESE WILL BE ENABLED IN OpenSSL 1.2
62         #HASHBANGPERL   => "PERL", # Only Unix actually cares
63     },
64
65     BASE_common => {
66         template        => 1,
67
68         enable          => [],
69         disable         => [],
70
71         defines         =>
72             sub {
73                 my @defs = ();
74                 push @defs, "ZLIB" unless $disabled{zlib};
75                 push @defs, "ZLIB_SHARED" unless $disabled{"zlib-dynamic"};
76                 return [ @defs ];
77             },
78         includes        =>
79             sub {
80                 my @incs = ();
81                 push @incs, $withargs{zlib_include}
82                     if !$disabled{zlib} && $withargs{zlib_include};
83                 return [ @incs ];
84             },
85     },
86
87     BASE_unix => {
88         inherit_from    => [ "BASE_common" ],
89         template        => 1,
90
91         AR              => "ar",
92         ARFLAGS         => "r",
93         CC              => "cc",
94         lflags          =>
95             sub { $withargs{zlib_lib} ? "-L".$withargs{zlib_lib} : () },
96         ex_libs         =>
97             sub { !defined($disabled{zlib})
98                   && defined($disabled{"zlib-dynamic"})
99                   ? "-lz" : () },
100         HASHBANGPERL    => "/usr/bin/env perl", # Only Unix actually cares
101         RANLIB          => sub { which("$config{cross_compile_prefix}ranlib")
102                                      ? "ranlib" : "" },
103         RC              => "windres",
104
105         build_scheme    => [ "unified", "unix" ],
106         build_file      => "Makefile",
107     },
108
109     BASE_Windows => {
110         inherit_from    => [ "BASE_common" ],
111         template        => 1,
112
113         lib_defines      =>
114             sub {
115                 my @defs = ();
116                 unless ($disabled{"zlib-dynamic"}) {
117                     my $zlib = $withargs{zlib_lib} // "ZLIB1";
118                     push @defs, 'LIBZ=' . (quotify("perl", $zlib))[0];
119                 }
120                 return [ @defs ];
121             },
122         ex_libs         =>
123             sub {
124                 unless ($disabled{zlib}) {
125                     if (defined($disabled{"zlib-dynamic"})) {
126                         return $withargs{zlib_lib} // "ZLIB1";
127                     }
128                 }
129                 return ();
130             },
131
132         LD              => "link",
133         LDFLAGS         => "/nologo",
134         ldoutflag       => "/out:",
135         AR              => "lib",
136         ARFLAGS         => "/nologo",
137         aroutflag       => "/out:",
138         RC               => "rc",
139         rcoutflag        => "/fo",
140         MT              => "mt",
141         MTFLAGS         => "-nologo",
142         mtinflag        => "-manifest ",
143         mtoutflag       => "-outputresource:",
144
145         build_file      => "makefile",
146         build_scheme    => [ "unified", "windows" ],
147     },
148
149     BASE_VMS => {
150         inherit_from    => [ "BASE_common" ],
151         template        => 1,
152
153         includes        =>
154             add(sub {
155                     my @incs = ();
156                     # GNV$ZLIB_INCLUDE is the standard logical name for later
157                     # zlib incarnations.
158                     push @incs, 'GNV$ZLIB_INCLUDE:'
159                         if !$disabled{zlib} && !$withargs{zlib_include};
160                     return [ @incs ];
161                 }),
162
163         build_file       => "descrip.mms",
164         build_scheme     => [ "unified", "VMS" ],
165     },
166
167     uplink_common => {
168         template        => 1,
169         apps_init_src   => add("../ms/applink.c"),
170         uplink_aux_src  => add("../ms/uplink.c"),
171         defines         => add("OPENSSL_USE_APPLINK"),
172     },
173     x86_uplink => {
174         inherit_from    => [ "uplink_common" ],
175         template        => 1,
176         uplink_aux_src  => add("uplink-x86.s"),
177     },
178     x86_64_uplink => {
179         inherit_from    => [ "uplink_common" ],
180         template        => 1,
181         uplink_aux_src  => add("uplink-x86_64.s"),
182     },
183     ia64_uplink => {
184         inherit_from    => [ "uplink_common" ],
185         template        => 1,
186         uplink_aux_src  => add("uplink-ia64.s"),
187     },
188
189     x86_asm => {
190         template        => 1,
191         cpuid_asm_src   => "x86cpuid.s",
192         bn_asm_src      => "bn-586.s co-586.s x86-mont.s x86-gf2m.s",
193         ec_asm_src      => "ecp_nistz256.c ecp_nistz256-x86.s",
194         des_asm_src     => "des-586.s crypt586.s",
195         aes_asm_src     => "aes-586.s vpaes-x86.s aesni-x86.s",
196         bf_asm_src      => "bf-586.s",
197         md5_asm_src     => "md5-586.s",
198         cast_asm_src    => "cast-586.s",
199         sha1_asm_src    => "sha1-586.s sha256-586.s sha512-586.s",
200         rc4_asm_src     => "rc4-586.s",
201         rmd160_asm_src  => "rmd-586.s",
202         rc5_asm_src     => "rc5-586.s",
203         wp_asm_src      => "wp_block.c wp-mmx.s",
204         cmll_asm_src    => "cmll-x86.s",
205         modes_asm_src   => "ghash-x86.s",
206         padlock_asm_src => "e_padlock-x86.s",
207         chacha_asm_src  => "chacha-x86.s",
208         poly1305_asm_src=> "poly1305-x86.s",
209     },
210     x86_elf_asm => {
211         template        => 1,
212         inherit_from    => [ "x86_asm" ],
213         perlasm_scheme  => "elf"
214     },
215     x86_64_asm => {
216         template        => 1,
217         cpuid_asm_src   => "x86_64cpuid.s",
218         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",
219         ec_asm_src      => "ecp_nistz256.c ecp_nistz256-x86_64.s x25519-x86_64.s",
220         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",
221         md5_asm_src     => "md5-x86_64.s",
222         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",
223         rc4_asm_src     => "rc4-x86_64.s rc4-md5-x86_64.s",
224         wp_asm_src      => "wp-x86_64.s",
225         cmll_asm_src    => "cmll-x86_64.s cmll_misc.c",
226         modes_asm_src   => "ghash-x86_64.s aesni-gcm-x86_64.s",
227         padlock_asm_src => "e_padlock-x86_64.s",
228         chacha_asm_src  => "chacha-x86_64.s",
229         poly1305_asm_src=> "poly1305-x86_64.s",
230         keccak1600_asm_src      => "keccak1600-x86_64.s",
231     },
232     ia64_asm => {
233         template        => 1,
234         cpuid_asm_src   => "ia64cpuid.s",
235         bn_asm_src      => "bn-ia64.s ia64-mont.s",
236         aes_asm_src     => "aes_core.c aes_cbc.c aes-ia64.s",
237         sha1_asm_src    => "sha1-ia64.s sha256-ia64.s sha512-ia64.s",
238         modes_asm_src   => "ghash-ia64.s",
239         perlasm_scheme  => "void"
240     },
241     sparcv9_asm => {
242         template        => 1,
243         cpuid_asm_src   => "sparcv9cap.c sparccpuid.S",
244         bn_asm_src      => "asm/sparcv8plus.S sparcv9-mont.S sparcv9a-mont.S vis3-mont.S sparct4-mont.S sparcv9-gf2m.S",
245         ec_asm_src      => "ecp_nistz256.c ecp_nistz256-sparcv9.S",
246         des_asm_src     => "des_enc-sparc.S fcrypt_b.c dest4-sparcv9.S",
247         aes_asm_src     => "aes_core.c aes_cbc.c aes-sparcv9.S aest4-sparcv9.S aesfx-sparcv9.S",
248         md5_asm_src     => "md5-sparcv9.S",
249         sha1_asm_src    => "sha1-sparcv9.S sha256-sparcv9.S sha512-sparcv9.S",
250         cmll_asm_src    => "camellia.c cmll_misc.c cmll_cbc.c cmllt4-sparcv9.S",
251         modes_asm_src   => "ghash-sparcv9.S",
252         poly1305_asm_src=> "poly1305-sparcv9.S",
253         perlasm_scheme  => "void"
254     },
255     sparcv8_asm => {
256         template        => 1,
257         cpuid_asm_src   => "",
258         bn_asm_src      => "asm/sparcv8.S",
259         des_asm_src     => "des_enc-sparc.S fcrypt_b.c",
260         perlasm_scheme  => "void"
261     },
262     alpha_asm => {
263         template        => 1,
264         cpuid_asm_src   => "alphacpuid.s",
265         bn_asm_src      => "bn_asm.c alpha-mont.S",
266         sha1_asm_src    => "sha1-alpha.S",
267         modes_asm_src   => "ghash-alpha.S",
268         perlasm_scheme  => "void"
269     },
270     mips32_asm => {
271         template        => 1,
272         bn_asm_src      => "bn-mips.S mips-mont.S",
273         aes_asm_src     => "aes_cbc.c aes-mips.S",
274         sha1_asm_src    => "sha1-mips.S sha256-mips.S",
275     },
276     mips64_asm => {
277         inherit_from    => [ "mips32_asm" ],
278         template        => 1,
279         sha1_asm_src    => add("sha512-mips.S"),
280         poly1305_asm_src=> "poly1305-mips.S",
281     },
282     s390x_asm => {
283         template        => 1,
284         cpuid_asm_src   => "s390xcap.c s390xcpuid.S",
285         bn_asm_src      => "asm/s390x.S s390x-mont.S s390x-gf2m.s",
286         aes_asm_src     => "aes-s390x.S aes-ctr.fake aes-xts.fake",
287         sha1_asm_src    => "sha1-s390x.S sha256-s390x.S sha512-s390x.S",
288         rc4_asm_src     => "rc4-s390x.s",
289         modes_asm_src   => "ghash-s390x.S",
290         chacha_asm_src  => "chacha-s390x.S",
291         poly1305_asm_src=> "poly1305-s390x.S",
292         keccak1600_asm_src      => "keccak1600-s390x.S",
293     },
294     armv4_asm => {
295         template        => 1,
296         cpuid_asm_src   => "armcap.c armv4cpuid.S",
297         bn_asm_src      => "bn_asm.c armv4-mont.S armv4-gf2m.S",
298         ec_asm_src      => "ecp_nistz256.c ecp_nistz256-armv4.S",
299         aes_asm_src     => "aes_cbc.c aes-armv4.S bsaes-armv7.S aesv8-armx.S",
300         sha1_asm_src    => "sha1-armv4-large.S sha256-armv4.S sha512-armv4.S",
301         modes_asm_src   => "ghash-armv4.S ghashv8-armx.S",
302         chacha_asm_src  => "chacha-armv4.S",
303         poly1305_asm_src=> "poly1305-armv4.S", 
304         keccak1600_asm_src      => "keccak1600-armv4.S",
305         perlasm_scheme  => "void"
306     },
307     aarch64_asm => {
308         template        => 1,
309         cpuid_asm_src   => "armcap.c arm64cpuid.S",
310         ec_asm_src      => "ecp_nistz256.c ecp_nistz256-armv8.S",
311         bn_asm_src      => "bn_asm.c armv8-mont.S",
312         aes_asm_src     => "aes_core.c aes_cbc.c aesv8-armx.S vpaes-armv8.S",
313         sha1_asm_src    => "sha1-armv8.S sha256-armv8.S sha512-armv8.S",
314         modes_asm_src   => "ghashv8-armx.S",
315         chacha_asm_src  => "chacha-armv8.S",
316         poly1305_asm_src=> "poly1305-armv8.S",
317         keccak1600_asm_src      => "keccak1600-armv8.S",
318     },
319     parisc11_asm => {
320         template        => 1,
321         cpuid_asm_src   => "pariscid.s",
322         bn_asm_src      => "bn_asm.c parisc-mont.s",
323         aes_asm_src     => "aes_core.c aes_cbc.c aes-parisc.s",
324         sha1_asm_src    => "sha1-parisc.s sha256-parisc.s sha512-parisc.s",
325         rc4_asm_src     => "rc4-parisc.s",
326         modes_asm_src   => "ghash-parisc.s",
327         perlasm_scheme  => "32"
328     },
329     parisc20_64_asm => {
330         template        => 1,
331         inherit_from    => [ "parisc11_asm" ],
332         perlasm_scheme  => "64",
333     },
334     ppc32_asm => {
335         template        => 1,
336         cpuid_asm_src   => "ppccpuid.s ppccap.c",
337         bn_asm_src      => "bn-ppc.s ppc-mont.s",
338         aes_asm_src     => "aes_core.c aes_cbc.c aes-ppc.s vpaes-ppc.s aesp8-ppc.s",
339         sha1_asm_src    => "sha1-ppc.s sha256-ppc.s sha512-ppc.s sha256p8-ppc.s sha512p8-ppc.s",
340         modes_asm_src   => "ghashp8-ppc.s",
341         chacha_asm_src  => "chacha-ppc.s",
342         poly1305_asm_src=> "poly1305-ppc.s poly1305-ppcfp.s",
343     },
344     ppc64_asm => {
345         inherit_from    => [ "ppc32_asm" ],
346         template        => 1,
347         ec_asm_src      => "ecp_nistz256.c ecp_nistz256-ppc64.s x25519-ppc64.s",
348         keccak1600_asm_src      => "keccak1600-ppc64.s",
349     },
350 );