mk1mf.pl revision 205128
1#!/usr/local/bin/perl 2# A bit of an evil hack but it post processes the file ../MINFO which 3# is generated by `make files` in the top directory. 4# This script outputs one mega makefile that has no shell stuff or any 5# funny stuff 6# 7 8$INSTALLTOP="/usr/local/ssl"; 9$OPTIONS=""; 10$ssl_version=""; 11$banner="\t\@echo Building OpenSSL"; 12 13my $no_static_engine = 0; 14my $engines = ""; 15local $zlib_opt = 0; # 0 = no zlib, 1 = static, 2 = dynamic 16local $zlib_lib = ""; 17 18local $fips_canister_path = ""; 19my $fips_premain_dso_exe_path = ""; 20my $fips_premain_c_path = ""; 21my $fips_sha1_exe_path = ""; 22 23local $fipscanisterbuild = 0; 24local $fipsdso = 0; 25 26my $fipslibdir = ""; 27my $baseaddr = ""; 28 29my $ex_l_libs = ""; 30 31open(IN,"<Makefile") || die "unable to open Makefile!\n"; 32while(<IN>) { 33 $ssl_version=$1 if (/^VERSION=(.*)$/); 34 $OPTIONS=$1 if (/^OPTIONS=(.*)$/); 35 $INSTALLTOP=$1 if (/^INSTALLTOP=(.*$)/); 36} 37close(IN); 38 39die "Makefile is not the toplevel Makefile!\n" if $ssl_version eq ""; 40 41$infile="MINFO"; 42 43%ops=( 44 "VC-WIN32", "Microsoft Visual C++ [4-6] - Windows NT or 9X", 45 "VC-WIN64I", "Microsoft C/C++ - Win64/IA-64", 46 "VC-WIN64A", "Microsoft C/C++ - Win64/x64", 47 "VC-CE", "Microsoft eMbedded Visual C++ 3.0 - Windows CE ONLY", 48 "VC-NT", "Microsoft Visual C++ [4-6] - Windows NT ONLY", 49 "Mingw32", "GNU C++ - Windows NT or 9x", 50 "Mingw32-files", "Create files with DOS copy ...", 51 "BC-NT", "Borland C++ 4.5 - Windows NT", 52 "linux-elf","Linux elf", 53 "ultrix-mips","DEC mips ultrix", 54 "FreeBSD","FreeBSD distribution", 55 "OS2-EMX", "EMX GCC OS/2", 56 "netware-clib", "CodeWarrior for NetWare - CLib - with WinSock Sockets", 57 "netware-clib-bsdsock", "CodeWarrior for NetWare - CLib - with BSD Sockets", 58 "netware-libc", "CodeWarrior for NetWare - LibC - with WinSock Sockets", 59 "netware-libc-bsdsock", "CodeWarrior for NetWare - LibC - with BSD Sockets", 60 "default","cc under unix", 61 ); 62 63$platform=""; 64my $xcflags=""; 65foreach (@ARGV) 66 { 67 if (!&read_options && !defined($ops{$_})) 68 { 69 print STDERR "unknown option - $_\n"; 70 print STDERR "usage: perl mk1mf.pl [options] [system]\n"; 71 print STDERR "\nwhere [system] can be one of the following\n"; 72 foreach $i (sort keys %ops) 73 { printf STDERR "\t%-10s\t%s\n",$i,$ops{$i}; } 74 print STDERR <<"EOF"; 75and [options] can be one of 76 no-md2 no-md4 no-md5 no-sha no-mdc2 - Skip this digest 77 no-ripemd 78 no-rc2 no-rc4 no-rc5 no-idea no-des - Skip this symetric cipher 79 no-bf no-cast no-aes no-camellia no-seed 80 no-rsa no-dsa no-dh - Skip this public key cipher 81 no-ssl2 no-ssl3 - Skip this version of SSL 82 just-ssl - remove all non-ssl keys/digest 83 no-asm - No x86 asm 84 no-krb5 - No KRB5 85 no-ec - No EC 86 no-ecdsa - No ECDSA 87 no-ecdh - No ECDH 88 no-engine - No engine 89 no-hw - No hw 90 nasm - Use NASM for x86 asm 91 nw-nasm - Use NASM x86 asm for NetWare 92 nw-mwasm - Use Metrowerks x86 asm for NetWare 93 gaswin - Use GNU as with Mingw32 94 no-socks - No socket code 95 no-err - No error strings 96 dll/shlib - Build shared libraries (MS) 97 debug - Debug build 98 profile - Profiling build 99 gcc - Use Gcc (unix) 100 101Values that can be set 102TMP=tmpdir OUT=outdir SRC=srcdir BIN=binpath INC=header-outdir CC=C-compiler 103 104-L<ex_lib_path> -l<ex_lib> - extra library flags (unix) 105-<ex_cc_flags> - extra 'cc' flags, 106 added (MS), or replace (unix) 107EOF 108 exit(1); 109 } 110 $platform=$_; 111 } 112foreach (grep(!/^$/, split(/ /, $OPTIONS))) 113 { 114 print STDERR "unknown option - $_\n" if !&read_options; 115 } 116 117$no_static_engine = 0 if (!$shlib); 118 119$no_mdc2=1 if ($no_des); 120 121$no_ssl3=1 if ($no_md5 || $no_sha); 122$no_ssl3=1 if ($no_rsa && $no_dh); 123 124$no_ssl2=1 if ($no_md5); 125$no_ssl2=1 if ($no_rsa); 126 127$out_def="out"; 128$inc_def="outinc"; 129$tmp_def="tmp"; 130 131$perl="perl" unless defined $perl; 132$mkdir="-mkdir" unless defined $mkdir; 133 134($ssl,$crypto)=("ssl","crypto"); 135$ranlib="echo ranlib"; 136 137$cc=(defined($VARS{'CC'}))?$VARS{'CC'}:'cc'; 138$src_dir=(defined($VARS{'SRC'}))?$VARS{'SRC'}:'.'; 139$bin_dir=(defined($VARS{'BIN'}))?$VARS{'BIN'}:''; 140 141# $bin_dir.=$o causes a core dump on my sparc :-( 142 143 144$NT=0; 145 146push(@INC,"util/pl","pl"); 147if (($platform =~ /VC-(.+)/)) 148 { 149 $FLAVOR=$1; 150 $NT = 1 if $1 eq "NT"; 151 require 'VC-32.pl'; 152 } 153elsif ($platform eq "Mingw32") 154 { 155 require 'Mingw32.pl'; 156 } 157elsif ($platform eq "Mingw32-files") 158 { 159 require 'Mingw32f.pl'; 160 } 161elsif ($platform eq "BC-NT") 162 { 163 $bc=1; 164 require 'BC-32.pl'; 165 } 166elsif ($platform eq "FreeBSD") 167 { 168 require 'unix.pl'; 169 $cflags='-DTERMIO -D_ANSI_SOURCE -O2 -fomit-frame-pointer'; 170 } 171elsif ($platform eq "linux-elf") 172 { 173 require "unix.pl"; 174 require "linux.pl"; 175 $unix=1; 176 } 177elsif ($platform eq "ultrix-mips") 178 { 179 require "unix.pl"; 180 require "ultrix.pl"; 181 $unix=1; 182 } 183elsif ($platform eq "OS2-EMX") 184 { 185 $wc=1; 186 require 'OS2-EMX.pl'; 187 } 188elsif (($platform eq "netware-clib") || ($platform eq "netware-libc") || 189 ($platform eq "netware-clib-bsdsock") || ($platform eq "netware-libc-bsdsock")) 190 { 191 $LIBC=1 if $platform eq "netware-libc" || $platform eq "netware-libc-bsdsock"; 192 $BSDSOCK=1 if ($platform eq "netware-libc-bsdsock") || ($platform eq "netware-clib-bsdsock"); 193 require 'netware.pl'; 194 } 195else 196 { 197 require "unix.pl"; 198 199 $unix=1; 200 $cflags.=' -DTERMIO'; 201 } 202 203$out_dir=(defined($VARS{'OUT'}))?$VARS{'OUT'}:$out_def.($debug?".dbg":""); 204$tmp_dir=(defined($VARS{'TMP'}))?$VARS{'TMP'}:$tmp_def.($debug?".dbg":""); 205$inc_dir=(defined($VARS{'INC'}))?$VARS{'INC'}:$inc_def; 206 207$bin_dir=$bin_dir.$o unless ((substr($bin_dir,-1,1) eq $o) || ($bin_dir eq '')); 208 209$cflags= "$xcflags$cflags" if $xcflags ne ""; 210 211$cflags.=" -DOPENSSL_NO_IDEA" if $no_idea; 212$cflags.=" -DOPENSSL_NO_AES" if $no_aes; 213$cflags.=" -DOPENSSL_NO_CAMELLIA" if $no_camellia; 214$cflags.=" -DOPENSSL_NO_SEED" if $no_seed; 215$cflags.=" -DOPENSSL_NO_RC2" if $no_rc2; 216$cflags.=" -DOPENSSL_NO_RC4" if $no_rc4; 217$cflags.=" -DOPENSSL_NO_RC5" if $no_rc5; 218$cflags.=" -DOPENSSL_NO_MD2" if $no_md2; 219$cflags.=" -DOPENSSL_NO_MD4" if $no_md4; 220$cflags.=" -DOPENSSL_NO_MD5" if $no_md5; 221$cflags.=" -DOPENSSL_NO_SHA" if $no_sha; 222$cflags.=" -DOPENSSL_NO_SHA1" if $no_sha1; 223$cflags.=" -DOPENSSL_NO_RIPEMD" if $no_ripemd; 224$cflags.=" -DOPENSSL_NO_MDC2" if $no_mdc2; 225$cflags.=" -DOPENSSL_NO_BF" if $no_bf; 226$cflags.=" -DOPENSSL_NO_CAST" if $no_cast; 227$cflags.=" -DOPENSSL_NO_DES" if $no_des; 228$cflags.=" -DOPENSSL_NO_RSA" if $no_rsa; 229$cflags.=" -DOPENSSL_NO_DSA" if $no_dsa; 230$cflags.=" -DOPENSSL_NO_DH" if $no_dh; 231$cflags.=" -DOPENSSL_NO_SOCK" if $no_sock; 232$cflags.=" -DOPENSSL_NO_SSL2" if $no_ssl2; 233$cflags.=" -DOPENSSL_NO_SSL3" if $no_ssl3; 234$cflags.=" -DOPENSSL_NO_TLSEXT" if $no_tlsext; 235$cflags.=" -DOPENSSL_NO_CMS" if $no_cms; 236$cflags.=" -DOPENSSL_NO_JPAKE" if $no_jpake; 237$cflags.=" -DOPENSSL_NO_CAPIENG" if $no_capieng; 238$cflags.=" -DOPENSSL_NO_ERR" if $no_err; 239$cflags.=" -DOPENSSL_NO_KRB5" if $no_krb5; 240$cflags.=" -DOPENSSL_NO_EC" if $no_ec; 241$cflags.=" -DOPENSSL_NO_ECDSA" if $no_ecdsa; 242$cflags.=" -DOPENSSL_NO_ECDH" if $no_ecdh; 243$cflags.=" -DOPENSSL_NO_ENGINE" if $no_engine; 244$cflags.=" -DOPENSSL_NO_HW" if $no_hw; 245$cflags.=" -DOPENSSL_FIPS" if $fips; 246$cflags.= " -DZLIB" if $zlib_opt; 247$cflags.= " -DZLIB_SHARED" if $zlib_opt == 2; 248 249if ($no_static_engine) 250 { 251 $cflags .= " -DOPENSSL_NO_STATIC_ENGINE"; 252 } 253else 254 { 255 $cflags .= " -DOPENSSL_NO_DYNAMIC_ENGINE"; 256 } 257 258#$cflags.=" -DRSAref" if $rsaref ne ""; 259 260## if ($unix) 261## { $cflags="$c_flags" if ($c_flags ne ""); } 262##else 263 { $cflags="$c_flags$cflags" if ($c_flags ne ""); } 264 265$ex_libs="$l_flags$ex_libs" if ($l_flags ne ""); 266 267%shlib_ex_cflags=("SSL" => " -DOPENSSL_BUILD_SHLIBSSL", 268 "CRYPTO" => " -DOPENSSL_BUILD_SHLIBCRYPTO", 269 "FIPS" => " -DOPENSSL_BUILD_SHLIBCRYPTO"); 270 271if ($msdos) 272 { 273 $banner ="\t\@echo Make sure you have run 'perl Configure $platform' in the\n"; 274 $banner.="\t\@echo top level directory, if you don't have perl, you will\n"; 275 $banner.="\t\@echo need to probably edit crypto/bn/bn.h, check the\n"; 276 $banner.="\t\@echo documentation for details.\n"; 277 } 278 279# have to do this to allow $(CC) under unix 280$link="$bin_dir$link" if ($link !~ /^\$/); 281 282$INSTALLTOP =~ s|/|$o|g; 283 284############################################# 285# We parse in input file and 'store' info for later printing. 286open(IN,"<$infile") || die "unable to open $infile:$!\n"; 287$_=<IN>; 288for (;;) 289 { 290 chop; 291 292 ($key,$val)=/^([^=]+)=(.*)/; 293 if ($key eq "RELATIVE_DIRECTORY") 294 { 295 if ($lib ne "") 296 { 297 if ($fips && $dir =~ /^fips/) 298 { 299 $uc = "FIPS"; 300 } 301 else 302 { 303 $uc=$lib; 304 $uc =~ s/^lib(.*)\.a/$1/; 305 $uc =~ tr/a-z/A-Z/; 306 } 307 if (($uc ne "FIPS") || $fipscanisterbuild) 308 { 309 $lib_nam{$uc}=$uc; 310 $lib_obj{$uc}.=$libobj." "; 311 } 312 } 313 last if ($val eq "FINISHED"); 314 $lib=""; 315 $libobj=""; 316 $dir=$val; 317 } 318 319 if ($key eq "KRB5_INCLUDES") 320 { $cflags .= " $val";} 321 322 if ($key eq "ZLIB_INCLUDE") 323 { $cflags .= " $val" if $val ne "";} 324 325 if ($key eq "LIBZLIB") 326 { $zlib_lib = "$val" if $val ne "";} 327 328 if ($key eq "LIBKRB5") 329 { $ex_libs .= " $val" if $val ne "";} 330 331 if ($key eq "TEST") 332 { $test.=&var_add($dir,$val, 0); } 333 334 if (($key eq "PROGS") || ($key eq "E_OBJ")) 335 { $e_exe.=&var_add($dir,$val, 0); } 336 337 if ($key eq "LIB") 338 { 339 $lib=$val; 340 $lib =~ s/^.*\/([^\/]+)$/$1/; 341 } 342 343 if ($key eq "EXHEADER") 344 { $exheader.=&var_add($dir,$val, 1); } 345 346 if ($key eq "HEADER") 347 { $header.=&var_add($dir,$val, 1); } 348 349 if ($key eq "LIBOBJ" && ($dir ne "engines" || !$no_static_engine)) 350 { $libobj=&var_add($dir,$val, 0); } 351 if ($key eq "LIBNAMES" && $dir eq "engines" && $no_static_engine) 352 { $engines.=$val } 353 354 if ($key eq "FIPS_EX_OBJ") 355 { 356 $fips_ex_obj=&var_add("crypto",$val,0); 357 } 358 359 if ($key eq "FIPSLIBDIR") 360 { 361 $fipslibdir=$val; 362 $fipslibdir =~ s/\/$//; 363 $fipslibdir =~ s/\//$o/g; 364 } 365 366 if ($key eq "BASEADDR") 367 { $baseaddr=$val;} 368 369 if (!($_=<IN>)) 370 { $_="RELATIVE_DIRECTORY=FINISHED\n"; } 371 } 372close(IN); 373 374if ($fips) 375 { 376 377 foreach (split " ", $fips_ex_obj) 378 { 379 $fips_exclude_obj{$1} = 1 if (/\/([^\/]*)$/); 380 } 381 382 $fips_exclude_obj{"cpu_win32"} = 1; 383 $fips_exclude_obj{"bn_asm"} = 1; 384 $fips_exclude_obj{"des_enc"} = 1; 385 $fips_exclude_obj{"fcrypt_b"} = 1; 386 $fips_exclude_obj{"aes_core"} = 1; 387 $fips_exclude_obj{"aes_cbc"} = 1; 388 389 my @ltmp = split " ", $lib_obj{"CRYPTO"}; 390 391 392 $lib_obj{"CRYPTO"} = ""; 393 394 foreach(@ltmp) 395 { 396 if (/\/([^\/]*)$/ && exists $fips_exclude_obj{$1}) 397 { 398 if ($fipscanisterbuild) 399 { 400 $lib_obj{"FIPS"} .= "$_ "; 401 } 402 } 403 else 404 { 405 $lib_obj{"CRYPTO"} .= "$_ "; 406 } 407 } 408 409 } 410 411if ($fipscanisterbuild) 412 { 413 $fips_canister_path = "\$(LIB_D)${o}fipscanister.lib" if $fips_canister_path eq ""; 414 $fips_premain_c_path = "\$(LIB_D)${o}fips_premain.c"; 415 } 416else 417 { 418 if ($fips_canister_path eq "") 419 { 420 $fips_canister_path = "\$(FIPSLIB_D)${o}fipscanister.lib"; 421 } 422 423 if ($fips_premain_c_path eq "") 424 { 425 $fips_premain_c_path = "\$(FIPSLIB_D)${o}fips_premain.c"; 426 } 427 } 428 429if ($fips) 430 { 431 if ($fips_sha1_exe_path eq "") 432 { 433 $fips_sha1_exe_path = 434 "\$(BIN_D)${o}fips_standalone_sha1$exep"; 435 } 436 } 437 else 438 { 439 $fips_sha1_exe_path = ""; 440 } 441 442if ($fips_premain_dso_exe_path eq "") 443 { 444 $fips_premain_dso_exe_path = "\$(BIN_D)${o}fips_premain_dso$exep"; 445 } 446 447# $ex_build_targets .= "\$(BIN_D)${o}\$(E_PREMAIN_DSO)$exep" if ($fips); 448 449#$ex_l_libs .= " \$(L_FIPS)" if $fipsdso; 450 451if ($fips) 452 { 453 if (!$shlib) 454 { 455 $ex_build_targets .= " \$(LIB_D)$o$crypto_compat \$(PREMAIN_DSO_EXE)"; 456 $ex_l_libs .= " \$(O_FIPSCANISTER)"; 457 $ex_libs_dep .= " \$(O_FIPSCANISTER)" if $fipscanisterbuild; 458 } 459 if ($fipscanisterbuild) 460 { 461 $fipslibdir = "\$(LIB_D)"; 462 } 463 else 464 { 465 if ($fipslibdir eq "") 466 { 467 open (IN, "util/fipslib_path.txt") || fipslib_error(); 468 $fipslibdir = <IN>; 469 chomp $fipslibdir; 470 close IN; 471 } 472 fips_check_files($fipslibdir, 473 "fipscanister.lib", "fipscanister.lib.sha1", 474 "fips_premain.c", "fips_premain.c.sha1"); 475 } 476 } 477 478if ($shlib) 479 { 480 $extra_install= <<"EOF"; 481 \$(CP) \"\$(O_SSL)\" \"\$(INSTALLTOP)${o}bin\" 482 \$(CP) \"\$(O_CRYPTO)\" \"\$(INSTALLTOP)${o}bin\" 483 \$(CP) \"\$(L_SSL)\" \"\$(INSTALLTOP)${o}lib\" 484 \$(CP) \"\$(L_CRYPTO)\" \"\$(INSTALLTOP)${o}lib\" 485EOF 486 if ($no_static_engine) 487 { 488 $extra_install .= <<"EOF" 489 \$(MKDIR) \"\$(INSTALLTOP)${o}lib${o}engines\" 490 \$(CP) \"\$(E_SHLIB)\" \"\$(INSTALLTOP)${o}lib${o}engines\" 491EOF 492 } 493 } 494else 495 { 496 $extra_install= <<"EOF"; 497 \$(CP) \"\$(O_SSL)\" \"\$(INSTALLTOP)${o}lib\" 498 \$(CP) \"\$(O_CRYPTO)\" \"\$(INSTALLTOP)${o}lib\" 499EOF 500 $ex_libs .= " $zlib_lib" if $zlib_opt == 1; 501 } 502 503$defs= <<"EOF"; 504# This makefile has been automatically generated from the OpenSSL distribution. 505# This single makefile will build the complete OpenSSL distribution and 506# by default leave the 'intertesting' output files in .${o}out and the stuff 507# that needs deleting in .${o}tmp. 508# The file was generated by running 'make makefile.one', which 509# does a 'make files', which writes all the environment variables from all 510# the makefiles to the file call MINFO. This file is used by 511# util${o}mk1mf.pl to generate makefile.one. 512# The 'makefile per directory' system suites me when developing this 513# library and also so I can 'distribute' indervidual library sections. 514# The one monster makefile better suits building in non-unix 515# environments. 516 517EOF 518 519$defs .= $preamble if defined $preamble; 520 521$defs.= <<"EOF"; 522INSTALLTOP=$INSTALLTOP 523 524# Set your compiler options 525PLATFORM=$platform 526CC=$bin_dir${cc} 527CFLAG=$cflags 528APP_CFLAG=$app_cflag 529LIB_CFLAG=$lib_cflag 530SHLIB_CFLAG=$shl_cflag 531APP_EX_OBJ=$app_ex_obj 532SHLIB_EX_OBJ=$shlib_ex_obj 533# add extra libraries to this define, for solaris -lsocket -lnsl would 534# be added 535EX_LIBS=$ex_libs 536 537# The OpenSSL directory 538SRC_D=$src_dir 539 540LINK=$link 541LFLAGS=$lflags 542RSC=$rsc 543FIPSLINK=\$(PERL) util${o}fipslink.pl 544 545AES_ASM_OBJ=$aes_asm_obj 546AES_ASM_SRC=$aes_asm_src 547BN_ASM_OBJ=$bn_asm_obj 548BN_ASM_SRC=$bn_asm_src 549BNCO_ASM_OBJ=$bnco_asm_obj 550BNCO_ASM_SRC=$bnco_asm_src 551DES_ENC_OBJ=$des_enc_obj 552DES_ENC_SRC=$des_enc_src 553BF_ENC_OBJ=$bf_enc_obj 554BF_ENC_SRC=$bf_enc_src 555CAST_ENC_OBJ=$cast_enc_obj 556CAST_ENC_SRC=$cast_enc_src 557RC4_ENC_OBJ=$rc4_enc_obj 558RC4_ENC_SRC=$rc4_enc_src 559RC5_ENC_OBJ=$rc5_enc_obj 560RC5_ENC_SRC=$rc5_enc_src 561MD5_ASM_OBJ=$md5_asm_obj 562MD5_ASM_SRC=$md5_asm_src 563SHA1_ASM_OBJ=$sha1_asm_obj 564SHA1_ASM_SRC=$sha1_asm_src 565RMD160_ASM_OBJ=$rmd160_asm_obj 566RMD160_ASM_SRC=$rmd160_asm_src 567CPUID_ASM_OBJ=$cpuid_asm_obj 568CPUID_ASM_SRC=$cpuid_asm_src 569 570# The output directory for everything intersting 571OUT_D=$out_dir 572# The output directory for all the temporary muck 573TMP_D=$tmp_dir 574# The output directory for the header files 575INC_D=$inc_dir 576INCO_D=$inc_dir${o}openssl 577 578PERL=$perl 579CP=$cp 580RM=$rm 581RANLIB=$ranlib 582MKDIR=$mkdir 583MKLIB=$bin_dir$mklib 584MLFLAGS=$mlflags 585ASM=$bin_dir$asm 586 587# FIPS validated module and support file locations 588 589E_PREMAIN_DSO=fips_premain_dso 590 591FIPSLIB_D=$fipslibdir 592BASEADDR=$baseaddr 593FIPS_PREMAIN_SRC=$fips_premain_c_path 594O_FIPSCANISTER=$fips_canister_path 595FIPS_SHA1_EXE=$fips_sha1_exe_path 596PREMAIN_DSO_EXE=$fips_premain_dso_exe_path 597 598###################################################### 599# You should not need to touch anything below this point 600###################################################### 601 602E_EXE=openssl 603SSL=$ssl 604CRYPTO=$crypto 605LIBFIPS=libosslfips 606 607# BIN_D - Binary output directory 608# TEST_D - Binary test file output directory 609# LIB_D - library output directory 610# ENG_D - dynamic engine output directory 611# Note: if you change these point to different directories then uncomment out 612# the lines around the 'NB' comment below. 613# 614BIN_D=\$(OUT_D) 615TEST_D=\$(OUT_D) 616LIB_D=\$(OUT_D) 617ENG_D=\$(OUT_D) 618 619# INCL_D - local library directory 620# OBJ_D - temp object file directory 621OBJ_D=\$(TMP_D) 622INCL_D=\$(TMP_D) 623 624O_SSL= \$(LIB_D)$o$plib\$(SSL)$shlibp 625O_CRYPTO= \$(LIB_D)$o$plib\$(CRYPTO)$shlibp 626O_FIPS= \$(LIB_D)$o$plib\$(LIBFIPS)$shlibp 627SO_SSL= $plib\$(SSL)$so_shlibp 628SO_CRYPTO= $plib\$(CRYPTO)$so_shlibp 629L_SSL= \$(LIB_D)$o$plib\$(SSL)$libp 630L_CRYPTO= \$(LIB_D)$o$plib\$(CRYPTO)$libp 631L_FIPS= \$(LIB_D)$o$plib\$(LIBFIPS)$libp 632 633L_LIBS= \$(L_SSL) \$(L_CRYPTO) $ex_l_libs 634 635###################################################### 636# Don't touch anything below this point 637###################################################### 638 639INC=-I\$(INC_D) -I\$(INCL_D) 640APP_CFLAGS=\$(INC) \$(CFLAG) \$(APP_CFLAG) 641LIB_CFLAGS=\$(INC) \$(CFLAG) \$(LIB_CFLAG) 642SHLIB_CFLAGS=\$(INC) \$(CFLAG) \$(LIB_CFLAG) \$(SHLIB_CFLAG) 643LIBS_DEP=\$(O_CRYPTO) \$(O_SSL) $ex_libs_dep 644 645############################################# 646EOF 647 648$rules=<<"EOF"; 649all: banner \$(TMP_D) \$(BIN_D) \$(TEST_D) \$(LIB_D) \$(INCO_D) headers \$(FIPS_SHA1_EXE) lib exe $ex_build_targets 650 651banner: 652$banner 653 654\$(TMP_D): 655 \$(MKDIR) \"\$(TMP_D)\" 656# NB: uncomment out these lines if BIN_D, TEST_D and LIB_D are different 657#\$(BIN_D): 658# \$(MKDIR) \$(BIN_D) 659# 660#\$(TEST_D): 661# \$(MKDIR) \$(TEST_D) 662 663\$(LIB_D): 664 \$(MKDIR) \"\$(LIB_D)\" 665 666\$(INCO_D): \$(INC_D) 667 \$(MKDIR) \"\$(INCO_D)\" 668 669\$(INC_D): 670 \$(MKDIR) \"\$(INC_D)\" 671 672headers: \$(HEADER) \$(EXHEADER) 673 @ 674 675lib: \$(LIBS_DEP) \$(E_SHLIB) 676 677exe: \$(T_EXE) \$(BIN_D)$o\$(E_EXE)$exep 678 679install: all 680 \$(MKDIR) \"\$(INSTALLTOP)\" 681 \$(MKDIR) \"\$(INSTALLTOP)${o}bin\" 682 \$(MKDIR) \"\$(INSTALLTOP)${o}include\" 683 \$(MKDIR) \"\$(INSTALLTOP)${o}include${o}openssl\" 684 \$(MKDIR) \"\$(INSTALLTOP)${o}lib\" 685 \$(CP) \"\$(INCO_D)${o}*.\[ch\]\" \"\$(INSTALLTOP)${o}include${o}openssl\" 686 \$(CP) \"\$(BIN_D)$o\$(E_EXE)$exep\" \"\$(INSTALLTOP)${o}bin\" 687 \$(CP) \"apps${o}openssl.cnf\" \"\$(INSTALLTOP)\" 688$extra_install 689 690 691test: \$(T_EXE) 692 cd \$(BIN_D) 693 ..${o}ms${o}test 694 695clean: 696 \$(RM) \$(TMP_D)$o*.* 697 698vclean: 699 \$(RM) \$(TMP_D)$o*.* 700 \$(RM) \$(OUT_D)$o*.* 701 702EOF 703 704my $platform_cpp_symbol = "MK1MF_PLATFORM_$platform"; 705$platform_cpp_symbol =~ s/-/_/g; 706if (open(IN,"crypto/buildinf.h")) 707 { 708 # Remove entry for this platform in existing file buildinf.h. 709 710 my $old_buildinf_h = ""; 711 while (<IN>) 712 { 713 if (/^\#ifdef $platform_cpp_symbol$/) 714 { 715 while (<IN>) { last if (/^\#endif/); } 716 } 717 else 718 { 719 $old_buildinf_h .= $_; 720 } 721 } 722 close(IN); 723 724 open(OUT,">crypto/buildinf.h") || die "Can't open buildinf.h"; 725 print OUT $old_buildinf_h; 726 close(OUT); 727 } 728 729open (OUT,">>crypto/buildinf.h") || die "Can't open buildinf.h"; 730printf OUT <<EOF; 731#ifdef $platform_cpp_symbol 732 /* auto-generated/updated by util/mk1mf.pl for crypto/cversion.c */ 733 #define CFLAGS "$cc $cflags" 734 #define PLATFORM "$platform" 735EOF 736printf OUT " #define DATE \"%s\"\n", scalar gmtime(); 737printf OUT "#endif\n"; 738close(OUT); 739 740# Strip of trailing ' ' 741foreach (keys %lib_obj) { $lib_obj{$_}=&clean_up_ws($lib_obj{$_}); } 742$test=&clean_up_ws($test); 743$e_exe=&clean_up_ws($e_exe); 744$exheader=&clean_up_ws($exheader); 745$header=&clean_up_ws($header); 746 747# First we strip the exheaders from the headers list 748foreach (split(/\s+/,$exheader)){ $h{$_}=1; } 749foreach (split(/\s+/,$header)) { $h.=$_." " unless $h{$_}; } 750chop($h); $header=$h; 751 752$defs.=&do_defs("HEADER",$header,"\$(INCL_D)",""); 753$rules.=&do_copy_rule("\$(INCL_D)",$header,""); 754 755$defs.=&do_defs("EXHEADER",$exheader,"\$(INCO_D)",""); 756$rules.=&do_copy_rule("\$(INCO_D)",$exheader,""); 757 758$defs.=&do_defs("T_OBJ",$test,"\$(OBJ_D)",$obj); 759$rules.=&do_compile_rule("\$(OBJ_D)",$test,"\$(APP_CFLAGS)"); 760 761$defs.=&do_defs("E_OBJ",$e_exe,"\$(OBJ_D)",$obj); 762$rules.=&do_compile_rule("\$(OBJ_D)",$e_exe,'-DMONOLITH $(APP_CFLAGS)'); 763 764# Special case rules for fips_start and fips_end fips_premain_dso 765 766if ($fips) 767 { 768 if ($fipscanisterbuild) 769 { 770 $rules.=&cc_compile_target("\$(OBJ_D)${o}fips_start$obj", 771 "fips${o}fips_canister.c", 772 "-DFIPS_START \$(SHLIB_CFLAGS)"); 773 $rules.=&cc_compile_target("\$(OBJ_D)${o}fips_end$obj", 774 "fips${o}fips_canister.c", "\$(SHLIB_CFLAGS)"); 775 } 776 $rules.=&cc_compile_target("\$(OBJ_D)${o}fips_standalone_sha1$obj", 777 "fips${o}sha${o}fips_standalone_sha1.c", 778 "\$(SHLIB_CFLAGS)"); 779 $rules.=&cc_compile_target("\$(OBJ_D)${o}\$(E_PREMAIN_DSO)$obj", 780 "fips${o}fips_premain.c", 781 "-DFINGERPRINT_PREMAIN_DSO_LOAD \$(SHLIB_CFLAGS)"); 782 } 783 784foreach (values %lib_nam) 785 { 786 $lib_obj=$lib_obj{$_}; 787 local($slib)=$shlib; 788 789 if (($_ eq "SSL") && $no_ssl2 && $no_ssl3) 790 { 791 $rules.="\$(O_SSL):\n\n"; 792 next; 793 } 794 795 if ((!$fips && ($_ eq "CRYPTO")) || ($fips && ($_ eq "FIPS"))) 796 { 797 if ($cpuid_asm_obj ne "") 798 { 799 $lib_obj =~ s/(\S*\/cryptlib\S*)/$1 \$(CPUID_ASM_OBJ)/; 800 $rules.=&do_asm_rule($cpuid_asm_obj,$cpuid_asm_src); 801 } 802 if ($aes_asm_obj ne "") 803 { 804 $lib_obj =~ s/\s(\S*\/aes_core\S*)/ \$(AES_ASM_OBJ)/; 805 $lib_obj =~ s/\s\S*\/aes_cbc\S*//; 806 $rules.=&do_asm_rule($aes_asm_obj,$aes_asm_src); 807 } 808 if ($sha1_asm_obj ne "") 809 { 810 $lib_obj =~ s/\s(\S*\/sha1dgst\S*)/ $1 \$(SHA1_ASM_OBJ)/; 811 $rules.=&do_asm_rule($sha1_asm_obj,$sha1_asm_src); 812 } 813 if ($bn_asm_obj ne "") 814 { 815 $lib_obj =~ s/\s\S*\/bn_asm\S*/ \$(BN_ASM_OBJ)/; 816 $rules.=&do_asm_rule($bn_asm_obj,$bn_asm_src); 817 } 818 if ($bnco_asm_obj ne "") 819 { 820 $lib_obj .= "\$(BNCO_ASM_OBJ)"; 821 $rules.=&do_asm_rule($bnco_asm_obj,$bnco_asm_src); 822 } 823 if ($des_enc_obj ne "") 824 { 825 $lib_obj =~ s/\s\S*des_enc\S*/ \$(DES_ENC_OBJ)/; 826 $lib_obj =~ s/\s\S*\/fcrypt_b\S*\s*/ /; 827 $rules.=&do_asm_rule($des_enc_obj,$des_enc_src); 828 } 829 } 830 if (($bf_enc_obj ne "") && ($_ eq "CRYPTO")) 831 { 832 $lib_obj =~ s/\s\S*\/bf_enc\S*/ \$(BF_ENC_OBJ)/; 833 $rules.=&do_asm_rule($bf_enc_obj,$bf_enc_src); 834 } 835 if (($cast_enc_obj ne "") && ($_ eq "CRYPTO")) 836 { 837 $lib_obj =~ s/(\s\S*\/c_enc\S*)/ \$(CAST_ENC_OBJ)/; 838 $rules.=&do_asm_rule($cast_enc_obj,$cast_enc_src); 839 } 840 if (($rc4_enc_obj ne "") && ($_ eq "CRYPTO")) 841 { 842 $lib_obj =~ s/\s\S*\/rc4_enc\S*/ \$(RC4_ENC_OBJ)/; 843 $rules.=&do_asm_rule($rc4_enc_obj,$rc4_enc_src); 844 } 845 if (($rc5_enc_obj ne "") && ($_ eq "CRYPTO")) 846 { 847 $lib_obj =~ s/\s\S*\/rc5_enc\S*/ \$(RC5_ENC_OBJ)/; 848 $rules.=&do_asm_rule($rc5_enc_obj,$rc5_enc_src); 849 } 850 if (($md5_asm_obj ne "") && ($_ eq "CRYPTO")) 851 { 852 $lib_obj =~ s/\s(\S*\/md5_dgst\S*)/ $1 \$(MD5_ASM_OBJ)/; 853 $rules.=&do_asm_rule($md5_asm_obj,$md5_asm_src); 854 } 855 if (($rmd160_asm_obj ne "") && ($_ eq "CRYPTO")) 856 { 857 $lib_obj =~ s/\s(\S*\/rmd_dgst\S*)/ $1 \$(RMD160_ASM_OBJ)/; 858 $rules.=&do_asm_rule($rmd160_asm_obj,$rmd160_asm_src); 859 } 860 $defs.=&do_defs(${_}."OBJ",$lib_obj,"\$(OBJ_D)",$obj); 861 $lib=($slib)?" \$(SHLIB_CFLAGS)".$shlib_ex_cflags{$_}:" \$(LIB_CFLAGS)"; 862 $rules.=&do_compile_rule("\$(OBJ_D)",$lib_obj{$_},$lib); 863 } 864 865# hack to add version info on MSVC 866if (($platform eq "VC-WIN32") || ($platform eq "VC-WIN64A") 867 || ($platform eq "VC-WIN64I") || ($platform eq "VC-NT")) { 868 $rules.= <<"EOF"; 869\$(OBJ_D)\\\$(CRYPTO).res: ms\\version32.rc 870 \$(RSC) /fo"\$(OBJ_D)\\\$(CRYPTO).res" /d CRYPTO ms\\version32.rc 871 872\$(OBJ_D)\\\$(SSL).res: ms\\version32.rc 873 \$(RSC) /fo"\$(OBJ_D)\\\$(SSL).res" /d SSL ms\\version32.rc 874 875\$(OBJ_D)\\\$(LIBFIPS).res: ms\\version32.rc 876 \$(RSC) /fo"\$(OBJ_D)\\\$(LIBFIPS).res" /d FIPS ms\\version32.rc 877 878EOF 879} 880 881$defs.=&do_defs("T_EXE",$test,"\$(TEST_D)",$exep); 882foreach (split(/\s+/,$test)) 883 { 884 my $t_libs; 885 $t=&bname($_); 886 my $ltype; 887 # Check to see if test program is FIPS 888 if ($fips && /fips/) 889 { 890 # If fipsdso link to libosslfips.dll 891 # otherwise perform static link to 892 # $(O_FIPSCANISTER) 893 if ($fipsdso) 894 { 895 $t_libs = "\$(L_FIPS)"; 896 $ltype = 0; 897 } 898 else 899 { 900 $t_libs = "\$(O_FIPSCANISTER)"; 901 $ltype = 2; 902 } 903 } 904 else 905 { 906 $t_libs = "\$(L_LIBS)"; 907 $ltype = 0; 908 } 909 910 $tt="\$(OBJ_D)${o}$t${obj}"; 911 $rules.=&do_link_rule("\$(TEST_D)$o$t$exep",$tt,"\$(LIBS_DEP)","$t_libs \$(EX_LIBS)", $ltype); 912 } 913 914$defs.=&do_defs("E_SHLIB",$engines,"\$(ENG_D)",$shlibp); 915 916foreach (split(/\s+/,$engines)) 917 { 918 $rules.=&do_compile_rule("\$(OBJ_D)","engines${o}e_$_",$lib); 919 $rules.= &do_lib_rule("\$(OBJ_D)${o}e_${_}.obj","\$(ENG_D)$o$_$shlibp","",$shlib,""); 920 } 921 922 923 924$rules.= &do_lib_rule("\$(SSLOBJ)","\$(O_SSL)",$ssl,$shlib,"\$(SO_SSL)"); 925 926if ($fips) 927 { 928 if ($shlib) 929 { 930 if ($fipsdso) 931 { 932 $rules.= &do_lib_rule("\$(CRYPTOOBJ)", 933 "\$(O_CRYPTO)", "$crypto", 934 $shlib, "", ""); 935 $rules.= &do_lib_rule( 936 "\$(O_FIPSCANISTER)", 937 "\$(O_FIPS)", "\$(LIBFIPS)", 938 $shlib, "\$(SO_CRYPTO)", "\$(BASEADDR)"); 939 $rules.= &do_sdef_rule(); 940 } 941 else 942 { 943 $rules.= &do_lib_rule( 944 "\$(CRYPTOOBJ) \$(O_FIPSCANISTER)", 945 "\$(O_CRYPTO)", "$crypto", 946 $shlib, "\$(SO_CRYPTO)", "\$(BASEADDR)"); 947 } 948 } 949 else 950 { 951 $rules.= &do_lib_rule("\$(CRYPTOOBJ)", 952 "\$(O_CRYPTO)",$crypto,$shlib,"\$(SO_CRYPTO)", ""); 953 $rules.= &do_lib_rule("\$(CRYPTOOBJ) \$(FIPSOBJ)", 954 "\$(LIB_D)$o$crypto_compat",$crypto,$shlib,"\$(SO_CRYPTO)", ""); 955 } 956 } 957 else 958 { 959 $rules.= &do_lib_rule("\$(CRYPTOOBJ)","\$(O_CRYPTO)",$crypto,$shlib, 960 "\$(SO_CRYPTO)"); 961 } 962 963if ($fips) 964 { 965 if ($fipscanisterbuild) 966 { 967 $rules.= &do_rlink_rule("\$(O_FIPSCANISTER)", 968 "\$(OBJ_D)${o}fips_start$obj", 969 "\$(FIPSOBJ)", 970 "\$(OBJ_D)${o}fips_end$obj", 971 "\$(FIPS_SHA1_EXE)", ""); 972 $rules.=&do_link_rule("\$(FIPS_SHA1_EXE)", 973 "\$(OBJ_D)${o}fips_standalone_sha1$obj \$(OBJ_D)${o}sha1dgst$obj \$(SHA1_ASM_OBJ)", 974 "","\$(EX_LIBS)", 1); 975 } 976 else 977 { 978 $rules.=&do_link_rule("\$(FIPS_SHA1_EXE)", 979 "\$(OBJ_D)${o}fips_standalone_sha1$obj \$(O_FIPSCANISTER)", 980 "","", 1); 981 982 } 983 $rules.=&do_link_rule("\$(PREMAIN_DSO_EXE)","\$(OBJ_D)${o}\$(E_PREMAIN_DSO)$obj \$(CRYPTOOBJ) \$(O_FIPSCANISTER)","","\$(EX_LIBS)", 1); 984 985 } 986 987$rules.=&do_link_rule("\$(BIN_D)$o\$(E_EXE)$exep","\$(E_OBJ)","\$(LIBS_DEP)","\$(L_LIBS) \$(EX_LIBS)", ($fips && !$shlib) ? 2 : 0); 988 989print $defs; 990 991if ($platform eq "linux-elf") { 992 print <<"EOF"; 993# Generate perlasm output files 994%.cpp: 995 (cd \$(\@D)/..; PERL=perl make -f Makefile asm/\$(\@F)) 996EOF 997} 998print "###################################################################\n"; 999print $rules; 1000 1001############################################### 1002# strip off any trailing .[och] and append the relative directory 1003# also remembering to do nothing if we are in one of the dropped 1004# directories 1005sub var_add 1006 { 1007 local($dir,$val,$keepext)=@_; 1008 local(@a,$_,$ret); 1009 1010 return("") if $no_engine && $dir =~ /\/engine/; 1011 return("") if $no_hw && $dir =~ /\/hw/; 1012 return("") if $no_idea && $dir =~ /\/idea/; 1013 return("") if $no_aes && $dir =~ /\/aes/; 1014 return("") if $no_camellia && $dir =~ /\/camellia/; 1015 return("") if $no_seed && $dir =~ /\/seed/; 1016 return("") if $no_rc2 && $dir =~ /\/rc2/; 1017 return("") if $no_rc4 && $dir =~ /\/rc4/; 1018 return("") if $no_rc5 && $dir =~ /\/rc5/; 1019 return("") if $no_rsa && $dir =~ /\/rsa/; 1020 return("") if $no_rsa && $dir =~ /^rsaref/; 1021 return("") if $no_dsa && $dir =~ /\/dsa/; 1022 return("") if $no_dh && $dir =~ /\/dh/; 1023 return("") if $no_ec && $dir =~ /\/ec/; 1024 return("") if $no_cms && $dir =~ /\/cms/; 1025 return("") if $no_jpake && $dir =~ /\/jpake/; 1026 return("") if !$fips && $dir =~ /^fips/; 1027 if ($no_des && $dir =~ /\/des/) 1028 { 1029 if ($val =~ /read_pwd/) 1030 { return("$dir/read_pwd "); } 1031 else 1032 { return(""); } 1033 } 1034 return("") if $no_mdc2 && $dir =~ /\/mdc2/; 1035 return("") if $no_sock && $dir =~ /\/proxy/; 1036 return("") if $no_bf && $dir =~ /\/bf/; 1037 return("") if $no_cast && $dir =~ /\/cast/; 1038 1039 $val =~ s/^\s*(.*)\s*$/$1/; 1040 @a=split(/\s+/,$val); 1041 grep(s/\.[och]$//,@a) unless $keepext; 1042 1043 @a=grep(!/^e_.*_3d$/,@a) if $no_des; 1044 @a=grep(!/^e_.*_d$/,@a) if $no_des; 1045 @a=grep(!/^e_.*_ae$/,@a) if $no_idea; 1046 @a=grep(!/^e_.*_i$/,@a) if $no_aes; 1047 @a=grep(!/^e_.*_r2$/,@a) if $no_rc2; 1048 @a=grep(!/^e_.*_r5$/,@a) if $no_rc5; 1049 @a=grep(!/^e_.*_bf$/,@a) if $no_bf; 1050 @a=grep(!/^e_.*_c$/,@a) if $no_cast; 1051 @a=grep(!/^e_rc4$/,@a) if $no_rc4; 1052 @a=grep(!/^e_camellia$/,@a) if $no_camellia; 1053 @a=grep(!/^e_seed$/,@a) if $no_seed; 1054 1055 @a=grep(!/(^s2_)|(^s23_)/,@a) if $no_ssl2; 1056 @a=grep(!/(^s3_)|(^s23_)/,@a) if $no_ssl3; 1057 1058 @a=grep(!/(_sock$)|(_acpt$)|(_conn$)|(^pxy_)/,@a) if $no_sock; 1059 1060 @a=grep(!/(^md2)|(_md2$)/,@a) if $no_md2; 1061 @a=grep(!/(^md4)|(_md4$)/,@a) if $no_md4; 1062 @a=grep(!/(^md5)|(_md5$)/,@a) if $no_md5; 1063 @a=grep(!/(rmd)|(ripemd)/,@a) if $no_ripemd; 1064 1065 @a=grep(!/(^d2i_r_)|(^i2d_r_)/,@a) if $no_rsa; 1066 @a=grep(!/(^p_open$)|(^p_seal$)/,@a) if $no_rsa; 1067 @a=grep(!/(^pem_seal$)/,@a) if $no_rsa; 1068 1069 @a=grep(!/(m_dss$)|(m_dss1$)/,@a) if $no_dsa; 1070 @a=grep(!/(^d2i_s_)|(^i2d_s_)|(_dsap$)/,@a) if $no_dsa; 1071 1072 @a=grep(!/^n_pkey$/,@a) if $no_rsa || $no_rc4; 1073 1074 @a=grep(!/_dhp$/,@a) if $no_dh; 1075 1076 @a=grep(!/(^sha[^1])|(_sha$)|(m_dss$)/,@a) if $no_sha; 1077 @a=grep(!/(^sha1)|(_sha1$)|(m_dss1$)/,@a) if $no_sha1; 1078 @a=grep(!/_mdc2$/,@a) if $no_mdc2; 1079 1080 @a=grep(!/^engine$/,@a) if $no_engine; 1081 @a=grep(!/^hw$/,@a) if $no_hw; 1082 @a=grep(!/(^rsa$)|(^genrsa$)/,@a) if $no_rsa; 1083 @a=grep(!/(^dsa$)|(^gendsa$)|(^dsaparam$)/,@a) if $no_dsa; 1084 @a=grep(!/^gendsa$/,@a) if $no_sha1; 1085 @a=grep(!/(^dh$)|(^gendh$)/,@a) if $no_dh; 1086 1087 @a=grep(!/(^dh)|(_sha1$)|(m_dss1$)/,@a) if $no_sha1; 1088 1089 grep($_="$dir/$_",@a); 1090 @a=grep(!/(^|\/)s_/,@a) if $no_sock; 1091 @a=grep(!/(^|\/)bio_sock/,@a) if $no_sock; 1092 $ret=join(' ',@a)." "; 1093 return($ret); 1094 } 1095 1096# change things so that each 'token' is only separated by one space 1097sub clean_up_ws 1098 { 1099 local($w)=@_; 1100 1101 $w =~ s/^\s*(.*)\s*$/$1/; 1102 $w =~ s/\s+/ /g; 1103 return($w); 1104 } 1105 1106sub do_defs 1107 { 1108 local($var,$files,$location,$postfix)=@_; 1109 local($_,$ret,$pf); 1110 local(*OUT,$tmp,$t); 1111 1112 $files =~ s/\//$o/g if $o ne '/'; 1113 $ret="$var="; 1114 $n=1; 1115 $Vars{$var}.=""; 1116 foreach (split(/ /,$files)) 1117 { 1118 $orig=$_; 1119 $_=&bname($_) unless /^\$/; 1120 if ($n++ == 2) 1121 { 1122 $n=0; 1123 $ret.="\\\n\t"; 1124 } 1125 if (($_ =~ /bss_file/) && ($postfix eq ".h")) 1126 { $pf=".c"; } 1127 else { $pf=$postfix; } 1128 if ($_ =~ /BN_ASM/) { $t="$_ "; } 1129 elsif ($_ =~ /BNCO_ASM/){ $t="$_ "; } 1130 elsif ($_ =~ /DES_ENC/) { $t="$_ "; } 1131 elsif ($_ =~ /BF_ENC/) { $t="$_ "; } 1132 elsif ($_ =~ /CAST_ENC/){ $t="$_ "; } 1133 elsif ($_ =~ /RC4_ENC/) { $t="$_ "; } 1134 elsif ($_ =~ /RC5_ENC/) { $t="$_ "; } 1135 elsif ($_ =~ /MD5_ASM/) { $t="$_ "; } 1136 elsif ($_ =~ /SHA1_ASM/){ $t="$_ "; } 1137 elsif ($_ =~ /AES_ASM/){ $t="$_ "; } 1138 elsif ($_ =~ /RMD160_ASM/){ $t="$_ "; } 1139 elsif ($_ =~ /CPUID_ASM/){ $t="$_ "; } 1140 else { $t="$location${o}$_$pf "; } 1141 1142 $Vars{$var}.="$t "; 1143 $ret.=$t; 1144 } 1145 # hack to add version info on MSVC 1146 if ($shlib && (($platform eq "VC-WIN32") || ($platfrom eq "VC-WIN64I") || ($platform eq "VC-WIN64A") || ($platform eq "VC-NT"))) 1147 { 1148 if ($var eq "CRYPTOOBJ") 1149 { $ret.="\$(OBJ_D)\\\$(CRYPTO).res "; } 1150 elsif ($var eq "SSLOBJ") 1151 { $ret.="\$(OBJ_D)\\\$(SSL).res "; } 1152 } 1153 chomp($ret); 1154 $ret.="\n\n"; 1155 return($ret); 1156 } 1157 1158# return the name with the leading path removed 1159sub bname 1160 { 1161 local($ret)=@_; 1162 $ret =~ s/^.*[\\\/]([^\\\/]+)$/$1/; 1163 return($ret); 1164 } 1165 1166 1167############################################################## 1168# do a rule for each file that says 'compile' to new direcory 1169# compile the files in '$files' into $to 1170sub do_compile_rule 1171 { 1172 local($to,$files,$ex)=@_; 1173 local($ret,$_,$n); 1174 1175 $files =~ s/\//$o/g if $o ne '/'; 1176 foreach (split(/\s+/,$files)) 1177 { 1178 $n=&bname($_); 1179 $ret.=&cc_compile_target("$to${o}$n$obj","${_}.c",$ex) 1180 } 1181 return($ret); 1182 } 1183 1184############################################################## 1185# do a rule for each file that says 'compile' to new direcory 1186sub cc_compile_target 1187 { 1188 local($target,$source,$ex_flags)=@_; 1189 local($ret); 1190 1191 $ex_flags.=" -DMK1MF_BUILD -D$platform_cpp_symbol" if ($source =~ /cversion/); 1192 $target =~ s/\//$o/g if $o ne "/"; 1193 $source =~ s/\//$o/g if $o ne "/"; 1194 $ret ="$target: \$(SRC_D)$o$source\n\t"; 1195 $ret.="\$(CC) ${ofile}$target $ex_flags -c \$(SRC_D)$o$source\n\n"; 1196 return($ret); 1197 } 1198 1199############################################################## 1200sub do_asm_rule 1201 { 1202 local($target,$src)=@_; 1203 local($ret,@s,@t,$i); 1204 1205 $target =~ s/\//$o/g if $o ne "/"; 1206 $src =~ s/\//$o/g if $o ne "/"; 1207 1208 @s=split(/\s+/,$src); 1209 @t=split(/\s+/,$target); 1210 1211 for ($i=0; $i<=$#s; $i++) 1212 { 1213 $ret.="$t[$i]: $s[$i]\n"; 1214 $ret.="\t\$(ASM) $afile$t[$i] \$(SRC_D)$o$s[$i]\n\n"; 1215 } 1216 return($ret); 1217 } 1218 1219sub do_shlib_rule 1220 { 1221 local($n,$def)=@_; 1222 local($ret,$nn); 1223 local($t); 1224 1225 ($nn=$n) =~ tr/a-z/A-Z/; 1226 $ret.="$n.dll: \$(${nn}OBJ)\n"; 1227 if ($vc && $w32) 1228 { 1229 $ret.="\t\$(MKSHLIB) $efile$n.dll $def @<<\n \$(${nn}OBJ_F)\n<<\n"; 1230 } 1231 $ret.="\n"; 1232 return($ret); 1233 } 1234 1235# do a rule for each file that says 'copy' to new direcory on change 1236sub do_copy_rule 1237 { 1238 local($to,$files,$p)=@_; 1239 local($ret,$_,$n,$pp); 1240 1241 $files =~ s/\//$o/g if $o ne '/'; 1242 foreach (split(/\s+/,$files)) 1243 { 1244 $n=&bname($_); 1245 if ($n =~ /bss_file/) 1246 { $pp=".c"; } 1247 else { $pp=$p; } 1248 $ret.="$to${o}$n$pp: \$(SRC_D)$o$_$pp\n\t\$(CP) \"\$(SRC_D)$o$_$pp\" \"$to${o}$n$pp\"\n\n"; 1249 } 1250 return($ret); 1251 } 1252 1253sub read_options 1254 { 1255 # Many options are handled in a similar way. In particular 1256 # no-xxx sets zero or more scalars to 1. 1257 # Process these using a hash containing the option name and 1258 # reference to the scalars to set. 1259 1260 my %valid_options = ( 1261 "no-rc2" => \$no_rc2, 1262 "no-rc4" => \$no_rc4, 1263 "no-rc5" => \$no_rc5, 1264 "no-idea" => \$no_idea, 1265 "no-aes" => \$no_aes, 1266 "no-camellia" => \$no_camellia, 1267 "no-seed" => \$no_seed, 1268 "no-des" => \$no_des, 1269 "no-bf" => \$no_bf, 1270 "no-cast" => \$no_cast, 1271 "no-md2" => \$no_md2, 1272 "no-md4" => \$no_md4, 1273 "no-md5" => \$no_md5, 1274 "no-sha" => \$no_sha, 1275 "no-sha1" => \$no_sha1, 1276 "no-ripemd" => \$no_ripemd, 1277 "no-mdc2" => \$no_mdc2, 1278 "no-patents" => 1279 [\$no_rc2, \$no_rc4, \$no_rc5, \$no_idea, \$no_rsa], 1280 "no-rsa" => \$no_rsa, 1281 "no-dsa" => \$no_dsa, 1282 "no-dh" => \$no_dh, 1283 "no-hmac" => \$no_hmac, 1284 "no-asm" => \$no_asm, 1285 "nasm" => \$nasm, 1286 "ml64" => \$ml64, 1287 "nw-nasm" => \$nw_nasm, 1288 "nw-mwasm" => \$nw_mwasm, 1289 "gaswin" => \$gaswin, 1290 "no-ssl2" => \$no_ssl2, 1291 "no-ssl3" => \$no_ssl3, 1292 "no-tlsext" => \$no_tlsext, 1293 "no-cms" => \$no_cms, 1294 "no-jpake" => \$no_jpake, 1295 "no-capieng" => \$no_capieng, 1296 "no-err" => \$no_err, 1297 "no-sock" => \$no_sock, 1298 "no-krb5" => \$no_krb5, 1299 "no-ec" => \$no_ec, 1300 "no-ecdsa" => \$no_ecdsa, 1301 "no-ecdh" => \$no_ecdh, 1302 "no-engine" => \$no_engine, 1303 "no-hw" => \$no_hw, 1304 "just-ssl" => 1305 [\$no_rc2, \$no_idea, \$no_des, \$no_bf, \$no_cast, 1306 \$no_md2, \$no_sha, \$no_mdc2, \$no_dsa, \$no_dh, 1307 \$no_ssl2, \$no_err, \$no_ripemd, \$no_rc5, 1308 \$no_aes, \$no_camellia, \$no_seed], 1309 "rsaref" => 0, 1310 "gcc" => \$gcc, 1311 "debug" => \$debug, 1312 "profile" => \$profile, 1313 "shlib" => \$shlib, 1314 "dll" => \$shlib, 1315 "shared" => 0, 1316 "no-gmp" => 0, 1317 "no-rfc3779" => 0, 1318 "no-montasm" => 0, 1319 "no-shared" => 0, 1320 "no-zlib" => 0, 1321 "no-zlib-dynamic" => 0, 1322 "fips" => \$fips, 1323 "fipscanisterbuild" => [\$fips, \$fipscanisterbuild], 1324 "fipsdso" => [\$fips, \$fipscanisterbuild, \$fipsdso], 1325 ); 1326 1327 if (exists $valid_options{$_}) 1328 { 1329 my $r = $valid_options{$_}; 1330 if ( ref $r eq "SCALAR") 1331 { $$r = 1;} 1332 elsif ( ref $r eq "ARRAY") 1333 { 1334 my $r2; 1335 foreach $r2 (@$r) 1336 { 1337 $$r2 = 1; 1338 } 1339 } 1340 } 1341 elsif (/^no-comp$/) { $xcflags = "-DOPENSSL_NO_COMP $xcflags"; } 1342 elsif (/^enable-zlib$/) { $zlib_opt = 1 if $zlib_opt == 0 } 1343 elsif (/^enable-zlib-dynamic$/) 1344 { 1345 $zlib_opt = 2; 1346 } 1347 elsif (/^no-static-engine/) 1348 { 1349 $no_static_engine = 1; 1350 } 1351 elsif (/^enable-static-engine/) 1352 { 1353 $no_static_engine = 0; 1354 } 1355 # There are also enable-xxx options which correspond to 1356 # the no-xxx. Since the scalars are enabled by default 1357 # these can be ignored. 1358 elsif (/^enable-/) 1359 { 1360 my $t = $_; 1361 $t =~ s/^enable/no/; 1362 if (exists $valid_options{$t}) 1363 {return 1;} 1364 return 0; 1365 } 1366 # experimental-xxx is mostly like enable-xxx, but opensslconf.v 1367 # will still set OPENSSL_NO_xxx unless we set OPENSSL_EXPERIMENTAL_xxx. 1368 # (No need to fail if we don't know the algorithm -- this is for adventurous users only.) 1369 elsif (/^experimental-/) 1370 { 1371 my $algo, $ALGO; 1372 ($algo = $_) =~ s/^experimental-//; 1373 ($ALGO = $algo) =~ tr/[a-z]/[A-Z]/; 1374 1375 $xcflags="-DOPENSSL_EXPERIMENTAL_$ALGO $xcflags"; 1376 1377 } 1378 elsif (/^--with-krb5-flavor=(.*)$/) 1379 { 1380 my $krb5_flavor = $1; 1381 if ($krb5_flavor =~ /^force-[Hh]eimdal$/) 1382 { 1383 $xcflags="-DKRB5_HEIMDAL $xcflags"; 1384 } 1385 elsif ($krb5_flavor =~ /^MIT/i) 1386 { 1387 $xcflags="-DKRB5_MIT $xcflags"; 1388 if ($krb5_flavor =~ /^MIT[._-]*1[._-]*[01]/i) 1389 { 1390 $xcflags="-DKRB5_MIT_OLD11 $xcflags" 1391 } 1392 } 1393 } 1394 elsif (/^([^=]*)=(.*)$/){ $VARS{$1}=$2; } 1395 elsif (/^-[lL].*$/) { $l_flags.="$_ "; } 1396 elsif ((!/^-help/) && (!/^-h/) && (!/^-\?/) && /^-.*$/) 1397 { $c_flags.="$_ "; } 1398 else { return(0); } 1399 return(1); 1400 } 1401 1402sub fipslib_error 1403 { 1404 print STDERR "***FIPS module directory sanity check failed***\n"; 1405 print STDERR "FIPS module build failed, or was deleted\n"; 1406 print STDERR "Please rebuild FIPS module.\n"; 1407 exit 1; 1408 } 1409 1410sub fips_check_files 1411 { 1412 my $dir = shift @_; 1413 my $ret = 1; 1414 if (!-d $dir) 1415 { 1416 print STDERR "FIPS module directory $dir does not exist\n"; 1417 fipslib_error(); 1418 } 1419 foreach (@_) 1420 { 1421 if (!-f "$dir${o}$_") 1422 { 1423 print STDERR "FIPS module file $_ does not exist!\n"; 1424 $ret = 0; 1425 } 1426 } 1427 fipslib_error() if ($ret == 0); 1428 } 1429