1diff -ur misc/openssl-1.0.2p/Configure misc/build/openssl-1.0.2p/Configure 2--- misc/openssl-1.0.2p/Configure 2018-08-14 05:49:04.000000000 -0700 3+++ misc/build/openssl-1.0.2p/Configure 2018-08-26 14:51:25.397910000 -0700 4@@ -477,19 +477,20 @@ 5 "android-mips","gcc:-mandroid -I\$(ANDROID_DEV)/include -B\$(ANDROID_DEV)/lib -O3 -Wall::-D_REENTRANT::-ldl:BN_LLONG RC4_CHAR RC4_CHUNK DES_INT DES_UNROLL BF_PTR:${mips32_asm}:o32:dlfcn:linux-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)", 6 7 #### *BSD [do see comment about ${BSDthreads} above!] 8-"BSD-generic32","gcc:-O3 -fomit-frame-pointer -Wall::${BSDthreads}:::BN_LLONG RC2_CHAR RC4_INDEX DES_INT DES_UNROLL:${no_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)", 9-"BSD-x86", "gcc:-DL_ENDIAN -O3 -fomit-frame-pointer -Wall::${BSDthreads}:::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_asm}:a.out:dlfcn:bsd-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)", 10-"BSD-x86-elf", "gcc:-DL_ENDIAN -O3 -fomit-frame-pointer -Wall::${BSDthreads}:::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:bsd-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)", 11-"debug-BSD-x86-elf", "gcc:-DL_ENDIAN -O3 -Wall -g::${BSDthreads}:::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:bsd-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)", 12-"BSD-sparcv8", "gcc:-DB_ENDIAN -O3 -mcpu=v8 -Wall::${BSDthreads}:::BN_LLONG RC2_CHAR RC4_INDEX DES_INT DES_UNROLL:${sparcv8_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)", 13+"BSD-generic32","$ENV{'FREEBSDCC'}:-O3 -fomit-frame-pointer -Wall $ENV{'CFLAGS'}::${BSDthreads}:::BN_LLONG RC2_CHAR RC4_INDEX DES_INT DES_UNROLL:${no_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIBVER)", 14+"BSD-x86", "$ENV{'FREEBSDCC'}:-DL_ENDIAN -O3 -fomit-frame-pointer -Wall $ENV{'CFLAGS'}::${BSDthreads}:::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_asm}:a.out:dlfcn:bsd-shared:-fPIC::.so.\$(SHLIBVER)", 15+"BSD-x86-elf", "$ENV{'FREEBSDCC'}:-DL_ENDIAN -O3 -fomit-frame-pointer -Wall $ENV{'CFLAGS'}::${BSDthreads}:::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:bsd-shared:-fPIC::.so.\$(SHLIBVER)", 16+"debug-BSD-x86-elf", "$ENV{'FREEBSDCC'}:-DL_ENDIAN -O3 -Wall -g $ENV{'CFLAGS'}::${BSDthreads}:::BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:bsd-shared:-fPIC::.so.\$(SHLIBVER)", 17+"BSD-sparcv8", "$ENV{'FREEBSDCC'}:-DB_ENDIAN -O3 -mcpu=v8 -Wall $ENV{'CFLAGS'}::${BSDthreads}:::BN_LLONG RC2_CHAR RC4_INDEX DES_INT DES_UNROLL:${sparcv8_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIBVER)", 18 19-"BSD-generic64","gcc:-O3 -Wall::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${no_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)", 20+"BSD-generic64","$ENV{'FREEBSDCC'}:-O3 -Wall $ENV{'CFLAGS'}::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${no_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIBVER)", 21 # -DMD32_REG_T=int doesn't actually belong in sparc64 target, it 22 # simply *happens* to work around a compiler bug in gcc 3.3.3, 23 # triggered by RIPEMD160 code. 24-"BSD-sparc64", "gcc:-DB_ENDIAN -O3 -DMD32_REG_T=int -Wall::${BSDthreads}:::BN_LLONG RC2_CHAR RC4_CHUNK DES_INT DES_PTR DES_RISC2 BF_PTR:${sparcv9_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)", 25-"BSD-ia64", "gcc:-DL_ENDIAN -O3 -Wall::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_UNROLL DES_INT:${ia64_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)", 26-"BSD-x86_64", "cc:-DL_ENDIAN -O3 -Wall::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)", 27+"BSD-sparc64", "$ENV{'FREEBSDCC'}:-DB_ENDIAN -O3 -DMD32_REG_T=int -Wall $ENV{'CFLAGS'}::${BSDthreads}:::BN_LLONG RC2_CHAR RC4_CHUNK DES_INT DES_PTR DES_RISC2 BF_PTR:${sparcv9_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIBVER)", 28+"BSD-ia64", "$ENV{'FREEBSDCC'}:-DL_ENDIAN -O3 -Wall $ENV{'CFLAGS'}::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_UNROLL DES_INT:${ia64_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIBVER)", 29+"BSD-x86_64", "$ENV{'FREEBSDCC'}:-DL_ENDIAN -O3 -Wall $ENV{'CFLAGS'}::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_INT DES_UNROLL:${x86_64_asm}:elf:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIBVER)", 30+"BSD-alpha", "$ENV{'FREEBSDCC'}:-DL_ENDIAN -O -Wall $ENV{'CFLAGS'}::${BSDthreads}:::SIXTY_FOUR_BIT_LONG RC4_CHUNK DES_UNROLL DES_RISC1:${no_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIBVER)", 31 32 "bsdi-elf-gcc", "gcc:-DPERL5 -DL_ENDIAN -fomit-frame-pointer -O3 -march=i486 -Wall::(unknown)::-ldl:BN_LLONG ${x86_gcc_des} ${x86_gcc_opts}:${x86_elf_asm}:dlfcn:bsd-gcc-shared:-fPIC::.so.\$(SHLIB_MAJOR).\$(SHLIB_MINOR)", 33 34@@ -592,9 +593,9 @@ 35 "debug-VC-WIN64A","cl:-W3 -Gs0 -Gy -Zi -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -DUNICODE -D_UNICODE -D_CRT_SECURE_NO_DEPRECATE:::WIN64A::SIXTY_FOUR_BIT RC4_CHUNK_LL DES_INT EXPORT_VAR_AS_FN:".eval{my $asm=$x86_64_asm;$asm=~s/x86_64-gcc\.o/bn_asm.o/;$asm}.":auto:win32", 36 # x86 Win32 target defaults to ANSI API, if you want UNICODE, complement 37 # 'perl Configure VC-WIN32' with '-DUNICODE -D_UNICODE' 38-"VC-WIN32","cl:-W3 -WX -Gs0 -GF -Gy -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -D_CRT_SECURE_NO_DEPRECATE -D_WINSOCK_DEPRECATED_NO_WARNINGS:::WIN32::BN_LLONG RC4_INDEX EXPORT_VAR_AS_FN ${x86_gcc_opts}:${x86_asm}:win32n:win32", 39+"VC-WIN32","cl:-W3 -w44129 -WX -Gs0 -GF -Gy -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -D_CRT_SECURE_NO_DEPRECATE -D_WINSOCK_DEPRECATED_NO_WARNINGS:::WIN32::BN_LLONG RC4_INDEX EXPORT_VAR_AS_FN ${x86_gcc_opts}:${x86_asm}:win32n:win32", 40 # Unified CE target 41-"debug-VC-WIN32","cl:-W3 -WX -Gs0 -GF -Gy -Zi -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -D_CRT_SECURE_NO_DEPRECATE -D_WINSOCK_DEPRECATED_NO_WARNINGS:::WIN32::BN_LLONG RC4_INDEX EXPORT_VAR_AS_FN ${x86_gcc_opts}:${x86_asm}:win32n:win32", 42+"debug-VC-WIN32","cl:-W3 -W44129 -WX -Gs0 -GF -Gy -Zi -nologo -DOPENSSL_SYSNAME_WIN32 -DWIN32_LEAN_AND_MEAN -DL_ENDIAN -D_CRT_SECURE_NO_DEPRECATE -D_WINSOCK_DEPRECATED_NO_WARNINGS:::WIN32::BN_LLONG RC4_INDEX EXPORT_VAR_AS_FN ${x86_gcc_opts}:${x86_asm}:win32n:win32", 43 "VC-CE","cl::::WINCE::BN_LLONG RC4_INDEX EXPORT_VAR_AS_FN ${x86_gcc_opts}:${no_asm}:win32", 44 45 # Borland C++ 4.5 46@@ -2065,10 +2066,12 @@ 47 if ( $perl =~ m@^/@) { 48 &dofile("tools/c_rehash",$perl,'^#!/', '#!%s','^my \$dir;$', 'my $dir = "' . $openssldir . '";', '^my \$prefix;$', 'my $prefix = "' . $prefix . '";'); 49 &dofile("apps/CA.pl",$perl,'^#!/', '#!%s'); 50+ &dofile("apps/tsget",$perl,'^#!/', '#!%s'); 51 } else { 52 # No path for Perl known ... 53 &dofile("tools/c_rehash",'/usr/local/bin/perl','^#!/', '#!%s','^my \$dir;$', 'my $dir = "' . $openssldir . '";', '^my \$prefix;$', 'my $prefix = "' . $prefix . '";'); 54 &dofile("apps/CA.pl",'/usr/local/bin/perl','^#!/', '#!%s'); 55+ &dofile("apps/tsget",'/usr/local/bin/perl',,'^#!/', '#!%s'); 56 } 57 if ($depflags ne $default_depflags && !$make_depend) { 58 $warn_make_depend++; 59diff -ur misc/openssl-1.0.2p/config misc/build/openssl-1.0.2p/config 60--- misc/openssl-1.0.2p/config 2018-08-14 05:48:56.000000000 -0700 61+++ misc/build/openssl-1.0.2p/config 2018-08-26 14:49:34.431584000 -0700 62@@ -762,14 +762,8 @@ 63 sparc64-*-*bsd*) OUT="BSD-sparc64" ;; 64 ia64-*-*bsd*) OUT="BSD-ia64" ;; 65 amd64-*-*bsd*) OUT="BSD-x86_64" ;; 66- *86*-*-*bsd*) # mimic ld behaviour when it's looking for libc... 67- if [ -L /usr/lib/libc.so ]; then # [Free|Net]BSD 68- libc=/usr/lib/libc.so 69- else # OpenBSD 70- # ld searches for highest libc.so.* and so do we 71- libc=`(ls /usr/lib/libc.so.* /lib/libc.so.* | tail -1) 2>/dev/null` 72- fi 73- case "`(file -L $libc) 2>/dev/null`" in 74+ *86*-*-*bsd*) 75+ case "`(file -L /bin/sh) 2>/dev/null`" in 76 *ELF*) OUT="BSD-x86-elf" ;; 77 *) OUT="BSD-x86"; options="$options no-sse2" ;; 78 esac ;; 79diff -ur misc/openssl-1.0.2p/ms/do_ms.bat misc/build/openssl-1.0.2p/ms/do_ms.bat 80--- misc/openssl-1.0.2p/ms/do_ms.bat 2018-08-14 05:48:59.000000000 -0700 81+++ misc/build/openssl-1.0.2p/ms/do_ms.bat 2018-08-26 14:49:34.432106000 -0700 82@@ -1,11 +1,11 @@ 83 84-perl util\mkfiles.pl >MINFO 85-perl util\mk1mf.pl no-asm VC-WIN32 >ms\nt.mak 86-perl util\mk1mf.pl dll no-asm VC-WIN32 >ms\ntdll.mak 87+%1 util\mkfiles.pl >MINFO 88+%1 util\mk1mf.pl no-asm VC-WIN32 >ms\nt.mak 89+%1 util\mk1mf.pl dll no-asm VC-WIN32 >ms\ntdll.mak 90 if x%OSVERSION% == x goto skipce 91-perl util\mk1mf.pl no-asm VC-CE >ms\ce.mak 92-perl util\mk1mf.pl dll no-asm VC-CE >ms\cedll.mak 93+%1 util\mk1mf.pl no-asm VC-CE >ms\ce.mak 94+%1 util\mk1mf.pl dll no-asm VC-CE >ms\cedll.mak 95 :skipce 96 97-perl util\mkdef.pl 32 libeay > ms\libeay32.def 98-perl util\mkdef.pl 32 ssleay > ms\ssleay32.def 99+%1 util\mkdef.pl 32 libeay > ms\libeay32.def 100+%1 util\mkdef.pl 32 ssleay > ms\ssleay32.def 101diff -ur misc/openssl-1.0.2p/ms/do_win64a.bat misc/build/openssl-1.0.2p/ms/do_win64a.bat 102--- misc/openssl-1.0.2p/ms/do_win64a.bat 2018-08-14 05:48:59.000000000 -0700 103+++ misc/build/openssl-1.0.2p/ms/do_win64a.bat 2018-08-26 14:49:34.432647000 -0700 104@@ -1,19 +1,19 @@ 105-perl util\mkfiles.pl >MINFO 106+%1 util\mkfiles.pl >MINFO 107 108 cmd /c "nasm -f win64 -v" >NUL 2>&1 109 if %errorlevel% neq 0 goto ml64 110 111-perl ms\uplink-x86_64.pl nasm > ms\uptable.asm 112+%1 ms\uplink-x86_64.pl nasm > ms\uptable.asm 113 nasm -f win64 -o ms\uptable.obj ms\uptable.asm 114 goto proceed 115 116 :ml64 117-perl ms\uplink-x86_64.pl masm > ms\uptable.asm 118+%1 ms/uplink-x86_64.pl masm > ms/uptable.asm 119 ml64 -c -Foms\uptable.obj ms\uptable.asm 120 121 :proceed 122-perl util\mk1mf.pl VC-WIN64A >ms\nt.mak 123-perl util\mk1mf.pl dll VC-WIN64A >ms\ntdll.mak 124+%1 util\mk1mf.pl VC-WIN64A >ms\nt.mak 125+%1 util\mk1mf.pl dll VC-WIN64A >ms\ntdll.mak 126 127-perl util\mkdef.pl 32 libeay > ms\libeay32.def 128-perl util\mkdef.pl 32 ssleay > ms\ssleay32.def 129+%1 util\mkdef.pl 32 libeay > ms\libeay32.def 130+%1 util\mkdef.pl 32 ssleay > ms\ssleay32.def 131diff -ur misc/openssl-1.0.2p/util/mk1mf.pl misc/build/openssl-1.0.2p/util/mk1mf.pl 132--- misc/openssl-1.0.2p/util/mk1mf.pl 2018-08-14 05:48:59.000000000 -0700 133+++ misc/build/openssl-1.0.2p/util/mk1mf.pl 2018-08-26 14:49:34.433421000 -0700 134@@ -163,7 +163,7 @@ 135 $inc_def="outinc"; 136 $tmp_def="tmp"; 137 138-$perl="perl" unless defined $perl; 139+$perl="$ENV{PERL}" unless defined $perl; 140 $mkdir="-mkdir" unless defined $mkdir; 141 142 ($ssl,$crypto)=("ssl","crypto"); 143@@ -346,6 +346,11 @@ 144 s/\s*$//; # was chop, didn't work in mixture of perls for Windows... 145 146 ($key,$val)=/^([^=]+)=(.*)/; 147+ 148+ # On some Windows machines, $val has linefeeds at the end, which confuses 149+ # subsequent code in this file. So we strip all whitespace at the end. 150+ $val =~ s/\s+$//; 151+ 152 if ($key eq "RELATIVE_DIRECTORY") 153 { 154 if ($lib ne "") 155diff -ur misc/openssl-1.0.2p/util/pl/VC-32.pl misc/build/openssl-1.0.2p/util/pl/VC-32.pl 156--- misc/openssl-1.0.2p/util/pl/VC-32.pl 2018-08-14 05:48:59.000000000 -0700 157+++ misc/build/openssl-1.0.2p/util/pl/VC-32.pl 2018-08-26 14:49:57.553776000 -0700 158@@ -30,7 +30,7 @@ 159 my $ff = ""; 160 161 # C compiler stuff 162-$cc='cl'; 163+$cc=$ENV{'CC'}; 164 if ($FLAVOR =~ /WIN64/) 165 { 166 # Note that we currently don't have /WX on Win64! There is a lot of 167