diff options
author | Shigeki Ohtsu <ohtsu@ohtsu.org> | 2018-03-07 21:38:23 +0900 |
---|---|---|
committer | Shigeki Ohtsu <ohtsu@ohtsu.org> | 2018-04-10 06:45:44 +0900 |
commit | 99eb744842462bad1c1c112d7994ffc6f65b06d9 (patch) | |
tree | 839773c539df830e204dce3c872841554a8dd023 /deps/openssl/config/generate_gypi.pl | |
parent | 1bcb6c0d26de749a806523de97b9309da839514d (diff) | |
download | android-node-v8-99eb744842462bad1c1c112d7994ffc6f65b06d9.tar.gz android-node-v8-99eb744842462bad1c1c112d7994ffc6f65b06d9.tar.bz2 android-node-v8-99eb744842462bad1c1c112d7994ffc6f65b06d9.zip |
deps: add gyp, header and Makefile for openssl110
This commit has a new binding scheme in builing OpenSSL-1.1.0 library
with Node. OpenSSL-1.1.0 uses a new build system with perl for various
supported platforms. See `Configurations/README` and
`Configurations/README.design` in the OpenSSL source for details.
In order to build OpenSSL library without perl in the build of Node
for various supported platforms, platform dependent files (e.g. asm
and header files ) are pre-generated and stored into the `config/arch`
directory.
- Makefile and generate_gypi.pl
Makefile has supported platform list and generates and copies platform
dependent files (e.g. asm files) into arch directory with
generate_gypi.pl. Platform dependent gypi files also created obtaining
build information from `configdata.pm` that is generated with
`Configure` in the OpenSSL build system.
For Windows, `Configure` generates makefile that is only available to
nmake command. Since nmake is not supported in Linux,
`Makefile_VC-WIN32` and `Makefile_VC-WIN64A` are made created by hand
for the use of GNU make. If make rules or targets are changed in the
version up of OpenSSL, they should be also updated.
The following files are used in upgrading openssl-1.1.0.
- gyp and gypi files
openssl.gyp has two targets of openssl and openssl-cli referred from
node.gyp. They includes asm and no_asm gypi files with arch dependent
gypi according to its build options and platforms . The gyp data which
is common with asm and no_asm are stored in openssl_common.gypi.
- header files
bn_conf.h, dso_conf.h and opensslconf.h are platform dependent in the
OpenSSL sources. They are replaced with *.h.tmpl files to include the
file in the `../../../config/` and referred to each arch files that
depends on asm and no-asm option.
Fixes: https://github.com/nodejs/node/issues/4270
PR-URL: https://github.com/nodejs/node/pull/19794
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Rod Vagg <rod@vagg.org>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Diffstat (limited to 'deps/openssl/config/generate_gypi.pl')
-rwxr-xr-x | deps/openssl/config/generate_gypi.pl | 165 |
1 files changed, 165 insertions, 0 deletions
diff --git a/deps/openssl/config/generate_gypi.pl b/deps/openssl/config/generate_gypi.pl new file mode 100755 index 0000000000..5c50c9953d --- /dev/null +++ b/deps/openssl/config/generate_gypi.pl @@ -0,0 +1,165 @@ +#! /usr/bin/env perl -w +use 5.10.0; +use strict; +use FindBin; +use lib "$FindBin::Bin/../openssl/"; +use lib "$FindBin::Bin/../openssl/util/perl"; +use File::Basename; +use File::Spec::Functions qw/:DEFAULT abs2rel rel2abs/; +use File::Copy; +use File::Path qw/make_path/; +use with_fallback qw(Text::Template); + +# Read configdata from ../openssl/configdata.pm that is generated +# with ../openssl/Configure options arch +use configdata; + +my $asm = $ARGV[0]; + +unless ($asm eq "asm" or $asm eq "no-asm") { + die "Error: $asm is invalid argument"; +} +my $arch = $ARGV[1]; + +# nasm version check +my $nasm_banner = `nasm -v`; +die "Error: nasm is not installed." if (!$nasm_banner); + +my $nasm_version_min = 2.11; +my ($nasm_version) = ($nasm_banner =~/^NASM version ([0-9]\.[0-9][0-9])+/); +if ($nasm_version < $nasm_version_min) { + die "Error: nasm version $nasm_version is too old." . + "$nasm_version_min or higher is required."; +} + +# gas version check +my $gas_version_min = 2.26; +my $gas_banner = `gcc -Wa,-v -c -o /dev/null -x assembler /dev/null 2>&1`; +my ($gas_version) = ($gas_banner =~/GNU assembler version ([2-9]\.[0-9]+)/); +if ($gas_version < $gas_version_min) { + die "Error: gas version $gas_version is too old." . + "$gas_version_min or higher is required."; +} + +my $src_dir = "../openssl"; +my $arch_dir = "../config/archs/$arch"; +my $base_dir = "$arch_dir/$asm"; + +my $is_win = ($arch =~/^VC-WIN/); +# VC-WIN32 and VC-WIN64A generate makefile but it can be available +# with only nmake. Use pre-created Makefile_VC_WIN32 +# Makefile_VC-WIN64A instead. +my $makefile = $is_win ? "../config/Makefile_$arch": "Makefile"; +# Generate arch dependent header files with Makefile +my $buildinf = "crypto/buildinf.h"; +my $progs = "apps/progs.h"; +my $cmd1 = "cd ../openssl; make -f $makefile build_generated $buildinf $progs;"; +system($cmd1) == 0 or die "Error in system($cmd1)"; + +# Copy and move all arch dependent header files into config/archs +make_path("$base_dir/crypto/include/internal", "$base_dir/include/openssl", + { + error => \my $make_path_err}); +if (@$make_path_err) { + for my $diag (@$make_path_err) { + my ($file, $message) = %$diag; + die "make_path error: $file $message\n"; + } +} +copy("$src_dir/configdata.pm", "$base_dir/") or die "Copy failed: $!"; +copy("$src_dir/include/openssl/opensslconf.h", + "$base_dir/include/openssl/") or die "Copy failed: $!"; +move("$src_dir/crypto/include/internal/bn_conf.h", + "$base_dir/crypto/include/internal/") or die "Move failed: $!"; +move("$src_dir/crypto/include/internal/dso_conf.h", + "$base_dir/crypto/include/internal/") or die "Move failed: $!"; +copy("$src_dir/$buildinf", + "$base_dir/crypto/") or die "Copy failed: $!"; +move("$src_dir/$progs", + "$base_dir/include") or die "Copy failed: $!"; + +# read openssl source lists from configdata.pm +my @libapps_srcs = (); +foreach my $obj (@{$unified_info{sources}->{'apps/libapps.a'}}) { + push(@libapps_srcs, ${$unified_info{sources}->{$obj}}[0]); +} + +my @libssl_srcs = (); +foreach my $obj (@{$unified_info{sources}->{libssl}}) { + push(@libssl_srcs, ${$unified_info{sources}->{$obj}}[0]); +} + +my @libcrypto_srcs = (); +my @generated_srcs = (); +foreach my $obj (@{$unified_info{sources}->{libcrypto}}) { + my $src = ${$unified_info{sources}->{$obj}}[0]; + # .S files should be preprocessed into .s + if ($unified_info{generate}->{$src}) { + # .S or .s files should be preprocessed into .asm for WIN + $src =~ s\.[sS]$\.asm\ if ($is_win); + push(@generated_srcs, $src); + } else { + push(@libcrypto_srcs, $src); + } +} + +my @apps_openssl_srcs = (); +foreach my $obj (@{$unified_info{sources}->{'apps/openssl'}}) { + push(@apps_openssl_srcs, ${$unified_info{sources}->{$obj}}[0]); +} + +# Generate all asm files and copy into config/archs +foreach my $src (@generated_srcs) { + my $cmd = "cd ../openssl; CC=gcc ASM=nasm make -f $makefile $src;" . + "cp --parents $src ../config/archs/$arch/$asm; cd ../config"; + system("$cmd") == 0 or die "Error in system($cmd)"; +} + +# Create openssl.gypi +my $template = + Text::Template->new(TYPE => 'FILE', + SOURCE => 'openssl.gypi.tmpl', + DELIMITERS => [ "%%-", "-%%" ] + ); + +my $gypi = $template->fill_in( + HASH => { + libssl_srcs => \@libssl_srcs, + libcrypto_srcs => \@libcrypto_srcs, + generated_srcs => \@generated_srcs, + config => \%config, + target => \%target, + asm => \$asm, + arch => \$arch, + is_win => \$is_win, + }); + +open(GYPI, "> ./archs/$arch/$asm/openssl.gypi"); +print GYPI "$gypi"; +close(GYPI); + +# Create openssl-cl.gypi +my $cltemplate = + Text::Template->new(TYPE => 'FILE', + SOURCE => 'openssl-cl.gypi.tmpl', + DELIMITERS => [ "%%-", "-%%" ] + ); + +my $clgypi = $cltemplate->fill_in( + HASH => { + apps_openssl_srcs => \@apps_openssl_srcs, + libapps_srcs => \@libapps_srcs, + config => \%config, + target => \%target, + arch => \$arch, + is_win => \$is_win, + }); + +open(CLGYPI, "> ./archs/$arch/$asm/openssl-cl.gypi"); +print CLGYPI "$clgypi"; +close(CLGYPI); + +# Clean Up +my $cmd2 ="cd $src_dir; make -f $makefile clean; make -f $makefile distclean;" . + "git clean -f $src_dir/crypto"; +system($cmd2) == 0 or die "Error in system($cmd2)"; |