14 thread_scheme => "(unknown)", # Assume we don't know
18 des_asm_src => "des_enc.c fcrypt_b.c",
19 aes_asm_src => "aes_core.c aes_cbc.c",
20 bf_asm_src => "bf_enc.c",
22 cast_asm_src => "c_enc.c",
23 rc4_asm_src => "rc4_enc.c rc4_skey.c",
25 rc5_asm_src => "rc5_enc.c",
26 wp_asm_src => "wp_block.c",
27 cmll_asm_src => "camellia.c cmll_misc.c cmll_cbc.c",
29 padlock_asm_src => "",
30 chacha_asm_src => "chacha_enc.c",
31 poly1305_asm_src => "",
32 keccak1600_asm_src => "keccak1600.c",
34 unistd => "<unistd.h>",
41 #### Defaults for the benefit of the config targets who don't inherit
42 #### a BASE and assume Unix defaults
43 #### THESE WILL DISAPPEAR IN OpenSSL 1.2
44 build_scheme => [ "unified", "unix" ],
45 build_file => "Makefile",
50 HASHBANGPERL => "/usr/bin/env perl",
51 RANLIB => sub { which("$config{cross_compile_prefix}ranlib")
55 #### THESE WILL BE ENABLED IN OpenSSL 1.2
56 #HASHBANGPERL => "PERL", # Only Unix actually cares
68 push @defs, "ZLIB" unless $disabled{zlib};
69 push @defs, "ZLIB_SHARED" unless $disabled{"zlib-dynamic"};
75 push @incs, $withargs{zlib_include}
76 if !$disabled{zlib} && $withargs{zlib_include};
82 inherit_from => [ "BASE_common" ],
89 sub { $withargs{zlib_lib} ? "-L".$withargs{zlib_lib} : () },
91 sub { !defined($disabled{zlib})
92 && defined($disabled{"zlib-dynamic"})
94 HASHBANGPERL => "/usr/bin/env perl", # Only Unix actually cares
95 RANLIB => sub { which("$config{cross_compile_prefix}ranlib")
99 build_scheme => [ "unified", "unix" ],
100 build_file => "Makefile",
102 perl_platform => 'Unix',
106 inherit_from => [ "BASE_common" ],
112 unless ($disabled{"zlib-dynamic"}) {
113 my $zlib = $withargs{zlib_lib} // "ZLIB1";
114 push @defs, 'LIBZ=' . (quotify("perl", $zlib))[0];
120 unless ($disabled{zlib}) {
121 if (defined($disabled{"zlib-dynamic"})) {
122 return $withargs{zlib_lib} // "ZLIB1";
129 LDFLAGS => "/nologo",
130 ldoutflag => "/out:",
132 ARFLAGS => "/nologo",
133 aroutflag => "/out:",
137 MTFLAGS => "-nologo",
138 mtinflag => "-manifest ",
139 mtoutflag => "-outputresource:",
141 build_file => "makefile",
142 build_scheme => [ "unified", "windows" ],
144 perl_platform => 'Windows',
148 inherit_from => [ "BASE_common" ],
154 # GNV$ZLIB_INCLUDE is the standard logical name for later
156 push @incs, 'GNV$ZLIB_INCLUDE:'
157 if !$disabled{zlib} && !$withargs{zlib_include};
161 build_file => "descrip.mms",
162 build_scheme => [ "unified", "VMS" ],
164 perl_platform => 'VMS',
169 ec_asm_src => "ecp_nistz256.c ecp_nistz256-x86.s",
170 des_asm_src => "des-586.s crypt586.s",
171 aes_asm_src => "aes-586.s vpaes-x86.s aesni-x86.s",
172 bf_asm_src => "bf-586.s",
173 md5_asm_src => "md5-586.s",
174 cast_asm_src => "cast-586.s",
175 sha1_asm_src => "sha1-586.s sha256-586.s sha512-586.s",
176 rc4_asm_src => "rc4-586.s",
177 rmd160_asm_src => "rmd-586.s",
178 rc5_asm_src => "rc5-586.s",
179 wp_asm_src => "wp_block.c wp-mmx.s",
180 cmll_asm_src => "cmll-x86.s",
181 modes_asm_src => "ghash-x86.s",
182 padlock_asm_src => "e_padlock-x86.s",
183 chacha_asm_src => "chacha-x86.s",
184 poly1305_asm_src=> "poly1305-x86.s",
188 inherit_from => [ "x86_asm" ],
192 ec_asm_src => "ecp_nistz256.c ecp_nistz256-x86_64.s x25519-x86_64.s",
193 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",
194 md5_asm_src => "md5-x86_64.s",
195 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",
196 rc4_asm_src => "rc4-x86_64.s rc4-md5-x86_64.s",
197 wp_asm_src => "wp-x86_64.s",
198 cmll_asm_src => "cmll-x86_64.s cmll_misc.c",
199 modes_asm_src => "ghash-x86_64.s aesni-gcm-x86_64.s",
200 padlock_asm_src => "e_padlock-x86_64.s",
201 chacha_asm_src => "chacha-x86_64.s",
202 poly1305_asm_src=> "poly1305-x86_64.s",
203 keccak1600_asm_src => "keccak1600-x86_64.s",
207 aes_asm_src => "aes_core.c aes_cbc.c aes-ia64.s",
208 sha1_asm_src => "sha1-ia64.s sha256-ia64.s sha512-ia64.s",
209 modes_asm_src => "ghash-ia64.s",
210 chacha_asm_src => "chacha-ia64.S",
211 poly1305_asm_src=> "asm/poly1305-ia64.S",
215 ec_asm_src => "ecp_nistz256.c ecp_nistz256-sparcv9.S",
216 des_asm_src => "des_enc-sparc.S fcrypt_b.c dest4-sparcv9.S",
217 aes_asm_src => "aes_core.c aes_cbc.c aes-sparcv9.S aest4-sparcv9.S aesfx-sparcv9.S",
218 md5_asm_src => "md5-sparcv9.S",
219 sha1_asm_src => "sha1-sparcv9.S sha256-sparcv9.S sha512-sparcv9.S",
220 cmll_asm_src => "camellia.c cmll_misc.c cmll_cbc.c cmllt4-sparcv9.S",
221 modes_asm_src => "ghash-sparcv9.S",
222 poly1305_asm_src=> "poly1305-sparcv9.S",
226 des_asm_src => "des_enc-sparc.S fcrypt_b.c",
230 sha1_asm_src => "sha1-alpha.S",
231 modes_asm_src => "ghash-alpha.S",
235 aes_asm_src => "aes_cbc.c aes-mips.S",
236 sha1_asm_src => "sha1-mips.S sha256-mips.S",
239 inherit_from => [ "mips32_asm" ],
241 sha1_asm_src => add("sha512-mips.S"),
242 poly1305_asm_src=> "poly1305-mips.S",
246 aes_asm_src => "aes-s390x.S aes-ctr.fake aes-xts.fake",
247 sha1_asm_src => "sha1-s390x.S sha256-s390x.S sha512-s390x.S",
248 rc4_asm_src => "rc4-s390x.s",
249 modes_asm_src => "ghash-s390x.S",
250 chacha_asm_src => "chacha-s390x.S",
251 poly1305_asm_src=> "poly1305-s390x.S",
252 keccak1600_asm_src => "keccak1600-s390x.S",
256 ec_asm_src => "ecp_nistz256.c ecp_nistz256-armv4.S",
257 aes_asm_src => "aes_cbc.c aes-armv4.S bsaes-armv7.S aesv8-armx.S",
258 sha1_asm_src => "sha1-armv4-large.S sha256-armv4.S sha512-armv4.S",
259 modes_asm_src => "ghash-armv4.S ghashv8-armx.S",
260 chacha_asm_src => "chacha-armv4.S",
261 poly1305_asm_src=> "poly1305-armv4.S",
262 keccak1600_asm_src => "keccak1600-armv4.S",
266 ec_asm_src => "ecp_nistz256.c ecp_nistz256-armv8.S",
267 aes_asm_src => "aes_core.c aes_cbc.c aesv8-armx.S vpaes-armv8.S",
268 sha1_asm_src => "sha1-armv8.S sha256-armv8.S sha512-armv8.S",
269 modes_asm_src => "ghashv8-armx.S",
270 chacha_asm_src => "chacha-armv8.S",
271 poly1305_asm_src=> "poly1305-armv8.S",
272 keccak1600_asm_src => "keccak1600-armv8.S",
276 aes_asm_src => "aes_core.c aes_cbc.c aes-parisc.s",
277 sha1_asm_src => "sha1-parisc.s sha256-parisc.s sha512-parisc.s",
278 rc4_asm_src => "rc4-parisc.s",
279 modes_asm_src => "ghash-parisc.s",
283 inherit_from => [ "parisc11_asm" ],
287 aes_asm_src => "aes_core.c aes_cbc.c aes-ppc.s vpaes-ppc.s aesp8-ppc.s",
288 sha1_asm_src => "sha1-ppc.s sha256-ppc.s sha512-ppc.s sha256p8-ppc.s sha512p8-ppc.s",
289 modes_asm_src => "ghashp8-ppc.s",
290 chacha_asm_src => "chacha-ppc.s",
291 poly1305_asm_src=> "poly1305-ppc.s poly1305-ppcfp.s",
294 inherit_from => [ "ppc32_asm" ],
296 ec_asm_src => "ecp_nistz256.c ecp_nistz256-ppc64.s x25519-ppc64.s",
297 keccak1600_asm_src => "keccak1600-ppc64.s",