aboutsummaryrefslogtreecommitdiff
path: root/openssl-1.1.0h/util
diff options
context:
space:
mode:
Diffstat (limited to 'openssl-1.1.0h/util')
-rw-r--r--openssl-1.1.0h/util/build.info8
-rwxr-xr-xopenssl-1.1.0h/util/ck_errf.pl70
-rw-r--r--openssl-1.1.0h/util/copy.pl78
-rw-r--r--openssl-1.1.0h/util/dofile.pl210
-rwxr-xr-xopenssl-1.1.0h/util/find-doc-nits549
-rwxr-xr-xopenssl-1.1.0h/util/find-undoc-api.pl82
-rwxr-xr-xopenssl-1.1.0h/util/find-unused-errs35
-rw-r--r--openssl-1.1.0h/util/fipslink.pl115
-rwxr-xr-xopenssl-1.1.0h/util/incore454
-rw-r--r--openssl-1.1.0h/util/indent.pro672
-rw-r--r--openssl-1.1.0h/util/libcrypto.num4236
-rw-r--r--openssl-1.1.0h/util/libssl.num407
-rw-r--r--openssl-1.1.0h/util/local_shlib.com.in30
-rwxr-xr-xopenssl-1.1.0h/util/mkbuildinf.pl41
-rwxr-xr-xopenssl-1.1.0h/util/mkcerts.sh220
-rwxr-xr-xopenssl-1.1.0h/util/mkdef.pl1685
-rwxr-xr-xopenssl-1.1.0h/util/mkdir-p.pl44
-rw-r--r--openssl-1.1.0h/util/mkerr.pl771
-rwxr-xr-xopenssl-1.1.0h/util/mkrc.pl83
-rwxr-xr-xopenssl-1.1.0h/util/openssl-format-source175
-rwxr-xr-xopenssl-1.1.0h/util/opensslwrap.sh26
-rw-r--r--openssl-1.1.0h/util/perl/OpenSSL/Glob.pm21
-rw-r--r--openssl-1.1.0h/util/perl/OpenSSL/Test.pm1051
-rw-r--r--openssl-1.1.0h/util/perl/OpenSSL/Test/Simple.pm91
-rw-r--r--openssl-1.1.0h/util/perl/OpenSSL/Test/Utils.pm240
-rw-r--r--openssl-1.1.0h/util/perl/OpenSSL/Util/Pod.pm158
-rw-r--r--openssl-1.1.0h/util/perl/TLSProxy/ClientHello.pm242
-rw-r--r--openssl-1.1.0h/util/perl/TLSProxy/Message.pm456
-rw-r--r--openssl-1.1.0h/util/perl/TLSProxy/NewSessionTicket.pm81
-rw-r--r--openssl-1.1.0h/util/perl/TLSProxy/Proxy.pm553
-rw-r--r--openssl-1.1.0h/util/perl/TLSProxy/Record.pm339
-rw-r--r--openssl-1.1.0h/util/perl/TLSProxy/ServerHello.pm210
-rw-r--r--openssl-1.1.0h/util/perl/TLSProxy/ServerKeyExchange.pm134
-rw-r--r--openssl-1.1.0h/util/perl/with_fallback.pm25
-rwxr-xr-xopenssl-1.1.0h/util/point.sh10
-rwxr-xr-xopenssl-1.1.0h/util/process_docs.pl248
-rw-r--r--openssl-1.1.0h/util/selftest.pl207
-rwxr-xr-xopenssl-1.1.0h/util/shlib_wrap.sh.in128
-rw-r--r--openssl-1.1.0h/util/su-filter.pl264
-rw-r--r--openssl-1.1.0h/util/unlocal_shlib.com.in26
40 files changed, 14475 insertions, 0 deletions
diff --git a/openssl-1.1.0h/util/build.info b/openssl-1.1.0h/util/build.info
new file mode 100644
index 0000000..609be51
--- /dev/null
+++ b/openssl-1.1.0h/util/build.info
@@ -0,0 +1,8 @@
+IF[{- $target{build_scheme}->[1] eq "VMS" -}]
+ SCRIPTS_NO_INST=local_shlib.com unlocal_shlib.com
+ SOURCE[local_shlib.com]=local_shlib.com.in
+ SOURCE[unlocal_shlib.com]=unlocal_shlib.com.in
+ELSIF[{- $target{build_scheme}->[1] eq "unix" -}]
+ SCRIPTS_NO_INST=shlib_wrap.sh
+ SOURCE[shlib_wrap.sh]=shlib_wrap.sh.in
+ENDIF
diff --git a/openssl-1.1.0h/util/ck_errf.pl b/openssl-1.1.0h/util/ck_errf.pl
new file mode 100755
index 0000000..7fc5367
--- /dev/null
+++ b/openssl-1.1.0h/util/ck_errf.pl
@@ -0,0 +1,70 @@
+#! /usr/bin/env perl
+# Copyright 1995-2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+# This is just a quick script to scan for cases where the 'error'
+# function name in a XXXerr() macro is wrong.
+#
+# Run in the top level by going
+# perl util/ck_errf.pl */*.c */*/*.c
+#
+
+my $err_strict = 0;
+my $bad = 0;
+
+foreach $file (@ARGV)
+ {
+ if ($file eq "-strict")
+ {
+ $err_strict = 1;
+ next;
+ }
+ open(IN,"<$file") || die "unable to open $file\n";
+ $func="";
+ while (<IN>)
+ {
+ if (!/;$/ && /^\**([a-zA-Z_].*[\s*])?([A-Za-z_0-9]+)\(.*([),]|$)/)
+ {
+ /^([^()]*(\([^()]*\)[^()]*)*)\(/;
+ $1 =~ /([A-Za-z_0-9]*)$/;
+ $func = $1;
+ $func =~ tr/A-Z/a-z/;
+ }
+ if (/([A-Z0-9]+)err\(([^,]+)/ && ! /ckerr_ignore/)
+ {
+ $errlib=$1;
+ $n=$2;
+
+ if ($func eq "")
+ { print "$file:$.:???:$n\n"; $bad = 1; next; }
+
+ if ($n !~ /([^_]+)_F_(.+)$/)
+ {
+ # print "check -$file:$.:$func:$n\n";
+ next;
+ }
+ $lib=$1;
+ $n=$2;
+
+ if ($lib ne $errlib)
+ { print "$file:$.:$func:$n [${errlib}err]\n"; $bad = 1; next; }
+
+ $n =~ tr/A-Z/a-z/;
+ if (($n ne $func) && ($errlib ne "SYS"))
+ { print "$file:$.:$func:$n\n"; $bad = 1; next; }
+ # print "$func:$1\n";
+ }
+ }
+ close(IN);
+ }
+
+if ($bad && $err_strict)
+ {
+ print STDERR "FATAL: error discrepancy\n";
+ exit 1;
+ }
+
diff --git a/openssl-1.1.0h/util/copy.pl b/openssl-1.1.0h/util/copy.pl
new file mode 100644
index 0000000..01964f5
--- /dev/null
+++ b/openssl-1.1.0h/util/copy.pl
@@ -0,0 +1,78 @@
+#! /usr/bin/env perl
+# Copyright 2005-2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+
+use Fcntl;
+
+
+# copy.pl
+
+# Perl script 'copy' comment. On Windows the built in "copy" command also
+# copies timestamps: this messes up Makefile dependencies.
+
+my $stripcr = 0;
+
+my $arg;
+
+foreach $arg (@ARGV) {
+ if ($arg eq "-stripcr")
+ {
+ $stripcr = 1;
+ next;
+ }
+ $arg =~ s|\\|/|g; # compensate for bug/feature in cygwin glob...
+ $arg = qq("$arg") if ($arg =~ /\s/); # compensate for bug in 5.10...
+ foreach (glob $arg)
+ {
+ push @filelist, $_;
+ }
+}
+
+$fnum = @filelist;
+
+if ($fnum <= 1)
+ {
+ die "Need at least two filenames";
+ }
+
+$dest = pop @filelist;
+
+if ($fnum > 2 && ! -d $dest)
+ {
+ die "Destination must be a directory";
+ }
+
+foreach (@filelist)
+ {
+ if (-d $dest)
+ {
+ $dfile = $_;
+ $dfile =~ s|^.*[/\\]([^/\\]*)$|$1|;
+ $dfile = "$dest/$dfile";
+ }
+ else
+ {
+ $dfile = $dest;
+ }
+ sysopen(IN, $_, O_RDONLY|O_BINARY) || die "Can't Open $_";
+ sysopen(OUT, $dfile, O_WRONLY|O_CREAT|O_TRUNC|O_BINARY)
+ || die "Can't Open $dfile";
+ while (sysread IN, $buf, 10240)
+ {
+ if ($stripcr)
+ {
+ $buf =~ tr/\015//d;
+ }
+ syswrite(OUT, $buf, length($buf));
+ }
+ close(IN);
+ close(OUT);
+ print "Copying: $_ to $dfile\n";
+ }
+
+
diff --git a/openssl-1.1.0h/util/dofile.pl b/openssl-1.1.0h/util/dofile.pl
new file mode 100644
index 0000000..fc72989
--- /dev/null
+++ b/openssl-1.1.0h/util/dofile.pl
@@ -0,0 +1,210 @@
+#! /usr/bin/env perl
+# Copyright 2016-2018 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+# Reads one or more template files and runs it through Text::Template
+#
+# It is assumed that this scripts is called with -Mconfigdata, a module
+# that holds configuration data in %config
+
+use strict;
+use warnings;
+
+use FindBin;
+use Getopt::Std;
+
+# We actually expect to get the following hash tables from configdata:
+#
+# %config
+# %target
+# %withargs
+# %unified_info
+#
+# We just do a minimal test to see that we got what we expected.
+# $config{target} must exist as an absolute minimum.
+die "You must run this script with -Mconfigdata\n" if !exists($config{target});
+
+# Make a subclass of Text::Template to override append_text_to_result,
+# as recommended here:
+#
+# http://search.cpan.org/~mjd/Text-Template-1.46/lib/Text/Template.pm#Automatic_postprocessing_of_template_hunks
+
+package OpenSSL::Template;
+
+# Because we know that Text::Template isn't a core Perl module, we use
+# a fallback in case it's not installed on the system
+use File::Basename;
+use File::Spec::Functions;
+use lib "$FindBin::Bin/perl";
+use with_fallback qw(Text::Template);
+
+#use parent qw/Text::Template/;
+use vars qw/@ISA/;
+push @ISA, qw/Text::Template/;
+
+# Override constructor
+sub new {
+ my ($class) = shift;
+
+ # Call the constructor of the parent class, Person.
+ my $self = $class->SUPER::new( @_ );
+ # Add few more attributes
+ $self->{_output_off} = 0; # Default to output hunks
+ bless $self, $class;
+ return $self;
+}
+
+sub append_text_to_output {
+ my $self = shift;
+
+ if ($self->{_output_off} == 0) {
+ $self->SUPER::append_text_to_output(@_);
+ }
+
+ return;
+}
+
+sub output_reset_on {
+ my $self = shift;
+ $self->{_output_off} = 0;
+}
+
+sub output_on {
+ my $self = shift;
+ if (--$self->{_output_off} < 0) {
+ $self->{_output_off} = 0;
+ }
+}
+
+sub output_off {
+ my $self = shift;
+ $self->{_output_off}++;
+}
+
+# Come back to main
+
+package main;
+
+# Helper functions for the templates #################################
+
+# It might be practical to quotify some strings and have them protected
+# from possible harm. These functions primarly quote things that might
+# be interpreted wrongly by a perl eval.
+
+# quotify1 STRING
+# This adds quotes (") around the given string, and escapes any $, @, \,
+# " and ' by prepending a \ to them.
+sub quotify1 {
+ my $s = my $orig = shift @_;
+ $s =~ s/([\$\@\\"'])/\\$1/g;
+ $s ne $orig || $s =~ /\s/ ? '"'.$s.'"' : $s;
+}
+
+# quotify_l LIST
+# For each defined element in LIST (i.e. elements that aren't undef), have
+# it quotified with 'quotofy1'
+sub quotify_l {
+ map {
+ if (!defined($_)) {
+ ();
+ } else {
+ quotify1($_);
+ }
+ } @_;
+}
+
+# Error reporter #####################################################
+
+# The error reporter uses %lines to figure out exactly which file the
+# error happened and at what line. Not that the line number may be
+# the start of a perl snippet rather than the exact line where it
+# happened. Nothing we can do about that here.
+
+my %lines = ();
+sub broken {
+ my %args = @_;
+ my $filename = "<STDIN>";
+ my $deducelines = 0;
+ foreach (sort keys %lines) {
+ $filename = $lines{$_};
+ last if ($_ > $args{lineno});
+ $deducelines += $_;
+ }
+ print STDERR $args{error}," in $filename, fragment starting at line ",$args{lineno}-$deducelines;
+ undef;
+}
+
+# Check options ######################################################
+
+my %opts = ();
+
+# -o ORIGINATOR
+# declares ORIGINATOR as the originating script.
+getopt('o', \%opts);
+
+my @autowarntext = ("WARNING: do not edit!",
+ "Generated"
+ . (defined($opts{o}) ? " by ".$opts{o} : "")
+ . (scalar(@ARGV) > 0 ? " from ".join(", ",@ARGV) : ""));
+
+# Template reading ###################################################
+
+# Read in all the templates into $text, while keeping track of each
+# file and its size in lines, to try to help report errors with the
+# correct file name and line number.
+
+my $prev_linecount = 0;
+my $text =
+ @ARGV
+ ? join("", map { my $x = Text::Template::_load_text($_);
+ if (!defined($x)) {
+ die $Text::Template::ERROR, "\n";
+ }
+ $x = "{- output_reset_on() -}" . $x;
+ my $linecount = $x =~ tr/\n//;
+ $prev_linecount = ($linecount += $prev_linecount);
+ $lines{$linecount} = $_;
+ $x } @ARGV)
+ : join("", <STDIN>);
+
+# Engage! ############################################################
+
+# Load the full template (combination of files) into Text::Template
+# and fill it up with our data. Output goes directly to STDOUT
+
+my $template =
+ OpenSSL::Template->new(TYPE => 'STRING',
+ SOURCE => $text,
+ PREPEND => qq{use lib "$FindBin::Bin/perl";});
+
+sub output_reset_on {
+ $template->output_reset_on();
+ "";
+}
+sub output_on {
+ $template->output_on();
+ "";
+}
+sub output_off {
+ $template->output_off();
+ "";
+}
+
+$template->fill_in(OUTPUT => \*STDOUT,
+ HASH => { config => \%config,
+ target => \%target,
+ disabled => \%disabled,
+ withargs => \%withargs,
+ unified_info => \%unified_info,
+ autowarntext => \@autowarntext,
+ quotify1 => \&quotify1,
+ quotify_l => \&quotify_l,
+ output_reset_on => \&output_reset_on,
+ output_on => \&output_on,
+ output_off => \&output_off },
+ DELIMITERS => [ "{-", "-}" ],
+ BROKEN => \&broken);
diff --git a/openssl-1.1.0h/util/find-doc-nits b/openssl-1.1.0h/util/find-doc-nits
new file mode 100755
index 0000000..598854c
--- /dev/null
+++ b/openssl-1.1.0h/util/find-doc-nits
@@ -0,0 +1,549 @@
+#! /usr/bin/env perl
+# Copyright 2002-2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+
+require 5.10.0;
+use warnings;
+use strict;
+use Pod::Checker;
+use File::Find;
+use File::Basename;
+use File::Spec::Functions;
+use Getopt::Std;
+use lib catdir(dirname($0), "perl");
+use OpenSSL::Util::Pod;
+
+# Options.
+our($opt_d);
+our($opt_h);
+our($opt_l);
+our($opt_n);
+our($opt_p);
+our($opt_s);
+our($opt_u);
+our($opt_c);
+
+sub help()
+{
+ print <<EOF;
+Find small errors (nits) in documentation. Options:
+ -d Detailed list of undocumented (implies -u)
+ -l Print bogus links
+ -n Print nits in POD pages
+ -s Also print missing sections in POD pages (implies -n)
+ -p Warn if non-public name documented (implies -n)
+ -u List undocumented functions
+ -h Print this help message
+ -c List undocumented commands and options
+EOF
+ exit;
+}
+
+my $temp = '/tmp/docnits.txt';
+my $OUT;
+my %public;
+
+my %mandatory_sections =
+ ( '*' => [ 'NAME', 'DESCRIPTION', 'COPYRIGHT' ],
+ 1 => [ 'SYNOPSIS', 'OPTIONS' ],
+ 3 => [ 'SYNOPSIS', 'RETURN VALUES' ],
+ 5 => [ ],
+ 7 => [ ] );
+
+# Cross-check functions in the NAME and SYNOPSIS section.
+sub name_synopsis()
+{
+ my $id = shift;
+ my $filename = shift;
+ my $contents = shift;
+
+ # Get NAME section and all words in it.
+ return unless $contents =~ /=head1 NAME(.*)=head1 SYNOPSIS/ms;
+ my $tmp = $1;
+ $tmp =~ tr/\n/ /;
+ print "$id trailing comma before - in NAME\n" if $tmp =~ /, *-/;
+ $tmp =~ s/ -.*//g;
+ $tmp =~ s/ */ /g;
+ print "$id missing comma in NAME\n" if $tmp =~ /[^,] /;
+ $tmp =~ s/,//g;
+
+ my $dirname = dirname($filename);
+ my $simplename = basename($filename);
+ $simplename =~ s/.pod$//;
+ my $foundfilename = 0;
+ my %foundfilenames = ();
+ my %names;
+ foreach my $n ( split ' ', $tmp ) {
+ $names{$n} = 1;
+ $foundfilename++ if $n eq $simplename;
+ $foundfilenames{$n} = 1
+ if -f "$dirname/$n.pod" && $n ne $simplename;
+ }
+ print "$id the following exist as other .pod files:\n",
+ join(" ", sort keys %foundfilenames), "\n"
+ if %foundfilenames;
+ print "$id $simplename (filename) missing from NAME section\n"
+ unless $foundfilename;
+ foreach my $n ( keys %names ) {
+ print "$id $n is not public\n"
+ if $opt_p and !defined $public{$n};
+ }
+
+ # Find all functions in SYNOPSIS
+ return unless $contents =~ /=head1 SYNOPSIS(.*)=head1 DESCRIPTION/ms;
+ my $syn = $1;
+ foreach my $line ( split /\n+/, $syn ) {
+ my $sym;
+ $line =~ s/STACK_OF\([^)]+\)/int/g;
+ $line =~ s/__declspec\([^)]+\)//;
+ if ( $line =~ /env (\S*)=/ ) {
+ # environment variable env NAME=...
+ $sym = $1;
+ } elsif ( $line =~ /typedef.*\(\*(\S+)\)\(.*/ ) {
+ # a callback function pointer: typedef ... (*NAME)(...
+ $sym = $1;
+ } elsif ( $line =~ /typedef.* (\S+)\(.*/ ) {
+ # a callback function signature: typedef ... NAME(...
+ $sym = $1;
+ } elsif ( $line =~ /typedef.* (\S+);/ ) {
+ # a simple typedef: typedef ... NAME;
+ $sym = $1;
+ } elsif ( $line =~ /enum (\S*) \{/ ) {
+ # an enumeration: enum ... {
+ $sym = $1;
+ } elsif ( $line =~ /#define ([A-Za-z0-9_]+)/ ) {
+ $sym = $1;
+ } elsif ( $line =~ /([A-Za-z0-9_]+)\(/ ) {
+ $sym = $1;
+ }
+ else {
+ next;
+ }
+ print "$id $sym missing from NAME section\n"
+ unless defined $names{$sym};
+ $names{$sym} = 2;
+
+ # Do some sanity checks on the prototype.
+ print "$id prototype missing spaces around commas: $line\n"
+ if ( $line =~ /[a-z0-9],[^ ]/ );
+ }
+
+ foreach my $n ( keys %names ) {
+ next if $names{$n} == 2;
+ print "$id $n missing from SYNOPSIS\n";
+ }
+}
+
+sub check()
+{
+ my $filename = shift;
+ my $dirname = basename(dirname($filename));
+
+ my $contents = '';
+ {
+ local $/ = undef;
+ open POD, $filename or die "Couldn't open $filename, $!";
+ $contents = <POD>;
+ close POD;
+ }
+
+ my $id = "${filename}:1:";
+
+ # Find what section this page is in; assume 3.
+ my $section = 3;
+ $section = 1 if $dirname eq 'apps';
+ $section = $1 if ( $contents =~ /=for comment openssl_manual_section:(\d)/);
+
+ &name_synopsis($id, $filename, $contents)
+ unless $contents =~ /=for comment generic/
+ or $section != 3;
+
+ print "$id doesn't start with =pod\n"
+ if $contents !~ /^=pod/;
+ print "$id doesn't end with =cut\n"
+ if $contents !~ /=cut\n$/;
+ print "$id more than one cut line.\n"
+ if $contents =~ /=cut.*=cut/ms;
+ print "$id missing copyright\n"
+ if $contents !~ /Copyright .* The OpenSSL Project Authors/;
+ print "$id copyright not last\n"
+ if $contents =~ /head1 COPYRIGHT.*=head/ms;
+ print "$id head2 in All uppercase\n"
+ if $contents =~ /head2\s+[A-Z ]+\n/;
+ print "$id extra space after head\n"
+ if $contents =~ /=head\d\s\s+/;
+ print "$id period in NAME section\n"
+ if $contents =~ /=head1 NAME.*\.\n.*=head1 SYNOPSIS/ms;
+ print "$id POD markup in NAME section\n"
+ if $contents =~ /=head1 NAME.*[<>].*=head1 SYNOPSIS/ms;
+ print "$id Duplicate $1 in L<>\n"
+ if $contents =~ /L<([^>]*)\|([^>]*)>/ && $1 eq $2;
+ print "$id Bad =over $1\n"
+ if $contents =~ /=over([^ ][^24])/;
+ print "$id Possible version style issue\n"
+ if $contents =~ /OpenSSL version [019]/;
+
+ if ( $contents !~ /=for comment multiple includes/ ) {
+ # Look for multiple consecutive openssl #include lines
+ # (non-consecutive lines are okay; see crypto/MD5.pod).
+ if ( $contents =~ /=head1 SYNOPSIS(.*)=head1 DESCRIPTION/ms ) {
+ my $count = 0;
+ foreach my $line ( split /\n+/, $1 ) {
+ if ( $line =~ m@include <openssl/@ ) {
+ print "$id has multiple includes\n" if ++$count == 2;
+ } else {
+ $count = 0;
+ }
+ }
+ }
+ }
+
+ open my $OUT, '>', $temp
+ or die "Can't open $temp, $!";
+ podchecker($filename, $OUT);
+ close $OUT;
+ open $OUT, '<', $temp
+ or die "Can't read $temp, $!";
+ while ( <$OUT> ) {
+ next if /\(section\) in.*deprecated/;
+ print;
+ }
+ close $OUT;
+ unlink $temp || warn "Can't remove $temp, $!";
+
+ foreach ((@{$mandatory_sections{'*'}}, @{$mandatory_sections{$section}})) {
+ # Skip "return values" if not -s
+ next if $_ eq 'RETURN VALUES' and not $opt_s;
+ print "$id: missing $_ head1 section\n"
+ if $contents !~ /^=head1\s+${_}\s*$/m;
+ }
+}
+
+my %dups;
+
+sub parsenum()
+{
+ my $file = shift;
+ my @apis;
+
+ open my $IN, '<', $file
+ or die "Can't open $file, $!, stopped";
+
+ while ( <$IN> ) {
+ next if /^#/;
+ next if /\bNOEXIST\b/;
+ next if /\bEXPORT_VAR_AS_FUNC\b/;
+ my @fields = split();
+ die "Malformed line $_"
+ if scalar @fields != 2 && scalar @fields != 4;
+ push @apis, $fields[0];
+ }
+
+ close $IN;
+
+ print "# Found ", scalar(@apis), " in $file\n" unless $opt_p;
+ return sort @apis;
+}
+
+sub getdocced()
+{
+ my $dir = shift;
+ my %return;
+
+ foreach my $pod ( glob("$dir/*.pod") ) {
+ my %podinfo = extract_pod_info($pod);
+ foreach my $n ( @{$podinfo{names}} ) {
+ $return{$n} = $pod;
+ print "# Duplicate $n in $pod and $dups{$n}\n"
+ if defined $dups{$n} && $dups{$n} ne $pod;
+ $dups{$n} = $pod;
+ }
+ }
+
+ return %return;
+}
+
+my %docced;
+
+sub checkmacros()
+{
+ my $count = 0;
+
+ print "# Checking macros (approximate)\n";
+ foreach my $f ( glob('include/openssl/*.h') ) {
+ # Skip some internals we don't want to document yet.
+ next if $f eq 'include/openssl/asn1.h';
+ next if $f eq 'include/openssl/asn1t.h';
+ next if $f eq 'include/openssl/err.h';
+ open(IN, $f) || die "Can't open $f, $!";
+ while ( <IN> ) {
+ next unless /^#\s*define\s*(\S+)\(/;
+ my $macro = $1;
+ next if $docced{$macro};
+ next if $macro =~ /i2d_/
+ || $macro =~ /d2i_/
+ || $macro =~ /DEPRECATEDIN/
+ || $macro =~ /IMPLEMENT_/
+ || $macro =~ /DECLARE_/;
+ print "$f:$macro\n" if $opt_d;
+ $count++;
+ }
+ close(IN);
+ }
+ print "# Found $count macros missing (not all should be documented)\n"
+}
+
+sub printem()
+{
+ my $libname = shift;
+ my $numfile = shift;
+ my $count = 0;
+
+ foreach my $func ( &parsenum($numfile) ) {
+ next if $docced{$func};
+
+ # Skip ASN1 utilities
+ next if $func =~ /^ASN1_/;
+
+ print "$libname:$func\n" if $opt_d;
+ $count++;
+ }
+ print "# Found $count missing from $numfile\n\n";
+}
+
+
+# Collection of links in each POD file.
+# filename => [ "foo(1)", "bar(3)", ... ]
+my %link_collection = ();
+# Collection of names in each POD file.
+# "name(s)" => filename
+my %name_collection = ();
+
+sub collectnames {
+ my $filename = shift;
+ $filename =~ m|man(\d)/|;
+ my $section = $1;
+ my $simplename = basename($filename, ".pod");
+ my $id = "${filename}:1:";
+
+ my $contents = '';
+ {
+ local $/ = undef;
+ open POD, $filename or die "Couldn't open $filename, $!";
+ $contents = <POD>;
+ close POD;
+ }
+
+ $contents =~ /=head1 NAME([^=]*)=head1 /ms;
+ my $tmp = $1;
+ unless (defined $tmp) {
+ print "$id weird name section\n";
+ return;
+ }
+ $tmp =~ tr/\n/ /;
+ $tmp =~ s/-.*//g;
+
+ my @names = map { s/\s+//g; $_ } split(/,/, $tmp);
+ unless (grep { $simplename eq $_ } @names) {
+ print "$id missing $simplename\n";
+ push @names, $simplename;
+ }
+ foreach my $name (@names) {
+ next if $name eq "";
+ my $name_sec = "$name($section)";
+ if (! exists $name_collection{$name_sec}) {
+ $name_collection{$name_sec} = $filename;
+ } else { #elsif ($filename ne $name_collection{$name_sec}) {
+ print "$id $name_sec also in $name_collection{$name_sec}\n";
+ }
+ }
+
+ my @foreign_names =
+ map { map { s/\s+//g; $_ } split(/,/, $_) }
+ $contents =~ /=for\s+comment\s+foreign\s+manuals:\s*(.*)\n\n/;
+ foreach (@foreign_names) {
+ $name_collection{$_} = undef; # It still exists!
+ }
+
+ my @links = $contents =~ /L<
+ # if the link is of the form L<something|name(s)>,
+ # then remove 'something'. Note that 'something'
+ # may contain POD codes as well...
+ (?:(?:[^\|]|<[^>]*>)*\|)?
+ # we're only interested in referenses that have
+ # a one digit section number
+ ([^\/>\(]+\(\d\))
+ /gx;
+ $link_collection{$filename} = [ @links ];
+}
+
+sub checklinks {
+ foreach my $filename (sort keys %link_collection) {
+ foreach my $link (@{$link_collection{$filename}}) {
+ print "${filename}:1: reference to non-existing $link\n"
+ unless exists $name_collection{$link};
+ }
+ }
+}
+
+sub publicize() {
+ foreach my $name ( &parsenum('util/libcrypto.num') ) {
+ $public{$name} = 1;
+ }
+ foreach my $name ( &parsenum('util/libssl.num') ) {
+ $public{$name} = 1;
+ }
+ foreach my $name ( &parsenum('util/private.num') ) {
+ $public{$name} = 1;
+ }
+}
+
+my %skips = (
+ 'aes128' => 1,
+ 'aes192' => 1,
+ 'aes256' => 1,
+ 'aria128' => 1,
+ 'aria192' => 1,
+ 'aria256' => 1,
+ 'camellia128' => 1,
+ 'camellia192' => 1,
+ 'camellia256' => 1,
+ 'des' => 1,
+ 'des3' => 1,
+ 'idea' => 1,
+ '[cipher]' => 1,
+ '[digest]' => 1,
+);
+
+sub checkflags() {
+ my $cmd = shift;
+ my %cmdopts;
+ my %docopts;
+ my $ok = 1;
+
+ # Get the list of options in the command.
+ open CFH, "./apps/openssl list --options $cmd|"
+ || die "Can list options for $cmd, $!";
+ while ( <CFH> ) {
+ chop;
+ s/ .$//;
+ $cmdopts{$_} = 1;
+ }
+ close CFH;
+
+ # Get the list of flags from the synopsis
+ open CFH, "<doc/apps/$cmd.pod"
+ || die "Can't open $cmd.pod, $!";
+ while ( <CFH> ) {
+ chop;
+ last if /DESCRIPTION/;
+ next unless /\[B<-([^ >]+)/;
+ $docopts{$1} = 1;
+ }
+ close CFH;
+
+ # See what's in the command not the manpage.
+ my @undocced = ();
+ foreach my $k ( keys %cmdopts ) {
+ push @undocced, $k unless $docopts{$k};
+ }
+ if ( scalar @undocced > 0 ) {
+ $ok = 0;
+ foreach ( @undocced ) {
+ print "doc/apps/$cmd.pod: Missing -$_\n";
+ }
+ }
+
+ # See what's in the command not the manpage.
+ my @unimpl = ();
+ foreach my $k ( keys %docopts ) {
+ push @unimpl, $k unless $cmdopts{$k};
+ }
+ if ( scalar @unimpl > 0 ) {
+ $ok = 0;
+ foreach ( @unimpl ) {
+ next if defined $skips{$_};
+ print "doc/apps/$cmd.pod: Not implemented -$_\n";
+ }
+ }
+
+ return $ok;
+}
+
+getopts('cdlnsphu');
+
+&help() if $opt_h;
+$opt_n = 1 if $opt_s or $opt_p;
+$opt_u = 1 if $opt_d;
+
+die "Need one of -[cdlnspu] flags.\n"
+ unless $opt_c or $opt_l or $opt_n or $opt_u;
+
+if ( $opt_c ) {
+ my $ok = 1;
+ my @commands = ();
+
+ # Get list of commands.
+ open FH, "./apps/openssl list -1 -commands|"
+ || die "Can't list commands, $!";
+ while ( <FH> ) {
+ chop;
+ push @commands, $_;
+ }
+ close FH;
+
+ # See if each has a manpage.
+ foreach ( @commands ) {
+ next if $_ eq 'help' || $_ eq 'exit';
+ if ( ! -f "doc/apps/$_.pod" ) {
+ print "doc/apps/$_.pod does not exist\n";
+ $ok = 0;
+ } else {
+ $ok = 0 if not &checkflags($_);
+ }
+ }
+
+ # See what help is missing.
+ open FH, "./apps/openssl list --missing-help |"
+ || die "Can't list missing help, $!";
+ while ( <FH> ) {
+ chop;
+ my ($cmd, $flag) = split;
+ print "$cmd has no help for -$flag\n";
+ $ok = 0;
+ }
+ close FH;
+
+ exit 1 if not $ok;
+}
+
+if ( $opt_l ) {
+ foreach (@ARGV ? @ARGV : glob('doc/*/*.pod')) {
+ collectnames($_);
+ }
+ checklinks();
+}
+
+if ( $opt_n ) {
+ &publicize() if $opt_p;
+ foreach (@ARGV ? @ARGV : glob('doc/*/*.pod')) {
+ &check($_);
+ }
+}
+
+if ( $opt_u ) {
+ my %temp = &getdocced('doc/crypto');
+ foreach ( keys %temp ) {
+ $docced{$_} = $temp{$_};
+ }
+ &printem('crypto', 'util/libcrypto.num');
+ &printem('ssl', 'util/libssl.num');
+ &checkmacros();
+}
+
+exit;
diff --git a/openssl-1.1.0h/util/find-undoc-api.pl b/openssl-1.1.0h/util/find-undoc-api.pl
new file mode 100755
index 0000000..7b2cb97
--- /dev/null
+++ b/openssl-1.1.0h/util/find-undoc-api.pl
@@ -0,0 +1,82 @@
+#! /usr/bin/env perl
+# Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+use strict;
+use warnings;
+
+use File::Spec::Functions;
+use File::Basename;
+#use File::Copy;
+#use File::Path;
+use lib catdir(dirname($0), "perl");
+use OpenSSL::Util::Pod;
+
+my %dups;
+
+sub parsenum()
+{
+ my $file = shift;
+ my @apis;
+
+ open my $IN, '<', $file
+ or die "Can't open $file, $!, stopped";
+
+ while ( <$IN> ) {
+ next if /\sNOEXIST/;
+ next if /EXPORT_VAR_AS_FUNC/;
+ push @apis, $1 if /([^\s]+).\s/;
+ }
+
+ close $IN;
+
+ print "# Found ", scalar(@apis), " in $file\n";
+ return sort @apis;
+}
+
+sub getdocced()
+{
+ my $dir = shift;
+ my %return;
+
+ foreach my $pod ( glob("$dir/*.pod") ) {
+ next if $pod eq 'doc/crypto/crypto.pod';
+ next if $pod eq 'doc/ssl/ssl.pod';
+ my %podinfo = extract_pod_info($pod);
+ foreach my $n ( @{$podinfo{names}} ) {
+ $return{$n} = $pod;
+ print "# Duplicate $n in $pod and $dups{$n}\n"
+ if defined $dups{$n};
+ $dups{$n} = $pod;
+ }
+ }
+
+ return %return;
+}
+
+sub printem()
+{
+ my $docdir = shift;
+ my $numfile = shift;
+ my %docced = &getdocced($docdir);
+ my $count = 0;
+
+ foreach my $func ( &parsenum($numfile) ) {
+ next if $docced{$func};
+
+ # Skip ASN1 utilities
+ next if $func =~ /^ASN1_/;
+
+ print $func, "\n";
+ $count++;
+ }
+ print "# Found $count missing from $numfile\n\n";
+}
+
+
+&printem('doc/crypto', 'util/libcrypto.num');
+&printem('doc/ssl', 'util/libssl.num');
diff --git a/openssl-1.1.0h/util/find-unused-errs b/openssl-1.1.0h/util/find-unused-errs
new file mode 100755
index 0000000..68cf66b
--- /dev/null
+++ b/openssl-1.1.0h/util/find-unused-errs
@@ -0,0 +1,35 @@
+#! /bin/bash
+# Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+# Find unused error function-names and reason-codes, and edit them
+# out of the source. Doesn't handle line-wrapping, might have to do
+# some manual cleanups to fix compile errors.
+
+export X1=/tmp/f.1.$$
+export X2=/tmp/f.2.$$
+
+cd include/openssl || exit 1
+grep '_[RF]_' * | awk '{print $3;}' | sort -u >$X1
+cd ../..
+
+for F in `cat $X1` ; do
+ git grep -l --full-name -F $F >$X2
+ NUM=`wc -l <$X2`
+ test $NUM -gt 2 && continue
+ if grep -q $F crypto/err/openssl.ec ; then
+ echo Possibly unused $F found in openssl.ec
+ continue
+ fi
+ echo $F
+ for FILE in `cat $X2` ; do
+ grep -v -w $F <$FILE >$FILE.new
+ mv $FILE.new $FILE
+ done
+done
+
+rm $X1 $X2
diff --git a/openssl-1.1.0h/util/fipslink.pl b/openssl-1.1.0h/util/fipslink.pl
new file mode 100644
index 0000000..18a9153
--- /dev/null
+++ b/openssl-1.1.0h/util/fipslink.pl
@@ -0,0 +1,115 @@
+#! /usr/bin/env perl
+# Copyright 2011-2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+sub check_env
+ {
+ my @ret;
+ foreach (@_)
+ {
+ die "Environment variable $_ not defined!\n" unless exists $ENV{$_};
+ push @ret, $ENV{$_};
+ }
+ return @ret;
+ }
+
+
+my ($fips_cc,$fips_cc_args, $fips_link,$fips_target, $fips_libdir, $sha1_exe)
+ = check_env("FIPS_CC", "FIPS_CC_ARGS", "FIPS_LINK", "FIPS_TARGET",
+ "FIPSLIB_D", "FIPS_SHA1_EXE");
+
+
+
+if (exists $ENV{"PREMAIN_DSO_EXE"})
+ {
+ $fips_premain_dso = $ENV{"PREMAIN_DSO_EXE"};
+ }
+ else
+ {
+ $fips_premain_dso = "";
+ }
+
+check_hash($sha1_exe, "fips_premain.c");
+check_hash($sha1_exe, "fipscanister.lib");
+
+
+print "Integrity check OK\n";
+
+if (is_premain_linked(@ARGV)) {
+ print "$fips_cc $fips_cc_args $fips_libdir/fips_premain.c\n";
+ system "$fips_cc $fips_cc_args $fips_libdir/fips_premain.c";
+ die "First stage Compile failure" if $? != 0;
+} elsif (!defined($ENV{FIPS_SIG})) {
+ die "no fips_premain.obj linked";
+}
+
+print "$fips_link @ARGV\n";
+system "$fips_link @ARGV";
+die "First stage Link failure" if $? != 0;
+
+if (defined($ENV{FIPS_SIG})) {
+ print "$ENV{FIPS_SIG} $fips_target\n";
+ system "$ENV{FIPS_SIG} $fips_target";
+ die "$ENV{FIPS_SIG} $fips_target failed" if $? != 0;
+ exit;
+}
+
+print "$fips_premain_dso $fips_target\n";
+system("$fips_premain_dso $fips_target >$fips_target.sha1");
+die "Get hash failure" if $? != 0;
+open my $sha1_res, '<', $fips_target.".sha1" or die "Get hash failure";
+$fips_hash=<$sha1_res>;
+close $sha1_res;
+unlink $fips_target.".sha1";
+$fips_hash =~ s|\R$||; # Better chomp
+die "Get hash failure" if $? != 0;
+
+
+print "$fips_cc -DHMAC_SHA1_SIG=\\\"$fips_hash\\\" $fips_cc_args $fips_libdir/fips_premain.c\n";
+system "$fips_cc -DHMAC_SHA1_SIG=\\\"$fips_hash\\\" $fips_cc_args $fips_libdir/fips_premain.c";
+die "Second stage Compile failure" if $? != 0;
+
+
+print "$fips_link @ARGV\n";
+system "$fips_link @ARGV";
+die "Second stage Link failure" if $? != 0;
+
+sub is_premain_linked
+ {
+ return 1 if (grep /fips_premain\.obj/,@_);
+ foreach (@_)
+ {
+ if (/^@(.*)/ && -f $1)
+ {
+ open FD,$1 or die "can't open $1";
+ my $ret = (grep /fips_premain\.obj/,<FD>)?1:0;
+ close FD;
+ return $ret;
+ }
+ }
+ return 0;
+ }
+
+sub check_hash
+ {
+ my ($sha1_exe, $filename) = @_;
+ my ($hashfile, $hashval);
+
+ open(IN, "${fips_libdir}/${filename}.sha1") || die "Cannot open file hash file ${fips_libdir}/${filename}.sha1";
+ $hashfile = <IN>;
+ close IN;
+ $hashval = `$sha1_exe ${fips_libdir}/$filename`;
+ $hashfile =~ s|\R$||; # Better chomp
+ $hashval =~ s|\R$||; # Better chomp
+ $hashfile =~ s/^.*=\s+//;
+ $hashval =~ s/^.*=\s+//;
+ die "Invalid hash syntax in file" if (length($hashfile) != 40);
+ die "Invalid hash received for file" if (length($hashval) != 40);
+ die "***HASH VALUE MISMATCH FOR FILE $filename ***" if ($hashval ne $hashfile);
+ }
+
+
diff --git a/openssl-1.1.0h/util/incore b/openssl-1.1.0h/util/incore
new file mode 100755
index 0000000..26fcf95
--- /dev/null
+++ b/openssl-1.1.0h/util/incore
@@ -0,0 +1,454 @@
+#! /usr/bin/env perl
+# Copyright 2011-2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+# The script embeds fingerprint into ELF executable object, either
+# application binary or shared library.
+
+######################################################################
+#
+# ELF symbol table parser by <appro@openssl.org>. The table entries
+# are extended with offset within executable file...
+#
+{ package ELF;
+ use FileHandle;
+
+ sub dup { my %copy=map {$_} @_; return \%copy; }
+
+ sub Load {
+ my $class = shift;
+ my $self = {};
+ my $FD = FileHandle->new(); # autoclose
+
+ bless $self,$class;
+
+ sysopen($FD,shift,0) or die "$!";
+ binmode($FD);
+
+ #################################################
+ # read and parse elf_ehdr.e_ident...
+ #
+ read($FD,my $elf,16) or die "$!";
+
+ my %e_ident;
+ @e_ident{magic,class,data,version,osabi,abiver,pad}=
+ unpack("a4C*",$elf);
+
+ $!=42; # signal fipsld to revert to two-step link
+ die "not ELF file" if ($e_ident{magic} ne chr(0177)."ELF");
+
+ my $elf_bits = $e_ident{class}*32; # 32 or 64
+ my $big_endian = $e_ident{data}-1; # 0 or 1
+
+ if ($elf_bits==64) {
+ if (!(((1<<31)<<1) && $big_endian==(unpack("L",pack("N",1))==1))) {
+ die "ELF64 is supported only natively";
+ }
+ }
+
+ #################################################
+ # read and parse remainder of elf_ehdr...
+ #
+ read($FD,my $elfhdr,64) or die "$!";
+
+ my %elf_ehdr;
+ @elf_ehdr{e_type,e_machine,e_version,
+ e_entry,e_phoff,e_shoff,e_flags,e_ehsize,
+ e_phentsize,e_phnum,e_shentsize,e_shnum,e_shstrndx} =
+ $elf_bits==32 ?
+ unpack($big_endian?"nnN5n6":"vvV5v6",$elfhdr)
+ : unpack("SSLQ3LS6",$elfhdr);
+
+ # put aside e_machine in case one has to treat specific
+ # platforms differently, see EM_ constants in elf.h for
+ # assortment...
+ $self->{e_machine} = $elf_ehdr{e_machine};
+
+ #################################################
+ # read and parse elf_shdr table...
+ #
+ my ($i,$sz,$symtab_idx,$blob,$strings);
+
+ seek($FD,$elf_ehdr{e_shoff},0) or die "$!";
+ read($FD,$blob,$elf_ehdr{e_shentsize}*$elf_ehdr{e_shnum}) or die "$!";
+
+ my @sections;
+ my $elf_shdr_struct=($elf_bits==32?($big_endian?"N10":"V10"):"L2Q4L2Q2");
+ for ($sz=$elf_ehdr{e_shentsize},$i=0;$i<length($blob);$i+=$sz) {
+ my %elf_shdr;
+
+ @elf_shdr{sh_name,sh_type,sh_flags,
+ sh_addr,sh_offset,sh_size,
+ sh_link,sh_info,sh_addalign,sh_entsize} =
+ unpack($elf_shdr_struct,substr($blob,$i,$sz));
+
+ push(@sections,dup(%elf_shdr));
+
+ # note SHT_SYMTAB or SHT_DYNSYM for future reference
+ if ($elf_shdr{sh_type}==2 || $elf_shdr{sh_type}==11) {
+ $symtab_idx = $#sections;
+ }
+ }
+
+ # read strings table and map section names...
+ seek($FD,@sections[$elf_ehdr{e_shstrndx}]->{sh_offset},0) or die "$!";
+ read($FD,$strings,@sections[$elf_ehdr{e_shstrndx}]->{sh_size}) or die "$!";
+ for (@sections) {
+ $_->{sh_name}=(split(chr(0),substr($strings,$_->{sh_name},64)))[0];
+ }
+
+ #################################################
+ # read symbol strings table...
+ #
+ $i=@sections[$symtab_idx]->{sh_link};
+ seek($FD,@sections[$i]->{sh_offset},0) or die "$!";
+ read($FD,$strings,@sections[$i]->{sh_size}) or die "$!";
+
+ #################################################
+ # read and parse elf_sym table...
+ #
+ seek($FD,@sections[$symtab_idx]->{sh_offset},0) or die "$!";
+ read($FD,my $blob,@sections[$symtab_idx]->{sh_size}) or die "$!";
+
+ for ($sz=@sections[$symtab_idx]->{sh_entsize},$i=0;$i<length($blob);$i+=$sz) {
+ my %elf_sym;
+
+ if ($elf_bits==32) {
+ @elf_sym{st_name,st_value,st_size,st_info,st_other,st_shndx} =
+ unpack($big_endian?"N3CCn":"V3CCv",substr($blob,$i,$sz));
+ } else {
+ @elf_sym{st_name,st_info,st_other,st_shndx,st_value,st_size} =
+ unpack("LCCSQQ",substr($blob,$i,$sz));
+ }
+
+ my $st_type = $elf_sym{st_info}&0xf;
+ my $st_bind = $elf_sym{st_info}>>4;
+ my $st_secn = $elf_sym{st_shndx};
+ my $name;
+ # (STT_OBJECT || STT_FUNC)
+ if ($st_bind<3 && ($st_type==1 || $st_type==2)
+ && $st_secn <= $#sections # sane st_shndx
+ && @sections[$st_secn]->{sh_type} # not SHN_UNDEF
+ && ($name=(split(chr(0),substr($strings,$elf_sym{st_name},128)))[0])
+ ) {
+ # synthesize st_offset, ...
+ $elf_sym{st_offset} = $elf_sym{st_value}
+ - @sections[$st_secn]->{sh_addr}
+ + @sections[$st_secn]->{sh_offset};
+ $elf_sym{st_name} = $name;
+ $elf_sym{st_section} = @sections[$st_secn]->{sh_name};
+ # ... and add to lookup table
+ $self->{symbols}{$name} = dup(%elf_sym);
+ }
+ }
+
+ return $self;
+ }
+
+ sub Lookup {
+ my $self = shift;
+ my $name = shift;
+ return $self->{symbols}{$name};
+ }
+
+ sub Traverse {
+ my $self = shift;
+ my $code = shift;
+
+ if (ref($code) eq 'CODE') {
+ for (keys(%{$self->{symbols}})) { &$code($self->{symbols}{$_}); }
+ }
+ }
+}
+
+######################################################################
+#
+# SHA1 and HMAC in Perl by <appro@openssl.org>.
+#
+{ package SHA1;
+ use integer;
+
+ {
+ ################################### SHA1 block code generator
+ my @V = ('$A','$B','$C','$D','$E');
+ my $i;
+
+ sub XUpdate {
+ my $ret;
+ $ret="(\$T=\$W[($i-16)%16]^\$W[($i-14)%16]^\$W[($i-8)%16]^\$W[($i-3)%16],\n\t";
+ if ((1<<31)<<1) {
+ $ret.=" \$W[$i%16]=((\$T<<1)|(\$T>>31))&0xffffffff)\n\t ";
+ } else {
+ $ret.=" \$W[$i%16]=(\$T<<1)|((\$T>>31)&1))\n\t ";
+ }
+ }
+ sub tail {
+ my ($a,$b,$c,$d,$e)=@V;
+ my $ret;
+ if ((1<<31)<<1) {
+ $ret.="(($a<<5)|($a>>27));\n\t";
+ $ret.="$b=($b<<30)|($b>>2); $e&=0xffffffff; #$b&=0xffffffff;\n\t";
+ } else {
+ $ret.="(($a<<5)|($a>>27)&0x1f);\n\t";
+ $ret.="$b=($b<<30)|($b>>2)&0x3fffffff;\n\t";
+ }
+ $ret;
+ }
+ sub BODY_00_15 {
+ my ($a,$b,$c,$d,$e)=@V;
+ "$e+=\$W[$i]+0x5a827999+((($c^$d)&$b)^$d)+".tail();
+ }
+ sub BODY_16_19 {
+ my ($a,$b,$c,$d,$e)=@V;
+ "$e+=".XUpdate()."+0x5a827999+((($c^$d)&$b)^$d)+".tail();
+ }
+ sub BODY_20_39 {
+ my ($a,$b,$c,$d,$e)=@V;
+ "$e+=".XUpdate()."+0x6ed9eba1+($b^$c^$d)+".tail();
+ }
+ sub BODY_40_59 {
+ my ($a,$b,$c,$d,$e)=@V;
+ "$e+=".XUpdate()."+0x8f1bbcdc+(($b&$c)|(($b|$c)&$d))+".tail();
+ }
+ sub BODY_60_79 {
+ my ($a,$b,$c,$d,$e)=@V;
+ "$e+=".XUpdate()."+0xca62c1d6+($b^$c^$d)+".tail();
+ }
+
+ my $sha1_impl =
+ 'sub block {
+ my $self = @_[0];
+ my @W = unpack("N16",@_[1]);
+ my ($A,$B,$C,$D,$E,$T) = @{$self->{H}};
+ ';
+
+ $sha1_impl.='
+ $A &= 0xffffffff;
+ $B &= 0xffffffff;
+ ' if ((1<<31)<<1);
+
+ for($i=0;$i<16;$i++){ $sha1_impl.=BODY_00_15(); unshift(@V,pop(@V)); }
+ for(;$i<20;$i++) { $sha1_impl.=BODY_16_19(); unshift(@V,pop(@V)); }
+ for(;$i<40;$i++) { $sha1_impl.=BODY_20_39(); unshift(@V,pop(@V)); }
+ for(;$i<60;$i++) { $sha1_impl.=BODY_40_59(); unshift(@V,pop(@V)); }
+ for(;$i<80;$i++) { $sha1_impl.=BODY_60_79(); unshift(@V,pop(@V)); }
+
+ $sha1_impl.='
+ $self->{H}[0]+=$A; $self->{H}[1]+=$B; $self->{H}[2]+=$C;
+ $self->{H}[3]+=$D; $self->{H}[4]+=$E; }';
+
+ #print $sha1_impl,"\n";
+ eval($sha1_impl); # generate code
+ }
+
+ sub Init {
+ my $class = shift; # multiple instances...
+ my $self = {};
+
+ bless $self,$class;
+ $self->{H} = [0x67452301,0xefcdab89,0x98badcfe,0x10325476,0xc3d2e1f0];
+ $self->{N} = 0;
+ return $self;
+ }
+
+ sub Update {
+ my $self = shift;
+ my $msg;
+
+ foreach $msg (@_) {
+ my $len = length($msg);
+ my $num = length($self->{buf});
+ my $off = 0;
+
+ $self->{N} += $len;
+
+ if (($num+$len)<64)
+ { $self->{buf} .= $msg; next; }
+ elsif ($num)
+ { $self->{buf} .= substr($msg,0,($off=64-$num));
+ $self->block($self->{buf});
+ }
+
+ while(($off+64) <= $len)
+ { $self->block(substr($msg,$off,64));
+ $off += 64;
+ }
+
+ $self->{buf} = substr($msg,$off);
+ }
+ return $self;
+ }
+
+ sub Final {
+ my $self = shift;
+ my $num = length($self->{buf});
+
+ $self->{buf} .= chr(0x80); $num++;
+ if ($num>56)
+ { $self->{buf} .= chr(0)x(64-$num);
+ $self->block($self->{buf});
+ $self->{buf}=undef;
+ $num=0;
+ }
+ $self->{buf} .= chr(0)x(56-$num);
+ $self->{buf} .= pack("N2",($self->{N}>>29)&0x7,$self->{N}<<3);
+ $self->block($self->{buf});
+
+ return pack("N*",@{$self->{H}});
+ }
+
+ sub Selftest {
+ my $hash;
+
+ $hash=SHA1->Init()->Update('abc')->Final();
+ die "SHA1 test#1" if (unpack("H*",$hash) ne 'a9993e364706816aba3e25717850c26c9cd0d89d');
+
+ $hash=SHA1->Init()->Update('abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq')->Final();
+ die "SHA1 test#2" if (unpack("H*",$hash) ne '84983e441c3bd26ebaae4aa1f95129e5e54670f1');
+
+ #$hash=SHA1->Init()->Update('a'x1000000)->Final();
+ #die "SHA1 test#3" if (unpack("H*",$hash) ne '34aa973cd4c4daa4f61eeb2bdbad27316534016f');
+ }
+}
+
+{ package HMAC;
+
+ sub Init {
+ my $class = shift;
+ my $key = shift;
+ my $self = {};
+
+ bless $self,$class;
+
+ if (length($key)>64) {
+ $key = SHA1->Init()->Update($key)->Final();
+ }
+ $key .= chr(0x00)x(64-length($key));
+
+ my @ikey = map($_^=0x36,unpack("C*",$key));
+ ($self->{hash} = SHA1->Init())->Update(pack("C*",@ikey));
+ $self->{okey} = pack("C*",map($_^=0x36^0x5c,@ikey));
+
+ return $self;
+ }
+
+ sub Update {
+ my $self = shift;
+ $self->{hash}->Update(@_);
+ return $self;
+ }
+
+ sub Final {
+ my $self = shift;
+ my $ihash = $self->{hash}->Final();
+ return SHA1->Init()->Update($self->{okey},$ihash)->Final();
+ }
+
+ sub Selftest {
+ my $hmac;
+
+ $hmac = HMAC->Init('0123456789:;<=>?@ABC')->Update('Sample #2')->Final();
+ die "HMAC test" if (unpack("H*",$hmac) ne '0922d3405faa3d194f82a45830737d5cc6c75d24');
+ }
+}
+
+######################################################################
+#
+# main()
+#
+my $legacy_mode;
+
+if ($ARGV<0 || ($#ARGV>0 && !($legacy_mode=(@ARGV[0] =~ /^\-(dso|exe)$/)))) {
+ print STDERR "usage: $0 [-dso|-exe] elfbinary\n";
+ exit(1);
+}
+
+$exe = ELF->Load(@ARGV[$#ARGV]);
+
+$FIPS_text_start = $exe->Lookup("FIPS_text_start") or die;
+$FIPS_text_end = $exe->Lookup("FIPS_text_end") or die;
+$FIPS_rodata_start = $exe->Lookup("FIPS_rodata_start") or die;
+$FIPS_rodata_end = $exe->Lookup("FIPS_rodata_end") or die;
+$FIPS_signature = $exe->Lookup("FIPS_signature") or die;
+
+# new cross-compile support
+$FIPS_text_startX = $exe->Lookup("FIPS_text_startX");
+$FIPS_text_endX = $exe->Lookup("FIPS_text_endX");
+
+if (!$legacy_mode) {
+ if (!$FIPS_text_startX || !$FIPS_text_endX) {
+ print STDERR "@ARGV[$#ARGV] is not cross-compiler aware.\n";
+ exit(42); # signal fipsld to revert to two-step link
+ }
+
+ $FINGERPRINT_ascii_value
+ = $exe->Lookup("FINGERPRINT_ascii_value");
+
+}
+if ($FIPS_text_startX && $FIPS_text_endX) {
+ $FIPS_text_start = $FIPS_text_startX;
+ $FIPS_text_end = $FIPS_text_endX;
+}
+
+sysopen(FD,@ARGV[$#ARGV],$legacy_mode?0:2) or die "$!"; # 2 is read/write
+binmode(FD);
+
+sub HMAC_Update {
+ my ($hmac,$off,$len) = @_;
+ my $blob;
+
+ seek(FD,$off,0) or die "$!";
+ read(FD,$blob,$len) or die "$!";
+ $$hmac->Update($blob);
+}
+
+# fips/fips.c:FIPS_incore_fingerprint's Perl twin
+#
+sub FIPS_incore_fingerprint {
+ my $p1 = $FIPS_text_start->{st_offset};
+ my $p2 = $FIPS_text_end->{st_offset};
+ my $p3 = $FIPS_rodata_start->{st_offset};
+ my $p4 = $FIPS_rodata_end->{st_offset};
+ my $sig = $FIPS_signature->{st_offset};
+ my $ctx = HMAC->Init("etaonrishdlcupfm");
+
+ # detect overlapping regions
+ if ($p1<=$p3 && $p2>=$p3) {
+ $p3 = $p1; $p4 = $p2>$p4?$p2:$p4; $p1 = 0; $p2 = 0;
+ } elsif ($p3<=$p1 && $p4>=$p1) {
+ $p3 = $p3; $p4 = $p2>$p4?$p2:$p4; $p1 = 0; $p2 = 0;
+ }
+
+ if ($p1) {
+ HMAC_Update (\$ctx,$p1,$p2-$p1);
+ }
+
+ if ($sig>=$p3 && $sig<$p4) {
+ # "punch" hole
+ HMAC_Update(\$ctx,$p3,$sig-$p3);
+ $p3 = $sig+20;
+ HMAC_Update(\$ctx,$p3,$p4-$p3);
+ } else {
+ HMAC_Update(\$ctx,$p3,$p4-$p3);
+ }
+
+ return $ctx->Final();
+}
+
+$fingerprint = FIPS_incore_fingerprint();
+
+if ($legacy_mode) {
+ print unpack("H*",$fingerprint);
+} elsif (defined($FINGERPRINT_ascii_value)) {
+ seek(FD,$FINGERPRINT_ascii_value->{st_offset},0) or die "$!";
+ print FD unpack("H*",$fingerprint) or die "$!";
+} else {
+ seek(FD,$FIPS_signature->{st_offset},0) or die "$!";
+ print FD $fingerprint or die "$!";
+}
+
+close (FD);
diff --git a/openssl-1.1.0h/util/indent.pro b/openssl-1.1.0h/util/indent.pro
new file mode 100644
index 0000000..b5398ab
--- /dev/null
+++ b/openssl-1.1.0h/util/indent.pro
@@ -0,0 +1,672 @@
+-bap
+-bbo
+-br
+-brs
+-c33
+-cd33
+-ce
+-ci4
+-cli0
+-cp33
+-d0
+-di1
+-hnl
+-i4
+-il1
+-ip0
+-l80
+-lp
+-nbad
+-nbc
+-ncdb
+-ncs
+-nfc1
+-nfca
+-npcs
+-nprs
+-npsl
+-nsc
+-ppi1
+-saf
+-sai
+-saw
+-sob
+-ss
+-ts0
+-T ACCESS_DESCRIPTION
+-T ADDED_OBJ
+-T AES_KEY
+-T APP_INFO
+-T ARGS
+-T ASIdOrRange
+-T ASIdOrRanges
+-T ASIdentifierChoice
+-T ASIdentifiers
+-T ASN1_ADB
+-T ASN1_ADB_TABLE
+-T ASN1_AUX
+-T ASN1_BIT_STRING
+-T ASN1_BMPSTRING
+-T ASN1_BOOLEAN
+-T ASN1_COMPAT_FUNCS
+-T ASN1_CTX
+-T ASN1_ENCODING
+-T ASN1_ENUMERATED
+-T ASN1_EXTERN_FUNCS
+-T ASN1_GENERALIZEDTIME
+-T ASN1_GENERALSTRING
+-T ASN1_IA5STRING
+-T ASN1_INTEGER
+-T ASN1_ITEM
+-T ASN1_ITEM_EXP
+-T ASN1_NULL
+-T ASN1_OBJECT
+-T ASN1_OCTET_STRING
+-T ASN1_PCTX
+-T ASN1_PRIMITIVE_FUNCS
+-T ASN1_PRINTABLESTRING
+-T ASN1_PRINT_ARG
+-T ASN1_SCTX
+-T ASN1_STREAM_ARG
+-T ASN1_STRING
+-T ASN1_STRING_TABLE
+-T ASN1_T61STRING
+-T ASN1_TEMPLATE
+-T ASN1_TIME
+-T ASN1_TLC
+-T ASN1_TYPE
+-T ASN1_UNIVERSALSTRING
+-T ASN1_UTCTIME
+-T ASN1_UTF8STRING
+-T ASN1_VALUE
+-T ASN1_VISIBLESTRING
+-T ASN1_const_CTX
+-T AUTHORITY_INFO_ACCESS
+-T AUTHORITY_KEYID
+-T BASIC_CONSTRAINTS
+-T BF_KEY
+-T BF_LONG
+-T BIGNUM
+-T BIO
+-T BIO_ACCEPT
+-T BIO_ADDR
+-T BIO_ASN1_BUF_CTX
+-T BIO_ASN1_EX_FUNCS
+-T BIO_B64_CTX
+-T BIO_CONNECT
+-T BIO_ENC_CTX
+-T BIO_F_BUFFER_CTX
+-T BIO_LINEBUFFER_CTX
+-T BIO_METHOD
+-T BIO_OK_CTX
+-T BIO_SSL
+-T BIT_STRING_BITNAME
+-T BN_BLINDING
+-T BN_CTX
+-T BN_GENCB
+-T BN_MONT_CTX
+-T BN_POOL
+-T BN_POOL_ITEM
+-T BN_RECP_CTX
+-T BN_STACK
+-T BN_ULONG
+-T BUF_MEM
+-T BY_DIR
+-T BY_DIR_ENTRY
+-T BY_DIR_HASH
+-T Bytef
+-T CAMELLIA_KEY
+-T CAST_KEY
+-T CAST_LONG
+-T CA_DB
+-T CCM128_CONTEXT
+-T CERT
+-T CERTIFICATEPOLICIES
+-T CERT_PKEY
+-T CIPHER_ORDER
+-T CMAC_CTX
+-T CMS_AuthenticatedData
+-T CMS_CertificateChoices
+-T CMS_CompressedData
+-T CMS_ContentInfo
+-T CMS_DigestedData
+-T CMS_EncapsulatedContentInfo
+-T CMS_EncryptedContentInfo
+-T CMS_EncryptedData
+-T CMS_EnvelopedData
+-T CMS_IssuerAndSerialNumber
+-T CMS_KEKIdentifier
+-T CMS_KEKRecipientInfo
+-T CMS_KeyAgreeRecipientIdentifier
+-T CMS_KeyAgreeRecipientInfo
+-T CMS_KeyTransRecipientInfo
+-T CMS_OriginatorIdentifierOrKey
+-T CMS_OriginatorInfo
+-T CMS_OriginatorPublicKey
+-T CMS_OtherCertificateFormat
+-T CMS_OtherKeyAttribute
+-T CMS_OtherRecipientInfo
+-T CMS_OtherRevocationInfoFormat
+-T CMS_PasswordRecipientInfo
+-T CMS_Receipt
+-T CMS_ReceiptRequest
+-T CMS_ReceiptsFrom
+-T CMS_RecipientEncryptedKey
+-T CMS_RecipientIdentifier
+-T CMS_RecipientInfo
+-T CMS_RecipientKeyIdentifier
+-T CMS_RevocationInfoChoice
+-T CMS_SignedData
+-T CMS_SignerIdentifier
+-T CMS_SignerInfo
+-T COMP_CTX
+-T COMP_METHOD
+-T CONF
+-T CONF_IMODULE
+-T CONF_METHOD
+-T CONF_MODULE
+-T CONF_VALUE
+-T CRYPTO_EX_DATA
+-T CRYPTO_EX_DATA_FUNCS
+-T CRYPTO_EX_DATA_IMPL
+-T CRYPTO_EX_dup
+-T CRYPTO_EX_free
+-T CRYPTO_EX_new
+-T CRYPTO_MEM_LEAK_CB
+-T CRYPTO_THREADID
+-T CRYPTO_dynlock_value
+-T DB_ATTR
+-T DES_LONG
+-T DES_cblock
+-T DES_key_schedule
+-T DH
+-T DH_METHOD
+-T DH_PKEY_CTX
+-T DIST_POINT
+-T DIST_POINT_NAME
+-T DRBG_CTX
+-T DSA
+-T DSA_METHOD
+-T DSA_SIG
+-T DSO
+-T DSO_FUNC_TYPE
+-T DSO_MERGER_FUNC
+-T DSO_METHOD
+-T DSO_NAME_CONVERTER_FUNC
+-T DSO_VMS_INTERNAL
+-T DTLS1_BITMAP
+-T DTLS1_RECORD_DATA
+-T DTLS1_STATE
+-T Dl_info
+-T ECDH_DATA
+-T ECDH_METHOD
+-T ECDSA_DATA
+-T ECDSA_METHOD
+-T ECDSA_SIG
+-T ECPARAMETERS
+-T ECPKPARAMETERS
+-T EC_EXTRA_DATA
+-T EC_GROUP
+-T EC_KEY
+-T EC_METHOD
+-T EC_POINT
+-T EC_PRE_COMP
+-T EC_PRIVATEKEY
+-T EC_builtin_curve
+-T EDIPARTYNAME
+-T ENGINE
+-T ENGINE_CIPHERS_PTR
+-T ENGINE_CLEANUP_CB
+-T ENGINE_CLEANUP_ITEM
+-T ENGINE_CMD_DEFN
+-T ENGINE_CTRL_FUNC_PTR
+-T ENGINE_DIGESTS_PTR
+-T ENGINE_GEN_FUNC_PTR
+-T ENGINE_GEN_INT_FUNC_PTR
+-T ENGINE_LOAD_KEY_PTR
+-T ENGINE_PILE
+-T ENGINE_PILE_DOALL
+-T ENGINE_PKEY_ASN1_METHS_PTR
+-T ENGINE_PKEY_METHS_PTR
+-T ENGINE_SSL_CLIENT_CERT_PTR
+-T ENGINE_TABLE
+-T ENUMERATED_NAMES
+-T ERR_STATE
+-T ERR_STRING_DATA
+-T ESS_CERT_ID
+-T ESS_ISSUER_SERIAL
+-T ESS_SIGNING_CERT
+-T EVP_AES_HMAC_SHA1
+-T EVP_AES_HMAC_SHA256
+-T EVP_CIPHER
+-T EVP_CIPHER_CTX
+-T EVP_CIPHER_INFO
+-T EVP_ENCODE_CTX
+-T EVP_MD
+-T EVP_MD_CTX
+-T EVP_PBE_CTL
+-T EVP_PBE_KEYGEN
+-T EVP_PKEY
+-T EVP_PKEY_ASN1_METHOD
+-T EVP_PKEY_CTX
+-T EVP_PKEY_METHOD
+-T EVP_PKEY_gen_cb
+-T EX_CLASS_ITEM
+-T E_GMP_RSA_CTX
+-T E_RSAX_MOD_CTX
+-T FILE
+-T F_DIGITALSIGNATUREVERIFY
+-T F_PUBLICKEYEXTRACT
+-T GCM128_CONTEXT
+-T GENERAL_NAME
+-T GENERAL_NAMES
+-T GENERAL_SUBTREE
+-T GEN_SESSION_CB
+-T HASH_CTX
+-T HEAPENTRY32
+-T HEAPLIST32
+-T HEARTBEAT_TEST_FIXTURE
+-T HMAC_CTX
+-T IDEA_KEY_SCHEDULE
+-T IPAddrBlocks
+-T IPAddressFamily
+-T IPAddressOrRange
+-T IPAddressOrRanges
+-T ISSUING_DIST_POINT
+-T KEY_TABLE_TYPE
+-T LHASH
+-T LHASH_COMP_FN_TYPE
+-T LHASH_DOALL_ARG_FN_TYPE
+-T LHASH_DOALL_FN_TYPE
+-T LHASH_HASH_FN_TYPE
+-T LHASH_NODE
+-T LPDIR_CTX
+-T LPHEAPENTRY32
+-T LPHEAPLIST32
+-T LPMODULEENTRY32
+-T LPMODULEENTRY32W
+-T LPPROCESSENTRY32
+-T LPPROCESSENTRY32W
+-T LPTHREADENTRY32
+-T LP_DIR_CTX
+-T MD2_CTX
+-T MD4_CTX
+-T MD5_CTX
+-T MDC2_CTX
+-T MD_DATA
+-T MEM
+-T MEM_LEAK
+-T MEM_OBJECT_DATA
+-T MIME_HEADER
+-T MIME_PARAM
+-T MODULEENTRY32
+-T MODULEENTRY32W
+-T MS_FAR
+-T NAME_CONSTRAINTS
+-T NAME_FUNCS
+-T NBIO_TEST
+-T NDEF_SUPPORT
+-T NETSCAPE_CERT_SEQUENCE
+-T NETSCAPE_ENCRYPTED_PKEY
+-T NETSCAPE_PKEY
+-T NETSCAPE_SPKAC
+-T NETSCAPE_SPKI
+-T NETSCAPE_X509
+-T NET_API_FUNCTION
+-T NOTICEREF
+-T OBJ_NAME
+-T OCB128_CONTEXT
+-T OCB_BLOCK
+-T OCSP_BASICRESP
+-T OCSP_CERTID
+-T OCSP_CERTSTATUS
+-T OCSP_CRLID
+-T OCSP_ONEREQ
+-T OCSP_REQINFO
+-T OCSP_REQUEST
+-T OCSP_REQ_CTX
+-T OCSP_RESPBYTES
+-T OCSP_RESPDATA
+-T OCSP_RESPID
+-T OCSP_RESPONSE
+-T OCSP_REVOKEDINFO
+-T OCSP_SERVICELOC
+-T OCSP_SIGNATURE
+-T OCSP_SINGLERESP
+-T OCSP_TBLSTR
+-T OPENSSL_BLOCK
+-T OPENSSL_CSTRING
+-T OPENSSL_DIR_CTX
+-T OPENSSL_ITEM
+-T OPENSSL_PSTRING
+-T OPENSSL_STRING
+-T OSSL_ASYNC_FD
+-T OTHERNAME
+-T P256_POINT
+-T P256_POINT_AFFINE
+-T PBE2PARAM
+-T PBEPARAM
+-T PBKDF2PARAM
+-T PCRYPTO_MEM_LEAK_CB
+-T PEM_CTX
+-T PEM_ENCODE_SEAL_CTX
+-T PEM_USER
+-T PHEAPENTRY32
+-T PHEAPLIST32
+-T PKCS12
+-T PKCS12_BAGS
+-T PKCS12_SAFEBAG
+-T PKCS7
+-T PKCS7_DIGEST
+-T PKCS7_ENCRYPT
+-T PKCS7_ENC_CONTENT
+-T PKCS7_ENVELOPE
+-T PKCS7_ISSUER_AND_SERIAL
+-T PKCS7_RECIP_INFO
+-T PKCS7_SIGNED
+-T PKCS7_SIGNER_INFO
+-T PKCS7_SIGN_ENVELOPE
+-T PKCS8_PRIV_KEY_INFO
+-T PKEY_USAGE_PERIOD
+-T PMODULEENTRY32
+-T PMODULEENTRY32W
+-T POLICYINFO
+-T POLICYQUALINFO
+-T POLICY_CONSTRAINTS
+-T POLICY_MAPPING
+-T POLICY_MAPPINGS
+-T PPROCESSENTRY32
+-T PPROCESSENTRY32W
+-T PRECOMP256_ROW
+-T PROCESSENTRY32
+-T PROCESSENTRY32W
+-T PROXY_CERT_INFO_EXTENSION
+-T PROXY_POLICY
+-T PTHREADENTRY32
+-T PW_CB_DATA
+-T RAND_METHOD
+-T RC2_KEY
+-T RC4_KEY
+-T RC5_32_KEY
+-T RIPEMD160_CTX
+-T RSA
+-T RSA_METHOD
+-T RSA_OAEP_PARAMS
+-T RSA_PKEY_CTX
+-T RSA_PSS_PARAMS
+-T SCT
+-T SEED_KEY_SCHEDULE
+-T SESS_CERT
+-T SHA256_CTX
+-T SHA512_CTX
+-T SHA_CTX
+-T SRP_ARG
+-T SRP_CLIENT_ARG
+-T SRP_CTX
+-T SRP_SERVER_ARG
+-T SRP_VBASE
+-T SRP_gN_cache
+-T SRP_user_pwd
+-T SRTP_PROTECTION_PROFILE
+-T SSL
+-T SSL2_STATE
+-T SSL3_BUFFER
+-T SSL3_COMP
+-T SSL3_ENC_METHOD
+-T SSL3_RECORD
+-T SSL3_STATE
+-T SSL_CIPHER
+-T SSL_COMP
+-T SSL_CONF_CTX
+-T SSL_CTX
+-T SSL_DANE
+-T SSL_EXCERT
+-T SSL_METHOD
+-T SSL_SESSION
+-T SSL_SESSION_ASN1
+-T STACK_OF
+-T SXNET
+-T SXNETID
+-T TCHAR
+-T TEST_INFO
+-T THREADENTRY32
+-T TIMEOUT_PARAM
+-T TLS_SESSION_TICKET_EXT
+-T TLS_SIGALGS
+-T TS_ACCURACY
+-T TS_MSG_IMPRINT
+-T TS_REQ
+-T TS_RESP
+-T TS_RESP_CTX
+-T TS_STATUS_INFO
+-T TS_TST_INFO
+-T TS_VERIFY_CTX
+-T TXT_DB
+-T UI
+-T UINT64
+-T UI_METHOD
+-T UI_STRING
+-T USERNOTICE
+-T WCHAR
+-T WHIRLPOOL_CTX
+-T WINAPI
+-T WSAAPI
+-T X509
+-T X509V3_CONF_METHOD
+-T X509V3_CTX
+-T X509V3_EXT_D2I
+-T X509V3_EXT_FREE
+-T X509V3_EXT_I2D
+-T X509V3_EXT_I2R
+-T X509V3_EXT_I2S
+-T X509V3_EXT_METHOD
+-T X509V3_EXT_NEW
+-T X509V3_EXT_R2I
+-T X509V3_EXT_S2I
+-T X509V3_EXT_V2I
+-T X509_ALGOR
+-T X509_ATTRIBUTE
+-T X509_CERT_AUX
+-T X509_CERT_FILE_CTX
+-T X509_CERT_PAIR
+-T X509_CINF
+-T X509_CRL
+-T X509_CRL_INFO
+-T X509_CRL_METHOD
+-T X509_EXTENSION
+-T X509_INFO
+-T X509_LOOKUP
+-T X509_LOOKUP_METHOD
+-T X509_NAME
+-T X509_NAME_ENTRY
+-T X509_OBJECT
+-T X509_OBJECTS
+-T X509_PKEY
+-T X509_POLICY_CACHE
+-T X509_POLICY_DATA
+-T X509_POLICY_LEVEL
+-T X509_POLICY_NODE
+-T X509_POLICY_TREE
+-T X509_PUBKEY
+-T X509_PURPOSE
+-T X509_REQ
+-T X509_REQ_INFO
+-T X509_REVOKED
+-T X509_SIG
+-T X509_STORE
+-T X509_STORE_CTX
+-T X509_TRUST
+-T X509_VAL
+-T X509_VERIFY_PARAM
+-T X509_VERIFY_PARAM_ID
+-T X9_62_CHARACTERISTIC_TWO
+-T X9_62_CURVE
+-T X9_62_FIELDID
+-T X9_62_PENTANOMIAL
+-T XTS128_CONTEXT
+-T ZEN_MD_DATA
+-T _LHASH
+-T _STACK
+-T __int64
+-T _ossl_old_des_cblock
+-T asn1_ps_func
+-T bio_dgram_data
+-T bio_info_cb
+-T BIO_info_cb
+-T BIO_callback_fn
+-T char_io
+-T conf_finish_func
+-T conf_init_func
+-T const_DES_cblock
+-T d2i_of_void
+-T des_cblock
+-T dynamic_data_ctx
+-T dynamic_fns
+-T engine_table_doall_cb
+-T i2d_of_void
+-T int_dhx942_dh
+-T nid_triple
+-T pem_password_cb
+-T pitem
+-T piterator
+-T pqueue_s
+-T session_op
+-T size_t
+-T tag_exp_arg
+-T testdata
+-T time_t
+-T time_t
+-T u32
+-T u64
+-T u8
+-T v3_ext_ctx
+-T v3_ext_method
+-T STACK_OF_ACCESS_DESCRIPTION_
+-T STACK_OF_ASIdOrRange_
+-T STACK_OF_ASN1_ADB_TABLE_
+-T STACK_OF_ASN1_INTEGER_
+-T STACK_OF_ASN1_OBJECT_
+-T STACK_OF_ASN1_STRING_TABLE_
+-T STACK_OF_ASN1_TYPE_
+-T STACK_OF_ASN1_UTF8STRING_
+-T STACK_OF_ASN1_VALUE_
+-T STACK_OF_BIO_
+-T STACK_OF_BY_DIR_ENTRY_
+-T STACK_OF_BY_DIR_HASH_
+-T STACK_OF_CMS_CertificateChoices_
+-T STACK_OF_CMS_RecipientEncryptedKey_
+-T STACK_OF_CMS_RecipientInfo_
+-T STACK_OF_CMS_RevocationInfoChoice_
+-T STACK_OF_CMS_SignerInfo_
+-T STACK_OF_CONF_IMODULE_
+-T STACK_OF_CONF_MODULE_
+-T STACK_OF_CONF_VALUE_
+-T STACK_OF_CRYPTO_EX_DATA_FUNCS_
+-T STACK_OF_CRYPTO_dynlock_
+-T STACK_OF_DIST_POINT_
+-T STACK_OF_ENGINE_
+-T STACK_OF_ENGINE_CLEANUP_ITEM_
+-T STACK_OF_ESS_CERT_ID_
+-T STACK_OF_EVP_PBE_CTL_
+-T STACK_OF_EVP_PKEY_ASN1_METHOD_
+-T STACK_OF_EVP_PKEY_METHOD_
+-T STACK_OF_GENERAL_NAMES_
+-T STACK_OF_GENERAL_NAME_
+-T STACK_OF_GENERAL_SUBTREE_
+-T STACK_OF_IPAddressFamily_
+-T STACK_OF_IPAddressOrRange_
+-T STACK_OF_MEM_OBJECT_DATA_
+-T STACK_OF_MIME_HEADER_
+-T STACK_OF_MIME_PARAM_
+-T STACK_OF_NAME_FUNCS_
+-T STACK_OF_OCSP_CERTID_
+-T STACK_OF_OCSP_ONEREQ_
+-T STACK_OF_OCSP_RESPID_
+-T STACK_OF_OCSP_SINGLERESP_
+-T STACK_OF_OPENSSL_BLOCK_
+-T STACK_OF_OPENSSL_PSTRING_
+-T STACK_OF_OPENSSL_STRING_
+-T STACK_OF_PKCS12_SAFEBAG_
+-T STACK_OF_PKCS7_
+-T STACK_OF_PKCS7_RECIP_INFO_
+-T STACK_OF_PKCS7_SIGNER_INFO_
+-T STACK_OF_POLICYINFO_
+-T STACK_OF_POLICYQUALINFO_
+-T STACK_OF_POLICY_MAPPING_
+-T STACK_OF_Request_
+-T STACK_OF_SCT_
+-T STACK_OF_SRP_gN_
+-T STACK_OF_SRP_gN_cache_
+-T STACK_OF_SRP_user_pwd_
+-T STACK_OF_SRTP_PROTECTION_PROFILE_
+-T STACK_OF_SSL_CIPHER_
+-T STACK_OF_SSL_COMP_
+-T STACK_OF_STRING_
+-T STACK_OF_SXNETID_
+-T STACK_OF_SingleResponse_
+-T STACK_OF_UI_STRING_
+-T STACK_OF_X509V3_EXT_METHOD_
+-T STACK_OF_X509_
+-T STACK_OF_X509_ALGOR_
+-T STACK_OF_X509_ATTRIBUTE_
+-T STACK_OF_X509_CRL_
+-T STACK_OF_X509_EXTENSION_
+-T STACK_OF_X509_INFO_
+-T STACK_OF_X509_LOOKUP_
+-T STACK_OF_X509_NAME_
+-T STACK_OF_X509_NAME_ENTRY_
+-T STACK_OF_X509_OBJECT_
+-T STACK_OF_X509_POLICY_DATA_
+-T STACK_OF_X509_POLICY_NODE_
+-T STACK_OF_X509_PURPOSE_
+-T STACK_OF_X509_REVOKED_
+-T STACK_OF_X509_TRUST_
+-T STACK_OF_X509_VERIFY_PARAM_
+-T STACK_OF_nid_triple_
+-T STACK_OF_void_
+-T LHASH_OF_ADDED_OBJ_
+-T LHASH_OF_APP_INFO_
+-T LHASH_OF_CONF_VALUE_
+-T LHASH_OF_ENGINE_PILE_
+-T LHASH_OF_ERR_STATE_
+-T LHASH_OF_ERR_STRING_DATA_
+-T LHASH_OF_EX_CLASS_ITEM_
+-T LHASH_OF_FUNCTION_
+-T LHASH_OF_MEM_
+-T LHASH_OF_OBJ_NAME_
+-T LHASH_OF_OPENSSL_STRING_
+-T LHASH_OF_SSL_SESSION_
+-T LHASH_OF_STRING_
+-T clock_t
+-T custom_ext_methods
+-T hm_fragment
+-T record_pqueue
+-T ssl_ctx_st
+-T ssl_flag_tbl
+-T ssl_st
+-T ssl_trace_tbl
+-T _stdcall
+-T tls12_lookup
+-T OPTIONS
+-T OPT_PAIR
+-T uint64_t
+-T int64_t
+-T uint32_t
+-T int32_t
+-T uint16_t
+-T int16_t
+-T uint8_t
+-T int8_t
+-T STRINT_PAIR
+-T felem
+-T felem_bytearray
+-T SH_LIST
+-T PACKET
+-T RECORD_LAYER
+-T ASYNC_FIBRE
+-T ASYNC_CTX
+-T ASYNC_JOB
+-T intmax_t
+-T uintmax_t
+-T pqueue
+-T danetls_record
diff --git a/openssl-1.1.0h/util/libcrypto.num b/openssl-1.1.0h/util/libcrypto.num
new file mode 100644
index 0000000..8414d97
--- /dev/null
+++ b/openssl-1.1.0h/util/libcrypto.num
@@ -0,0 +1,4236 @@
+d2i_EC_PUBKEY 1 1_1_0 EXIST::FUNCTION:EC
+b2i_PVK_bio 2 1_1_0 EXIST::FUNCTION:DSA,RC4
+PEM_read_bio_NETSCAPE_CERT_SEQUENCE 3 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get0_chain 4 1_1_0 EXIST::FUNCTION:
+COMP_expand_block 5 1_1_0 EXIST::FUNCTION:COMP
+X509V3_get_string 6 1_1_0 EXIST::FUNCTION:
+TS_MSG_IMPRINT_free 7 1_1_0 EXIST::FUNCTION:TS
+DES_xcbc_encrypt 8 1_1_0 EXIST::FUNCTION:DES
+TS_RESP_CTX_new 9 1_1_0 EXIST::FUNCTION:TS
+PKCS5_PBE_add 10 1_1_0 EXIST::FUNCTION:
+i2d_DSAparams 11 1_1_0 EXIST::FUNCTION:DSA
+X509_NAME_get0_der 12 1_1_0 EXIST::FUNCTION:
+i2d_ESS_ISSUER_SERIAL 13 1_1_0 EXIST::FUNCTION:TS
+X509at_get_attr_by_NID 14 1_1_0 EXIST::FUNCTION:
+X509_PUBKEY_set0_param 15 1_1_0 EXIST::FUNCTION:
+PKCS12_it 16 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS12_it 16 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+i2d_ASN1_OCTET_STRING 17 1_1_0 EXIST::FUNCTION:
+EC_KEY_set_private_key 18 1_1_0 EXIST::FUNCTION:EC
+SRP_VBASE_get_by_user 19 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,SRP
+Camellia_cfb128_encrypt 21 1_1_0 EXIST::FUNCTION:CAMELLIA
+DES_ncbc_encrypt 22 1_1_0 EXIST::FUNCTION:DES
+TS_REQ_get_ext_count 23 1_1_0 EXIST::FUNCTION:TS
+EVP_aes_128_ocb 24 1_1_0 EXIST::FUNCTION:OCB
+ASN1_item_d2i_fp 25 1_1_0 EXIST::FUNCTION:STDIO
+BN_lshift 26 1_1_0 EXIST::FUNCTION:
+X509_NAME_add_entry_by_NID 27 1_1_0 EXIST::FUNCTION:
+X509V3_add_value_bool 28 1_1_0 EXIST::FUNCTION:
+GENERAL_NAME_get0_otherName 29 1_1_0 EXIST::FUNCTION:
+ASN1_INTEGER_get_uint64 30 1_1_0 EXIST::FUNCTION:
+EVP_DigestInit_ex 31 1_1_0 EXIST::FUNCTION:
+CTLOG_new 32 1_1_0 EXIST::FUNCTION:CT
+UI_get_result_minsize 33 1_1_0 EXIST::FUNCTION:UI
+EVP_PBE_alg_add_type 34 1_1_0 EXIST::FUNCTION:
+EVP_cast5_ofb 35 1_1_0 EXIST::FUNCTION:CAST
+d2i_PUBKEY_fp 36 1_1_0 EXIST::FUNCTION:STDIO
+PKCS7_set_cipher 37 1_1_0 EXIST::FUNCTION:
+BF_decrypt 38 1_1_0 EXIST::FUNCTION:BF
+PEM_read_bio_PUBKEY 39 1_1_0 EXIST::FUNCTION:
+X509_NAME_delete_entry 40 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_set_verify_recover 41 1_1_0 EXIST::FUNCTION:
+UI_set_method 42 1_1_0 EXIST::FUNCTION:UI
+PKCS7_ISSUER_AND_SERIAL_it 43 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS7_ISSUER_AND_SERIAL_it 43 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+EC_GROUP_method_of 44 1_1_0 EXIST::FUNCTION:EC
+RSA_blinding_on 45 1_1_0 EXIST::FUNCTION:RSA
+X509_get0_signature 47 1_1_0 EXIST::FUNCTION:
+X509_REVOKED_get0_extensions 48 1_1_0 EXIST::FUNCTION:
+NETSCAPE_SPKI_verify 49 1_1_0 EXIST::FUNCTION:
+i2d_OCSP_RESPONSE 50 1_1_0 EXIST::FUNCTION:OCSP
+ERR_peek_error 51 1_1_0 EXIST::FUNCTION:
+X509v3_asid_validate_resource_set 52 1_1_0 EXIST::FUNCTION:RFC3779
+PEM_write_bio_Parameters 53 1_1_0 EXIST::FUNCTION:
+CMS_SignerInfo_verify 54 1_1_0 EXIST::FUNCTION:CMS
+X509v3_asid_is_canonical 55 1_1_0 EXIST::FUNCTION:RFC3779
+ASN1_ENUMERATED_get 56 1_1_0 EXIST::FUNCTION:
+EVP_MD_do_all_sorted 57 1_1_0 EXIST::FUNCTION:
+OCSP_crl_reason_str 58 1_1_0 EXIST::FUNCTION:OCSP
+ENGINE_ctrl_cmd_string 59 1_1_0 EXIST::FUNCTION:ENGINE
+ENGINE_finish 60 1_1_0 EXIST::FUNCTION:ENGINE
+SRP_Calc_client_key 61 1_1_0 EXIST::FUNCTION:SRP
+X509_PUBKEY_free 62 1_1_0 EXIST::FUNCTION:
+BIO_free_all 63 1_1_0 EXIST::FUNCTION:
+EVP_idea_ofb 64 1_1_0 EXIST::FUNCTION:IDEA
+DSO_bind_func 65 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_get_copy 66 1_1_0 EXIST::FUNCTION:
+RSA_up_ref 67 1_1_0 EXIST::FUNCTION:RSA
+EVP_PKEY_meth_set_ctrl 68 1_1_0 EXIST::FUNCTION:
+OCSP_basic_sign 69 1_1_0 EXIST::FUNCTION:OCSP
+BN_GENCB_set 70 1_1_0 EXIST::FUNCTION:
+BN_generate_prime 71 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_0_9_8
+d2i_DSAPrivateKey_fp 72 1_1_0 EXIST::FUNCTION:DSA,STDIO
+BIO_nread0 73 1_1_0 EXIST::FUNCTION:
+NETSCAPE_SPKI_print 74 1_1_0 EXIST::FUNCTION:
+X509_set_pubkey 75 1_1_0 EXIST::FUNCTION:
+ASN1_item_print 76 1_1_0 EXIST::FUNCTION:
+CONF_set_nconf 77 1_1_0 EXIST::FUNCTION:
+RAND_set_rand_method 78 1_1_0 EXIST::FUNCTION:
+BN_GF2m_mod_mul 79 1_1_0 EXIST::FUNCTION:EC2M
+UI_add_input_boolean 80 1_1_0 EXIST::FUNCTION:UI
+ASN1_TIME_adj 81 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_asn1_get0_info 82 1_1_0 EXIST::FUNCTION:
+BN_add_word 83 1_1_0 EXIST::FUNCTION:
+EVP_des_ede 84 1_1_0 EXIST::FUNCTION:DES
+EVP_PKEY_add1_attr_by_OBJ 85 1_1_0 EXIST::FUNCTION:
+ASYNC_WAIT_CTX_get_all_fds 86 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_meth_set_do_cipher 87 1_1_0 EXIST::FUNCTION:
+EVP_set_pw_prompt 88 1_1_0 EXIST::FUNCTION:UI
+d2i_OCSP_RESPBYTES 89 1_1_0 EXIST::FUNCTION:OCSP
+TS_REQ_get_ext_by_NID 90 1_1_0 EXIST::FUNCTION:TS
+ASN1_item_ndef_i2d 91 1_1_0 EXIST::FUNCTION:
+OCSP_archive_cutoff_new 92 1_1_0 EXIST::FUNCTION:OCSP
+DSA_size 93 1_1_0 EXIST::FUNCTION:DSA
+IPAddressRange_free 94 1_1_0 EXIST::FUNCTION:RFC3779
+CMS_ContentInfo_free 95 1_1_0 EXIST::FUNCTION:CMS
+BIO_accept 96 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,SOCK
+X509_VERIFY_PARAM_set1_policies 97 1_1_0 EXIST::FUNCTION:
+SCT_set0_extensions 98 1_1_0 EXIST::FUNCTION:CT
+PKCS5_pbe2_set_scrypt 99 1_1_0 EXIST::FUNCTION:SCRYPT
+X509_find_by_subject 100 1_1_0 EXIST::FUNCTION:
+DSAparams_print 101 1_1_0 EXIST::FUNCTION:DSA
+BF_set_key 102 1_1_0 EXIST::FUNCTION:BF
+d2i_DHparams 103 1_1_0 EXIST::FUNCTION:DH
+i2d_PKCS7_ENC_CONTENT 104 1_1_0 EXIST::FUNCTION:
+DH_generate_key 105 1_1_0 EXIST::FUNCTION:DH
+ENGINE_add_conf_module 106 1_1_0 EXIST::FUNCTION:ENGINE
+BIO_new_socket 107 1_1_0 EXIST::FUNCTION:SOCK
+ASN1_OBJECT_free 108 1_1_0 EXIST::FUNCTION:
+X509_REQ_get_extensions 109 1_1_0 EXIST::FUNCTION:
+X509_get_version 110 1_1_0 EXIST::FUNCTION:
+OCSP_CERTID_dup 111 1_1_0 EXIST::FUNCTION:OCSP
+RSA_PSS_PARAMS_free 112 1_1_0 EXIST::FUNCTION:RSA
+i2d_TS_MSG_IMPRINT 113 1_1_0 EXIST::FUNCTION:TS
+EC_POINT_mul 114 1_1_0 EXIST::FUNCTION:EC
+WHIRLPOOL_Final 115 1_1_0 EXIST::FUNCTION:WHIRLPOOL
+CMS_get1_ReceiptRequest 116 1_1_0 EXIST::FUNCTION:CMS
+BIO_sock_non_fatal_error 117 1_1_0 EXIST::FUNCTION:SOCK
+HMAC_Update 118 1_1_0 EXIST::FUNCTION:
+i2d_PKCS12 119 1_1_0 EXIST::FUNCTION:
+EVP_BytesToKey 120 1_1_0 EXIST::FUNCTION:
+ENGINE_set_default_pkey_asn1_meths 121 1_1_0 EXIST::FUNCTION:ENGINE
+OCSP_BASICRESP_add1_ext_i2d 122 1_1_0 EXIST::FUNCTION:OCSP
+EVP_camellia_128_ctr 123 1_1_0 EXIST::FUNCTION:CAMELLIA
+EVP_CIPHER_impl_ctx_size 124 1_1_0 EXIST::FUNCTION:
+X509_CRL_get_nextUpdate 125 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0
+PKCS12_free 126 1_1_0 EXIST::FUNCTION:
+CMS_signed_get_attr 127 1_1_0 EXIST::FUNCTION:CMS
+ENGINE_set_destroy_function 128 1_1_0 EXIST::FUNCTION:ENGINE
+ASN1_STRING_TABLE_add 129 1_1_0 EXIST::FUNCTION:
+d2i_ASIdentifiers 130 1_1_0 EXIST::FUNCTION:RFC3779
+i2d_PKCS12_bio 131 1_1_0 EXIST::FUNCTION:
+X509_to_X509_REQ 132 1_1_0 EXIST::FUNCTION:
+OCSP_basic_add1_nonce 133 1_1_0 EXIST::FUNCTION:OCSP
+d2i_OCSP_BASICRESP 134 1_1_0 EXIST::FUNCTION:OCSP
+X509v3_add_ext 135 1_1_0 EXIST::FUNCTION:
+X509v3_addr_subset 136 1_1_0 EXIST::FUNCTION:RFC3779
+CRYPTO_strndup 137 1_1_0 EXIST::FUNCTION:
+OCSP_REQ_CTX_free 138 1_1_0 EXIST::FUNCTION:OCSP
+X509_STORE_new 140 1_1_0 EXIST::FUNCTION:
+ASN1_TYPE_free 141 1_1_0 EXIST::FUNCTION:
+PKCS12_BAGS_new 142 1_1_0 EXIST::FUNCTION:
+CMAC_CTX_new 143 1_1_0 EXIST::FUNCTION:CMAC
+ASIdentifierChoice_new 144 1_1_0 EXIST::FUNCTION:RFC3779
+EVP_PKEY_asn1_set_public 145 1_1_0 EXIST::FUNCTION:
+IDEA_set_decrypt_key 146 1_1_0 EXIST::FUNCTION:IDEA
+X509_STORE_CTX_set_flags 147 1_1_0 EXIST::FUNCTION:
+BIO_ADDR_rawmake 148 1_1_0 EXIST::FUNCTION:SOCK
+EVP_PKEY_asn1_set_ctrl 149 1_1_0 EXIST::FUNCTION:
+EC_POINTs_mul 150 1_1_0 EXIST::FUNCTION:EC
+ASN1_get_object 151 1_1_0 EXIST::FUNCTION:
+i2d_IPAddressFamily 152 1_1_0 EXIST::FUNCTION:RFC3779
+ENGINE_get_ctrl_function 153 1_1_0 EXIST::FUNCTION:ENGINE
+X509_REVOKED_get_ext_count 154 1_1_0 EXIST::FUNCTION:
+BN_is_prime_fasttest_ex 155 1_1_0 EXIST::FUNCTION:
+ERR_load_PKCS12_strings 156 1_1_0 EXIST::FUNCTION:
+EVP_sha384 157 1_1_0 EXIST::FUNCTION:
+i2d_DHparams 158 1_1_0 EXIST::FUNCTION:DH
+TS_VERIFY_CTX_set_store 159 1_1_0 EXIST::FUNCTION:TS
+PKCS12_verify_mac 160 1_1_0 EXIST::FUNCTION:
+X509v3_addr_canonize 161 1_1_0 EXIST::FUNCTION:RFC3779
+ASN1_item_ex_i2d 162 1_1_0 EXIST::FUNCTION:
+ENGINE_set_digests 163 1_1_0 EXIST::FUNCTION:ENGINE
+PEM_ASN1_read_bio 164 1_1_0 EXIST::FUNCTION:
+CT_POLICY_EVAL_CTX_free 165 1_1_0 EXIST::FUNCTION:CT
+CMS_RecipientInfo_kari_get0_ctx 166 1_1_0 EXIST::FUNCTION:CMS
+PKCS7_set_attributes 167 1_1_0 EXIST::FUNCTION:
+d2i_POLICYQUALINFO 168 1_1_0 EXIST::FUNCTION:
+EVP_MD_type 170 1_1_0 EXIST::FUNCTION:
+EVP_PKCS82PKEY 171 1_1_0 EXIST::FUNCTION:
+BN_generate_prime_ex 172 1_1_0 EXIST::FUNCTION:
+EVP_EncryptInit 173 1_1_0 EXIST::FUNCTION:
+RAND_OpenSSL 174 1_1_0 EXIST::FUNCTION:
+BN_uadd 175 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_derive_init 176 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_ASN1_stream 177 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_delete_attr 178 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_CTX_key_length 179 1_1_0 EXIST::FUNCTION:
+BIO_clear_flags 180 1_1_0 EXIST::FUNCTION:
+i2d_DISPLAYTEXT 181 1_1_0 EXIST::FUNCTION:
+OCSP_response_status 182 1_1_0 EXIST::FUNCTION:OCSP
+i2d_ASN1_PRINTABLESTRING 183 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_set_hostflags 184 1_1_0 EXIST::FUNCTION:
+SCT_get0_log_id 185 1_1_0 EXIST::FUNCTION:CT
+ASN1_IA5STRING_it 186 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_IA5STRING_it 186 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+PEM_write_bio_ECPrivateKey 187 1_1_0 EXIST::FUNCTION:EC
+BN_consttime_swap 188 1_1_0 EXIST::FUNCTION:
+BIO_f_buffer 189 1_1_0 EXIST::FUNCTION:
+CMS_SignerInfo_get0_signer_id 190 1_1_0 EXIST::FUNCTION:CMS
+TS_TST_INFO_new 191 1_1_0 EXIST::FUNCTION:TS
+X509_REQ_check_private_key 192 1_1_0 EXIST::FUNCTION:
+EVP_DigestInit 193 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_find 194 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_get_count 195 1_1_0 EXIST::FUNCTION:
+ASN1_BIT_STRING_get_bit 196 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_cmp 197 1_1_0 EXIST::FUNCTION:
+d2i_X509_ALGORS 198 1_1_0 EXIST::FUNCTION:
+EVP_PKEY2PKCS8 199 1_1_0 EXIST::FUNCTION:
+BN_nist_mod_256 200 1_1_0 EXIST::FUNCTION:
+OCSP_request_add0_id 201 1_1_0 EXIST::FUNCTION:OCSP
+EVP_seed_cfb128 202 1_1_0 EXIST::FUNCTION:SEED
+BASIC_CONSTRAINTS_free 203 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_flags 204 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_ECPKParameters 205 1_1_0 EXIST::FUNCTION:EC
+SCT_set_version 206 1_1_0 EXIST::FUNCTION:CT
+CMS_add1_ReceiptRequest 207 1_1_0 EXIST::FUNCTION:CMS
+d2i_CRL_DIST_POINTS 208 1_1_0 EXIST::FUNCTION:
+X509_CRL_INFO_free 209 1_1_0 EXIST::FUNCTION:
+ERR_load_UI_strings 210 1_1_0 EXIST::FUNCTION:UI
+ERR_load_strings 211 1_1_0 EXIST::FUNCTION:
+RSA_X931_hash_id 212 1_1_0 EXIST::FUNCTION:RSA
+EC_KEY_set_method 213 1_1_0 EXIST::FUNCTION:EC
+PEM_write_PKCS8_PRIV_KEY_INFO 214 1_1_0 EXIST::FUNCTION:STDIO
+X509at_get0_data_by_OBJ 215 1_1_0 EXIST::FUNCTION:
+b2i_PublicKey_bio 216 1_1_0 EXIST::FUNCTION:DSA
+s2i_ASN1_OCTET_STRING 217 1_1_0 EXIST::FUNCTION:
+POLICYINFO_it 218 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+POLICYINFO_it 218 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+OBJ_create 219 1_1_0 EXIST::FUNCTION:
+d2i_NOTICEREF 220 1_1_0 EXIST::FUNCTION:
+BN_get_rfc2409_prime_768 221 1_1_0 EXIST::FUNCTION:
+PEM_read_bio_PKCS8 222 1_1_0 EXIST::FUNCTION:
+X509_ATTRIBUTE_new 223 1_1_0 EXIST::FUNCTION:
+ASN1_STRING_TABLE_cleanup 224 1_1_0 EXIST::FUNCTION:
+ASN1_put_eoc 225 1_1_0 EXIST::FUNCTION:
+EVP_MD_meth_set_input_blocksize 226 1_1_0 EXIST::FUNCTION:
+PKCS12_SAFEBAG_get0_attrs 227 1_1_0 EXIST::FUNCTION:
+PKCS8_get_attr 228 1_1_0 EXIST::FUNCTION:
+DSAparams_print_fp 229 1_1_0 EXIST::FUNCTION:DSA,STDIO
+EC_POINT_set_Jprojective_coordinates_GFp 230 1_1_0 EXIST::FUNCTION:EC
+DIST_POINT_NAME_new 231 1_1_0 EXIST::FUNCTION:
+X509_LOOKUP_file 232 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_set_decrypt 233 1_1_0 EXIST::FUNCTION:
+EVP_rc2_ecb 234 1_1_0 EXIST::FUNCTION:RC2
+i2b_PublicKey_bio 235 1_1_0 EXIST::FUNCTION:DSA
+d2i_ASN1_SET_ANY 236 1_1_0 EXIST::FUNCTION:
+ASN1_item_i2d 238 1_1_0 EXIST::FUNCTION:
+OCSP_copy_nonce 239 1_1_0 EXIST::FUNCTION:OCSP
+OBJ_txt2nid 240 1_1_0 EXIST::FUNCTION:
+SEED_set_key 241 1_1_0 EXIST::FUNCTION:SEED
+EC_KEY_clear_flags 242 1_1_0 EXIST::FUNCTION:EC
+CMS_RecipientInfo_ktri_get0_algs 243 1_1_0 EXIST::FUNCTION:CMS
+i2d_EC_PUBKEY 244 1_1_0 EXIST::FUNCTION:EC
+MDC2 245 1_1_0 EXIST::FUNCTION:MDC2
+BN_clear_free 246 1_1_0 EXIST::FUNCTION:
+ENGINE_get_pkey_asn1_meths 247 1_1_0 EXIST::FUNCTION:ENGINE
+DSO_merge 248 1_1_0 EXIST::FUNCTION:
+RSA_get_ex_data 249 1_1_0 EXIST::FUNCTION:RSA
+EVP_PKEY_meth_get_decrypt 250 1_1_0 EXIST::FUNCTION:
+DES_cfb_encrypt 251 1_1_0 EXIST::FUNCTION:DES
+CMS_SignerInfo_set1_signer_cert 252 1_1_0 EXIST::FUNCTION:CMS
+X509_CRL_http_nbio 253 1_1_0 EXIST::FUNCTION:OCSP
+ENGINE_register_all_ciphers 254 1_1_0 EXIST::FUNCTION:ENGINE
+SXNET_new 255 1_1_0 EXIST::FUNCTION:
+EVP_camellia_256_ctr 256 1_1_0 EXIST::FUNCTION:CAMELLIA
+d2i_PKCS8_PRIV_KEY_INFO 257 1_1_0 EXIST::FUNCTION:
+EVP_md2 259 1_1_0 EXIST::FUNCTION:MD2
+RC2_ecb_encrypt 260 1_1_0 EXIST::FUNCTION:RC2
+ENGINE_register_DH 261 1_1_0 EXIST::FUNCTION:ENGINE
+ASN1_NULL_free 262 1_1_0 EXIST::FUNCTION:
+EC_KEY_copy 263 1_1_0 EXIST::FUNCTION:EC
+EVP_des_ede3 264 1_1_0 EXIST::FUNCTION:DES
+PKCS7_add1_attrib_digest 265 1_1_0 EXIST::FUNCTION:
+EC_POINT_get_affine_coordinates_GFp 266 1_1_0 EXIST::FUNCTION:EC
+EVP_seed_ecb 267 1_1_0 EXIST::FUNCTION:SEED
+BIO_dgram_sctp_wait_for_dry 268 1_1_0 EXIST::FUNCTION:DGRAM,SCTP
+ASN1_OCTET_STRING_NDEF_it 269 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_OCTET_STRING_NDEF_it 269 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+EVP_PKEY_asn1_get_count 270 1_1_0 EXIST::FUNCTION:
+WHIRLPOOL_Init 271 1_1_0 EXIST::FUNCTION:WHIRLPOOL
+EVP_OpenInit 272 1_1_0 EXIST::FUNCTION:RSA
+OCSP_response_get1_basic 273 1_1_0 EXIST::FUNCTION:OCSP
+CRYPTO_gcm128_tag 274 1_1_0 EXIST::FUNCTION:
+OCSP_parse_url 275 1_1_0 EXIST::FUNCTION:OCSP
+UI_get0_test_string 276 1_1_0 EXIST::FUNCTION:UI
+CRYPTO_secure_free 277 1_1_0 EXIST::FUNCTION:
+DSA_print_fp 278 1_1_0 EXIST::FUNCTION:DSA,STDIO
+X509_get_ext_d2i 279 1_1_0 EXIST::FUNCTION:
+d2i_PKCS7_ENC_CONTENT 280 1_1_0 EXIST::FUNCTION:
+BUF_MEM_grow 281 1_1_0 EXIST::FUNCTION:
+TS_REQ_free 282 1_1_0 EXIST::FUNCTION:TS
+PEM_read_DHparams 283 1_1_0 EXIST::FUNCTION:DH,STDIO
+RSA_private_decrypt 284 1_1_0 EXIST::FUNCTION:RSA
+X509V3_EXT_get_nid 285 1_1_0 EXIST::FUNCTION:
+BIO_s_log 286 1_1_0 EXIST:!WIN32,!macintosh:FUNCTION:
+EC_POINT_set_to_infinity 287 1_1_0 EXIST::FUNCTION:EC
+EVP_des_ede_ofb 288 1_1_0 EXIST::FUNCTION:DES
+ECDH_KDF_X9_62 289 1_1_0 EXIST::FUNCTION:EC
+ASN1_UNIVERSALSTRING_to_string 290 1_1_0 EXIST::FUNCTION:
+CRYPTO_gcm128_setiv 291 1_1_0 EXIST::FUNCTION:
+ASN1_PCTX_set_oid_flags 292 1_1_0 EXIST::FUNCTION:
+d2i_ASN1_INTEGER 293 1_1_0 EXIST::FUNCTION:
+i2d_PKCS7_ENCRYPT 294 1_1_0 EXIST::FUNCTION:
+CT_POLICY_EVAL_CTX_set1_issuer 295 1_1_0 EXIST::FUNCTION:CT
+X509_NAME_ENTRY_set 296 1_1_0 EXIST::FUNCTION:
+PKCS8_set0_pbe 297 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_DSA_PUBKEY 298 1_1_0 EXIST::FUNCTION:DSA
+PEM_X509_INFO_read_bio 299 1_1_0 EXIST::FUNCTION:
+EC_GROUP_get0_order 300 1_1_0 EXIST::FUNCTION:EC
+OCSP_BASICRESP_delete_ext 301 1_1_0 EXIST::FUNCTION:OCSP
+PKCS12_get_attr_gen 302 1_1_0 EXIST::FUNCTION:
+PKCS12_SAFEBAG_get0_safes 303 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_derive 304 1_1_0 EXIST::FUNCTION:
+OCSP_BASICRESP_get_ext_by_NID 305 1_1_0 EXIST::FUNCTION:OCSP
+OBJ_dup 306 1_1_0 EXIST::FUNCTION:
+CMS_signed_get_attr_count 307 1_1_0 EXIST::FUNCTION:CMS
+EC_get_builtin_curves 308 1_1_0 EXIST::FUNCTION:EC
+i2d_ASN1_IA5STRING 309 1_1_0 EXIST::FUNCTION:
+OCSP_check_nonce 310 1_1_0 EXIST::FUNCTION:OCSP
+X509_STORE_CTX_init 311 1_1_0 EXIST::FUNCTION:
+OCSP_RESPONSE_free 312 1_1_0 EXIST::FUNCTION:OCSP
+ENGINE_set_DH 313 1_1_0 EXIST::FUNCTION:ENGINE
+EVP_CIPHER_CTX_set_flags 314 1_1_0 EXIST::FUNCTION:
+err_free_strings_int 315 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_PKCS7_stream 316 1_1_0 EXIST::FUNCTION:
+d2i_X509_CERT_AUX 317 1_1_0 EXIST::FUNCTION:
+UI_process 318 1_1_0 EXIST::FUNCTION:UI
+X509_get_subject_name 319 1_1_0 EXIST::FUNCTION:
+DH_get_1024_160 320 1_1_0 EXIST::FUNCTION:DH
+i2d_ASN1_UNIVERSALSTRING 321 1_1_0 EXIST::FUNCTION:
+d2i_OCSP_RESPID 322 1_1_0 EXIST::FUNCTION:OCSP
+BIO_s_accept 323 1_1_0 EXIST::FUNCTION:SOCK
+EVP_whirlpool 324 1_1_0 EXIST::FUNCTION:WHIRLPOOL
+OCSP_ONEREQ_get1_ext_d2i 325 1_1_0 EXIST::FUNCTION:OCSP
+d2i_ESS_SIGNING_CERT 326 1_1_0 EXIST::FUNCTION:TS
+EC_KEY_set_default_method 327 1_1_0 EXIST::FUNCTION:EC
+X509_OBJECT_up_ref_count 328 1_1_0 EXIST::FUNCTION:
+RAND_load_file 329 1_1_0 EXIST::FUNCTION:
+BIO_ctrl_reset_read_request 330 1_1_0 EXIST::FUNCTION:
+CRYPTO_ccm128_tag 331 1_1_0 EXIST::FUNCTION:
+BIO_new_dgram_sctp 332 1_1_0 EXIST::FUNCTION:DGRAM,SCTP
+d2i_RSAPrivateKey_fp 333 1_1_0 EXIST::FUNCTION:RSA,STDIO
+s2i_ASN1_IA5STRING 334 1_1_0 EXIST::FUNCTION:
+UI_get_ex_data 335 1_1_0 EXIST::FUNCTION:UI
+EVP_EncryptUpdate 336 1_1_0 EXIST::FUNCTION:
+SRP_create_verifier 337 1_1_0 EXIST::FUNCTION:SRP
+TS_TST_INFO_print_bio 338 1_1_0 EXIST::FUNCTION:TS
+X509_NAME_get_index_by_OBJ 339 1_1_0 EXIST::FUNCTION:
+BIO_get_host_ip 340 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,SOCK
+PKCS7_add_certificate 341 1_1_0 EXIST::FUNCTION:
+TS_REQ_get_ext 342 1_1_0 EXIST::FUNCTION:TS
+X509_NAME_cmp 343 1_1_0 EXIST::FUNCTION:
+DIST_POINT_it 344 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+DIST_POINT_it 344 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+PEM_read_X509_CRL 345 1_1_0 EXIST::FUNCTION:STDIO
+OPENSSL_sk_sort 346 1_1_0 EXIST::FUNCTION:
+CTLOG_STORE_load_file 347 1_1_0 EXIST::FUNCTION:CT
+ASN1_SEQUENCE_it 348 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_SEQUENCE_it 348 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+TS_RESP_CTX_get_tst_info 349 1_1_0 EXIST::FUNCTION:TS
+RC4 350 1_1_0 EXIST::FUNCTION:RC4
+PKCS7_stream 352 1_1_0 EXIST::FUNCTION:
+i2t_ASN1_OBJECT 353 1_1_0 EXIST::FUNCTION:
+EC_GROUP_get0_generator 354 1_1_0 EXIST::FUNCTION:EC
+RSA_padding_add_PKCS1_PSS_mgf1 355 1_1_0 EXIST::FUNCTION:RSA
+EVP_MD_meth_set_init 356 1_1_0 EXIST::FUNCTION:
+X509_get_issuer_name 357 1_1_0 EXIST::FUNCTION:
+EVP_SignFinal 358 1_1_0 EXIST::FUNCTION:
+PKCS12_mac_present 359 1_1_0 EXIST::FUNCTION:
+d2i_PUBKEY_bio 360 1_1_0 EXIST::FUNCTION:
+BN_asc2bn 361 1_1_0 EXIST::FUNCTION:
+EVP_desx_cbc 362 1_1_0 EXIST::FUNCTION:DES
+SXNETID_it 363 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+SXNETID_it 363 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+CRYPTO_gcm128_encrypt 364 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_CTX_ctrl_str 365 1_1_0 EXIST::FUNCTION:
+CMS_signed_add1_attr_by_txt 366 1_1_0 EXIST::FUNCTION:CMS
+i2d_NETSCAPE_SPKAC 367 1_1_0 EXIST::FUNCTION:
+X509V3_add_value_bool_nf 368 1_1_0 EXIST::FUNCTION:
+ASN1_item_verify 369 1_1_0 EXIST::FUNCTION:
+SEED_ecb_encrypt 370 1_1_0 EXIST::FUNCTION:SEED
+X509_PUBKEY_get0_param 371 1_1_0 EXIST::FUNCTION:
+ASN1_i2d_fp 372 1_1_0 EXIST::FUNCTION:STDIO
+BIO_new_mem_buf 373 1_1_0 EXIST::FUNCTION:
+UI_get_input_flags 374 1_1_0 EXIST::FUNCTION:UI
+X509V3_EXT_REQ_add_nconf 375 1_1_0 EXIST::FUNCTION:
+X509v3_asid_subset 376 1_1_0 EXIST::FUNCTION:RFC3779
+RSA_check_key_ex 377 1_1_0 EXIST::FUNCTION:RSA
+d2i_TS_MSG_IMPRINT_bio 378 1_1_0 EXIST::FUNCTION:TS
+i2d_ASN1_TYPE 379 1_1_0 EXIST::FUNCTION:
+EVP_aes_256_wrap_pad 380 1_1_0 EXIST::FUNCTION:
+CMS_RecipientInfo_kekri_id_cmp 381 1_1_0 EXIST::FUNCTION:CMS
+X509_VERIFY_PARAM_get0_peername 382 1_1_0 EXIST::FUNCTION:
+ASN1_PCTX_get_oid_flags 383 1_1_0 EXIST::FUNCTION:
+CONF_free 384 1_1_0 EXIST::FUNCTION:
+DSO_get_filename 385 1_1_0 EXIST::FUNCTION:
+i2d_ASN1_SEQUENCE_ANY 387 1_1_0 EXIST::FUNCTION:
+OPENSSL_strlcpy 388 1_1_0 EXIST::FUNCTION:
+BIO_get_port 389 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,SOCK
+DISPLAYTEXT_free 390 1_1_0 EXIST::FUNCTION:
+BN_div 391 1_1_0 EXIST::FUNCTION:
+RIPEMD160_Update 392 1_1_0 EXIST::FUNCTION:RMD160
+PEM_write_bio_CMS 393 1_1_0 EXIST::FUNCTION:CMS
+ASN1_OBJECT_new 394 1_1_0 EXIST::FUNCTION:
+EVP_des_ede3_cfb8 395 1_1_0 EXIST::FUNCTION:DES
+BIO_dump_indent_fp 396 1_1_0 EXIST::FUNCTION:STDIO
+X509_NAME_ENTRY_get_data 397 1_1_0 EXIST::FUNCTION:
+BIO_socket 398 1_1_0 EXIST::FUNCTION:SOCK
+EVP_PKEY_meth_get_derive 399 1_1_0 EXIST::FUNCTION:
+ASN1_STRING_clear_free 400 1_1_0 EXIST::FUNCTION:
+d2i_OCSP_REVOKEDINFO 401 1_1_0 EXIST::FUNCTION:OCSP
+ASN1_STRING_print_ex_fp 402 1_1_0 EXIST::FUNCTION:STDIO
+PKCS7_SIGNED_new 403 1_1_0 EXIST::FUNCTION:
+CMS_get0_eContentType 404 1_1_0 EXIST::FUNCTION:CMS
+HMAC_Final 405 1_1_0 EXIST::FUNCTION:
+X509_CRL_delete_ext 406 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_get_ordering 407 1_1_0 EXIST::FUNCTION:TS
+X509_get_extended_key_usage 408 1_1_0 EXIST::FUNCTION:
+ERR_print_errors 409 1_1_0 EXIST::FUNCTION:
+X509_REVOKED_set_revocationDate 410 1_1_0 EXIST::FUNCTION:
+EVP_CipherFinal_ex 411 1_1_0 EXIST::FUNCTION:
+d2i_DSA_PUBKEY 412 1_1_0 EXIST::FUNCTION:DSA
+BN_CTX_get 413 1_1_0 EXIST::FUNCTION:
+BN_to_montgomery 414 1_1_0 EXIST::FUNCTION:
+X509_OBJECT_get0_X509_CRL 415 1_1_0 EXIST::FUNCTION:
+EVP_camellia_128_cfb8 416 1_1_0 EXIST::FUNCTION:CAMELLIA
+EC_KEY_METHOD_free 417 1_1_0 EXIST::FUNCTION:EC
+TS_TST_INFO_set_policy_id 418 1_1_0 EXIST::FUNCTION:TS
+d2i_EXTENDED_KEY_USAGE 419 1_1_0 EXIST::FUNCTION:
+ASYNC_unblock_pause 420 1_1_0 EXIST::FUNCTION:
+i2d_X509_VAL 421 1_1_0 EXIST::FUNCTION:
+ASN1_SCTX_get_flags 422 1_1_0 EXIST::FUNCTION:
+RIPEMD160 423 1_1_0 EXIST::FUNCTION:RMD160
+CRYPTO_ocb128_setiv 424 1_1_0 EXIST::FUNCTION:OCB
+X509_CRL_digest 425 1_1_0 EXIST::FUNCTION:
+EVP_aes_128_cbc_hmac_sha1 426 1_1_0 EXIST::FUNCTION:
+ERR_load_CMS_strings 427 1_1_0 EXIST::FUNCTION:CMS
+EVP_MD_CTX_md 428 1_1_0 EXIST::FUNCTION:
+X509_REVOKED_get_ext 429 1_1_0 EXIST::FUNCTION:
+d2i_RSA_PSS_PARAMS 430 1_1_0 EXIST::FUNCTION:RSA
+USERNOTICE_free 431 1_1_0 EXIST::FUNCTION:
+MD4_Transform 432 1_1_0 EXIST::FUNCTION:MD4
+EVP_CIPHER_block_size 433 1_1_0 EXIST::FUNCTION:
+CERTIFICATEPOLICIES_new 434 1_1_0 EXIST::FUNCTION:
+BIO_dump_fp 435 1_1_0 EXIST::FUNCTION:STDIO
+BIO_set_flags 436 1_1_0 EXIST::FUNCTION:
+BN_is_one 437 1_1_0 EXIST::FUNCTION:
+TS_CONF_set_def_policy 438 1_1_0 EXIST::FUNCTION:TS
+DSA_free 439 1_1_0 EXIST::FUNCTION:DSA
+BN_GENCB_new 440 1_1_0 EXIST::FUNCTION:
+X509_VAL_new 441 1_1_0 EXIST::FUNCTION:
+NCONF_load 442 1_1_0 EXIST::FUNCTION:
+ASN1_put_object 443 1_1_0 EXIST::FUNCTION:
+d2i_OCSP_RESPONSE 444 1_1_0 EXIST::FUNCTION:OCSP
+d2i_PublicKey 445 1_1_0 EXIST::FUNCTION:
+ENGINE_set_ex_data 446 1_1_0 EXIST::FUNCTION:ENGINE
+X509_get_default_private_dir 447 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_set0_dane 448 1_1_0 EXIST::FUNCTION:
+EVP_des_ecb 449 1_1_0 EXIST::FUNCTION:DES
+OCSP_resp_get0 450 1_1_0 EXIST::FUNCTION:OCSP
+RSA_X931_generate_key_ex 452 1_1_0 EXIST::FUNCTION:RSA
+X509_get_serialNumber 453 1_1_0 EXIST::FUNCTION:
+BIO_sock_should_retry 454 1_1_0 EXIST::FUNCTION:SOCK
+ENGINE_get_digests 455 1_1_0 EXIST::FUNCTION:ENGINE
+TS_MSG_IMPRINT_get_algo 456 1_1_0 EXIST::FUNCTION:TS
+DH_new_method 457 1_1_0 EXIST::FUNCTION:DH
+BF_ecb_encrypt 458 1_1_0 EXIST::FUNCTION:BF
+PEM_write_bio_DHparams 459 1_1_0 EXIST::FUNCTION:DH
+EVP_DigestFinal 460 1_1_0 EXIST::FUNCTION:
+CT_POLICY_EVAL_CTX_set_shared_CTLOG_STORE 461 1_1_0 EXIST::FUNCTION:CT
+X509v3_asid_add_id_or_range 462 1_1_0 EXIST::FUNCTION:RFC3779
+X509_NAME_ENTRY_create_by_NID 463 1_1_0 EXIST::FUNCTION:
+EC_KEY_METHOD_get_init 464 1_1_0 EXIST::FUNCTION:EC
+ASN1_INTEGER_to_BN 465 1_1_0 EXIST::FUNCTION:
+OPENSSL_memcmp 466 1_1_0 EXIST::FUNCTION:
+BUF_MEM_new 467 1_1_0 EXIST::FUNCTION:
+DSO_set_filename 468 1_1_0 EXIST::FUNCTION:
+DH_new 469 1_1_0 EXIST::FUNCTION:DH
+OCSP_RESPID_free 470 1_1_0 EXIST::FUNCTION:OCSP
+PKCS5_pbe2_set 471 1_1_0 EXIST::FUNCTION:
+SCT_set_signature_nid 473 1_1_0 EXIST::FUNCTION:CT
+i2d_RSA_PUBKEY_fp 474 1_1_0 EXIST::FUNCTION:RSA,STDIO
+PKCS12_BAGS_it 475 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS12_BAGS_it 475 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+X509_pubkey_digest 476 1_1_0 EXIST::FUNCTION:
+ENGINE_register_all_RSA 477 1_1_0 EXIST::FUNCTION:ENGINE
+CRYPTO_THREAD_set_local 478 1_1_0 EXIST::FUNCTION:
+X509_get_default_cert_dir_env 479 1_1_0 EXIST::FUNCTION:
+X509_CRL_sort 480 1_1_0 EXIST::FUNCTION:
+i2d_RSA_PUBKEY_bio 481 1_1_0 EXIST::FUNCTION:RSA
+ASN1_T61STRING_free 482 1_1_0 EXIST::FUNCTION:
+PEM_write_CMS 483 1_1_0 EXIST::FUNCTION:CMS,STDIO
+OPENSSL_sk_find 484 1_1_0 EXIST::FUNCTION:
+ENGINE_get_ciphers 485 1_1_0 EXIST::FUNCTION:ENGINE
+EVP_rc2_ofb 486 1_1_0 EXIST::FUNCTION:RC2
+EVP_PKEY_set1_RSA 487 1_1_0 EXIST::FUNCTION:RSA
+CMS_SignerInfo_get0_md_ctx 488 1_1_0 EXIST::FUNCTION:CMS
+X509_STORE_set_trust 489 1_1_0 EXIST::FUNCTION:
+d2i_POLICYINFO 490 1_1_0 EXIST::FUNCTION:
+DES_cbc_encrypt 491 1_1_0 EXIST::FUNCTION:DES
+BN_GF2m_mod_sqr_arr 492 1_1_0 EXIST::FUNCTION:EC2M
+ASN1_PRINTABLESTRING_it 493 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_PRINTABLESTRING_it 493 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+BIO_f_cipher 494 1_1_0 EXIST::FUNCTION:
+UI_destroy_method 495 1_1_0 EXIST::FUNCTION:UI
+BN_get_rfc3526_prime_3072 496 1_1_0 EXIST::FUNCTION:
+X509_INFO_new 497 1_1_0 EXIST::FUNCTION:
+OCSP_RESPDATA_it 498 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:OCSP
+OCSP_RESPDATA_it 498 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:OCSP
+X509_CRL_print 499 1_1_0 EXIST::FUNCTION:
+WHIRLPOOL_Update 500 1_1_0 EXIST::FUNCTION:WHIRLPOOL
+DSA_get_ex_data 501 1_1_0 EXIST::FUNCTION:DSA
+BN_copy 502 1_1_0 EXIST::FUNCTION:
+FIPS_mode_set 503 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_add0_policy 504 1_1_0 EXIST::FUNCTION:
+PKCS7_cert_from_signer_info 505 1_1_0 EXIST::FUNCTION:
+X509_TRUST_get_trust 506 1_1_0 EXIST::FUNCTION:
+DES_string_to_key 507 1_1_0 EXIST::FUNCTION:DES
+ERR_error_string 508 1_1_0 EXIST::FUNCTION:
+BIO_new_connect 509 1_1_0 EXIST::FUNCTION:SOCK
+DSA_new_method 511 1_1_0 EXIST::FUNCTION:DSA
+OCSP_CERTID_new 512 1_1_0 EXIST::FUNCTION:OCSP
+X509_CRL_get_signature_nid 513 1_1_0 EXIST::FUNCTION:
+X509_policy_level_node_count 514 1_1_0 EXIST::FUNCTION:
+d2i_OCSP_CERTSTATUS 515 1_1_0 EXIST::FUNCTION:OCSP
+X509V3_add1_i2d 516 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_set_serial 517 1_1_0 EXIST::FUNCTION:TS
+OCSP_RESPBYTES_new 518 1_1_0 EXIST::FUNCTION:OCSP
+OCSP_SINGLERESP_delete_ext 519 1_1_0 EXIST::FUNCTION:OCSP
+EVP_MD_CTX_test_flags 521 1_1_0 EXIST::FUNCTION:
+X509v3_addr_validate_path 522 1_1_0 EXIST::FUNCTION:RFC3779
+BIO_new_fp 523 1_1_0 EXIST::FUNCTION:STDIO
+EC_GROUP_set_generator 524 1_1_0 EXIST::FUNCTION:EC
+CRYPTO_memdup 525 1_1_0 EXIST::FUNCTION:
+DH_generate_parameters 526 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_0_9_8,DH
+BN_set_negative 527 1_1_0 EXIST::FUNCTION:
+i2d_TS_RESP_bio 528 1_1_0 EXIST::FUNCTION:TS
+ASYNC_WAIT_CTX_set_wait_fd 529 1_1_0 EXIST::FUNCTION:
+ERR_func_error_string 530 1_1_0 EXIST::FUNCTION:
+ASN1_STRING_data 531 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0
+X509_CRL_add1_ext_i2d 532 1_1_0 EXIST::FUNCTION:
+i2d_TS_TST_INFO 533 1_1_0 EXIST::FUNCTION:TS
+OBJ_sigid_free 534 1_1_0 EXIST::FUNCTION:
+TS_STATUS_INFO_get0_status 535 1_1_0 EXIST::FUNCTION:TS
+EC_KEY_get_flags 536 1_1_0 EXIST::FUNCTION:EC
+ASN1_TYPE_cmp 537 1_1_0 EXIST::FUNCTION:
+i2d_RSAPublicKey 538 1_1_0 EXIST::FUNCTION:RSA
+EC_GROUP_get_trinomial_basis 539 1_1_0 EXIST::FUNCTION:EC,EC2M
+BIO_ADDRINFO_protocol 540 1_1_0 EXIST::FUNCTION:SOCK
+i2d_PBKDF2PARAM 541 1_1_0 EXIST::FUNCTION:
+ENGINE_unregister_RAND 542 1_1_0 EXIST::FUNCTION:ENGINE
+PEM_write_bio_RSAPrivateKey 543 1_1_0 EXIST::FUNCTION:RSA
+CONF_get_number 544 1_1_0 EXIST::FUNCTION:
+X509_EXTENSION_get_object 545 1_1_0 EXIST::FUNCTION:
+X509_EXTENSIONS_it 546 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_EXTENSIONS_it 546 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+EC_POINT_set_compressed_coordinates_GF2m 547 1_1_0 EXIST::FUNCTION:EC,EC2M
+RSA_sign_ASN1_OCTET_STRING 548 1_1_0 EXIST::FUNCTION:RSA
+d2i_X509_CRL_fp 549 1_1_0 EXIST::FUNCTION:STDIO
+i2d_RSA_PUBKEY 550 1_1_0 EXIST::FUNCTION:RSA
+EVP_aes_128_ccm 551 1_1_0 EXIST::FUNCTION:
+ECParameters_print 552 1_1_0 EXIST::FUNCTION:EC
+OCSP_SINGLERESP_get1_ext_d2i 553 1_1_0 EXIST::FUNCTION:OCSP
+RAND_status 554 1_1_0 EXIST::FUNCTION:
+EVP_ripemd160 555 1_1_0 EXIST::FUNCTION:RMD160
+EVP_MD_meth_set_final 556 1_1_0 EXIST::FUNCTION:
+ENGINE_get_cmd_defns 557 1_1_0 EXIST::FUNCTION:ENGINE
+d2i_PKEY_USAGE_PERIOD 558 1_1_0 EXIST::FUNCTION:
+RSAPublicKey_dup 559 1_1_0 EXIST::FUNCTION:RSA
+RAND_write_file 560 1_1_0 EXIST::FUNCTION:
+BN_GF2m_mod 561 1_1_0 EXIST::FUNCTION:EC2M
+EC_GROUP_get_pentanomial_basis 562 1_1_0 EXIST::FUNCTION:EC,EC2M
+X509_CINF_free 563 1_1_0 EXIST::FUNCTION:
+X509_EXTENSION_free 564 1_1_0 EXIST::FUNCTION:
+EVP_DigestSignInit 565 1_1_0 EXIST::FUNCTION:
+CT_POLICY_EVAL_CTX_get0_issuer 566 1_1_0 EXIST::FUNCTION:CT
+TLS_FEATURE_new 567 1_1_0 EXIST::FUNCTION:
+RSA_get_default_method 568 1_1_0 EXIST::FUNCTION:RSA
+CRYPTO_cts128_encrypt_block 569 1_1_0 EXIST::FUNCTION:
+ASN1_digest 570 1_1_0 EXIST::FUNCTION:
+ERR_load_X509V3_strings 571 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_get_cleanup 572 1_1_0 EXIST::FUNCTION:
+d2i_X509 574 1_1_0 EXIST::FUNCTION:
+a2i_ASN1_STRING 575 1_1_0 EXIST::FUNCTION:
+EC_GROUP_get_mont_data 576 1_1_0 EXIST::FUNCTION:EC
+CMAC_CTX_copy 577 1_1_0 EXIST::FUNCTION:CMAC
+EVP_camellia_128_cfb128 579 1_1_0 EXIST::FUNCTION:CAMELLIA
+DH_compute_key_padded 580 1_1_0 EXIST::FUNCTION:DH
+ERR_load_CONF_strings 581 1_1_0 EXIST::FUNCTION:
+ESS_ISSUER_SERIAL_dup 582 1_1_0 EXIST::FUNCTION:TS
+BN_GF2m_mod_exp_arr 583 1_1_0 EXIST::FUNCTION:EC2M
+ASN1_UTF8STRING_free 584 1_1_0 EXIST::FUNCTION:
+BN_X931_generate_prime_ex 585 1_1_0 EXIST::FUNCTION:
+ENGINE_get_RAND 586 1_1_0 EXIST::FUNCTION:ENGINE
+EVP_DecryptInit 587 1_1_0 EXIST::FUNCTION:
+BN_bin2bn 588 1_1_0 EXIST::FUNCTION:
+X509_subject_name_hash 589 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_meth_set_flags 590 1_1_0 EXIST::FUNCTION:
+TS_CONF_set_clock_precision_digits 591 1_1_0 EXIST::FUNCTION:TS
+ASN1_TYPE_set 592 1_1_0 EXIST::FUNCTION:
+i2d_PKCS8_PRIV_KEY_INFO 593 1_1_0 EXIST::FUNCTION:
+i2d_PKCS7_bio 594 1_1_0 EXIST::FUNCTION:
+EVP_MD_meth_get_copy 595 1_1_0 EXIST::FUNCTION:
+RAND_query_egd_bytes 596 1_1_0 EXIST::FUNCTION:EGD
+i2d_ASN1_PRINTABLE 597 1_1_0 EXIST::FUNCTION:
+ENGINE_cmd_is_executable 598 1_1_0 EXIST::FUNCTION:ENGINE
+BIO_puts 599 1_1_0 EXIST::FUNCTION:
+RSAPublicKey_it 601 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:RSA
+RSAPublicKey_it 601 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:RSA
+ISSUING_DIST_POINT_new 602 1_1_0 EXIST::FUNCTION:
+X509_VAL_it 603 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_VAL_it 603 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+EVP_DigestVerifyInit 604 1_1_0 EXIST::FUNCTION:
+i2d_IPAddressChoice 605 1_1_0 EXIST::FUNCTION:RFC3779
+EVP_md5 606 1_1_0 EXIST::FUNCTION:MD5
+ASRange_new 607 1_1_0 EXIST::FUNCTION:RFC3779
+BN_GF2m_mod_mul_arr 608 1_1_0 EXIST::FUNCTION:EC2M
+d2i_RSA_OAEP_PARAMS 609 1_1_0 EXIST::FUNCTION:RSA
+BIO_s_bio 610 1_1_0 EXIST::FUNCTION:
+OBJ_NAME_add 611 1_1_0 EXIST::FUNCTION:
+BIO_fd_non_fatal_error 612 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_set_type 613 1_1_0 EXIST::FUNCTION:
+ENGINE_get_next 614 1_1_0 EXIST::FUNCTION:ENGINE
+BN_is_negative 615 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_get_attr_count 616 1_1_0 EXIST::FUNCTION:
+X509_REVOKED_get_ext_by_critical 617 1_1_0 EXIST::FUNCTION:
+X509at_get_attr 618 1_1_0 EXIST::FUNCTION:
+X509_PUBKEY_it 619 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_PUBKEY_it 619 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+DES_ede3_ofb64_encrypt 620 1_1_0 EXIST::FUNCTION:DES
+EC_KEY_METHOD_get_compute_key 621 1_1_0 EXIST::FUNCTION:EC
+RC2_cfb64_encrypt 622 1_1_0 EXIST::FUNCTION:RC2
+EVP_EncryptFinal_ex 623 1_1_0 EXIST::FUNCTION:
+ERR_load_RSA_strings 624 1_1_0 EXIST::FUNCTION:RSA
+CRYPTO_secure_malloc_done 625 1_1_0 EXIST::FUNCTION:
+RSA_OAEP_PARAMS_new 626 1_1_0 EXIST::FUNCTION:RSA
+X509_NAME_free 627 1_1_0 EXIST::FUNCTION:
+PKCS12_set_mac 628 1_1_0 EXIST::FUNCTION:
+UI_get0_result_string 629 1_1_0 EXIST::FUNCTION:UI
+TS_RESP_CTX_add_policy 630 1_1_0 EXIST::FUNCTION:TS
+X509_REQ_dup 631 1_1_0 EXIST::FUNCTION:
+d2i_DSA_PUBKEY_fp 633 1_1_0 EXIST::FUNCTION:DSA,STDIO
+OCSP_REQ_CTX_nbio_d2i 634 1_1_0 EXIST::FUNCTION:OCSP
+d2i_X509_REQ_fp 635 1_1_0 EXIST::FUNCTION:STDIO
+DH_OpenSSL 636 1_1_0 EXIST::FUNCTION:DH
+BN_get_rfc3526_prime_8192 637 1_1_0 EXIST::FUNCTION:
+X509_REVOKED_it 638 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_REVOKED_it 638 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+CRYPTO_THREAD_write_lock 639 1_1_0 EXIST::FUNCTION:
+X509V3_NAME_from_section 640 1_1_0 EXIST::FUNCTION:
+EC_POINT_set_compressed_coordinates_GFp 641 1_1_0 EXIST::FUNCTION:EC
+OCSP_SINGLERESP_get0_id 642 1_1_0 EXIST::FUNCTION:OCSP
+UI_add_info_string 643 1_1_0 EXIST::FUNCTION:UI
+OBJ_NAME_remove 644 1_1_0 EXIST::FUNCTION:
+UI_get_method 645 1_1_0 EXIST::FUNCTION:UI
+CONF_modules_unload 646 1_1_0 EXIST::FUNCTION:
+CRYPTO_ccm128_encrypt_ccm64 647 1_1_0 EXIST::FUNCTION:
+CRYPTO_secure_malloc_init 648 1_1_0 EXIST::FUNCTION:
+DSAparams_dup 649 1_1_0 EXIST::FUNCTION:DSA
+PKCS8_PRIV_KEY_INFO_new 650 1_1_0 EXIST::FUNCTION:
+TS_RESP_verify_token 652 1_1_0 EXIST::FUNCTION:TS
+PEM_read_bio_CMS 653 1_1_0 EXIST::FUNCTION:CMS
+PEM_get_EVP_CIPHER_INFO 654 1_1_0 EXIST::FUNCTION:
+X509V3_EXT_print 655 1_1_0 EXIST::FUNCTION:
+i2d_OCSP_SINGLERESP 656 1_1_0 EXIST::FUNCTION:OCSP
+ESS_CERT_ID_free 657 1_1_0 EXIST::FUNCTION:TS
+PEM_SignInit 658 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_CTX_set_key_length 659 1_1_0 EXIST::FUNCTION:
+X509_delete_ext 660 1_1_0 EXIST::FUNCTION:
+OCSP_resp_get0_produced_at 661 1_1_0 EXIST::FUNCTION:OCSP
+IDEA_encrypt 662 1_1_0 EXIST::FUNCTION:IDEA
+CRYPTO_nistcts128_encrypt_block 663 1_1_0 EXIST::FUNCTION:
+EVP_MD_do_all 664 1_1_0 EXIST::FUNCTION:
+EC_KEY_oct2priv 665 1_1_0 EXIST::FUNCTION:EC
+CONF_parse_list 666 1_1_0 EXIST::FUNCTION:
+ENGINE_set_table_flags 667 1_1_0 EXIST::FUNCTION:ENGINE
+EVP_MD_meth_get_ctrl 668 1_1_0 EXIST::FUNCTION:
+ASN1_TYPE_get_int_octetstring 669 1_1_0 EXIST::FUNCTION:
+PKCS5_pbe_set0_algor 670 1_1_0 EXIST::FUNCTION:
+ENGINE_get_table_flags 671 1_1_0 EXIST::FUNCTION:ENGINE
+PKCS12_MAC_DATA_new 672 1_1_0 EXIST::FUNCTION:
+X509_chain_up_ref 673 1_1_0 EXIST::FUNCTION:
+OCSP_REQINFO_it 674 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:OCSP
+OCSP_REQINFO_it 674 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:OCSP
+PKCS12_add_localkeyid 675 1_1_0 EXIST::FUNCTION:
+PKCS12_SAFEBAG_get0_type 676 1_1_0 EXIST::FUNCTION:
+X509_TRUST_set_default 677 1_1_0 EXIST::FUNCTION:
+TXT_DB_read 678 1_1_0 EXIST::FUNCTION:
+BN_sub 679 1_1_0 EXIST::FUNCTION:
+ASRange_free 680 1_1_0 EXIST::FUNCTION:RFC3779
+EVP_aes_192_cfb8 681 1_1_0 EXIST::FUNCTION:
+DSO_global_lookup 682 1_1_0 EXIST::FUNCTION:
+PKCS7_SIGNER_INFO_it 683 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS7_SIGNER_INFO_it 683 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+CRYPTO_ocb128_copy_ctx 684 1_1_0 EXIST::FUNCTION:OCB
+TS_REQ_get_ext_d2i 685 1_1_0 EXIST::FUNCTION:TS
+AES_ige_encrypt 686 1_1_0 EXIST::FUNCTION:
+d2i_SXNET 687 1_1_0 EXIST::FUNCTION:
+CTLOG_get0_log_id 688 1_1_0 EXIST::FUNCTION:CT
+CMS_RecipientInfo_ktri_get0_signer_id 689 1_1_0 EXIST::FUNCTION:CMS
+OCSP_REQUEST_add1_ext_i2d 690 1_1_0 EXIST::FUNCTION:OCSP
+EVP_PBE_CipherInit 691 1_1_0 EXIST::FUNCTION:
+DSA_dup_DH 692 1_1_0 EXIST::FUNCTION:DH,DSA
+CONF_imodule_get_value 693 1_1_0 EXIST::FUNCTION:
+OCSP_id_issuer_cmp 694 1_1_0 EXIST::FUNCTION:OCSP
+ASN1_INTEGER_free 695 1_1_0 EXIST::FUNCTION:
+BN_get0_nist_prime_224 696 1_1_0 EXIST::FUNCTION:
+OPENSSL_isservice 697 1_1_0 EXIST::FUNCTION:
+DH_compute_key 698 1_1_0 EXIST::FUNCTION:DH
+TS_RESP_CTX_set_signer_key 699 1_1_0 EXIST::FUNCTION:TS
+i2d_DSAPrivateKey_bio 700 1_1_0 EXIST::FUNCTION:DSA
+ASN1_item_d2i 702 1_1_0 EXIST::FUNCTION:
+BIO_int_ctrl 703 1_1_0 EXIST::FUNCTION:
+CMS_ReceiptRequest_it 704 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:CMS
+CMS_ReceiptRequest_it 704 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:CMS
+X509_ATTRIBUTE_get0_type 705 1_1_0 EXIST::FUNCTION:
+EVP_MD_meth_set_copy 706 1_1_0 EXIST::FUNCTION:
+d2i_ASN1_ENUMERATED 707 1_1_0 EXIST::FUNCTION:
+d2i_ASIdOrRange 708 1_1_0 EXIST::FUNCTION:RFC3779
+i2s_ASN1_OCTET_STRING 709 1_1_0 EXIST::FUNCTION:
+X509_add1_reject_object 710 1_1_0 EXIST::FUNCTION:
+ERR_set_mark 711 1_1_0 EXIST::FUNCTION:
+d2i_ASN1_VISIBLESTRING 712 1_1_0 EXIST::FUNCTION:
+X509_NAME_ENTRY_dup 714 1_1_0 EXIST::FUNCTION:
+X509_certificate_type 715 1_1_0 EXIST::FUNCTION:
+PKCS7_add_signature 716 1_1_0 EXIST::FUNCTION:
+OBJ_ln2nid 717 1_1_0 EXIST::FUNCTION:
+CRYPTO_128_unwrap 718 1_1_0 EXIST::FUNCTION:
+BIO_new_PKCS7 719 1_1_0 EXIST::FUNCTION:
+UI_get0_user_data 720 1_1_0 EXIST::FUNCTION:UI
+TS_RESP_get_token 721 1_1_0 EXIST::FUNCTION:TS
+OCSP_RESPID_new 722 1_1_0 EXIST::FUNCTION:OCSP
+ASN1_SET_ANY_it 723 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_SET_ANY_it 723 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+d2i_TS_RESP_bio 724 1_1_0 EXIST::FUNCTION:TS
+PEM_write_X509_REQ 725 1_1_0 EXIST::FUNCTION:STDIO
+BIO_snprintf 726 1_1_0 EXIST::FUNCTION:
+EC_POINT_hex2point 727 1_1_0 EXIST::FUNCTION:EC
+X509v3_get_ext_by_critical 728 1_1_0 EXIST::FUNCTION:
+ENGINE_get_default_RSA 729 1_1_0 EXIST::FUNCTION:ENGINE
+DSA_sign_setup 730 1_1_0 EXIST::FUNCTION:DSA
+OPENSSL_sk_new_null 731 1_1_0 EXIST::FUNCTION:
+PEM_read_PKCS8 732 1_1_0 EXIST::FUNCTION:STDIO
+BN_mod_sqr 733 1_1_0 EXIST::FUNCTION:
+CAST_ofb64_encrypt 734 1_1_0 EXIST::FUNCTION:CAST
+TXT_DB_write 735 1_1_0 EXIST::FUNCTION:
+OCSP_REQUEST_get1_ext_d2i 736 1_1_0 EXIST::FUNCTION:OCSP
+CMS_unsigned_add1_attr_by_NID 737 1_1_0 EXIST::FUNCTION:CMS
+BN_mod_exp_mont 738 1_1_0 EXIST::FUNCTION:
+d2i_DHxparams 739 1_1_0 EXIST::FUNCTION:DH
+DH_size 740 1_1_0 EXIST::FUNCTION:DH
+CONF_imodule_get_name 741 1_1_0 EXIST::FUNCTION:
+ENGINE_get_pkey_meth_engine 742 1_1_0 EXIST::FUNCTION:ENGINE
+OCSP_BASICRESP_free 743 1_1_0 EXIST::FUNCTION:OCSP
+BN_set_params 744 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_0_9_8
+BN_add 745 1_1_0 EXIST::FUNCTION:
+OPENSSL_sk_free 746 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_get_ext_d2i 747 1_1_0 EXIST::FUNCTION:TS
+RSA_check_key 748 1_1_0 EXIST::FUNCTION:RSA
+TS_MSG_IMPRINT_set_algo 749 1_1_0 EXIST::FUNCTION:TS
+BN_nist_mod_521 750 1_1_0 EXIST::FUNCTION:
+CRYPTO_THREAD_get_local 751 1_1_0 EXIST::FUNCTION:
+PKCS7_to_TS_TST_INFO 752 1_1_0 EXIST::FUNCTION:TS
+X509_STORE_CTX_new 753 1_1_0 EXIST::FUNCTION:
+CTLOG_STORE_new 754 1_1_0 EXIST::FUNCTION:CT
+EVP_CIPHER_meth_set_cleanup 755 1_1_0 EXIST::FUNCTION:
+d2i_PKCS12_SAFEBAG 756 1_1_0 EXIST::FUNCTION:
+EVP_MD_pkey_type 757 1_1_0 EXIST::FUNCTION:
+X509_policy_node_get0_qualifiers 758 1_1_0 EXIST::FUNCTION:
+OCSP_cert_status_str 759 1_1_0 EXIST::FUNCTION:OCSP
+EVP_MD_meth_get_flags 760 1_1_0 EXIST::FUNCTION:
+ASN1_ENUMERATED_set 761 1_1_0 EXIST::FUNCTION:
+UI_UTIL_read_pw 762 1_1_0 EXIST::FUNCTION:UI
+PKCS7_ENC_CONTENT_free 763 1_1_0 EXIST::FUNCTION:
+CMS_RecipientInfo_type 764 1_1_0 EXIST::FUNCTION:CMS
+OCSP_BASICRESP_get_ext 765 1_1_0 EXIST::FUNCTION:OCSP
+BN_lebin2bn 766 1_1_0 EXIST::FUNCTION:
+AES_decrypt 767 1_1_0 EXIST::FUNCTION:
+BIO_fd_should_retry 768 1_1_0 EXIST::FUNCTION:
+ASN1_STRING_new 769 1_1_0 EXIST::FUNCTION:
+ENGINE_init 770 1_1_0 EXIST::FUNCTION:ENGINE
+TS_RESP_CTX_add_flags 771 1_1_0 EXIST::FUNCTION:TS
+BIO_gethostbyname 772 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,SOCK
+X509V3_EXT_add 773 1_1_0 EXIST::FUNCTION:
+UI_add_verify_string 774 1_1_0 EXIST::FUNCTION:UI
+EVP_rc5_32_12_16_cfb64 775 1_1_0 EXIST::FUNCTION:RC5
+PKCS7_dataVerify 776 1_1_0 EXIST::FUNCTION:
+PKCS7_SIGNER_INFO_free 777 1_1_0 EXIST::FUNCTION:
+PKCS7_add_attrib_smimecap 778 1_1_0 EXIST::FUNCTION:
+ERR_peek_last_error_line_data 779 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_set_sign 780 1_1_0 EXIST::FUNCTION:
+ASN1_i2d_bio 781 1_1_0 EXIST::FUNCTION:
+DSA_verify 782 1_1_0 EXIST::FUNCTION:DSA
+i2a_ASN1_OBJECT 783 1_1_0 EXIST::FUNCTION:
+i2d_PKEY_USAGE_PERIOD 784 1_1_0 EXIST::FUNCTION:
+DSA_new 785 1_1_0 EXIST::FUNCTION:DSA
+PEM_read_bio_X509_CRL 786 1_1_0 EXIST::FUNCTION:
+PKCS7_dataDecode 787 1_1_0 EXIST::FUNCTION:
+DSA_up_ref 788 1_1_0 EXIST::FUNCTION:DSA
+EVP_DecryptInit_ex 789 1_1_0 EXIST::FUNCTION:
+CONF_get1_default_config_file 790 1_1_0 EXIST::FUNCTION:
+CRYPTO_ocb128_encrypt 791 1_1_0 EXIST::FUNCTION:OCB
+EXTENDED_KEY_USAGE_new 792 1_1_0 EXIST::FUNCTION:
+EVP_EncryptFinal 793 1_1_0 EXIST::FUNCTION:
+PEM_write_ECPrivateKey 794 1_1_0 EXIST::FUNCTION:EC,STDIO
+EVP_CIPHER_meth_set_get_asn1_params 796 1_1_0 EXIST::FUNCTION:
+PKCS7_dataInit 797 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_CTX_set_app_data 798 1_1_0 EXIST::FUNCTION:
+a2i_GENERAL_NAME 799 1_1_0 EXIST::FUNCTION:
+SXNETID_new 800 1_1_0 EXIST::FUNCTION:
+RC4_options 801 1_1_0 EXIST::FUNCTION:RC4
+BIO_f_null 802 1_1_0 EXIST::FUNCTION:
+EC_GROUP_set_curve_name 803 1_1_0 EXIST::FUNCTION:EC
+d2i_PBE2PARAM 804 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_security_bits 805 1_1_0 EXIST::FUNCTION:
+PKCS12_unpack_p7encdata 806 1_1_0 EXIST::FUNCTION:
+X509V3_EXT_i2d 807 1_1_0 EXIST::FUNCTION:
+X509V3_get_value_bool 808 1_1_0 EXIST::FUNCTION:
+X509_verify_cert_error_string 809 1_1_0 EXIST::FUNCTION:
+d2i_X509_PUBKEY 810 1_1_0 EXIST::FUNCTION:
+i2a_ASN1_ENUMERATED 811 1_1_0 EXIST::FUNCTION:
+PKCS7_ISSUER_AND_SERIAL_new 812 1_1_0 EXIST::FUNCTION:
+d2i_USERNOTICE 813 1_1_0 EXIST::FUNCTION:
+X509_cmp 814 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_set1_EC_KEY 815 1_1_0 EXIST::FUNCTION:EC
+ECPKParameters_print_fp 816 1_1_0 EXIST::FUNCTION:EC,STDIO
+GENERAL_SUBTREE_free 817 1_1_0 EXIST::FUNCTION:
+RSA_blinding_off 818 1_1_0 EXIST::FUNCTION:RSA
+i2d_OCSP_REVOKEDINFO 819 1_1_0 EXIST::FUNCTION:OCSP
+X509V3_add_standard_extensions 820 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_RSA_PUBKEY 821 1_1_0 EXIST::FUNCTION:RSA
+i2d_ASN1_UTF8STRING 822 1_1_0 EXIST::FUNCTION:
+TS_REQ_delete_ext 823 1_1_0 EXIST::FUNCTION:TS
+PKCS7_DIGEST_free 824 1_1_0 EXIST::FUNCTION:
+OBJ_nid2ln 825 1_1_0 EXIST::FUNCTION:
+COMP_CTX_new 826 1_1_0 EXIST::FUNCTION:COMP
+BIO_ADDR_family 827 1_1_0 EXIST::FUNCTION:SOCK
+OCSP_RESPONSE_it 828 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:OCSP
+OCSP_RESPONSE_it 828 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:OCSP
+BIO_ADDRINFO_socktype 829 1_1_0 EXIST::FUNCTION:SOCK
+d2i_X509_REQ_bio 830 1_1_0 EXIST::FUNCTION:
+EVP_PBE_cleanup 831 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get0_current_crl 832 1_1_0 EXIST::FUNCTION:
+CMS_get0_SignerInfos 833 1_1_0 EXIST::FUNCTION:CMS
+EVP_PKEY_paramgen 834 1_1_0 EXIST::FUNCTION:
+PEM_write_PKCS8PrivateKey_nid 835 1_1_0 EXIST::FUNCTION:STDIO
+PKCS7_ATTR_VERIFY_it 836 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS7_ATTR_VERIFY_it 836 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+OCSP_response_status_str 837 1_1_0 EXIST::FUNCTION:OCSP
+CRYPTO_gcm128_new 838 1_1_0 EXIST::FUNCTION:
+SMIME_read_PKCS7 839 1_1_0 EXIST::FUNCTION:
+EC_GROUP_copy 840 1_1_0 EXIST::FUNCTION:EC
+ENGINE_set_ciphers 841 1_1_0 EXIST::FUNCTION:ENGINE
+OPENSSL_LH_doall_arg 842 1_1_0 EXIST::FUNCTION:
+OCSP_REQUEST_get_ext_by_NID 843 1_1_0 EXIST::FUNCTION:OCSP
+X509_REQ_get_attr_by_NID 844 1_1_0 EXIST::FUNCTION:
+PBE2PARAM_new 845 1_1_0 EXIST::FUNCTION:
+DES_ecb_encrypt 846 1_1_0 EXIST::FUNCTION:DES
+EVP_camellia_256_ecb 847 1_1_0 EXIST::FUNCTION:CAMELLIA
+PEM_read_RSA_PUBKEY 848 1_1_0 EXIST::FUNCTION:RSA,STDIO
+d2i_NETSCAPE_SPKAC 849 1_1_0 EXIST::FUNCTION:
+ASN1_TIME_check 851 1_1_0 EXIST::FUNCTION:
+PKCS7_DIGEST_new 852 1_1_0 EXIST::FUNCTION:
+i2d_TS_TST_INFO_fp 853 1_1_0 EXIST::FUNCTION:STDIO,TS
+d2i_PKCS8_fp 854 1_1_0 EXIST::FUNCTION:STDIO
+EVP_PKEY_keygen 855 1_1_0 EXIST::FUNCTION:
+X509_CRL_dup 856 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_CTX_get_cb 857 1_1_0 EXIST::FUNCTION:
+X509_STORE_free 858 1_1_0 EXIST::FUNCTION:
+ECDSA_sign_ex 859 1_1_0 EXIST::FUNCTION:EC
+TXT_DB_insert 860 1_1_0 EXIST::FUNCTION:
+EC_POINTs_make_affine 861 1_1_0 EXIST::FUNCTION:EC
+RSA_padding_add_PKCS1_PSS 862 1_1_0 EXIST::FUNCTION:RSA
+BF_options 863 1_1_0 EXIST::FUNCTION:BF
+OCSP_BASICRESP_it 864 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:OCSP
+OCSP_BASICRESP_it 864 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:OCSP
+X509_VERIFY_PARAM_get0_name 865 1_1_0 EXIST::FUNCTION:
+TS_RESP_CTX_set_signer_digest 866 1_1_0 EXIST::FUNCTION:TS
+X509_VERIFY_PARAM_set1_email 867 1_1_0 EXIST::FUNCTION:
+BIO_sock_error 868 1_1_0 EXIST::FUNCTION:SOCK
+RSA_set_default_method 869 1_1_0 EXIST::FUNCTION:RSA
+BN_GF2m_mod_sqrt_arr 870 1_1_0 EXIST::FUNCTION:EC2M
+X509_get0_extensions 871 1_1_0 EXIST::FUNCTION:
+TS_STATUS_INFO_set_status 872 1_1_0 EXIST::FUNCTION:TS
+RSA_verify 873 1_1_0 EXIST::FUNCTION:RSA
+ASN1_FBOOLEAN_it 874 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_FBOOLEAN_it 874 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+d2i_ASN1_TIME 875 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_get_signctx 876 1_1_0 EXIST::FUNCTION:
+EC_KEY_METHOD_set_compute_key 877 1_1_0 EXIST::FUNCTION:EC
+X509_REQ_INFO_free 878 1_1_0 EXIST::FUNCTION:
+CMS_ReceiptRequest_create0 879 1_1_0 EXIST::FUNCTION:CMS
+EVP_MD_meth_set_cleanup 880 1_1_0 EXIST::FUNCTION:
+EVP_aes_128_xts 881 1_1_0 EXIST::FUNCTION:
+TS_RESP_verify_signature 883 1_1_0 EXIST::FUNCTION:TS
+ENGINE_set_pkey_meths 884 1_1_0 EXIST::FUNCTION:ENGINE
+CMS_EncryptedData_decrypt 885 1_1_0 EXIST::FUNCTION:CMS
+CONF_module_add 886 1_1_0 EXIST::FUNCTION:
+ASN1_UTCTIME_print 887 1_1_0 EXIST::FUNCTION:
+X509_REQ_verify 888 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_set_purpose 889 1_1_0 EXIST::FUNCTION:
+i2d_TS_MSG_IMPRINT_bio 890 1_1_0 EXIST::FUNCTION:TS
+X509_EXTENSION_set_object 891 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_CTX_get_app_data 892 1_1_0 EXIST::FUNCTION:
+CRL_DIST_POINTS_it 893 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+CRL_DIST_POINTS_it 893 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+DIRECTORYSTRING_new 894 1_1_0 EXIST::FUNCTION:
+ERR_load_ASYNC_strings 895 1_1_0 EXIST::FUNCTION:
+EVP_bf_cfb64 896 1_1_0 EXIST::FUNCTION:BF
+PKCS7_sign_add_signer 897 1_1_0 EXIST::FUNCTION:
+X509_print_ex 898 1_1_0 EXIST::FUNCTION:
+PKCS7_add_recipient 899 1_1_0 EXIST::FUNCTION:
+OCSP_SINGLERESP_add_ext 900 1_1_0 EXIST::FUNCTION:OCSP
+d2i_X509_SIG 901 1_1_0 EXIST::FUNCTION:
+X509_NAME_set 902 1_1_0 EXIST::FUNCTION:
+OPENSSL_sk_pop 903 1_1_0 EXIST::FUNCTION:
+ENGINE_register_ciphers 904 1_1_0 EXIST::FUNCTION:ENGINE
+PKCS5_pbe2_set_iv 905 1_1_0 EXIST::FUNCTION:
+ASN1_add_stable_module 906 1_1_0 EXIST::FUNCTION:
+EVP_camellia_128_cbc 907 1_1_0 EXIST::FUNCTION:CAMELLIA
+COMP_zlib 908 1_1_0 EXIST::FUNCTION:COMP
+EVP_read_pw_string 909 1_1_0 EXIST::FUNCTION:UI
+i2d_ASN1_NULL 910 1_1_0 EXIST::FUNCTION:
+DES_encrypt1 911 1_1_0 EXIST::FUNCTION:DES
+BN_mod_lshift1_quick 912 1_1_0 EXIST::FUNCTION:
+BN_get_rfc3526_prime_6144 913 1_1_0 EXIST::FUNCTION:
+OBJ_obj2txt 914 1_1_0 EXIST::FUNCTION:
+UI_set_result 915 1_1_0 EXIST::FUNCTION:UI
+EVP_EncodeUpdate 916 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_X509_CRL 917 1_1_0 EXIST::FUNCTION:
+BN_cmp 918 1_1_0 EXIST::FUNCTION:
+CT_POLICY_EVAL_CTX_get0_log_store 919 1_1_0 EXIST::FUNCTION:CT
+CONF_set_default_method 920 1_1_0 EXIST::FUNCTION:
+ASN1_PCTX_get_nm_flags 921 1_1_0 EXIST::FUNCTION:
+X509_add1_ext_i2d 922 1_1_0 EXIST::FUNCTION:
+i2d_PKCS7_RECIP_INFO 924 1_1_0 EXIST::FUNCTION:
+PKCS1_MGF1 925 1_1_0 EXIST::FUNCTION:RSA
+BIO_vsnprintf 926 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get0_current_issuer 927 1_1_0 EXIST::FUNCTION:
+CRYPTO_secure_malloc_initialized 928 1_1_0 EXIST::FUNCTION:
+o2i_SCT_LIST 929 1_1_0 EXIST::FUNCTION:CT
+ASN1_PCTX_get_cert_flags 930 1_1_0 EXIST::FUNCTION:
+X509at_add1_attr_by_NID 931 1_1_0 EXIST::FUNCTION:
+DHparams_dup 932 1_1_0 EXIST::FUNCTION:DH
+X509_get_ext 933 1_1_0 EXIST::FUNCTION:
+X509_issuer_and_serial_hash 934 1_1_0 EXIST::FUNCTION:
+ASN1_BMPSTRING_it 935 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_BMPSTRING_it 935 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+PEM_read_EC_PUBKEY 936 1_1_0 EXIST::FUNCTION:EC,STDIO
+d2i_ASN1_IA5STRING 937 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_ext_free 938 1_1_0 EXIST::FUNCTION:TS
+i2d_X509_CRL_fp 939 1_1_0 EXIST::FUNCTION:STDIO
+PKCS7_get0_signers 940 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_set_ex_data 941 1_1_0 EXIST::FUNCTION:
+TS_VERIFY_CTS_set_certs 942 1_1_0 EXIST::FUNCTION:TS
+BN_MONT_CTX_copy 943 1_1_0 EXIST::FUNCTION:
+OPENSSL_INIT_new 945 1_1_0 EXIST::FUNCTION:
+TS_ACCURACY_dup 946 1_1_0 EXIST::FUNCTION:TS
+i2d_ECPrivateKey 947 1_1_0 EXIST::FUNCTION:EC
+X509_NAME_ENTRY_create_by_OBJ 948 1_1_0 EXIST::FUNCTION:
+TS_VERIFY_CTX_cleanup 949 1_1_0 EXIST::FUNCTION:TS
+ASN1_INTEGER_get 950 1_1_0 EXIST::FUNCTION:
+ASN1_PRINTABLE_it 951 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_PRINTABLE_it 951 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+EVP_VerifyFinal 952 1_1_0 EXIST::FUNCTION:
+TS_ASN1_INTEGER_print_bio 953 1_1_0 EXIST::FUNCTION:TS
+X509_NAME_ENTRY_set_object 954 1_1_0 EXIST::FUNCTION:
+BIO_s_socket 955 1_1_0 EXIST::FUNCTION:SOCK
+EVP_rc5_32_12_16_ecb 956 1_1_0 EXIST::FUNCTION:RC5
+i2d_PKCS8_bio 957 1_1_0 EXIST::FUNCTION:
+v2i_ASN1_BIT_STRING 958 1_1_0 EXIST::FUNCTION:
+PKEY_USAGE_PERIOD_new 959 1_1_0 EXIST::FUNCTION:
+OBJ_NAME_init 960 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_set_keygen 961 1_1_0 EXIST::FUNCTION:
+RSA_PSS_PARAMS_new 962 1_1_0 EXIST::FUNCTION:RSA
+RSA_sign 963 1_1_0 EXIST::FUNCTION:RSA
+EVP_DigestVerifyFinal 964 1_1_0 EXIST::FUNCTION:
+d2i_RSA_PUBKEY_bio 965 1_1_0 EXIST::FUNCTION:RSA
+TS_RESP_dup 966 1_1_0 EXIST::FUNCTION:TS
+ERR_set_error_data 967 1_1_0 EXIST::FUNCTION:
+BN_RECP_CTX_new 968 1_1_0 EXIST::FUNCTION:
+DES_options 969 1_1_0 EXIST::FUNCTION:DES
+IPAddressChoice_it 970 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:RFC3779
+IPAddressChoice_it 970 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:RFC3779
+ASN1_UNIVERSALSTRING_it 971 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_UNIVERSALSTRING_it 971 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+d2i_DSAPublicKey 972 1_1_0 EXIST::FUNCTION:DSA
+ENGINE_get_name 973 1_1_0 EXIST::FUNCTION:ENGINE
+CRYPTO_THREAD_read_lock 974 1_1_0 EXIST::FUNCTION:
+ASIdentifierChoice_free 975 1_1_0 EXIST::FUNCTION:RFC3779
+BIO_dgram_sctp_msg_waiting 976 1_1_0 EXIST::FUNCTION:DGRAM,SCTP
+BN_is_bit_set 978 1_1_0 EXIST::FUNCTION:
+AES_ofb128_encrypt 979 1_1_0 EXIST::FUNCTION:
+X509_STORE_add_lookup 980 1_1_0 EXIST::FUNCTION:
+ASN1_GENERALSTRING_new 981 1_1_0 EXIST::FUNCTION:
+IDEA_options 982 1_1_0 EXIST::FUNCTION:IDEA
+d2i_X509_REQ 983 1_1_0 EXIST::FUNCTION:
+i2d_TS_STATUS_INFO 984 1_1_0 EXIST::FUNCTION:TS
+X509_PURPOSE_get_by_id 985 1_1_0 EXIST::FUNCTION:
+X509_get1_ocsp 986 1_1_0 EXIST::FUNCTION:
+ISSUING_DIST_POINT_free 987 1_1_0 EXIST::FUNCTION:
+ASN1_UTCTIME_free 988 1_1_0 EXIST::FUNCTION:
+ERR_load_TS_strings 989 1_1_0 EXIST::FUNCTION:TS
+BN_nist_mod_func 990 1_1_0 EXIST::FUNCTION:
+OCSP_ONEREQ_new 991 1_1_0 EXIST::FUNCTION:OCSP
+DSA_SIG_new 992 1_1_0 EXIST::FUNCTION:DSA
+DH_get_default_method 993 1_1_0 EXIST::FUNCTION:DH
+PEM_proc_type 994 1_1_0 EXIST::FUNCTION:
+BIO_printf 995 1_1_0 EXIST::FUNCTION:
+a2i_IPADDRESS 996 1_1_0 EXIST::FUNCTION:
+ERR_peek_error_line_data 997 1_1_0 EXIST::FUNCTION:
+ERR_unload_strings 998 1_1_0 EXIST::FUNCTION:
+SEED_cfb128_encrypt 999 1_1_0 EXIST::FUNCTION:SEED
+ASN1_BIT_STRING_it 1000 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_BIT_STRING_it 1000 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+PKCS12_decrypt_skey 1001 1_1_0 EXIST::FUNCTION:
+ENGINE_register_EC 1002 1_1_0 EXIST::FUNCTION:ENGINE
+OCSP_RESPONSE_new 1003 1_1_0 EXIST::FUNCTION:OCSP
+CRYPTO_cbc128_encrypt 1004 1_1_0 EXIST::FUNCTION:
+i2d_RSAPublicKey_bio 1005 1_1_0 EXIST::FUNCTION:RSA
+X509_chain_check_suiteb 1006 1_1_0 EXIST::FUNCTION:
+i2d_OCSP_REQUEST 1007 1_1_0 EXIST::FUNCTION:OCSP
+BN_X931_generate_Xpq 1008 1_1_0 EXIST::FUNCTION:
+ASN1_item_digest 1009 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_set_trust 1010 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_error 1011 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_set_encrypt 1012 1_1_0 EXIST::FUNCTION:
+ASN1_UTCTIME_it 1013 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_UTCTIME_it 1013 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+i2d_DSA_PUBKEY_fp 1014 1_1_0 EXIST::FUNCTION:DSA,STDIO
+X509at_get_attr_by_OBJ 1015 1_1_0 EXIST::FUNCTION:
+EVP_MD_CTX_copy_ex 1016 1_1_0 EXIST::FUNCTION:
+UI_dup_error_string 1017 1_1_0 EXIST::FUNCTION:UI
+OPENSSL_LH_num_items 1018 1_1_0 EXIST::FUNCTION:
+ASN1_INTEGER_cmp 1020 1_1_0 EXIST::FUNCTION:
+X509_NAME_entry_count 1021 1_1_0 EXIST::FUNCTION:
+UI_method_set_closer 1022 1_1_0 EXIST::FUNCTION:UI
+OPENSSL_LH_get_down_load 1023 1_1_0 EXIST::FUNCTION:
+EVP_md4 1024 1_1_0 EXIST::FUNCTION:MD4
+X509_set_subject_name 1025 1_1_0 EXIST::FUNCTION:
+i2d_PKCS8PrivateKey_nid_bio 1026 1_1_0 EXIST::FUNCTION:
+ERR_put_error 1027 1_1_0 EXIST::FUNCTION:
+ERR_add_error_data 1028 1_1_0 EXIST::FUNCTION:
+X509_ALGORS_it 1029 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_ALGORS_it 1029 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+MD5_Update 1030 1_1_0 EXIST::FUNCTION:MD5
+X509_policy_check 1031 1_1_0 EXIST::FUNCTION:
+X509_CRL_METHOD_new 1032 1_1_0 EXIST::FUNCTION:
+ASN1_ANY_it 1033 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_ANY_it 1033 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+d2i_DSA_SIG 1034 1_1_0 EXIST::FUNCTION:DSA
+DH_free 1035 1_1_0 EXIST::FUNCTION:DH
+ENGINE_register_all_DSA 1036 1_1_0 EXIST::FUNCTION:ENGINE
+TS_REQ_set_msg_imprint 1037 1_1_0 EXIST::FUNCTION:TS
+BN_mod_sub_quick 1038 1_1_0 EXIST::FUNCTION:
+SMIME_write_CMS 1039 1_1_0 EXIST::FUNCTION:CMS
+i2d_DSAPublicKey 1040 1_1_0 EXIST::FUNCTION:DSA
+SMIME_text 1042 1_1_0 EXIST::FUNCTION:
+PKCS7_add_recipient_info 1043 1_1_0 EXIST::FUNCTION:
+BN_get_word 1044 1_1_0 EXIST::FUNCTION:
+EVP_CipherFinal 1045 1_1_0 EXIST::FUNCTION:
+i2d_X509_bio 1046 1_1_0 EXIST::FUNCTION:
+X509_EXTENSION_new 1047 1_1_0 EXIST::FUNCTION:
+X509_getm_notAfter 1048 1_1_0 EXIST::FUNCTION:
+X509_ALGOR_dup 1049 1_1_0 EXIST::FUNCTION:
+d2i_X509_REQ_INFO 1050 1_1_0 EXIST::FUNCTION:
+d2i_EC_PUBKEY_bio 1051 1_1_0 EXIST::FUNCTION:EC
+X509_STORE_CTX_set_error 1052 1_1_0 EXIST::FUNCTION:
+EC_KEY_METHOD_set_keygen 1053 1_1_0 EXIST::FUNCTION:EC
+CRYPTO_free 1054 1_1_0 EXIST::FUNCTION:
+BN_GF2m_mod_exp 1055 1_1_0 EXIST::FUNCTION:EC2M
+OPENSSL_buf2hexstr 1056 1_1_0 EXIST::FUNCTION:
+DES_encrypt2 1057 1_1_0 EXIST::FUNCTION:DES
+DH_up_ref 1058 1_1_0 EXIST::FUNCTION:DH
+RC2_ofb64_encrypt 1059 1_1_0 EXIST::FUNCTION:RC2
+PKCS12_pbe_crypt 1060 1_1_0 EXIST::FUNCTION:
+ASIdentifiers_free 1061 1_1_0 EXIST::FUNCTION:RFC3779
+X509_VERIFY_PARAM_get0 1062 1_1_0 EXIST::FUNCTION:
+EVP_MD_meth_get_input_blocksize 1063 1_1_0 EXIST::FUNCTION:
+TS_ACCURACY_get_micros 1064 1_1_0 EXIST::FUNCTION:TS
+PKCS12_SAFEBAG_create_cert 1065 1_1_0 EXIST::FUNCTION:
+CRYPTO_mem_debug_malloc 1066 1_1_0 EXIST::FUNCTION:CRYPTO_MDEBUG
+RAND_seed 1067 1_1_0 EXIST::FUNCTION:
+NETSCAPE_SPKAC_free 1068 1_1_0 EXIST::FUNCTION:
+X509_CRL_diff 1069 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_set_flags 1070 1_1_0 EXIST::FUNCTION:
+X509_EXTENSION_set_data 1071 1_1_0 EXIST::FUNCTION:
+ENGINE_get_EC 1072 1_1_0 EXIST::FUNCTION:ENGINE
+ASN1_STRING_copy 1073 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_encrypt_old 1074 1_1_0 EXIST::FUNCTION:
+OPENSSL_LH_free 1075 1_1_0 EXIST::FUNCTION:
+DES_is_weak_key 1076 1_1_0 EXIST::FUNCTION:DES
+EVP_PKEY_verify 1077 1_1_0 EXIST::FUNCTION:
+ERR_load_BIO_strings 1078 1_1_0 EXIST::FUNCTION:
+BIO_nread 1079 1_1_0 EXIST::FUNCTION:
+PEM_read_bio_RSAPrivateKey 1080 1_1_0 EXIST::FUNCTION:RSA
+OBJ_nid2obj 1081 1_1_0 EXIST::FUNCTION:
+CRYPTO_ofb128_encrypt 1082 1_1_0 EXIST::FUNCTION:
+ENGINE_set_init_function 1083 1_1_0 EXIST::FUNCTION:ENGINE
+NCONF_default 1084 1_1_0 EXIST::FUNCTION:
+ENGINE_remove 1085 1_1_0 EXIST::FUNCTION:ENGINE
+ASYNC_get_current_job 1086 1_1_0 EXIST::FUNCTION:
+OBJ_nid2sn 1087 1_1_0 EXIST::FUNCTION:
+X509_gmtime_adj 1088 1_1_0 EXIST::FUNCTION:
+X509_add_ext 1089 1_1_0 EXIST::FUNCTION:
+ENGINE_set_DSA 1090 1_1_0 EXIST::FUNCTION:ENGINE
+EC_KEY_METHOD_set_sign 1091 1_1_0 EXIST::FUNCTION:EC
+d2i_TS_MSG_IMPRINT 1092 1_1_0 EXIST::FUNCTION:TS
+X509_print_ex_fp 1093 1_1_0 EXIST::FUNCTION:STDIO
+ERR_load_PEM_strings 1094 1_1_0 EXIST::FUNCTION:
+ENGINE_unregister_pkey_asn1_meths 1095 1_1_0 EXIST::FUNCTION:ENGINE
+IPAddressFamily_free 1096 1_1_0 EXIST::FUNCTION:RFC3779
+UI_method_get_prompt_constructor 1097 1_1_0 EXIST::FUNCTION:UI
+ASN1_NULL_it 1098 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_NULL_it 1098 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+X509_REQ_get_pubkey 1099 1_1_0 EXIST::FUNCTION:
+X509_CRL_set1_nextUpdate 1100 1_1_0 EXIST::FUNCTION:
+EVP_des_ede3_cfb64 1101 1_1_0 EXIST::FUNCTION:DES
+BN_to_ASN1_INTEGER 1102 1_1_0 EXIST::FUNCTION:
+EXTENDED_KEY_USAGE_free 1103 1_1_0 EXIST::FUNCTION:
+PEM_read_bio_EC_PUBKEY 1104 1_1_0 EXIST::FUNCTION:EC
+BN_MONT_CTX_set 1105 1_1_0 EXIST::FUNCTION:
+TS_CONF_set_serial 1106 1_1_0 EXIST::FUNCTION:TS
+X509_NAME_ENTRY_new 1107 1_1_0 EXIST::FUNCTION:
+RSA_security_bits 1108 1_1_0 EXIST::FUNCTION:RSA
+X509v3_addr_add_prefix 1109 1_1_0 EXIST::FUNCTION:RFC3779
+X509_REQ_print_fp 1110 1_1_0 EXIST::FUNCTION:STDIO
+ASN1_item_ex_new 1111 1_1_0 EXIST::FUNCTION:
+BIO_s_datagram 1112 1_1_0 EXIST::FUNCTION:DGRAM
+PEM_write_bio_PKCS8 1113 1_1_0 EXIST::FUNCTION:
+ASN1_str2mask 1114 1_1_0 EXIST::FUNCTION:
+ASN1_TYPE_get 1115 1_1_0 EXIST::FUNCTION:
+i2d_X509_EXTENSIONS 1116 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get0_store 1117 1_1_0 EXIST::FUNCTION:
+PKCS12_pack_p7data 1118 1_1_0 EXIST::FUNCTION:
+RSA_print_fp 1119 1_1_0 EXIST::FUNCTION:RSA,STDIO
+OPENSSL_INIT_set_config_appname 1120 1_1_0 EXIST::FUNCTION:STDIO
+EC_KEY_print_fp 1121 1_1_0 EXIST::FUNCTION:EC,STDIO
+BIO_dup_chain 1122 1_1_0 EXIST::FUNCTION:
+PKCS8_PRIV_KEY_INFO_it 1123 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS8_PRIV_KEY_INFO_it 1123 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+RSA_OAEP_PARAMS_free 1124 1_1_0 EXIST::FUNCTION:RSA
+ASN1_item_new 1125 1_1_0 EXIST::FUNCTION:
+CRYPTO_cts128_encrypt 1126 1_1_0 EXIST::FUNCTION:
+RC2_encrypt 1127 1_1_0 EXIST::FUNCTION:RC2
+PEM_write 1128 1_1_0 EXIST::FUNCTION:STDIO
+EVP_CIPHER_meth_get_get_asn1_params 1129 1_1_0 EXIST::FUNCTION:
+i2d_OCSP_RESPBYTES 1130 1_1_0 EXIST::FUNCTION:OCSP
+d2i_ASN1_UTF8STRING 1131 1_1_0 EXIST::FUNCTION:
+EXTENDED_KEY_USAGE_it 1132 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+EXTENDED_KEY_USAGE_it 1132 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+EVP_CipherInit 1133 1_1_0 EXIST::FUNCTION:
+PKCS12_add_safe 1134 1_1_0 EXIST::FUNCTION:
+ENGINE_get_digest 1135 1_1_0 EXIST::FUNCTION:ENGINE
+EC_GROUP_have_precompute_mult 1136 1_1_0 EXIST::FUNCTION:EC
+OPENSSL_gmtime 1137 1_1_0 EXIST::FUNCTION:
+X509_set_issuer_name 1138 1_1_0 EXIST::FUNCTION:
+RSA_new 1139 1_1_0 EXIST::FUNCTION:RSA
+ASN1_STRING_set_by_NID 1140 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_PKCS7 1141 1_1_0 EXIST::FUNCTION:
+MDC2_Final 1142 1_1_0 EXIST::FUNCTION:MDC2
+SMIME_crlf_copy 1143 1_1_0 EXIST::FUNCTION:
+OCSP_REQUEST_get_ext_count 1144 1_1_0 EXIST::FUNCTION:OCSP
+OCSP_REQ_CTX_new 1145 1_1_0 EXIST::FUNCTION:OCSP
+X509_load_cert_crl_file 1146 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_new_mac_key 1147 1_1_0 EXIST::FUNCTION:
+DIST_POINT_new 1148 1_1_0 EXIST::FUNCTION:
+BN_is_prime_fasttest 1149 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_0_9_8
+EC_POINT_dup 1150 1_1_0 EXIST::FUNCTION:EC
+PKCS5_v2_scrypt_keyivgen 1151 1_1_0 EXIST::FUNCTION:SCRYPT
+X509_STORE_CTX_set0_param 1152 1_1_0 EXIST::FUNCTION:
+DES_check_key_parity 1153 1_1_0 EXIST::FUNCTION:DES
+EVP_aes_256_ocb 1154 1_1_0 EXIST::FUNCTION:OCB
+X509_VAL_free 1155 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get1_certs 1156 1_1_0 EXIST::FUNCTION:
+PEM_write_RSA_PUBKEY 1157 1_1_0 EXIST::FUNCTION:RSA,STDIO
+PKCS12_SAFEBAG_get0_p8inf 1158 1_1_0 EXIST::FUNCTION:
+X509_CRL_set_issuer_name 1159 1_1_0 EXIST::FUNCTION:
+CMS_EncryptedData_encrypt 1160 1_1_0 EXIST::FUNCTION:CMS
+ASN1_tag2str 1161 1_1_0 EXIST::FUNCTION:
+BN_zero_ex 1162 1_1_0 EXIST::FUNCTION:
+X509_NAME_dup 1163 1_1_0 EXIST::FUNCTION:
+SCT_LIST_print 1164 1_1_0 EXIST::FUNCTION:CT
+NOTICEREF_it 1165 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+NOTICEREF_it 1165 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+CMS_add0_crl 1166 1_1_0 EXIST::FUNCTION:CMS
+d2i_DSAparams 1167 1_1_0 EXIST::FUNCTION:DSA
+EVP_CIPHER_CTX_set_app_data 1168 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_param_to_asn1 1169 1_1_0 EXIST::FUNCTION:
+TS_CONF_set_certs 1170 1_1_0 EXIST::FUNCTION:TS
+BN_security_bits 1171 1_1_0 EXIST::FUNCTION:
+X509_PURPOSE_get0_name 1172 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_get_serial 1173 1_1_0 EXIST::FUNCTION:TS
+ASN1_PCTX_get_str_flags 1174 1_1_0 EXIST::FUNCTION:
+SHA256 1175 1_1_0 EXIST::FUNCTION:
+X509_LOOKUP_hash_dir 1176 1_1_0 EXIST::FUNCTION:
+ASN1_BIT_STRING_check 1177 1_1_0 EXIST::FUNCTION:
+ENGINE_set_default_RAND 1178 1_1_0 EXIST::FUNCTION:ENGINE
+BIO_connect 1179 1_1_0 EXIST::FUNCTION:SOCK
+TS_TST_INFO_add_ext 1180 1_1_0 EXIST::FUNCTION:TS
+EVP_aes_192_ccm 1181 1_1_0 EXIST::FUNCTION:
+X509V3_add_value 1182 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_CTX_set0_keygen_info 1183 1_1_0 EXIST::FUNCTION:
+ENGINE_unregister_digests 1184 1_1_0 EXIST::FUNCTION:ENGINE
+IPAddressOrRange_new 1185 1_1_0 EXIST::FUNCTION:RFC3779
+EVP_aes_256_ofb 1186 1_1_0 EXIST::FUNCTION:
+CRYPTO_mem_debug_push 1187 1_1_0 EXIST::FUNCTION:CRYPTO_MDEBUG
+X509_PKEY_new 1188 1_1_0 EXIST::FUNCTION:
+X509_get_key_usage 1189 1_1_0 EXIST::FUNCTION:
+X509_ATTRIBUTE_create_by_txt 1190 1_1_0 EXIST::FUNCTION:
+PEM_SignFinal 1191 1_1_0 EXIST::FUNCTION:
+PEM_bytes_read_bio 1192 1_1_0 EXIST::FUNCTION:
+X509_signature_dump 1193 1_1_0 EXIST::FUNCTION:
+TS_RESP_CTX_set_def_policy 1194 1_1_0 EXIST::FUNCTION:TS
+RAND_pseudo_bytes 1195 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0
+DES_ofb_encrypt 1196 1_1_0 EXIST::FUNCTION:DES
+EVP_add_digest 1197 1_1_0 EXIST::FUNCTION:
+ASN1_item_sign_ctx 1198 1_1_0 EXIST::FUNCTION:
+BIO_dump_indent_cb 1199 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_set_depth 1200 1_1_0 EXIST::FUNCTION:
+DES_ecb3_encrypt 1201 1_1_0 EXIST::FUNCTION:DES
+OBJ_obj2nid 1202 1_1_0 EXIST::FUNCTION:
+PKCS12_SAFEBAG_free 1203 1_1_0 EXIST::FUNCTION:
+EVP_cast5_cfb64 1204 1_1_0 EXIST::FUNCTION:CAST
+OPENSSL_uni2asc 1205 1_1_0 EXIST::FUNCTION:
+SCT_validation_status_string 1206 1_1_0 EXIST::FUNCTION:CT
+PKCS7_add_attribute 1207 1_1_0 EXIST::FUNCTION:
+ENGINE_register_DSA 1208 1_1_0 EXIST::FUNCTION:ENGINE
+OPENSSL_LH_node_stats 1209 1_1_0 EXIST::FUNCTION:STDIO
+X509_policy_tree_free 1210 1_1_0 EXIST::FUNCTION:
+EC_GFp_simple_method 1211 1_1_0 EXIST::FUNCTION:EC
+X509_it 1212 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_it 1212 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+d2i_PROXY_POLICY 1213 1_1_0 EXIST::FUNCTION:
+MDC2_Update 1214 1_1_0 EXIST::FUNCTION:MDC2
+EC_KEY_new_by_curve_name 1215 1_1_0 EXIST::FUNCTION:EC
+X509_CRL_free 1216 1_1_0 EXIST::FUNCTION:
+i2d_PKCS7_SIGN_ENVELOPE 1217 1_1_0 EXIST::FUNCTION:
+OCSP_CERTSTATUS_it 1218 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:OCSP
+OCSP_CERTSTATUS_it 1218 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:OCSP
+BIO_f_reliable 1219 1_1_0 EXIST::FUNCTION:
+OCSP_resp_count 1220 1_1_0 EXIST::FUNCTION:OCSP
+i2d_X509_AUX 1221 1_1_0 EXIST::FUNCTION:
+RSA_verify_PKCS1_PSS_mgf1 1222 1_1_0 EXIST::FUNCTION:RSA
+X509_time_adj 1223 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_asn1_find_str 1224 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_get_flags 1225 1_1_0 EXIST::FUNCTION:
+OPENSSL_DIR_end 1226 1_1_0 EXIST::FUNCTION:
+EC_GROUP_new 1227 1_1_0 EXIST::FUNCTION:EC
+CMS_SignerInfo_get0_pkey_ctx 1228 1_1_0 EXIST::FUNCTION:CMS
+d2i_ASN1_PRINTABLESTRING 1229 1_1_0 EXIST::FUNCTION:
+CMS_RecipientInfo_ktri_cert_cmp 1230 1_1_0 EXIST::FUNCTION:CMS
+CMS_decrypt_set1_pkey 1231 1_1_0 EXIST::FUNCTION:CMS
+PKCS7_RECIP_INFO_set 1232 1_1_0 EXIST::FUNCTION:
+EC_POINT_is_on_curve 1233 1_1_0 EXIST::FUNCTION:EC
+PKCS12_add_cert 1234 1_1_0 EXIST::FUNCTION:
+X509_NAME_hash_old 1235 1_1_0 EXIST::FUNCTION:
+PBKDF2PARAM_free 1236 1_1_0 EXIST::FUNCTION:
+i2d_CMS_ContentInfo 1237 1_1_0 EXIST::FUNCTION:CMS
+EVP_CIPHER_meth_set_ctrl 1238 1_1_0 EXIST::FUNCTION:
+RSA_public_decrypt 1239 1_1_0 EXIST::FUNCTION:RSA
+ENGINE_get_id 1240 1_1_0 EXIST::FUNCTION:ENGINE
+PKCS12_item_decrypt_d2i 1241 1_1_0 EXIST::FUNCTION:
+PEM_read_bio_DSAparams 1242 1_1_0 EXIST::FUNCTION:DSA
+X509_CRL_cmp 1243 1_1_0 EXIST::FUNCTION:
+DSO_METHOD_openssl 1244 1_1_0 EXIST::FUNCTION:
+d2i_PrivateKey_fp 1245 1_1_0 EXIST::FUNCTION:STDIO
+i2d_NETSCAPE_CERT_SEQUENCE 1246 1_1_0 EXIST::FUNCTION:
+EC_POINT_oct2point 1248 1_1_0 EXIST::FUNCTION:EC
+EVP_CIPHER_CTX_buf_noconst 1249 1_1_0 EXIST::FUNCTION:
+OPENSSL_DIR_read 1250 1_1_0 EXIST::FUNCTION:
+CMS_add_smimecap 1251 1_1_0 EXIST::FUNCTION:CMS
+X509_check_email 1252 1_1_0 EXIST::FUNCTION:
+CRYPTO_cts128_decrypt_block 1253 1_1_0 EXIST::FUNCTION:
+UI_method_get_opener 1254 1_1_0 EXIST::FUNCTION:UI
+EVP_aes_192_gcm 1255 1_1_0 EXIST::FUNCTION:
+TS_CONF_set_tsa_name 1256 1_1_0 EXIST::FUNCTION:TS
+X509_email_free 1257 1_1_0 EXIST::FUNCTION:
+BIO_get_callback 1258 1_1_0 EXIST::FUNCTION:
+OPENSSL_sk_shift 1259 1_1_0 EXIST::FUNCTION:
+i2d_X509_REVOKED 1260 1_1_0 EXIST::FUNCTION:
+CMS_sign 1261 1_1_0 EXIST::FUNCTION:CMS
+X509_STORE_add_cert 1262 1_1_0 EXIST::FUNCTION:
+EC_GROUP_precompute_mult 1263 1_1_0 EXIST::FUNCTION:EC
+d2i_DISPLAYTEXT 1265 1_1_0 EXIST::FUNCTION:
+HMAC_CTX_copy 1266 1_1_0 EXIST::FUNCTION:
+CRYPTO_gcm128_init 1267 1_1_0 EXIST::FUNCTION:
+i2d_X509_CINF 1268 1_1_0 EXIST::FUNCTION:
+X509_REVOKED_delete_ext 1269 1_1_0 EXIST::FUNCTION:
+RC5_32_cfb64_encrypt 1270 1_1_0 EXIST::FUNCTION:RC5
+TS_REQ_set_cert_req 1271 1_1_0 EXIST::FUNCTION:TS
+TXT_DB_get_by_index 1272 1_1_0 EXIST::FUNCTION:
+X509_check_ca 1273 1_1_0 EXIST::FUNCTION:
+DH_get_2048_224 1274 1_1_0 EXIST::FUNCTION:DH
+X509_http_nbio 1275 1_1_0 EXIST::FUNCTION:OCSP
+i2d_AUTHORITY_INFO_ACCESS 1276 1_1_0 EXIST::FUNCTION:
+EVP_get_cipherbyname 1277 1_1_0 EXIST::FUNCTION:
+CONF_dump_fp 1278 1_1_0 EXIST::FUNCTION:STDIO
+d2i_DIST_POINT_NAME 1279 1_1_0 EXIST::FUNCTION:
+ASN1_INTEGER_set_int64 1280 1_1_0 EXIST::FUNCTION:
+ASN1_TIME_free 1281 1_1_0 EXIST::FUNCTION:
+i2o_SCT_LIST 1282 1_1_0 EXIST::FUNCTION:CT
+AES_encrypt 1283 1_1_0 EXIST::FUNCTION:
+MD5_Init 1284 1_1_0 EXIST::FUNCTION:MD5
+UI_add_error_string 1285 1_1_0 EXIST::FUNCTION:UI
+X509_TRUST_cleanup 1286 1_1_0 EXIST::FUNCTION:
+PEM_read_X509 1287 1_1_0 EXIST::FUNCTION:STDIO
+EC_KEY_new_method 1288 1_1_0 EXIST::FUNCTION:EC
+i2d_RSAPublicKey_fp 1289 1_1_0 EXIST::FUNCTION:RSA,STDIO
+CRYPTO_ctr128_encrypt_ctr32 1290 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_move_peername 1291 1_1_0 EXIST::FUNCTION:
+OCSP_SINGLERESP_it 1292 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:OCSP
+OCSP_SINGLERESP_it 1292 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:OCSP
+BN_num_bits 1293 1_1_0 EXIST::FUNCTION:
+X509_CRL_METHOD_free 1294 1_1_0 EXIST::FUNCTION:
+PEM_read_NETSCAPE_CERT_SEQUENCE 1295 1_1_0 EXIST::FUNCTION:STDIO
+OPENSSL_load_builtin_modules 1296 1_1_0 EXIST::FUNCTION:
+X509_set_version 1297 1_1_0 EXIST::FUNCTION:
+i2d_EC_PUBKEY_bio 1298 1_1_0 EXIST::FUNCTION:EC
+X509_REQ_get_attr_count 1299 1_1_0 EXIST::FUNCTION:
+CMS_set1_signers_certs 1300 1_1_0 EXIST::FUNCTION:CMS
+TS_ACCURACY_free 1301 1_1_0 EXIST::FUNCTION:TS
+PEM_write_DSA_PUBKEY 1302 1_1_0 EXIST::FUNCTION:DSA,STDIO
+BN_rshift1 1303 1_1_0 EXIST::FUNCTION:
+i2d_PKCS7_ENVELOPE 1304 1_1_0 EXIST::FUNCTION:
+PBKDF2PARAM_it 1305 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PBKDF2PARAM_it 1305 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+UI_get_result_maxsize 1306 1_1_0 EXIST::FUNCTION:UI
+PBEPARAM_it 1307 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PBEPARAM_it 1307 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+TS_ACCURACY_set_seconds 1308 1_1_0 EXIST::FUNCTION:TS
+UI_get0_action_string 1309 1_1_0 EXIST::FUNCTION:UI
+RC2_decrypt 1310 1_1_0 EXIST::FUNCTION:RC2
+OPENSSL_atexit 1311 1_1_0 EXIST::FUNCTION:
+CMS_add_standard_smimecap 1312 1_1_0 EXIST::FUNCTION:CMS
+PKCS7_add_attrib_content_type 1313 1_1_0 EXIST::FUNCTION:
+BN_BLINDING_set_flags 1314 1_1_0 EXIST::FUNCTION:
+ERR_peek_last_error 1315 1_1_0 EXIST::FUNCTION:
+ENGINE_set_cmd_defns 1316 1_1_0 EXIST::FUNCTION:ENGINE
+d2i_ASN1_NULL 1317 1_1_0 EXIST::FUNCTION:
+RAND_event 1318 1_1_0 EXIST:_WIN32:FUNCTION:DEPRECATEDIN_1_1_0
+i2d_PKCS12_fp 1319 1_1_0 EXIST::FUNCTION:STDIO
+EVP_PKEY_meth_get_init 1320 1_1_0 EXIST::FUNCTION:
+X509_check_trust 1321 1_1_0 EXIST::FUNCTION:
+b2i_PrivateKey 1322 1_1_0 EXIST::FUNCTION:DSA
+HMAC_Init_ex 1323 1_1_0 EXIST::FUNCTION:
+SMIME_read_CMS 1324 1_1_0 EXIST::FUNCTION:CMS
+X509_subject_name_cmp 1325 1_1_0 EXIST::FUNCTION:
+CRYPTO_ocb128_finish 1326 1_1_0 EXIST::FUNCTION:OCB
+EVP_CIPHER_do_all 1327 1_1_0 EXIST::FUNCTION:
+POLICY_MAPPINGS_it 1328 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+POLICY_MAPPINGS_it 1328 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+SCT_set0_log_id 1329 1_1_0 EXIST::FUNCTION:CT
+CRYPTO_cfb128_encrypt 1330 1_1_0 EXIST::FUNCTION:
+RSA_padding_add_PKCS1_type_2 1331 1_1_0 EXIST::FUNCTION:RSA
+TS_CONF_set_signer_cert 1332 1_1_0 EXIST::FUNCTION:TS
+i2d_ASN1_OBJECT 1333 1_1_0 EXIST::FUNCTION:
+d2i_PKCS8_PRIV_KEY_INFO_bio 1334 1_1_0 EXIST::FUNCTION:
+X509V3_add_value_int 1335 1_1_0 EXIST::FUNCTION:
+TS_REQ_set_nonce 1336 1_1_0 EXIST::FUNCTION:TS
+Camellia_ctr128_encrypt 1337 1_1_0 EXIST::FUNCTION:CAMELLIA
+X509_LOOKUP_new 1338 1_1_0 EXIST::FUNCTION:
+AUTHORITY_INFO_ACCESS_new 1339 1_1_0 EXIST::FUNCTION:
+CRYPTO_mem_leaks_fp 1340 1_1_0 EXIST::FUNCTION:CRYPTO_MDEBUG,STDIO
+DES_set_key_unchecked 1341 1_1_0 EXIST::FUNCTION:DES
+BN_free 1342 1_1_0 EXIST::FUNCTION:
+EVP_aes_128_cfb1 1343 1_1_0 EXIST::FUNCTION:
+EC_KEY_get0_group 1344 1_1_0 EXIST::FUNCTION:EC
+PEM_write_bio_CMS_stream 1345 1_1_0 EXIST::FUNCTION:CMS
+BIO_f_linebuffer 1346 1_1_0 EXIST::FUNCTION:
+ASN1_item_d2i_bio 1347 1_1_0 EXIST::FUNCTION:
+ENGINE_get_flags 1348 1_1_0 EXIST::FUNCTION:ENGINE
+OCSP_resp_find 1349 1_1_0 EXIST::FUNCTION:OCSP
+OPENSSL_LH_node_usage_stats_bio 1350 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_encrypt 1351 1_1_0 EXIST::FUNCTION:
+CRYPTO_cfb128_8_encrypt 1352 1_1_0 EXIST::FUNCTION:
+SXNET_get_id_INTEGER 1353 1_1_0 EXIST::FUNCTION:
+CRYPTO_clear_free 1354 1_1_0 EXIST::FUNCTION:
+i2v_GENERAL_NAME 1355 1_1_0 EXIST::FUNCTION:
+PKCS7_ENC_CONTENT_new 1356 1_1_0 EXIST::FUNCTION:
+CRYPTO_realloc 1357 1_1_0 EXIST::FUNCTION:
+BIO_ctrl_pending 1358 1_1_0 EXIST::FUNCTION:
+EVP_MD_meth_new 1360 1_1_0 EXIST::FUNCTION:
+X509_sign_ctx 1361 1_1_0 EXIST::FUNCTION:
+BN_is_odd 1362 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_current_cert 1363 1_1_0 EXIST::FUNCTION:
+ASN1_ENUMERATED_get_int64 1364 1_1_0 EXIST::FUNCTION:
+ASN1_SCTX_get_app_data 1365 1_1_0 EXIST::FUNCTION:
+X509_get_default_cert_file_env 1366 1_1_0 EXIST::FUNCTION:
+X509v3_addr_validate_resource_set 1367 1_1_0 EXIST::FUNCTION:RFC3779
+d2i_X509_VAL 1368 1_1_0 EXIST::FUNCTION:
+CRYPTO_gcm128_decrypt_ctr32 1370 1_1_0 EXIST::FUNCTION:
+DHparams_print 1371 1_1_0 EXIST::FUNCTION:DH
+OPENSSL_sk_unshift 1372 1_1_0 EXIST::FUNCTION:
+BN_GENCB_set_old 1373 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_X509 1374 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_asn1_free 1375 1_1_0 EXIST::FUNCTION:
+ENGINE_unregister_DH 1376 1_1_0 EXIST::FUNCTION:ENGINE
+PROXY_CERT_INFO_EXTENSION_it 1377 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PROXY_CERT_INFO_EXTENSION_it 1377 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+CT_POLICY_EVAL_CTX_set1_cert 1378 1_1_0 EXIST::FUNCTION:CT
+X509_NAME_hash 1379 1_1_0 EXIST::FUNCTION:
+SCT_set_timestamp 1380 1_1_0 EXIST::FUNCTION:CT
+UI_new 1381 1_1_0 EXIST::FUNCTION:UI
+TS_REQ_get_msg_imprint 1382 1_1_0 EXIST::FUNCTION:TS
+i2d_PKCS12_BAGS 1383 1_1_0 EXIST::FUNCTION:
+CERTIFICATEPOLICIES_free 1385 1_1_0 EXIST::FUNCTION:
+X509V3_get_section 1386 1_1_0 EXIST::FUNCTION:
+BIO_parse_hostserv 1387 1_1_0 EXIST::FUNCTION:SOCK
+EVP_PKEY_meth_set_cleanup 1388 1_1_0 EXIST::FUNCTION:
+PROXY_CERT_INFO_EXTENSION_free 1389 1_1_0 EXIST::FUNCTION:
+X509_dup 1390 1_1_0 EXIST::FUNCTION:
+EDIPARTYNAME_free 1391 1_1_0 EXIST::FUNCTION:
+X509_CRL_add0_revoked 1393 1_1_0 EXIST::FUNCTION:
+GENERAL_NAME_set0_value 1394 1_1_0 EXIST::FUNCTION:
+X509_ATTRIBUTE_dup 1395 1_1_0 EXIST::FUNCTION:
+EC_GROUP_check_discriminant 1396 1_1_0 EXIST::FUNCTION:EC
+PKCS12_MAC_DATA_free 1397 1_1_0 EXIST::FUNCTION:
+PEM_read_bio_PrivateKey 1398 1_1_0 EXIST::FUNCTION:
+d2i_PKCS7_ENCRYPT 1399 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_CTX_ctrl 1400 1_1_0 EXIST::FUNCTION:
+X509_REQ_set_pubkey 1401 1_1_0 EXIST::FUNCTION:
+UI_create_method 1402 1_1_0 EXIST::FUNCTION:UI
+X509_REQ_add_extensions_nid 1403 1_1_0 EXIST::FUNCTION:
+PEM_X509_INFO_write_bio 1404 1_1_0 EXIST::FUNCTION:
+BIO_dump_cb 1405 1_1_0 EXIST::FUNCTION:
+v2i_GENERAL_NAMES 1406 1_1_0 EXIST::FUNCTION:
+EVP_des_ede3_ofb 1407 1_1_0 EXIST::FUNCTION:DES
+EVP_MD_meth_get_cleanup 1408 1_1_0 EXIST::FUNCTION:
+SRP_Calc_server_key 1409 1_1_0 EXIST::FUNCTION:SRP
+BN_mod_exp_simple 1410 1_1_0 EXIST::FUNCTION:
+BIO_set_ex_data 1411 1_1_0 EXIST::FUNCTION:
+SHA512 1412 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_explicit_policy 1413 1_1_0 EXIST::FUNCTION:
+EVP_DecodeBlock 1414 1_1_0 EXIST::FUNCTION:
+OCSP_REQ_CTX_http 1415 1_1_0 EXIST::FUNCTION:OCSP
+EVP_MD_CTX_reset 1416 1_1_0 EXIST::FUNCTION:
+X509_NAME_new 1417 1_1_0 EXIST::FUNCTION:
+ASN1_item_pack 1418 1_1_0 EXIST::FUNCTION:
+ASN1_BIT_STRING_set_asc 1419 1_1_0 EXIST::FUNCTION:
+d2i_GENERAL_NAME 1420 1_1_0 EXIST::FUNCTION:
+i2d_ESS_CERT_ID 1421 1_1_0 EXIST::FUNCTION:TS
+X509_TRUST_get_by_id 1422 1_1_0 EXIST::FUNCTION:
+d2i_RSA_PUBKEY_fp 1423 1_1_0 EXIST::FUNCTION:RSA,STDIO
+EVP_PBE_get 1424 1_1_0 EXIST::FUNCTION:
+CRYPTO_nistcts128_encrypt 1425 1_1_0 EXIST::FUNCTION:
+CONF_modules_finish 1426 1_1_0 EXIST::FUNCTION:
+BN_value_one 1427 1_1_0 EXIST::FUNCTION:
+RSA_padding_add_SSLv23 1428 1_1_0 EXIST::FUNCTION:RSA
+OCSP_RESPBYTES_it 1429 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:OCSP
+OCSP_RESPBYTES_it 1429 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:OCSP
+EVP_aes_192_wrap 1430 1_1_0 EXIST::FUNCTION:
+OCSP_CERTID_it 1431 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:OCSP
+OCSP_CERTID_it 1431 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:OCSP
+ENGINE_get_RSA 1432 1_1_0 EXIST::FUNCTION:ENGINE
+RAND_get_rand_method 1433 1_1_0 EXIST::FUNCTION:
+ERR_load_DSA_strings 1434 1_1_0 EXIST::FUNCTION:DSA
+ASN1_check_infinite_end 1435 1_1_0 EXIST::FUNCTION:
+i2d_PKCS7_DIGEST 1436 1_1_0 EXIST::FUNCTION:
+ERR_lib_error_string 1437 1_1_0 EXIST::FUNCTION:
+X509_ATTRIBUTE_set1_object 1438 1_1_0 EXIST::FUNCTION:
+i2d_ECPrivateKey_bio 1439 1_1_0 EXIST::FUNCTION:EC
+BN_GENCB_free 1440 1_1_0 EXIST::FUNCTION:
+HMAC_size 1441 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_get0_DH 1442 1_1_0 EXIST::FUNCTION:DH
+d2i_OCSP_CRLID 1443 1_1_0 EXIST::FUNCTION:OCSP
+EVP_CIPHER_CTX_set_padding 1444 1_1_0 EXIST::FUNCTION:
+CTLOG_new_from_base64 1445 1_1_0 EXIST::FUNCTION:CT
+AES_bi_ige_encrypt 1446 1_1_0 EXIST::FUNCTION:
+ERR_pop_to_mark 1447 1_1_0 EXIST::FUNCTION:
+CRL_DIST_POINTS_new 1449 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_get0_asn1 1450 1_1_0 EXIST::FUNCTION:
+EVP_camellia_192_ctr 1451 1_1_0 EXIST::FUNCTION:CAMELLIA
+EVP_PKEY_free 1452 1_1_0 EXIST::FUNCTION:
+X509_ATTRIBUTE_count 1453 1_1_0 EXIST::FUNCTION:
+BIO_new_dgram 1454 1_1_0 EXIST::FUNCTION:DGRAM
+CMS_RecipientInfo_kari_get0_reks 1455 1_1_0 EXIST::FUNCTION:CMS
+BASIC_CONSTRAINTS_new 1456 1_1_0 EXIST::FUNCTION:
+PEM_read_bio_X509_REQ 1457 1_1_0 EXIST::FUNCTION:
+BIO_sock_init 1458 1_1_0 EXIST::FUNCTION:SOCK
+BN_nist_mod_192 1459 1_1_0 EXIST::FUNCTION:
+i2d_PKCS7_ISSUER_AND_SERIAL 1460 1_1_0 EXIST::FUNCTION:
+X509V3_EXT_nconf 1461 1_1_0 EXIST::FUNCTION:
+X509v3_addr_inherits 1462 1_1_0 EXIST::FUNCTION:RFC3779
+NETSCAPE_SPKI_sign 1463 1_1_0 EXIST::FUNCTION:
+BN_BLINDING_update 1464 1_1_0 EXIST::FUNCTION:
+BN_gcd 1465 1_1_0 EXIST::FUNCTION:
+CMS_dataInit 1466 1_1_0 EXIST::FUNCTION:CMS
+TS_CONF_get_tsa_section 1467 1_1_0 EXIST::FUNCTION:TS
+i2d_PKCS7_SIGNER_INFO 1468 1_1_0 EXIST::FUNCTION:
+EVP_get_pw_prompt 1469 1_1_0 EXIST::FUNCTION:UI
+BN_bn2bin 1470 1_1_0 EXIST::FUNCTION:
+d2i_ASN1_BIT_STRING 1471 1_1_0 EXIST::FUNCTION:
+OCSP_CERTSTATUS_new 1472 1_1_0 EXIST::FUNCTION:OCSP
+ENGINE_register_RAND 1473 1_1_0 EXIST::FUNCTION:ENGINE
+X509V3_section_free 1474 1_1_0 EXIST::FUNCTION:
+CRYPTO_mem_debug_free 1475 1_1_0 EXIST::FUNCTION:CRYPTO_MDEBUG
+d2i_OCSP_REQUEST 1476 1_1_0 EXIST::FUNCTION:OCSP
+ENGINE_get_cipher_engine 1477 1_1_0 EXIST::FUNCTION:ENGINE
+SHA384_Final 1478 1_1_0 EXIST::FUNCTION:
+TS_RESP_CTX_set_certs 1479 1_1_0 EXIST::FUNCTION:TS
+BN_MONT_CTX_free 1480 1_1_0 EXIST::FUNCTION:
+BN_GF2m_mod_solve_quad_arr 1481 1_1_0 EXIST::FUNCTION:EC2M
+UI_add_input_string 1482 1_1_0 EXIST::FUNCTION:UI
+TS_TST_INFO_get_version 1483 1_1_0 EXIST::FUNCTION:TS
+BIO_accept_ex 1484 1_1_0 EXIST::FUNCTION:SOCK
+CRYPTO_get_mem_functions 1485 1_1_0 EXIST::FUNCTION:
+PEM_read_bio 1486 1_1_0 EXIST::FUNCTION:
+OCSP_BASICRESP_get_ext_by_critical 1487 1_1_0 EXIST::FUNCTION:OCSP
+SXNET_it 1488 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+SXNET_it 1488 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+BIO_indent 1489 1_1_0 EXIST::FUNCTION:
+i2d_X509_fp 1490 1_1_0 EXIST::FUNCTION:STDIO
+d2i_ASN1_TYPE 1491 1_1_0 EXIST::FUNCTION:
+CTLOG_STORE_free 1492 1_1_0 EXIST::FUNCTION:CT
+ENGINE_get_pkey_meths 1493 1_1_0 EXIST::FUNCTION:ENGINE
+i2d_TS_REQ_bio 1494 1_1_0 EXIST::FUNCTION:TS
+EVP_PKEY_CTX_get_operation 1495 1_1_0 EXIST::FUNCTION:
+EVP_MD_meth_set_ctrl 1496 1_1_0 EXIST::FUNCTION:
+X509_EXTENSION_set_critical 1497 1_1_0 EXIST::FUNCTION:
+BIO_ADDR_clear 1498 1_1_0 EXIST::FUNCTION:SOCK
+ENGINE_get_DSA 1499 1_1_0 EXIST::FUNCTION:ENGINE
+ASYNC_get_wait_ctx 1500 1_1_0 EXIST::FUNCTION:
+ENGINE_set_load_privkey_function 1501 1_1_0 EXIST::FUNCTION:ENGINE
+CRYPTO_ccm128_setiv 1502 1_1_0 EXIST::FUNCTION:
+PKCS7_dataFinal 1503 1_1_0 EXIST::FUNCTION:
+SHA1_Final 1504 1_1_0 EXIST::FUNCTION:
+i2a_ASN1_STRING 1505 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_CTX_rand_key 1506 1_1_0 EXIST::FUNCTION:
+AES_set_encrypt_key 1507 1_1_0 EXIST::FUNCTION:
+ASN1_UTCTIME_new 1508 1_1_0 EXIST::FUNCTION:
+AES_cbc_encrypt 1509 1_1_0 EXIST::FUNCTION:
+OCSP_RESPDATA_free 1510 1_1_0 EXIST::FUNCTION:OCSP
+EVP_PKEY_asn1_find 1511 1_1_0 EXIST::FUNCTION:
+d2i_ASN1_GENERALIZEDTIME 1512 1_1_0 EXIST::FUNCTION:
+OPENSSL_cleanup 1513 1_1_0 EXIST::FUNCTION:
+X509_ATTRIBUTE_create 1514 1_1_0 EXIST::FUNCTION:
+SCT_get_source 1515 1_1_0 EXIST::FUNCTION:CT
+EVP_PKEY_verify_init 1516 1_1_0 EXIST::FUNCTION:
+ASN1_TIME_set_string 1517 1_1_0 EXIST::FUNCTION:
+BIO_free 1518 1_1_0 EXIST::FUNCTION:
+i2d_X509_ALGOR 1519 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_set0_crls 1520 1_1_0 EXIST::FUNCTION:
+ASYNC_pause_job 1521 1_1_0 EXIST::FUNCTION:
+OCSP_BASICRESP_new 1522 1_1_0 EXIST::FUNCTION:OCSP
+EVP_camellia_256_ofb 1523 1_1_0 EXIST::FUNCTION:CAMELLIA
+PKCS12_item_i2d_encrypt 1524 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_set_copy 1525 1_1_0 EXIST::FUNCTION:
+EC_POINT_clear_free 1526 1_1_0 EXIST::FUNCTION:EC
+i2s_ASN1_ENUMERATED_TABLE 1527 1_1_0 EXIST::FUNCTION:
+PKCS7_verify 1528 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_add0_table 1529 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_set_cert 1530 1_1_0 EXIST::FUNCTION:
+ASN1_GENERALSTRING_free 1531 1_1_0 EXIST::FUNCTION:
+BN_MONT_CTX_set_locked 1532 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_CTX_set_num 1533 1_1_0 EXIST::FUNCTION:
+CONF_load 1534 1_1_0 EXIST::FUNCTION:
+EC_KEY_METHOD_get_keygen 1535 1_1_0 EXIST::FUNCTION:EC
+EVP_PKEY_add1_attr_by_txt 1536 1_1_0 EXIST::FUNCTION:
+ASN1_INTEGER_set_uint64 1537 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_get_attr_by_OBJ 1538 1_1_0 EXIST::FUNCTION:
+ASN1_add_oid_module 1539 1_1_0 EXIST::FUNCTION:
+BN_div_recp 1540 1_1_0 EXIST::FUNCTION:
+SRP_Verify_B_mod_N 1541 1_1_0 EXIST::FUNCTION:SRP
+SXNET_free 1542 1_1_0 EXIST::FUNCTION:
+CMS_get0_content 1543 1_1_0 EXIST::FUNCTION:CMS
+BN_is_word 1544 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_key_length 1545 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_asn1_to_param 1546 1_1_0 EXIST::FUNCTION:
+OCSP_request_onereq_get0 1547 1_1_0 EXIST::FUNCTION:OCSP
+ERR_load_PKCS7_strings 1548 1_1_0 EXIST::FUNCTION:
+X509_PUBKEY_get 1549 1_1_0 EXIST::FUNCTION:
+EC_KEY_free 1550 1_1_0 EXIST::FUNCTION:EC
+BIO_read 1551 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_get_attr_by_NID 1552 1_1_0 EXIST::FUNCTION:
+BIO_get_accept_socket 1553 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,SOCK
+CMS_SignerInfo_sign 1554 1_1_0 EXIST::FUNCTION:CMS
+ASN1_item_i2d_bio 1555 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_CTX_block_size 1556 1_1_0 EXIST::FUNCTION:
+DIRECTORYSTRING_free 1557 1_1_0 EXIST::FUNCTION:
+TS_CONF_set_default_engine 1558 1_1_0 EXIST::FUNCTION:ENGINE,TS
+BN_set_bit 1559 1_1_0 EXIST::FUNCTION:
+EVP_MD_meth_set_app_datasize 1560 1_1_0 EXIST::FUNCTION:
+DSO_free 1561 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_get_tsa 1562 1_1_0 EXIST::FUNCTION:TS
+EC_GROUP_check 1563 1_1_0 EXIST::FUNCTION:EC
+OPENSSL_sk_delete 1564 1_1_0 EXIST::FUNCTION:
+TS_RESP_CTX_set_extension_cb 1565 1_1_0 EXIST::FUNCTION:TS
+EVP_CIPHER_CTX_nid 1566 1_1_0 EXIST::FUNCTION:
+TS_RESP_CTX_add_md 1567 1_1_0 EXIST::FUNCTION:TS
+DES_set_key 1568 1_1_0 EXIST::FUNCTION:DES
+X509V3_extensions_print 1569 1_1_0 EXIST::FUNCTION:
+PEM_do_header 1570 1_1_0 EXIST::FUNCTION:
+i2d_re_X509_CRL_tbs 1571 1_1_0 EXIST::FUNCTION:
+BIO_method_name 1572 1_1_0 EXIST::FUNCTION:
+i2d_OCSP_CRLID 1573 1_1_0 EXIST::FUNCTION:OCSP
+OCSP_request_set1_name 1574 1_1_0 EXIST::FUNCTION:OCSP
+d2i_X509_NAME_ENTRY 1575 1_1_0 EXIST::FUNCTION:
+X509_trusted 1576 1_1_0 EXIST::FUNCTION:
+X509_TRUST_get_flags 1577 1_1_0 EXIST::FUNCTION:
+PKCS7_set_content 1578 1_1_0 EXIST::FUNCTION:
+PEM_write_X509_REQ_NEW 1579 1_1_0 EXIST::FUNCTION:STDIO
+CONF_imodule_set_usr_data 1580 1_1_0 EXIST::FUNCTION:
+d2i_TS_RESP_fp 1581 1_1_0 EXIST::FUNCTION:STDIO,TS
+X509_policy_tree_get0_user_policies 1582 1_1_0 EXIST::FUNCTION:
+DSA_do_sign 1584 1_1_0 EXIST::FUNCTION:DSA
+EVP_CIPHER_CTX_reset 1585 1_1_0 EXIST::FUNCTION:
+OCSP_REVOKEDINFO_new 1586 1_1_0 EXIST::FUNCTION:OCSP
+SRP_Verify_A_mod_N 1587 1_1_0 EXIST::FUNCTION:SRP
+SRP_VBASE_free 1588 1_1_0 EXIST::FUNCTION:SRP
+PKCS7_add0_attrib_signing_time 1589 1_1_0 EXIST::FUNCTION:
+X509_STORE_set_flags 1590 1_1_0 EXIST::FUNCTION:
+UI_get0_output_string 1591 1_1_0 EXIST::FUNCTION:UI
+ERR_get_error_line_data 1592 1_1_0 EXIST::FUNCTION:
+CTLOG_get0_name 1593 1_1_0 EXIST::FUNCTION:CT
+ASN1_TBOOLEAN_it 1594 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_TBOOLEAN_it 1594 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+RC2_set_key 1595 1_1_0 EXIST::FUNCTION:RC2
+X509_REVOKED_get_ext_by_NID 1596 1_1_0 EXIST::FUNCTION:
+RSA_padding_add_none 1597 1_1_0 EXIST::FUNCTION:RSA
+EVP_rc5_32_12_16_cbc 1599 1_1_0 EXIST::FUNCTION:RC5
+PEM_dek_info 1600 1_1_0 EXIST::FUNCTION:
+ASN1_SCTX_get_template 1601 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_asn1_get0 1602 1_1_0 EXIST::FUNCTION:
+X509_verify 1603 1_1_0 EXIST::FUNCTION:
+TS_RESP_CTX_get_request 1604 1_1_0 EXIST::FUNCTION:TS
+EVP_cast5_cbc 1605 1_1_0 EXIST::FUNCTION:CAST
+PEM_read_bio_X509_AUX 1606 1_1_0 EXIST::FUNCTION:
+TS_ext_print_bio 1607 1_1_0 EXIST::FUNCTION:TS
+SCT_set1_log_id 1608 1_1_0 EXIST::FUNCTION:CT
+X509_get0_pubkey_bitstr 1609 1_1_0 EXIST::FUNCTION:
+ENGINE_register_all_RAND 1610 1_1_0 EXIST::FUNCTION:ENGINE
+EVP_MD_meth_get_result_size 1612 1_1_0 EXIST::FUNCTION:
+BIO_ADDRINFO_address 1613 1_1_0 EXIST::FUNCTION:SOCK
+ASN1_STRING_print_ex 1614 1_1_0 EXIST::FUNCTION:
+i2d_CMS_ReceiptRequest 1615 1_1_0 EXIST::FUNCTION:CMS
+d2i_TS_REQ_fp 1616 1_1_0 EXIST::FUNCTION:STDIO,TS
+OCSP_REQ_CTX_i2d 1617 1_1_0 EXIST::FUNCTION:OCSP
+EVP_PKEY_get_default_digest_nid 1618 1_1_0 EXIST::FUNCTION:
+ASIdOrRange_new 1619 1_1_0 EXIST::FUNCTION:RFC3779
+ASN1_SCTX_new 1620 1_1_0 EXIST::FUNCTION:
+X509V3_EXT_get 1621 1_1_0 EXIST::FUNCTION:
+OCSP_id_cmp 1622 1_1_0 EXIST::FUNCTION:OCSP
+NCONF_dump_bio 1623 1_1_0 EXIST::FUNCTION:
+X509_NAME_get_entry 1624 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_get1_DH 1625 1_1_0 EXIST::FUNCTION:DH
+CRYPTO_gcm128_aad 1626 1_1_0 EXIST::FUNCTION:
+EVP_des_cfb8 1627 1_1_0 EXIST::FUNCTION:DES
+BN_BLINDING_convert 1628 1_1_0 EXIST::FUNCTION:
+CRYPTO_ocb128_cleanup 1629 1_1_0 EXIST::FUNCTION:OCB
+EVP_des_ede_cbc 1630 1_1_0 EXIST::FUNCTION:DES
+i2d_ASN1_TIME 1631 1_1_0 EXIST::FUNCTION:
+ENGINE_register_all_pkey_asn1_meths 1632 1_1_0 EXIST::FUNCTION:ENGINE
+OCSP_set_max_response_length 1633 1_1_0 EXIST::FUNCTION:OCSP
+d2i_ISSUING_DIST_POINT 1634 1_1_0 EXIST::FUNCTION:
+CMS_RecipientInfo_set0_key 1635 1_1_0 EXIST::FUNCTION:CMS
+NCONF_new 1636 1_1_0 EXIST::FUNCTION:
+OCSP_SINGLERESP_free 1637 1_1_0 EXIST::FUNCTION:OCSP
+PKCS7_ENCRYPT_free 1638 1_1_0 EXIST::FUNCTION:
+i2d_DIST_POINT 1639 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_paramgen_init 1640 1_1_0 EXIST::FUNCTION:
+TS_MSG_IMPRINT_dup 1641 1_1_0 EXIST::FUNCTION:TS
+CMS_ContentInfo_it 1642 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:CMS
+CMS_ContentInfo_it 1642 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:CMS
+OCSP_resp_get0_signature 1643 1_1_0 EXIST::FUNCTION:OCSP
+X509_STORE_CTX_get1_issuer 1644 1_1_0 EXIST::FUNCTION:
+EVP_Digest 1645 1_1_0 EXIST::FUNCTION:
+CRYPTO_set_ex_data 1646 1_1_0 EXIST::FUNCTION:
+BN_bn2hex 1647 1_1_0 EXIST::FUNCTION:
+BN_lshift1 1648 1_1_0 EXIST::FUNCTION:
+i2d_EDIPARTYNAME 1649 1_1_0 EXIST::FUNCTION:
+X509_policy_tree_get0_policies 1650 1_1_0 EXIST::FUNCTION:
+X509at_add1_attr 1651 1_1_0 EXIST::FUNCTION:
+X509_get_ex_data 1653 1_1_0 EXIST::FUNCTION:
+RSA_set_method 1654 1_1_0 EXIST::FUNCTION:RSA
+X509_REVOKED_dup 1655 1_1_0 EXIST::FUNCTION:
+ASN1_TIME_new 1656 1_1_0 EXIST::FUNCTION:
+PEM_write_NETSCAPE_CERT_SEQUENCE 1657 1_1_0 EXIST::FUNCTION:STDIO
+PEM_read_X509_REQ 1658 1_1_0 EXIST::FUNCTION:STDIO
+EC_GROUP_free 1659 1_1_0 EXIST::FUNCTION:EC
+X509_CRL_get_meth_data 1660 1_1_0 EXIST::FUNCTION:
+X509V3_add_value_uchar 1661 1_1_0 EXIST::FUNCTION:
+BIO_asn1_get_suffix 1662 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_clear_flags 1663 1_1_0 EXIST::FUNCTION:
+X509_NAME_add_entry_by_txt 1664 1_1_0 EXIST::FUNCTION:
+DES_ede3_cfb_encrypt 1665 1_1_0 EXIST::FUNCTION:DES
+i2d_CMS_bio_stream 1667 1_1_0 EXIST::FUNCTION:CMS
+DES_quad_cksum 1668 1_1_0 EXIST::FUNCTION:DES
+X509_ATTRIBUTE_create_by_NID 1669 1_1_0 EXIST::FUNCTION:
+TS_VERIFY_CTX_free 1670 1_1_0 EXIST::FUNCTION:TS
+EC_KEY_up_ref 1671 1_1_0 EXIST::FUNCTION:EC
+EC_GROUP_get_basis_type 1672 1_1_0 EXIST::FUNCTION:EC
+OCSP_crlID_new 1673 1_1_0 EXIST:!VMS:FUNCTION:OCSP
+OCSP_crlID2_new 1673 1_1_0 EXIST:VMS:FUNCTION:OCSP
+PEM_write_PKCS7 1674 1_1_0 EXIST::FUNCTION:STDIO
+PKCS7_add_signer 1675 1_1_0 EXIST::FUNCTION:
+X509_SIG_it 1676 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_SIG_it 1676 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ASYNC_start_job 1677 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_dup 1678 1_1_0 EXIST::FUNCTION:TS
+EVP_aes_192_ctr 1679 1_1_0 EXIST::FUNCTION:
+PKCS12_pack_authsafes 1680 1_1_0 EXIST::FUNCTION:
+PKCS7_get_attribute 1681 1_1_0 EXIST::FUNCTION:
+OPENSSL_config 1682 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0
+s2i_ASN1_INTEGER 1683 1_1_0 EXIST::FUNCTION:
+CMS_signed_add1_attr_by_OBJ 1684 1_1_0 EXIST::FUNCTION:CMS
+CRYPTO_128_wrap_pad 1685 1_1_0 EXIST::FUNCTION:
+CMS_EncryptedData_set1_key 1686 1_1_0 EXIST::FUNCTION:CMS
+OBJ_find_sigid_by_algs 1687 1_1_0 EXIST::FUNCTION:
+ASN1_generate_nconf 1688 1_1_0 EXIST::FUNCTION:
+CMS_add0_recipient_password 1689 1_1_0 EXIST::FUNCTION:CMS
+UI_get_string_type 1690 1_1_0 EXIST::FUNCTION:UI
+PEM_read_bio_ECPrivateKey 1691 1_1_0 EXIST::FUNCTION:EC
+EVP_PKEY_get_attr 1692 1_1_0 EXIST::FUNCTION:
+PEM_read_bio_ECPKParameters 1693 1_1_0 EXIST::FUNCTION:EC
+d2i_PKCS12_MAC_DATA 1694 1_1_0 EXIST::FUNCTION:
+ENGINE_ctrl_cmd 1695 1_1_0 EXIST::FUNCTION:ENGINE
+PKCS12_SAFEBAG_get_bag_nid 1696 1_1_0 EXIST::FUNCTION:
+TS_CONF_set_digests 1697 1_1_0 EXIST::FUNCTION:TS
+PKCS7_SIGNED_it 1698 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS7_SIGNED_it 1698 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+b2i_PublicKey 1699 1_1_0 EXIST::FUNCTION:DSA
+X509_PURPOSE_cleanup 1700 1_1_0 EXIST::FUNCTION:
+ESS_SIGNING_CERT_dup 1701 1_1_0 EXIST::FUNCTION:TS
+ENGINE_set_default_DSA 1702 1_1_0 EXIST::FUNCTION:ENGINE
+X509_REVOKED_new 1703 1_1_0 EXIST::FUNCTION:
+NCONF_WIN32 1704 1_1_0 EXIST::FUNCTION:
+RSA_padding_check_PKCS1_OAEP_mgf1 1705 1_1_0 EXIST::FUNCTION:RSA
+X509_policy_tree_get0_level 1706 1_1_0 EXIST::FUNCTION:
+ASN1_parse_dump 1708 1_1_0 EXIST::FUNCTION:
+BIO_vfree 1709 1_1_0 EXIST::FUNCTION:
+CRYPTO_cbc128_decrypt 1710 1_1_0 EXIST::FUNCTION:
+UI_dup_verify_string 1711 1_1_0 EXIST::FUNCTION:UI
+d2i_PKCS7_bio 1712 1_1_0 EXIST::FUNCTION:
+ENGINE_set_default_digests 1713 1_1_0 EXIST::FUNCTION:ENGINE
+i2d_PublicKey 1714 1_1_0 EXIST::FUNCTION:
+RC5_32_set_key 1715 1_1_0 EXIST::FUNCTION:RC5
+AES_unwrap_key 1716 1_1_0 EXIST::FUNCTION:
+EVP_Cipher 1717 1_1_0 EXIST::FUNCTION:
+AES_set_decrypt_key 1718 1_1_0 EXIST::FUNCTION:
+BF_ofb64_encrypt 1719 1_1_0 EXIST::FUNCTION:BF
+d2i_TS_TST_INFO_fp 1720 1_1_0 EXIST::FUNCTION:STDIO,TS
+X509_find_by_issuer_and_serial 1721 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_type 1722 1_1_0 EXIST::FUNCTION:
+ENGINE_ctrl 1723 1_1_0 EXIST::FUNCTION:ENGINE
+EVP_cast5_ecb 1724 1_1_0 EXIST::FUNCTION:CAST
+BIO_nwrite0 1725 1_1_0 EXIST::FUNCTION:
+CAST_encrypt 1726 1_1_0 EXIST::FUNCTION:CAST
+a2d_ASN1_OBJECT 1727 1_1_0 EXIST::FUNCTION:
+OCSP_ONEREQ_delete_ext 1728 1_1_0 EXIST::FUNCTION:OCSP
+UI_method_get_reader 1729 1_1_0 EXIST::FUNCTION:UI
+CMS_unsigned_get_attr 1730 1_1_0 EXIST::FUNCTION:CMS
+EVP_aes_256_cbc 1731 1_1_0 EXIST::FUNCTION:
+X509_check_ip_asc 1732 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_X509_AUX 1733 1_1_0 EXIST::FUNCTION:
+RC2_cbc_encrypt 1734 1_1_0 EXIST::FUNCTION:RC2
+TS_MSG_IMPRINT_new 1735 1_1_0 EXIST::FUNCTION:TS
+EVP_ENCODE_CTX_new 1736 1_1_0 EXIST::FUNCTION:
+BIO_f_base64 1737 1_1_0 EXIST::FUNCTION:
+CMS_verify 1738 1_1_0 EXIST::FUNCTION:CMS
+i2d_PrivateKey 1739 1_1_0 EXIST::FUNCTION:
+i2d_OCSP_ONEREQ 1740 1_1_0 EXIST::FUNCTION:OCSP
+OPENSSL_issetugid 1741 1_1_0 EXIST::FUNCTION:
+d2i_ASN1_OBJECT 1742 1_1_0 EXIST::FUNCTION:
+EVP_MD_meth_set_flags 1743 1_1_0 EXIST::FUNCTION:
+EVP_idea_cbc 1744 1_1_0 EXIST::FUNCTION:IDEA
+EC_POINT_cmp 1745 1_1_0 EXIST::FUNCTION:EC
+ASN1_buf_print 1746 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_CTX_hex2ctrl 1747 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_PKCS8PrivateKey 1748 1_1_0 EXIST::FUNCTION:
+CMAC_Update 1749 1_1_0 EXIST::FUNCTION:CMAC
+d2i_ASN1_UTCTIME 1750 1_1_0 EXIST::FUNCTION:
+OPENSSL_sk_insert 1751 1_1_0 EXIST::FUNCTION:
+DSO_up_ref 1752 1_1_0 EXIST::FUNCTION:
+EVP_rc2_cbc 1753 1_1_0 EXIST::FUNCTION:RC2
+i2d_NETSCAPE_SPKI 1754 1_1_0 EXIST::FUNCTION:
+ASYNC_init_thread 1755 1_1_0 EXIST::FUNCTION:
+OCSP_BASICRESP_get_ext_by_OBJ 1756 1_1_0 EXIST::FUNCTION:OCSP
+X509_reject_clear 1757 1_1_0 EXIST::FUNCTION:
+DH_security_bits 1758 1_1_0 EXIST::FUNCTION:DH
+LONG_it 1759 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+LONG_it 1759 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ASN1_dup 1760 1_1_0 EXIST::FUNCTION:
+TS_RESP_new 1761 1_1_0 EXIST::FUNCTION:TS
+i2d_PKCS8PrivateKeyInfo_fp 1762 1_1_0 EXIST::FUNCTION:STDIO
+X509_alias_get0 1763 1_1_0 EXIST::FUNCTION:
+X509_ATTRIBUTE_free 1764 1_1_0 EXIST::FUNCTION:
+d2i_X509_bio 1765 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_get_exts 1766 1_1_0 EXIST::FUNCTION:TS
+EVP_aes_256_ecb 1767 1_1_0 EXIST::FUNCTION:
+ASN1_BIT_STRING_name_print 1768 1_1_0 EXIST::FUNCTION:
+d2i_X509_EXTENSIONS 1769 1_1_0 EXIST::FUNCTION:
+ASN1_OCTET_STRING_free 1770 1_1_0 EXIST::FUNCTION:
+PKCS7_RECIP_INFO_free 1771 1_1_0 EXIST::FUNCTION:
+ASN1_tag2bit 1772 1_1_0 EXIST::FUNCTION:
+TS_REQ_add_ext 1773 1_1_0 EXIST::FUNCTION:TS
+X509_digest 1776 1_1_0 EXIST::FUNCTION:
+CRYPTO_THREAD_cleanup_local 1777 1_1_0 EXIST::FUNCTION:
+NETSCAPE_CERT_SEQUENCE_it 1778 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+NETSCAPE_CERT_SEQUENCE_it 1778 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+EVP_aes_128_wrap 1779 1_1_0 EXIST::FUNCTION:
+X509V3_conf_free 1780 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_get_ext_by_NID 1781 1_1_0 EXIST::FUNCTION:TS
+EVP_aes_256_cfb1 1782 1_1_0 EXIST::FUNCTION:
+X509_issuer_name_cmp 1783 1_1_0 EXIST::FUNCTION:
+CMS_RecipientEncryptedKey_get0_id 1784 1_1_0 EXIST::FUNCTION:CMS
+EVP_PKEY_meth_get_verify_recover 1785 1_1_0 EXIST::FUNCTION:
+NAME_CONSTRAINTS_check 1786 1_1_0 EXIST::FUNCTION:
+X509_CERT_AUX_it 1787 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_CERT_AUX_it 1787 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+X509_get_X509_PUBKEY 1789 1_1_0 EXIST::FUNCTION:
+TXT_DB_create_index 1790 1_1_0 EXIST::FUNCTION:
+RAND_set_rand_engine 1791 1_1_0 EXIST::FUNCTION:ENGINE
+X509_set_serialNumber 1792 1_1_0 EXIST::FUNCTION:
+BN_mod_exp_mont_consttime 1793 1_1_0 EXIST::FUNCTION:
+X509V3_parse_list 1794 1_1_0 EXIST::FUNCTION:
+ACCESS_DESCRIPTION_new 1795 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_CTX_clear_flags 1796 1_1_0 EXIST::FUNCTION:
+ECDSA_size 1797 1_1_0 EXIST::FUNCTION:EC
+X509_ALGOR_get0 1798 1_1_0 EXIST::FUNCTION:
+d2i_ACCESS_DESCRIPTION 1799 1_1_0 EXIST::FUNCTION:
+OCSP_SINGLERESP_get_ext_by_NID 1800 1_1_0 EXIST::FUNCTION:OCSP
+a2i_IPADDRESS_NC 1801 1_1_0 EXIST::FUNCTION:
+CTLOG_STORE_load_default_file 1802 1_1_0 EXIST::FUNCTION:CT
+PKCS12_SAFEBAG_create_pkcs8_encrypt 1803 1_1_0 EXIST::FUNCTION:
+RAND_screen 1804 1_1_0 EXIST:_WIN32:FUNCTION:DEPRECATEDIN_1_1_0
+CONF_get_string 1805 1_1_0 EXIST::FUNCTION:
+X509_cmp_current_time 1806 1_1_0 EXIST::FUNCTION:
+i2d_DSAPrivateKey 1807 1_1_0 EXIST::FUNCTION:DSA
+ASN1_BIT_STRING_new 1808 1_1_0 EXIST::FUNCTION:
+BIO_new_file 1809 1_1_0 EXIST::FUNCTION:
+PKCS7_SIGNER_INFO_get0_algs 1810 1_1_0 EXIST::FUNCTION:
+TS_RESP_set_status_info 1811 1_1_0 EXIST::FUNCTION:TS
+OPENSSL_LH_delete 1812 1_1_0 EXIST::FUNCTION:
+TS_STATUS_INFO_dup 1813 1_1_0 EXIST::FUNCTION:TS
+X509v3_addr_get_range 1814 1_1_0 EXIST::FUNCTION:RFC3779
+X509_EXTENSION_get_data 1815 1_1_0 EXIST::FUNCTION:
+RC5_32_encrypt 1816 1_1_0 EXIST::FUNCTION:RC5
+DIST_POINT_set_dpname 1817 1_1_0 EXIST::FUNCTION:
+BIO_sock_info 1818 1_1_0 EXIST::FUNCTION:SOCK
+OPENSSL_hexstr2buf 1819 1_1_0 EXIST::FUNCTION:
+EVP_add_cipher 1820 1_1_0 EXIST::FUNCTION:
+X509V3_EXT_add_list 1821 1_1_0 EXIST::FUNCTION:
+CMS_compress 1822 1_1_0 EXIST::FUNCTION:CMS
+X509_get_ext_by_critical 1823 1_1_0 EXIST::FUNCTION:
+ASYNC_WAIT_CTX_clear_fd 1824 1_1_0 EXIST::FUNCTION:
+ZLONG_it 1825 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ZLONG_it 1825 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+OPENSSL_sk_find_ex 1826 1_1_0 EXIST::FUNCTION:
+ASN1_ENUMERATED_to_BN 1827 1_1_0 EXIST::FUNCTION:
+X509_CRL_get_ext_d2i 1828 1_1_0 EXIST::FUNCTION:
+i2d_AUTHORITY_KEYID 1829 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_get_time 1830 1_1_0 EXIST::FUNCTION:TS
+ASN1_VISIBLESTRING_it 1831 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_VISIBLESTRING_it 1831 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+X509V3_EXT_REQ_add_conf 1832 1_1_0 EXIST::FUNCTION:
+ASN1_STRING_to_UTF8 1833 1_1_0 EXIST::FUNCTION:
+EVP_MD_meth_set_update 1835 1_1_0 EXIST::FUNCTION:
+EVP_camellia_192_cbc 1836 1_1_0 EXIST::FUNCTION:CAMELLIA
+OPENSSL_LH_stats_bio 1837 1_1_0 EXIST::FUNCTION:
+PKCS7_set_signed_attributes 1838 1_1_0 EXIST::FUNCTION:
+EC_KEY_priv2buf 1839 1_1_0 EXIST::FUNCTION:EC
+BN_BLINDING_free 1840 1_1_0 EXIST::FUNCTION:
+IPAddressChoice_new 1841 1_1_0 EXIST::FUNCTION:RFC3779
+X509_CRL_get_ext_count 1842 1_1_0 EXIST::FUNCTION:
+PKCS12_add_key 1843 1_1_0 EXIST::FUNCTION:
+EVP_camellia_128_cfb1 1844 1_1_0 EXIST::FUNCTION:CAMELLIA
+BIO_find_type 1845 1_1_0 EXIST::FUNCTION:
+ISSUING_DIST_POINT_it 1846 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ISSUING_DIST_POINT_it 1846 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+BIO_ctrl_wpending 1847 1_1_0 EXIST::FUNCTION:
+X509_ALGOR_cmp 1848 1_1_0 EXIST::FUNCTION:
+i2d_ASN1_bio_stream 1849 1_1_0 EXIST::FUNCTION:
+CRYPTO_THREAD_init_local 1850 1_1_0 EXIST::FUNCTION:
+TS_RESP_CTX_set_serial_cb 1851 1_1_0 EXIST::FUNCTION:TS
+POLICY_MAPPING_it 1852 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+POLICY_MAPPING_it 1852 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ERR_load_KDF_strings 1853 1_1_0 EXIST::FUNCTION:
+UI_method_set_reader 1854 1_1_0 EXIST::FUNCTION:UI
+BIO_next 1855 1_1_0 EXIST::FUNCTION:
+ASN1_STRING_set_default_mask_asc 1856 1_1_0 EXIST::FUNCTION:
+X509_CRL_new 1857 1_1_0 EXIST::FUNCTION:
+i2b_PrivateKey_bio 1858 1_1_0 EXIST::FUNCTION:DSA
+ASN1_STRING_length_set 1859 1_1_0 EXIST::FUNCTION:
+PEM_write_PKCS8 1860 1_1_0 EXIST::FUNCTION:STDIO
+PKCS7_digest_from_attributes 1861 1_1_0 EXIST::FUNCTION:
+EC_GROUP_set_curve_GFp 1862 1_1_0 EXIST::FUNCTION:EC
+X509_PURPOSE_get0 1863 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_set1_DSA 1864 1_1_0 EXIST::FUNCTION:DSA
+X509_NAME_it 1865 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_NAME_it 1865 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+OBJ_add_object 1866 1_1_0 EXIST::FUNCTION:
+DSA_generate_key 1867 1_1_0 EXIST::FUNCTION:DSA
+EVP_DigestUpdate 1868 1_1_0 EXIST::FUNCTION:
+X509_get_ext_by_OBJ 1869 1_1_0 EXIST::FUNCTION:
+PBEPARAM_new 1870 1_1_0 EXIST::FUNCTION:
+EVP_aes_128_cbc 1871 1_1_0 EXIST::FUNCTION:
+CRYPTO_dup_ex_data 1872 1_1_0 EXIST::FUNCTION:
+OCSP_single_get0_status 1873 1_1_0 EXIST::FUNCTION:OCSP
+d2i_AUTHORITY_INFO_ACCESS 1874 1_1_0 EXIST::FUNCTION:
+PEM_read_RSAPrivateKey 1875 1_1_0 EXIST::FUNCTION:RSA,STDIO
+BIO_closesocket 1876 1_1_0 EXIST::FUNCTION:SOCK
+RSA_verify_ASN1_OCTET_STRING 1877 1_1_0 EXIST::FUNCTION:RSA
+SCT_set_log_entry_type 1878 1_1_0 EXIST::FUNCTION:CT
+BN_new 1879 1_1_0 EXIST::FUNCTION:
+X509_OBJECT_retrieve_by_subject 1880 1_1_0 EXIST::FUNCTION:
+MD5_Final 1881 1_1_0 EXIST::FUNCTION:MD5
+X509_STORE_set_verify_cb 1882 1_1_0 EXIST::FUNCTION:
+OCSP_REQUEST_print 1883 1_1_0 EXIST::FUNCTION:OCSP
+CMS_add1_crl 1884 1_1_0 EXIST::FUNCTION:CMS
+d2i_EDIPARTYNAME 1885 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_set0_trusted_stack 1886 1_1_0 EXIST::FUNCTION:
+BIO_ADDR_service_string 1887 1_1_0 EXIST::FUNCTION:SOCK
+ASN1_BOOLEAN_it 1888 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_BOOLEAN_it 1888 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+TS_RESP_CTX_set_time_cb 1889 1_1_0 EXIST::FUNCTION:TS
+IDEA_cbc_encrypt 1890 1_1_0 EXIST::FUNCTION:IDEA
+BN_CTX_secure_new 1891 1_1_0 EXIST::FUNCTION:
+OCSP_ONEREQ_add_ext 1892 1_1_0 EXIST::FUNCTION:OCSP
+CMS_uncompress 1893 1_1_0 EXIST::FUNCTION:CMS
+CRYPTO_mem_debug_pop 1895 1_1_0 EXIST::FUNCTION:CRYPTO_MDEBUG
+EVP_aes_192_cfb128 1896 1_1_0 EXIST::FUNCTION:
+OCSP_REQ_CTX_nbio 1897 1_1_0 EXIST::FUNCTION:OCSP
+EVP_CIPHER_CTX_copy 1898 1_1_0 EXIST::FUNCTION:
+CRYPTO_secure_allocated 1899 1_1_0 EXIST::FUNCTION:
+UI_UTIL_read_pw_string 1900 1_1_0 EXIST::FUNCTION:UI
+NOTICEREF_free 1901 1_1_0 EXIST::FUNCTION:
+AES_cfb1_encrypt 1902 1_1_0 EXIST::FUNCTION:
+X509v3_get_ext 1903 1_1_0 EXIST::FUNCTION:
+CRYPTO_gcm128_encrypt_ctr32 1905 1_1_0 EXIST::FUNCTION:
+SCT_set1_signature 1906 1_1_0 EXIST::FUNCTION:CT
+CONF_imodule_get_module 1907 1_1_0 EXIST::FUNCTION:
+NAME_CONSTRAINTS_new 1908 1_1_0 EXIST::FUNCTION:
+BN_usub 1909 1_1_0 EXIST::FUNCTION:
+SRP_Calc_B 1910 1_1_0 EXIST::FUNCTION:SRP
+CMS_decrypt_set1_key 1911 1_1_0 EXIST::FUNCTION:CMS
+EC_GROUP_get_degree 1912 1_1_0 EXIST::FUNCTION:EC
+X509_ALGOR_set0 1913 1_1_0 EXIST::FUNCTION:
+OPENSSL_LH_set_down_load 1914 1_1_0 EXIST::FUNCTION:
+X509v3_asid_inherits 1915 1_1_0 EXIST::FUNCTION:RFC3779
+EVP_MD_meth_get_app_datasize 1916 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_num_untrusted 1917 1_1_0 EXIST::FUNCTION:
+RAND_poll 1918 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_print_public 1919 1_1_0 EXIST::FUNCTION:
+CMS_SignedData_init 1920 1_1_0 EXIST::FUNCTION:CMS
+X509_REQ_free 1921 1_1_0 EXIST::FUNCTION:
+ASN1_INTEGER_set 1922 1_1_0 EXIST::FUNCTION:
+EVP_DecodeFinal 1923 1_1_0 EXIST::FUNCTION:
+MD5_Transform 1925 1_1_0 EXIST::FUNCTION:MD5
+SRP_create_verifier_BN 1926 1_1_0 EXIST::FUNCTION:SRP
+ENGINE_register_all_EC 1927 1_1_0 EXIST::FUNCTION:ENGINE
+EVP_camellia_128_ofb 1928 1_1_0 EXIST::FUNCTION:CAMELLIA
+PEM_write_X509_AUX 1929 1_1_0 EXIST::FUNCTION:STDIO
+X509_LOOKUP_by_subject 1930 1_1_0 EXIST::FUNCTION:
+X509_REQ_add_extensions 1931 1_1_0 EXIST::FUNCTION:
+Camellia_cbc_encrypt 1932 1_1_0 EXIST::FUNCTION:CAMELLIA
+EC_KEY_METHOD_new 1933 1_1_0 EXIST::FUNCTION:EC
+RSA_flags 1934 1_1_0 EXIST::FUNCTION:RSA
+X509_NAME_add_entry 1935 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_get_asn1_iv 1936 1_1_0 EXIST::FUNCTION:
+i2d_RSAPrivateKey_bio 1937 1_1_0 EXIST::FUNCTION:RSA
+PKCS5_PBE_keyivgen 1938 1_1_0 EXIST::FUNCTION:
+i2d_OCSP_SERVICELOC 1939 1_1_0 EXIST::FUNCTION:OCSP
+EC_POINT_copy 1940 1_1_0 EXIST::FUNCTION:EC
+X509V3_EXT_CRL_add_nconf 1941 1_1_0 EXIST::FUNCTION:
+SHA256_Init 1942 1_1_0 EXIST::FUNCTION:
+X509_NAME_ENTRY_get_object 1943 1_1_0 EXIST::FUNCTION:
+ASN1_ENUMERATED_free 1944 1_1_0 EXIST::FUNCTION:
+X509_CRL_set_meth_data 1945 1_1_0 EXIST::FUNCTION:
+EVP_aes_192_cfb1 1946 1_1_0 EXIST::FUNCTION:
+EVP_MD_CTX_set_flags 1947 1_1_0 EXIST::FUNCTION:
+EVP_seed_cbc 1948 1_1_0 EXIST::FUNCTION:SEED
+d2i_PKCS12 1949 1_1_0 EXIST::FUNCTION:
+X509_policy_node_get0_policy 1950 1_1_0 EXIST::FUNCTION:
+PKCS12_unpack_p7data 1951 1_1_0 EXIST::FUNCTION:
+ECDSA_sign 1952 1_1_0 EXIST::FUNCTION:EC
+d2i_PKCS12_fp 1953 1_1_0 EXIST::FUNCTION:STDIO
+CMS_unsigned_get_attr_by_NID 1954 1_1_0 EXIST::FUNCTION:CMS
+UI_add_user_data 1955 1_1_0 EXIST::FUNCTION:UI
+BN_bntest_rand 1956 1_1_0 EXIST::FUNCTION:
+X509_get_pubkey 1957 1_1_0 EXIST::FUNCTION:
+i2d_X509_NAME 1958 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_add1_attr 1959 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_purpose_inherit 1960 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_get_keygen 1961 1_1_0 EXIST::FUNCTION:
+ENGINE_get_pkey_asn1_meth 1962 1_1_0 EXIST::FUNCTION:ENGINE
+SHA256_Update 1963 1_1_0 EXIST::FUNCTION:
+d2i_PKCS7_ISSUER_AND_SERIAL 1964 1_1_0 EXIST::FUNCTION:
+PKCS12_unpack_authsafes 1965 1_1_0 EXIST::FUNCTION:
+X509_CRL_it 1966 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_CRL_it 1966 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+d2i_X509_ALGOR 1967 1_1_0 EXIST::FUNCTION:
+PKCS12_PBE_keyivgen 1968 1_1_0 EXIST::FUNCTION:
+BIO_test_flags 1969 1_1_0 EXIST::FUNCTION:
+EC_POINT_get_affine_coordinates_GF2m 1970 1_1_0 EXIST::FUNCTION:EC,EC2M
+EVP_ENCODE_CTX_num 1971 1_1_0 EXIST::FUNCTION:
+Camellia_cfb1_encrypt 1972 1_1_0 EXIST::FUNCTION:CAMELLIA
+NCONF_load_fp 1973 1_1_0 EXIST::FUNCTION:STDIO
+i2d_OCSP_REQINFO 1974 1_1_0 EXIST::FUNCTION:OCSP
+EVP_PKEY_sign 1975 1_1_0 EXIST::FUNCTION:
+TS_REQ_get_ext_by_critical 1976 1_1_0 EXIST::FUNCTION:TS
+EC_KEY_key2buf 1977 1_1_0 EXIST::FUNCTION:EC
+X509_EXTENSION_it 1978 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_EXTENSION_it 1978 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+i2d_PKCS8_fp 1979 1_1_0 EXIST::FUNCTION:STDIO
+UTF8_getc 1980 1_1_0 EXIST::FUNCTION:
+ASN1_IA5STRING_free 1981 1_1_0 EXIST::FUNCTION:
+EC_KEY_METHOD_get_verify 1982 1_1_0 EXIST::FUNCTION:EC
+OBJ_NAME_do_all 1983 1_1_0 EXIST::FUNCTION:
+d2i_TS_MSG_IMPRINT_fp 1984 1_1_0 EXIST::FUNCTION:STDIO,TS
+X509_CRL_verify 1985 1_1_0 EXIST::FUNCTION:
+X509_get0_uids 1986 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_get0_DSA 1987 1_1_0 EXIST::FUNCTION:DSA
+d2i_CMS_ContentInfo 1988 1_1_0 EXIST::FUNCTION:CMS
+EVP_CIPHER_meth_get_do_cipher 1989 1_1_0 EXIST::FUNCTION:
+i2d_DSA_PUBKEY 1990 1_1_0 EXIST::FUNCTION:DSA
+GENERAL_NAME_it 1991 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+GENERAL_NAME_it 1991 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+EVP_des_ede_ecb 1992 1_1_0 EXIST::FUNCTION:DES
+i2d_CRL_DIST_POINTS 1993 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_X509_REQ_NEW 1994 1_1_0 EXIST::FUNCTION:
+RC5_32_ofb64_encrypt 1995 1_1_0 EXIST::FUNCTION:RC5
+i2d_PKCS7 1996 1_1_0 EXIST::FUNCTION:
+BN_mod_lshift_quick 1997 1_1_0 EXIST::FUNCTION:
+DIST_POINT_NAME_it 1998 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+DIST_POINT_NAME_it 1998 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+PEM_read_PrivateKey 1999 1_1_0 EXIST::FUNCTION:STDIO
+X509V3_get_d2i 2000 1_1_0 EXIST::FUNCTION:
+PKCS7_SIGNER_INFO_sign 2001 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_free 2002 1_1_0 EXIST::FUNCTION:TS
+DSA_security_bits 2003 1_1_0 EXIST::FUNCTION:DSA
+X509v3_addr_is_canonical 2004 1_1_0 EXIST::FUNCTION:RFC3779
+BN_mod_mul_reciprocal 2005 1_1_0 EXIST::FUNCTION:
+TS_REQ_get_version 2006 1_1_0 EXIST::FUNCTION:TS
+BN_exp 2007 1_1_0 EXIST::FUNCTION:
+i2d_SXNET 2008 1_1_0 EXIST::FUNCTION:
+OBJ_bsearch_ 2009 1_1_0 EXIST::FUNCTION:
+OPENSSL_LH_new 2010 1_1_0 EXIST::FUNCTION:
+ENGINE_register_all_pkey_meths 2011 1_1_0 EXIST::FUNCTION:ENGINE
+ENGINE_get_init_function 2012 1_1_0 EXIST::FUNCTION:ENGINE
+EC_POINT_point2hex 2013 1_1_0 EXIST::FUNCTION:EC
+ENGINE_get_default_DSA 2014 1_1_0 EXIST::FUNCTION:ENGINE
+ENGINE_register_all_complete 2015 1_1_0 EXIST::FUNCTION:ENGINE
+SRP_get_default_gN 2016 1_1_0 EXIST::FUNCTION:SRP
+UI_dup_input_boolean 2017 1_1_0 EXIST::FUNCTION:UI
+PKCS7_dup 2018 1_1_0 EXIST::FUNCTION:
+i2d_TS_REQ_fp 2019 1_1_0 EXIST::FUNCTION:STDIO,TS
+i2d_OTHERNAME 2020 1_1_0 EXIST::FUNCTION:
+EC_KEY_get0_private_key 2021 1_1_0 EXIST::FUNCTION:EC
+SCT_get0_extensions 2022 1_1_0 EXIST::FUNCTION:CT
+OPENSSL_LH_node_stats_bio 2023 1_1_0 EXIST::FUNCTION:
+i2d_DIRECTORYSTRING 2024 1_1_0 EXIST::FUNCTION:
+BN_X931_derive_prime_ex 2025 1_1_0 EXIST::FUNCTION:
+ENGINE_get_pkey_asn1_meth_str 2026 1_1_0 EXIST::FUNCTION:ENGINE
+PKCS7_signatureVerify 2027 1_1_0 EXIST::FUNCTION:
+CRYPTO_ocb128_new 2028 1_1_0 EXIST::FUNCTION:OCB
+EC_curve_nist2nid 2029 1_1_0 EXIST::FUNCTION:EC
+UI_get0_result 2030 1_1_0 EXIST::FUNCTION:UI
+OCSP_request_add1_nonce 2031 1_1_0 EXIST::FUNCTION:OCSP
+UI_construct_prompt 2032 1_1_0 EXIST::FUNCTION:UI
+ENGINE_unregister_RSA 2033 1_1_0 EXIST::FUNCTION:ENGINE
+EC_GROUP_order_bits 2034 1_1_0 EXIST::FUNCTION:EC
+d2i_CMS_bio 2035 1_1_0 EXIST::FUNCTION:CMS
+OPENSSL_sk_num 2036 1_1_0 EXIST::FUNCTION:
+_shadow_DES_check_key 2037 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:DES
+_shadow_DES_check_key 2037 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:DES
+CMS_RecipientInfo_set0_pkey 2038 1_1_0 EXIST::FUNCTION:CMS
+X509_STORE_CTX_set_default 2039 1_1_0 EXIST::FUNCTION:
+AES_wrap_key 2040 1_1_0 EXIST::FUNCTION:
+EVP_md_null 2041 1_1_0 EXIST::FUNCTION:
+i2d_SCT_LIST 2042 1_1_0 EXIST::FUNCTION:CT
+PKCS7_get_issuer_and_serial 2043 1_1_0 EXIST::FUNCTION:
+PKCS7_SIGN_ENVELOPE_it 2044 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS7_SIGN_ENVELOPE_it 2044 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ASN1_d2i_fp 2045 1_1_0 EXIST::FUNCTION:STDIO
+EVP_DecryptFinal 2046 1_1_0 EXIST::FUNCTION:
+ASN1_ENUMERATED_it 2047 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_ENUMERATED_it 2047 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+o2i_ECPublicKey 2048 1_1_0 EXIST::FUNCTION:EC
+ERR_load_BUF_strings 2049 1_1_0 EXIST::FUNCTION:
+PEM_read_bio_RSA_PUBKEY 2050 1_1_0 EXIST::FUNCTION:RSA
+OCSP_SINGLERESP_new 2051 1_1_0 EXIST::FUNCTION:OCSP
+ASN1_SCTX_free 2052 1_1_0 EXIST::FUNCTION:
+i2d_ECPrivateKey_fp 2053 1_1_0 EXIST::FUNCTION:EC,STDIO
+EVP_CIPHER_CTX_original_iv 2054 1_1_0 EXIST::FUNCTION:
+PKCS7_SIGNED_free 2055 1_1_0 EXIST::FUNCTION:
+X509_TRUST_get0_name 2056 1_1_0 EXIST::FUNCTION:
+ENGINE_get_load_pubkey_function 2057 1_1_0 EXIST::FUNCTION:ENGINE
+UI_get_default_method 2058 1_1_0 EXIST::FUNCTION:UI
+PKCS12_add_CSPName_asc 2059 1_1_0 EXIST::FUNCTION:
+PEM_write_PUBKEY 2060 1_1_0 EXIST::FUNCTION:STDIO
+UI_method_set_prompt_constructor 2061 1_1_0 EXIST::FUNCTION:UI
+OBJ_length 2062 1_1_0 EXIST::FUNCTION:
+BN_GENCB_get_arg 2063 1_1_0 EXIST::FUNCTION:
+EVP_MD_CTX_clear_flags 2064 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_get_verifyctx 2065 1_1_0 EXIST::FUNCTION:
+CT_POLICY_EVAL_CTX_get0_cert 2066 1_1_0 EXIST::FUNCTION:CT
+PEM_write_DHparams 2067 1_1_0 EXIST::FUNCTION:DH,STDIO
+DH_set_ex_data 2068 1_1_0 EXIST::FUNCTION:DH
+OCSP_SIGNATURE_free 2069 1_1_0 EXIST::FUNCTION:OCSP
+CRYPTO_128_unwrap_pad 2070 1_1_0 EXIST::FUNCTION:
+BIO_new_CMS 2071 1_1_0 EXIST::FUNCTION:CMS
+i2d_ASN1_ENUMERATED 2072 1_1_0 EXIST::FUNCTION:
+PEM_read_DSAparams 2073 1_1_0 EXIST::FUNCTION:DSA,STDIO
+TS_TST_INFO_set_ordering 2074 1_1_0 EXIST::FUNCTION:TS
+MDC2_Init 2075 1_1_0 EXIST::FUNCTION:MDC2
+i2o_SCT 2076 1_1_0 EXIST::FUNCTION:CT
+d2i_TS_STATUS_INFO 2077 1_1_0 EXIST::FUNCTION:TS
+ERR_error_string_n 2078 1_1_0 EXIST::FUNCTION:
+HMAC 2079 1_1_0 EXIST::FUNCTION:
+BN_mul 2080 1_1_0 EXIST::FUNCTION:
+BN_get0_nist_prime_384 2081 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_set1_ip_asc 2082 1_1_0 EXIST::FUNCTION:
+CONF_modules_load 2083 1_1_0 EXIST::FUNCTION:
+d2i_RSAPublicKey 2084 1_1_0 EXIST::FUNCTION:RSA
+i2d_ASN1_GENERALSTRING 2085 1_1_0 EXIST::FUNCTION:
+POLICYQUALINFO_new 2086 1_1_0 EXIST::FUNCTION:
+PKCS7_RECIP_INFO_get0_alg 2087 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_base_id 2088 1_1_0 EXIST::FUNCTION:
+UI_method_set_opener 2089 1_1_0 EXIST::FUNCTION:UI
+X509v3_get_ext_by_NID 2090 1_1_0 EXIST::FUNCTION:
+TS_CONF_set_policies 2091 1_1_0 EXIST::FUNCTION:TS
+CMS_SignerInfo_cert_cmp 2092 1_1_0 EXIST::FUNCTION:CMS
+PEM_read 2093 1_1_0 EXIST::FUNCTION:STDIO
+X509_STORE_set_depth 2094 1_1_0 EXIST::FUNCTION:
+EC_KEY_METHOD_get_sign 2095 1_1_0 EXIST::FUNCTION:EC
+EVP_CIPHER_CTX_iv 2096 1_1_0 EXIST::FUNCTION:
+i2d_ESS_SIGNING_CERT 2097 1_1_0 EXIST::FUNCTION:TS
+TS_RESP_set_tst_info 2098 1_1_0 EXIST::FUNCTION:TS
+EVP_PKEY_CTX_set_data 2099 1_1_0 EXIST::FUNCTION:
+CMS_EnvelopedData_create 2100 1_1_0 EXIST::FUNCTION:CMS
+SCT_new 2101 1_1_0 EXIST::FUNCTION:CT
+X509_REQ_add1_attr 2102 1_1_0 EXIST::FUNCTION:
+X509_get_ext_count 2103 1_1_0 EXIST::FUNCTION:
+CRYPTO_cts128_decrypt 2104 1_1_0 EXIST::FUNCTION:
+ASYNC_WAIT_CTX_get_fd 2105 1_1_0 EXIST::FUNCTION:
+i2d_TS_REQ 2106 1_1_0 EXIST::FUNCTION:TS
+OCSP_ONEREQ_add1_ext_i2d 2107 1_1_0 EXIST::FUNCTION:OCSP
+ENGINE_register_pkey_meths 2108 1_1_0 EXIST::FUNCTION:ENGINE
+ENGINE_load_public_key 2109 1_1_0 EXIST::FUNCTION:ENGINE
+ASIdOrRange_it 2110 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:RFC3779
+ASIdOrRange_it 2110 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:RFC3779
+DHparams_print_fp 2111 1_1_0 EXIST::FUNCTION:DH,STDIO
+ERR_load_CRYPTO_strings 2112 1_1_0 EXIST:!VMS:FUNCTION:
+ERR_load_CRYPTOlib_strings 2112 1_1_0 EXIST:VMS:FUNCTION:
+X509_REQ_set_version 2113 1_1_0 EXIST::FUNCTION:
+d2i_ASN1_GENERALSTRING 2114 1_1_0 EXIST::FUNCTION:
+i2d_ASIdentifiers 2115 1_1_0 EXIST::FUNCTION:RFC3779
+X509V3_EXT_cleanup 2116 1_1_0 EXIST::FUNCTION:
+CAST_ecb_encrypt 2117 1_1_0 EXIST::FUNCTION:CAST
+BIO_s_file 2118 1_1_0 EXIST::FUNCTION:
+RSA_X931_derive_ex 2119 1_1_0 EXIST::FUNCTION:RSA
+EVP_PKEY_decrypt_init 2120 1_1_0 EXIST::FUNCTION:
+ENGINE_get_destroy_function 2121 1_1_0 EXIST::FUNCTION:ENGINE
+SHA224_Init 2122 1_1_0 EXIST::FUNCTION:
+X509V3_EXT_add_conf 2123 1_1_0 EXIST::FUNCTION:
+ASN1_object_size 2124 1_1_0 EXIST::FUNCTION:
+X509_REVOKED_free 2125 1_1_0 EXIST::FUNCTION:
+BN_mod_exp_recp 2126 1_1_0 EXIST::FUNCTION:
+EVP_mdc2 2127 1_1_0 EXIST::FUNCTION:MDC2
+EVP_des_cfb64 2128 1_1_0 EXIST::FUNCTION:DES
+PKCS7_sign 2129 1_1_0 EXIST::FUNCTION:
+OCSP_SINGLERESP_get_ext_by_critical 2130 1_1_0 EXIST::FUNCTION:OCSP
+EDIPARTYNAME_it 2131 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+EDIPARTYNAME_it 2131 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ERR_print_errors_fp 2132 1_1_0 EXIST::FUNCTION:STDIO
+BN_GF2m_mod_div_arr 2133 1_1_0 EXIST::FUNCTION:EC2M
+PKCS12_SAFEBAG_get0_attr 2134 1_1_0 EXIST::FUNCTION:
+BIO_s_mem 2135 1_1_0 EXIST::FUNCTION:
+OCSP_RESPDATA_new 2136 1_1_0 EXIST::FUNCTION:OCSP
+ASN1_item_i2d_fp 2137 1_1_0 EXIST::FUNCTION:STDIO
+BN_GF2m_mod_sqr 2138 1_1_0 EXIST::FUNCTION:EC2M
+ASN1_PRINTABLE_new 2139 1_1_0 EXIST::FUNCTION:
+OBJ_NAME_new_index 2140 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_asn1_add_alias 2141 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_get1_DSA 2142 1_1_0 EXIST::FUNCTION:DSA
+SEED_cbc_encrypt 2143 1_1_0 EXIST::FUNCTION:SEED
+EVP_rc2_40_cbc 2144 1_1_0 EXIST::FUNCTION:RC2
+ECDSA_SIG_new 2145 1_1_0 EXIST::FUNCTION:EC
+i2d_PKCS8PrivateKey_nid_fp 2146 1_1_0 EXIST::FUNCTION:STDIO
+X509_NAME_ENTRY_it 2147 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_NAME_ENTRY_it 2147 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+CRYPTO_THREAD_compare_id 2148 1_1_0 EXIST::FUNCTION:
+d2i_IPAddressChoice 2149 1_1_0 EXIST::FUNCTION:RFC3779
+IPAddressFamily_it 2150 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:RFC3779
+IPAddressFamily_it 2150 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:RFC3779
+ERR_load_OCSP_strings 2151 1_1_0 EXIST::FUNCTION:OCSP
+BIO_push 2152 1_1_0 EXIST::FUNCTION:
+ASN1_BMPSTRING_new 2153 1_1_0 EXIST::FUNCTION:
+COMP_get_type 2154 1_1_0 EXIST::FUNCTION:COMP
+d2i_ASIdentifierChoice 2155 1_1_0 EXIST::FUNCTION:RFC3779
+i2d_ASN1_T61STRING 2156 1_1_0 EXIST::FUNCTION:
+X509_add1_trust_object 2157 1_1_0 EXIST::FUNCTION:
+PEM_write_X509 2158 1_1_0 EXIST::FUNCTION:STDIO
+BN_CTX_free 2159 1_1_0 EXIST::FUNCTION:
+EC_GROUP_get_curve_GF2m 2160 1_1_0 EXIST::FUNCTION:EC,EC2M
+EVP_MD_flags 2161 1_1_0 EXIST::FUNCTION:
+OPENSSL_sk_set 2162 1_1_0 EXIST::FUNCTION:
+OCSP_request_sign 2163 1_1_0 EXIST::FUNCTION:OCSP
+BN_GF2m_mod_solve_quad 2164 1_1_0 EXIST::FUNCTION:EC2M
+EC_POINT_method_of 2165 1_1_0 EXIST::FUNCTION:EC
+PKCS7_ENCRYPT_it 2166 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS7_ENCRYPT_it 2166 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+AUTHORITY_INFO_ACCESS_it 2167 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+AUTHORITY_INFO_ACCESS_it 2167 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+X509_EXTENSION_create_by_NID 2168 1_1_0 EXIST::FUNCTION:
+i2d_RSAPrivateKey 2169 1_1_0 EXIST::FUNCTION:RSA
+d2i_CERTIFICATEPOLICIES 2170 1_1_0 EXIST::FUNCTION:
+CMAC_CTX_get0_cipher_ctx 2171 1_1_0 EXIST::FUNCTION:CMAC
+X509_STORE_load_locations 2172 1_1_0 EXIST::FUNCTION:
+OBJ_find_sigid_algs 2173 1_1_0 EXIST::FUNCTION:
+TS_RESP_CTX_set_accuracy 2174 1_1_0 EXIST::FUNCTION:TS
+NETSCAPE_SPKI_get_pubkey 2175 1_1_0 EXIST::FUNCTION:
+ECDSA_do_sign_ex 2176 1_1_0 EXIST::FUNCTION:EC
+OCSP_ONEREQ_get_ext 2177 1_1_0 EXIST::FUNCTION:OCSP
+BN_get_rfc3526_prime_4096 2179 1_1_0 EXIST::FUNCTION:
+d2i_PKCS7_fp 2180 1_1_0 EXIST::FUNCTION:STDIO
+PEM_write_bio_NETSCAPE_CERT_SEQUENCE 2181 1_1_0 EXIST::FUNCTION:
+PKCS12_AUTHSAFES_it 2182 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS12_AUTHSAFES_it 2182 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+EVP_MD_CTX_free 2183 1_1_0 EXIST::FUNCTION:
+CMS_RecipientInfo_kari_orig_id_cmp 2184 1_1_0 EXIST::FUNCTION:CMS
+NETSCAPE_SPKI_b64_encode 2185 1_1_0 EXIST::FUNCTION:
+d2i_PrivateKey 2186 1_1_0 EXIST::FUNCTION:
+EVP_MD_CTX_new 2187 1_1_0 EXIST::FUNCTION:
+X509_get0_tbs_sigalg 2189 1_1_0 EXIST::FUNCTION:
+ASN1_GENERALIZEDTIME_new 2190 1_1_0 EXIST::FUNCTION:
+d2i_ECDSA_SIG 2191 1_1_0 EXIST::FUNCTION:EC
+d2i_OTHERNAME 2192 1_1_0 EXIST::FUNCTION:
+i2d_TS_RESP_fp 2193 1_1_0 EXIST::FUNCTION:STDIO,TS
+OCSP_BASICRESP_get_ext_count 2194 1_1_0 EXIST::FUNCTION:OCSP
+ASN1_T61STRING_new 2195 1_1_0 EXIST::FUNCTION:
+BN_kronecker 2196 1_1_0 EXIST::FUNCTION:
+i2d_ACCESS_DESCRIPTION 2197 1_1_0 EXIST::FUNCTION:
+EVP_camellia_192_cfb8 2198 1_1_0 EXIST::FUNCTION:CAMELLIA
+X509_STORE_CTX_set_depth 2199 1_1_0 EXIST::FUNCTION:
+X509v3_delete_ext 2200 1_1_0 EXIST::FUNCTION:
+ASN1_STRING_set0 2201 1_1_0 EXIST::FUNCTION:
+BN_GF2m_add 2202 1_1_0 EXIST::FUNCTION:EC2M
+CMAC_resume 2203 1_1_0 EXIST::FUNCTION:CMAC
+TS_ACCURACY_set_millis 2204 1_1_0 EXIST::FUNCTION:TS
+X509V3_EXT_conf 2205 1_1_0 EXIST::FUNCTION:
+i2d_DHxparams 2206 1_1_0 EXIST::FUNCTION:DH
+EVP_CIPHER_CTX_free 2207 1_1_0 EXIST::FUNCTION:
+WHIRLPOOL_BitUpdate 2208 1_1_0 EXIST::FUNCTION:WHIRLPOOL
+EVP_idea_ecb 2209 1_1_0 EXIST::FUNCTION:IDEA
+i2d_TS_ACCURACY 2210 1_1_0 EXIST::FUNCTION:TS
+ASN1_VISIBLESTRING_free 2211 1_1_0 EXIST::FUNCTION:
+NCONF_load_bio 2212 1_1_0 EXIST::FUNCTION:
+DSA_get_default_method 2213 1_1_0 EXIST::FUNCTION:DSA
+OPENSSL_LH_retrieve 2214 1_1_0 EXIST::FUNCTION:
+CRYPTO_ccm128_decrypt_ccm64 2215 1_1_0 EXIST::FUNCTION:
+TS_RESP_CTX_set_clock_precision_digits 2216 1_1_0 EXIST::FUNCTION:TS
+SCT_LIST_validate 2217 1_1_0 EXIST::FUNCTION:CT
+X509_PURPOSE_get_id 2218 1_1_0 EXIST::FUNCTION:
+EC_KEY_get_ex_data 2219 1_1_0 EXIST::FUNCTION:EC
+EVP_MD_size 2220 1_1_0 EXIST::FUNCTION:
+CRYPTO_malloc 2221 1_1_0 EXIST::FUNCTION:
+ERR_load_ASN1_strings 2222 1_1_0 EXIST::FUNCTION:
+X509_REQ_get_extension_nids 2223 1_1_0 EXIST::FUNCTION:
+TS_REQ_get_ext_by_OBJ 2224 1_1_0 EXIST::FUNCTION:TS
+i2d_X509 2225 1_1_0 EXIST::FUNCTION:
+PEM_read_X509_AUX 2226 1_1_0 EXIST::FUNCTION:STDIO
+TS_VERIFY_CTX_set_flags 2227 1_1_0 EXIST::FUNCTION:TS
+IPAddressRange_new 2228 1_1_0 EXIST::FUNCTION:RFC3779
+TS_REQ_get_exts 2229 1_1_0 EXIST::FUNCTION:TS
+POLICY_CONSTRAINTS_new 2230 1_1_0 EXIST::FUNCTION:
+OTHERNAME_new 2231 1_1_0 EXIST::FUNCTION:
+BN_rshift 2232 1_1_0 EXIST::FUNCTION:
+i2d_GENERAL_NAMES 2233 1_1_0 EXIST::FUNCTION:
+EC_METHOD_get_field_type 2234 1_1_0 EXIST::FUNCTION:EC
+ENGINE_set_name 2235 1_1_0 EXIST::FUNCTION:ENGINE
+TS_TST_INFO_get_policy_id 2236 1_1_0 EXIST::FUNCTION:TS
+PKCS7_SIGNER_INFO_set 2237 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_PKCS8_PRIV_KEY_INFO 2238 1_1_0 EXIST::FUNCTION:
+EC_GROUP_set_curve_GF2m 2239 1_1_0 EXIST::FUNCTION:EC,EC2M
+ENGINE_load_builtin_engines 2240 1_1_0 EXIST::FUNCTION:ENGINE
+SRP_VBASE_init 2241 1_1_0 EXIST::FUNCTION:SRP
+SHA224_Final 2242 1_1_0 EXIST::FUNCTION:
+OCSP_CERTSTATUS_free 2243 1_1_0 EXIST::FUNCTION:OCSP
+d2i_TS_TST_INFO 2244 1_1_0 EXIST::FUNCTION:TS
+IPAddressOrRange_it 2245 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:RFC3779
+IPAddressOrRange_it 2245 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:RFC3779
+ENGINE_get_cipher 2246 1_1_0 EXIST::FUNCTION:ENGINE
+TS_TST_INFO_delete_ext 2247 1_1_0 EXIST::FUNCTION:TS
+TS_OBJ_print_bio 2248 1_1_0 EXIST::FUNCTION:TS
+X509_time_adj_ex 2249 1_1_0 EXIST::FUNCTION:
+OCSP_request_add1_cert 2250 1_1_0 EXIST::FUNCTION:OCSP
+ERR_load_X509_strings 2251 1_1_0 EXIST::FUNCTION:
+SHA1_Transform 2252 1_1_0 EXIST::FUNCTION:
+CMS_signed_get_attr_by_NID 2253 1_1_0 EXIST::FUNCTION:CMS
+X509_STORE_CTX_get_by_subject 2254 1_1_0 EXIST::FUNCTION:
+ASN1_OCTET_STRING_it 2255 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_OCTET_STRING_it 2255 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+OPENSSL_sk_set_cmp_func 2256 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_table_cleanup 2257 1_1_0 EXIST::FUNCTION:
+i2d_re_X509_REQ_tbs 2258 1_1_0 EXIST::FUNCTION:
+CONF_load_bio 2259 1_1_0 EXIST::FUNCTION:
+X509_ATTRIBUTE_get0_object 2260 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_missing_parameters 2261 1_1_0 EXIST::FUNCTION:
+X509_REQ_INFO_new 2262 1_1_0 EXIST::FUNCTION:
+EVP_rc2_cfb64 2263 1_1_0 EXIST::FUNCTION:RC2
+PKCS7_get_smimecap 2264 1_1_0 EXIST::FUNCTION:
+ERR_get_state 2265 1_1_0 EXIST::FUNCTION:
+d2i_DSAPrivateKey_bio 2266 1_1_0 EXIST::FUNCTION:DSA
+X509_PURPOSE_get_trust 2267 1_1_0 EXIST::FUNCTION:
+EC_GROUP_get_point_conversion_form 2268 1_1_0 EXIST::FUNCTION:EC
+ASN1_OBJECT_it 2269 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_OBJECT_it 2269 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+BN_mod_add_quick 2270 1_1_0 EXIST::FUNCTION:
+NCONF_free 2271 1_1_0 EXIST::FUNCTION:
+NETSCAPE_SPKI_b64_decode 2272 1_1_0 EXIST::FUNCTION:
+BIO_f_md 2273 1_1_0 EXIST::FUNCTION:
+EVP_MD_CTX_pkey_ctx 2274 1_1_0 EXIST::FUNCTION:
+ENGINE_set_default_EC 2275 1_1_0 EXIST::FUNCTION:ENGINE
+CMS_ReceiptRequest_free 2276 1_1_0 EXIST::FUNCTION:CMS
+TS_STATUS_INFO_get0_text 2277 1_1_0 EXIST::FUNCTION:TS
+CRYPTO_get_ex_new_index 2278 1_1_0 EXIST::FUNCTION:
+ASN1_PCTX_set_flags 2279 1_1_0 EXIST::FUNCTION:
+PEM_write_X509_CRL 2280 1_1_0 EXIST::FUNCTION:STDIO
+BF_cbc_encrypt 2281 1_1_0 EXIST::FUNCTION:BF
+BN_num_bits_word 2282 1_1_0 EXIST::FUNCTION:
+EVP_DecodeInit 2283 1_1_0 EXIST::FUNCTION:
+BN_ucmp 2284 1_1_0 EXIST::FUNCTION:
+SXNET_get_id_asc 2285 1_1_0 EXIST::FUNCTION:
+SCT_set1_extensions 2286 1_1_0 EXIST::FUNCTION:CT
+PKCS12_SAFEBAG_new 2287 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_set_nonce 2288 1_1_0 EXIST::FUNCTION:TS
+PEM_read_ECPrivateKey 2289 1_1_0 EXIST::FUNCTION:EC,STDIO
+RSA_free 2290 1_1_0 EXIST::FUNCTION:RSA
+X509_CRL_INFO_new 2291 1_1_0 EXIST::FUNCTION:
+AES_cfb8_encrypt 2292 1_1_0 EXIST::FUNCTION:
+d2i_ASN1_SEQUENCE_ANY 2293 1_1_0 EXIST::FUNCTION:
+PKCS12_create 2294 1_1_0 EXIST::FUNCTION:
+X509at_get_attr_count 2295 1_1_0 EXIST::FUNCTION:
+PKCS12_init 2296 1_1_0 EXIST::FUNCTION:
+CRYPTO_free_ex_data 2297 1_1_0 EXIST::FUNCTION:
+EVP_aes_128_cfb8 2298 1_1_0 EXIST::FUNCTION:
+ESS_ISSUER_SERIAL_free 2299 1_1_0 EXIST::FUNCTION:TS
+BN_mod_exp_mont_word 2300 1_1_0 EXIST::FUNCTION:
+X509V3_EXT_nconf_nid 2301 1_1_0 EXIST::FUNCTION:
+UTF8_putc 2302 1_1_0 EXIST::FUNCTION:
+RSA_private_encrypt 2303 1_1_0 EXIST::FUNCTION:RSA
+X509_LOOKUP_shutdown 2304 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_set_accuracy 2305 1_1_0 EXIST::FUNCTION:TS
+OCSP_basic_verify 2306 1_1_0 EXIST::FUNCTION:OCSP
+X509at_add1_attr_by_OBJ 2307 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_asn1_add0 2308 1_1_0 EXIST::FUNCTION:
+PKCS12_SAFEBAG_get1_crl 2309 1_1_0 EXIST::FUNCTION:
+ASN1_STRING_get_default_mask 2310 1_1_0 EXIST::FUNCTION:
+X509_alias_set1 2311 1_1_0 EXIST::FUNCTION:
+ASN1_item_unpack 2312 1_1_0 EXIST::FUNCTION:
+HMAC_CTX_free 2313 1_1_0 EXIST::FUNCTION:
+EC_POINT_new 2314 1_1_0 EXIST::FUNCTION:EC
+PKCS7_ISSUER_AND_SERIAL_digest 2315 1_1_0 EXIST::FUNCTION:
+EVP_des_ofb 2316 1_1_0 EXIST::FUNCTION:DES
+DSA_set_method 2317 1_1_0 EXIST::FUNCTION:DSA
+EVP_PKEY_get1_RSA 2318 1_1_0 EXIST::FUNCTION:RSA
+EC_KEY_OpenSSL 2319 1_1_0 EXIST::FUNCTION:EC
+EVP_camellia_192_ofb 2320 1_1_0 EXIST::FUNCTION:CAMELLIA
+ASN1_STRING_length 2321 1_1_0 EXIST::FUNCTION:
+PKCS7_set_digest 2322 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_PUBKEY 2323 1_1_0 EXIST::FUNCTION:
+PEM_read_PKCS7 2324 1_1_0 EXIST::FUNCTION:STDIO
+DH_get_2048_256 2325 1_1_0 EXIST::FUNCTION:DH
+X509at_delete_attr 2326 1_1_0 EXIST::FUNCTION:
+PEM_write_bio 2327 1_1_0 EXIST::FUNCTION:
+CMS_signed_get_attr_by_OBJ 2329 1_1_0 EXIST::FUNCTION:CMS
+X509_REVOKED_add_ext 2330 1_1_0 EXIST::FUNCTION:
+EVP_CipherUpdate 2331 1_1_0 EXIST::FUNCTION:
+Camellia_cfb8_encrypt 2332 1_1_0 EXIST::FUNCTION:CAMELLIA
+EVP_aes_256_xts 2333 1_1_0 EXIST::FUNCTION:
+EVP_DigestSignFinal 2334 1_1_0 EXIST::FUNCTION:
+ASN1_STRING_cmp 2335 1_1_0 EXIST::FUNCTION:
+EVP_chacha20_poly1305 2336 1_1_0 EXIST::FUNCTION:CHACHA,POLY1305
+OPENSSL_sk_zero 2337 1_1_0 EXIST::FUNCTION:
+ASN1_PRINTABLE_type 2338 1_1_0 EXIST::FUNCTION:
+TS_CONF_set_ess_cert_id_chain 2339 1_1_0 EXIST::FUNCTION:TS
+PEM_read_DSAPrivateKey 2340 1_1_0 EXIST::FUNCTION:DSA,STDIO
+DH_generate_parameters_ex 2341 1_1_0 EXIST::FUNCTION:DH
+UI_dup_input_string 2342 1_1_0 EXIST::FUNCTION:UI
+X509_keyid_set1 2343 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_set1 2344 1_1_0 EXIST::FUNCTION:
+EC_GROUP_get_asn1_flag 2345 1_1_0 EXIST::FUNCTION:EC
+CMS_decrypt_set1_password 2346 1_1_0 EXIST::FUNCTION:CMS
+BIO_copy_next_retry 2347 1_1_0 EXIST::FUNCTION:
+X509_POLICY_NODE_print 2348 1_1_0 EXIST::FUNCTION:
+ASN1_TIME_diff 2349 1_1_0 EXIST::FUNCTION:
+BIO_s_fd 2350 1_1_0 EXIST::FUNCTION:
+i2d_CMS_bio 2351 1_1_0 EXIST::FUNCTION:CMS
+CRYPTO_gcm128_decrypt 2352 1_1_0 EXIST::FUNCTION:
+EVP_aes_256_ctr 2353 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_bits 2354 1_1_0 EXIST::FUNCTION:
+BN_BLINDING_new 2355 1_1_0 EXIST::FUNCTION:
+ASN1_GENERALIZEDTIME_check 2356 1_1_0 EXIST::FUNCTION:
+BN_clear_bit 2357 1_1_0 EXIST::FUNCTION:
+BN_bn2lebinpad 2358 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_up_ref 2359 1_1_0 EXIST::FUNCTION:
+X509_getm_notBefore 2360 1_1_0 EXIST::FUNCTION:
+BN_nist_mod_224 2361 1_1_0 EXIST::FUNCTION:
+DES_decrypt3 2362 1_1_0 EXIST::FUNCTION:DES
+OTHERNAME_it 2363 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+OTHERNAME_it 2363 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+X509at_add1_attr_by_txt 2364 1_1_0 EXIST::FUNCTION:
+PKCS7_SIGN_ENVELOPE_free 2365 1_1_0 EXIST::FUNCTION:
+BIO_dgram_is_sctp 2366 1_1_0 EXIST::FUNCTION:DGRAM,SCTP
+DH_check 2367 1_1_0 EXIST::FUNCTION:DH
+Camellia_set_key 2368 1_1_0 EXIST::FUNCTION:CAMELLIA
+X509_LOOKUP_by_issuer_serial 2369 1_1_0 EXIST::FUNCTION:
+ASN1_BMPSTRING_free 2370 1_1_0 EXIST::FUNCTION:
+BIO_new_accept 2371 1_1_0 EXIST::FUNCTION:SOCK
+GENERAL_NAME_new 2372 1_1_0 EXIST::FUNCTION:
+DES_encrypt3 2373 1_1_0 EXIST::FUNCTION:DES
+PKCS7_get_signer_info 2374 1_1_0 EXIST::FUNCTION:
+ASN1_OCTET_STRING_set 2375 1_1_0 EXIST::FUNCTION:
+BN_mask_bits 2376 1_1_0 EXIST::FUNCTION:
+ASN1_UTF8STRING_it 2377 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_UTF8STRING_it 2377 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ASN1_SCTX_set_app_data 2378 1_1_0 EXIST::FUNCTION:
+CMS_add0_cert 2379 1_1_0 EXIST::FUNCTION:CMS
+i2d_GENERAL_NAME 2380 1_1_0 EXIST::FUNCTION:
+BIO_ADDR_new 2381 1_1_0 EXIST::FUNCTION:SOCK
+ENGINE_get_pkey_asn1_meth_engine 2382 1_1_0 EXIST::FUNCTION:ENGINE
+d2i_ASN1_BMPSTRING 2383 1_1_0 EXIST::FUNCTION:
+PKCS12_SAFEBAG_create0_p8inf 2384 1_1_0 EXIST::FUNCTION:
+OBJ_cmp 2385 1_1_0 EXIST::FUNCTION:
+MD2 2386 1_1_0 EXIST::FUNCTION:MD2
+X509_PUBKEY_new 2387 1_1_0 EXIST::FUNCTION:
+BN_CTX_end 2388 1_1_0 EXIST::FUNCTION:
+BIO_get_retry_BIO 2389 1_1_0 EXIST::FUNCTION:
+X509_REQ_add1_attr_by_OBJ 2390 1_1_0 EXIST::FUNCTION:
+ASN1_item_ex_free 2391 1_1_0 EXIST::FUNCTION:
+X509_SIG_new 2392 1_1_0 EXIST::FUNCTION:
+BN_sqr 2393 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_set_time 2394 1_1_0 EXIST::FUNCTION:TS
+OPENSSL_die 2395 1_1_0 EXIST::FUNCTION:
+X509_LOOKUP_by_alias 2396 1_1_0 EXIST::FUNCTION:
+EC_KEY_set_conv_form 2397 1_1_0 EXIST::FUNCTION:EC
+X509_TRUST_get_count 2399 1_1_0 EXIST::FUNCTION:
+IPAddressOrRange_free 2400 1_1_0 EXIST::FUNCTION:RFC3779
+RSA_padding_add_PKCS1_OAEP 2401 1_1_0 EXIST::FUNCTION:RSA
+EC_KEY_set_ex_data 2402 1_1_0 EXIST::FUNCTION:EC
+SRP_VBASE_new 2403 1_1_0 EXIST::FUNCTION:SRP
+i2d_ECDSA_SIG 2404 1_1_0 EXIST::FUNCTION:EC
+BIO_dump_indent 2405 1_1_0 EXIST::FUNCTION:
+ENGINE_set_pkey_asn1_meths 2406 1_1_0 EXIST::FUNCTION:ENGINE
+OPENSSL_gmtime_diff 2407 1_1_0 EXIST::FUNCTION:
+TS_CONF_set_crypto_device 2408 1_1_0 EXIST::FUNCTION:ENGINE,TS
+COMP_CTX_get_method 2409 1_1_0 EXIST::FUNCTION:COMP
+EC_GROUP_get_cofactor 2410 1_1_0 EXIST::FUNCTION:EC
+EVP_rc5_32_12_16_ofb 2411 1_1_0 EXIST::FUNCTION:RC5
+EVP_MD_CTX_md_data 2412 1_1_0 EXIST::FUNCTION:
+ASN1_PCTX_set_nm_flags 2413 1_1_0 EXIST::FUNCTION:
+BIO_ctrl 2414 1_1_0 EXIST::FUNCTION:
+X509_CRL_set_default_method 2415 1_1_0 EXIST::FUNCTION:
+d2i_RSAPublicKey_fp 2417 1_1_0 EXIST::FUNCTION:RSA,STDIO
+UI_method_get_flusher 2418 1_1_0 EXIST::FUNCTION:UI
+EC_POINT_dbl 2419 1_1_0 EXIST::FUNCTION:EC
+i2d_X509_CRL_INFO 2420 1_1_0 EXIST::FUNCTION:
+i2d_OCSP_CERTSTATUS 2421 1_1_0 EXIST::FUNCTION:OCSP
+X509_REVOKED_get0_revocationDate 2422 1_1_0 EXIST::FUNCTION:
+PKCS7_add_crl 2423 1_1_0 EXIST::FUNCTION:
+ECDSA_do_sign 2424 1_1_0 EXIST::FUNCTION:EC
+ASN1_GENERALIZEDTIME_it 2425 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_GENERALIZEDTIME_it 2425 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+PKCS8_pkey_get0 2426 1_1_0 EXIST::FUNCTION:
+OCSP_sendreq_new 2427 1_1_0 EXIST::FUNCTION:OCSP
+EVP_aes_256_cfb128 2428 1_1_0 EXIST::FUNCTION:
+RSA_set_ex_data 2429 1_1_0 EXIST::FUNCTION:RSA
+BN_GENCB_call 2430 1_1_0 EXIST::FUNCTION:
+X509V3_EXT_add_nconf_sk 2431 1_1_0 EXIST::FUNCTION:
+i2d_TS_MSG_IMPRINT_fp 2432 1_1_0 EXIST::FUNCTION:STDIO,TS
+PKCS12_new 2433 1_1_0 EXIST::FUNCTION:
+X509_REVOKED_set_serialNumber 2434 1_1_0 EXIST::FUNCTION:
+EVP_get_digestbyname 2435 1_1_0 EXIST::FUNCTION:
+X509_CRL_get_lastUpdate 2436 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0
+OBJ_create_objects 2437 1_1_0 EXIST::FUNCTION:
+EVP_enc_null 2438 1_1_0 EXIST::FUNCTION:
+OCSP_ONEREQ_get_ext_by_critical 2439 1_1_0 EXIST::FUNCTION:OCSP
+OCSP_request_onereq_count 2440 1_1_0 EXIST::FUNCTION:OCSP
+BN_hex2bn 2441 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_meth_set_impl_ctx_size 2442 1_1_0 EXIST::FUNCTION:
+ASIdentifiers_new 2443 1_1_0 EXIST::FUNCTION:RFC3779
+CONF_imodule_get_flags 2444 1_1_0 EXIST::FUNCTION:
+PKCS12_SAFEBAG_it 2445 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS12_SAFEBAG_it 2445 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+EVP_CIPHER_meth_set_set_asn1_params 2446 1_1_0 EXIST::FUNCTION:
+EC_KEY_get_enc_flags 2447 1_1_0 EXIST::FUNCTION:EC
+X509_OBJECT_idx_by_subject 2448 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_copy 2449 1_1_0 EXIST::FUNCTION:
+NETSCAPE_CERT_SEQUENCE_new 2450 1_1_0 EXIST::FUNCTION:
+CRYPTO_ocb128_decrypt 2451 1_1_0 EXIST::FUNCTION:OCB
+ASYNC_WAIT_CTX_free 2452 1_1_0 EXIST::FUNCTION:
+d2i_PKCS7_DIGEST 2453 1_1_0 EXIST::FUNCTION:
+d2i_TS_TST_INFO_bio 2454 1_1_0 EXIST::FUNCTION:TS
+BIGNUM_it 2455 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+BIGNUM_it 2455 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+BN_BLINDING_get_flags 2456 1_1_0 EXIST::FUNCTION:
+X509_EXTENSION_get_critical 2457 1_1_0 EXIST::FUNCTION:
+DSA_set_default_method 2458 1_1_0 EXIST::FUNCTION:DSA
+PEM_write_bio_DHxparams 2459 1_1_0 EXIST::FUNCTION:DH
+DSA_set_ex_data 2460 1_1_0 EXIST::FUNCTION:DSA
+BIO_s_datagram_sctp 2461 1_1_0 EXIST::FUNCTION:DGRAM,SCTP
+SXNET_add_id_asc 2462 1_1_0 EXIST::FUNCTION:
+X509_print_fp 2463 1_1_0 EXIST::FUNCTION:STDIO
+TS_REQ_set_version 2464 1_1_0 EXIST::FUNCTION:TS
+OCSP_REQINFO_new 2465 1_1_0 EXIST::FUNCTION:OCSP
+Camellia_decrypt 2466 1_1_0 EXIST::FUNCTION:CAMELLIA
+X509_signature_print 2467 1_1_0 EXIST::FUNCTION:
+EVP_camellia_128_ecb 2468 1_1_0 EXIST::FUNCTION:CAMELLIA
+MD2_Final 2469 1_1_0 EXIST::FUNCTION:MD2
+OCSP_REQ_CTX_add1_header 2470 1_1_0 EXIST::FUNCTION:OCSP
+NETSCAPE_SPKAC_it 2471 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+NETSCAPE_SPKAC_it 2471 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ASIdOrRange_free 2472 1_1_0 EXIST::FUNCTION:RFC3779
+EC_POINT_get_Jprojective_coordinates_GFp 2473 1_1_0 EXIST::FUNCTION:EC
+EVP_aes_128_cbc_hmac_sha256 2474 1_1_0 EXIST::FUNCTION:
+i2d_PKCS7_SIGNED 2475 1_1_0 EXIST::FUNCTION:
+TS_VERIFY_CTX_set_data 2476 1_1_0 EXIST::FUNCTION:TS
+BN_pseudo_rand_range 2477 1_1_0 EXIST::FUNCTION:
+X509V3_EXT_add_nconf 2478 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_CTX_ctrl 2479 1_1_0 EXIST::FUNCTION:
+ASN1_T61STRING_it 2480 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_T61STRING_it 2480 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ENGINE_get_prev 2481 1_1_0 EXIST::FUNCTION:ENGINE
+OCSP_accept_responses_new 2482 1_1_0 EXIST::FUNCTION:OCSP
+ERR_load_EC_strings 2483 1_1_0 EXIST::FUNCTION:EC
+X509V3_string_free 2484 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_set_paramgen 2485 1_1_0 EXIST::FUNCTION:
+ENGINE_set_load_ssl_client_cert_function 2486 1_1_0 EXIST::FUNCTION:ENGINE
+EVP_ENCODE_CTX_free 2487 1_1_0 EXIST::FUNCTION:
+i2d_ASN1_BIT_STRING 2488 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_set_verifyctx 2489 1_1_0 EXIST::FUNCTION:
+X509_TRUST_add 2490 1_1_0 EXIST::FUNCTION:
+BUF_MEM_free 2491 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_get_accuracy 2492 1_1_0 EXIST::FUNCTION:TS
+TS_REQ_dup 2493 1_1_0 EXIST::FUNCTION:TS
+ASN1_STRING_type_new 2494 1_1_0 EXIST::FUNCTION:
+TS_STATUS_INFO_free 2495 1_1_0 EXIST::FUNCTION:TS
+BN_mod_mul 2496 1_1_0 EXIST::FUNCTION:
+CMS_add0_recipient_key 2497 1_1_0 EXIST::FUNCTION:CMS
+BIO_f_zlib 2498 1_1_0 EXIST:ZLIB:FUNCTION:COMP
+AES_cfb128_encrypt 2499 1_1_0 EXIST::FUNCTION:
+ENGINE_set_EC 2500 1_1_0 EXIST::FUNCTION:ENGINE
+d2i_ECPKParameters 2501 1_1_0 EXIST::FUNCTION:EC
+IDEA_ofb64_encrypt 2502 1_1_0 EXIST::FUNCTION:IDEA
+CAST_decrypt 2503 1_1_0 EXIST::FUNCTION:CAST
+TS_STATUS_INFO_get0_failure_info 2504 1_1_0 EXIST::FUNCTION:TS
+ENGINE_unregister_pkey_meths 2506 1_1_0 EXIST::FUNCTION:ENGINE
+DISPLAYTEXT_new 2507 1_1_0 EXIST::FUNCTION:
+CMS_final 2508 1_1_0 EXIST::FUNCTION:CMS
+BIO_nwrite 2509 1_1_0 EXIST::FUNCTION:
+GENERAL_NAME_free 2510 1_1_0 EXIST::FUNCTION:
+PKCS12_pack_p7encdata 2511 1_1_0 EXIST::FUNCTION:
+BN_generate_dsa_nonce 2512 1_1_0 EXIST::FUNCTION:
+X509_verify_cert 2513 1_1_0 EXIST::FUNCTION:
+X509_policy_level_get0_node 2514 1_1_0 EXIST::FUNCTION:
+X509_REQ_get_attr 2515 1_1_0 EXIST::FUNCTION:
+SHA1 2516 1_1_0 EXIST::FUNCTION:
+X509_print 2517 1_1_0 EXIST::FUNCTION:
+d2i_AutoPrivateKey 2518 1_1_0 EXIST::FUNCTION:
+X509_REQ_new 2519 1_1_0 EXIST::FUNCTION:
+PKCS12_add_safes 2520 1_1_0 EXIST::FUNCTION:
+PKCS12_parse 2521 1_1_0 EXIST::FUNCTION:
+BN_GF2m_mod_div 2522 1_1_0 EXIST::FUNCTION:EC2M
+i2d_USERNOTICE 2523 1_1_0 EXIST::FUNCTION:
+d2i_NETSCAPE_SPKI 2524 1_1_0 EXIST::FUNCTION:
+CRYPTO_mem_leaks 2525 1_1_0 EXIST::FUNCTION:CRYPTO_MDEBUG
+BN_get_rfc3526_prime_1536 2526 1_1_0 EXIST::FUNCTION:
+DSA_sign 2527 1_1_0 EXIST::FUNCTION:DSA
+RAND_egd 2528 1_1_0 EXIST::FUNCTION:EGD
+ASN1_d2i_bio 2529 1_1_0 EXIST::FUNCTION:
+X509_REQ_digest 2531 1_1_0 EXIST::FUNCTION:
+X509_set1_notAfter 2532 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_type 2533 1_1_0 EXIST::FUNCTION:
+ASN1_TYPE_set_octetstring 2534 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_asn1_set_free 2535 1_1_0 EXIST::FUNCTION:
+CMS_signed_get0_data_by_OBJ 2536 1_1_0 EXIST::FUNCTION:CMS
+X509_PURPOSE_add 2537 1_1_0 EXIST::FUNCTION:
+PKCS7_ENVELOPE_free 2538 1_1_0 EXIST::FUNCTION:
+PKCS12_key_gen_uni 2539 1_1_0 EXIST::FUNCTION:
+WHIRLPOOL 2540 1_1_0 EXIST::FUNCTION:WHIRLPOOL
+UI_set_default_method 2542 1_1_0 EXIST::FUNCTION:UI
+EC_POINT_is_at_infinity 2543 1_1_0 EXIST::FUNCTION:EC
+i2d_NOTICEREF 2544 1_1_0 EXIST::FUNCTION:
+EC_KEY_new 2545 1_1_0 EXIST::FUNCTION:EC
+EVP_chacha20 2546 1_1_0 EXIST::FUNCTION:CHACHA
+BN_bn2dec 2547 1_1_0 EXIST::FUNCTION:
+X509_REQ_print_ex 2548 1_1_0 EXIST::FUNCTION:
+PEM_read_CMS 2549 1_1_0 EXIST::FUNCTION:CMS,STDIO
+d2i_NETSCAPE_CERT_SEQUENCE 2550 1_1_0 EXIST::FUNCTION:
+X509_CRL_set_version 2551 1_1_0 EXIST::FUNCTION:
+ASN1_PCTX_set_cert_flags 2552 1_1_0 EXIST::FUNCTION:
+PKCS8_PRIV_KEY_INFO_free 2553 1_1_0 EXIST::FUNCTION:
+SHA224_Update 2554 1_1_0 EXIST::FUNCTION:
+EC_GROUP_new_by_curve_name 2555 1_1_0 EXIST::FUNCTION:EC
+X509_STORE_set_purpose 2556 1_1_0 EXIST::FUNCTION:
+X509_CRL_get0_signature 2557 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_CTX_get_keygen_info 2558 1_1_0 EXIST::FUNCTION:
+d2i_ASN1_UINTEGER 2559 1_1_0 EXIST::FUNCTION:
+i2s_ASN1_INTEGER 2560 1_1_0 EXIST::FUNCTION:
+d2i_EC_PUBKEY_fp 2561 1_1_0 EXIST::FUNCTION:EC,STDIO
+i2d_OCSP_SIGNATURE 2562 1_1_0 EXIST::FUNCTION:OCSP
+i2d_X509_EXTENSION 2563 1_1_0 EXIST::FUNCTION:
+PEM_read_bio_X509 2564 1_1_0 EXIST::FUNCTION:
+DES_key_sched 2565 1_1_0 EXIST::FUNCTION:DES
+GENERAL_NAME_dup 2566 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get1_crls 2567 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_set_verify 2568 1_1_0 EXIST::FUNCTION:
+EVP_sha256 2569 1_1_0 EXIST::FUNCTION:
+CMS_unsigned_delete_attr 2570 1_1_0 EXIST::FUNCTION:CMS
+EVP_md5_sha1 2571 1_1_0 EXIST::FUNCTION:MD5
+EVP_PKEY_sign_init 2572 1_1_0 EXIST::FUNCTION:
+OPENSSL_LH_insert 2573 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_meth_get_cleanup 2574 1_1_0 EXIST::FUNCTION:
+ASN1_item_ex_d2i 2575 1_1_0 EXIST::FUNCTION:
+EVP_MD_meth_free 2576 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_new 2577 1_1_0 EXIST::FUNCTION:
+RSA_padding_check_PKCS1_OAEP 2578 1_1_0 EXIST::FUNCTION:RSA
+OCSP_SERVICELOC_it 2579 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:OCSP
+OCSP_SERVICELOC_it 2579 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:OCSP
+PKCS12_SAFEBAG_get_nid 2580 1_1_0 EXIST::FUNCTION:
+EVP_MD_CTX_set_update_fn 2581 1_1_0 EXIST::FUNCTION:
+BIO_f_asn1 2582 1_1_0 EXIST::FUNCTION:
+BIO_dump 2583 1_1_0 EXIST::FUNCTION:
+ENGINE_load_ssl_client_cert 2584 1_1_0 EXIST::FUNCTION:ENGINE
+X509_STORE_CTX_set_verify_cb 2585 1_1_0 EXIST::FUNCTION:
+CRYPTO_clear_realloc 2586 1_1_0 EXIST::FUNCTION:
+OPENSSL_strnlen 2587 1_1_0 EXIST::FUNCTION:
+IDEA_ecb_encrypt 2588 1_1_0 EXIST::FUNCTION:IDEA
+ASN1_STRING_set_default_mask 2589 1_1_0 EXIST::FUNCTION:
+TS_VERIFY_CTX_add_flags 2590 1_1_0 EXIST::FUNCTION:TS
+FIPS_mode 2591 1_1_0 EXIST::FUNCTION:
+d2i_ASN1_UNIVERSALSTRING 2592 1_1_0 EXIST::FUNCTION:
+NAME_CONSTRAINTS_free 2593 1_1_0 EXIST::FUNCTION:
+EC_GROUP_get_order 2594 1_1_0 EXIST::FUNCTION:EC
+X509_REVOKED_add1_ext_i2d 2595 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_add1_host 2596 1_1_0 EXIST::FUNCTION:
+i2d_PUBKEY_bio 2597 1_1_0 EXIST::FUNCTION:
+MD4_Update 2598 1_1_0 EXIST::FUNCTION:MD4
+X509_STORE_CTX_set_time 2599 1_1_0 EXIST::FUNCTION:
+ENGINE_set_default_DH 2600 1_1_0 EXIST::FUNCTION:ENGINE
+X509_ocspid_print 2601 1_1_0 EXIST::FUNCTION:
+DH_set_method 2602 1_1_0 EXIST::FUNCTION:DH
+EVP_rc2_64_cbc 2603 1_1_0 EXIST::FUNCTION:RC2
+CRYPTO_THREAD_get_current_id 2604 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_CTX_set_cb 2605 1_1_0 EXIST::FUNCTION:
+PROXY_POLICY_it 2606 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PROXY_POLICY_it 2606 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ENGINE_register_complete 2607 1_1_0 EXIST::FUNCTION:ENGINE
+EVP_DecodeUpdate 2609 1_1_0 EXIST::FUNCTION:
+ENGINE_get_default_RAND 2610 1_1_0 EXIST::FUNCTION:ENGINE
+ERR_peek_last_error_line 2611 1_1_0 EXIST::FUNCTION:
+ENGINE_get_ssl_client_cert_function 2612 1_1_0 EXIST::FUNCTION:ENGINE
+OPENSSL_LH_node_usage_stats 2613 1_1_0 EXIST::FUNCTION:STDIO
+DIRECTORYSTRING_it 2614 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+DIRECTORYSTRING_it 2614 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+BIO_write 2615 1_1_0 EXIST::FUNCTION:
+OCSP_ONEREQ_get_ext_by_OBJ 2616 1_1_0 EXIST::FUNCTION:OCSP
+SEED_encrypt 2617 1_1_0 EXIST::FUNCTION:SEED
+IPAddressRange_it 2618 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:RFC3779
+IPAddressRange_it 2618 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:RFC3779
+PEM_read_bio_DSAPrivateKey 2619 1_1_0 EXIST::FUNCTION:DSA
+CMS_get0_type 2620 1_1_0 EXIST::FUNCTION:CMS
+ASN1_PCTX_free 2621 1_1_0 EXIST::FUNCTION:
+ESS_SIGNING_CERT_new 2622 1_1_0 EXIST::FUNCTION:TS
+X509V3_EXT_conf_nid 2623 1_1_0 EXIST::FUNCTION:
+EC_KEY_check_key 2624 1_1_0 EXIST::FUNCTION:EC
+PKCS5_PBKDF2_HMAC 2625 1_1_0 EXIST::FUNCTION:
+CONF_get_section 2626 1_1_0 EXIST::FUNCTION:
+CMS_RecipientInfo_kari_decrypt 2627 1_1_0 EXIST::FUNCTION:CMS
+OBJ_add_sigid 2628 1_1_0 EXIST::FUNCTION:
+d2i_SXNETID 2629 1_1_0 EXIST::FUNCTION:
+CMS_get1_certs 2630 1_1_0 EXIST::FUNCTION:CMS
+X509_CRL_check_suiteb 2631 1_1_0 EXIST::FUNCTION:
+PKCS7_ENVELOPE_it 2632 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS7_ENVELOPE_it 2632 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ASIdentifierChoice_it 2633 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:RFC3779
+ASIdentifierChoice_it 2633 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:RFC3779
+CMS_RecipientEncryptedKey_cert_cmp 2634 1_1_0 EXIST::FUNCTION:CMS
+EVP_PKEY_CTX_get_app_data 2635 1_1_0 EXIST::FUNCTION:
+EC_GROUP_clear_free 2636 1_1_0 EXIST::FUNCTION:EC
+BN_get_rfc2409_prime_1024 2637 1_1_0 EXIST::FUNCTION:
+CRYPTO_set_mem_functions 2638 1_1_0 EXIST::FUNCTION:
+i2d_ASN1_VISIBLESTRING 2639 1_1_0 EXIST::FUNCTION:
+d2i_PBKDF2PARAM 2640 1_1_0 EXIST::FUNCTION:
+ERR_load_COMP_strings 2641 1_1_0 EXIST::FUNCTION:COMP
+EVP_PKEY_meth_add0 2642 1_1_0 EXIST::FUNCTION:
+EVP_rc4_40 2643 1_1_0 EXIST::FUNCTION:RC4
+RSA_bits 2645 1_1_0 EXIST::FUNCTION:RSA
+ASN1_item_dup 2646 1_1_0 EXIST::FUNCTION:
+GENERAL_NAMES_it 2647 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+GENERAL_NAMES_it 2647 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+X509_issuer_name_hash 2648 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_get_nonce 2649 1_1_0 EXIST::FUNCTION:TS
+MD4_Init 2650 1_1_0 EXIST::FUNCTION:MD4
+X509_EXTENSION_create_by_OBJ 2651 1_1_0 EXIST::FUNCTION:
+EVP_aes_256_cbc_hmac_sha1 2652 1_1_0 EXIST::FUNCTION:
+SCT_validate 2653 1_1_0 EXIST::FUNCTION:CT
+EC_GROUP_dup 2654 1_1_0 EXIST::FUNCTION:EC
+EVP_sha1 2655 1_1_0 EXIST::FUNCTION:
+OPENSSL_sk_new 2656 1_1_0 EXIST::FUNCTION:
+BN_dup 2657 1_1_0 EXIST::FUNCTION:
+TS_MSG_IMPRINT_print_bio 2658 1_1_0 EXIST::FUNCTION:TS
+CONF_module_set_usr_data 2659 1_1_0 EXIST::FUNCTION:
+EC_KEY_generate_key 2660 1_1_0 EXIST::FUNCTION:EC
+BIO_ctrl_get_write_guarantee 2661 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_assign 2662 1_1_0 EXIST::FUNCTION:
+EVP_aes_128_ofb 2663 1_1_0 EXIST::FUNCTION:
+CMS_data 2664 1_1_0 EXIST::FUNCTION:CMS
+X509_load_cert_file 2665 1_1_0 EXIST::FUNCTION:
+EC_GFp_nistp521_method 2667 1_1_0 EXIST::FUNCTION:EC,EC_NISTP_64_GCC_128
+ECDSA_SIG_free 2668 1_1_0 EXIST::FUNCTION:EC
+d2i_PKCS12_BAGS 2669 1_1_0 EXIST::FUNCTION:
+RSA_public_encrypt 2670 1_1_0 EXIST::FUNCTION:RSA
+X509_CRL_get0_extensions 2671 1_1_0 EXIST::FUNCTION:
+CMS_digest_verify 2672 1_1_0 EXIST::FUNCTION:CMS
+ASN1_GENERALIZEDTIME_set 2673 1_1_0 EXIST::FUNCTION:
+TS_VERIFY_CTX_set_imprint 2674 1_1_0 EXIST::FUNCTION:TS
+BN_RECP_CTX_set 2675 1_1_0 EXIST::FUNCTION:
+CRYPTO_secure_zalloc 2676 1_1_0 EXIST::FUNCTION:
+i2d_EXTENDED_KEY_USAGE 2677 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_DSAparams 2678 1_1_0 EXIST::FUNCTION:DSA
+X509_cmp_time 2679 1_1_0 EXIST::FUNCTION:
+d2i_CMS_ReceiptRequest 2680 1_1_0 EXIST::FUNCTION:CMS
+X509_CRL_INFO_it 2681 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_CRL_INFO_it 2681 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+BUF_reverse 2682 1_1_0 EXIST::FUNCTION:
+d2i_OCSP_SIGNATURE 2683 1_1_0 EXIST::FUNCTION:OCSP
+X509_REQ_delete_attr 2684 1_1_0 EXIST::FUNCTION:
+TS_RESP_CTX_set_signer_cert 2685 1_1_0 EXIST::FUNCTION:TS
+X509V3_EXT_d2i 2686 1_1_0 EXIST::FUNCTION:
+ASN1_GENERALSTRING_it 2687 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_GENERALSTRING_it 2687 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+POLICYQUALINFO_free 2688 1_1_0 EXIST::FUNCTION:
+EC_KEY_set_group 2689 1_1_0 EXIST::FUNCTION:EC
+OCSP_check_validity 2690 1_1_0 EXIST::FUNCTION:OCSP
+PEM_write_ECPKParameters 2691 1_1_0 EXIST::FUNCTION:EC,STDIO
+X509_VERIFY_PARAM_lookup 2692 1_1_0 EXIST::FUNCTION:
+X509_LOOKUP_by_fingerprint 2693 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_meth_free 2694 1_1_0 EXIST::FUNCTION:
+PKCS7_RECIP_INFO_new 2695 1_1_0 EXIST::FUNCTION:
+d2i_ECPrivateKey_fp 2696 1_1_0 EXIST::FUNCTION:EC,STDIO
+TS_CONF_set_ordering 2697 1_1_0 EXIST::FUNCTION:TS
+X509_CRL_get_ext 2698 1_1_0 EXIST::FUNCTION:
+X509_CRL_get_ext_by_OBJ 2699 1_1_0 EXIST::FUNCTION:
+OCSP_basic_add1_cert 2700 1_1_0 EXIST::FUNCTION:OCSP
+ASN1_PRINTABLESTRING_new 2701 1_1_0 EXIST::FUNCTION:
+i2d_PBEPARAM 2702 1_1_0 EXIST::FUNCTION:
+NETSCAPE_SPKI_new 2703 1_1_0 EXIST::FUNCTION:
+AES_options 2704 1_1_0 EXIST::FUNCTION:
+POLICYINFO_free 2705 1_1_0 EXIST::FUNCTION:
+PEM_read_bio_Parameters 2706 1_1_0 EXIST::FUNCTION:
+BN_abs_is_word 2707 1_1_0 EXIST::FUNCTION:
+BIO_set_callback_arg 2708 1_1_0 EXIST::FUNCTION:
+CONF_modules_load_file 2709 1_1_0 EXIST::FUNCTION:
+X509_trust_clear 2710 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_CTX_test_flags 2711 1_1_0 EXIST::FUNCTION:
+PKCS12_BAGS_free 2712 1_1_0 EXIST::FUNCTION:
+PEM_X509_INFO_read 2713 1_1_0 EXIST::FUNCTION:STDIO
+d2i_DSAPrivateKey 2714 1_1_0 EXIST::FUNCTION:DSA
+i2d_PKCS8_PRIV_KEY_INFO_fp 2715 1_1_0 EXIST::FUNCTION:STDIO
+TS_RESP_print_bio 2716 1_1_0 EXIST::FUNCTION:TS
+X509_STORE_set_default_paths 2717 1_1_0 EXIST::FUNCTION:
+d2i_TS_REQ 2718 1_1_0 EXIST::FUNCTION:TS
+i2d_TS_TST_INFO_bio 2719 1_1_0 EXIST::FUNCTION:TS
+CMS_sign_receipt 2720 1_1_0 EXIST::FUNCTION:CMS
+ENGINE_set_RAND 2721 1_1_0 EXIST::FUNCTION:ENGINE
+X509_REVOKED_get_ext_by_OBJ 2722 1_1_0 EXIST::FUNCTION:
+SEED_decrypt 2723 1_1_0 EXIST::FUNCTION:SEED
+PEM_write_PKCS8PrivateKey 2724 1_1_0 EXIST::FUNCTION:STDIO
+ENGINE_new 2725 1_1_0 EXIST::FUNCTION:ENGINE
+X509_check_issued 2726 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_CTX_iv_length 2727 1_1_0 EXIST::FUNCTION:
+DES_string_to_2keys 2728 1_1_0 EXIST::FUNCTION:DES
+EVP_PKEY_copy_parameters 2729 1_1_0 EXIST::FUNCTION:
+CMS_ContentInfo_print_ctx 2730 1_1_0 EXIST::FUNCTION:CMS
+d2i_PKCS7_SIGNED 2731 1_1_0 EXIST::FUNCTION:
+GENERAL_NAMES_free 2732 1_1_0 EXIST::FUNCTION:
+SCT_get_timestamp 2733 1_1_0 EXIST::FUNCTION:CT
+OCSP_SIGNATURE_it 2734 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:OCSP
+OCSP_SIGNATURE_it 2734 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:OCSP
+CMS_verify_receipt 2735 1_1_0 EXIST::FUNCTION:CMS
+CRYPTO_THREAD_lock_new 2736 1_1_0 EXIST::FUNCTION:
+BIO_get_ex_data 2737 1_1_0 EXIST::FUNCTION:
+CMS_digest_create 2738 1_1_0 EXIST::FUNCTION:CMS
+EC_KEY_METHOD_set_verify 2739 1_1_0 EXIST::FUNCTION:EC
+PEM_read_RSAPublicKey 2740 1_1_0 EXIST::FUNCTION:RSA,STDIO
+ENGINE_pkey_asn1_find_str 2741 1_1_0 EXIST::FUNCTION:ENGINE
+ENGINE_get_load_privkey_function 2742 1_1_0 EXIST::FUNCTION:ENGINE
+d2i_IPAddressRange 2743 1_1_0 EXIST::FUNCTION:RFC3779
+ERR_remove_state 2744 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_0_0
+X509_CRL_print_fp 2745 1_1_0 EXIST::FUNCTION:STDIO
+TS_CONF_load_key 2746 1_1_0 EXIST::FUNCTION:TS
+d2i_OCSP_REQINFO 2747 1_1_0 EXIST::FUNCTION:OCSP
+d2i_X509_CINF 2748 1_1_0 EXIST::FUNCTION:
+OCSP_REQUEST_get_ext_by_critical 2749 1_1_0 EXIST::FUNCTION:OCSP
+X509_REQ_to_X509 2750 1_1_0 EXIST::FUNCTION:
+EVP_aes_192_wrap_pad 2751 1_1_0 EXIST::FUNCTION:
+PKCS7_SIGN_ENVELOPE_new 2752 1_1_0 EXIST::FUNCTION:
+TS_REQ_get_policy_id 2753 1_1_0 EXIST::FUNCTION:TS
+RC5_32_cbc_encrypt 2754 1_1_0 EXIST::FUNCTION:RC5
+BN_is_zero 2755 1_1_0 EXIST::FUNCTION:
+CT_POLICY_EVAL_CTX_new 2756 1_1_0 EXIST::FUNCTION:CT
+NETSCAPE_SPKI_it 2757 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+NETSCAPE_SPKI_it 2757 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+CRYPTO_THREAD_unlock 2758 1_1_0 EXIST::FUNCTION:
+UI_method_set_writer 2759 1_1_0 EXIST::FUNCTION:UI
+UI_dup_info_string 2760 1_1_0 EXIST::FUNCTION:UI
+OPENSSL_init 2761 1_1_0 EXIST::FUNCTION:
+TS_RESP_get_tst_info 2762 1_1_0 EXIST::FUNCTION:TS
+X509_VERIFY_PARAM_get_depth 2763 1_1_0 EXIST::FUNCTION:
+EVP_SealFinal 2764 1_1_0 EXIST::FUNCTION:RSA
+BIO_set 2765 1_1_0 NOEXIST::FUNCTION:
+CONF_imodule_set_flags 2766 1_1_0 EXIST::FUNCTION:
+i2d_ASN1_SET_ANY 2767 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_decrypt 2768 1_1_0 EXIST::FUNCTION:
+OCSP_RESPID_it 2769 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:OCSP
+OCSP_RESPID_it 2769 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:OCSP
+EVP_des_ede3_cbc 2770 1_1_0 EXIST::FUNCTION:DES
+X509_up_ref 2771 1_1_0 EXIST::FUNCTION:
+OBJ_NAME_do_all_sorted 2772 1_1_0 EXIST::FUNCTION:
+ENGINE_unregister_DSA 2773 1_1_0 EXIST::FUNCTION:ENGINE
+ASN1_bn_print 2774 1_1_0 EXIST::FUNCTION:
+CMS_is_detached 2775 1_1_0 EXIST::FUNCTION:CMS
+X509_REQ_INFO_it 2776 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_REQ_INFO_it 2776 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+RSAPrivateKey_it 2777 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:RSA
+RSAPrivateKey_it 2777 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:RSA
+X509_NAME_ENTRY_free 2778 1_1_0 EXIST::FUNCTION:
+BIO_new_fd 2779 1_1_0 EXIST::FUNCTION:
+OPENSSL_sk_value 2781 1_1_0 EXIST::FUNCTION:
+NCONF_get_section 2782 1_1_0 EXIST::FUNCTION:
+PKCS12_MAC_DATA_it 2783 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS12_MAC_DATA_it 2783 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+X509_REQ_add1_attr_by_NID 2784 1_1_0 EXIST::FUNCTION:
+ASN1_sign 2785 1_1_0 EXIST::FUNCTION:
+CMS_RecipientInfo_encrypt 2786 1_1_0 EXIST::FUNCTION:CMS
+X509_get_pubkey_parameters 2787 1_1_0 EXIST::FUNCTION:
+PKCS12_setup_mac 2788 1_1_0 EXIST::FUNCTION:
+PEM_read_bio_PKCS7 2789 1_1_0 EXIST::FUNCTION:
+SHA512_Final 2790 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_set1_host 2791 1_1_0 EXIST::FUNCTION:
+OCSP_resp_find_status 2792 1_1_0 EXIST::FUNCTION:OCSP
+d2i_ASN1_T61STRING 2793 1_1_0 EXIST::FUNCTION:
+DES_pcbc_encrypt 2794 1_1_0 EXIST::FUNCTION:DES
+EVP_PKEY_print_params 2795 1_1_0 EXIST::FUNCTION:
+BN_get0_nist_prime_192 2796 1_1_0 EXIST::FUNCTION:
+EVP_SealInit 2798 1_1_0 EXIST::FUNCTION:RSA
+X509_REQ_get0_signature 2799 1_1_0 EXIST::FUNCTION:
+PKEY_USAGE_PERIOD_free 2800 1_1_0 EXIST::FUNCTION:
+EC_GROUP_set_point_conversion_form 2801 1_1_0 EXIST::FUNCTION:EC
+CMS_dataFinal 2802 1_1_0 EXIST::FUNCTION:CMS
+ASN1_TIME_it 2803 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_TIME_it 2803 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ENGINE_get_static_state 2804 1_1_0 EXIST::FUNCTION:ENGINE
+EC_KEY_set_asn1_flag 2805 1_1_0 EXIST::FUNCTION:EC
+EC_GFp_mont_method 2806 1_1_0 EXIST::FUNCTION:EC
+OPENSSL_asc2uni 2807 1_1_0 EXIST::FUNCTION:
+TS_REQ_new 2808 1_1_0 EXIST::FUNCTION:TS
+ENGINE_register_all_DH 2809 1_1_0 EXIST::FUNCTION:ENGINE
+ERR_clear_error 2810 1_1_0 EXIST::FUNCTION:
+EC_KEY_dup 2811 1_1_0 EXIST::FUNCTION:EC
+X509_LOOKUP_init 2812 1_1_0 EXIST::FUNCTION:
+i2b_PVK_bio 2813 1_1_0 EXIST::FUNCTION:DSA,RC4
+OCSP_ONEREQ_free 2814 1_1_0 EXIST::FUNCTION:OCSP
+X509V3_EXT_print_fp 2815 1_1_0 EXIST::FUNCTION:STDIO
+OBJ_bsearch_ex_ 2816 1_1_0 EXIST::FUNCTION:
+DES_ofb64_encrypt 2817 1_1_0 EXIST::FUNCTION:DES
+i2d_IPAddressOrRange 2818 1_1_0 EXIST::FUNCTION:RFC3779
+CRYPTO_secure_used 2819 1_1_0 EXIST::FUNCTION:
+d2i_X509_CRL_INFO 2820 1_1_0 EXIST::FUNCTION:
+X509_CRL_get_issuer 2821 1_1_0 EXIST::FUNCTION:
+d2i_SCT_LIST 2822 1_1_0 EXIST::FUNCTION:CT
+EC_GFp_nist_method 2823 1_1_0 EXIST::FUNCTION:EC
+SCT_free 2824 1_1_0 EXIST::FUNCTION:CT
+TS_TST_INFO_get_msg_imprint 2825 1_1_0 EXIST::FUNCTION:TS
+X509v3_addr_add_range 2826 1_1_0 EXIST::FUNCTION:RFC3779
+PKCS12_get_friendlyname 2827 1_1_0 EXIST::FUNCTION:
+X509_CRL_add_ext 2829 1_1_0 EXIST::FUNCTION:
+X509_REQ_get_signature_nid 2830 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_get_ext 2831 1_1_0 EXIST::FUNCTION:TS
+i2d_OCSP_RESPID 2832 1_1_0 EXIST::FUNCTION:OCSP
+EVP_camellia_256_cfb8 2833 1_1_0 EXIST::FUNCTION:CAMELLIA
+EC_KEY_get0_public_key 2834 1_1_0 EXIST::FUNCTION:EC
+SRP_Calc_x 2835 1_1_0 EXIST::FUNCTION:SRP
+a2i_ASN1_ENUMERATED 2836 1_1_0 EXIST::FUNCTION:
+CONF_module_get_usr_data 2837 1_1_0 EXIST::FUNCTION:
+i2d_X509_NAME_ENTRY 2838 1_1_0 EXIST::FUNCTION:
+SCT_LIST_free 2839 1_1_0 EXIST::FUNCTION:CT
+PROXY_POLICY_new 2840 1_1_0 EXIST::FUNCTION:
+X509_ALGOR_set_md 2841 1_1_0 EXIST::FUNCTION:
+PKCS7_print_ctx 2842 1_1_0 EXIST::FUNCTION:
+ASN1_UTF8STRING_new 2843 1_1_0 EXIST::FUNCTION:
+EVP_des_cbc 2844 1_1_0 EXIST::FUNCTION:DES
+i2v_ASN1_BIT_STRING 2845 1_1_0 EXIST::FUNCTION:
+ASN1_TYPE_set1 2846 1_1_0 EXIST::FUNCTION:
+d2i_X509_CRL_bio 2847 1_1_0 EXIST::FUNCTION:
+PKCS12_SAFEBAG_get1_cert 2848 1_1_0 EXIST::FUNCTION:
+ASN1_UNIVERSALSTRING_free 2849 1_1_0 EXIST::FUNCTION:
+EC_KEY_precompute_mult 2850 1_1_0 EXIST::FUNCTION:EC
+CRYPTO_mem_debug_realloc 2851 1_1_0 EXIST::FUNCTION:CRYPTO_MDEBUG
+PKCS7_new 2852 1_1_0 EXIST::FUNCTION:
+BASIC_CONSTRAINTS_it 2853 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+BASIC_CONSTRAINTS_it 2853 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ASN1_generate_v3 2854 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_PrivateKey 2855 1_1_0 EXIST::FUNCTION:
+ASN1_UTCTIME_check 2856 1_1_0 EXIST::FUNCTION:
+ACCESS_DESCRIPTION_it 2857 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ACCESS_DESCRIPTION_it 2857 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+TS_MSG_IMPRINT_get_msg 2859 1_1_0 EXIST::FUNCTION:TS
+PKCS8_add_keyusage 2860 1_1_0 EXIST::FUNCTION:
+X509_EXTENSION_dup 2861 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_asn1_new 2862 1_1_0 EXIST::FUNCTION:
+BIO_socket_nbio 2863 1_1_0 EXIST::FUNCTION:SOCK
+EVP_CIPHER_set_asn1_iv 2864 1_1_0 EXIST::FUNCTION:
+EC_GFp_nistp224_method 2865 1_1_0 EXIST::FUNCTION:EC,EC_NISTP_64_GCC_128
+BN_swap 2866 1_1_0 EXIST::FUNCTION:
+d2i_ECParameters 2867 1_1_0 EXIST::FUNCTION:EC
+X509_NAME_add_entry_by_OBJ 2868 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_get_ext_count 2869 1_1_0 EXIST::FUNCTION:TS
+i2d_OCSP_CERTID 2870 1_1_0 EXIST::FUNCTION:OCSP
+BN_CTX_start 2871 1_1_0 EXIST::FUNCTION:
+BN_print 2872 1_1_0 EXIST::FUNCTION:
+EC_KEY_set_flags 2873 1_1_0 EXIST::FUNCTION:EC
+EVP_PKEY_get0 2874 1_1_0 EXIST::FUNCTION:
+ENGINE_set_default 2875 1_1_0 EXIST::FUNCTION:ENGINE
+NCONF_get_number_e 2876 1_1_0 EXIST::FUNCTION:
+OPENSSL_cleanse 2877 1_1_0 EXIST::FUNCTION:
+SCT_set0_signature 2878 1_1_0 EXIST::FUNCTION:CT
+X509_CRL_sign 2879 1_1_0 EXIST::FUNCTION:
+X509_CINF_it 2880 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_CINF_it 2880 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+TS_CONF_set_accuracy 2881 1_1_0 EXIST::FUNCTION:TS
+DES_crypt 2882 1_1_0 EXIST::FUNCTION:DES
+BN_BLINDING_create_param 2883 1_1_0 EXIST::FUNCTION:
+OCSP_SERVICELOC_free 2884 1_1_0 EXIST::FUNCTION:OCSP
+DIST_POINT_NAME_free 2885 1_1_0 EXIST::FUNCTION:
+BIO_listen 2886 1_1_0 EXIST::FUNCTION:SOCK
+BIO_ADDR_path_string 2887 1_1_0 EXIST::FUNCTION:SOCK
+POLICY_CONSTRAINTS_it 2888 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+POLICY_CONSTRAINTS_it 2888 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+NCONF_free_data 2889 1_1_0 EXIST::FUNCTION:
+BIO_asn1_set_prefix 2890 1_1_0 EXIST::FUNCTION:
+PEM_SignUpdate 2891 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_EC_PUBKEY 2892 1_1_0 EXIST::FUNCTION:EC
+CMS_add_simple_smimecap 2893 1_1_0 EXIST::FUNCTION:CMS
+IPAddressChoice_free 2894 1_1_0 EXIST::FUNCTION:RFC3779
+d2i_X509_AUX 2895 1_1_0 EXIST::FUNCTION:
+X509_get_default_cert_area 2896 1_1_0 EXIST::FUNCTION:
+ERR_load_DSO_strings 2897 1_1_0 EXIST::FUNCTION:
+ASIdentifiers_it 2898 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:RFC3779
+ASIdentifiers_it 2898 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:RFC3779
+BN_mod_lshift 2899 1_1_0 EXIST::FUNCTION:
+ENGINE_get_last 2900 1_1_0 EXIST::FUNCTION:ENGINE
+EVP_PKEY_encrypt_init 2901 1_1_0 EXIST::FUNCTION:
+i2d_RSAPrivateKey_fp 2902 1_1_0 EXIST::FUNCTION:RSA,STDIO
+X509_REQ_print 2903 1_1_0 EXIST::FUNCTION:
+RSA_size 2904 1_1_0 EXIST::FUNCTION:RSA
+EVP_CIPHER_CTX_iv_noconst 2905 1_1_0 EXIST::FUNCTION:
+DH_set_default_method 2906 1_1_0 EXIST::FUNCTION:DH
+X509_ALGOR_new 2907 1_1_0 EXIST::FUNCTION:
+EVP_aes_192_ofb 2908 1_1_0 EXIST::FUNCTION:
+EVP_des_ede3_cfb1 2909 1_1_0 EXIST::FUNCTION:DES
+TS_REQ_to_TS_VERIFY_CTX 2910 1_1_0 EXIST::FUNCTION:TS
+d2i_PBEPARAM 2911 1_1_0 EXIST::FUNCTION:
+BN_get0_nist_prime_521 2912 1_1_0 EXIST::FUNCTION:
+OCSP_ONEREQ_get_ext_by_NID 2913 1_1_0 EXIST::FUNCTION:OCSP
+X509_PUBKEY_get0 2914 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get0_parent_ctx 2915 1_1_0 EXIST::FUNCTION:
+EC_GROUP_set_seed 2916 1_1_0 EXIST::FUNCTION:EC
+X509_STORE_CTX_free 2917 1_1_0 EXIST::FUNCTION:
+AUTHORITY_KEYID_it 2918 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+AUTHORITY_KEYID_it 2918 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+X509V3_get_value_int 2919 1_1_0 EXIST::FUNCTION:
+ASN1_UTCTIME_set_string 2920 1_1_0 EXIST::FUNCTION:
+RC5_32_decrypt 2921 1_1_0 EXIST::FUNCTION:RC5
+i2d_X509_REQ_INFO 2922 1_1_0 EXIST::FUNCTION:
+EVP_des_cfb1 2923 1_1_0 EXIST::FUNCTION:DES
+OBJ_NAME_cleanup 2924 1_1_0 EXIST::FUNCTION:
+OCSP_BASICRESP_get1_ext_d2i 2925 1_1_0 EXIST::FUNCTION:OCSP
+DES_cfb64_encrypt 2926 1_1_0 EXIST::FUNCTION:DES
+CAST_cfb64_encrypt 2927 1_1_0 EXIST::FUNCTION:CAST
+EVP_PKEY_asn1_set_param 2928 1_1_0 EXIST::FUNCTION:
+BN_RECP_CTX_free 2929 1_1_0 EXIST::FUNCTION:
+BN_with_flags 2930 1_1_0 EXIST::FUNCTION:
+DSO_ctrl 2931 1_1_0 EXIST::FUNCTION:
+EVP_MD_meth_get_final 2932 1_1_0 EXIST::FUNCTION:
+ASN1_TYPE_get_octetstring 2933 1_1_0 EXIST::FUNCTION:
+ENGINE_by_id 2934 1_1_0 EXIST::FUNCTION:ENGINE
+d2i_PKCS7_SIGNER_INFO 2935 1_1_0 EXIST::FUNCTION:
+EVP_aes_192_cbc 2936 1_1_0 EXIST::FUNCTION:
+PKCS8_pkey_set0 2937 1_1_0 EXIST::FUNCTION:
+X509_get1_email 2938 1_1_0 EXIST::FUNCTION:
+EC_POINT_point2oct 2939 1_1_0 EXIST::FUNCTION:EC
+EC_GROUP_get_curve_GFp 2940 1_1_0 EXIST::FUNCTION:EC
+ASYNC_block_pause 2941 1_1_0 EXIST::FUNCTION:
+OCSP_SINGLERESP_get_ext 2942 1_1_0 EXIST::FUNCTION:OCSP
+CRYPTO_strdup 2943 1_1_0 EXIST::FUNCTION:
+i2d_X509_CRL_bio 2945 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_asn1_set_item 2946 1_1_0 EXIST::FUNCTION:
+CRYPTO_ccm128_encrypt 2947 1_1_0 EXIST::FUNCTION:
+X509v3_addr_get_afi 2948 1_1_0 EXIST::FUNCTION:RFC3779
+X509_STORE_CTX_get0_param 2949 1_1_0 EXIST::FUNCTION:
+EVP_add_alg_module 2950 1_1_0 EXIST::FUNCTION:
+X509_check_purpose 2951 1_1_0 EXIST::FUNCTION:
+OCSP_REQUEST_delete_ext 2952 1_1_0 EXIST::FUNCTION:OCSP
+X509_PURPOSE_get_count 2953 1_1_0 EXIST::FUNCTION:
+d2i_PKCS12_bio 2954 1_1_0 EXIST::FUNCTION:
+ASN1_item_free 2955 1_1_0 EXIST::FUNCTION:
+PKCS7_content_new 2956 1_1_0 EXIST::FUNCTION:
+X509_keyid_get0 2957 1_1_0 EXIST::FUNCTION:
+COMP_get_name 2958 1_1_0 EXIST::FUNCTION:COMP
+EC_GROUP_new_curve_GF2m 2959 1_1_0 EXIST::FUNCTION:EC,EC2M
+X509_SIG_free 2960 1_1_0 EXIST::FUNCTION:
+PEM_ASN1_write 2961 1_1_0 EXIST::FUNCTION:STDIO
+ENGINE_get_digest_engine 2962 1_1_0 EXIST::FUNCTION:ENGINE
+BN_CTX_new 2963 1_1_0 EXIST::FUNCTION:
+EC_curve_nid2nist 2964 1_1_0 EXIST::FUNCTION:EC
+ENGINE_get_finish_function 2965 1_1_0 EXIST::FUNCTION:ENGINE
+EC_POINT_add 2966 1_1_0 EXIST::FUNCTION:EC
+EC_KEY_oct2key 2967 1_1_0 EXIST::FUNCTION:EC
+SHA384_Init 2968 1_1_0 EXIST::FUNCTION:
+ASN1_UNIVERSALSTRING_new 2969 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_print_private 2970 1_1_0 EXIST::FUNCTION:
+ASN1_INTEGER_new 2971 1_1_0 EXIST::FUNCTION:
+NAME_CONSTRAINTS_it 2972 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+NAME_CONSTRAINTS_it 2972 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+TS_REQ_get_cert_req 2973 1_1_0 EXIST::FUNCTION:TS
+BIO_pop 2974 1_1_0 EXIST::FUNCTION:
+SHA256_Final 2975 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_set1_DH 2976 1_1_0 EXIST::FUNCTION:DH
+DH_get_ex_data 2977 1_1_0 EXIST::FUNCTION:DH
+CRYPTO_secure_malloc 2978 1_1_0 EXIST::FUNCTION:
+TS_RESP_get_status_info 2979 1_1_0 EXIST::FUNCTION:TS
+HMAC_CTX_new 2980 1_1_0 EXIST::FUNCTION:
+ENGINE_get_default_DH 2981 1_1_0 EXIST::FUNCTION:ENGINE
+ECDSA_do_verify 2982 1_1_0 EXIST::FUNCTION:EC
+DSO_flags 2983 1_1_0 EXIST::FUNCTION:
+RAND_add 2984 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_do_all_sorted 2985 1_1_0 EXIST::FUNCTION:
+PKCS7_encrypt 2986 1_1_0 EXIST::FUNCTION:
+i2d_DSA_SIG 2987 1_1_0 EXIST::FUNCTION:DSA
+CMS_set_detached 2988 1_1_0 EXIST::FUNCTION:CMS
+X509_REQ_get_attr_by_OBJ 2989 1_1_0 EXIST::FUNCTION:
+i2d_ASRange 2990 1_1_0 EXIST::FUNCTION:RFC3779
+EC_GROUP_set_asn1_flag 2991 1_1_0 EXIST::FUNCTION:EC
+EVP_PKEY_new 2992 1_1_0 EXIST::FUNCTION:
+i2d_POLICYINFO 2993 1_1_0 EXIST::FUNCTION:
+BN_get_flags 2994 1_1_0 EXIST::FUNCTION:
+SHA384 2995 1_1_0 EXIST::FUNCTION:
+NCONF_get_string 2996 1_1_0 EXIST::FUNCTION:
+d2i_PROXY_CERT_INFO_EXTENSION 2997 1_1_0 EXIST::FUNCTION:
+EC_POINT_point2buf 2998 1_1_0 EXIST::FUNCTION:EC
+RSA_padding_add_PKCS1_OAEP_mgf1 2999 1_1_0 EXIST::FUNCTION:RSA
+COMP_CTX_get_type 3000 1_1_0 EXIST::FUNCTION:COMP
+TS_RESP_CTX_set_status_info 3001 1_1_0 EXIST::FUNCTION:TS
+BIO_f_nbio_test 3002 1_1_0 EXIST::FUNCTION:
+SEED_ofb128_encrypt 3003 1_1_0 EXIST::FUNCTION:SEED
+d2i_RSAPrivateKey_bio 3004 1_1_0 EXIST::FUNCTION:RSA
+DH_KDF_X9_42 3005 1_1_0 EXIST::FUNCTION:CMS,DH
+EVP_PKEY_meth_set_signctx 3006 1_1_0 EXIST::FUNCTION:
+X509_CRL_get_version 3007 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_get0_info 3008 1_1_0 EXIST::FUNCTION:
+PEM_read_bio_RSAPublicKey 3009 1_1_0 EXIST::FUNCTION:RSA
+EVP_PKEY_asn1_set_private 3010 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_get0_RSA 3011 1_1_0 EXIST::FUNCTION:RSA
+DES_ede3_cfb64_encrypt 3012 1_1_0 EXIST::FUNCTION:DES
+POLICY_MAPPING_free 3014 1_1_0 EXIST::FUNCTION:
+EVP_aes_128_gcm 3015 1_1_0 EXIST::FUNCTION:
+BIO_dgram_non_fatal_error 3016 1_1_0 EXIST::FUNCTION:DGRAM
+OCSP_request_is_signed 3017 1_1_0 EXIST::FUNCTION:OCSP
+i2d_BASIC_CONSTRAINTS 3018 1_1_0 EXIST::FUNCTION:
+EC_KEY_get_method 3019 1_1_0 EXIST::FUNCTION:EC
+EC_POINT_bn2point 3021 1_1_0 EXIST::FUNCTION:EC
+PBE2PARAM_it 3022 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PBE2PARAM_it 3022 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+BN_rand 3023 1_1_0 EXIST::FUNCTION:
+ASN1_TYPE_unpack_sequence 3024 1_1_0 EXIST::FUNCTION:
+X509_CRL_sign_ctx 3025 1_1_0 EXIST::FUNCTION:
+X509_STORE_add_crl 3026 1_1_0 EXIST::FUNCTION:
+PEM_write_RSAPrivateKey 3027 1_1_0 EXIST::FUNCTION:RSA,STDIO
+RC4_set_key 3028 1_1_0 EXIST::FUNCTION:RC4
+EVP_CIPHER_CTX_cipher 3029 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_PKCS8PrivateKey_nid 3030 1_1_0 EXIST::FUNCTION:
+BN_MONT_CTX_new 3031 1_1_0 EXIST::FUNCTION:
+CRYPTO_free_ex_index 3032 1_1_0 EXIST::FUNCTION:
+ASYNC_WAIT_CTX_new 3033 1_1_0 EXIST::FUNCTION:
+PKCS7_it 3034 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS7_it 3034 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+CMS_unsigned_get_attr_by_OBJ 3035 1_1_0 EXIST::FUNCTION:CMS
+BN_clear 3036 1_1_0 EXIST::FUNCTION:
+BIO_socket_ioctl 3037 1_1_0 EXIST::FUNCTION:SOCK
+GENERAL_NAME_cmp 3038 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_set_purpose 3039 1_1_0 EXIST::FUNCTION:
+X509_REVOKED_get_ext_d2i 3040 1_1_0 EXIST::FUNCTION:
+X509V3_set_conf_lhash 3041 1_1_0 EXIST::FUNCTION:
+PKCS7_ENC_CONTENT_it 3042 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS7_ENC_CONTENT_it 3042 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+PKCS12_item_pack_safebag 3043 1_1_0 EXIST::FUNCTION:
+i2d_OCSP_RESPDATA 3044 1_1_0 EXIST::FUNCTION:OCSP
+i2d_X509_PUBKEY 3045 1_1_0 EXIST::FUNCTION:
+EVP_DecryptUpdate 3046 1_1_0 EXIST::FUNCTION:
+CAST_cbc_encrypt 3047 1_1_0 EXIST::FUNCTION:CAST
+BN_BLINDING_invert 3048 1_1_0 EXIST::FUNCTION:
+SHA512_Update 3049 1_1_0 EXIST::FUNCTION:
+ESS_ISSUER_SERIAL_new 3050 1_1_0 EXIST::FUNCTION:TS
+PKCS12_SAFEBAG_get0_pkcs8 3051 1_1_0 EXIST::FUNCTION:
+X509_get_ext_by_NID 3052 1_1_0 EXIST::FUNCTION:
+d2i_IPAddressFamily 3053 1_1_0 EXIST::FUNCTION:RFC3779
+X509_check_private_key 3054 1_1_0 EXIST::FUNCTION:
+GENERAL_NAME_get0_value 3055 1_1_0 EXIST::FUNCTION:
+X509_check_akid 3056 1_1_0 EXIST::FUNCTION:
+PKCS12_key_gen_asc 3057 1_1_0 EXIST::FUNCTION:
+EVP_bf_ofb 3058 1_1_0 EXIST::FUNCTION:BF
+AUTHORITY_KEYID_free 3059 1_1_0 EXIST::FUNCTION:
+EVP_seed_ofb 3060 1_1_0 EXIST::FUNCTION:SEED
+OBJ_NAME_get 3061 1_1_0 EXIST::FUNCTION:
+ASN1_UTCTIME_set 3062 1_1_0 EXIST::FUNCTION:
+X509_NAME_ENTRY_set_data 3063 1_1_0 EXIST::FUNCTION:
+ASN1_PCTX_set_str_flags 3064 1_1_0 EXIST::FUNCTION:
+i2a_ASN1_INTEGER 3065 1_1_0 EXIST::FUNCTION:
+d2i_TS_RESP 3066 1_1_0 EXIST::FUNCTION:TS
+EVP_des_ede_cfb64 3067 1_1_0 EXIST::FUNCTION:DES
+d2i_RSAPrivateKey 3068 1_1_0 EXIST::FUNCTION:RSA
+ERR_load_BN_strings 3069 1_1_0 EXIST::FUNCTION:
+BF_encrypt 3070 1_1_0 EXIST::FUNCTION:BF
+MD5 3071 1_1_0 EXIST::FUNCTION:MD5
+BN_GF2m_arr2poly 3072 1_1_0 EXIST::FUNCTION:EC2M
+EVP_PKEY_meth_get_ctrl 3073 1_1_0 EXIST::FUNCTION:
+i2d_X509_REQ_bio 3074 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_set1_name 3075 1_1_0 EXIST::FUNCTION:
+d2i_RSAPublicKey_bio 3076 1_1_0 EXIST::FUNCTION:RSA
+X509_REQ_get_X509_PUBKEY 3077 1_1_0 EXIST::FUNCTION:
+ENGINE_load_private_key 3078 1_1_0 EXIST::FUNCTION:ENGINE
+GENERAL_NAMES_new 3079 1_1_0 EXIST::FUNCTION:
+i2d_POLICYQUALINFO 3080 1_1_0 EXIST::FUNCTION:
+EC_GF2m_simple_method 3081 1_1_0 EXIST::FUNCTION:EC,EC2M
+RSA_get_method 3082 1_1_0 EXIST::FUNCTION:RSA
+d2i_ASRange 3083 1_1_0 EXIST::FUNCTION:RFC3779
+CMS_ContentInfo_new 3084 1_1_0 EXIST::FUNCTION:CMS
+OPENSSL_init_crypto 3085 1_1_0 EXIST::FUNCTION:
+X509_TRUST_set 3086 1_1_0 EXIST::FUNCTION:
+EVP_camellia_192_ecb 3087 1_1_0 EXIST::FUNCTION:CAMELLIA
+d2i_X509_REVOKED 3088 1_1_0 EXIST::FUNCTION:
+d2i_IPAddressOrRange 3089 1_1_0 EXIST::FUNCTION:RFC3779
+TS_TST_INFO_set_version 3090 1_1_0 EXIST::FUNCTION:TS
+PKCS12_get0_mac 3091 1_1_0 EXIST::FUNCTION:
+EVP_EncodeInit 3092 1_1_0 EXIST::FUNCTION:
+X509_get0_trust_objects 3093 1_1_0 EXIST::FUNCTION:
+d2i_ECPrivateKey_bio 3094 1_1_0 EXIST::FUNCTION:EC
+BIO_s_secmem 3095 1_1_0 EXIST::FUNCTION:
+ENGINE_get_default_EC 3096 1_1_0 EXIST::FUNCTION:ENGINE
+TS_RESP_create_response 3097 1_1_0 EXIST::FUNCTION:TS
+BIO_ADDR_rawaddress 3098 1_1_0 EXIST::FUNCTION:SOCK
+PKCS7_ENCRYPT_new 3099 1_1_0 EXIST::FUNCTION:
+i2d_PKCS8PrivateKey_fp 3100 1_1_0 EXIST::FUNCTION:STDIO
+SRP_user_pwd_free 3101 1_1_0 EXIST::FUNCTION:SRP
+Camellia_encrypt 3102 1_1_0 EXIST::FUNCTION:CAMELLIA
+BIO_ADDR_hostname_string 3103 1_1_0 EXIST::FUNCTION:SOCK
+USERNOTICE_new 3104 1_1_0 EXIST::FUNCTION:
+POLICY_MAPPING_new 3105 1_1_0 EXIST::FUNCTION:
+CRYPTO_gcm128_release 3106 1_1_0 EXIST::FUNCTION:
+BIO_new 3107 1_1_0 EXIST::FUNCTION:
+d2i_GENERAL_NAMES 3108 1_1_0 EXIST::FUNCTION:
+PKCS7_SIGNER_INFO_new 3109 1_1_0 EXIST::FUNCTION:
+PEM_read_DSA_PUBKEY 3110 1_1_0 EXIST::FUNCTION:DSA,STDIO
+X509_get0_subject_key_id 3111 1_1_0 EXIST::FUNCTION:
+i2s_ASN1_ENUMERATED 3112 1_1_0 EXIST::FUNCTION:
+X509v3_get_ext_by_OBJ 3113 1_1_0 EXIST::FUNCTION:
+OCSP_REQUEST_free 3114 1_1_0 EXIST::FUNCTION:OCSP
+CRYPTO_ocb128_aad 3115 1_1_0 EXIST::FUNCTION:OCB
+OPENSSL_sk_deep_copy 3116 1_1_0 EXIST::FUNCTION:
+i2d_RSA_PSS_PARAMS 3117 1_1_0 EXIST::FUNCTION:RSA
+EVP_aes_128_wrap_pad 3118 1_1_0 EXIST::FUNCTION:
+ASN1_BIT_STRING_set 3119 1_1_0 EXIST::FUNCTION:
+PKCS5_PBKDF2_HMAC_SHA1 3120 1_1_0 EXIST::FUNCTION:
+RSA_padding_check_PKCS1_type_2 3121 1_1_0 EXIST::FUNCTION:RSA
+EVP_des_ede3_ecb 3122 1_1_0 EXIST::FUNCTION:DES
+CBIGNUM_it 3123 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+CBIGNUM_it 3123 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+BIO_new_NDEF 3124 1_1_0 EXIST::FUNCTION:
+EVP_aes_256_wrap 3125 1_1_0 EXIST::FUNCTION:
+ASN1_STRING_print 3126 1_1_0 EXIST::FUNCTION:
+CRYPTO_THREAD_lock_free 3127 1_1_0 EXIST::FUNCTION:
+TS_ACCURACY_get_seconds 3128 1_1_0 EXIST::FUNCTION:TS
+BN_options 3129 1_1_0 EXIST::FUNCTION:
+BIO_debug_callback 3130 1_1_0 EXIST::FUNCTION:
+EVP_MD_meth_get_update 3131 1_1_0 EXIST::FUNCTION:
+GENERAL_NAME_set0_othername 3132 1_1_0 EXIST::FUNCTION:
+ASN1_BIT_STRING_set_bit 3133 1_1_0 EXIST::FUNCTION:
+EVP_aes_256_ccm 3134 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_CTX_get0_pkey 3135 1_1_0 EXIST::FUNCTION:
+CONF_load_fp 3136 1_1_0 EXIST::FUNCTION:STDIO
+BN_to_ASN1_ENUMERATED 3137 1_1_0 EXIST::FUNCTION:
+i2d_ISSUING_DIST_POINT 3138 1_1_0 EXIST::FUNCTION:
+TXT_DB_free 3139 1_1_0 EXIST::FUNCTION:
+ASN1_STRING_set 3140 1_1_0 EXIST::FUNCTION:
+d2i_ESS_CERT_ID 3141 1_1_0 EXIST::FUNCTION:TS
+EVP_PKEY_meth_set_derive 3142 1_1_0 EXIST::FUNCTION:
+OPENSSL_LH_stats 3143 1_1_0 EXIST::FUNCTION:STDIO
+NCONF_dump_fp 3144 1_1_0 EXIST::FUNCTION:STDIO
+TS_STATUS_INFO_print_bio 3145 1_1_0 EXIST::FUNCTION:TS
+OPENSSL_sk_dup 3146 1_1_0 EXIST::FUNCTION:
+BF_cfb64_encrypt 3147 1_1_0 EXIST::FUNCTION:BF
+ASN1_GENERALIZEDTIME_adj 3148 1_1_0 EXIST::FUNCTION:
+ECDSA_verify 3149 1_1_0 EXIST::FUNCTION:EC
+EVP_camellia_256_cfb128 3150 1_1_0 EXIST::FUNCTION:CAMELLIA
+CMAC_Init 3151 1_1_0 EXIST::FUNCTION:CMAC
+OCSP_basic_add1_status 3152 1_1_0 EXIST::FUNCTION:OCSP
+X509_CRL_get0_by_cert 3153 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_set_tsa 3154 1_1_0 EXIST::FUNCTION:TS
+i2d_ASN1_GENERALIZEDTIME 3155 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_derive_set_peer 3156 1_1_0 EXIST::FUNCTION:
+X509V3_EXT_CRL_add_conf 3157 1_1_0 EXIST::FUNCTION:
+CRYPTO_ccm128_init 3158 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_set_time 3159 1_1_0 EXIST::FUNCTION:
+BN_reciprocal 3160 1_1_0 EXIST::FUNCTION:
+d2i_PKCS7_SIGN_ENVELOPE 3161 1_1_0 EXIST::FUNCTION:
+X509_NAME_digest 3162 1_1_0 EXIST::FUNCTION:
+d2i_OCSP_SERVICELOC 3163 1_1_0 EXIST::FUNCTION:OCSP
+GENERAL_NAME_print 3164 1_1_0 EXIST::FUNCTION:
+CMS_ReceiptRequest_get0_values 3165 1_1_0 EXIST::FUNCTION:CMS
+a2i_ASN1_INTEGER 3166 1_1_0 EXIST::FUNCTION:
+OCSP_sendreq_bio 3167 1_1_0 EXIST::FUNCTION:OCSP
+PKCS12_SAFEBAG_create_crl 3168 1_1_0 EXIST::FUNCTION:
+d2i_X509_NAME 3169 1_1_0 EXIST::FUNCTION:
+IDEA_cfb64_encrypt 3170 1_1_0 EXIST::FUNCTION:IDEA
+BN_mod_sub 3171 1_1_0 EXIST::FUNCTION:
+ASN1_NULL_new 3172 1_1_0 EXIST::FUNCTION:
+HMAC_Init 3173 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0
+EVP_MD_CTX_update_fn 3174 1_1_0 EXIST::FUNCTION:
+EVP_aes_128_ecb 3175 1_1_0 EXIST::FUNCTION:
+i2d_PKCS7_bio_stream 3176 1_1_0 EXIST::FUNCTION:
+i2a_ACCESS_DESCRIPTION 3178 1_1_0 EXIST::FUNCTION:
+EC_KEY_set_enc_flags 3179 1_1_0 EXIST::FUNCTION:EC
+i2d_PUBKEY_fp 3180 1_1_0 EXIST::FUNCTION:STDIO
+b2i_PrivateKey_bio 3181 1_1_0 EXIST::FUNCTION:DSA
+OCSP_REQUEST_add_ext 3182 1_1_0 EXIST::FUNCTION:OCSP
+SXNET_add_id_INTEGER 3183 1_1_0 EXIST::FUNCTION:
+CTLOG_get0_public_key 3184 1_1_0 EXIST::FUNCTION:CT
+OCSP_REQUEST_get_ext_by_OBJ 3185 1_1_0 EXIST::FUNCTION:OCSP
+X509_NAME_oneline 3186 1_1_0 EXIST::FUNCTION:
+X509V3_set_nconf 3187 1_1_0 EXIST::FUNCTION:
+RSAPrivateKey_dup 3188 1_1_0 EXIST::FUNCTION:RSA
+BN_mod_add 3189 1_1_0 EXIST::FUNCTION:
+EC_POINT_set_affine_coordinates_GFp 3190 1_1_0 EXIST::FUNCTION:EC
+X509_get_default_cert_file 3191 1_1_0 EXIST::FUNCTION:
+UI_method_set_flusher 3192 1_1_0 EXIST::FUNCTION:UI
+RSA_new_method 3193 1_1_0 EXIST::FUNCTION:RSA
+OCSP_request_verify 3194 1_1_0 EXIST::FUNCTION:OCSP
+CRYPTO_THREAD_run_once 3195 1_1_0 EXIST::FUNCTION:
+TS_REQ_print_bio 3196 1_1_0 EXIST::FUNCTION:TS
+SCT_get_version 3197 1_1_0 EXIST::FUNCTION:CT
+IDEA_set_encrypt_key 3198 1_1_0 EXIST::FUNCTION:IDEA
+ENGINE_get_DH 3199 1_1_0 EXIST::FUNCTION:ENGINE
+i2d_ASIdentifierChoice 3200 1_1_0 EXIST::FUNCTION:RFC3779
+SRP_Calc_A 3201 1_1_0 EXIST::FUNCTION:SRP
+OCSP_BASICRESP_add_ext 3202 1_1_0 EXIST::FUNCTION:OCSP
+EVP_idea_cfb64 3203 1_1_0 EXIST::FUNCTION:IDEA
+PKCS12_newpass 3204 1_1_0 EXIST::FUNCTION:
+EVP_aes_256_cbc_hmac_sha256 3205 1_1_0 EXIST::FUNCTION:
+TS_ACCURACY_get_millis 3206 1_1_0 EXIST::FUNCTION:TS
+X509_CRL_get_REVOKED 3207 1_1_0 EXIST::FUNCTION:
+X509_issuer_name_hash_old 3208 1_1_0 EXIST::FUNCTION:MD5
+i2d_PKCS12_SAFEBAG 3209 1_1_0 EXIST::FUNCTION:
+BN_rand_range 3210 1_1_0 EXIST::FUNCTION:
+SMIME_write_ASN1 3211 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_CTX_new 3212 1_1_0 EXIST::FUNCTION:
+MD4_Final 3213 1_1_0 EXIST::FUNCTION:MD4
+EVP_PKEY_id 3214 1_1_0 EXIST::FUNCTION:
+CMS_RecipientInfo_get0_pkey_ctx 3215 1_1_0 EXIST::FUNCTION:CMS
+OCSP_REQINFO_free 3216 1_1_0 EXIST::FUNCTION:OCSP
+AUTHORITY_KEYID_new 3217 1_1_0 EXIST::FUNCTION:
+i2d_DIST_POINT_NAME 3218 1_1_0 EXIST::FUNCTION:
+OpenSSL_version_num 3219 1_1_0 EXIST::FUNCTION:
+OCSP_CERTID_free 3220 1_1_0 EXIST::FUNCTION:OCSP
+BIO_hex_string 3221 1_1_0 EXIST::FUNCTION:
+X509_REQ_sign_ctx 3222 1_1_0 EXIST::FUNCTION:
+CRYPTO_ocb128_init 3223 1_1_0 EXIST::FUNCTION:OCB
+EVP_PKEY_get1_EC_KEY 3224 1_1_0 EXIST::FUNCTION:EC
+ASN1_PRINTABLESTRING_free 3225 1_1_0 EXIST::FUNCTION:
+BIO_get_retry_reason 3226 1_1_0 EXIST::FUNCTION:
+X509_NAME_print 3227 1_1_0 EXIST::FUNCTION:
+ACCESS_DESCRIPTION_free 3228 1_1_0 EXIST::FUNCTION:
+BN_nist_mod_384 3229 1_1_0 EXIST::FUNCTION:
+i2d_EC_PUBKEY_fp 3230 1_1_0 EXIST::FUNCTION:EC,STDIO
+ENGINE_set_default_pkey_meths 3231 1_1_0 EXIST::FUNCTION:ENGINE
+DH_bits 3232 1_1_0 EXIST::FUNCTION:DH
+i2d_X509_ALGORS 3233 1_1_0 EXIST::FUNCTION:
+EVP_camellia_192_cfb1 3234 1_1_0 EXIST::FUNCTION:CAMELLIA
+TS_RESP_CTX_add_failure_info 3235 1_1_0 EXIST::FUNCTION:TS
+EVP_PBE_alg_add 3236 1_1_0 EXIST::FUNCTION:
+ESS_CERT_ID_dup 3237 1_1_0 EXIST::FUNCTION:TS
+CMS_SignerInfo_get0_signature 3238 1_1_0 EXIST::FUNCTION:CMS
+EVP_PKEY_verify_recover 3239 1_1_0 EXIST::FUNCTION:
+i2d_PUBKEY 3240 1_1_0 EXIST::FUNCTION:
+ERR_load_EVP_strings 3241 1_1_0 EXIST::FUNCTION:
+X509_ATTRIBUTE_set1_data 3242 1_1_0 EXIST::FUNCTION:
+d2i_X509_fp 3243 1_1_0 EXIST::FUNCTION:STDIO
+MD2_Init 3244 1_1_0 EXIST::FUNCTION:MD2
+ERR_get_error_line 3245 1_1_0 EXIST::FUNCTION:
+X509_CRL_get_ext_by_NID 3246 1_1_0 EXIST::FUNCTION:
+OPENSSL_INIT_free 3247 1_1_0 EXIST::FUNCTION:
+PBE2PARAM_free 3248 1_1_0 EXIST::FUNCTION:
+EVP_aes_192_ecb 3249 1_1_0 EXIST::FUNCTION:
+ASN1_OCTET_STRING_new 3250 1_1_0 EXIST::FUNCTION:
+CMS_set1_eContentType 3251 1_1_0 EXIST::FUNCTION:CMS
+EVP_des_ede3_wrap 3252 1_1_0 EXIST::FUNCTION:DES
+GENERAL_SUBTREE_it 3253 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+GENERAL_SUBTREE_it 3253 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+EVP_read_pw_string_min 3254 1_1_0 EXIST::FUNCTION:UI
+X509_set1_notBefore 3255 1_1_0 EXIST::FUNCTION:
+MD4 3256 1_1_0 EXIST::FUNCTION:MD4
+EVP_PKEY_CTX_dup 3257 1_1_0 EXIST::FUNCTION:
+ENGINE_setup_bsd_cryptodev 3258 1_1_0 EXIST:__FreeBSD__:FUNCTION:DEPRECATEDIN_1_1_0,ENGINE
+PEM_read_bio_DHparams 3259 1_1_0 EXIST::FUNCTION:DH
+CMS_SharedInfo_encode 3260 1_1_0 EXIST::FUNCTION:CMS
+ASN1_OBJECT_create 3261 1_1_0 EXIST::FUNCTION:
+i2d_ECParameters 3262 1_1_0 EXIST::FUNCTION:EC
+BN_GF2m_mod_arr 3263 1_1_0 EXIST::FUNCTION:EC2M
+ENGINE_set_finish_function 3264 1_1_0 EXIST::FUNCTION:ENGINE
+d2i_ASN1_OCTET_STRING 3265 1_1_0 EXIST::FUNCTION:
+ENGINE_set_load_pubkey_function 3266 1_1_0 EXIST::FUNCTION:ENGINE
+BIO_vprintf 3267 1_1_0 EXIST::FUNCTION:
+CMS_RecipientInfo_decrypt 3268 1_1_0 EXIST::FUNCTION:CMS
+RSA_generate_key 3269 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_0_9_8,RSA
+PKCS7_set0_type_other 3270 1_1_0 EXIST::FUNCTION:
+OCSP_REQUEST_new 3271 1_1_0 EXIST::FUNCTION:OCSP
+BIO_lookup 3272 1_1_0 EXIST::FUNCTION:SOCK
+EC_GROUP_get0_cofactor 3273 1_1_0 EXIST::FUNCTION:EC
+SCT_print 3275 1_1_0 EXIST::FUNCTION:CT
+X509_PUBKEY_set 3276 1_1_0 EXIST::FUNCTION:
+POLICY_CONSTRAINTS_free 3277 1_1_0 EXIST::FUNCTION:
+EVP_aes_256_cfb8 3278 1_1_0 EXIST::FUNCTION:
+d2i_DSA_PUBKEY_bio 3279 1_1_0 EXIST::FUNCTION:DSA
+X509_NAME_get_text_by_OBJ 3280 1_1_0 EXIST::FUNCTION:
+RSA_padding_check_none 3281 1_1_0 EXIST::FUNCTION:RSA
+CRYPTO_set_mem_debug 3282 1_1_0 EXIST::FUNCTION:
+TS_VERIFY_CTX_init 3283 1_1_0 EXIST::FUNCTION:TS
+OCSP_cert_id_new 3284 1_1_0 EXIST::FUNCTION:OCSP
+GENERAL_SUBTREE_new 3285 1_1_0 EXIST::FUNCTION:
+OPENSSL_sk_push 3286 1_1_0 EXIST::FUNCTION:
+X509_LOOKUP_ctrl 3287 1_1_0 EXIST::FUNCTION:
+SRP_check_known_gN_param 3288 1_1_0 EXIST::FUNCTION:SRP
+d2i_DIST_POINT 3289 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_CTX_free 3290 1_1_0 EXIST::FUNCTION:
+PBEPARAM_free 3291 1_1_0 EXIST::FUNCTION:
+NETSCAPE_SPKI_set_pubkey 3292 1_1_0 EXIST::FUNCTION:
+EVP_sha512 3293 1_1_0 EXIST::FUNCTION:
+X509_CRL_match 3294 1_1_0 EXIST::FUNCTION:
+i2s_ASN1_IA5STRING 3295 1_1_0 EXIST::FUNCTION:
+EC_KEY_get_default_method 3296 1_1_0 EXIST::FUNCTION:EC
+PKCS8_decrypt 3297 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_CTX_get_data 3298 1_1_0 EXIST::FUNCTION:
+POLICYQUALINFO_it 3299 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+POLICYQUALINFO_it 3299 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+PKCS7_ISSUER_AND_SERIAL_free 3300 1_1_0 EXIST::FUNCTION:
+DSA_SIG_free 3301 1_1_0 EXIST::FUNCTION:DSA
+BIO_asn1_set_suffix 3302 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_set_type_str 3303 1_1_0 EXIST::FUNCTION:
+i2d_X509_SIG 3304 1_1_0 EXIST::FUNCTION:
+OPENSSL_LH_strhash 3305 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_set_trust 3306 1_1_0 EXIST::FUNCTION:
+TS_ACCURACY_set_micros 3307 1_1_0 EXIST::FUNCTION:TS
+EVP_DigestFinal_ex 3308 1_1_0 EXIST::FUNCTION:
+X509_get0_pubkey 3309 1_1_0 EXIST::FUNCTION:
+X509_check_ip 3310 1_1_0 EXIST::FUNCTION:
+PKCS7_get_signed_attribute 3311 1_1_0 EXIST::FUNCTION:
+ASN1_GENERALIZEDTIME_free 3312 1_1_0 EXIST::FUNCTION:
+COMP_compress_block 3313 1_1_0 EXIST::FUNCTION:COMP
+ASN1_STRING_dup 3314 1_1_0 EXIST::FUNCTION:
+X509_LOOKUP_free 3315 1_1_0 EXIST::FUNCTION:
+EC_GROUP_cmp 3316 1_1_0 EXIST::FUNCTION:EC
+TS_TST_INFO_get_ext_by_critical 3317 1_1_0 EXIST::FUNCTION:TS
+ECParameters_print_fp 3318 1_1_0 EXIST::FUNCTION:EC,STDIO
+X509_REQ_sign 3319 1_1_0 EXIST::FUNCTION:
+CRYPTO_xts128_encrypt 3320 1_1_0 EXIST::FUNCTION:
+PEM_def_callback 3321 1_1_0 EXIST::FUNCTION:
+PKCS12_add_friendlyname_uni 3322 1_1_0 EXIST::FUNCTION:
+X509_policy_tree_level_count 3323 1_1_0 EXIST::FUNCTION:
+OBJ_sn2nid 3324 1_1_0 EXIST::FUNCTION:
+CTLOG_free 3325 1_1_0 EXIST::FUNCTION:CT
+EVP_CIPHER_meth_dup 3326 1_1_0 EXIST::FUNCTION:
+CMS_get1_crls 3327 1_1_0 EXIST::FUNCTION:CMS
+X509_aux_print 3328 1_1_0 EXIST::FUNCTION:
+OPENSSL_thread_stop 3330 1_1_0 EXIST::FUNCTION:
+X509_policy_node_get0_parent 3331 1_1_0 EXIST::FUNCTION:
+X509_PKEY_free 3332 1_1_0 EXIST::FUNCTION:
+OCSP_CRLID_new 3333 1_1_0 EXIST::FUNCTION:OCSP
+CONF_dump_bio 3334 1_1_0 EXIST::FUNCTION:
+d2i_PKCS8PrivateKey_fp 3335 1_1_0 EXIST::FUNCTION:STDIO
+RSA_setup_blinding 3336 1_1_0 EXIST::FUNCTION:RSA
+ERR_peek_error_line 3337 1_1_0 EXIST::FUNCTION:
+d2i_PKCS7 3338 1_1_0 EXIST::FUNCTION:
+ERR_reason_error_string 3339 1_1_0 EXIST::FUNCTION:
+ERR_remove_thread_state 3340 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0
+PEM_write_PrivateKey 3341 1_1_0 EXIST::FUNCTION:STDIO
+EVP_PKEY_CTX_str2ctrl 3342 1_1_0 EXIST::FUNCTION:
+CMS_SignerInfo_verify_content 3343 1_1_0 EXIST::FUNCTION:CMS
+ASN1_INTEGER_get_int64 3344 1_1_0 EXIST::FUNCTION:
+ASN1_item_sign 3345 1_1_0 EXIST::FUNCTION:
+OCSP_SERVICELOC_new 3346 1_1_0 EXIST::FUNCTION:OCSP
+ASN1_VISIBLESTRING_new 3347 1_1_0 EXIST::FUNCTION:
+BN_set_flags 3348 1_1_0 EXIST::FUNCTION:
+d2i_PrivateKey_bio 3349 1_1_0 EXIST::FUNCTION:
+ASN1_SEQUENCE_ANY_it 3350 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_SEQUENCE_ANY_it 3350 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ASN1_UTCTIME_adj 3351 1_1_0 EXIST::FUNCTION:
+BN_mod_sqrt 3352 1_1_0 EXIST::FUNCTION:
+OPENSSL_sk_is_sorted 3353 1_1_0 EXIST::FUNCTION:
+OCSP_SIGNATURE_new 3354 1_1_0 EXIST::FUNCTION:OCSP
+EVP_PKEY_meth_get_paramgen 3355 1_1_0 EXIST::FUNCTION:
+X509_ATTRIBUTE_create_by_OBJ 3356 1_1_0 EXIST::FUNCTION:
+RSA_generate_key_ex 3357 1_1_0 EXIST::FUNCTION:RSA
+CMS_SignerInfo_get0_algs 3358 1_1_0 EXIST::FUNCTION:CMS
+DIST_POINT_free 3359 1_1_0 EXIST::FUNCTION:
+ESS_SIGNING_CERT_free 3360 1_1_0 EXIST::FUNCTION:TS
+SCT_new_from_base64 3361 1_1_0 EXIST::FUNCTION:CT
+OpenSSL_version 3362 1_1_0 EXIST::FUNCTION:
+OCSP_SINGLERESP_get_ext_by_OBJ 3363 1_1_0 EXIST::FUNCTION:OCSP
+ECDSA_SIG_get0 3364 1_1_0 EXIST::FUNCTION:EC
+BN_set_word 3365 1_1_0 EXIST::FUNCTION:
+ENGINE_set_flags 3366 1_1_0 EXIST::FUNCTION:ENGINE
+DSA_OpenSSL 3367 1_1_0 EXIST::FUNCTION:DSA
+CMS_RecipientInfo_kari_get0_alg 3368 1_1_0 EXIST::FUNCTION:CMS
+PKCS7_ENVELOPE_new 3369 1_1_0 EXIST::FUNCTION:
+EDIPARTYNAME_new 3370 1_1_0 EXIST::FUNCTION:
+CMS_add1_cert 3371 1_1_0 EXIST::FUNCTION:CMS
+DSO_convert_filename 3372 1_1_0 EXIST::FUNCTION:
+RSA_padding_check_SSLv23 3373 1_1_0 EXIST::FUNCTION:RSA
+CRYPTO_gcm128_finish 3374 1_1_0 EXIST::FUNCTION:
+PKCS12_SAFEBAGS_it 3375 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS12_SAFEBAGS_it 3375 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+PKCS12_PBE_add 3376 1_1_0 EXIST::FUNCTION:
+EC_KEY_set_public_key_affine_coordinates 3377 1_1_0 EXIST::FUNCTION:EC
+EVP_EncryptInit_ex 3378 1_1_0 EXIST::FUNCTION:
+ENGINE_add 3379 1_1_0 EXIST::FUNCTION:ENGINE
+OPENSSL_LH_error 3380 1_1_0 EXIST::FUNCTION:
+PKCS7_DIGEST_it 3381 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS7_DIGEST_it 3381 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+X509_CINF_new 3382 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_keygen_init 3383 1_1_0 EXIST::FUNCTION:
+EVP_aes_192_ocb 3384 1_1_0 EXIST::FUNCTION:OCB
+EVP_camellia_256_cfb1 3385 1_1_0 EXIST::FUNCTION:CAMELLIA
+CRYPTO_secure_actual_size 3387 1_1_0 EXIST::FUNCTION:
+COMP_CTX_free 3388 1_1_0 EXIST::FUNCTION:COMP
+i2d_PBE2PARAM 3389 1_1_0 EXIST::FUNCTION:
+EC_POINT_make_affine 3390 1_1_0 EXIST::FUNCTION:EC
+DSA_generate_parameters 3391 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_0_9_8,DSA
+ASN1_BIT_STRING_num_asc 3392 1_1_0 EXIST::FUNCTION:
+X509_INFO_free 3394 1_1_0 EXIST::FUNCTION:
+d2i_PKCS8_PRIV_KEY_INFO_fp 3395 1_1_0 EXIST::FUNCTION:STDIO
+X509_OBJECT_retrieve_match 3396 1_1_0 EXIST::FUNCTION:
+EVP_aes_128_ctr 3397 1_1_0 EXIST::FUNCTION:
+EVP_PBE_find 3398 1_1_0 EXIST::FUNCTION:
+SHA512_Transform 3399 1_1_0 EXIST::FUNCTION:
+ERR_add_error_vdata 3400 1_1_0 EXIST::FUNCTION:
+OCSP_REQUEST_get_ext 3401 1_1_0 EXIST::FUNCTION:OCSP
+NETSCAPE_SPKAC_new 3402 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_get_verify 3403 1_1_0 EXIST::FUNCTION:
+CRYPTO_128_wrap 3404 1_1_0 EXIST::FUNCTION:
+X509_STORE_set_lookup_crls 3405 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_meth_get_ctrl 3406 1_1_0 EXIST::FUNCTION:
+OCSP_REQ_CTX_set1_req 3407 1_1_0 EXIST::FUNCTION:OCSP
+CONF_imodule_get_usr_data 3408 1_1_0 EXIST::FUNCTION:
+CRYPTO_new_ex_data 3409 1_1_0 EXIST::FUNCTION:
+PEM_read_PKCS8_PRIV_KEY_INFO 3410 1_1_0 EXIST::FUNCTION:STDIO
+TS_VERIFY_CTX_new 3411 1_1_0 EXIST::FUNCTION:TS
+BUF_MEM_new_ex 3412 1_1_0 EXIST::FUNCTION:
+RSA_padding_add_X931 3413 1_1_0 EXIST::FUNCTION:RSA
+BN_get0_nist_prime_256 3414 1_1_0 EXIST::FUNCTION:
+CRYPTO_memcmp 3415 1_1_0 EXIST::FUNCTION:
+DH_check_pub_key 3416 1_1_0 EXIST::FUNCTION:DH
+ASN1_mbstring_copy 3417 1_1_0 EXIST::FUNCTION:
+PKCS7_set_type 3418 1_1_0 EXIST::FUNCTION:
+BIO_gets 3419 1_1_0 EXIST::FUNCTION:
+RSA_padding_check_PKCS1_type_1 3420 1_1_0 EXIST::FUNCTION:RSA
+UI_ctrl 3421 1_1_0 EXIST::FUNCTION:UI
+i2d_X509_REQ_fp 3422 1_1_0 EXIST::FUNCTION:STDIO
+BN_BLINDING_convert_ex 3423 1_1_0 EXIST::FUNCTION:
+ASN1_GENERALIZEDTIME_print 3424 1_1_0 EXIST::FUNCTION:
+BIO_s_null 3425 1_1_0 EXIST::FUNCTION:
+PEM_ASN1_read 3426 1_1_0 EXIST::FUNCTION:STDIO
+SCT_get_log_entry_type 3427 1_1_0 EXIST::FUNCTION:CT
+EVP_CIPHER_meth_get_init 3428 1_1_0 EXIST::FUNCTION:
+X509_ALGOR_free 3429 1_1_0 EXIST::FUNCTION:
+OCSP_SINGLERESP_get_ext_count 3430 1_1_0 EXIST::FUNCTION:OCSP
+EC_POINT_free 3431 1_1_0 EXIST::FUNCTION:EC
+EVP_OpenFinal 3432 1_1_0 EXIST::FUNCTION:RSA
+RAND_egd_bytes 3433 1_1_0 EXIST::FUNCTION:EGD
+UI_method_get_writer 3434 1_1_0 EXIST::FUNCTION:UI
+BN_secure_new 3435 1_1_0 EXIST::FUNCTION:
+SHA1_Update 3437 1_1_0 EXIST::FUNCTION:
+BIO_s_connect 3438 1_1_0 EXIST::FUNCTION:SOCK
+EVP_MD_meth_get_init 3439 1_1_0 EXIST::FUNCTION:
+ASN1_BIT_STRING_free 3440 1_1_0 EXIST::FUNCTION:
+i2d_PROXY_CERT_INFO_EXTENSION 3441 1_1_0 EXIST::FUNCTION:
+ASN1_IA5STRING_new 3442 1_1_0 EXIST::FUNCTION:
+X509_CRL_up_ref 3443 1_1_0 EXIST::FUNCTION:
+EVP_EncodeFinal 3444 1_1_0 EXIST::FUNCTION:
+X509_set_ex_data 3445 1_1_0 EXIST::FUNCTION:
+ERR_get_next_error_library 3446 1_1_0 EXIST::FUNCTION:
+OCSP_RESPONSE_print 3447 1_1_0 EXIST::FUNCTION:OCSP
+BN_get_rfc3526_prime_2048 3448 1_1_0 EXIST::FUNCTION:
+BIO_new_bio_pair 3449 1_1_0 EXIST::FUNCTION:
+EC_GFp_nistp256_method 3450 1_1_0 EXIST::FUNCTION:EC,EC_NISTP_64_GCC_128
+BIO_method_type 3451 1_1_0 EXIST::FUNCTION:
+ECPKParameters_print 3452 1_1_0 EXIST::FUNCTION:EC
+EVP_rc4 3453 1_1_0 EXIST::FUNCTION:RC4
+CMS_data_create 3454 1_1_0 EXIST::FUNCTION:CMS
+EC_POINT_point2bn 3455 1_1_0 EXIST::FUNCTION:EC
+CMS_unsigned_get0_data_by_OBJ 3456 1_1_0 EXIST::FUNCTION:CMS
+ASN1_OCTET_STRING_cmp 3457 1_1_0 EXIST::FUNCTION:
+X509_NAME_print_ex 3458 1_1_0 EXIST::FUNCTION:
+ASN1_parse 3459 1_1_0 EXIST::FUNCTION:
+EC_KEY_priv2oct 3460 1_1_0 EXIST::FUNCTION:EC
+PKCS7_simple_smimecap 3461 1_1_0 EXIST::FUNCTION:
+ASN1_TYPE_set_int_octetstring 3462 1_1_0 EXIST::FUNCTION:
+BIO_number_written 3463 1_1_0 EXIST::FUNCTION:
+TS_TST_INFO_set_msg_imprint 3464 1_1_0 EXIST::FUNCTION:TS
+CRYPTO_get_ex_data 3465 1_1_0 EXIST::FUNCTION:
+X509_PURPOSE_get0_sname 3466 1_1_0 EXIST::FUNCTION:
+RSA_verify_PKCS1_PSS 3467 1_1_0 EXIST::FUNCTION:RSA
+HMAC_CTX_reset 3468 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_set_init 3469 1_1_0 EXIST::FUNCTION:
+X509_REQ_extension_nid 3470 1_1_0 EXIST::FUNCTION:
+ENGINE_up_ref 3471 1_1_0 EXIST::FUNCTION:ENGINE
+BN_BLINDING_invert_ex 3472 1_1_0 EXIST::FUNCTION:
+RIPEMD160_Init 3473 1_1_0 EXIST::FUNCTION:RMD160
+ASYNC_WAIT_CTX_get_changed_fds 3474 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_save_parameters 3475 1_1_0 EXIST::FUNCTION:
+SCT_set_source 3476 1_1_0 EXIST::FUNCTION:CT
+DES_set_odd_parity 3477 1_1_0 EXIST::FUNCTION:DES
+CMAC_CTX_free 3478 1_1_0 EXIST::FUNCTION:CMAC
+d2i_ESS_ISSUER_SERIAL 3479 1_1_0 EXIST::FUNCTION:TS
+HMAC_CTX_set_flags 3480 1_1_0 EXIST::FUNCTION:
+d2i_PKCS8_bio 3481 1_1_0 EXIST::FUNCTION:
+OCSP_ONEREQ_get_ext_count 3482 1_1_0 EXIST::FUNCTION:OCSP
+PEM_read_bio_PKCS8_PRIV_KEY_INFO 3483 1_1_0 EXIST::FUNCTION:
+i2d_OCSP_BASICRESP 3484 1_1_0 EXIST::FUNCTION:OCSP
+CMAC_Final 3485 1_1_0 EXIST::FUNCTION:CMAC
+X509V3_EXT_add_alias 3486 1_1_0 EXIST::FUNCTION:
+BN_get_params 3487 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_0_9_8
+PKCS5_pbkdf2_set 3488 1_1_0 EXIST::FUNCTION:
+d2i_PKCS8PrivateKey_bio 3489 1_1_0 EXIST::FUNCTION:
+ASN1_ENUMERATED_new 3490 1_1_0 EXIST::FUNCTION:
+ENGINE_register_digests 3491 1_1_0 EXIST::FUNCTION:ENGINE
+X509_NAME_get_text_by_NID 3492 1_1_0 EXIST::FUNCTION:
+SMIME_read_ASN1 3493 1_1_0 EXIST::FUNCTION:
+X509_REQ_set_subject_name 3494 1_1_0 EXIST::FUNCTION:
+BN_sub_word 3495 1_1_0 EXIST::FUNCTION:
+DSO_load 3496 1_1_0 EXIST::FUNCTION:
+BN_mod_exp 3497 1_1_0 EXIST::FUNCTION:
+X509_get_signature_type 3498 1_1_0 EXIST::FUNCTION:
+BIO_ptr_ctrl 3499 1_1_0 EXIST::FUNCTION:
+EVP_rc4_hmac_md5 3500 1_1_0 EXIST::FUNCTION:MD5,RC4
+OPENSSL_strlcat 3501 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_new 3502 1_1_0 EXIST::FUNCTION:
+BIO_ADDR_rawport 3503 1_1_0 EXIST::FUNCTION:SOCK
+BUF_MEM_grow_clean 3504 1_1_0 EXIST::FUNCTION:
+X509_NAME_print_ex_fp 3505 1_1_0 EXIST::FUNCTION:STDIO
+X509_check_host 3506 1_1_0 EXIST::FUNCTION:
+PEM_read_ECPKParameters 3507 1_1_0 EXIST::FUNCTION:EC,STDIO
+X509_ATTRIBUTE_get0_data 3508 1_1_0 EXIST::FUNCTION:
+CMS_add1_signer 3509 1_1_0 EXIST::FUNCTION:CMS
+BN_pseudo_rand 3510 1_1_0 EXIST::FUNCTION:
+d2i_DIRECTORYSTRING 3511 1_1_0 EXIST::FUNCTION:
+d2i_ASN1_PRINTABLE 3512 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_add1_attr_by_NID 3513 1_1_0 EXIST::FUNCTION:
+i2d_PKCS8_PRIV_KEY_INFO_bio 3514 1_1_0 EXIST::FUNCTION:
+X509_NAME_get_index_by_NID 3515 1_1_0 EXIST::FUNCTION:
+ENGINE_get_first 3516 1_1_0 EXIST::FUNCTION:ENGINE
+CERTIFICATEPOLICIES_it 3517 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+CERTIFICATEPOLICIES_it 3517 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+EVP_MD_CTX_ctrl 3518 1_1_0 EXIST::FUNCTION:
+PKCS7_final 3519 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_size 3520 1_1_0 EXIST::FUNCTION:
+EVP_DecryptFinal_ex 3521 1_1_0 EXIST::FUNCTION:
+SCT_get_signature_nid 3522 1_1_0 EXIST::FUNCTION:CT
+PROXY_CERT_INFO_EXTENSION_new 3523 1_1_0 EXIST::FUNCTION:
+EVP_bf_cbc 3524 1_1_0 EXIST::FUNCTION:BF
+DSA_do_verify 3525 1_1_0 EXIST::FUNCTION:DSA
+EC_GROUP_get_seed_len 3526 1_1_0 EXIST::FUNCTION:EC
+EC_POINT_set_affine_coordinates_GF2m 3527 1_1_0 EXIST::FUNCTION:EC,EC2M
+TS_REQ_set_policy_id 3528 1_1_0 EXIST::FUNCTION:TS
+BIO_callback_ctrl 3529 1_1_0 EXIST::FUNCTION:
+v2i_GENERAL_NAME 3530 1_1_0 EXIST::FUNCTION:
+ERR_print_errors_cb 3531 1_1_0 EXIST::FUNCTION:
+ENGINE_set_default_string 3532 1_1_0 EXIST::FUNCTION:ENGINE
+BIO_number_read 3533 1_1_0 EXIST::FUNCTION:
+CRYPTO_zalloc 3534 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_cmp_parameters 3535 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_CTX_new_id 3537 1_1_0 EXIST::FUNCTION:
+TLS_FEATURE_free 3538 1_1_0 EXIST::FUNCTION:
+d2i_BASIC_CONSTRAINTS 3539 1_1_0 EXIST::FUNCTION:
+X509_CERT_AUX_new 3540 1_1_0 EXIST::FUNCTION:
+ENGINE_register_pkey_asn1_meths 3541 1_1_0 EXIST::FUNCTION:ENGINE
+CRYPTO_ocb128_tag 3542 1_1_0 EXIST::FUNCTION:OCB
+ERR_load_OBJ_strings 3544 1_1_0 EXIST::FUNCTION:
+BIO_ctrl_get_read_request 3545 1_1_0 EXIST::FUNCTION:
+BN_from_montgomery 3546 1_1_0 EXIST::FUNCTION:
+DSO_new 3547 1_1_0 EXIST::FUNCTION:
+AES_ecb_encrypt 3548 1_1_0 EXIST::FUNCTION:
+BN_dec2bn 3549 1_1_0 EXIST::FUNCTION:
+CMS_decrypt 3550 1_1_0 EXIST::FUNCTION:CMS
+BN_mpi2bn 3551 1_1_0 EXIST::FUNCTION:
+EVP_aes_128_cfb128 3552 1_1_0 EXIST::FUNCTION:
+RC5_32_ecb_encrypt 3554 1_1_0 EXIST::FUNCTION:RC5
+EVP_CIPHER_meth_new 3555 1_1_0 EXIST::FUNCTION:
+i2d_RSA_OAEP_PARAMS 3556 1_1_0 EXIST::FUNCTION:RSA
+SXNET_get_id_ulong 3557 1_1_0 EXIST::FUNCTION:
+BIO_get_callback_arg 3558 1_1_0 EXIST::FUNCTION:
+ENGINE_register_RSA 3559 1_1_0 EXIST::FUNCTION:ENGINE
+i2v_GENERAL_NAMES 3560 1_1_0 EXIST::FUNCTION:
+PKCS7_decrypt 3562 1_1_0 EXIST::FUNCTION:
+X509_STORE_set1_param 3563 1_1_0 EXIST::FUNCTION:
+RAND_file_name 3564 1_1_0 EXIST::FUNCTION:
+EVP_CipherInit_ex 3566 1_1_0 EXIST::FUNCTION:
+BIO_dgram_sctp_notification_cb 3567 1_1_0 EXIST::FUNCTION:DGRAM,SCTP
+ERR_load_RAND_strings 3568 1_1_0 EXIST::FUNCTION:
+X509_ATTRIBUTE_it 3569 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_ATTRIBUTE_it 3569 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+X509_ALGOR_it 3570 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_ALGOR_it 3570 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+OCSP_CRLID_free 3571 1_1_0 EXIST::FUNCTION:OCSP
+CRYPTO_ccm128_aad 3572 1_1_0 EXIST::FUNCTION:
+IPAddressFamily_new 3573 1_1_0 EXIST::FUNCTION:RFC3779
+d2i_TS_ACCURACY 3574 1_1_0 EXIST::FUNCTION:TS
+X509_load_crl_file 3575 1_1_0 EXIST::FUNCTION:
+SXNET_add_id_ulong 3576 1_1_0 EXIST::FUNCTION:
+EVP_camellia_256_cbc 3577 1_1_0 EXIST::FUNCTION:CAMELLIA
+i2d_PROXY_POLICY 3578 1_1_0 EXIST::FUNCTION:
+X509_subject_name_hash_old 3579 1_1_0 EXIST::FUNCTION:MD5
+PEM_read_bio_DSA_PUBKEY 3580 1_1_0 EXIST::FUNCTION:DSA
+OCSP_cert_to_id 3581 1_1_0 EXIST::FUNCTION:OCSP
+PEM_write_DSAparams 3582 1_1_0 EXIST::FUNCTION:DSA,STDIO
+ASN1_TIME_to_generalizedtime 3583 1_1_0 EXIST::FUNCTION:
+X509_CRL_get_ext_by_critical 3584 1_1_0 EXIST::FUNCTION:
+ASN1_STRING_type 3585 1_1_0 EXIST::FUNCTION:
+X509_REQ_add1_attr_by_txt 3586 1_1_0 EXIST::FUNCTION:
+PEM_write_RSAPublicKey 3587 1_1_0 EXIST::FUNCTION:RSA,STDIO
+EVP_MD_meth_dup 3588 1_1_0 EXIST::FUNCTION:
+ENGINE_unregister_ciphers 3589 1_1_0 EXIST::FUNCTION:ENGINE
+X509_issuer_and_serial_cmp 3590 1_1_0 EXIST::FUNCTION:
+OCSP_response_create 3591 1_1_0 EXIST::FUNCTION:OCSP
+SHA224 3592 1_1_0 EXIST::FUNCTION:
+MD2_options 3593 1_1_0 EXIST::FUNCTION:MD2
+X509_REQ_it 3595 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+X509_REQ_it 3595 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+RAND_bytes 3596 1_1_0 EXIST::FUNCTION:
+PKCS7_free 3597 1_1_0 EXIST::FUNCTION:
+X509_NAME_ENTRY_create_by_txt 3598 1_1_0 EXIST::FUNCTION:
+DES_cbc_cksum 3599 1_1_0 EXIST::FUNCTION:DES
+UI_free 3600 1_1_0 EXIST::FUNCTION:UI
+BN_is_prime 3601 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_0_9_8
+CMS_get0_signers 3602 1_1_0 EXIST::FUNCTION:CMS
+i2d_PrivateKey_fp 3603 1_1_0 EXIST::FUNCTION:STDIO
+OTHERNAME_cmp 3604 1_1_0 EXIST::FUNCTION:
+SMIME_write_PKCS7 3605 1_1_0 EXIST::FUNCTION:
+EC_KEY_set_public_key 3606 1_1_0 EXIST::FUNCTION:EC
+d2i_X509_EXTENSION 3607 1_1_0 EXIST::FUNCTION:
+CMS_add1_recipient_cert 3608 1_1_0 EXIST::FUNCTION:CMS
+CMS_RecipientInfo_kekri_get0_id 3609 1_1_0 EXIST::FUNCTION:CMS
+BN_mod_word 3610 1_1_0 EXIST::FUNCTION:
+ASN1_PCTX_new 3611 1_1_0 EXIST::FUNCTION:
+BN_is_prime_ex 3612 1_1_0 EXIST::FUNCTION:
+PKCS5_v2_PBE_keyivgen 3613 1_1_0 EXIST::FUNCTION:
+CRYPTO_ctr128_encrypt 3614 1_1_0 EXIST::FUNCTION:
+CMS_unsigned_add1_attr_by_OBJ 3615 1_1_0 EXIST::FUNCTION:CMS
+PEM_write_EC_PUBKEY 3616 1_1_0 EXIST::FUNCTION:EC,STDIO
+X509v3_asid_add_inherit 3617 1_1_0 EXIST::FUNCTION:RFC3779
+ERR_get_error 3618 1_1_0 EXIST::FUNCTION:
+TS_CONF_set_signer_digest 3619 1_1_0 EXIST::FUNCTION:TS
+OBJ_new_nid 3620 1_1_0 EXIST::FUNCTION:
+CMS_ReceiptRequest_new 3621 1_1_0 EXIST::FUNCTION:CMS
+SRP_VBASE_get1_by_user 3622 1_1_0 EXIST::FUNCTION:SRP
+UI_method_get_closer 3623 1_1_0 EXIST::FUNCTION:UI
+ENGINE_get_ex_data 3624 1_1_0 EXIST::FUNCTION:ENGINE
+BN_print_fp 3625 1_1_0 EXIST::FUNCTION:STDIO
+MD2_Update 3626 1_1_0 EXIST::FUNCTION:MD2
+ENGINE_free 3628 1_1_0 EXIST::FUNCTION:ENGINE
+d2i_X509_ATTRIBUTE 3629 1_1_0 EXIST::FUNCTION:
+TS_RESP_free 3630 1_1_0 EXIST::FUNCTION:TS
+PKCS5_pbe_set 3631 1_1_0 EXIST::FUNCTION:
+TS_RESP_CTX_free 3632 1_1_0 EXIST::FUNCTION:TS
+d2i_PUBKEY 3633 1_1_0 EXIST::FUNCTION:
+ASYNC_cleanup_thread 3634 1_1_0 EXIST::FUNCTION:
+SHA384_Update 3635 1_1_0 EXIST::FUNCTION:
+CRYPTO_cfb128_1_encrypt 3636 1_1_0 EXIST::FUNCTION:
+BIO_set_cipher 3637 1_1_0 EXIST::FUNCTION:
+PEM_read_PUBKEY 3638 1_1_0 EXIST::FUNCTION:STDIO
+RSA_PKCS1_OpenSSL 3639 1_1_0 EXIST::FUNCTION:RSA
+AUTHORITY_INFO_ACCESS_free 3640 1_1_0 EXIST::FUNCTION:
+SCT_get0_signature 3641 1_1_0 EXIST::FUNCTION:CT
+DISPLAYTEXT_it 3643 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+DISPLAYTEXT_it 3643 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+OPENSSL_gmtime_adj 3644 1_1_0 EXIST::FUNCTION:
+ASN1_INTEGER_dup 3645 1_1_0 EXIST::FUNCTION:
+DSA_print 3646 1_1_0 EXIST::FUNCTION:DSA
+X509_REQ_set_extension_nids 3647 1_1_0 EXIST::FUNCTION:
+X509_free 3648 1_1_0 EXIST::FUNCTION:
+ERR_load_ERR_strings 3649 1_1_0 EXIST::FUNCTION:
+ASN1_const_check_infinite_end 3650 1_1_0 EXIST::FUNCTION:
+RSA_null_method 3651 1_1_0 EXIST::FUNCTION:RSA
+TS_REQ_ext_free 3652 1_1_0 EXIST::FUNCTION:TS
+EVP_PKEY_meth_get_encrypt 3653 1_1_0 EXIST::FUNCTION:
+Camellia_ecb_encrypt 3654 1_1_0 EXIST::FUNCTION:CAMELLIA
+ENGINE_set_default_RSA 3655 1_1_0 EXIST::FUNCTION:ENGINE
+EVP_EncodeBlock 3656 1_1_0 EXIST::FUNCTION:
+SXNETID_free 3657 1_1_0 EXIST::FUNCTION:
+SHA1_Init 3658 1_1_0 EXIST::FUNCTION:
+CRYPTO_atomic_add 3659 1_1_0 EXIST::FUNCTION:
+TS_CONF_load_certs 3660 1_1_0 EXIST::FUNCTION:TS
+PEM_write_bio_DSAPrivateKey 3661 1_1_0 EXIST::FUNCTION:DSA
+CMS_encrypt 3662 1_1_0 EXIST::FUNCTION:CMS
+CRYPTO_nistcts128_decrypt 3663 1_1_0 EXIST::FUNCTION:
+ERR_load_DH_strings 3664 1_1_0 EXIST::FUNCTION:DH
+EVP_MD_block_size 3665 1_1_0 EXIST::FUNCTION:
+TS_X509_ALGOR_print_bio 3666 1_1_0 EXIST::FUNCTION:TS
+d2i_PKCS7_ENVELOPE 3667 1_1_0 EXIST::FUNCTION:
+ESS_CERT_ID_new 3669 1_1_0 EXIST::FUNCTION:TS
+EC_POINT_invert 3670 1_1_0 EXIST::FUNCTION:EC
+CAST_set_key 3671 1_1_0 EXIST::FUNCTION:CAST
+ENGINE_get_pkey_meth 3672 1_1_0 EXIST::FUNCTION:ENGINE
+BIO_ADDRINFO_free 3673 1_1_0 EXIST::FUNCTION:SOCK
+DES_ede3_cbc_encrypt 3674 1_1_0 EXIST::FUNCTION:DES
+X509v3_asid_canonize 3675 1_1_0 EXIST::FUNCTION:RFC3779
+i2d_ASIdOrRange 3676 1_1_0 EXIST::FUNCTION:RFC3779
+OCSP_url_svcloc_new 3677 1_1_0 EXIST::FUNCTION:OCSP
+CRYPTO_mem_ctrl 3678 1_1_0 EXIST::FUNCTION:
+ASN1_verify 3679 1_1_0 EXIST::FUNCTION:
+DSA_generate_parameters_ex 3680 1_1_0 EXIST::FUNCTION:DSA
+X509_sign 3681 1_1_0 EXIST::FUNCTION:
+SHA256_Transform 3682 1_1_0 EXIST::FUNCTION:
+BIO_ADDR_free 3683 1_1_0 EXIST::FUNCTION:SOCK
+ASN1_STRING_free 3684 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_inherit 3685 1_1_0 EXIST::FUNCTION:
+EC_GROUP_get_curve_name 3686 1_1_0 EXIST::FUNCTION:EC
+RSA_print 3687 1_1_0 EXIST::FUNCTION:RSA
+i2d_ASN1_BMPSTRING 3688 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_decrypt_old 3689 1_1_0 EXIST::FUNCTION:
+ASN1_UTCTIME_cmp_time_t 3690 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_set1_ip 3691 1_1_0 EXIST::FUNCTION:
+OTHERNAME_free 3692 1_1_0 EXIST::FUNCTION:
+OCSP_REVOKEDINFO_free 3693 1_1_0 EXIST::FUNCTION:OCSP
+EVP_CIPHER_CTX_encrypting 3694 1_1_0 EXIST::FUNCTION:
+EC_KEY_can_sign 3695 1_1_0 EXIST::FUNCTION:EC
+PEM_write_bio_RSAPublicKey 3696 1_1_0 EXIST::FUNCTION:RSA
+X509_CRL_set1_lastUpdate 3697 1_1_0 EXIST::FUNCTION:
+OCSP_sendreq_nbio 3698 1_1_0 EXIST::FUNCTION:OCSP
+PKCS8_encrypt 3699 1_1_0 EXIST::FUNCTION:
+i2d_PKCS7_fp 3700 1_1_0 EXIST::FUNCTION:STDIO
+i2d_X509_REQ 3701 1_1_0 EXIST::FUNCTION:
+OCSP_CRLID_it 3702 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:OCSP
+OCSP_CRLID_it 3702 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:OCSP
+PEM_ASN1_write_bio 3703 1_1_0 EXIST::FUNCTION:
+X509_get0_reject_objects 3704 1_1_0 EXIST::FUNCTION:
+BIO_set_tcp_ndelay 3705 1_1_0 EXIST::FUNCTION:SOCK
+CMS_add0_CertificateChoices 3706 1_1_0 EXIST::FUNCTION:CMS
+POLICYINFO_new 3707 1_1_0 EXIST::FUNCTION:
+X509_CRL_get0_by_serial 3708 1_1_0 EXIST::FUNCTION:
+PKCS12_add_friendlyname_asc 3709 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get1_chain 3710 1_1_0 EXIST::FUNCTION:
+ASN1_mbstring_ncopy 3711 1_1_0 EXIST::FUNCTION:
+PKCS7_RECIP_INFO_it 3712 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS7_RECIP_INFO_it 3712 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ENGINE_register_all_digests 3713 1_1_0 EXIST::FUNCTION:ENGINE
+X509_REQ_get_version 3714 1_1_0 EXIST::FUNCTION:
+i2d_ASN1_UTCTIME 3715 1_1_0 EXIST::FUNCTION:
+TS_STATUS_INFO_new 3716 1_1_0 EXIST::FUNCTION:TS
+UI_set_ex_data 3717 1_1_0 EXIST::FUNCTION:UI
+ASN1_TIME_set 3718 1_1_0 EXIST::FUNCTION:
+TS_RESP_verify_response 3719 1_1_0 EXIST::FUNCTION:TS
+X509_REVOKED_get0_serialNumber 3720 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_free 3721 1_1_0 EXIST::FUNCTION:
+ASN1_TYPE_new 3722 1_1_0 EXIST::FUNCTION:
+CMAC_CTX_cleanup 3723 1_1_0 EXIST::FUNCTION:CMAC
+i2d_PKCS7_NDEF 3724 1_1_0 EXIST::FUNCTION:
+OPENSSL_sk_pop_free 3725 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get0_policy_tree 3726 1_1_0 EXIST::FUNCTION:
+DES_set_key_checked 3727 1_1_0 EXIST::FUNCTION:DES
+EVP_PKEY_meth_free 3728 1_1_0 EXIST::FUNCTION:
+EVP_sha224 3729 1_1_0 EXIST::FUNCTION:
+ENGINE_set_id 3730 1_1_0 EXIST::FUNCTION:ENGINE
+d2i_ECPrivateKey 3731 1_1_0 EXIST::FUNCTION:EC
+CMS_signed_add1_attr_by_NID 3732 1_1_0 EXIST::FUNCTION:CMS
+i2d_DSAPrivateKey_fp 3733 1_1_0 EXIST::FUNCTION:DSA,STDIO
+EVP_CIPHER_meth_get_set_asn1_params 3734 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_ex_data 3735 1_1_0 EXIST::FUNCTION:
+CMS_RecipientInfo_kari_set0_pkey 3736 1_1_0 EXIST::FUNCTION:CMS
+X509v3_addr_add_inherit 3737 1_1_0 EXIST::FUNCTION:RFC3779
+SRP_Calc_u 3738 1_1_0 EXIST::FUNCTION:SRP
+i2d_PKCS8PrivateKey_bio 3739 1_1_0 EXIST::FUNCTION:
+X509_get_extension_flags 3740 1_1_0 EXIST::FUNCTION:
+X509V3_EXT_val_prn 3741 1_1_0 EXIST::FUNCTION:
+SCT_get_validation_status 3742 1_1_0 EXIST::FUNCTION:CT
+NETSCAPE_CERT_SEQUENCE_free 3743 1_1_0 EXIST::FUNCTION:
+EVP_PBE_scrypt 3744 1_1_0 EXIST::FUNCTION:SCRYPT
+d2i_TS_REQ_bio 3745 1_1_0 EXIST::FUNCTION:TS
+ENGINE_set_default_ciphers 3746 1_1_0 EXIST::FUNCTION:ENGINE
+X509_get_signature_nid 3747 1_1_0 EXIST::FUNCTION:
+DES_fcrypt 3748 1_1_0 EXIST::FUNCTION:DES
+PEM_write_bio_X509_REQ 3749 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_meth_get_sign 3750 1_1_0 EXIST::FUNCTION:
+TS_REQ_get_nonce 3751 1_1_0 EXIST::FUNCTION:TS
+ENGINE_unregister_EC 3752 1_1_0 EXIST::FUNCTION:ENGINE
+X509v3_get_ext_count 3753 1_1_0 EXIST::FUNCTION:
+UI_OpenSSL 3754 1_1_0 EXIST::FUNCTION:UI
+CRYPTO_ccm128_decrypt 3755 1_1_0 EXIST::FUNCTION:
+d2i_OCSP_RESPDATA 3756 1_1_0 EXIST::FUNCTION:OCSP
+BIO_set_callback 3757 1_1_0 EXIST::FUNCTION:
+BN_GF2m_poly2arr 3758 1_1_0 EXIST::FUNCTION:EC2M
+CMS_unsigned_get_attr_count 3759 1_1_0 EXIST::FUNCTION:CMS
+EVP_aes_256_gcm 3760 1_1_0 EXIST::FUNCTION:
+RSA_padding_check_X931 3761 1_1_0 EXIST::FUNCTION:RSA
+ECDH_compute_key 3762 1_1_0 EXIST::FUNCTION:EC
+ASN1_TIME_print 3763 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_CTX_get0_peerkey 3764 1_1_0 EXIST::FUNCTION:
+BN_mod_lshift1 3765 1_1_0 EXIST::FUNCTION:
+BIO_ADDRINFO_family 3766 1_1_0 EXIST::FUNCTION:SOCK
+PEM_write_DHxparams 3767 1_1_0 EXIST::FUNCTION:DH,STDIO
+BN_mod_exp2_mont 3768 1_1_0 EXIST::FUNCTION:
+ASN1_PRINTABLE_free 3769 1_1_0 EXIST::FUNCTION:
+PKCS7_ATTR_SIGN_it 3771 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKCS7_ATTR_SIGN_it 3771 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+EVP_MD_CTX_copy 3772 1_1_0 EXIST::FUNCTION:
+ENGINE_set_ctrl_function 3773 1_1_0 EXIST::FUNCTION:ENGINE
+OCSP_id_get0_info 3774 1_1_0 EXIST::FUNCTION:OCSP
+BIO_ADDRINFO_next 3775 1_1_0 EXIST::FUNCTION:SOCK
+OCSP_RESPBYTES_free 3776 1_1_0 EXIST::FUNCTION:OCSP
+EC_KEY_METHOD_set_init 3777 1_1_0 EXIST::FUNCTION:EC
+EVP_PKEY_asn1_copy 3778 1_1_0 EXIST::FUNCTION:
+RSA_PSS_PARAMS_it 3779 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:RSA
+RSA_PSS_PARAMS_it 3779 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:RSA
+X509_STORE_CTX_get_error_depth 3780 1_1_0 EXIST::FUNCTION:
+ASN1_GENERALIZEDTIME_set_string 3781 1_1_0 EXIST::FUNCTION:
+EC_GROUP_new_curve_GFp 3782 1_1_0 EXIST::FUNCTION:EC
+UI_new_method 3783 1_1_0 EXIST::FUNCTION:UI
+Camellia_ofb128_encrypt 3784 1_1_0 EXIST::FUNCTION:CAMELLIA
+X509_new 3785 1_1_0 EXIST::FUNCTION:
+EC_KEY_get_conv_form 3786 1_1_0 EXIST::FUNCTION:EC
+CTLOG_STORE_get0_log_by_id 3787 1_1_0 EXIST::FUNCTION:CT
+CMS_signed_add1_attr 3788 1_1_0 EXIST::FUNCTION:CMS
+EVP_CIPHER_meth_set_iv_length 3789 1_1_0 EXIST::FUNCTION:
+X509v3_asid_validate_path 3790 1_1_0 EXIST::FUNCTION:RFC3779
+CMS_RecipientInfo_set0_password 3791 1_1_0 EXIST::FUNCTION:CMS
+TS_CONF_load_cert 3792 1_1_0 EXIST::FUNCTION:TS
+i2d_ECPKParameters 3793 1_1_0 EXIST::FUNCTION:EC
+X509_TRUST_get0 3794 1_1_0 EXIST::FUNCTION:
+CMS_get0_RecipientInfos 3795 1_1_0 EXIST::FUNCTION:CMS
+EVP_PKEY_CTX_new 3796 1_1_0 EXIST::FUNCTION:
+i2d_DSA_PUBKEY_bio 3797 1_1_0 EXIST::FUNCTION:DSA
+X509_REQ_get_subject_name 3798 1_1_0 EXIST::FUNCTION:
+BN_div_word 3799 1_1_0 EXIST::FUNCTION:
+TS_CONF_set_signer_key 3800 1_1_0 EXIST::FUNCTION:TS
+BN_GF2m_mod_sqrt 3801 1_1_0 EXIST::FUNCTION:EC2M
+EVP_CIPHER_nid 3802 1_1_0 EXIST::FUNCTION:
+OBJ_txt2obj 3803 1_1_0 EXIST::FUNCTION:
+CMS_RecipientInfo_kari_get0_orig_id 3804 1_1_0 EXIST::FUNCTION:CMS
+EVP_bf_ecb 3805 1_1_0 EXIST::FUNCTION:BF
+v2i_GENERAL_NAME_ex 3806 1_1_0 EXIST::FUNCTION:
+CMS_signed_delete_attr 3807 1_1_0 EXIST::FUNCTION:CMS
+ASN1_TYPE_pack_sequence 3808 1_1_0 EXIST::FUNCTION:
+USERNOTICE_it 3809 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+USERNOTICE_it 3809 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+PKEY_USAGE_PERIOD_it 3810 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+PKEY_USAGE_PERIOD_it 3810 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+BN_mul_word 3811 1_1_0 EXIST::FUNCTION:
+i2d_IPAddressRange 3813 1_1_0 EXIST::FUNCTION:RFC3779
+CMS_unsigned_add1_attr_by_txt 3814 1_1_0 EXIST::FUNCTION:CMS
+d2i_RSA_PUBKEY 3815 1_1_0 EXIST::FUNCTION:RSA
+PKCS12_gen_mac 3816 1_1_0 EXIST::FUNCTION:
+ERR_load_ENGINE_strings 3817 1_1_0 EXIST::FUNCTION:ENGINE
+ERR_load_CT_strings 3818 1_1_0 EXIST::FUNCTION:CT
+OCSP_ONEREQ_it 3819 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:OCSP
+OCSP_ONEREQ_it 3819 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:OCSP
+X509_PURPOSE_get_by_sname 3820 1_1_0 EXIST::FUNCTION:
+X509_PURPOSE_set 3821 1_1_0 EXIST::FUNCTION:
+BN_mod_inverse 3822 1_1_0 EXIST::FUNCTION:
+ASN1_STRING_TABLE_get 3823 1_1_0 EXIST::FUNCTION:
+BN_bn2binpad 3824 1_1_0 EXIST::FUNCTION:
+X509_supported_extension 3825 1_1_0 EXIST::FUNCTION:
+ECDSA_sign_setup 3826 1_1_0 EXIST::FUNCTION:EC
+EVP_camellia_192_cfb128 3827 1_1_0 EXIST::FUNCTION:CAMELLIA
+d2i_AUTHORITY_KEYID 3828 1_1_0 EXIST::FUNCTION:
+RIPEMD160_Transform 3829 1_1_0 EXIST::FUNCTION:RMD160
+DES_random_key 3830 1_1_0 EXIST::FUNCTION:DES
+i2d_PKCS12_MAC_DATA 3831 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_get0_EC_KEY 3832 1_1_0 EXIST::FUNCTION:EC
+ASN1_SCTX_get_item 3833 1_1_0 EXIST::FUNCTION:
+NOTICEREF_new 3834 1_1_0 EXIST::FUNCTION:
+BN_GF2m_mod_inv 3835 1_1_0 EXIST::FUNCTION:EC2M
+X509_CERT_AUX_free 3836 1_1_0 EXIST::FUNCTION:
+BN_GF2m_mod_inv_arr 3837 1_1_0 EXIST::FUNCTION:EC2M
+X509_REQ_get1_email 3838 1_1_0 EXIST::FUNCTION:
+EC_KEY_print 3839 1_1_0 EXIST::FUNCTION:EC
+i2d_ASN1_INTEGER 3840 1_1_0 EXIST::FUNCTION:
+OCSP_SINGLERESP_add1_ext_i2d 3841 1_1_0 EXIST::FUNCTION:OCSP
+PKCS7_add_signed_attribute 3842 1_1_0 EXIST::FUNCTION:
+i2d_PrivateKey_bio 3843 1_1_0 EXIST::FUNCTION:
+RSA_padding_add_PKCS1_type_1 3844 1_1_0 EXIST::FUNCTION:RSA
+i2d_re_X509_tbs 3845 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_iv_length 3846 1_1_0 EXIST::FUNCTION:
+OCSP_REQ_CTX_get0_mem_bio 3847 1_1_0 EXIST::FUNCTION:OCSP
+i2d_PKCS8PrivateKeyInfo_bio 3848 1_1_0 EXIST::FUNCTION:
+d2i_OCSP_CERTID 3849 1_1_0 EXIST::FUNCTION:OCSP
+EVP_CIPHER_meth_set_init 3850 1_1_0 EXIST::FUNCTION:
+RIPEMD160_Final 3851 1_1_0 EXIST::FUNCTION:RMD160
+NETSCAPE_SPKI_free 3852 1_1_0 EXIST::FUNCTION:
+BIO_asn1_get_prefix 3853 1_1_0 EXIST::FUNCTION:
+d2i_OCSP_ONEREQ 3854 1_1_0 EXIST::FUNCTION:OCSP
+EVP_PKEY_asn1_set_security_bits 3855 1_1_0 EXIST::FUNCTION:
+i2d_CERTIFICATEPOLICIES 3856 1_1_0 EXIST::FUNCTION:
+i2d_X509_CERT_AUX 3857 1_1_0 EXIST::FUNCTION:
+i2o_ECPublicKey 3858 1_1_0 EXIST::FUNCTION:EC
+PKCS12_SAFEBAG_create0_pkcs8 3859 1_1_0 EXIST::FUNCTION:
+OBJ_get0_data 3860 1_1_0 EXIST::FUNCTION:
+EC_GROUP_get0_seed 3861 1_1_0 EXIST::FUNCTION:EC
+OCSP_REQUEST_it 3862 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:OCSP
+OCSP_REQUEST_it 3862 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:OCSP
+ASRange_it 3863 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:RFC3779
+ASRange_it 3863 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:RFC3779
+i2d_TS_RESP 3864 1_1_0 EXIST::FUNCTION:TS
+TS_TST_INFO_get_ext_by_OBJ 3865 1_1_0 EXIST::FUNCTION:TS
+d2i_PKCS7_RECIP_INFO 3866 1_1_0 EXIST::FUNCTION:
+d2i_X509_CRL 3867 1_1_0 EXIST::FUNCTION:
+ASN1_OCTET_STRING_dup 3868 1_1_0 EXIST::FUNCTION:
+CRYPTO_nistcts128_decrypt_block 3869 1_1_0 EXIST::FUNCTION:
+CMS_stream 3870 1_1_0 EXIST::FUNCTION:CMS
+RSA_OAEP_PARAMS_it 3871 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:RSA
+RSA_OAEP_PARAMS_it 3871 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:RSA
+BN_bn2mpi 3872 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_cleanup 3873 1_1_0 EXIST::FUNCTION:
+OCSP_onereq_get0_id 3874 1_1_0 EXIST::FUNCTION:OCSP
+X509_get_default_cert_dir 3875 1_1_0 EXIST::FUNCTION:
+PROXY_POLICY_free 3877 1_1_0 EXIST::FUNCTION:
+PEM_write_DSAPrivateKey 3878 1_1_0 EXIST::FUNCTION:DSA,STDIO
+OPENSSL_sk_delete_ptr 3879 1_1_0 EXIST::FUNCTION:
+CMS_add0_RevocationInfoChoice 3880 1_1_0 EXIST::FUNCTION:CMS
+ASN1_PCTX_get_flags 3881 1_1_0 EXIST::FUNCTION:
+EVP_MD_meth_set_result_size 3882 1_1_0 EXIST::FUNCTION:
+i2d_X509_CRL 3883 1_1_0 EXIST::FUNCTION:
+ASN1_INTEGER_it 3885 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ASN1_INTEGER_it 3885 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+TS_ACCURACY_new 3886 1_1_0 EXIST::FUNCTION:TS
+i2d_SXNETID 3887 1_1_0 EXIST::FUNCTION:
+BN_mod_mul_montgomery 3888 1_1_0 EXIST::FUNCTION:
+BN_nnmod 3889 1_1_0 EXIST::FUNCTION:
+TS_RESP_CTX_set_status_info_cond 3890 1_1_0 EXIST::FUNCTION:TS
+PBKDF2PARAM_new 3891 1_1_0 EXIST::FUNCTION:
+ENGINE_set_RSA 3892 1_1_0 EXIST::FUNCTION:ENGINE
+i2d_X509_ATTRIBUTE 3893 1_1_0 EXIST::FUNCTION:
+PKCS7_ctrl 3894 1_1_0 EXIST::FUNCTION:
+OCSP_REVOKEDINFO_it 3895 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:OCSP
+OCSP_REVOKEDINFO_it 3895 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:OCSP
+X509V3_set_ctx 3896 1_1_0 EXIST::FUNCTION:
+ASN1_ENUMERATED_set_int64 3897 1_1_0 EXIST::FUNCTION:
+o2i_SCT 3898 1_1_0 EXIST::FUNCTION:CT
+CRL_DIST_POINTS_free 3899 1_1_0 EXIST::FUNCTION:
+d2i_OCSP_SINGLERESP 3900 1_1_0 EXIST::FUNCTION:OCSP
+EVP_CIPHER_CTX_num 3901 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_verify_recover_init 3902 1_1_0 EXIST::FUNCTION:
+SHA512_Init 3903 1_1_0 EXIST::FUNCTION:
+TS_MSG_IMPRINT_set_msg 3904 1_1_0 EXIST::FUNCTION:TS
+CMS_unsigned_add1_attr 3905 1_1_0 EXIST::FUNCTION:CMS
+OPENSSL_LH_doall 3906 1_1_0 EXIST::FUNCTION:
+PKCS8_pkey_get0_attrs 3907 1_1_0 EXIST::FUNCTION:
+PKCS8_pkey_add1_attr_by_NID 3908 1_1_0 EXIST::FUNCTION:
+ASYNC_is_capable 3909 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_CTX_set_cipher_data 3910 1_1_0 EXIST::FUNCTION:
+EVP_CIPHER_CTX_get_cipher_data 3911 1_1_0 EXIST::FUNCTION:
+BIO_up_ref 3912 1_1_0 EXIST::FUNCTION:
+X509_STORE_up_ref 3913 1_1_0 EXIST::FUNCTION:
+DSA_SIG_get0 3914 1_1_0 EXIST::FUNCTION:DSA
+BN_BLINDING_is_current_thread 3915 1_1_0 EXIST::FUNCTION:
+BN_BLINDING_set_current_thread 3916 1_1_0 EXIST::FUNCTION:
+BN_BLINDING_lock 3917 1_1_0 EXIST::FUNCTION:
+BN_BLINDING_unlock 3918 1_1_0 EXIST::FUNCTION:
+EC_GROUP_new_from_ecpkparameters 3919 1_1_0 EXIST::FUNCTION:EC
+EC_GROUP_get_ecpkparameters 3920 1_1_0 EXIST::FUNCTION:EC
+EC_GROUP_new_from_ecparameters 3921 1_1_0 EXIST::FUNCTION:EC
+ECPARAMETERS_it 3922 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:EC
+ECPARAMETERS_it 3922 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:EC
+ECPKPARAMETERS_it 3923 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:EC
+ECPKPARAMETERS_it 3923 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:EC
+EC_GROUP_get_ecparameters 3924 1_1_0 EXIST::FUNCTION:EC
+DHparams_it 3925 1_1_0 EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:DH
+DHparams_it 3925 1_1_0 EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:DH
+EVP_blake2s256 3926 1_1_0 EXIST::FUNCTION:BLAKE2
+EVP_blake2b512 3927 1_1_0 EXIST::FUNCTION:BLAKE2
+X509_SIG_get0 3928 1_1_0 EXIST::FUNCTION:
+BIO_meth_new 3929 1_1_0 EXIST::FUNCTION:
+BIO_meth_get_puts 3930 1_1_0 EXIST::FUNCTION:
+BIO_meth_get_ctrl 3931 1_1_0 EXIST::FUNCTION:
+BIO_meth_get_gets 3932 1_1_0 EXIST::FUNCTION:
+BIO_get_data 3933 1_1_0 EXIST::FUNCTION:
+BIO_set_init 3934 1_1_0 EXIST::FUNCTION:
+BIO_meth_set_puts 3935 1_1_0 EXIST::FUNCTION:
+BIO_get_shutdown 3936 1_1_0 EXIST::FUNCTION:
+BIO_get_init 3937 1_1_0 EXIST::FUNCTION:
+BIO_meth_set_ctrl 3938 1_1_0 EXIST::FUNCTION:
+BIO_meth_set_read 3939 1_1_0 EXIST::FUNCTION:
+BIO_set_shutdown 3940 1_1_0 EXIST::FUNCTION:
+BIO_meth_set_create 3941 1_1_0 EXIST::FUNCTION:
+BIO_meth_get_write 3942 1_1_0 EXIST::FUNCTION:
+BIO_meth_set_callback_ctrl 3943 1_1_0 EXIST::FUNCTION:
+BIO_meth_get_create 3944 1_1_0 EXIST::FUNCTION:
+BIO_set_next 3945 1_1_0 EXIST::FUNCTION:
+BIO_set_data 3946 1_1_0 EXIST::FUNCTION:
+BIO_meth_set_write 3947 1_1_0 EXIST::FUNCTION:
+BIO_meth_set_destroy 3948 1_1_0 EXIST::FUNCTION:
+BIO_meth_set_gets 3949 1_1_0 EXIST::FUNCTION:
+BIO_meth_get_callback_ctrl 3950 1_1_0 EXIST::FUNCTION:
+BIO_meth_get_destroy 3951 1_1_0 EXIST::FUNCTION:
+BIO_meth_get_read 3952 1_1_0 EXIST::FUNCTION:
+BIO_set_retry_reason 3953 1_1_0 EXIST::FUNCTION:
+BIO_meth_free 3954 1_1_0 EXIST::FUNCTION:
+DSA_meth_set_bn_mod_exp 3955 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_set_init 3956 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_free 3957 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_set_mod_exp 3958 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_set_sign 3959 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_get_finish 3960 1_1_0 EXIST::FUNCTION:DSA
+DSA_set_flags 3961 1_1_0 EXIST::FUNCTION:DSA
+DSA_get0_pqg 3962 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_get0_app_data 3963 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_get_keygen 3964 1_1_0 EXIST::FUNCTION:DSA
+DSA_clear_flags 3965 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_get0_name 3966 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_get_paramgen 3967 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_get_sign 3968 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_set_paramgen 3969 1_1_0 EXIST::FUNCTION:DSA
+DSA_test_flags 3970 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_set0_app_data 3971 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_set1_name 3972 1_1_0 EXIST::FUNCTION:DSA
+DSA_get0_key 3973 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_get_mod_exp 3974 1_1_0 EXIST::FUNCTION:DSA
+DSA_set0_pqg 3975 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_get_flags 3976 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_get_verify 3977 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_set_verify 3978 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_set_finish 3979 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_set_keygen 3980 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_dup 3981 1_1_0 EXIST::FUNCTION:DSA
+DSA_set0_key 3982 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_get_init 3983 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_set_sign_setup 3984 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_get_bn_mod_exp 3985 1_1_0 EXIST::FUNCTION:DSA
+DSA_get_method 3986 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_new 3987 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_set_flags 3988 1_1_0 EXIST::FUNCTION:DSA
+DSA_meth_get_sign_setup 3989 1_1_0 EXIST::FUNCTION:DSA
+DSA_get0_engine 3990 1_1_0 EXIST::FUNCTION:DSA
+X509_VERIFY_PARAM_set_auth_level 3991 1_1_0 EXIST::FUNCTION:
+X509_VERIFY_PARAM_get_auth_level 3992 1_1_0 EXIST::FUNCTION:
+X509_REQ_get0_pubkey 3993 1_1_0 EXIST::FUNCTION:
+RSA_set0_key 3994 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_get_flags 3995 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_set_finish 3996 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_get_priv_dec 3997 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_get_sign 3998 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_get_bn_mod_exp 3999 1_1_0 EXIST::FUNCTION:RSA
+RSA_test_flags 4000 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_new 4001 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_get0_app_data 4002 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_dup 4003 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_set1_name 4004 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_set0_app_data 4005 1_1_0 EXIST::FUNCTION:RSA
+RSA_set_flags 4006 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_set_sign 4007 1_1_0 EXIST::FUNCTION:RSA
+RSA_clear_flags 4008 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_get_keygen 4009 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_set_keygen 4010 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_set_pub_dec 4011 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_get_finish 4012 1_1_0 EXIST::FUNCTION:RSA
+RSA_get0_key 4013 1_1_0 EXIST::FUNCTION:RSA
+RSA_get0_engine 4014 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_set_priv_enc 4015 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_set_verify 4016 1_1_0 EXIST::FUNCTION:RSA
+RSA_get0_factors 4017 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_get0_name 4018 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_get_mod_exp 4019 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_set_flags 4020 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_get_pub_dec 4021 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_set_bn_mod_exp 4022 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_get_init 4023 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_free 4024 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_get_pub_enc 4025 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_set_mod_exp 4026 1_1_0 EXIST::FUNCTION:RSA
+RSA_set0_factors 4027 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_set_pub_enc 4028 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_set_priv_dec 4029 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_get_verify 4030 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_set_init 4031 1_1_0 EXIST::FUNCTION:RSA
+RSA_meth_get_priv_enc 4032 1_1_0 EXIST::FUNCTION:RSA
+RSA_set0_crt_params 4037 1_1_0 EXIST::FUNCTION:RSA
+RSA_get0_crt_params 4038 1_1_0 EXIST::FUNCTION:RSA
+DH_set0_pqg 4039 1_1_0 EXIST::FUNCTION:DH
+DH_clear_flags 4041 1_1_0 EXIST::FUNCTION:DH
+DH_get0_key 4042 1_1_0 EXIST::FUNCTION:DH
+DH_get0_engine 4043 1_1_0 EXIST::FUNCTION:DH
+DH_set0_key 4044 1_1_0 EXIST::FUNCTION:DH
+DH_set_length 4045 1_1_0 EXIST::FUNCTION:DH
+DH_test_flags 4046 1_1_0 EXIST::FUNCTION:DH
+DH_get_length 4047 1_1_0 EXIST::FUNCTION:DH
+DH_get0_pqg 4048 1_1_0 EXIST::FUNCTION:DH
+DH_meth_get_compute_key 4049 1_1_0 EXIST::FUNCTION:DH
+DH_meth_set1_name 4050 1_1_0 EXIST::FUNCTION:DH
+DH_meth_set_init 4051 1_1_0 EXIST::FUNCTION:DH
+DH_meth_get_finish 4052 1_1_0 EXIST::FUNCTION:DH
+DH_meth_get0_name 4053 1_1_0 EXIST::FUNCTION:DH
+DH_meth_set_generate_params 4054 1_1_0 EXIST::FUNCTION:DH
+DH_meth_set_compute_key 4055 1_1_0 EXIST::FUNCTION:DH
+DH_meth_set_flags 4056 1_1_0 EXIST::FUNCTION:DH
+DH_meth_get_generate_params 4057 1_1_0 EXIST::FUNCTION:DH
+DH_meth_get_flags 4058 1_1_0 EXIST::FUNCTION:DH
+DH_meth_set_finish 4059 1_1_0 EXIST::FUNCTION:DH
+DH_meth_get0_app_data 4060 1_1_0 EXIST::FUNCTION:DH
+DH_meth_set0_app_data 4061 1_1_0 EXIST::FUNCTION:DH
+DH_meth_get_init 4062 1_1_0 EXIST::FUNCTION:DH
+DH_meth_get_bn_mod_exp 4063 1_1_0 EXIST::FUNCTION:DH
+DH_meth_new 4064 1_1_0 EXIST::FUNCTION:DH
+DH_meth_dup 4065 1_1_0 EXIST::FUNCTION:DH
+DH_meth_set_bn_mod_exp 4066 1_1_0 EXIST::FUNCTION:DH
+DH_meth_set_generate_key 4067 1_1_0 EXIST::FUNCTION:DH
+DH_meth_free 4068 1_1_0 EXIST::FUNCTION:DH
+DH_meth_get_generate_key 4069 1_1_0 EXIST::FUNCTION:DH
+DH_set_flags 4070 1_1_0 EXIST::FUNCTION:DH
+X509_STORE_CTX_get_obj_by_subject 4071 1_1_0 EXIST::FUNCTION:
+X509_OBJECT_free 4072 1_1_0 EXIST::FUNCTION:
+X509_OBJECT_get0_X509 4073 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get0_untrusted 4074 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_set_error_depth 4075 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get0_cert 4076 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_set_verify 4077 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_set_current_cert 4078 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_verify 4079 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_verify_cb 4080 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_set0_verified_chain 4081 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_set0_untrusted 4082 1_1_0 EXIST::FUNCTION:
+OPENSSL_hexchar2int 4083 1_1_0 EXIST::FUNCTION:
+X509_STORE_set_ex_data 4084 1_1_0 EXIST::FUNCTION:
+X509_STORE_get_ex_data 4085 1_1_0 EXIST::FUNCTION:
+X509_STORE_get0_objects 4086 1_1_0 EXIST::FUNCTION:
+X509_OBJECT_get_type 4087 1_1_0 EXIST::FUNCTION:
+X509_STORE_set_verify 4088 1_1_0 EXIST::FUNCTION:
+X509_OBJECT_new 4089 1_1_0 EXIST::FUNCTION:
+X509_STORE_get0_param 4090 1_1_0 EXIST::FUNCTION:
+PEM_write_bio_PrivateKey_traditional 4091 1_1_0 EXIST::FUNCTION:
+X509_get_pathlen 4092 1_1_0 EXIST::FUNCTION:
+ECDSA_SIG_set0 4093 1_1_0 EXIST::FUNCTION:EC
+DSA_SIG_set0 4094 1_1_0 EXIST::FUNCTION:DSA
+EVP_PKEY_get0_hmac 4095 1_1_0 EXIST::FUNCTION:
+HMAC_CTX_get_md 4096 1_1_0 EXIST::FUNCTION:
+NAME_CONSTRAINTS_check_CN 4097 1_1_0 EXIST::FUNCTION:
+OCSP_resp_get0_id 4098 1_1_0 EXIST::FUNCTION:OCSP
+OCSP_resp_get0_certs 4099 1_1_0 EXIST::FUNCTION:OCSP
+X509_set_proxy_flag 4100 1_1_0 EXIST::FUNCTION:
+EVP_ENCODE_CTX_copy 4101 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_check_issued 4102 1_1_0 EXIST::FUNCTION:
+X509_STORE_set_lookup_certs 4103 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_check_crl 4104 1_1_0 EXIST::FUNCTION:
+X509_STORE_get_cleanup 4105 1_1_0 EXIST::FUNCTION:
+X509_STORE_get_lookup_crls 4106 1_1_0 EXIST::FUNCTION:
+X509_STORE_get_cert_crl 4107 1_1_0 EXIST::FUNCTION:
+X509_STORE_get_lookup_certs 4108 1_1_0 EXIST::FUNCTION:
+X509_STORE_get_check_revocation 4109 1_1_0 EXIST::FUNCTION:
+X509_STORE_set_get_crl 4110 1_1_0 EXIST::FUNCTION:
+X509_STORE_set_check_issued 4111 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_check_policy 4112 1_1_0 EXIST::FUNCTION:
+X509_STORE_get_check_crl 4113 1_1_0 EXIST::FUNCTION:
+X509_STORE_set_check_crl 4114 1_1_0 EXIST::FUNCTION:
+X509_STORE_get_check_issued 4115 1_1_0 EXIST::FUNCTION:
+X509_STORE_get_get_issuer 4116 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_get_crl 4117 1_1_0 EXIST::FUNCTION:
+X509_STORE_set_get_issuer 4118 1_1_0 EXIST::FUNCTION:
+X509_STORE_set_cleanup 4119 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_cleanup 4120 1_1_0 EXIST::FUNCTION:
+X509_STORE_get_get_crl 4121 1_1_0 EXIST::FUNCTION:
+X509_STORE_set_check_revocation 4122 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_cert_crl 4123 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_lookup_certs 4124 1_1_0 EXIST::FUNCTION:
+X509_STORE_set_check_policy 4125 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_get_issuer 4126 1_1_0 EXIST::FUNCTION:
+X509_STORE_get_check_policy 4127 1_1_0 EXIST::FUNCTION:
+X509_STORE_set_cert_crl 4128 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_check_revocation 4129 1_1_0 EXIST::FUNCTION:
+X509_STORE_get_verify_cb 4130 1_1_0 EXIST::FUNCTION:
+X509_STORE_CTX_get_lookup_crls 4131 1_1_0 EXIST::FUNCTION:
+X509_STORE_get_verify 4132 1_1_0 EXIST::FUNCTION:
+X509_STORE_unlock 4133 1_1_0 EXIST::FUNCTION:
+X509_STORE_lock 4134 1_1_0 EXIST::FUNCTION:
+X509_set_proxy_pathlen 4135 1_1_0 EXIST::FUNCTION:
+X509_get_proxy_pathlen 4136 1_1_0 EXIST::FUNCTION:
+DSA_bits 4137 1_1_0 EXIST::FUNCTION:DSA
+EVP_PKEY_set1_tls_encodedpoint 4138 1_1_0 EXIST::FUNCTION:
+EVP_PKEY_get1_tls_encodedpoint 4139 1_1_0 EXIST::FUNCTION:
+ASN1_STRING_get0_data 4140 1_1_0 EXIST::FUNCTION:
+X509_SIG_getm 4141 1_1_0 EXIST::FUNCTION:
+X509_get0_serialNumber 4142 1_1_0 EXIST::FUNCTION:
+PKCS12_get_attr 4143 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0
+X509_CRL_get0_lastUpdate 4144 1_1_0 EXIST::FUNCTION:
+X509_get0_notBefore 4145 1_1_0 EXIST::FUNCTION:
+X509_get0_notAfter 4146 1_1_0 EXIST::FUNCTION:
+X509_CRL_get0_nextUpdate 4147 1_1_0 EXIST::FUNCTION:
+BIO_get_new_index 4148 1_1_0 EXIST::FUNCTION:
+OPENSSL_utf82uni 4149 1_1_0 EXIST::FUNCTION:
+PKCS12_add_friendlyname_utf8 4150 1_1_0 EXIST::FUNCTION:
+OPENSSL_uni2utf8 4151 1_1_0 EXIST::FUNCTION:
+PKCS12_key_gen_utf8 4152 1_1_0 EXIST::FUNCTION:
+ECPKPARAMETERS_free 4153 1_1_0 EXIST::FUNCTION:EC
+ECPARAMETERS_free 4154 1_1_0 EXIST::FUNCTION:EC
+ECPKPARAMETERS_new 4155 1_1_0 EXIST::FUNCTION:EC
+ECPARAMETERS_new 4156 1_1_0 EXIST::FUNCTION:EC
+OCSP_RESPID_set_by_name 4157 1_1_0a EXIST::FUNCTION:OCSP
+OCSP_RESPID_set_by_key 4158 1_1_0a EXIST::FUNCTION:OCSP
+OCSP_RESPID_match 4159 1_1_0a EXIST::FUNCTION:OCSP
+DSO_pathbyaddr 4170 1_1_0c EXIST::FUNCTION:
+DSO_dsobyaddr 4171 1_1_0c EXIST::FUNCTION:
+CT_POLICY_EVAL_CTX_get_time 4172 1_1_0d EXIST::FUNCTION:CT
+CT_POLICY_EVAL_CTX_set_time 4173 1_1_0d EXIST::FUNCTION:CT
+X509_VERIFY_PARAM_set_inh_flags 4174 1_1_0d EXIST::FUNCTION:
+X509_VERIFY_PARAM_get_inh_flags 4175 1_1_0d EXIST::FUNCTION:
+X509_VERIFY_PARAM_get_time 4181 1_1_0d EXIST::FUNCTION:
+DH_check_params 4183 1_1_0d EXIST::FUNCTION:DH
+INT32_it 4208 1_1_0f EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+INT32_it 4208 1_1_0f EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+UINT64_it 4209 1_1_0f EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+UINT64_it 4209 1_1_0f EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ZINT32_it 4210 1_1_0f EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ZINT32_it 4210 1_1_0f EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ZUINT64_it 4211 1_1_0f EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ZUINT64_it 4211 1_1_0f EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+INT64_it 4212 1_1_0f EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+INT64_it 4212 1_1_0f EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ZUINT32_it 4213 1_1_0f EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ZUINT32_it 4213 1_1_0f EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+UINT32_it 4214 1_1_0f EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+UINT32_it 4214 1_1_0f EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+ZINT64_it 4215 1_1_0f EXIST:!EXPORT_VAR_AS_FUNCTION:VARIABLE:
+ZINT64_it 4215 1_1_0f EXIST:EXPORT_VAR_AS_FUNCTION:FUNCTION:
+CRYPTO_secure_clear_free 4315 1_1_0g EXIST::FUNCTION:
+EVP_PKEY_set1_engine 4347 1_1_0g EXIST::FUNCTION:ENGINE
+OCSP_resp_get0_signer 4374 1_1_0h EXIST::FUNCTION:OCSP
+X509_get0_authority_key_id 4448 1_1_0h EXIST::FUNCTION:
diff --git a/openssl-1.1.0h/util/libssl.num b/openssl-1.1.0h/util/libssl.num
new file mode 100644
index 0000000..7b9b3c2
--- /dev/null
+++ b/openssl-1.1.0h/util/libssl.num
@@ -0,0 +1,407 @@
+SSL_get_selected_srtp_profile 1 1_1_0 EXIST::FUNCTION:SRTP
+SSL_set_read_ahead 2 1_1_0 EXIST::FUNCTION:
+SSL_set_accept_state 3 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_cipher_list 4 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_srp_client_pwd_callback 5 1_1_0 EXIST::FUNCTION:SRP
+SSL_copy_session_id 6 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_srp_password 7 1_1_0 EXIST::FUNCTION:SRP
+SSL_shutdown 8 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_msg_callback 9 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_get0_ticket 11 1_1_0 EXIST::FUNCTION:
+SSL_get1_supported_ciphers 12 1_1_0 EXIST::FUNCTION:
+SSL_state_string_long 13 1_1_0 EXIST::FUNCTION:
+SSL_CTX_get0_certificate 14 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_set_ex_data 15 1_1_0 EXIST::FUNCTION:
+SSL_get_verify_depth 16 1_1_0 EXIST::FUNCTION:
+SSL_get0_dane 17 1_1_0 EXIST::FUNCTION:
+SSL_CTX_sess_get_get_cb 18 1_1_0 EXIST::FUNCTION:
+SSL_CTX_get_default_passwd_cb_userdata 19 1_1_0 EXIST::FUNCTION:
+SSL_set_tmp_dh_callback 20 1_1_0 EXIST::FUNCTION:DH
+SSL_CTX_get_verify_depth 21 1_1_0 EXIST::FUNCTION:
+SSL_CTX_use_RSAPrivateKey_file 22 1_1_0 EXIST::FUNCTION:RSA
+SSL_use_PrivateKey_file 23 1_1_0 EXIST::FUNCTION:
+SSL_set_generate_session_id 24 1_1_0 EXIST::FUNCTION:
+SSL_get_ex_data_X509_STORE_CTX_idx 25 1_1_0 EXIST::FUNCTION:
+SSL_get_quiet_shutdown 26 1_1_0 EXIST::FUNCTION:
+SSL_dane_enable 27 1_1_0 EXIST::FUNCTION:
+SSL_COMP_add_compression_method 28 1_1_0 EXIST::FUNCTION:
+SSL_CTX_use_RSAPrivateKey 29 1_1_0 EXIST::FUNCTION:RSA
+SSL_CTX_sess_get_new_cb 30 1_1_0 EXIST::FUNCTION:
+d2i_SSL_SESSION 31 1_1_0 EXIST::FUNCTION:
+SSL_use_PrivateKey_ASN1 32 1_1_0 EXIST::FUNCTION:
+PEM_write_SSL_SESSION 33 1_1_0 EXIST::FUNCTION:STDIO
+SSL_CTX_set_session_id_context 34 1_1_0 EXIST::FUNCTION:
+SSL_CIPHER_get_cipher_nid 35 1_1_0 EXIST::FUNCTION:
+SSL_get_srp_g 36 1_1_0 EXIST::FUNCTION:SRP
+SSL_want 37 1_1_0 EXIST::FUNCTION:
+SSL_get_cipher_list 38 1_1_0 EXIST::FUNCTION:
+SSL_get_verify_result 39 1_1_0 EXIST::FUNCTION:
+SSL_renegotiate 40 1_1_0 EXIST::FUNCTION:
+SSL_get_privatekey 41 1_1_0 EXIST::FUNCTION:
+SSL_peek 42 1_1_0 EXIST::FUNCTION:
+SRP_Calc_A_param 43 1_1_0 EXIST::FUNCTION:SRP
+SSL_SESSION_get_ticket_lifetime_hint 44 1_1_0 EXIST::FUNCTION:
+SSL_SRP_CTX_free 45 1_1_0 EXIST::FUNCTION:SRP
+SSL_CTX_set_client_CA_list 46 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_next_proto_select_cb 47 1_1_0 EXIST::FUNCTION:NEXTPROTONEG
+BIO_ssl_copy_session_id 48 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_security_callback 49 1_1_0 EXIST::FUNCTION:
+SSL_CONF_cmd_value_type 50 1_1_0 EXIST::FUNCTION:
+SSL_CTX_remove_session 51 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_new 52 1_1_0 EXIST::FUNCTION:
+TLSv1_2_server_method 53 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,TLS1_2_METHOD
+BIO_new_buffer_ssl_connect 54 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set0_security_ex_data 55 1_1_0 EXIST::FUNCTION:
+SSL_alert_desc_string 56 1_1_0 EXIST::FUNCTION:
+SSL_get0_dane_authority 57 1_1_0 EXIST::FUNCTION:
+SSL_set_purpose 58 1_1_0 EXIST::FUNCTION:
+SSL_CTX_use_PrivateKey_file 59 1_1_0 EXIST::FUNCTION:
+SSL_get_rfd 60 1_1_0 EXIST::FUNCTION:
+DTLSv1_listen 61 1_1_0 EXIST::FUNCTION:SOCK
+SSL_set_ssl_method 62 1_1_0 EXIST::FUNCTION:
+SSL_get0_security_ex_data 63 1_1_0 EXIST::FUNCTION:
+SSLv3_client_method 64 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,SSL3_METHOD
+SSL_set_security_level 65 1_1_0 EXIST::FUNCTION:
+DTLSv1_2_method 66 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,DTLS1_2_METHOD
+SSL_get_fd 67 1_1_0 EXIST::FUNCTION:
+SSL_get1_session 68 1_1_0 EXIST::FUNCTION:
+SSL_use_RSAPrivateKey 69 1_1_0 EXIST::FUNCTION:RSA
+SSL_CTX_set_srp_cb_arg 70 1_1_0 EXIST::FUNCTION:SRP
+SSL_CTX_add_session 71 1_1_0 EXIST::FUNCTION:
+SSL_get_srp_N 72 1_1_0 EXIST::FUNCTION:SRP
+SSL_has_matching_session_id 73 1_1_0 EXIST::FUNCTION:
+PEM_read_SSL_SESSION 74 1_1_0 EXIST::FUNCTION:STDIO
+SSL_get_shared_ciphers 75 1_1_0 EXIST::FUNCTION:
+SSL_add1_host 76 1_1_0 EXIST::FUNCTION:
+SSL_CONF_cmd_argv 77 1_1_0 EXIST::FUNCTION:
+SSL_version 78 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_print 79 1_1_0 EXIST::FUNCTION:
+SSL_get_client_ciphers 80 1_1_0 EXIST::FUNCTION:
+SSL_get_srtp_profiles 81 1_1_0 EXIST::FUNCTION:SRTP
+SSL_use_certificate_ASN1 82 1_1_0 EXIST::FUNCTION:
+SSL_get_peer_certificate 83 1_1_0 EXIST::FUNCTION:
+DTLSv1_2_server_method 84 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,DTLS1_2_METHOD
+SSL_set_cert_cb 85 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_cookie_verify_cb 86 1_1_0 EXIST::FUNCTION:
+SSL_get_shared_sigalgs 87 1_1_0 EXIST::FUNCTION:
+SSL_config 88 1_1_0 EXIST::FUNCTION:
+TLSv1_1_client_method 89 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,TLS1_1_METHOD
+SSL_CIPHER_standard_name 90 1_1_0 EXIST::FUNCTION:SSL_TRACE
+SSL_CTX_get_verify_mode 91 1_1_0 EXIST::FUNCTION:
+SSL_get_all_async_fds 92 1_1_0 EXIST::FUNCTION:
+SSL_CTX_check_private_key 93 1_1_0 EXIST::FUNCTION:
+SSL_set_wfd 94 1_1_0 EXIST::FUNCTION:SOCK
+SSL_get_client_CA_list 95 1_1_0 EXIST::FUNCTION:
+SSL_CONF_CTX_set_flags 96 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_srp_username_callback 97 1_1_0 EXIST::FUNCTION:SRP
+SSL_connect 98 1_1_0 EXIST::FUNCTION:
+SSL_get_psk_identity 99 1_1_0 EXIST::FUNCTION:PSK
+SSL_CTX_use_certificate_file 100 1_1_0 EXIST::FUNCTION:
+SSL_set_session_ticket_ext 101 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_psk_server_callback 102 1_1_0 EXIST::FUNCTION:PSK
+SSL_get_sigalgs 103 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_next_protos_advertised_cb 104 1_1_0 EXIST::FUNCTION:NEXTPROTONEG
+SSL_CTX_set_trust 105 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_verify 106 1_1_0 EXIST::FUNCTION:
+SSL_set_rfd 107 1_1_0 EXIST::FUNCTION:SOCK
+SSL_SESSION_set_timeout 108 1_1_0 EXIST::FUNCTION:
+SSL_set_psk_client_callback 109 1_1_0 EXIST::FUNCTION:PSK
+SSL_get_client_random 110 1_1_0 EXIST::FUNCTION:
+TLS_method 111 1_1_0 EXIST::FUNCTION:
+SSL_CONF_CTX_clear_flags 112 1_1_0 EXIST::FUNCTION:
+TLSv1_client_method 113 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,TLS1_METHOD
+SSL_CIPHER_get_bits 114 1_1_0 EXIST::FUNCTION:
+SSL_test_functions 115 1_1_0 EXIST::FUNCTION:UNIT_TEST
+SSL_get_SSL_CTX 116 1_1_0 EXIST::FUNCTION:
+SSL_get_session 117 1_1_0 EXIST::FUNCTION:
+SSL_CTX_callback_ctrl 118 1_1_0 EXIST::FUNCTION:
+SSL_get_finished 119 1_1_0 EXIST::FUNCTION:
+SSL_add_dir_cert_subjects_to_stack 120 1_1_0 EXIST::FUNCTION:
+SSL_get_state 121 1_1_0 EXIST::FUNCTION:
+SSL_CONF_CTX_finish 122 1_1_0 EXIST::FUNCTION:
+SSL_CTX_add_server_custom_ext 123 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_get_ex_data 124 1_1_0 EXIST::FUNCTION:
+SSL_get_srp_username 125 1_1_0 EXIST::FUNCTION:SRP
+SSL_CTX_set_purpose 126 1_1_0 EXIST::FUNCTION:
+SSL_clear 127 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_cert_store 128 1_1_0 EXIST::FUNCTION:
+TLSv1_2_method 129 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,TLS1_2_METHOD
+SSL_session_reused 130 1_1_0 EXIST::FUNCTION:
+SSL_free 131 1_1_0 EXIST::FUNCTION:
+BIO_ssl_shutdown 132 1_1_0 EXIST::FUNCTION:
+SSL_CTX_get_client_CA_list 133 1_1_0 EXIST::FUNCTION:
+SSL_CTX_sessions 134 1_1_0 EXIST::FUNCTION:
+SSL_get_options 135 1_1_0 EXIST::FUNCTION:
+SSL_set_verify_depth 136 1_1_0 EXIST::FUNCTION:
+SSL_get_error 137 1_1_0 EXIST::FUNCTION:
+SSL_get_servername 138 1_1_0 EXIST::FUNCTION:
+SSL_get_version 139 1_1_0 EXIST::FUNCTION:
+SSL_state_string 140 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_get_timeout 141 1_1_0 EXIST::FUNCTION:
+SSL_CTX_sess_get_remove_cb 142 1_1_0 EXIST::FUNCTION:
+SSL_get_current_cipher 143 1_1_0 EXIST::FUNCTION:
+SSL_up_ref 144 1_1_0 EXIST::FUNCTION:
+SSL_export_keying_material 145 1_1_0 EXIST::FUNCTION:
+SSL_callback_ctrl 146 1_1_0 EXIST::FUNCTION:
+SSL_set_security_callback 147 1_1_0 EXIST::FUNCTION:
+SSL_SRP_CTX_init 148 1_1_0 EXIST::FUNCTION:SRP
+ERR_load_SSL_strings 149 1_1_0 EXIST::FUNCTION:
+SSL_CTX_SRP_CTX_init 150 1_1_0 EXIST::FUNCTION:SRP
+SSL_SESSION_set_time 151 1_1_0 EXIST::FUNCTION:
+i2d_SSL_SESSION 152 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_get_master_key 153 1_1_0 EXIST::FUNCTION:
+SSL_COMP_get_compression_methods 154 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_alpn_select_cb 155 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_tmp_dh_callback 156 1_1_0 EXIST::FUNCTION:DH
+SSL_CTX_get_default_passwd_cb 157 1_1_0 EXIST::FUNCTION:
+TLSv1_server_method 158 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,TLS1_METHOD
+DTLS_server_method 159 1_1_0 EXIST::FUNCTION:
+SSL_set0_rbio 160 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_options 161 1_1_0 EXIST::FUNCTION:
+SSL_set_msg_callback 162 1_1_0 EXIST::FUNCTION:
+SSL_CONF_CTX_free 163 1_1_0 EXIST::FUNCTION:
+SSL_CTX_get_ssl_method 164 1_1_0 EXIST::FUNCTION:
+SSL_get_server_random 165 1_1_0 EXIST::FUNCTION:
+SSL_set_shutdown 166 1_1_0 EXIST::FUNCTION:
+SSL_CTX_add_client_CA 167 1_1_0 EXIST::FUNCTION:
+TLSv1_1_server_method 168 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,TLS1_1_METHOD
+PEM_write_bio_SSL_SESSION 169 1_1_0 EXIST::FUNCTION:
+SSL_write 170 1_1_0 EXIST::FUNCTION:
+SSL_set1_host 171 1_1_0 EXIST::FUNCTION:
+SSL_use_RSAPrivateKey_file 172 1_1_0 EXIST::FUNCTION:RSA
+SSL_CTX_get_info_callback 173 1_1_0 EXIST::FUNCTION:
+SSL_get0_peername 174 1_1_0 EXIST::FUNCTION:
+SSL_set_srp_server_param 175 1_1_0 EXIST::FUNCTION:SRP
+TLS_server_method 176 1_1_0 EXIST::FUNCTION:
+SSL_get_psk_identity_hint 177 1_1_0 EXIST::FUNCTION:PSK
+SSL_set_session 178 1_1_0 EXIST::FUNCTION:
+SSL_get0_param 179 1_1_0 EXIST::FUNCTION:
+SSL_set_default_passwd_cb 180 1_1_0 EXIST::FUNCTION:
+SSL_get_read_ahead 181 1_1_0 EXIST::FUNCTION:
+SSL_dup_CA_list 182 1_1_0 EXIST::FUNCTION:
+SSL_get_verify_callback 183 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_default_passwd_cb 184 1_1_0 EXIST::FUNCTION:
+SSL_get_servername_type 185 1_1_0 EXIST::FUNCTION:
+TLSv1_2_client_method 186 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,TLS1_2_METHOD
+SSL_add_client_CA 187 1_1_0 EXIST::FUNCTION:
+SSL_CTX_get0_security_ex_data 188 1_1_0 EXIST::FUNCTION:
+SSL_get_ex_data 189 1_1_0 EXIST::FUNCTION:
+SSL_CTX_flush_sessions 190 1_1_0 EXIST::FUNCTION:
+SSL_use_PrivateKey 191 1_1_0 EXIST::FUNCTION:
+DTLSv1_client_method 192 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,DTLS1_METHOD
+SSL_CTX_dane_mtype_set 193 1_1_0 EXIST::FUNCTION:
+SSL_get_wfd 194 1_1_0 EXIST::FUNCTION:
+SSL_get_ssl_method 195 1_1_0 EXIST::FUNCTION:
+SSL_set_verify_result 196 1_1_0 EXIST::FUNCTION:
+SSL_use_RSAPrivateKey_ASN1 197 1_1_0 EXIST::FUNCTION:RSA
+SSL_CIPHER_get_name 198 1_1_0 EXIST::FUNCTION:
+OPENSSL_init_ssl 199 1_1_0 EXIST::FUNCTION:
+SSL_dup 200 1_1_0 EXIST::FUNCTION:
+SSL_CTX_use_serverinfo 201 1_1_0 EXIST::FUNCTION:
+SSL_CTX_use_serverinfo_file 202 1_1_0 EXIST::FUNCTION:
+SSL_set_options 203 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_default_verify_dir 204 1_1_0 EXIST::FUNCTION:
+SSL_do_handshake 205 1_1_0 EXIST::FUNCTION:
+SSL_CTX_get_ex_data 206 1_1_0 EXIST::FUNCTION:
+SSL_is_init_finished 207 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_default_verify_file 208 1_1_0 EXIST::FUNCTION:
+SSLv3_method 209 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,SSL3_METHOD
+SSL_CTX_set_cookie_generate_cb 210 1_1_0 EXIST::FUNCTION:
+SSL_certs_clear 211 1_1_0 EXIST::FUNCTION:
+SSL_set_connect_state 212 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_ex_data 213 1_1_0 EXIST::FUNCTION:
+SSL_rstate_string 214 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_get0_peer 215 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_get_compress_id 216 1_1_0 EXIST::FUNCTION:
+SSL_get_peer_cert_chain 217 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_cert_cb 218 1_1_0 EXIST::FUNCTION:
+PEM_read_bio_SSL_SESSION 219 1_1_0 EXIST::FUNCTION:
+SSL_set_info_callback 220 1_1_0 EXIST::FUNCTION:
+SSL_CTX_sess_set_new_cb 221 1_1_0 EXIST::FUNCTION:
+SSL_CTX_get_security_level 222 1_1_0 EXIST::FUNCTION:
+SSL_CTX_ctrl 223 1_1_0 EXIST::FUNCTION:
+SSL_set_alpn_protos 224 1_1_0 EXIST::FUNCTION:
+SSL_set_ex_data 225 1_1_0 EXIST::FUNCTION:
+SSL_rstate_string_long 226 1_1_0 EXIST::FUNCTION:
+SSL_ctrl 227 1_1_0 EXIST::FUNCTION:
+SSL_get_current_compression 228 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_has_ticket 229 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_cert_verify_callback 230 1_1_0 EXIST::FUNCTION:
+SSL_set_session_secret_cb 231 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_client_cert_engine 232 1_1_0 EXIST::FUNCTION:ENGINE
+SSL_CTX_get0_param 233 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set1_param 234 1_1_0 EXIST::FUNCTION:
+SSL_get_certificate 235 1_1_0 EXIST::FUNCTION:
+DTLSv1_server_method 236 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,DTLS1_METHOD
+SSL_set_fd 237 1_1_0 EXIST::FUNCTION:SOCK
+SSL_use_certificate 238 1_1_0 EXIST::FUNCTION:
+DTLSv1_method 239 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,DTLS1_METHOD
+SSL_set0_wbio 240 1_1_0 EXIST::FUNCTION:
+SSL_read 241 1_1_0 EXIST::FUNCTION:
+SSL_CTX_get_options 242 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_ssl_version 243 1_1_0 EXIST::FUNCTION:
+SSL_set_SSL_CTX 244 1_1_0 EXIST::FUNCTION:
+SSL_renegotiate_abbreviated 245 1_1_0 EXIST::FUNCTION:
+SSL_get_verify_mode 246 1_1_0 EXIST::FUNCTION:
+SSL_CIPHER_get_id 247 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_print_keylog 248 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_psk_client_callback 249 1_1_0 EXIST::FUNCTION:PSK
+SSL_SESSION_get_time 250 1_1_0 EXIST::FUNCTION:
+SSL_set_debug 251 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0
+SSL_get_security_level 252 1_1_0 EXIST::FUNCTION:
+SSL_CIPHER_description 253 1_1_0 EXIST::FUNCTION:
+SSL_set_default_passwd_cb_userdata 254 1_1_0 EXIST::FUNCTION:
+SSL_get_srp_userinfo 255 1_1_0 EXIST::FUNCTION:SRP
+SSL_extension_supported 256 1_1_0 EXIST::FUNCTION:
+SSL_dane_tlsa_add 257 1_1_0 EXIST::FUNCTION:
+SSL_srp_server_param_with_username 258 1_1_0 EXIST::FUNCTION:SRP
+SSL_CIPHER_get_version 259 1_1_0 EXIST::FUNCTION:
+SSL_get0_verified_chain 260 1_1_0 EXIST::FUNCTION:
+SSL_CIPHER_find 261 1_1_0 EXIST::FUNCTION:
+SSL_get_rbio 262 1_1_0 EXIST::FUNCTION:
+SSL_CONF_CTX_set_ssl 263 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_verify_depth 264 1_1_0 EXIST::FUNCTION:
+SSL_get_ciphers 265 1_1_0 EXIST::FUNCTION:
+SSL_CTX_config 266 1_1_0 EXIST::FUNCTION:
+SSL_CONF_CTX_set_ssl_ctx 267 1_1_0 EXIST::FUNCTION:
+SSL_CONF_cmd 268 1_1_0 EXIST::FUNCTION:
+SSL_add_ssl_module 269 1_1_0 EXIST::FUNCTION:
+SSL_CTX_get_verify_callback 270 1_1_0 EXIST::FUNCTION:
+SSL_set1_param 271 1_1_0 EXIST::FUNCTION:
+SSL_use_certificate_file 272 1_1_0 EXIST::FUNCTION:
+SSL_get_changed_async_fds 273 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_client_cert_cb 274 1_1_0 EXIST::FUNCTION:
+DTLS_client_method 275 1_1_0 EXIST::FUNCTION:
+SSL_set_trust 276 1_1_0 EXIST::FUNCTION:
+SSL_CTX_get_security_callback 277 1_1_0 EXIST::FUNCTION:
+SSL_CTX_clear_options 278 1_1_0 EXIST::FUNCTION:
+SSL_check_chain 279 1_1_0 EXIST::FUNCTION:
+SSL_CTX_sess_set_remove_cb 280 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_info_callback 281 1_1_0 EXIST::FUNCTION:
+SSL_pending 282 1_1_0 EXIST::FUNCTION:
+SSL_set_bio 283 1_1_0 EXIST::FUNCTION:
+BIO_new_ssl_connect 284 1_1_0 EXIST::FUNCTION:
+SSL_waiting_for_async 285 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_srp_strength 286 1_1_0 EXIST::FUNCTION:SRP
+SSL_CTX_get_quiet_shutdown 287 1_1_0 EXIST::FUNCTION:
+SSL_CTX_use_certificate_chain_file 288 1_1_0 EXIST::FUNCTION:
+SSL_CTX_dane_enable 289 1_1_0 EXIST::FUNCTION:
+SSL_CONF_CTX_new 290 1_1_0 EXIST::FUNCTION:
+SSL_get0_alpn_selected 291 1_1_0 EXIST::FUNCTION:
+SSL_get0_next_proto_negotiated 292 1_1_0 EXIST::FUNCTION:NEXTPROTONEG
+SSL_set0_security_ex_data 293 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_tlsext_use_srtp 294 1_1_0 EXIST::FUNCTION:SRTP
+SSL_COMP_set0_compression_methods 295 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_not_resumable_session_callback 296 1_1_0 EXIST::FUNCTION:
+SSL_accept 297 1_1_0 EXIST::FUNCTION:
+SSL_use_psk_identity_hint 298 1_1_0 EXIST::FUNCTION:PSK
+SSL_trace 299 1_1_0 EXIST::FUNCTION:SSL_TRACE
+DTLS_method 300 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_srp_verify_param_callback 301 1_1_0 EXIST::FUNCTION:SRP
+SSL_CTX_set_timeout 302 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_security_level 303 1_1_0 EXIST::FUNCTION:
+TLS_client_method 304 1_1_0 EXIST::FUNCTION:
+SSL_set_quiet_shutdown 305 1_1_0 EXIST::FUNCTION:
+SSL_CTX_up_ref 306 1_1_0 EXIST::FUNCTION:
+SSL_check_private_key 307 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_quiet_shutdown 308 1_1_0 EXIST::FUNCTION:
+SSL_select_next_proto 309 1_1_0 EXIST::FUNCTION:
+SSL_load_client_CA_file 310 1_1_0 EXIST::FUNCTION:
+SSL_set_srp_server_param_pw 311 1_1_0 EXIST::FUNCTION:SRP
+SSL_renegotiate_pending 312 1_1_0 EXIST::FUNCTION:
+SSL_CTX_new 313 1_1_0 EXIST::FUNCTION:
+SSL_set_session_ticket_ext_cb 314 1_1_0 EXIST::FUNCTION:
+SSL_CTX_get_timeout 315 1_1_0 EXIST::FUNCTION:
+SSL_use_certificate_chain_file 316 1_1_0 EXIST::FUNCTION:
+SSL_set_not_resumable_session_callback 317 1_1_0 EXIST::FUNCTION:
+SSL_CTX_SRP_CTX_free 318 1_1_0 EXIST::FUNCTION:SRP
+SSL_get_current_expansion 319 1_1_0 EXIST::FUNCTION:
+SSL_clear_options 320 1_1_0 EXIST::FUNCTION:
+SSL_CTX_use_PrivateKey 321 1_1_0 EXIST::FUNCTION:
+SSL_get_info_callback 322 1_1_0 EXIST::FUNCTION:
+SSL_CTX_use_psk_identity_hint 323 1_1_0 EXIST::FUNCTION:PSK
+SSL_CTX_use_RSAPrivateKey_ASN1 324 1_1_0 EXIST::FUNCTION:RSA
+SSL_CTX_use_PrivateKey_ASN1 325 1_1_0 EXIST::FUNCTION:
+SSL_CTX_get0_privatekey 326 1_1_0 EXIST::FUNCTION:
+BIO_f_ssl 327 1_1_0 EXIST::FUNCTION:
+SSLv3_server_method 328 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,SSL3_METHOD
+SSL_SESSION_free 329 1_1_0 EXIST::FUNCTION:
+SSL_get_shutdown 330 1_1_0 EXIST::FUNCTION:
+SSL_get_peer_finished 331 1_1_0 EXIST::FUNCTION:
+SSL_set_tlsext_use_srtp 332 1_1_0 EXIST::FUNCTION:SRTP
+TLSv1_method 333 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,TLS1_METHOD
+SSL_set_psk_server_callback 334 1_1_0 EXIST::FUNCTION:PSK
+SSL_CTX_set_alpn_protos 335 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_default_verify_paths 336 1_1_0 EXIST::FUNCTION:
+SSL_CTX_sess_set_get_cb 337 1_1_0 EXIST::FUNCTION:
+SSL_add_file_cert_subjects_to_stack 338 1_1_0 EXIST::FUNCTION:
+SSL_get_default_passwd_cb_userdata 339 1_1_0 EXIST::FUNCTION:
+SSL_get_security_callback 340 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_srp_username 341 1_1_0 EXIST::FUNCTION:SRP
+SSL_COMP_get_name 342 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_default_passwd_cb_userdata 343 1_1_0 EXIST::FUNCTION:
+SSL_set_verify 344 1_1_0 EXIST::FUNCTION:
+SSL_in_before 345 1_1_0 EXIST::FUNCTION:
+SSL_CIPHER_get_digest_nid 346 1_1_0 EXIST::FUNCTION:
+SSL_CTX_add_client_custom_ext 347 1_1_0 EXIST::FUNCTION:
+SSL_CTX_use_certificate 348 1_1_0 EXIST::FUNCTION:
+SSL_set_cipher_list 349 1_1_0 EXIST::FUNCTION:
+SSL_get_wbio 350 1_1_0 EXIST::FUNCTION:
+SSL_set_hostflags 351 1_1_0 EXIST::FUNCTION:
+SSL_alert_desc_string_long 352 1_1_0 EXIST::FUNCTION:
+SSL_get_default_timeout 353 1_1_0 EXIST::FUNCTION:
+SSL_set_session_id_context 354 1_1_0 EXIST::FUNCTION:
+SSL_new 355 1_1_0 EXIST::FUNCTION:
+TLSv1_1_method 356 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,TLS1_1_METHOD
+SSL_CTX_get_cert_store 357 1_1_0 EXIST::FUNCTION:
+SSL_CTX_load_verify_locations 358 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_print_fp 359 1_1_0 EXIST::FUNCTION:STDIO
+SSL_get0_dane_tlsa 360 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_generate_session_id 361 1_1_0 EXIST::FUNCTION:
+SSL_alert_type_string_long 362 1_1_0 EXIST::FUNCTION:
+SSL_CONF_CTX_set1_prefix 363 1_1_0 EXIST::FUNCTION:
+SSL_in_init 364 1_1_0 EXIST::FUNCTION:
+BIO_new_ssl 365 1_1_0 EXIST::FUNCTION:
+SSL_CTX_get_client_cert_cb 366 1_1_0 EXIST::FUNCTION:
+SSL_CTX_use_certificate_ASN1 367 1_1_0 EXIST::FUNCTION:
+SSL_set_client_CA_list 368 1_1_0 EXIST::FUNCTION:
+SSL_CTX_free 369 1_1_0 EXIST::FUNCTION:
+SSL_get_default_passwd_cb 370 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_get_id 371 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_set1_id_context 372 1_1_0 EXIST::FUNCTION:
+SSL_is_server 373 1_1_0 EXIST::FUNCTION:
+SSL_alert_type_string 374 1_1_0 EXIST::FUNCTION:
+DTLSv1_2_client_method 375 1_1_0 EXIST::FUNCTION:DEPRECATEDIN_1_1_0,DTLS1_2_METHOD
+SSL_CTX_set_ctlog_list_file 376 1_1_0 EXIST::FUNCTION:CT
+SSL_set_ct_validation_callback 377 1_1_0 EXIST::FUNCTION:CT
+SSL_CTX_set_default_ctlog_list_file 378 1_1_0 EXIST::FUNCTION:CT
+SSL_CTX_has_client_custom_ext 379 1_1_0 EXIST::FUNCTION:
+SSL_ct_is_enabled 380 1_1_0 EXIST::FUNCTION:CT
+SSL_get0_peer_scts 381 1_1_0 EXIST::FUNCTION:CT
+SSL_CTX_set_ct_validation_callback 382 1_1_0 EXIST::FUNCTION:CT
+SSL_CTX_ct_is_enabled 383 1_1_0 EXIST::FUNCTION:CT
+SSL_set_default_read_buffer_len 384 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set_default_read_buffer_len 385 1_1_0 EXIST::FUNCTION:
+SSL_has_pending 386 1_1_0 EXIST::FUNCTION:
+SSL_CIPHER_get_auth_nid 387 1_1_0 EXIST::FUNCTION:
+SSL_CIPHER_get_kx_nid 388 1_1_0 EXIST::FUNCTION:
+SSL_CIPHER_is_aead 389 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_up_ref 390 1_1_0 EXIST::FUNCTION:
+SSL_CTX_set0_ctlog_store 391 1_1_0 EXIST::FUNCTION:CT
+SSL_CTX_get0_ctlog_store 392 1_1_0 EXIST::FUNCTION:CT
+SSL_enable_ct 393 1_1_0 EXIST::FUNCTION:CT
+SSL_CTX_enable_ct 394 1_1_0 EXIST::FUNCTION:CT
+SSL_CTX_get_ciphers 395 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_get0_hostname 396 1_1_0 EXIST::FUNCTION:
+SSL_client_version 397 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_get_protocol_version 398 1_1_0 EXIST::FUNCTION:
+SSL_is_dtls 399 1_1_0 EXIST::FUNCTION:
+SSL_CTX_dane_set_flags 400 1_1_0 EXIST::FUNCTION:
+SSL_dane_set_flags 401 1_1_0 EXIST::FUNCTION:
+SSL_CTX_dane_clear_flags 402 1_1_0 EXIST::FUNCTION:
+SSL_dane_clear_flags 403 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_get0_cipher 404 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_get0_id_context 405 1_1_0 EXIST::FUNCTION:
+SSL_SESSION_set1_id 406 1_1_0 EXIST::FUNCTION:
+SSL_COMP_get_id 412 1_1_0d EXIST::FUNCTION:
+SSL_COMP_get0_name 413 1_1_0d EXIST::FUNCTION:
diff --git a/openssl-1.1.0h/util/local_shlib.com.in b/openssl-1.1.0h/util/local_shlib.com.in
new file mode 100644
index 0000000..e49aa15
--- /dev/null
+++ b/openssl-1.1.0h/util/local_shlib.com.in
@@ -0,0 +1,30 @@
+${-
+ use File::Spec::Functions qw(rel2abs);
+
+ my $bldtop = rel2abs($config{builddir});
+ our %names = ( map { $_ => $bldtop.$_.".EXE" }
+ map { $unified_info{sharednames}->{$_} || () }
+ @{$unified_info{libraries}} );
+ "" -}
+$ ! Create a local environment with the shared library logical names
+$ ! properly set. Undo this with unlocal_shlib.com
+$
+$ OPENSSL_NAMES := OPENSSL_NAMES_'F$GETJPI("","PID")'
+$ CREATE/NAME_TABLE/PARENT_TABLE=LNM$PROCESS_DIRECTORY 'OPENSSL_NAMES'
+$ DEFINE/TABLE='OPENSSL_NAMES' OSSL_FLAG YES
+$
+$ NAMES := {- join(",", keys %names); -}
+{-
+ join("\n", map { "\$ __$_ = \"".$names{$_}."\"" } keys %names);
+-}
+$ I = 0
+$ LOOP:
+$ E = F$ELEMENT(I,",",NAMES)
+$ I = I + 1
+$ IF E .EQS. "," THEN GOTO ENDLOOP
+$ EV = __'E'
+$ OLDV = F$TRNLNM(E,"LNM$PROCESS")
+$ IF OLDV .NES. "" THEN DEFINE/TABLE='OPENSSL_NAMES' 'E' 'OLDV'
+$ DEFINE 'E' 'EV'
+$ GOTO LOOP
+$ ENDLOOP:
diff --git a/openssl-1.1.0h/util/mkbuildinf.pl b/openssl-1.1.0h/util/mkbuildinf.pl
new file mode 100755
index 0000000..5bf0168
--- /dev/null
+++ b/openssl-1.1.0h/util/mkbuildinf.pl
@@ -0,0 +1,41 @@
+#! /usr/bin/env perl
+# Copyright 2014-2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+
+my ($cflags, $platform) = @ARGV;
+
+$cflags = "compiler: $cflags";
+$date = localtime();
+print <<"END_OUTPUT";
+/* auto-generated by util/mkbuildinf.pl for crypto/cversion.c */
+#define CFLAGS cflags
+/*
+ * Generate CFLAGS as an array of individual characters. This is a
+ * workaround for the situation where CFLAGS gets too long for a C90 string
+ * literal
+ */
+static const char cflags[] = {
+END_OUTPUT
+my $ctr = 0;
+foreach my $c (split //, $cflags) {
+ $c =~ s|([\\'])|\\$1|;
+ # Max 16 characters per line
+ if (($ctr++ % 16) == 0) {
+ if ($ctr != 1) {
+ print "\n";
+ }
+ print " ";
+ }
+ print "'$c',";
+}
+print <<"END_OUTPUT";
+'\\0'
+};
+#define PLATFORM "platform: $platform"
+#define DATE "built on: $date"
+END_OUTPUT
diff --git a/openssl-1.1.0h/util/mkcerts.sh b/openssl-1.1.0h/util/mkcerts.sh
new file mode 100755
index 0000000..e4a9892
--- /dev/null
+++ b/openssl-1.1.0h/util/mkcerts.sh
@@ -0,0 +1,220 @@
+#!/bin/sh
+
+# This script will re-make all the required certs.
+# cd apps
+# sh ../util/mkcerts.sh
+# mv ca-cert.pem pca-cert.pem ../certs
+# cd ..
+# cat certs/*.pem >>apps/server.pem
+# cat certs/*.pem >>apps/server2.pem
+# SSLEAY=`pwd`/apps/ssleay; export SSLEAY
+# sh tools/c_rehash certs
+#
+
+CAbits=1024
+SSLEAY="../apps/openssl"
+CONF="-config ../apps/openssl.cnf"
+
+# create pca request.
+echo creating $CAbits bit PCA cert request
+$SSLEAY req $CONF \
+ -new -sha256 -newkey $CAbits \
+ -keyout pca-key.pem \
+ -out pca-req.pem -nodes >/dev/null <<EOF
+AU
+Queensland
+.
+CryptSoft Pty Ltd
+.
+Test PCA (1024 bit)
+
+
+
+EOF
+
+if [ $? != 0 ]; then
+ echo problems generating PCA request
+ exit 1
+fi
+
+#sign it.
+echo
+echo self signing PCA
+$SSLEAY x509 -sha256 -days 36525 \
+ -req -signkey pca-key.pem \
+ -CAcreateserial -CAserial pca-cert.srl \
+ -in pca-req.pem -out pca-cert.pem
+
+if [ $? != 0 ]; then
+ echo problems self signing PCA cert
+ exit 1
+fi
+echo
+
+# create ca request.
+echo creating $CAbits bit CA cert request
+$SSLEAY req $CONF \
+ -new -sha256 -newkey $CAbits \
+ -keyout ca-key.pem \
+ -out ca-req.pem -nodes >/dev/null <<EOF
+AU
+Queensland
+.
+CryptSoft Pty Ltd
+.
+Test CA (1024 bit)
+
+
+
+EOF
+
+if [ $? != 0 ]; then
+ echo problems generating CA request
+ exit 1
+fi
+
+#sign it.
+echo
+echo signing CA
+$SSLEAY x509 -sha256 -days 36525 \
+ -req \
+ -CAcreateserial -CAserial pca-cert.srl \
+ -CA pca-cert.pem -CAkey pca-key.pem \
+ -in ca-req.pem -out ca-cert.pem
+
+if [ $? != 0 ]; then
+ echo problems signing CA cert
+ exit 1
+fi
+echo
+
+# create server request.
+echo creating 512 bit server cert request
+$SSLEAY req $CONF \
+ -new -sha256 -newkey 512 \
+ -keyout s512-key.pem \
+ -out s512-req.pem -nodes >/dev/null <<EOF
+AU
+Queensland
+.
+CryptSoft Pty Ltd
+.
+Server test cert (512 bit)
+
+
+
+EOF
+
+if [ $? != 0 ]; then
+ echo problems generating 512 bit server cert request
+ exit 1
+fi
+
+#sign it.
+echo
+echo signing 512 bit server cert
+$SSLEAY x509 -sha256 -days 36525 \
+ -req \
+ -CAcreateserial -CAserial ca-cert.srl \
+ -CA ca-cert.pem -CAkey ca-key.pem \
+ -in s512-req.pem -out server.pem
+
+if [ $? != 0 ]; then
+ echo problems signing 512 bit server cert
+ exit 1
+fi
+echo
+
+# create 1024 bit server request.
+echo creating 1024 bit server cert request
+$SSLEAY req $CONF \
+ -new -sha256 -newkey 1024 \
+ -keyout s1024key.pem \
+ -out s1024req.pem -nodes >/dev/null <<EOF
+AU
+Queensland
+.
+CryptSoft Pty Ltd
+.
+Server test cert (1024 bit)
+
+
+
+EOF
+
+if [ $? != 0 ]; then
+ echo problems generating 1024 bit server cert request
+ exit 1
+fi
+
+#sign it.
+echo
+echo signing 1024 bit server cert
+$SSLEAY x509 -sha256 -days 36525 \
+ -req \
+ -CAcreateserial -CAserial ca-cert.srl \
+ -CA ca-cert.pem -CAkey ca-key.pem \
+ -in s1024req.pem -out server2.pem
+
+if [ $? != 0 ]; then
+ echo problems signing 1024 bit server cert
+ exit 1
+fi
+echo
+
+# create 512 bit client request.
+echo creating 512 bit client cert request
+$SSLEAY req $CONF \
+ -new -sha256 -newkey 512 \
+ -keyout c512-key.pem \
+ -out c512-req.pem -nodes >/dev/null <<EOF
+AU
+Queensland
+.
+CryptSoft Pty Ltd
+.
+Client test cert (512 bit)
+
+
+
+EOF
+
+if [ $? != 0 ]; then
+ echo problems generating 512 bit client cert request
+ exit 1
+fi
+
+#sign it.
+echo
+echo signing 512 bit client cert
+$SSLEAY x509 -sha256 -days 36525 \
+ -req \
+ -CAcreateserial -CAserial ca-cert.srl \
+ -CA ca-cert.pem -CAkey ca-key.pem \
+ -in c512-req.pem -out client.pem
+
+if [ $? != 0 ]; then
+ echo problems signing 512 bit client cert
+ exit 1
+fi
+
+echo cleanup
+
+cat pca-key.pem >> pca-cert.pem
+cat ca-key.pem >> ca-cert.pem
+cat s512-key.pem >> server.pem
+cat s1024key.pem >> server2.pem
+cat c512-key.pem >> client.pem
+
+for i in pca-cert.pem ca-cert.pem server.pem server2.pem client.pem
+do
+$SSLEAY x509 -issuer -subject -in $i -noout >$$
+cat $$
+/bin/cat $i >>$$
+/bin/mv $$ $i
+done
+
+#/bin/rm -f *key.pem *req.pem *.srl
+
+echo Finished
+
diff --git a/openssl-1.1.0h/util/mkdef.pl b/openssl-1.1.0h/util/mkdef.pl
new file mode 100755
index 0000000..66db26c
--- /dev/null
+++ b/openssl-1.1.0h/util/mkdef.pl
@@ -0,0 +1,1685 @@
+#! /usr/bin/env perl
+# Copyright 1995-2018 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+#
+# generate a .def file
+#
+# It does this by parsing the header files and looking for the
+# prototyped functions: it then prunes the output.
+#
+# Intermediary files are created, call libcrypto.num and libssl.num,
+# The format of these files is:
+#
+# routine-name nnnn vers info
+#
+# The "nnnn" and "vers" fields are the numeric id and version for the symbol
+# respectively. The "info" part is actually a colon-separated string of fields
+# with the following meaning:
+#
+# existence:platform:kind:algorithms
+#
+# - "existence" can be "EXIST" or "NOEXIST" depending on if the symbol is
+# found somewhere in the source,
+# - "platforms" is empty if it exists on all platforms, otherwise it contains
+# comma-separated list of the platform, just as they are if the symbol exists
+# for those platforms, or prepended with a "!" if not. This helps resolve
+# symbol name variants for platforms where the names are too long for the
+# compiler or linker, or if the systems is case insensitive and there is a
+# clash, or the symbol is implemented differently (see
+# EXPORT_VAR_AS_FUNCTION). This script assumes renaming of symbols is found
+# in the file crypto/symhacks.h.
+# The semantics for the platforms is that every item is checked against the
+# environment. For the negative items ("!FOO"), if any of them is false
+# (i.e. "FOO" is true) in the environment, the corresponding symbol can't be
+# used. For the positive itms, if all of them are false in the environment,
+# the corresponding symbol can't be used. Any combination of positive and
+# negative items are possible, and of course leave room for some redundancy.
+# - "kind" is "FUNCTION" or "VARIABLE". The meaning of that is obvious.
+# - "algorithms" is a comma-separated list of algorithm names. This helps
+# exclude symbols that are part of an algorithm that some user wants to
+# exclude.
+#
+
+use lib ".";
+use configdata;
+use File::Spec::Functions;
+use File::Basename;
+use FindBin;
+use lib "$FindBin::Bin/perl";
+use OpenSSL::Glob;
+
+# When building a "variant" shared library, with a custom SONAME, also customize
+# all the symbol versions. This produces a shared object that can coexist
+# without conflict in the same address space as a default build, or an object
+# with a different variant tag.
+#
+# For example, with a target definition that includes:
+#
+# shlib_variant => "-opt",
+#
+# we build the following objects:
+#
+# $ perl -le '
+# for (@ARGV) {
+# if ($l = readlink) {
+# printf "%s -> %s\n", $_, $l
+# } else {
+# print
+# }
+# }' *.so*
+# libcrypto-opt.so.1.1
+# libcrypto.so -> libcrypto-opt.so.1.1
+# libssl-opt.so.1.1
+# libssl.so -> libssl-opt.so.1.1
+#
+# whose SONAMEs and dependencies are:
+#
+# $ for l in *.so; do
+# echo $l
+# readelf -d $l | egrep 'SONAME|NEEDED.*(ssl|crypto)'
+# done
+# libcrypto.so
+# 0x000000000000000e (SONAME) Library soname: [libcrypto-opt.so.1.1]
+# libssl.so
+# 0x0000000000000001 (NEEDED) Shared library: [libcrypto-opt.so.1.1]
+# 0x000000000000000e (SONAME) Library soname: [libssl-opt.so.1.1]
+#
+# We case-fold the variant tag to upper case and replace all non-alnum
+# characters with "_". This yields the following symbol versions:
+#
+# $ nm libcrypto.so | grep -w A
+# 0000000000000000 A OPENSSL_OPT_1_1_0
+# 0000000000000000 A OPENSSL_OPT_1_1_0a
+# 0000000000000000 A OPENSSL_OPT_1_1_0c
+# 0000000000000000 A OPENSSL_OPT_1_1_0d
+# 0000000000000000 A OPENSSL_OPT_1_1_0f
+# 0000000000000000 A OPENSSL_OPT_1_1_0g
+# $ nm libssl.so | grep -w A
+# 0000000000000000 A OPENSSL_OPT_1_1_0
+# 0000000000000000 A OPENSSL_OPT_1_1_0d
+#
+(my $SO_VARIANT = qq{\U$target{"shlib_variant"}}) =~ s/\W/_/g;
+
+my $debug=0;
+my $trace=0;
+my $verbose=0;
+
+my $crypto_num= catfile($config{sourcedir},"util","libcrypto.num");
+my $ssl_num= catfile($config{sourcedir},"util","libssl.num");
+my $libname;
+
+my $do_update = 0;
+my $do_rewrite = 1;
+my $do_crypto = 0;
+my $do_ssl = 0;
+my $do_ctest = 0;
+my $do_ctestall = 0;
+my $do_checkexist = 0;
+
+my $VMS=0;
+my $W32=0;
+my $NT=0;
+my $UNIX=0;
+my $linux=0;
+# Set this to make typesafe STACK definitions appear in DEF
+my $safe_stack_def = 0;
+
+my @known_platforms = ( "__FreeBSD__", "PERL5",
+ "EXPORT_VAR_AS_FUNCTION", "ZLIB", "_WIN32"
+ );
+my @known_ossl_platforms = ( "UNIX", "VMS", "WIN32", "WINNT", "OS2" );
+my @known_algorithms = ( # These are algorithms we know are guarded in relevant
+ # header files, but aren't actually disablable.
+ # Without these, this script will warn a lot.
+ "RSA", "MD5",
+ # @disablables comes from configdata.pm
+ map { (my $x = uc $_) =~ s|-|_|g; $x; } @disablables,
+ # Deprecated functions. Not really algorithmss, but
+ # treated as such here for the sake of simplicity
+ "DEPRECATEDIN_0_9_8",
+ "DEPRECATEDIN_1_0_0",
+ "DEPRECATEDIN_1_1_0",
+ );
+
+# %disabled comes from configdata.pm
+my %disabled_algorithms =
+ map { (my $x = uc $_) =~ s|-|_|g; $x => 1; } keys %disabled;
+
+my $zlib;
+
+foreach (@ARGV, split(/ /, $config{options}))
+ {
+ $debug=1 if $_ eq "debug";
+ $trace=1 if $_ eq "trace";
+ $verbose=1 if $_ eq "verbose";
+ $W32=1 if $_ eq "32";
+ die "win16 not supported" if $_ eq "16";
+ if($_ eq "NT") {
+ $W32 = 1;
+ $NT = 1;
+ }
+ if ($_ eq "linux") {
+ $linux=1;
+ $UNIX=1;
+ }
+ $VMS=1 if $_ eq "VMS";
+ if ($_ eq "zlib" || $_ eq "enable-zlib" || $_ eq "zlib-dynamic"
+ || $_ eq "enable-zlib-dynamic") {
+ $zlib = 1;
+ }
+
+ $do_ssl=1 if $_ eq "libssl";
+ if ($_ eq "ssl") {
+ $do_ssl=1;
+ $libname=$_
+ }
+ $do_crypto=1 if $_ eq "libcrypto";
+ if ($_ eq "crypto") {
+ $do_crypto=1;
+ $libname=$_;
+ }
+ $do_update=1 if $_ eq "update";
+ $do_rewrite=1 if $_ eq "rewrite";
+ $do_ctest=1 if $_ eq "ctest";
+ $do_ctestall=1 if $_ eq "ctestall";
+ $do_checkexist=1 if $_ eq "exist";
+ if (/^--api=(\d+)\.(\d+)\.(\d+)$/) {
+ my $apiv = sprintf "%x%02x%02x", $1, $2, $3;
+ foreach (@known_algorithms) {
+ if (/^DEPRECATEDIN_(\d+)_(\d+)_(\d+)$/) {
+ my $depv = sprintf "%x%02x%02x", $1, $2, $3;
+ $disabled_algorithms{$_} = 1 if $apiv ge $depv;
+ }
+ }
+ }
+ if (/^no-deprecated$/) {
+ foreach (@known_algorithms) {
+ if (/^DEPRECATEDIN_/) {
+ $disabled_algorithms{$_} = 1;
+ }
+ }
+ }
+ elsif (/^(enable|disable|no)-(.*)$/) {
+ my $alg = uc $2;
+ $alg =~ tr/-/_/;
+ if (exists $disabled_algorithms{$alg}) {
+ $disabled_algorithms{$alg} = $1 eq "enable" ? 0 : 1;
+ }
+ }
+
+ }
+
+if (!$libname) {
+ if ($do_ssl) {
+ $libname="LIBSSL";
+ }
+ if ($do_crypto) {
+ $libname="LIBCRYPTO";
+ }
+}
+
+# If no platform is given, assume WIN32
+if ($W32 + $VMS + $linux == 0) {
+ $W32 = 1;
+}
+die "Please, only one platform at a time"
+ if ($W32 + $VMS + $linux > 1);
+
+if (!$do_ssl && !$do_crypto)
+ {
+ print STDERR "usage: $0 ( ssl | crypto ) [ 16 | 32 | NT | OS2 | linux | VMS ]\n";
+ exit(1);
+ }
+
+%ssl_list=&load_numbers($ssl_num);
+$max_ssl = $max_num;
+%crypto_list=&load_numbers($crypto_num);
+$max_crypto = $max_num;
+
+my $ssl="include/openssl/ssl.h";
+$ssl.=" include/openssl/tls1.h";
+$ssl.=" include/openssl/srtp.h";
+
+# We use headers found in include/openssl and include/internal only.
+# The latter is needed so libssl.so/.dll/.exe can link properly.
+my $crypto ="include/openssl/crypto.h";
+$crypto.=" include/internal/o_dir.h";
+$crypto.=" include/internal/o_str.h";
+$crypto.=" include/internal/err.h";
+$crypto.=" include/internal/asn1t.h";
+$crypto.=" include/openssl/des.h" ; # unless $no_des;
+$crypto.=" include/openssl/idea.h" ; # unless $no_idea;
+$crypto.=" include/openssl/rc4.h" ; # unless $no_rc4;
+$crypto.=" include/openssl/rc5.h" ; # unless $no_rc5;
+$crypto.=" include/openssl/rc2.h" ; # unless $no_rc2;
+$crypto.=" include/openssl/blowfish.h" ; # unless $no_bf;
+$crypto.=" include/openssl/cast.h" ; # unless $no_cast;
+$crypto.=" include/openssl/whrlpool.h" ;
+$crypto.=" include/openssl/md2.h" ; # unless $no_md2;
+$crypto.=" include/openssl/md4.h" ; # unless $no_md4;
+$crypto.=" include/openssl/md5.h" ; # unless $no_md5;
+$crypto.=" include/openssl/mdc2.h" ; # unless $no_mdc2;
+$crypto.=" include/openssl/sha.h" ; # unless $no_sha;
+$crypto.=" include/openssl/ripemd.h" ; # unless $no_ripemd;
+$crypto.=" include/openssl/aes.h" ; # unless $no_aes;
+$crypto.=" include/openssl/camellia.h" ; # unless $no_camellia;
+$crypto.=" include/openssl/seed.h"; # unless $no_seed;
+
+$crypto.=" include/openssl/bn.h";
+$crypto.=" include/openssl/rsa.h" ; # unless $no_rsa;
+$crypto.=" include/openssl/dsa.h" ; # unless $no_dsa;
+$crypto.=" include/openssl/dh.h" ; # unless $no_dh;
+$crypto.=" include/openssl/ec.h" ; # unless $no_ec;
+$crypto.=" include/openssl/hmac.h" ; # unless $no_hmac;
+$crypto.=" include/openssl/cmac.h" ;
+
+$crypto.=" include/openssl/engine.h"; # unless $no_engine;
+$crypto.=" include/openssl/stack.h" ; # unless $no_stack;
+$crypto.=" include/openssl/buffer.h" ; # unless $no_buffer;
+$crypto.=" include/openssl/bio.h" ; # unless $no_bio;
+$crypto.=" include/internal/dso.h" ; # unless $no_dso;
+$crypto.=" include/openssl/lhash.h" ; # unless $no_lhash;
+$crypto.=" include/openssl/conf.h";
+$crypto.=" include/openssl/txt_db.h";
+
+$crypto.=" include/openssl/evp.h" ; # unless $no_evp;
+$crypto.=" include/openssl/objects.h";
+$crypto.=" include/openssl/pem.h";
+#$crypto.=" include/openssl/meth.h";
+$crypto.=" include/openssl/asn1.h";
+$crypto.=" include/openssl/asn1t.h";
+$crypto.=" include/openssl/err.h" ; # unless $no_err;
+$crypto.=" include/openssl/pkcs7.h";
+$crypto.=" include/openssl/pkcs12.h";
+$crypto.=" include/openssl/x509.h";
+$crypto.=" include/openssl/x509_vfy.h";
+$crypto.=" include/openssl/x509v3.h";
+$crypto.=" include/openssl/ts.h";
+$crypto.=" include/openssl/rand.h";
+$crypto.=" include/openssl/comp.h" ; # unless $no_comp;
+$crypto.=" include/openssl/ocsp.h";
+$crypto.=" include/openssl/ui.h";
+#$crypto.=" include/openssl/store.h";
+$crypto.=" include/openssl/cms.h";
+$crypto.=" include/openssl/srp.h";
+$crypto.=" include/openssl/modes.h";
+$crypto.=" include/openssl/async.h";
+$crypto.=" include/openssl/ct.h";
+$crypto.=" include/openssl/kdf.h";
+
+my $symhacks="include/openssl/symhacks.h";
+
+my @ssl_symbols = &do_defs("LIBSSL", $ssl, $symhacks);
+my @crypto_symbols = &do_defs("LIBCRYPTO", $crypto, $symhacks);
+
+if ($do_update) {
+
+if ($do_ssl == 1) {
+
+ &maybe_add_info("LIBSSL",*ssl_list,@ssl_symbols);
+ if ($do_rewrite == 1) {
+ open(OUT, ">$ssl_num");
+ &rewrite_numbers(*OUT,"LIBSSL",*ssl_list,@ssl_symbols);
+ } else {
+ open(OUT, ">>$ssl_num");
+ }
+ &update_numbers(*OUT,"LIBSSL",*ssl_list,$max_ssl,@ssl_symbols);
+ close OUT;
+}
+
+if($do_crypto == 1) {
+
+ &maybe_add_info("LIBCRYPTO",*crypto_list,@crypto_symbols);
+ if ($do_rewrite == 1) {
+ open(OUT, ">$crypto_num");
+ &rewrite_numbers(*OUT,"LIBCRYPTO",*crypto_list,@crypto_symbols);
+ } else {
+ open(OUT, ">>$crypto_num");
+ }
+ &update_numbers(*OUT,"LIBCRYPTO",*crypto_list,$max_crypto,@crypto_symbols);
+ close OUT;
+}
+
+} elsif ($do_checkexist) {
+ &check_existing(*ssl_list, @ssl_symbols)
+ if $do_ssl == 1;
+ &check_existing(*crypto_list, @crypto_symbols)
+ if $do_crypto == 1;
+} elsif ($do_ctest || $do_ctestall) {
+
+ print <<"EOF";
+
+/* Test file to check all DEF file symbols are present by trying
+ * to link to all of them. This is *not* intended to be run!
+ */
+
+int main()
+{
+EOF
+ &print_test_file(*STDOUT,"LIBSSL",*ssl_list,$do_ctestall,@ssl_symbols)
+ if $do_ssl == 1;
+
+ &print_test_file(*STDOUT,"LIBCRYPTO",*crypto_list,$do_ctestall,@crypto_symbols)
+ if $do_crypto == 1;
+
+ print "}\n";
+
+} else {
+
+ &print_def_file(*STDOUT,$libname,*ssl_list,@ssl_symbols)
+ if $do_ssl == 1;
+
+ &print_def_file(*STDOUT,$libname,*crypto_list,@crypto_symbols)
+ if $do_crypto == 1;
+
+}
+
+
+sub do_defs
+{
+ my($name,$files,$symhacksfile)=@_;
+ my $file;
+ my @ret;
+ my %syms;
+ my %platform; # For anything undefined, we assume ""
+ my %kind; # For anything undefined, we assume "FUNCTION"
+ my %algorithm; # For anything undefined, we assume ""
+ my %variant;
+ my %variant_cnt; # To be able to allocate "name{n}" if "name"
+ # is the same name as the original.
+ my $cpp;
+ my %unknown_algorithms = ();
+ my $parens = 0;
+
+ foreach $file (split(/\s+/,$symhacksfile." ".$files))
+ {
+ my $fn = catfile($config{sourcedir},$file);
+ print STDERR "TRACE: start reading $fn\n" if $trace;
+ open(IN,"<$fn") || die "unable to open $fn:$!\n";
+ my $line = "", my $def= "";
+ my %tag = (
+ (map { $_ => 0 } @known_platforms),
+ (map { "OPENSSL_SYS_".$_ => 0 } @known_ossl_platforms),
+ (map { "OPENSSL_NO_".$_ => 0 } @known_algorithms),
+ (map { "OPENSSL_USE_".$_ => 0 } @known_algorithms),
+ NOPROTO => 0,
+ PERL5 => 0,
+ _WINDLL => 0,
+ CONST_STRICT => 0,
+ TRUE => 1,
+ );
+ my $symhacking = $file eq $symhacksfile;
+ my @current_platforms = ();
+ my @current_algorithms = ();
+
+ # params: symbol, alias, platforms, kind
+ # The reason to put this subroutine in a variable is that
+ # it will otherwise create it's own, unshared, version of
+ # %tag and %variant...
+ my $make_variant = sub
+ {
+ my ($s, $a, $p, $k) = @_;
+ my ($a1, $a2);
+
+ print STDERR "DEBUG: make_variant: Entered with ",$s,", ",$a,", ",(defined($p)?$p:""),", ",(defined($k)?$k:""),"\n" if $debug;
+ if (defined($p))
+ {
+ $a1 = join(",",$p,
+ grep(!/^$/,
+ map { $tag{$_} == 1 ? $_ : "" }
+ @known_platforms));
+ }
+ else
+ {
+ $a1 = join(",",
+ grep(!/^$/,
+ map { $tag{$_} == 1 ? $_ : "" }
+ @known_platforms));
+ }
+ $a2 = join(",",
+ grep(!/^$/,
+ map { $tag{"OPENSSL_SYS_".$_} == 1 ? $_ : "" }
+ @known_ossl_platforms));
+ print STDERR "DEBUG: make_variant: a1 = $a1; a2 = $a2\n" if $debug;
+ if ($a1 eq "") { $a1 = $a2; }
+ elsif ($a1 ne "" && $a2 ne "") { $a1 .= ",".$a2; }
+ if ($a eq $s)
+ {
+ if (!defined($variant_cnt{$s}))
+ {
+ $variant_cnt{$s} = 0;
+ }
+ $variant_cnt{$s}++;
+ $a .= "{$variant_cnt{$s}}";
+ }
+ my $toadd = $a.":".$a1.(defined($k)?":".$k:"");
+ my $togrep = $s.'(\{[0-9]+\})?:'.$a1.(defined($k)?":".$k:"");
+ if (!grep(/^$togrep$/,
+ split(/;/, defined($variant{$s})?$variant{$s}:""))) {
+ if (defined($variant{$s})) { $variant{$s} .= ";"; }
+ $variant{$s} .= $toadd;
+ }
+ print STDERR "DEBUG: make_variant: Exit with variant of ",$s," = ",$variant{$s},"\n" if $debug;
+ };
+
+ print STDERR "DEBUG: parsing ----------\n" if $debug;
+ while(<IN>) {
+ s|\R$||; # Better chomp
+ if($parens > 0) {
+ #Inside a DEPRECATEDIN
+ $stored_multiline .= $_;
+ print STDERR "DEBUG: Continuing multiline DEPRECATEDIN: $stored_multiline\n" if $debug;
+ $parens = count_parens($stored_multiline);
+ if ($parens == 0) {
+ $def .= do_deprecated($stored_multiline,
+ \@current_platforms,
+ \@current_algorithms);
+ }
+ next;
+ }
+ if (/\/\* Error codes for the \w+ functions\. \*\//)
+ {
+ undef @tag;
+ last;
+ }
+ if ($line ne '') {
+ $_ = $line . $_;
+ $line = '';
+ }
+
+ if (/\\$/) {
+ $line = $`; # keep what was before the backslash
+ next;
+ }
+
+ if(/\/\*/) {
+ if (not /\*\//) { # multiline comment...
+ $line = $_; # ... just accumulate
+ next;
+ } else {
+ s/\/\*.*?\*\///gs;# wipe it
+ }
+ }
+
+ if ($cpp) {
+ $cpp++ if /^#\s*if/;
+ $cpp-- if /^#\s*endif/;
+ next;
+ }
+ if (/^#.*ifdef.*cplusplus/) {
+ $cpp = 1;
+ next;
+ }
+
+ s/{[^{}]*}//gs; # ignore {} blocks
+ print STDERR "DEBUG: \$def=\"$def\"\n" if $debug && $def ne "";
+ print STDERR "DEBUG: \$_=\"$_\"\n" if $debug;
+ if (/^\#\s*ifndef\s+(.*)/) {
+ push(@tag,"-");
+ push(@tag,$1);
+ $tag{$1}=-1;
+ print STDERR "DEBUG: $file: found tag $1 = -1\n" if $debug;
+ } elsif (/^\#\s*if\s+!defined\s*\(([^\)]+)\)/) {
+ push(@tag,"-");
+ if (/^\#\s*if\s+(!defined\s*\(([^\)]+)\)(\s+\&\&\s+!defined\s*\(([^\)]+)\))*)$/) {
+ my $tmp_1 = $1;
+ my $tmp_;
+ foreach $tmp_ (split '\&\&',$tmp_1) {
+ $tmp_ =~ /!defined\s*\(([^\)]+)\)/;
+ print STDERR "DEBUG: $file: found tag $1 = -1\n" if $debug;
+ push(@tag,$1);
+ $tag{$1}=-1;
+ }
+ } else {
+ print STDERR "Warning: $file: taking only '!defined($1)' of complicated expression: $_" if $verbose; # because it is O...
+ print STDERR "DEBUG: $file: found tag $1 = -1\n" if $debug;
+ push(@tag,$1);
+ $tag{$1}=-1;
+ }
+ } elsif (/^\#\s*ifdef\s+(\S*)/) {
+ push(@tag,"-");
+ push(@tag,$1);
+ $tag{$1}=1;
+ print STDERR "DEBUG: $file: found tag $1 = 1\n" if $debug;
+ } elsif (/^\#\s*if\s+defined\s*\(([^\)]+)\)/) {
+ push(@tag,"-");
+ if (/^\#\s*if\s+(defined\s*\(([^\)]+)\)(\s+\|\|\s+defined\s*\(([^\)]+)\))*)$/) {
+ my $tmp_1 = $1;
+ my $tmp_;
+ foreach $tmp_ (split '\|\|',$tmp_1) {
+ $tmp_ =~ /defined\s*\(([^\)]+)\)/;
+ print STDERR "DEBUG: $file: found tag $1 = 1\n" if $debug;
+ push(@tag,$1);
+ $tag{$1}=1;
+ }
+ } else {
+ print STDERR "Warning: $file: taking only 'defined($1)' of complicated expression: $_\n" if $verbose; # because it is O...
+ print STDERR "DEBUG: $file: found tag $1 = 1\n" if $debug;
+ push(@tag,$1);
+ $tag{$1}=1;
+ }
+ } elsif (/^\#\s*error\s+(\w+) is disabled\./) {
+ my $tag_i = $#tag;
+ while($tag[$tag_i] ne "-") {
+ if ($tag[$tag_i] eq "OPENSSL_NO_".$1) {
+ $tag{$tag[$tag_i]}=2;
+ print STDERR "DEBUG: $file: chaged tag $1 = 2\n" if $debug;
+ }
+ $tag_i--;
+ }
+ } elsif (/^\#\s*endif/) {
+ my $tag_i = $#tag;
+ while($tag_i > 0 && $tag[$tag_i] ne "-") {
+ my $t=$tag[$tag_i];
+ print STDERR "DEBUG: \$t=\"$t\"\n" if $debug;
+ if ($tag{$t}==2) {
+ $tag{$t}=-1;
+ } else {
+ $tag{$t}=0;
+ }
+ print STDERR "DEBUG: $file: changed tag ",$t," = ",$tag{$t},"\n" if $debug;
+ pop(@tag);
+ if ($t =~ /^OPENSSL_NO_([A-Z0-9_]+)$/) {
+ $t=$1;
+ } elsif($t =~ /^OPENSSL_USE_([A-Z0-9_]+)$/) {
+ $t=$1;
+ } else {
+ $t="";
+ }
+ if ($t ne ""
+ && !grep(/^$t$/, @known_algorithms)) {
+ $unknown_algorithms{$t} = 1;
+ #print STDERR "DEBUG: Added as unknown algorithm: $t\n" if $debug;
+ }
+ $tag_i--;
+ }
+ pop(@tag);
+ } elsif (/^\#\s*else/) {
+ my $tag_i = $#tag;
+ die "$file unmatched else\n" if $tag_i < 0;
+ while($tag[$tag_i] ne "-") {
+ my $t=$tag[$tag_i];
+ $tag{$t}= -$tag{$t};
+ print STDERR "DEBUG: $file: changed tag ",$t," = ",$tag{$t},"\n" if $debug;
+ $tag_i--;
+ }
+ } elsif (/^\#\s*if\s+1/) {
+ push(@tag,"-");
+ # Dummy tag
+ push(@tag,"TRUE");
+ $tag{"TRUE"}=1;
+ print STDERR "DEBUG: $file: found 1\n" if $debug;
+ } elsif (/^\#\s*if\s+0/) {
+ push(@tag,"-");
+ # Dummy tag
+ push(@tag,"TRUE");
+ $tag{"TRUE"}=-1;
+ print STDERR "DEBUG: $file: found 0\n" if $debug;
+ } elsif (/^\#\s*if\s+/) {
+ #Some other unrecognized "if" style
+ push(@tag,"-");
+ print STDERR "Warning: $file: ignoring unrecognized expression: $_\n" if $verbose; # because it is O...
+ } elsif (/^\#\s*define\s+(\w+)\s+(\w+)/
+ && $symhacking && $tag{'TRUE'} != -1) {
+ # This is for aliasing. When we find an alias,
+ # we have to invert
+ &$make_variant($1,$2);
+ print STDERR "DEBUG: $file: defined $1 = $2\n" if $debug;
+ }
+ if (/^\#/) {
+ @current_platforms =
+ grep(!/^$/,
+ map { $tag{$_} == 1 ? $_ :
+ $tag{$_} == -1 ? "!".$_ : "" }
+ @known_platforms);
+ push @current_platforms
+ , grep(!/^$/,
+ map { $tag{"OPENSSL_SYS_".$_} == 1 ? $_ :
+ $tag{"OPENSSL_SYS_".$_} == -1 ? "!".$_ : "" }
+ @known_ossl_platforms);
+ @current_algorithms = ();
+ @current_algorithms =
+ grep(!/^$/,
+ map { $tag{"OPENSSL_NO_".$_} == -1 ? $_ : "" }
+ @known_algorithms);
+ push @current_algorithms
+ , grep(!/^$/,
+ map { $tag{"OPENSSL_USE_".$_} == 1 ? $_ : "" }
+ @known_algorithms);
+ $def .=
+ "#INFO:"
+ .join(',',@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ next;
+ }
+ if ($tag{'TRUE'} != -1) {
+ if (/^\s*DEFINE_STACK_OF\s*\(\s*(\w*)\s*\)/
+ || /^\s*DEFINE_STACK_OF_CONST\s*\(\s*(\w*)\s*\)/) {
+ next;
+ } elsif (/^\s*DECLARE_ASN1_ENCODE_FUNCTIONS\s*\(\s*(\w*)\s*,\s*(\w*)\s*,\s*(\w*)\s*\)/) {
+ $def .= "int d2i_$3(void);";
+ $def .= "int i2d_$3(void);";
+ # Variant for platforms that do not
+ # have to access globale variables
+ # in shared libraries through functions
+ $def .=
+ "#INFO:"
+ .join(',',"!EXPORT_VAR_AS_FUNCTION",@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ $def .= "OPENSSL_EXTERN int $2_it;";
+ $def .=
+ "#INFO:"
+ .join(',',@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ # Variant for platforms that have to
+ # access globale variables in shared
+ # libraries through functions
+ &$make_variant("$2_it","$2_it",
+ "EXPORT_VAR_AS_FUNCTION",
+ "FUNCTION");
+ next;
+ } elsif (/^\s*DECLARE_ASN1_FUNCTIONS_fname\s*\(\s*(\w*)\s*,\s*(\w*)\s*,\s*(\w*)\s*\)/) {
+ $def .= "int d2i_$3(void);";
+ $def .= "int i2d_$3(void);";
+ $def .= "int $3_free(void);";
+ $def .= "int $3_new(void);";
+ # Variant for platforms that do not
+ # have to access globale variables
+ # in shared libraries through functions
+ $def .=
+ "#INFO:"
+ .join(',',"!EXPORT_VAR_AS_FUNCTION",@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ $def .= "OPENSSL_EXTERN int $2_it;";
+ $def .=
+ "#INFO:"
+ .join(',',@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ # Variant for platforms that have to
+ # access globale variables in shared
+ # libraries through functions
+ &$make_variant("$2_it","$2_it",
+ "EXPORT_VAR_AS_FUNCTION",
+ "FUNCTION");
+ next;
+ } elsif (/^\s*DECLARE_ASN1_FUNCTIONS\s*\(\s*(\w*)\s*\)/ ||
+ /^\s*DECLARE_ASN1_FUNCTIONS_const\s*\(\s*(\w*)\s*\)/) {
+ $def .= "int d2i_$1(void);";
+ $def .= "int i2d_$1(void);";
+ $def .= "int $1_free(void);";
+ $def .= "int $1_new(void);";
+ # Variant for platforms that do not
+ # have to access globale variables
+ # in shared libraries through functions
+ $def .=
+ "#INFO:"
+ .join(',',"!EXPORT_VAR_AS_FUNCTION",@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ $def .= "OPENSSL_EXTERN int $1_it;";
+ $def .=
+ "#INFO:"
+ .join(',',@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ # Variant for platforms that have to
+ # access globale variables in shared
+ # libraries through functions
+ &$make_variant("$1_it","$1_it",
+ "EXPORT_VAR_AS_FUNCTION",
+ "FUNCTION");
+ next;
+ } elsif (/^\s*DECLARE_ASN1_ENCODE_FUNCTIONS_const\s*\(\s*(\w*)\s*,\s*(\w*)\s*\)/) {
+ $def .= "int d2i_$2(void);";
+ $def .= "int i2d_$2(void);";
+ # Variant for platforms that do not
+ # have to access globale variables
+ # in shared libraries through functions
+ $def .=
+ "#INFO:"
+ .join(',',"!EXPORT_VAR_AS_FUNCTION",@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ $def .= "OPENSSL_EXTERN int $2_it;";
+ $def .=
+ "#INFO:"
+ .join(',',@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ # Variant for platforms that have to
+ # access globale variables in shared
+ # libraries through functions
+ &$make_variant("$2_it","$2_it",
+ "EXPORT_VAR_AS_FUNCTION",
+ "FUNCTION");
+ next;
+ } elsif (/^\s*DECLARE_ASN1_ALLOC_FUNCTIONS\s*\(\s*(\w*)\s*\)/) {
+ $def .= "int $1_free(void);";
+ $def .= "int $1_new(void);";
+ next;
+ } elsif (/^\s*DECLARE_ASN1_FUNCTIONS_name\s*\(\s*(\w*)\s*,\s*(\w*)\s*\)/) {
+ $def .= "int d2i_$2(void);";
+ $def .= "int i2d_$2(void);";
+ $def .= "int $2_free(void);";
+ $def .= "int $2_new(void);";
+ # Variant for platforms that do not
+ # have to access globale variables
+ # in shared libraries through functions
+ $def .=
+ "#INFO:"
+ .join(',',"!EXPORT_VAR_AS_FUNCTION",@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ $def .= "OPENSSL_EXTERN int $2_it;";
+ $def .=
+ "#INFO:"
+ .join(',',@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ # Variant for platforms that have to
+ # access globale variables in shared
+ # libraries through functions
+ &$make_variant("$2_it","$2_it",
+ "EXPORT_VAR_AS_FUNCTION",
+ "FUNCTION");
+ next;
+ } elsif (/^\s*DECLARE_ASN1_ITEM\s*\(\s*(\w*)\s*\)/) {
+ # Variant for platforms that do not
+ # have to access globale variables
+ # in shared libraries through functions
+ $def .=
+ "#INFO:"
+ .join(',',"!EXPORT_VAR_AS_FUNCTION",@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ $def .= "OPENSSL_EXTERN int $1_it;";
+ $def .=
+ "#INFO:"
+ .join(',',@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ # Variant for platforms that have to
+ # access globale variables in shared
+ # libraries through functions
+ &$make_variant("$1_it","$1_it",
+ "EXPORT_VAR_AS_FUNCTION",
+ "FUNCTION");
+ next;
+ } elsif (/^\s*DECLARE_ASN1_NDEF_FUNCTION\s*\(\s*(\w*)\s*\)/) {
+ $def .= "int i2d_$1_NDEF(void);";
+ } elsif (/^\s*DECLARE_ASN1_SET_OF\s*\(\s*(\w*)\s*\)/) {
+ next;
+ } elsif (/^\s*DECLARE_ASN1_PRINT_FUNCTION\s*\(\s*(\w*)\s*\)/) {
+ $def .= "int $1_print_ctx(void);";
+ next;
+ } elsif (/^\s*DECLARE_ASN1_PRINT_FUNCTION_name\s*\(\s*(\w*)\s*,\s*(\w*)\s*\)/) {
+ $def .= "int $2_print_ctx(void);";
+ next;
+ } elsif (/^\s*DECLARE_PKCS12_STACK_OF\s*\(\s*(\w*)\s*\)/) {
+ next;
+ } elsif (/^DECLARE_PEM_rw\s*\(\s*(\w*)\s*,/ ||
+ /^DECLARE_PEM_rw_cb\s*\(\s*(\w*)\s*,/ ||
+ /^DECLARE_PEM_rw_const\s*\(\s*(\w*)\s*,/ ) {
+ $def .=
+ "#INFO:"
+ .join(',',@current_platforms).":"
+ .join(',',"STDIO",@current_algorithms).";";
+ $def .= "int PEM_read_$1(void);";
+ $def .= "int PEM_write_$1(void);";
+ $def .=
+ "#INFO:"
+ .join(',',@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ # Things that are everywhere
+ $def .= "int PEM_read_bio_$1(void);";
+ $def .= "int PEM_write_bio_$1(void);";
+ next;
+ } elsif (/^DECLARE_PEM_write\s*\(\s*(\w*)\s*,/ ||
+ /^DECLARE_PEM_write_const\s*\(\s*(\w*)\s*,/ ||
+ /^DECLARE_PEM_write_cb\s*\(\s*(\w*)\s*,/ ) {
+ $def .=
+ "#INFO:"
+ .join(',',@current_platforms).":"
+ .join(',',"STDIO",@current_algorithms).";";
+ $def .= "int PEM_write_$1(void);";
+ $def .=
+ "#INFO:"
+ .join(',',@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ # Things that are everywhere
+ $def .= "int PEM_write_bio_$1(void);";
+ next;
+ } elsif (/^DECLARE_PEM_read\s*\(\s*(\w*)\s*,/ ||
+ /^DECLARE_PEM_read_cb\s*\(\s*(\w*)\s*,/ ) {
+ $def .=
+ "#INFO:"
+ .join(',',@current_platforms).":"
+ .join(',',"STDIO",@current_algorithms).";";
+ $def .= "int PEM_read_$1(void);";
+ $def .=
+ "#INFO:"
+ .join(',',@current_platforms).":"
+ .join(',',"STDIO",@current_algorithms).";";
+ # Things that are everywhere
+ $def .= "int PEM_read_bio_$1(void);";
+ next;
+ } elsif (/^OPENSSL_DECLARE_GLOBAL\s*\(\s*(\w*)\s*,\s*(\w*)\s*\)/) {
+ # Variant for platforms that do not
+ # have to access globale variables
+ # in shared libraries through functions
+ $def .=
+ "#INFO:"
+ .join(',',"!EXPORT_VAR_AS_FUNCTION",@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ $def .= "OPENSSL_EXTERN int _shadow_$2;";
+ $def .=
+ "#INFO:"
+ .join(',',@current_platforms).":"
+ .join(',',@current_algorithms).";";
+ # Variant for platforms that have to
+ # access globale variables in shared
+ # libraries through functions
+ &$make_variant("_shadow_$2","_shadow_$2",
+ "EXPORT_VAR_AS_FUNCTION",
+ "FUNCTION");
+ } elsif (/^\s*DEPRECATEDIN/) {
+ $parens = count_parens($_);
+ if ($parens == 0) {
+ $def .= do_deprecated($_,
+ \@current_platforms,
+ \@current_algorithms);
+ } else {
+ $stored_multiline = $_;
+ print STDERR "DEBUG: Found multiline DEPRECATEDIN starting with: $stored_multiline\n" if $debug;
+ next;
+ }
+ } elsif ($tag{'CONST_STRICT'} != 1) {
+ if (/\{|\/\*|\([^\)]*$/) {
+ $line = $_;
+ } else {
+ $def .= $_;
+ }
+ }
+ }
+ }
+ close(IN);
+ die "$file: Unmatched tags\n" if $#tag >= 0;
+
+ my $algs;
+ my $plays;
+
+ print STDERR "DEBUG: postprocessing ----------\n" if $debug;
+ foreach (split /;/, $def) {
+ my $s; my $k = "FUNCTION"; my $p; my $a;
+ s/^[\n\s]*//g;
+ s/[\n\s]*$//g;
+ next if(/\#undef/);
+ next if(/typedef\W/);
+ next if(/\#define/);
+
+ print STDERR "TRACE: processing $_\n" if $trace && !/^\#INFO:/;
+ # Reduce argument lists to empty ()
+ # fold round brackets recursively: (t(*v)(t),t) -> (t{}{},t) -> {}
+ my $nsubst = 1; # prevent infinite loop, e.g., on int fn()
+ while($nsubst && /\(.*\)/s) {
+ $nsubst = s/\([^\(\)]+\)/\{\}/gs;
+ $nsubst+= s/\(\s*\*\s*(\w+)\s*\{\}\s*\)/$1/gs; #(*f{}) -> f
+ }
+ # pretend as we didn't use curly braces: {} -> ()
+ s/\{\}/\(\)/gs;
+
+ s/STACK_OF\(\)/void/gs;
+ s/LHASH_OF\(\)/void/gs;
+
+ print STDERR "DEBUG: \$_ = \"$_\"\n" if $debug;
+ if (/^\#INFO:([^:]*):(.*)$/) {
+ $plats = $1;
+ $algs = $2;
+ print STDERR "DEBUG: found info on platforms ($plats) and algorithms ($algs)\n" if $debug;
+ next;
+ } elsif (/^\s*OPENSSL_EXTERN\s.*?(\w+(\{[0-9]+\})?)(\[[0-9]*\])*\s*$/) {
+ $s = $1;
+ $k = "VARIABLE";
+ print STDERR "DEBUG: found external variable $s\n" if $debug;
+ } elsif (/TYPEDEF_\w+_OF/s) {
+ next;
+ } elsif (/(\w+)\s*\(\).*/s) { # first token prior [first] () is
+ $s = $1; # a function name!
+ print STDERR "DEBUG: found function $s\n" if $debug;
+ } elsif (/\(/ and not (/=/)) {
+ print STDERR "File $file: cannot parse: $_;\n";
+ next;
+ } else {
+ next;
+ }
+
+ $syms{$s} = 1;
+ $kind{$s} = $k;
+
+ $p = $plats;
+ $a = $algs;
+
+ $platform{$s} =
+ &reduce_platforms((defined($platform{$s})?$platform{$s}.',':"").$p);
+ $algorithm{$s} .= ','.$a;
+
+ if (defined($variant{$s})) {
+ foreach $v (split /;/,$variant{$s}) {
+ (my $r, my $p, my $k) = split(/:/,$v);
+ my $ip = join ',',map({ /^!(.*)$/ ? $1 : "!".$_ } split /,/, $p);
+ $syms{$r} = 1;
+ if (!defined($k)) { $k = $kind{$s}; }
+ $kind{$r} = $k."(".$s.")";
+ $algorithm{$r} = $algorithm{$s};
+ $platform{$r} = &reduce_platforms($platform{$s}.",".$p.",".$p);
+ $platform{$s} = &reduce_platforms($platform{$s}.','.$ip.','.$ip);
+ print STDERR "DEBUG: \$variant{\"$s\"} = ",$v,"; \$r = $r; \$p = ",$platform{$r},"; \$a = ",$algorithm{$r},"; \$kind = ",$kind{$r},"\n" if $debug;
+ }
+ }
+ print STDERR "DEBUG: \$s = $s; \$p = ",$platform{$s},"; \$a = ",$algorithm{$s},"; \$kind = ",$kind{$s},"\n" if $debug;
+ }
+ }
+
+ # Prune the returned symbols
+
+ delete $syms{"bn_dump1"};
+ $platform{"BIO_s_log"} .= ",!WIN32,!macintosh";
+
+ $platform{"PEM_read_NS_CERT_SEQ"} = "VMS";
+ $platform{"PEM_write_NS_CERT_SEQ"} = "VMS";
+ $platform{"PEM_read_P8_PRIV_KEY_INFO"} = "VMS";
+ $platform{"PEM_write_P8_PRIV_KEY_INFO"} = "VMS";
+
+ # Info we know about
+
+ push @ret, map { $_."\\".&info_string($_,"EXIST",
+ $platform{$_},
+ $kind{$_},
+ $algorithm{$_}) } keys %syms;
+
+ if (keys %unknown_algorithms) {
+ print STDERR "WARNING: mkdef.pl doesn't know the following algorithms:\n";
+ print STDERR "\t",join("\n\t",keys %unknown_algorithms),"\n";
+ }
+ return(@ret);
+}
+
+# Param: string of comma-separated platform-specs.
+sub reduce_platforms
+{
+ my ($platforms) = @_;
+ my $pl = defined($platforms) ? $platforms : "";
+ my %p = map { $_ => 0 } split /,/, $pl;
+ my $ret;
+
+ print STDERR "DEBUG: Entered reduce_platforms with \"$platforms\"\n"
+ if $debug;
+ # We do this, because if there's code like the following, it really
+ # means the function exists in all cases and should therefore be
+ # everywhere. By increasing and decreasing, we may attain 0:
+ #
+ # ifndef WIN16
+ # int foo();
+ # else
+ # int _fat foo();
+ # endif
+ foreach $platform (split /,/, $pl) {
+ if ($platform =~ /^!(.*)$/) {
+ $p{$1}--;
+ } else {
+ $p{$platform}++;
+ }
+ }
+ foreach $platform (keys %p) {
+ if ($p{$platform} == 0) { delete $p{$platform}; }
+ }
+
+ delete $p{""};
+
+ $ret = join(',',sort(map { $p{$_} < 0 ? "!".$_ : $_ } keys %p));
+ print STDERR "DEBUG: Exiting reduce_platforms with \"$ret\"\n"
+ if $debug;
+ return $ret;
+}
+
+sub info_string
+{
+ (my $symbol, my $exist, my $platforms, my $kind, my $algorithms) = @_;
+
+ my %a = defined($algorithms) ?
+ map { $_ => 1 } split /,/, $algorithms : ();
+ my $k = defined($kind) ? $kind : "FUNCTION";
+ my $ret;
+ my $p = &reduce_platforms($platforms);
+
+ delete $a{""};
+
+ $ret = $exist;
+ $ret .= ":".$p;
+ $ret .= ":".$k;
+ $ret .= ":".join(',',sort keys %a);
+ return $ret;
+}
+
+sub maybe_add_info
+{
+ (my $name, *nums, my @symbols) = @_;
+ my $sym;
+ my $new_info = 0;
+ my %syms=();
+
+ foreach $sym (@symbols) {
+ (my $s, my $i) = split /\\/, $sym;
+ if (defined($nums{$s})) {
+ $i =~ s/^(.*?:.*?:\w+)(\(\w+\))?/$1/;
+ (my $n, my $vers, my $dummy) = split /\\/, $nums{$s};
+ if (!defined($dummy) || $i ne $dummy) {
+ $nums{$s} = $n."\\".$vers."\\".$i;
+ $new_info++;
+ print STDERR "DEBUG: maybe_add_info for $s: \"$dummy\" => \"$i\"\n" if $debug;
+ }
+ }
+ $syms{$s} = 1;
+ }
+
+ my @s=sort { &parse_number($nums{$a},"n") <=> &parse_number($nums{$b},"n") } keys %nums;
+ foreach $sym (@s) {
+ (my $n, my $vers, my $i) = split /\\/, $nums{$sym};
+ if (!defined($syms{$sym}) && $i !~ /^NOEXIST:/) {
+ $new_info++;
+ print STDERR "DEBUG: maybe_add_info for $sym: -> undefined\n" if $debug;
+ }
+ }
+ if ($new_info) {
+ print STDERR "$name: $new_info old symbols have updated info\n";
+ if (!$do_rewrite) {
+ print STDERR "You should do a rewrite to fix this.\n";
+ }
+ } else {
+ }
+}
+
+# Param: string of comma-separated keywords, each possibly prefixed with a "!"
+sub is_valid
+{
+ my ($keywords_txt,$platforms) = @_;
+ my (@keywords) = split /,/,$keywords_txt;
+ my ($falsesum, $truesum) = (0, 1);
+
+ # Param: one keyword
+ sub recognise
+ {
+ my ($keyword,$platforms) = @_;
+
+ if ($platforms) {
+ # platforms
+ if ($keyword eq "UNIX" && $UNIX) { return 1; }
+ if ($keyword eq "VMS" && $VMS) { return 1; }
+ if ($keyword eq "WIN32" && $W32) { return 1; }
+ if ($keyword eq "_WIN32" && $W32) { return 1; }
+ if ($keyword eq "WINNT" && $NT) { return 1; }
+ # Special platforms:
+ # EXPORT_VAR_AS_FUNCTION means that global variables
+ # will be represented as functions.
+ if ($keyword eq "EXPORT_VAR_AS_FUNCTION" && $W32) {
+ return 1;
+ }
+ if ($keyword eq "ZLIB" && $zlib) { return 1; }
+ return 0;
+ } else {
+ # algorithms
+ if ($disabled_algorithms{$keyword} == 1) { return 0;}
+
+ # Nothing recognise as true
+ return 1;
+ }
+ }
+
+ foreach $k (@keywords) {
+ if ($k =~ /^!(.*)$/) {
+ $falsesum += &recognise($1,$platforms);
+ } else {
+ $truesum *= &recognise($k,$platforms);
+ }
+ }
+ print STDERR "DEBUG: [",$#keywords,",",$#keywords < 0,"] is_valid($keywords_txt) => (\!$falsesum) && $truesum = ",(!$falsesum) && $truesum,"\n" if $debug;
+ return (!$falsesum) && $truesum;
+}
+
+sub print_test_file
+{
+ (*OUT,my $name,*nums,my $testall,my @symbols)=@_;
+ my $n = 1; my @e; my @r;
+ my $sym; my $prev = ""; my $prefSSLeay;
+
+ (@e)=grep(/^SSLeay(\{[0-9]+\})?\\.*?:.*?:.*/,@symbols);
+ (@r)=grep(/^\w+(\{[0-9]+\})?\\.*?:.*?:.*/ && !/^SSLeay(\{[0-9]+\})?\\.*?:.*?:.*/,@symbols);
+ @symbols=((sort @e),(sort @r));
+
+ foreach $sym (@symbols) {
+ (my $s, my $i) = $sym =~ /^(.*?)\\(.*)$/;
+ my $v = 0;
+ $v = 1 if $i=~ /^.*?:.*?:VARIABLE/;
+ my $p = ($i =~ /^[^:]*:([^:]*):/,$1);
+ my $a = ($i =~ /^[^:]*:[^:]*:[^:]*:([^:]*)/,$1);
+ if (!defined($nums{$s})) {
+ print STDERR "Warning: $s does not have a number assigned\n"
+ if(!$do_update);
+ } elsif (is_valid($p,1) && is_valid($a,0)) {
+ my $s2 = ($s =~ /^(.*?)(\{[0-9]+\})?$/, $1);
+ if ($prev eq $s2) {
+ print OUT "\t/* The following has already appeared previously */\n";
+ print STDERR "Warning: Symbol '",$s2,"' redefined. old=",($nums{$prev} =~ /^(.*?)\\/,$1),", new=",($nums{$s2} =~ /^(.*?)\\/,$1),"\n";
+ }
+ $prev = $s2; # To warn about duplicates...
+
+ (my $nn, my $vers, my $ni) = split /\\/, $nums{$s2};
+ if ($v) {
+ print OUT "\textern int $s2; /* type unknown */ /* $nn $ni */\n";
+ } else {
+ print OUT "\textern int $s2(); /* type unknown */ /* $nn $ni */\n";
+ }
+ }
+ }
+}
+
+sub get_version
+{
+ return $config{version};
+}
+
+sub print_def_file
+{
+ (*OUT,my $name,*nums,my @symbols)=@_;
+ my $n = 1; my @e; my @r; my @v; my $prev="";
+ my $liboptions="";
+ my $libname = $name;
+ my $http_vendor = 'www.openssl.org/';
+ my $version = get_version();
+ my $what = "OpenSSL: implementation of Secure Socket Layer";
+ my $description = "$what $version, $name - http://$http_vendor";
+ my $prevsymversion = "", $prevprevsymversion = "";
+ # For VMS
+ my $prevnum = 0;
+ my $symvtextcount = 0;
+
+ if ($W32)
+ { $libname.="32"; }
+
+ if ($W32)
+ {
+ print OUT <<"EOF";
+;
+; Definition file for the DLL version of the $name library from OpenSSL
+;
+
+LIBRARY $libname $liboptions
+
+EOF
+
+ print "EXPORTS\n";
+ }
+ elsif ($VMS)
+ {
+ print OUT <<"EOF";
+CASE_SENSITIVE=YES
+SYMBOL_VECTOR=(-
+EOF
+ $symvtextcount = 16; # length of "SYMBOL_VECTOR=(-"
+ }
+
+ (@r)=grep(/^\w+(\{[0-9]+\})?\\.*?:.*?:FUNCTION/,@symbols);
+ (@v)=grep(/^\w+(\{[0-9]+\})?\\.*?:.*?:VARIABLE/,@symbols);
+ if ($VMS) {
+ # VMS needs to have the symbols on slot number order
+ @symbols=(map { $_->[1] }
+ sort { $a->[0] <=> $b->[0] }
+ map { (my $s, my $i) = $_ =~ /^(.*?)\\(.*)$/;
+ die "Error: $s doesn't have a number assigned\n"
+ if !defined($nums{$s});
+ (my $n, my @rest) = split /\\/, $nums{$s};
+ [ $n, $_ ] } (@e, @r, @v));
+ } else {
+ @symbols=((sort @e),(sort @r), (sort @v));
+ }
+
+ my ($baseversion, $currversion) = get_openssl_version();
+ my $thisversion;
+ do {
+ if (!defined($thisversion)) {
+ $thisversion = $baseversion;
+ } else {
+ $thisversion = get_next_version($thisversion);
+ }
+ foreach $sym (@symbols) {
+ (my $s, my $i) = $sym =~ /^(.*?)\\(.*)$/;
+ my $v = 0;
+ $v = 1 if $i =~ /^.*?:.*?:VARIABLE/;
+ if (!defined($nums{$s})) {
+ die "Error: $s does not have a number assigned\n"
+ if(!$do_update);
+ } else {
+ (my $n, my $symversion, my $dummy) = split /\\/, $nums{$s};
+ my %pf = ();
+ my $p = ($i =~ /^[^:]*:([^:]*):/,$1);
+ my $a = ($i =~ /^[^:]*:[^:]*:[^:]*:([^:]*)/,$1);
+ if (is_valid($p,1) && is_valid($a,0)) {
+ my $s2 = ($s =~ /^(.*?)(\{[0-9]+\})?$/, $1);
+ if ($prev eq $s2) {
+ print STDERR "Warning: Symbol '",$s2,
+ "' redefined. old=",($nums{$prev} =~ /^(.*?)\\/,$1),
+ ", new=",($nums{$s2} =~ /^(.*?)\\/,$1),"\n";
+ }
+ $prev = $s2; # To warn about duplicates...
+ if($linux) {
+ next if $symversion ne $thisversion;
+ if ($symversion ne $prevsymversion) {
+ if ($prevsymversion ne "") {
+ if ($prevprevsymversion ne "") {
+ print OUT "} OPENSSL${SO_VARIANT}_"
+ ."$prevprevsymversion;\n\n";
+ } else {
+ print OUT "};\n\n";
+ }
+ }
+ print OUT "OPENSSL${SO_VARIANT}_$symversion {\n global:\n";
+ $prevprevsymversion = $prevsymversion;
+ $prevsymversion = $symversion;
+ }
+ print OUT " $s2;\n";
+ } elsif ($VMS) {
+ while(++$prevnum < $n) {
+ my $symline=" ,SPARE -\n ,SPARE -\n";
+ if ($symvtextcount + length($symline) - 2 > 1024) {
+ print OUT ")\nSYMBOL_VECTOR=(-\n";
+ $symvtextcount = 16; # length of "SYMBOL_VECTOR=(-"
+ }
+ if ($symvtextcount == 16) {
+ # Take away first comma
+ $symline =~ s/,//;
+ }
+ print OUT $symline;
+ $symvtextcount += length($symline) - 2;
+ }
+ (my $s_uc = $s) =~ tr/a-z/A-Z/;
+ my $symtype=
+ $v ? "DATA" : "PROCEDURE";
+ my $symline=
+ ($s_uc ne $s
+ ? " ,$s_uc/$s=$symtype -\n ,$s=$symtype -\n"
+ : " ,$s=$symtype -\n ,SPARE -\n");
+ if ($symvtextcount + length($symline) - 2 > 1024) {
+ print OUT ")\nSYMBOL_VECTOR=(-\n";
+ $symvtextcount = 16; # length of "SYMBOL_VECTOR=(-"
+ }
+ if ($symvtextcount == 16) {
+ # Take away first comma
+ $symline =~ s/,//;
+ }
+ print OUT $symline;
+ $symvtextcount += length($symline) - 2;
+ } elsif($v) {
+ printf OUT " %s%-39s DATA\n",
+ ($W32)?"":"_",$s2;
+ } else {
+ printf OUT " %s%s\n",
+ ($W32)?"":"_",$s2;
+ }
+ }
+ }
+ }
+ } while ($linux && $thisversion ne $currversion);
+ if ($linux) {
+ if ($prevprevsymversion ne "") {
+ print OUT " local: *;\n} OPENSSL${SO_VARIANT}_$prevprevsymversion;\n\n";
+ } else {
+ print OUT " local: *;\n};\n\n";
+ }
+ } elsif ($VMS) {
+ print OUT ")\n";
+ (my $libvmaj, my $libvmin, my $libvedit) =
+ $currversion =~ /^(\d+)_(\d+)_(\d+)$/;
+ # The reason to multiply the edit number with 100 is to make space
+ # for the possibility that we want to encode the patch letters
+ print OUT "GSMATCH=LEQUAL,",($libvmaj * 100 + $libvmin),",",($libvedit * 100),"\n";
+ }
+ printf OUT "\n";
+}
+
+sub load_numbers
+{
+ my($name)=@_;
+ my(@a,%ret);
+ my $prevversion;
+
+ $max_num = 0;
+ $num_noinfo = 0;
+ $prev = "";
+ $prev_cnt = 0;
+
+ my ($baseversion, $currversion) = get_openssl_version();
+
+ open(IN,"<$name") || die "unable to open $name:$!\n";
+ while (<IN>) {
+ s|\R$||; # Better chomp
+ s/#.*$//;
+ next if /^\s*$/;
+ @a=split;
+ if (defined $ret{$a[0]}) {
+ # This is actually perfectly OK
+ #print STDERR "Warning: Symbol '",$a[0],"' redefined. old=",$ret{$a[0]},", new=",$a[1],"\n";
+ }
+ if ($max_num > $a[1]) {
+ print STDERR "Warning: Number decreased from ",$max_num," to ",$a[1],"\n";
+ }
+ elsif ($max_num == $a[1]) {
+ # This is actually perfectly OK
+ #print STDERR "Warning: Symbol ",$a[0]," has same number as previous ",$prev,": ",$a[1],"\n";
+ if ($a[0] eq $prev) {
+ $prev_cnt++;
+ $a[0] .= "{$prev_cnt}";
+ }
+ }
+ else {
+ $prev_cnt = 0;
+ }
+ if ($#a < 2) {
+ # Existence will be proven later, in do_defs
+ $ret{$a[0]}=$a[1];
+ $num_noinfo++;
+ } else {
+ #Sanity check the version number
+ if (defined $prevversion) {
+ check_version_lte($prevversion, $a[2]);
+ }
+ check_version_lte($a[2], $currversion);
+ $prevversion = $a[2];
+ $ret{$a[0]}=$a[1]."\\".$a[2]."\\".$a[3]; # \\ is a special marker
+ }
+ $max_num = $a[1] if $a[1] > $max_num;
+ $prev=$a[0];
+ }
+ if ($num_noinfo) {
+ print STDERR "Warning: $num_noinfo symbols were without info." if $verbose || !$do_rewrite;
+ if ($do_rewrite) {
+ printf STDERR " The rewrite will fix this.\n" if $verbose;
+ } else {
+ printf STDERR " You should do a rewrite to fix this.\n";
+ }
+ }
+ close(IN);
+ return(%ret);
+}
+
+sub parse_number
+{
+ (my $str, my $what) = @_;
+ (my $n, my $v, my $i) = split(/\\/,$str);
+ if ($what eq "n") {
+ return $n;
+ } else {
+ return $i;
+ }
+}
+
+sub rewrite_numbers
+{
+ (*OUT,$name,*nums,@symbols)=@_;
+ my $thing;
+
+ my @r = grep(/^\w+(\{[0-9]+\})?\\.*?:.*?:\w+\(\w+\)/,@symbols);
+ my $r; my %r; my %rsyms;
+ foreach $r (@r) {
+ (my $s, my $i) = split /\\/, $r;
+ my $a = $1 if $i =~ /^.*?:.*?:\w+\((\w+)\)/;
+ $i =~ s/^(.*?:.*?:\w+)\(\w+\)/$1/;
+ $r{$a} = $s."\\".$i;
+ $rsyms{$s} = 1;
+ }
+
+ my %syms = ();
+ foreach $_ (@symbols) {
+ (my $n, my $i) = split /\\/;
+ $syms{$n} = 1;
+ }
+
+ my @s=sort {
+ &parse_number($nums{$a},"n") <=> &parse_number($nums{$b},"n")
+ || $a cmp $b
+ } keys %nums;
+ foreach $sym (@s) {
+ (my $n, my $vers, my $i) = split /\\/, $nums{$sym};
+ next if defined($i) && $i =~ /^.*?:.*?:\w+\(\w+\)/;
+ next if defined($rsyms{$sym});
+ print STDERR "DEBUG: rewrite_numbers for sym = ",$sym,": i = ",$i,", n = ",$n,", rsym{sym} = ",$rsyms{$sym},"syms{sym} = ",$syms{$sym},"\n" if $debug;
+ $i="NOEXIST::FUNCTION:"
+ if !defined($i) || $i eq "" || !defined($syms{$sym});
+ my $s2 = $sym;
+ $s2 =~ s/\{[0-9]+\}$//;
+ printf OUT "%s%-39s %d\t%s\t%s\n","",$s2,$n,$vers,$i;
+ if (exists $r{$sym}) {
+ (my $s, $i) = split /\\/,$r{$sym};
+ my $s2 = $s;
+ $s2 =~ s/\{[0-9]+\}$//;
+ printf OUT "%s%-39s %d\t%s\t%s\n","",$s2,$n,$vers,$i;
+ }
+ }
+}
+
+sub update_numbers
+{
+ (*OUT,$name,*nums,my $start_num, my @symbols)=@_;
+ my $new_syms = 0;
+ my $basevers;
+ my $vers;
+
+ ($basevers, $vers) = get_openssl_version();
+
+ my @r = grep(/^\w+(\{[0-9]+\})?\\.*?:.*?:\w+\(\w+\)/,@symbols);
+ my $r; my %r; my %rsyms;
+ foreach $r (@r) {
+ (my $s, my $i) = split /\\/, $r;
+ my $a = $1 if $i =~ /^.*?:.*?:\w+\((\w+)\)/;
+ $i =~ s/^(.*?:.*?:\w+)\(\w+\)/$1/;
+ $r{$a} = $s."\\".$i;
+ $rsyms{$s} = 1;
+ }
+
+ foreach $sym (@symbols) {
+ (my $s, my $i) = $sym =~ /^(.*?)\\(.*)$/;
+ next if $i =~ /^.*?:.*?:\w+\(\w+\)/;
+ next if defined($rsyms{$sym});
+ die "ERROR: Symbol $sym had no info attached to it."
+ if $i eq "";
+ if (!exists $nums{$s}) {
+ $new_syms++;
+ my $s2 = $s;
+ $s2 =~ s/\{[0-9]+\}$//;
+ printf OUT "%s%-39s %d\t%s\t%s\n","",$s2, ++$start_num,$vers,$i;
+ if (exists $r{$s}) {
+ ($s, $i) = split /\\/,$r{$s};
+ $s =~ s/\{[0-9]+\}$//;
+ printf OUT "%s%-39s %d\t%s\t%s\n","",$s, $start_num,$vers,$i;
+ }
+ }
+ }
+ if($new_syms) {
+ print STDERR "$name: Added $new_syms new symbols\n";
+ } else {
+ print STDERR "$name: No new symbols added\n";
+ }
+}
+
+sub check_existing
+{
+ (*nums, my @symbols)=@_;
+ my %existing; my @remaining;
+ @remaining=();
+ foreach $sym (@symbols) {
+ (my $s, my $i) = $sym =~ /^(.*?)\\(.*)$/;
+ $existing{$s}=1;
+ }
+ foreach $sym (keys %nums) {
+ if (!exists $existing{$sym}) {
+ push @remaining, $sym;
+ }
+ }
+ if(@remaining) {
+ print STDERR "The following symbols do not seem to exist:\n";
+ foreach $sym (@remaining) {
+ print STDERR "\t",$sym,"\n";
+ }
+ }
+}
+
+sub count_parens
+{
+ my $line = shift(@_);
+
+ my $open = $line =~ tr/\(//;
+ my $close = $line =~ tr/\)//;
+
+ return $open - $close;
+}
+
+#Parse opensslv.h to get the current version number. Also work out the base
+#version, i.e. the lowest version number that is binary compatible with this
+#version
+sub get_openssl_version()
+{
+ my $fn = catfile($config{sourcedir},"include","openssl","opensslv.h");
+ open (IN, "$fn") || die "Can't open opensslv.h";
+
+ while(<IN>) {
+ if (/OPENSSL_VERSION_TEXT\s+"OpenSSL (\d\.\d\.)(\d[a-z]*)(-| )/) {
+ my $suffix = $2;
+ (my $baseversion = $1) =~ s/\./_/g;
+ close IN;
+ return ($baseversion."0", $baseversion.$suffix);
+ }
+ }
+ die "Can't find OpenSSL version number\n";
+}
+
+#Given an OpenSSL version number, calculate the next version number. If the
+#version number gets to a.b.czz then we go to a.b.(c+1)
+sub get_next_version()
+{
+ my $thisversion = shift;
+
+ my ($base, $letter) = $thisversion =~ /^(\d_\d_\d)([a-z]{0,2})$/;
+
+ if ($letter eq "zz") {
+ my $lastnum = substr($base, -1);
+ return substr($base, 0, length($base)-1).(++$lastnum);
+ }
+ return $base.get_next_letter($letter);
+}
+
+#Given the letters off the end of an OpenSSL version string, calculate what
+#the letters for the next release would be.
+sub get_next_letter()
+{
+ my $thisletter = shift;
+ my $baseletter = "";
+ my $endletter;
+
+ if ($thisletter eq "") {
+ return "a";
+ }
+ if ((length $thisletter) > 1) {
+ ($baseletter, $endletter) = $thisletter =~ /([a-z]+)([a-z])/;
+ } else {
+ $endletter = $thisletter;
+ }
+
+ if ($endletter eq "z") {
+ return $thisletter."a";
+ } else {
+ return $baseletter.(++$endletter);
+ }
+}
+
+#Check if a version is less than or equal to the current version. Its a fatal
+#error if not. They must also only differ in letters, or the last number (i.e.
+#the first two numbers must be the same)
+sub check_version_lte()
+{
+ my ($testversion, $currversion) = @_;
+ my $lentv;
+ my $lencv;
+ my $cvbase;
+
+ my ($cvnums) = $currversion =~ /^(\d_\d_\d)[a-z]*$/;
+ my ($tvnums) = $testversion =~ /^(\d_\d_\d)[a-z]*$/;
+
+ #Die if we can't parse the version numbers or they don't look sane
+ die "Invalid version number: $testversion and $currversion\n"
+ if (!defined($cvnums) || !defined($tvnums)
+ || length($cvnums) != 5
+ || length($tvnums) != 5);
+
+ #If the base versions (without letters) don't match check they only differ
+ #in the last number
+ if ($cvnums ne $tvnums) {
+ die "Invalid version number: $testversion "
+ ."for current version $currversion\n"
+ if (substr($cvnums, -1) < substr($tvnums, -1)
+ || substr($cvnums, 0, 4) ne substr($tvnums, 0, 4));
+ return;
+ }
+ #If we get here then the base version (i.e. the numbers) are the same - they
+ #only differ in the letters
+
+ $lentv = length $testversion;
+ $lencv = length $currversion;
+
+ #If the testversion has more letters than the current version then it must
+ #be later (or malformed)
+ if ($lentv > $lencv) {
+ die "Invalid version number: $testversion "
+ ."is greater than $currversion\n";
+ }
+
+ #Get the last letter from the current version
+ my ($cvletter) = $currversion =~ /([a-z])$/;
+ if (defined $cvletter) {
+ ($cvbase) = $currversion =~ /(\d_\d_\d[a-z]*)$cvletter$/;
+ } else {
+ $cvbase = $currversion;
+ }
+ die "Unable to parse version number $currversion" if (!defined $cvbase);
+ my $tvbase;
+ my ($tvletter) = $testversion =~ /([a-z])$/;
+ if (defined $tvletter) {
+ ($tvbase) = $testversion =~ /(\d_\d_\d[a-z]*)$tvletter$/;
+ } else {
+ $tvbase = $testversion;
+ }
+ die "Unable to parse version number $testversion" if (!defined $tvbase);
+
+ if ($lencv > $lentv) {
+ #If current version has more letters than testversion then testversion
+ #minus the final letter must be a substring of the current version
+ die "Invalid version number $testversion "
+ ."is greater than $currversion or is invalid\n"
+ if (index($cvbase, $tvbase) != 0);
+ } else {
+ #If both versions have the same number of letters then they must be
+ #equal up to the last letter, and the last letter in testversion must
+ #be less than or equal to the last letter in current version.
+ die "Invalid version number $testversion "
+ ."is greater than $currversion\n"
+ if (($cvbase ne $tvbase) && ($tvletter gt $cvletter));
+ }
+}
+
+sub do_deprecated()
+{
+ my ($decl, $plats, $algs) = @_;
+ $decl =~ /^\s*(DEPRECATEDIN_\d+_\d+_\d+)\s*\((.*)\)\s*$/
+ or die "Bad DEPRECTEDIN: $decl\n";
+ my $info1 .= "#INFO:";
+ $info1 .= join(',', @{$plats}) . ":";
+ my $info2 = $info1;
+ $info1 .= join(',',@{$algs}, $1) . ";";
+ $info2 .= join(',',@{$algs}) . ";";
+ return $info1 . $2 . ";" . $info2;
+}
diff --git a/openssl-1.1.0h/util/mkdir-p.pl b/openssl-1.1.0h/util/mkdir-p.pl
new file mode 100755
index 0000000..3280602
--- /dev/null
+++ b/openssl-1.1.0h/util/mkdir-p.pl
@@ -0,0 +1,44 @@
+#! /usr/bin/env perl
+# Copyright 1999-2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+# On some systems, the -p option to mkdir (= also create any missing parent
+# directories) is not available.
+
+my $arg;
+
+foreach $arg (@ARGV) {
+ $arg =~ tr|\\|/|;
+ &do_mkdir_p($arg);
+}
+
+
+sub do_mkdir_p {
+ local($dir) = @_;
+
+ $dir =~ s|/*\Z(?!\n)||s;
+
+ if (-d $dir) {
+ return;
+ }
+
+ if ($dir =~ m|[^/]/|s) {
+ local($parent) = $dir;
+ $parent =~ s|[^/]*\Z(?!\n)||s;
+
+ do_mkdir_p($parent);
+ }
+
+ unless (mkdir($dir, 0777)) {
+ if (-d $dir) {
+ # We raced against another instance doing the same thing.
+ return;
+ }
+ die "Cannot create directory $dir: $!\n";
+ }
+ print "created directory `$dir'\n";
+}
diff --git a/openssl-1.1.0h/util/mkerr.pl b/openssl-1.1.0h/util/mkerr.pl
new file mode 100644
index 0000000..79c8cfc
--- /dev/null
+++ b/openssl-1.1.0h/util/mkerr.pl
@@ -0,0 +1,771 @@
+#! /usr/bin/env perl
+# Copyright 1999-2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+my $config = "crypto/err/openssl.ec";
+my $debug = 0;
+my $unref = 0;
+my $rebuild = 0;
+my $static = 1;
+my $recurse = 0;
+my $reindex = 0;
+my $dowrite = 0;
+my $staticloader = "";
+my @t = localtime();
+my $YEAR = @t[5] + 1900;
+
+my $pack_errcode;
+my $load_errcode;
+
+my $errcount;
+my $year = (localtime)[5] + 1900;
+
+while (@ARGV) {
+ my $arg = $ARGV[0];
+ if($arg eq "-conf") {
+ shift @ARGV;
+ $config = shift @ARGV;
+ } elsif($arg eq "-hprefix") {
+ shift @ARGV;
+ $hprefix = shift @ARGV;
+ } elsif($arg eq "-debug") {
+ $debug = 1;
+ $unref = 1;
+ shift @ARGV;
+ } elsif($arg eq "-rebuild") {
+ $rebuild = 1;
+ shift @ARGV;
+ } elsif($arg eq "-recurse") {
+ $recurse = 1;
+ shift @ARGV;
+ } elsif($arg eq "-reindex") {
+ $reindex = 1;
+ shift @ARGV;
+ } elsif($arg eq "-nostatic") {
+ $static = 0;
+ shift @ARGV;
+ } elsif($arg eq "-staticloader") {
+ $staticloader = "static ";
+ shift @ARGV;
+ } elsif($arg eq "-unref") {
+ $unref = 1;
+ shift @ARGV;
+ } elsif($arg eq "-write") {
+ $dowrite = 1;
+ shift @ARGV;
+ } elsif($arg eq "-help" || $arg eq "-h" || $arg eq "-?" || $arg eq "--help") {
+ print STDERR <<"EOF";
+mkerr.pl [options] ...
+
+Options:
+
+ -conf F Use the config file F instead of the default one:
+ crypto/err/openssl.ec
+
+ -hprefix P Prepend the filenames in generated #include <header>
+ statements with prefix P. Default: 'openssl/' (without
+ the quotes, naturally)
+ NOTE: not used any more because our include directory
+ structure has changed.
+
+ -debug Turn on debugging verbose output on stderr.
+
+ -rebuild Rebuild all header and C source files, irrespective of the
+ fact if any error or function codes have been added/removed.
+ Default: only update files for libraries which saw change
+ (of course, this requires '-write' as well, or no
+ files will be touched!)
+
+ -recurse scan a preconfigured set of directories / files for error and
+ function codes:
+ (<crypto/*.c>, <crypto/*/*.c>, <ssl/*.c>, <apps/*.c>)
+ When this option is NOT specified, the filelist is taken from
+ the commandline instead. Here, wildcards may be embedded. (Be
+ sure to escape those to prevent the shell from expanding them
+ for you when you wish mkerr.pl to do so instead.)
+ Default: take file list to scan from the command line.
+
+ -reindex Discard the numeric values previously assigned to the error
+ and function codes as extracted from the scanned header files;
+ instead renumber all of them starting from 100. (Note that
+ the numbers assigned through 'R' records in the config file
+ remain intact.)
+ Default: keep previously assigned numbers. (You are warned
+ when collisions are detected.)
+
+ -nostatic Generates a different source code, where these additional
+ functions are generated for each library specified in the
+ config file:
+ void ERR_load_<LIB>_strings(void);
+ void ERR_unload_<LIB>_strings(void);
+ void ERR_<LIB>_error(int f, int r, char *fn, int ln);
+ #define <LIB>err(f,r) ERR_<LIB>_error(f,r,OPENSSL_FILE,OPENSSL_LINE)
+ while the code facilitates the use of these in an environment
+ where the error support routines are dynamically loaded at
+ runtime.
+ Default: 'static' code generation.
+
+ -staticloader Prefix generated functions with the 'static' scope modifier.
+ Default: don't write any scope modifier prefix.
+
+ -unref Print out unreferenced function and reason codes.
+
+ -write Actually (over)write the generated code to the header and C
+ source files as assigned to each library through the config
+ file.
+ Default: don't write.
+
+ -help / -h / -? / --help Show this help text.
+
+ ... Additional arguments are added to the file list to scan,
+ assuming '-recurse' was NOT specified on the command line.
+
+EOF
+ exit 1;
+ } else {
+ last;
+ }
+}
+
+if($recurse) {
+ @source = ( <crypto/*.c>, <crypto/*/*.c>, <ssl/*.c>, <ssl/*/*.c> )
+} else {
+ @source = @ARGV;
+}
+
+# Read in the config file
+
+open(IN, "<$config") || die "Can't open config file $config";
+
+# Parse config file
+
+while(<IN>)
+{
+ if(/^L\s+(\S+)\s+(\S+)\s+(\S+)/) {
+ $hinc{$1} = $2;
+ $libinc{$2} = $1;
+ $cskip{$3} = $1;
+ if($3 ne "NONE") {
+ $csrc{$1} = $3;
+ $fmax{$1} = 100;
+ $rmax{$1} = 100;
+ $fassigned{$1} = ":";
+ $rassigned{$1} = ":";
+ $fnew{$1} = 0;
+ $rnew{$1} = 0;
+ }
+ } elsif (/^F\s+(\S+)/) {
+ # Add extra function with $1
+ } elsif (/^R\s+(\S+)\s+(\S+)/) {
+ $rextra{$1} = $2;
+ $rcodes{$1} = $2;
+ }
+}
+
+close IN;
+
+# Scan each header file in turn and make a list of error codes
+# and function names
+
+while (($hdr, $lib) = each %libinc)
+{
+ next if($hdr eq "NONE");
+ print STDERR "Scanning header file $hdr\n" if $debug;
+ my $line = "", $def= "", $linenr = 0, $gotfile = 0, $cpp = 0;
+ if (open(IN, "<$hdr")) {
+ $gotfile = 1;
+ while(<IN>) {
+ $linenr++;
+ print STDERR "line: $linenr\r" if $debug;
+
+ last if(/BEGIN\s+ERROR\s+CODES/);
+ if ($line ne '') {
+ $_ = $line . $_;
+ $line = '';
+ }
+
+ if (/\\$/) {
+ $line = $_;
+ next;
+ }
+
+ if(/\/\*/) {
+ if (not /\*\//) { # multiline comment...
+ $line = $_; # ... just accumulate
+ next;
+ } else {
+ s/\/\*.*?\*\///gs; # wipe it
+ }
+ }
+
+ if ($cpp) {
+ $cpp++ if /^#\s*if/;
+ $cpp-- if /^#\s*endif/;
+ next;
+ }
+ $cpp = 1 if /^#.*ifdef.*cplusplus/; # skip "C" declaration
+
+ next if (/^\#/); # skip preprocessor directives
+
+ s/{[^{}]*}//gs; # ignore {} blocks
+
+ if (/\{|\/\*/) { # Add a } so editor works...
+ $line = $_;
+ } else {
+ $def .= $_;
+ }
+ }
+ }
+
+ print STDERR " \r" if $debug;
+ $defnr = 0;
+ # Delete any DECLARE_ macros
+ $def =~ s/DECLARE_\w+\([\w,\s]+\)//gs;
+ foreach (split /;/, $def) {
+ $defnr++;
+ print STDERR "def: $defnr\r" if $debug;
+
+ # The goal is to collect function names from function declarations.
+
+ s/^[\n\s]*//g;
+ s/[\n\s]*$//g;
+
+ # Skip over recognized non-function declarations
+ next if(/typedef\W/ or /DECLARE_STACK_OF/ or /TYPEDEF_.*_OF/);
+
+ # Remove STACK_OF(foo)
+ s/STACK_OF\(\w+\)/void/;
+
+ # Reduce argument lists to empty ()
+ # fold round brackets recursively: (t(*v)(t),t) -> (t{}{},t) -> {}
+ while(/\(.*\)/s) {
+ s/\([^\(\)]+\)/\{\}/gs;
+ s/\(\s*\*\s*(\w+)\s*\{\}\s*\)/$1/gs; #(*f{}) -> f
+ }
+ # pretend as we didn't use curly braces: {} -> ()
+ s/\{\}/\(\)/gs;
+
+ if (/(\w+)\s*\(\).*/s) { # first token prior [first] () is
+ my $name = $1; # a function name!
+ $name =~ tr/[a-z]/[A-Z]/;
+ $ftrans{$name} = $1;
+ } elsif (/[\(\)]/ and not (/=/)) {
+ print STDERR "Header $hdr: cannot parse: $_;\n";
+ }
+ }
+
+ print STDERR " \r" if $debug;
+
+ next if $reindex;
+
+ # Scan function and reason codes and store them: keep a note of the
+ # maximum code used.
+
+ if ($gotfile) {
+ while(<IN>) {
+ if(/^\#\s*define\s+(\S+)\s+(\S+)/) {
+ $name = $1;
+ $code = $2;
+ next if $name =~ /^${lib}err/;
+ unless($name =~ /^${lib}_([RF])_(\w+)$/) {
+ print STDERR "Invalid error code $name\n";
+ next;
+ }
+ if($1 eq "R") {
+ $rcodes{$name} = $code;
+ if ($rassigned{$lib} =~ /:$code:/) {
+ print STDERR "!! ERROR: $lib reason code $code assigned twice (collision at $name)\n";
+ ++$errcount;
+ }
+ $rassigned{$lib} .= "$code:";
+ if(!(exists $rextra{$name}) &&
+ ($code > $rmax{$lib}) ) {
+ $rmax{$lib} = $code;
+ }
+ } else {
+ if ($fassigned{$lib} =~ /:$code:/) {
+ print STDERR "!! ERROR: $lib function code $code assigned twice (collision at $name)\n";
+ ++$errcount;
+ }
+ $fassigned{$lib} .= "$code:";
+ if($code > $fmax{$lib}) {
+ $fmax{$lib} = $code;
+ }
+ $fcodes{$name} = $code;
+ }
+ }
+ }
+ }
+
+ if ($debug) {
+ if (defined($fmax{$lib})) {
+ print STDERR "Max function code fmax" . "{" . "$lib" . "} = $fmax{$lib}\n";
+ $fassigned{$lib} =~ m/^:(.*):$/;
+ @fassigned = sort {$a <=> $b} split(":", $1);
+ print STDERR " @fassigned\n";
+ }
+ if (defined($rmax{$lib})) {
+ print STDERR "Max reason code rmax" . "{" . "$lib" . "} = $rmax{$lib}\n";
+ $rassigned{$lib} =~ m/^:(.*):$/;
+ @rassigned = sort {$a <=> $b} split(":", $1);
+ print STDERR " @rassigned\n";
+ }
+ }
+
+ if ($lib eq "SSL") {
+ if ($rmax{$lib} >= 1000) {
+ print STDERR "!! ERROR: SSL error codes 1000+ are reserved for alerts.\n";
+ print STDERR "!! Any new alerts must be added to $config.\n";
+ ++$errcount;
+ print STDERR "\n";
+ }
+ }
+ close IN;
+}
+
+# Scan each C source file and look for function and reason codes
+# This is done by looking for strings that "look like" function or
+# reason codes: basically anything consisting of all upper case and
+# numerics which has _F_ or _R_ in it and which has the name of an
+# error library at the start. This seems to work fine except for the
+# oddly named structure BIO_F_CTX which needs to be ignored.
+# If a code doesn't exist in list compiled from headers then mark it
+# with the value "X" as a place holder to give it a value later.
+# Store all function and reason codes found in %ufcodes and %urcodes
+# so all those unreferenced can be printed out.
+
+
+foreach $file (@source) {
+ # Don't parse the error source file.
+ next if exists $cskip{$file};
+ print STDERR "File loaded: ".$file."\r" if $debug;
+ open(IN, "<$file") || die "Can't open source file $file\n";
+ my $func;
+ my $linenr = 0;
+ while(<IN>) {
+ # skip obsoleted source files entirely!
+ last if(/^#error\s+obsolete/);
+ $linenr++;
+ if (!/;$/ && /^\**([a-zA-Z_].*[\s*])?([A-Za-z_0-9]+)\(.*([),]|$)/)
+ {
+ /^([^()]*(\([^()]*\)[^()]*)*)\(/;
+ $1 =~ /([A-Za-z_0-9]*)$/;
+ $func = $1;
+ }
+
+ if(/(([A-Z0-9]+)_F_([A-Z0-9_]+))/) {
+ next unless exists $csrc{$2};
+ next if($1 eq "BIO_F_BUFFER_CTX");
+ $ufcodes{$1} = 1;
+ if(!exists $fcodes{$1}) {
+ $fcodes{$1} = "X";
+ $fnew{$2}++;
+ }
+ $ftrans{$3} = $func unless exists $ftrans{$3};
+ if (uc $func ne $3) {
+ print STDERR "ERROR: mismatch $file:$linenr $func:$3\n";
+ $errcount++;
+ }
+ print STDERR "Function: $1\t= $fcodes{$1} (lib: $2, name: $3)\n" if $debug;
+ }
+ if(/(([A-Z0-9]+)_R_[A-Z0-9_]+)/) {
+ next unless exists $csrc{$2};
+ $urcodes{$1} = 1;
+ if(!exists $rcodes{$1}) {
+ $rcodes{$1} = "X";
+ $rnew{$2}++;
+ }
+ print STDERR "Reason: $1\t= $rcodes{$1} (lib: $2)\n" if $debug;
+ }
+ }
+ close IN;
+}
+print STDERR " \n" if $debug;
+
+# Now process each library in turn.
+
+foreach $lib (keys %csrc)
+{
+ my $hfile = $hinc{$lib};
+ my $cfile = $csrc{$lib};
+ if(!$fnew{$lib} && !$rnew{$lib}) {
+ next unless $rebuild;
+ } else {
+ print STDERR "$lib:\t\t$fnew{$lib} New Functions,";
+ print STDERR " $rnew{$lib} New Reasons.\n";
+ next unless $dowrite;
+ }
+
+ # If we get here then we have some new error codes so we
+ # need to rebuild the header file and C file.
+
+ # Make a sorted list of error and reason codes for later use.
+
+ my @function = sort grep(/^${lib}_/,keys %fcodes);
+ my @reasons = sort grep(/^${lib}_/,keys %rcodes);
+
+ # Rewrite the header file
+
+ $cpp = 0;
+ $cplusplus = 0;
+ if (open(IN, "<$hfile")) {
+ # Copy across the old file
+ while(<IN>) {
+ $cplusplus = $cpp if /^#.*ifdef.*cplusplus/;
+ $cpp++ if /^#\s*if/;
+ $cpp-- if /^#\s*endif/;
+ push @out, $_;
+ last if (/BEGIN ERROR CODES/);
+ }
+ close IN;
+ } else {
+ $cpp = 1;
+ $cplusplus = 1;
+ push @out,
+"/*\n",
+" * Copyright 1995-$YEAR The OpenSSL Project Authors. All Rights Reserved.\n",
+" *\n",
+" * Licensed under the OpenSSL license (the \"License\"). You may not use\n",
+" * this file except in compliance with the License. You can obtain a copy\n",
+" * in the file LICENSE in the source distribution or at\n",
+" * https://www.openssl.org/source/license.html\n",
+" */\n",
+"\n",
+"#ifndef HEADER_${lib}_ERR_H\n",
+"# define HEADER_${lib}_ERR_H\n",
+"\n",
+"# ifdef __cplusplus\n",
+"extern \"C\" {\n",
+"# endif\n",
+"\n",
+"/* BEGIN ERROR CODES */\n";
+ }
+ open (OUT, ">$hfile") || die "Can't Open File $hfile for writing\n";
+
+ print OUT @out;
+ undef @out;
+ print OUT <<"EOF";
+/*
+ * The following lines are auto generated by the script mkerr.pl. Any changes
+ * made after this point may be overwritten when the script is next run.
+ */
+
+EOF
+ if($static) {
+ print OUT <<"EOF";
+${staticloader}int ERR_load_${lib}_strings(void);
+
+EOF
+ } else {
+ print OUT <<"EOF";
+${staticloader}int ERR_load_${lib}_strings(void);
+${staticloader}void ERR_unload_${lib}_strings(void);
+${staticloader}void ERR_${lib}_error(int function, int reason, char *file, int line);
+# define ${lib}err(f,r) ERR_${lib}_error((f),(r),OPENSSL_FILE,OPENSSL_LINE)
+
+EOF
+ }
+ print OUT <<"EOF";
+/* Error codes for the $lib functions. */
+
+/* Function codes. */
+EOF
+
+ foreach $i (@function) {
+ $z=48 - length($i);
+ if($fcodes{$i} eq "X") {
+ $fassigned{$lib} =~ m/^:([^:]*):/;
+ $findcode = $1;
+ if (!defined($findcode)) {
+ $findcode = $fmax{$lib};
+ }
+ while ($fassigned{$lib} =~ m/:$findcode:/) {
+ $findcode++;
+ }
+ $fcodes{$i} = $findcode;
+ $fassigned{$lib} .= "$findcode:";
+ print STDERR "New Function code $i\n" if $debug;
+ }
+ printf OUT "# define $i%s $fcodes{$i}\n"," " x $z;
+ }
+
+ print OUT "\n/* Reason codes. */\n";
+
+ foreach $i (@reasons) {
+ $z=48 - length($i);
+ if($rcodes{$i} eq "X") {
+ $rassigned{$lib} =~ m/^:([^:]*):/;
+ $findcode = $1;
+ if (!defined($findcode)) {
+ $findcode = $rmax{$lib};
+ }
+ while ($rassigned{$lib} =~ m/:$findcode:/) {
+ $findcode++;
+ }
+ $rcodes{$i} = $findcode;
+ $rassigned{$lib} .= "$findcode:";
+ print STDERR "New Reason code $i\n" if $debug;
+ }
+ printf OUT "# define $i%s $rcodes{$i}\n"," " x $z;
+ }
+ print OUT <<"EOF";
+
+EOF
+ do {
+ if ($cplusplus == $cpp) {
+ print OUT "#", " "x$cpp, "ifdef __cplusplus\n";
+ print OUT "}\n";
+ print OUT "#", " "x$cpp, "endif\n";
+ }
+ if ($cpp-- > 0) {
+ print OUT "#", " "x$cpp, "endif\n";
+ }
+ } while ($cpp);
+ close OUT;
+
+ # Rewrite the C source file containing the error details.
+
+ # First, read any existing reason string definitions:
+ my %err_reason_strings;
+ if (open(IN,"<$cfile")) {
+ my $line = "";
+ while (<IN>) {
+ s|\R$||; # Better chomp
+ $_ = $line . $_;
+ $line = "";
+ if (/{ERR_(FUNC|REASON)\(/) {
+ if (/\b(${lib}_R_\w*)\b.*\"(.*)\"/) {
+ $err_reason_strings{$1} = $2;
+ } elsif (/\b${lib}_F_(\w*)\b.*\"(.*)\"/) {
+ if (!exists $ftrans{$1} && ($1 ne $2)) {
+ print STDERR "WARNING: Mismatched function string $2\n";
+ $ftrans{$1} = $2;
+ }
+ } else {
+ $line = $_;
+ }
+ }
+ }
+ close(IN);
+ }
+
+
+ my $hincf;
+ if($static) {
+ $hincf = $hfile;
+ $hincf =~ s|.*include/||;
+ if ($hincf =~ m|^openssl/|) {
+ $hincf = "<${hincf}>";
+ } else {
+ $hincf = "\"${hincf}\"";
+ }
+ } else {
+ $hincf = "\"$hfile\"";
+ }
+
+ # If static we know the error code at compile time so use it
+ # in error definitions.
+
+ if ($static)
+ {
+ $pack_errcode = "ERR_LIB_${lib}";
+ $load_errcode = "0";
+ }
+ else
+ {
+ $pack_errcode = "0";
+ $load_errcode = "ERR_LIB_${lib}";
+ }
+
+
+ open (OUT,">$cfile") || die "Can't open $cfile for writing";
+
+ print OUT <<"EOF";
+/*
+ * Generated by util/mkerr.pl DO NOT EDIT
+ * Copyright 1995-$YEAR The OpenSSL Project Authors. All Rights Reserved.
+ *
+ * Licensed under the OpenSSL license (the "License"). You may not use
+ * this file except in compliance with the License. You can obtain a copy
+ * in the file LICENSE in the source distribution or at
+ * https://www.openssl.org/source/license.html
+ */
+
+#include <stdio.h>
+#include <openssl/err.h>
+#include $hincf
+
+/* BEGIN ERROR CODES */
+#ifndef OPENSSL_NO_ERR
+
+# define ERR_FUNC(func) ERR_PACK($pack_errcode,func,0)
+# define ERR_REASON(reason) ERR_PACK($pack_errcode,0,reason)
+
+static ERR_STRING_DATA ${lib}_str_functs[] = {
+EOF
+ # Add each function code: if a function name is found then use it.
+ foreach $i (@function) {
+ my $fn;
+ $i =~ /^${lib}_F_(\S+)$/;
+ $fn = $1;
+ if(exists $ftrans{$fn}) {
+ $fn = $ftrans{$fn};
+ }
+# print OUT "{ERR_PACK($pack_errcode,$i,0),\t\"$fn\"},\n";
+ if(length($i) + length($fn) > 57) {
+ print OUT " {ERR_FUNC($i),\n \"$fn\"},\n";
+ } else {
+ print OUT " {ERR_FUNC($i), \"$fn\"},\n";
+ }
+ }
+ print OUT <<"EOF";
+ {0, NULL}
+};
+
+static ERR_STRING_DATA ${lib}_str_reasons[] = {
+EOF
+ # Add each reason code.
+ foreach $i (@reasons) {
+ my $rn;
+ my $rstr = "ERR_REASON($i)";
+ if (exists $err_reason_strings{$i}) {
+ $rn = $err_reason_strings{$i};
+ } else {
+ $i =~ /^${lib}_R_(\S+)$/;
+ $rn = $1;
+ $rn =~ tr/_[A-Z]/ [a-z]/;
+ }
+ if(length($i) + length($rn) > 55) {
+ print OUT " {${rstr},\n \"$rn\"},\n";
+ } else {
+ print OUT " {${rstr}, \"$rn\"},\n";
+ }
+ }
+if($static) {
+ print OUT <<"EOF";
+ {0, NULL}
+};
+
+#endif
+
+${staticloader}int ERR_load_${lib}_strings(void)
+{
+#ifndef OPENSSL_NO_ERR
+
+ if (ERR_func_error_string(${lib}_str_functs[0].error) == NULL) {
+ ERR_load_strings($load_errcode, ${lib}_str_functs);
+ ERR_load_strings($load_errcode, ${lib}_str_reasons);
+ }
+#endif
+ return 1;
+}
+EOF
+} else {
+ print OUT <<"EOF";
+ {0, NULL}
+};
+
+#endif
+
+#ifdef ${lib}_LIB_NAME
+static ERR_STRING_DATA ${lib}_lib_name[] = {
+ {0, ${lib}_LIB_NAME},
+ {0, NULL}
+};
+#endif
+
+static int ${lib}_lib_error_code = 0;
+static int ${lib}_error_init = 1;
+
+${staticloader}int ERR_load_${lib}_strings(void)
+{
+ if (${lib}_lib_error_code == 0)
+ ${lib}_lib_error_code = ERR_get_next_error_library();
+
+ if (${lib}_error_init) {
+ ${lib}_error_init = 0;
+#ifndef OPENSSL_NO_ERR
+ ERR_load_strings(${lib}_lib_error_code, ${lib}_str_functs);
+ ERR_load_strings(${lib}_lib_error_code, ${lib}_str_reasons);
+#endif
+
+#ifdef ${lib}_LIB_NAME
+ ${lib}_lib_name->error = ERR_PACK(${lib}_lib_error_code, 0, 0);
+ ERR_load_strings(0, ${lib}_lib_name);
+#endif
+ }
+ return 1;
+}
+
+${staticloader}void ERR_unload_${lib}_strings(void)
+{
+ if (${lib}_error_init == 0) {
+#ifndef OPENSSL_NO_ERR
+ ERR_unload_strings(${lib}_lib_error_code, ${lib}_str_functs);
+ ERR_unload_strings(${lib}_lib_error_code, ${lib}_str_reasons);
+#endif
+
+#ifdef ${lib}_LIB_NAME
+ ERR_unload_strings(0, ${lib}_lib_name);
+#endif
+ ${lib}_error_init = 1;
+ }
+}
+
+${staticloader}void ERR_${lib}_error(int function, int reason, char *file, int line)
+{
+ if (${lib}_lib_error_code == 0)
+ ${lib}_lib_error_code = ERR_get_next_error_library();
+ ERR_PUT_error(${lib}_lib_error_code, function, reason, file, line);
+}
+EOF
+
+}
+
+ close OUT;
+ undef %err_reason_strings;
+}
+
+if($debug && %notrans) {
+ print STDERR "The following function codes were not translated:\n";
+ foreach(sort keys %notrans)
+ {
+ print STDERR "$_\n";
+ }
+}
+
+# Make a list of unreferenced function and reason codes
+
+foreach (keys %fcodes) {
+ push (@funref, $_) unless exists $ufcodes{$_};
+}
+
+foreach (keys %rcodes) {
+ push (@runref, $_) unless exists $urcodes{$_};
+}
+
+if($unref && @funref) {
+ print STDERR "The following function codes were not referenced:\n";
+ foreach(sort @funref)
+ {
+ print STDERR "$_\n";
+ }
+}
+
+if($unref && @runref) {
+ print STDERR "The following reason codes were not referenced:\n";
+ foreach(sort @runref)
+ {
+ print STDERR "$_\n";
+ }
+}
+
+if($errcount) {
+ print STDERR "There were errors, failing...\n\n";
+ exit $errcount;
+}
+
diff --git a/openssl-1.1.0h/util/mkrc.pl b/openssl-1.1.0h/util/mkrc.pl
new file mode 100755
index 0000000..c177349
--- /dev/null
+++ b/openssl-1.1.0h/util/mkrc.pl
@@ -0,0 +1,83 @@
+#! /usr/bin/env perl
+# Copyright 2006-2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+use lib ".";
+use configdata;
+use File::Spec::Functions;
+
+my $versionfile = catfile($config{sourcedir},"include/openssl/opensslv.h");
+
+open FD, $versionfile or die "Couldn't open include/openssl/opensslv.h: $!\n";
+while(<FD>) {
+ if (/OPENSSL_VERSION_NUMBER\s+(0x[0-9a-f]+)/i) {
+ $ver = hex($1);
+ $v1 = ($ver>>28);
+ $v2 = ($ver>>20)&0xff;
+ $v3 = ($ver>>12)&0xff;
+ $v4 = ($ver>> 4)&0xff;
+ $beta = $ver&0xf;
+ $version = "$v1.$v2.$v3";
+ if ($beta==0xf) { $version .= chr(ord('a')+$v4-1) if ($v4); }
+ elsif ($beta==0){ $version .= "-dev"; }
+ else { $version .= "-beta$beta"; }
+ last;
+ }
+}
+close(FD);
+
+$filename = $ARGV[0]; $filename =~ /(.*)\.([^.]+)$/;
+$basename = $1;
+$extname = $2;
+
+if ($extname =~ /dll/i) { $description = "OpenSSL shared library"; }
+else { $description = "OpenSSL application"; }
+
+print <<___;
+#include <winver.h>
+
+LANGUAGE 0x09,0x01
+
+1 VERSIONINFO
+ FILEVERSION $v1,$v2,$v3,$v4
+ PRODUCTVERSION $v1,$v2,$v3,$v4
+ FILEFLAGSMASK 0x3fL
+#ifdef _DEBUG
+ FILEFLAGS 0x01L
+#else
+ FILEFLAGS 0x00L
+#endif
+ FILEOS VOS__WINDOWS32
+ FILETYPE VFT_DLL
+ FILESUBTYPE 0x0L
+BEGIN
+ BLOCK "StringFileInfo"
+ BEGIN
+ BLOCK "040904b0"
+ BEGIN
+ // Required:
+ VALUE "CompanyName", "The OpenSSL Project, http://www.openssl.org/\\0"
+ VALUE "FileDescription", "$description\\0"
+ VALUE "FileVersion", "$version\\0"
+ VALUE "InternalName", "$basename\\0"
+ VALUE "OriginalFilename", "$filename\\0"
+ VALUE "ProductName", "The OpenSSL Toolkit\\0"
+ VALUE "ProductVersion", "$version\\0"
+ // Optional:
+ //VALUE "Comments", "\\0"
+ VALUE "LegalCopyright", "Copyright 1998-2016 The OpenSSL Authors. All rights reserved.\\0"
+ //VALUE "LegalTrademarks", "\\0"
+ //VALUE "PrivateBuild", "\\0"
+ //VALUE "SpecialBuild", "\\0"
+ END
+ END
+ BLOCK "VarFileInfo"
+ BEGIN
+ VALUE "Translation", 0x409, 0x4b0
+ END
+END
+___
diff --git a/openssl-1.1.0h/util/openssl-format-source b/openssl-1.1.0h/util/openssl-format-source
new file mode 100755
index 0000000..3dcc128
--- /dev/null
+++ b/openssl-1.1.0h/util/openssl-format-source
@@ -0,0 +1,175 @@
+#!/bin/sh
+#
+# Copyright 2015-2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+#
+# openssl-format-source
+# - format source tree according to OpenSSL coding style using indent
+#
+# usage:
+# openssl-format-source [-v] [-n] [file|directory] ...
+#
+# note: the indent options assume GNU indent v2.2.10 which was released
+# Feb-2009 so if you have an older indent the options may not
+# match what is expected
+#
+# any marked block comment blocks have to be moved to align manually after
+# the reformatting has been completed as marking a block causes indent to
+# not move it at all ...
+#
+
+PATH=/usr/local/bin:/bin:/usr/bin:$PATH
+export PATH
+HERE="`dirname $0`"
+
+set -e
+
+INDENT=indent
+uname -s | grep BSD > /dev/null && type gindent > /dev/null 2>&1 && INDENT=gindent
+
+if [ $# -eq 0 ]; then
+ echo "usage: $0 [-v] [-n] [-c] [sourcefile|sourcedir] ..." >&2
+ exit 1
+fi
+
+VERBOSE=false
+DONT=false
+STOPARGS=false
+COMMENTS=false
+CHANGED=false
+DEBUG=""
+
+# for this exercise, we want to force the openssl style, so we roll
+# our own indent profile, which is at a well known location
+INDENT_PROFILE="$HERE/indent.pro"
+export INDENT_PROFILE
+if [ ! -f "$INDENT_PROFILE" ]; then
+ echo "$0: unable to locate the openssl indent.pro file" >&2
+ exit 1
+fi
+
+# Extra arguments; for adding the comment-formatting
+INDENT_ARGS=""
+for i
+do
+ if [ "$STOPARGS" != "true" ]; then
+ case $i in
+ --) STOPARGS="true"; continue;;
+ -n) DONT="true"; continue;;
+ -v) VERBOSE="true";
+ echo "INDENT_PROFILE=$INDENT_PROFILE";
+ continue;;
+ -c) COMMENTS="true";
+ INDENT_ARGS="-fc1 -fca -cdb -sc";
+ continue;;
+ -nc) COMMENTS="true";
+ continue;;
+ -d) DEBUG='eval tee "$j.pre" |'
+ continue;;
+ esac
+ fi
+
+ if [ -d "$i" ]; then
+ LIST=`find "$i" -name '*.[ch]' -print`
+ else
+ if [ ! -f "$i" ]; then
+ echo "$0: source file not found: $i" >&2
+ exit 1
+ fi
+ LIST="$i"
+ fi
+
+ for j in $LIST
+ do
+ # ignore symlinks - we only ever process the base file - so if we
+ # expand a directory tree we need to ignore any located symlinks
+ if [ -d "$i" ]; then
+ if [ -h "$j" ]; then
+ continue;
+ fi
+ fi
+
+ if [ "$DONT" = "false" ]; then
+ tmp=$(mktemp /tmp/indent.XXXXXX)
+ trap 'rm -f "$tmp"' HUP INT TERM EXIT
+
+ case `basename $j` in
+ # the list of files that indent is unable to handle correctly
+ # that we simply leave alone for manual formatting now
+ obj_dat.h|aes_core.c|aes_x86core.c|ecp_nistz256.c)
+ echo "skipping $j"
+ ;;
+ *)
+ if [ "$COMMENTS" = "true" ]; then
+ # we have to mark single line comments as /*- ...*/ to stop indent
+ # messing with them, run expand then indent as usual but with the
+ # the process-comments options and then undo that marking, and then
+ # finally re-run indent without process-comments so the marked-to-
+ # be-ignored comments we did automatically end up getting moved
+ # into the right possition within the code as indent leaves marked
+ # comments entirely untouched - we appear to have no way to avoid
+ # the double processing and get the desired output
+ cat "$j" | \
+ expand | \
+ perl -0 -np \
+ -e 's/(\n#[ \t]*ifdef[ \t]+__cplusplus\n[^\n]*\n#[ \t]*endif\n)/\n\/**INDENT-OFF**\/$1\/**INDENT-ON**\/\n/g;' \
+ -e 's/(\n\/\*\!)/\n\/**/g;' \
+ -e 's/(STACK_OF|LHASH_OF)\(([^ \t,\)]+)\)( |\n)/$1_$2_$3/g;' \
+ | \
+ perl -np \
+ -e 's/^([ \t]*)\/\*([ \t]+.*)\*\/[ \t]*$/my ($x1,$x2) = ($1, $2); if (length("$x1$x2")<75 && $x2 !~ m#^\s*\*INDENT-(ON|OFF)\*\s*$#) {$c="-"}else{$c=""}; "$x1\/*$c$x2*\/"/e;' \
+ -e 's/^\/\* ((Copyright|=|----).*)$/\/*-$1/;' \
+ -e 's/^((DECLARE|IMPLEMENT)_.*)$/\/**INDENT-OFF**\/\n$1\n\/**INDENT-ON**\//;' \
+ -e 's/^([ \t]*(make_dh|make_dh_bn|make_rfc5114_td)\(.*\)[ \t,]*)$/\/**INDENT-OFF**\/\n$1\n\/**INDENT-ON**\//;' \
+ -e 's/^(ASN1_ADB_TEMPLATE\(.*)$/\/**INDENT-OFF**\/\n$1\n\/**INDENT-ON**\//;' \
+ -e 's/^((ASN1|ADB)_.*_(end|END)\(.*[\){=,;]+[ \t]*)$/$1\n\/**INDENT-ON**\//;' \
+ -e '/ASN1_(ITEM_ref|ITEM_ptr|ITEM_rptr|PCTX)/ || s/^((ASN1|ADB)_[^\*]*[){=,]+[ \t]*)$/\/**INDENT-OFF**\/\n$1/;' \
+ -e 's/^(} (ASN1|ADB)_[^\*]*[\){=,;]+)$/$1\n\/**INDENT-ON**\//;' \
+ | \
+ $DEBUG $INDENT $INDENT_ARGS | \
+ perl -np \
+ -e 's/^([ \t]*)\/\*-(.*)\*\/[ \t]*$/$1\/*$2*\//;' \
+ -e 's/^\/\*-((Copyright|=|----).*)$/\/* $1/;' \
+ | $INDENT | \
+ perl -0 -np \
+ -e 's/\/\*\*INDENT-(ON|OFF)\*\*\/\n//g;' \
+ | perl -np \
+ -e 's/(STACK_OF|LHASH_OF)_([^ \t,]+)_( |\/)/$1($2)$3/g;' \
+ -e 's/(STACK_OF|LHASH_OF)_([^ \t,]+)_$/$1($2)/g;' \
+ | perl "$HERE"/su-filter.pl \
+ > "$tmp"
+ else
+ expand "$j" | $INDENT $INDENT_ARGS > "$tmp"
+ fi;
+ if cmp -s "$tmp" "$j"; then
+ if [ "$VERBOSE" = "true" ]; then
+ echo "$j unchanged"
+ fi
+ rm "$tmp"
+ else
+ if [ "$VERBOSE" = "true" ]; then
+ echo "$j changed"
+ fi
+ CHANGED=true
+ mv "$tmp" "$j"
+ fi
+ ;;
+ esac
+ fi
+ done
+done
+
+
+if [ "$VERBOSE" = "true" ]; then
+ echo
+ if [ "$CHANGED" = "true" ]; then
+ echo "SOURCE WAS MODIFIED"
+ else
+ echo "SOURCE WAS NOT MODIFIED"
+ fi
+fi
diff --git a/openssl-1.1.0h/util/opensslwrap.sh b/openssl-1.1.0h/util/opensslwrap.sh
new file mode 100755
index 0000000..b27cbb8
--- /dev/null
+++ b/openssl-1.1.0h/util/opensslwrap.sh
@@ -0,0 +1,26 @@
+#!/bin/sh
+
+HERE="`echo $0 | sed -e 's|[^/]*$||'`"
+OPENSSL="${HERE}../apps/openssl"
+
+if [ -d "${HERE}../engines" -a "x$OPENSSL_ENGINES" = "x" ]; then
+ OPENSSL_ENGINES="${HERE}../engines"; export OPENSSL_ENGINES
+fi
+
+if [ -x "${OPENSSL}.exe" ]; then
+ # The original reason for this script existence is to work around
+ # certain caveats in run-time linker behaviour. On Windows platforms
+ # adjusting $PATH used to be sufficient, but with introduction of
+ # SafeDllSearchMode in XP/2003 the only way to get it right in
+ # *all* possible situations is to copy newly built .DLLs to apps/
+ # and test/, which is now done elsewhere... The $PATH is adjusted
+ # for backward compatibility (and nostagical reasons:-).
+ if [ "$OSTYPE" != msdosdjgpp ]; then
+ PATH="${HERE}..:$PATH"; export PATH
+ fi
+ exec "${OPENSSL}.exe" "$@"
+elif [ -x "${OPENSSL}" -a -x "${HERE}shlib_wrap.sh" ]; then
+ exec "${HERE}shlib_wrap.sh" "${OPENSSL}" "$@"
+else
+ exec "${OPENSSL}" "$@" # hope for the best...
+fi
diff --git a/openssl-1.1.0h/util/perl/OpenSSL/Glob.pm b/openssl-1.1.0h/util/perl/OpenSSL/Glob.pm
new file mode 100644
index 0000000..ec87da4
--- /dev/null
+++ b/openssl-1.1.0h/util/perl/OpenSSL/Glob.pm
@@ -0,0 +1,21 @@
+package OpenSSL::Glob;
+
+use strict;
+use warnings;
+
+use File::Glob;
+
+use Exporter;
+use vars qw($VERSION @ISA @EXPORT);
+
+$VERSION = '0.1';
+@ISA = qw(Exporter);
+@EXPORT = qw(glob);
+
+sub glob {
+ goto &File::Glob::bsd_glob if $^O ne "VMS";
+ goto &CORE::glob;
+}
+
+1;
+__END__
diff --git a/openssl-1.1.0h/util/perl/OpenSSL/Test.pm b/openssl-1.1.0h/util/perl/OpenSSL/Test.pm
new file mode 100644
index 0000000..5de7b58
--- /dev/null
+++ b/openssl-1.1.0h/util/perl/OpenSSL/Test.pm
@@ -0,0 +1,1051 @@
+# Copyright 2016-2018 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+package OpenSSL::Test;
+
+use strict;
+use warnings;
+
+use Test::More 0.96;
+
+use Exporter;
+use vars qw($VERSION @ISA @EXPORT @EXPORT_OK %EXPORT_TAGS);
+$VERSION = "0.8";
+@ISA = qw(Exporter);
+@EXPORT = (@Test::More::EXPORT, qw(setup indir app fuzz perlapp test perltest
+ run));
+@EXPORT_OK = (@Test::More::EXPORT_OK, qw(bldtop_dir bldtop_file
+ srctop_dir srctop_file
+ data_file
+ pipe with cmdstr quotify));
+
+=head1 NAME
+
+OpenSSL::Test - a private extension of Test::More
+
+=head1 SYNOPSIS
+
+ use OpenSSL::Test;
+
+ setup("my_test_name");
+
+ ok(run(app(["openssl", "version"])), "check for openssl presence");
+
+ indir "subdir" => sub {
+ ok(run(test(["sometest", "arg1"], stdout => "foo.txt")),
+ "run sometest with output to foo.txt");
+ };
+
+=head1 DESCRIPTION
+
+This module is a private extension of L<Test::More> for testing OpenSSL.
+In addition to the Test::More functions, it also provides functions that
+easily find the diverse programs within a OpenSSL build tree, as well as
+some other useful functions.
+
+This module I<depends> on the environment variables C<$TOP> or C<$SRCTOP>
+and C<$BLDTOP>. Without one of the combinations it refuses to work.
+See L</ENVIRONMENT> below.
+
+With each test recipe, a parallel data directory with (almost) the same name
+as the recipe is possible in the source directory tree. For example, for a
+recipe C<$SRCTOP/test/recipes/99-foo.t>, there could be a directory
+C<$SRCTOP/test/recipes/99-foo_data/>.
+
+=cut
+
+use File::Copy;
+use File::Spec::Functions qw/file_name_is_absolute curdir canonpath splitdir
+ catdir catfile splitpath catpath devnull abs2rel
+ rel2abs/;
+use File::Path 2.00 qw/rmtree mkpath/;
+use File::Basename;
+
+
+# The name of the test. This is set by setup() and is used in the other
+# functions to verify that setup() has been used.
+my $test_name = undef;
+
+# Directories we want to keep track of TOP, APPS, TEST and RESULTS are the
+# ones we're interested in, corresponding to the environment variables TOP
+# (mandatory), BIN_D, TEST_D, UTIL_D and RESULT_D.
+my %directories = ();
+
+# The environment variables that gave us the contents in %directories. These
+# get modified whenever we change directories, so that subprocesses can use
+# the values of those environment variables as well
+my @direnv = ();
+
+# A bool saying if we shall stop all testing if the current recipe has failing
+# tests or not. This is set by setup() if the environment variable STOPTEST
+# is defined with a non-empty value.
+my $end_with_bailout = 0;
+
+# A set of hooks that is affected by with() and may be used in diverse places.
+# All hooks are expected to be CODE references.
+my %hooks = (
+
+ # exit_checker is used by run() directly after completion of a command.
+ # it receives the exit code from that command and is expected to return
+ # 1 (for success) or 0 (for failure). This is the value that will be
+ # returned by run().
+ # NOTE: When run() gets the option 'capture => 1', this hook is ignored.
+ exit_checker => sub { return shift == 0 ? 1 : 0 },
+
+ );
+
+# Debug flag, to be set manually when needed
+my $debug = 0;
+
+# Declare some utility functions that are defined at the end
+sub bldtop_file;
+sub bldtop_dir;
+sub srctop_file;
+sub srctop_dir;
+sub quotify;
+
+# Declare some private functions that are defined at the end
+sub __env;
+sub __cwd;
+sub __apps_file;
+sub __results_file;
+sub __fixup_cmd;
+sub __build_cmd;
+
+=head2 Main functions
+
+The following functions are exported by default when using C<OpenSSL::Test>.
+
+=cut
+
+=over 4
+
+=item B<setup "NAME">
+
+C<setup> is used for initial setup, and it is mandatory that it's used.
+If it's not used in a OpenSSL test recipe, the rest of the recipe will
+most likely refuse to run.
+
+C<setup> checks for environment variables (see L</ENVIRONMENT> below),
+checks that C<$TOP/Configure> or C<$SRCTOP/Configure> exists, C<chdir>
+into the results directory (defined by the C<$RESULT_D> environment
+variable if defined, otherwise C<$BLDTOP/test> or C<$TOP/test>, whichever
+is defined).
+
+=back
+
+=cut
+
+sub setup {
+ my $old_test_name = $test_name;
+ $test_name = shift;
+
+ BAIL_OUT("setup() must receive a name") unless $test_name;
+ warn "setup() detected test name change. Innocuous, so we continue...\n"
+ if $old_test_name && $old_test_name ne $test_name;
+
+ return if $old_test_name;
+
+ BAIL_OUT("setup() needs \$TOP or \$SRCTOP and \$BLDTOP to be defined")
+ unless $ENV{TOP} || ($ENV{SRCTOP} && $ENV{BLDTOP});
+ BAIL_OUT("setup() found both \$TOP and \$SRCTOP or \$BLDTOP...")
+ if $ENV{TOP} && ($ENV{SRCTOP} || $ENV{BLDTOP});
+
+ __env();
+
+ BAIL_OUT("setup() expects the file Configure in the source top directory")
+ unless -f srctop_file("Configure");
+
+ __cwd($directories{RESULTS});
+}
+
+=over 4
+
+=item B<indir "SUBDIR" =E<gt> sub BLOCK, OPTS>
+
+C<indir> is used to run a part of the recipe in a different directory than
+the one C<setup> moved into, usually a subdirectory, given by SUBDIR.
+The part of the recipe that's run there is given by the codeblock BLOCK.
+
+C<indir> takes some additional options OPTS that affect the subdirectory:
+
+=over 4
+
+=item B<create =E<gt> 0|1>
+
+When set to 1 (or any value that perl preceives as true), the subdirectory
+will be created if it doesn't already exist. This happens before BLOCK
+is executed.
+
+=item B<cleanup =E<gt> 0|1>
+
+When set to 1 (or any value that perl preceives as true), the subdirectory
+will be cleaned out and removed. This happens both before and after BLOCK
+is executed.
+
+=back
+
+An example:
+
+ indir "foo" => sub {
+ ok(run(app(["openssl", "version"]), stdout => "foo.txt"));
+ if (ok(open(RESULT, "foo.txt"), "reading foo.txt")) {
+ my $line = <RESULT>;
+ close RESULT;
+ is($line, qr/^OpenSSL 1\./,
+ "check that we're using OpenSSL 1.x.x");
+ }
+ }, create => 1, cleanup => 1;
+
+=back
+
+=cut
+
+sub indir {
+ my $subdir = shift;
+ my $codeblock = shift;
+ my %opts = @_;
+
+ my $reverse = __cwd($subdir,%opts);
+ BAIL_OUT("FAILURE: indir, \"$subdir\" wasn't possible to move into")
+ unless $reverse;
+
+ $codeblock->();
+
+ __cwd($reverse);
+
+ if ($opts{cleanup}) {
+ rmtree($subdir, { safe => 0 });
+ }
+}
+
+=over 4
+
+=item B<app ARRAYREF, OPTS>
+
+=item B<test ARRAYREF, OPTS>
+
+Both of these functions take a reference to a list that is a command and
+its arguments, and some additional options (described further on).
+
+C<app> expects to find the given command (the first item in the given list
+reference) as an executable in C<$BIN_D> (if defined, otherwise C<$TOP/apps>
+or C<$BLDTOP/apps>).
+
+C<test> expects to find the given command (the first item in the given list
+reference) as an executable in C<$TEST_D> (if defined, otherwise C<$TOP/test>
+or C<$BLDTOP/test>).
+
+Both return a CODEREF to be used by C<run>, C<pipe> or C<cmdstr>.
+
+The options that both C<app> and C<test> can take are in the form of hash
+values:
+
+=over 4
+
+=item B<stdin =E<gt> PATH>
+
+=item B<stdout =E<gt> PATH>
+
+=item B<stderr =E<gt> PATH>
+
+In all three cases, the corresponding standard input, output or error is
+redirected from (for stdin) or to (for the others) a file given by the
+string PATH, I<or>, if the value is C<undef>, C</dev/null> or similar.
+
+=back
+
+=item B<perlapp ARRAYREF, OPTS>
+
+=item B<perltest ARRAYREF, OPTS>
+
+Both these functions function the same way as B<app> and B<test>, except
+that they expect the command to be a perl script. Also, they support one
+more option:
+
+=over 4
+
+=item B<interpreter_args =E<gt> ARRAYref>
+
+The array reference is a set of arguments for perl rather than the script.
+Take care so that none of them can be seen as a script! Flags and their
+eventual arguments only!
+
+=back
+
+An example:
+
+ ok(run(perlapp(["foo.pl", "arg1"],
+ interpreter_args => [ "-I", srctop_dir("test") ])));
+
+=back
+
+=cut
+
+sub app {
+ my $cmd = shift;
+ my %opts = @_;
+ return sub { my $num = shift;
+ return __build_cmd($num, \&__apps_file, $cmd, %opts); }
+}
+
+sub fuzz {
+ my $cmd = shift;
+ my %opts = @_;
+ return sub { my $num = shift;
+ return __build_cmd($num, \&__fuzz_file, $cmd, %opts); }
+}
+
+sub test {
+ my $cmd = shift;
+ my %opts = @_;
+ return sub { my $num = shift;
+ return __build_cmd($num, \&__test_file, $cmd, %opts); }
+}
+
+sub perlapp {
+ my $cmd = shift;
+ my %opts = @_;
+ return sub { my $num = shift;
+ return __build_cmd($num, \&__perlapps_file, $cmd, %opts); }
+}
+
+sub perltest {
+ my $cmd = shift;
+ my %opts = @_;
+ return sub { my $num = shift;
+ return __build_cmd($num, \&__perltest_file, $cmd, %opts); }
+}
+
+=over 4
+
+=item B<run CODEREF, OPTS>
+
+This CODEREF is expected to be the value return by C<app> or C<test>,
+anything else will most likely cause an error unless you know what you're
+doing.
+
+C<run> executes the command returned by CODEREF and return either the
+resulting output (if the option C<capture> is set true) or a boolean indicating
+if the command succeeded or not.
+
+The options that C<run> can take are in the form of hash values:
+
+=over 4
+
+=item B<capture =E<gt> 0|1>
+
+If true, the command will be executed with a perl backtick, and C<run> will
+return the resulting output as an array of lines. If false or not given,
+the command will be executed with C<system()>, and C<run> will return 1 if
+the command was successful or 0 if it wasn't.
+
+=back
+
+For further discussion on what is considered a successful command or not, see
+the function C<with> further down.
+
+=back
+
+=cut
+
+sub run {
+ my ($cmd, $display_cmd) = shift->(0);
+ my %opts = @_;
+
+ return () if !$cmd;
+
+ my $prefix = "";
+ if ( $^O eq "VMS" ) { # VMS
+ $prefix = "pipe ";
+ }
+
+ my @r = ();
+ my $r = 0;
+ my $e = 0;
+
+ # In non-verbose, we want to shut up the command interpreter, in case
+ # it has something to complain about. On VMS, it might complain both
+ # on stdout and stderr
+ my $save_STDOUT;
+ my $save_STDERR;
+ if ($ENV{HARNESS_ACTIVE} && !$ENV{HARNESS_VERBOSE}) {
+ open $save_STDOUT, '>&', \*STDOUT or die "Can't dup STDOUT: $!";
+ open $save_STDERR, '>&', \*STDERR or die "Can't dup STDERR: $!";
+ open STDOUT, ">", devnull();
+ open STDERR, ">", devnull();
+ }
+
+ # The dance we do with $? is the same dance the Unix shells appear to
+ # do. For example, a program that gets aborted (and therefore signals
+ # SIGABRT = 6) will appear to exit with the code 134. We mimic this
+ # to make it easier to compare with a manual run of the command.
+ if ($opts{capture}) {
+ @r = `$prefix$cmd`;
+ $e = ($? & 0x7f) ? ($? & 0x7f)|0x80 : ($? >> 8);
+ } else {
+ system("$prefix$cmd");
+ $e = ($? & 0x7f) ? ($? & 0x7f)|0x80 : ($? >> 8);
+ $r = $hooks{exit_checker}->($e);
+ }
+
+ if ($ENV{HARNESS_ACTIVE} && !$ENV{HARNESS_VERBOSE}) {
+ close STDOUT;
+ close STDERR;
+ open STDOUT, '>&', $save_STDOUT or die "Can't restore STDOUT: $!";
+ open STDERR, '>&', $save_STDERR or die "Can't restore STDERR: $!";
+ }
+
+ print STDERR "$prefix$display_cmd => $e\n"
+ if !$ENV{HARNESS_ACTIVE} || $ENV{HARNESS_VERBOSE};
+
+ # At this point, $? stops being interesting, and unfortunately,
+ # there are Test::More versions that get picky if we leave it
+ # non-zero.
+ $? = 0;
+
+ if ($opts{capture}) {
+ return @r;
+ } else {
+ return $r;
+ }
+}
+
+END {
+ my $tb = Test::More->builder;
+ my $failure = scalar(grep { $_ == 0; } $tb->summary);
+ if ($failure && $end_with_bailout) {
+ BAIL_OUT("Stoptest!");
+ }
+}
+
+=head2 Utility functions
+
+The following functions are exported on request when using C<OpenSSL::Test>.
+
+ # To only get the bldtop_file and srctop_file functions.
+ use OpenSSL::Test qw/bldtop_file srctop_file/;
+
+ # To only get the bldtop_file function in addition to the default ones.
+ use OpenSSL::Test qw/:DEFAULT bldtop_file/;
+
+=cut
+
+# Utility functions, exported on request
+
+=over 4
+
+=item B<bldtop_dir LIST>
+
+LIST is a list of directories that make up a path from the top of the OpenSSL
+build directory (as indicated by the environment variable C<$TOP> or
+C<$BLDTOP>).
+C<bldtop_dir> returns the resulting directory as a string, adapted to the local
+operating system.
+
+=back
+
+=cut
+
+sub bldtop_dir {
+ return __bldtop_dir(@_); # This caters for operating systems that have
+ # a very distinct syntax for directories.
+}
+
+=over 4
+
+=item B<bldtop_file LIST, FILENAME>
+
+LIST is a list of directories that make up a path from the top of the OpenSSL
+build directory (as indicated by the environment variable C<$TOP> or
+C<$BLDTOP>) and FILENAME is the name of a file located in that directory path.
+C<bldtop_file> returns the resulting file path as a string, adapted to the local
+operating system.
+
+=back
+
+=cut
+
+sub bldtop_file {
+ return __bldtop_file(@_);
+}
+
+=over 4
+
+=item B<srctop_dir LIST>
+
+LIST is a list of directories that make up a path from the top of the OpenSSL
+source directory (as indicated by the environment variable C<$TOP> or
+C<$SRCTOP>).
+C<srctop_dir> returns the resulting directory as a string, adapted to the local
+operating system.
+
+=back
+
+=cut
+
+sub srctop_dir {
+ return __srctop_dir(@_); # This caters for operating systems that have
+ # a very distinct syntax for directories.
+}
+
+=over 4
+
+=item B<srctop_file LIST, FILENAME>
+
+LIST is a list of directories that make up a path from the top of the OpenSSL
+source directory (as indicated by the environment variable C<$TOP> or
+C<$SRCTOP>) and FILENAME is the name of a file located in that directory path.
+C<srctop_file> returns the resulting file path as a string, adapted to the local
+operating system.
+
+=back
+
+=cut
+
+sub srctop_file {
+ return __srctop_file(@_);
+}
+
+=over 4
+
+=item B<data_file LIST, FILENAME>
+
+LIST is a list of directories that make up a path from the data directory
+associated with the test (see L</DESCRIPTION> above) and FILENAME is the name
+of a file located in that directory path. C<data_file> returns the resulting
+file path as a string, adapted to the local operating system.
+
+=back
+
+=cut
+
+sub data_file {
+ return __data_file(@_);
+}
+
+=over 4
+
+=item B<pipe LIST>
+
+LIST is a list of CODEREFs returned by C<app> or C<test>, from which C<pipe>
+creates a new command composed of all the given commands put together in a
+pipe. C<pipe> returns a new CODEREF in the same manner as C<app> or C<test>,
+to be passed to C<run> for execution.
+
+=back
+
+=cut
+
+sub pipe {
+ my @cmds = @_;
+ return
+ sub {
+ my @cs = ();
+ my @dcs = ();
+ my @els = ();
+ my $counter = 0;
+ foreach (@cmds) {
+ my ($c, $dc, @el) = $_->(++$counter);
+
+ return () if !$c;
+
+ push @cs, $c;
+ push @dcs, $dc;
+ push @els, @el;
+ }
+ return (
+ join(" | ", @cs),
+ join(" | ", @dcs),
+ @els
+ );
+ };
+}
+
+=over 4
+
+=item B<with HASHREF, CODEREF>
+
+C<with> will temporarly install hooks given by the HASHREF and then execute
+the given CODEREF. Hooks are usually expected to have a coderef as value.
+
+The currently available hoosk are:
+
+=over 4
+
+=item B<exit_checker =E<gt> CODEREF>
+
+This hook is executed after C<run> has performed its given command. The
+CODEREF receives the exit code as only argument and is expected to return
+1 (if the exit code indicated success) or 0 (if the exit code indicated
+failure).
+
+=back
+
+=back
+
+=cut
+
+sub with {
+ my $opts = shift;
+ my %opts = %{$opts};
+ my $codeblock = shift;
+
+ my %saved_hooks = ();
+
+ foreach (keys %opts) {
+ $saved_hooks{$_} = $hooks{$_} if exists($hooks{$_});
+ $hooks{$_} = $opts{$_};
+ }
+
+ $codeblock->();
+
+ foreach (keys %saved_hooks) {
+ $hooks{$_} = $saved_hooks{$_};
+ }
+}
+
+=over 4
+
+=item B<cmdstr CODEREF, OPTS>
+
+C<cmdstr> takes a CODEREF from C<app> or C<test> and simply returns the
+command as a string.
+
+C<cmdstr> takes some additiona options OPTS that affect the string returned:
+
+=over 4
+
+=item B<display =E<gt> 0|1>
+
+When set to 0, the returned string will be with all decorations, such as a
+possible redirect of stderr to the null device. This is suitable if the
+string is to be used directly in a recipe.
+
+When set to 1, the returned string will be without extra decorations. This
+is suitable for display if that is desired (doesn't confuse people with all
+internal stuff), or if it's used to pass a command down to a subprocess.
+
+Default: 0
+
+=back
+
+=back
+
+=cut
+
+sub cmdstr {
+ my ($cmd, $display_cmd) = shift->(0);
+ my %opts = @_;
+
+ if ($opts{display}) {
+ return $display_cmd;
+ } else {
+ return $cmd;
+ }
+}
+
+=over 4
+
+=item B<quotify LIST>
+
+LIST is a list of strings that are going to be used as arguments for a
+command, and makes sure to inject quotes and escapes as necessary depending
+on the content of each string.
+
+This can also be used to put quotes around the executable of a command.
+I<This must never ever be done on VMS.>
+
+=back
+
+=cut
+
+sub quotify {
+ # Unix setup (default if nothing else is mentioned)
+ my $arg_formatter =
+ sub { $_ = shift;
+ ($_ eq '' || /\s|[\{\}\\\$\[\]\*\?\|\&:;<>]/) ? "'$_'" : $_ };
+
+ if ( $^O eq "VMS") { # VMS setup
+ $arg_formatter = sub {
+ $_ = shift;
+ if ($_ eq '' || /\s|["[:upper:]]/) {
+ s/"/""/g;
+ '"'.$_.'"';
+ } else {
+ $_;
+ }
+ };
+ } elsif ( $^O eq "MSWin32") { # MSWin setup
+ $arg_formatter = sub {
+ $_ = shift;
+ if ($_ eq '' || /\s|["\|\&\*\;<>]/) {
+ s/(["\\])/\\$1/g;
+ '"'.$_.'"';
+ } else {
+ $_;
+ }
+ };
+ }
+
+ return map { $arg_formatter->($_) } @_;
+}
+
+######################################################################
+# private functions. These are never exported.
+
+=head1 ENVIRONMENT
+
+OpenSSL::Test depends on some environment variables.
+
+=over 4
+
+=item B<TOP>
+
+This environment variable is mandatory. C<setup> will check that it's
+defined and that it's a directory that contains the file C<Configure>.
+If this isn't so, C<setup> will C<BAIL_OUT>.
+
+=item B<BIN_D>
+
+If defined, its value should be the directory where the openssl application
+is located. Defaults to C<$TOP/apps> (adapted to the operating system).
+
+=item B<TEST_D>
+
+If defined, its value should be the directory where the test applications
+are located. Defaults to C<$TOP/test> (adapted to the operating system).
+
+=item B<STOPTEST>
+
+If defined, it puts testing in a different mode, where a recipe with
+failures will result in a C<BAIL_OUT> at the end of its run.
+
+=back
+
+=cut
+
+sub __env {
+ (my $recipe_datadir = basename($0)) =~ s/\.t$/_data/i;
+
+ $directories{SRCTOP} = $ENV{SRCTOP} || $ENV{TOP};
+ $directories{BLDTOP} = $ENV{BLDTOP} || $ENV{TOP};
+ $directories{BLDAPPS} = $ENV{BIN_D} || __bldtop_dir("apps");
+ $directories{SRCAPPS} = __srctop_dir("apps");
+ $directories{BLDFUZZ} = __bldtop_dir("fuzz");
+ $directories{SRCFUZZ} = __srctop_dir("fuzz");
+ $directories{BLDTEST} = $ENV{TEST_D} || __bldtop_dir("test");
+ $directories{SRCTEST} = __srctop_dir("test");
+ $directories{SRCDATA} = __srctop_dir("test", "recipes",
+ $recipe_datadir);
+ $directories{RESULTS} = $ENV{RESULT_D} || $directories{BLDTEST};
+
+ push @direnv, "TOP" if $ENV{TOP};
+ push @direnv, "SRCTOP" if $ENV{SRCTOP};
+ push @direnv, "BLDTOP" if $ENV{BLDTOP};
+ push @direnv, "BIN_D" if $ENV{BIN_D};
+ push @direnv, "TEST_D" if $ENV{TEST_D};
+ push @direnv, "RESULT_D" if $ENV{RESULT_D};
+
+ $end_with_bailout = $ENV{STOPTEST} ? 1 : 0;
+};
+
+sub __srctop_file {
+ BAIL_OUT("Must run setup() first") if (! $test_name);
+
+ my $f = pop;
+ return catfile($directories{SRCTOP},@_,$f);
+}
+
+sub __srctop_dir {
+ BAIL_OUT("Must run setup() first") if (! $test_name);
+
+ return catdir($directories{SRCTOP},@_);
+}
+
+sub __bldtop_file {
+ BAIL_OUT("Must run setup() first") if (! $test_name);
+
+ my $f = pop;
+ return catfile($directories{BLDTOP},@_,$f);
+}
+
+sub __bldtop_dir {
+ BAIL_OUT("Must run setup() first") if (! $test_name);
+
+ return catdir($directories{BLDTOP},@_);
+}
+
+sub __exeext {
+ my $ext = "";
+ if ($^O eq "VMS" ) { # VMS
+ $ext = ".exe";
+ } elsif ($^O eq "MSWin32") { # Windows
+ $ext = ".exe";
+ }
+ return $ENV{"EXE_EXT"} || $ext;
+}
+
+sub __test_file {
+ BAIL_OUT("Must run setup() first") if (! $test_name);
+
+ my $f = pop;
+ my $out = catfile($directories{BLDTEST},@_,$f . __exeext());
+ $out = catfile($directories{SRCTEST},@_,$f) unless -x $out;
+ return $out;
+}
+
+sub __perltest_file {
+ BAIL_OUT("Must run setup() first") if (! $test_name);
+
+ my $f = pop;
+ my $out = catfile($directories{BLDTEST},@_,$f);
+ $out = catfile($directories{SRCTEST},@_,$f) unless -f $out;
+ return ($^X, $out);
+}
+
+sub __apps_file {
+ BAIL_OUT("Must run setup() first") if (! $test_name);
+
+ my $f = pop;
+ my $out = catfile($directories{BLDAPPS},@_,$f . __exeext());
+ $out = catfile($directories{SRCAPPS},@_,$f) unless -x $out;
+ return $out;
+}
+
+sub __fuzz_file {
+ BAIL_OUT("Must run setup() first") if (! $test_name);
+
+ my $f = pop;
+ my $out = catfile($directories{BLDFUZZ},@_,$f . __exeext());
+ $out = catfile($directories{SRCFUZZ},@_,$f) unless -x $out;
+ return $out;
+}
+
+sub __perlapps_file {
+ BAIL_OUT("Must run setup() first") if (! $test_name);
+
+ my $f = pop;
+ my $out = catfile($directories{BLDAPPS},@_,$f);
+ $out = catfile($directories{SRCAPPS},@_,$f) unless -f $out;
+ return ($^X, $out);
+}
+
+sub __data_file {
+ BAIL_OUT("Must run setup() first") if (! $test_name);
+
+ my $f = pop;
+ return catfile($directories{SRCDATA},@_,$f);
+}
+
+sub __results_file {
+ BAIL_OUT("Must run setup() first") if (! $test_name);
+
+ my $f = pop;
+ return catfile($directories{RESULTS},@_,$f);
+}
+
+sub __cwd {
+ my $dir = catdir(shift);
+ my %opts = @_;
+ my $abscurdir = rel2abs(curdir());
+ my $absdir = rel2abs($dir);
+ my $reverse = abs2rel($abscurdir, $absdir);
+
+ # PARANOIA: if we're not moving anywhere, we do nothing more
+ if ($abscurdir eq $absdir) {
+ return $reverse;
+ }
+
+ # Do not support a move to a different volume for now. Maybe later.
+ BAIL_OUT("FAILURE: \"$dir\" moves to a different volume, not supported")
+ if $reverse eq $abscurdir;
+
+ # If someone happened to give a directory that leads back to the current,
+ # it's extremely silly to do anything more, so just simulate that we did
+ # move.
+ # In this case, we won't even clean it out, for safety's sake.
+ return "." if $reverse eq "";
+
+ $dir = canonpath($dir);
+ if ($opts{create}) {
+ mkpath($dir);
+ }
+
+ # We are recalculating the directories we keep track of, but need to save
+ # away the result for after having moved into the new directory.
+ my %tmp_directories = ();
+ my %tmp_ENV = ();
+
+ # For each of these directory variables, figure out where they are relative
+ # to the directory we want to move to if they aren't absolute (if they are,
+ # they don't change!)
+ my @dirtags = sort keys %directories;
+ foreach (@dirtags) {
+ if (!file_name_is_absolute($directories{$_})) {
+ my $newpath = abs2rel(rel2abs($directories{$_}), rel2abs($dir));
+ $tmp_directories{$_} = $newpath;
+ }
+ }
+
+ # Treat each environment variable that was used to get us the values in
+ # %directories the same was as the paths in %directories, so any sub
+ # process can use their values properly as well
+ foreach (@direnv) {
+ if (!file_name_is_absolute($ENV{$_})) {
+ my $newpath = abs2rel(rel2abs($ENV{$_}), rel2abs($dir));
+ $tmp_ENV{$_} = $newpath;
+ }
+ }
+
+ # Should we just bail out here as well? I'm unsure.
+ return undef unless chdir($dir);
+
+ if ($opts{cleanup}) {
+ rmtree(".", { safe => 0, keep_root => 1 });
+ }
+
+ # We put back new values carefully. Doing the obvious
+ # %directories = ( %tmp_irectories )
+ # will clear out any value that happens to be an absolute path
+ foreach (keys %tmp_directories) {
+ $directories{$_} = $tmp_directories{$_};
+ }
+ foreach (keys %tmp_ENV) {
+ $ENV{$_} = $tmp_ENV{$_};
+ }
+
+ if ($debug) {
+ print STDERR "DEBUG: __cwd(), directories and files:\n";
+ print STDERR " \$directories{BLDTEST} = \"$directories{BLDTEST}\"\n";
+ print STDERR " \$directories{SRCTEST} = \"$directories{SRCTEST}\"\n";
+ print STDERR " \$directories{SRCDATA} = \"$directories{SRCDATA}\"\n";
+ print STDERR " \$directories{RESULTS} = \"$directories{RESULTS}\"\n";
+ print STDERR " \$directories{BLDAPPS} = \"$directories{BLDAPPS}\"\n";
+ print STDERR " \$directories{SRCAPPS} = \"$directories{SRCAPPS}\"\n";
+ print STDERR " \$directories{SRCTOP} = \"$directories{SRCTOP}\"\n";
+ print STDERR " \$directories{BLDTOP} = \"$directories{BLDTOP}\"\n";
+ print STDERR "\n";
+ print STDERR " current directory is \"",curdir(),"\"\n";
+ print STDERR " the way back is \"$reverse\"\n";
+ }
+
+ return $reverse;
+}
+
+sub __fixup_cmd {
+ my $prog = shift;
+ my $exe_shell = shift;
+
+ my $prefix = __bldtop_file("util", "shlib_wrap.sh")." ";
+
+ if (defined($exe_shell)) {
+ $prefix = "$exe_shell ";
+ } elsif ($^O eq "VMS" ) { # VMS
+ $prefix = ($prog =~ /^(?:[\$a-z0-9_]+:)?[<\[]/i ? "mcr " : "mcr []");
+ } elsif ($^O eq "MSWin32") { # Windows
+ $prefix = "";
+ }
+
+ # We test both with and without extension. The reason
+ # is that we might be passed a complete file spec, with
+ # extension.
+ if ( ! -x $prog ) {
+ my $prog = "$prog";
+ if ( ! -x $prog ) {
+ $prog = undef;
+ }
+ }
+
+ if (defined($prog)) {
+ # Make sure to quotify the program file on platforms that may
+ # have spaces or similar in their path name.
+ # To our knowledge, VMS is the exception where quotifying should
+ # never happen.
+ ($prog) = quotify($prog) unless $^O eq "VMS";
+ return $prefix.$prog;
+ }
+
+ print STDERR "$prog not found\n";
+ return undef;
+}
+
+sub __build_cmd {
+ BAIL_OUT("Must run setup() first") if (! $test_name);
+
+ my $num = shift;
+ my $path_builder = shift;
+ # Make a copy to not destroy the caller's array
+ my @cmdarray = ( @{$_[0]} ); shift;
+ my %opts = @_;
+
+ # We do a little dance, as $path_builder might return a list of
+ # more than one. If so, only the first is to be considered a
+ # program to fix up, the rest is part of the arguments. This
+ # happens for perl scripts, where $path_builder will return
+ # a list of two, $^X and the script name.
+ # Also, if $path_builder returned more than one, we don't apply
+ # the EXE_SHELL environment variable.
+ my @prog = ($path_builder->(shift @cmdarray));
+ my $first = shift @prog;
+ my $exe_shell = @prog ? undef : $ENV{EXE_SHELL};
+ my $cmd = __fixup_cmd($first, $exe_shell);
+ if (@prog) {
+ if ( ! -f $prog[0] ) {
+ print STDERR "$prog[0] not found\n";
+ $cmd = undef;
+ }
+ }
+ my @args = (@prog, @cmdarray);
+ if (defined($opts{interpreter_args})) {
+ unshift @args, @{$opts{interpreter_args}};
+ }
+
+ return () if !$cmd;
+
+ my $arg_str = "";
+ my $null = devnull();
+
+
+ $arg_str = " ".join(" ", quotify @args) if @args;
+
+ my $fileornull = sub { $_[0] ? $_[0] : $null; };
+ my $stdin = "";
+ my $stdout = "";
+ my $stderr = "";
+ my $saved_stderr = undef;
+ $stdin = " < ".$fileornull->($opts{stdin}) if exists($opts{stdin});
+ $stdout= " > ".$fileornull->($opts{stdout}) if exists($opts{stdout});
+ $stderr=" 2> ".$fileornull->($opts{stderr}) if exists($opts{stderr});
+
+ my $display_cmd = "$cmd$arg_str$stdin$stdout$stderr";
+
+ $stderr=" 2> ".$null
+ unless $stderr || !$ENV{HARNESS_ACTIVE} || $ENV{HARNESS_VERBOSE};
+
+ $cmd .= "$arg_str$stdin$stdout$stderr";
+
+ if ($debug) {
+ print STDERR "DEBUG[__build_cmd]: \$cmd = \"$cmd\"\n";
+ print STDERR "DEBUG[__build_cmd]: \$display_cmd = \"$display_cmd\"\n";
+ }
+
+ return ($cmd, $display_cmd);
+}
+
+=head1 SEE ALSO
+
+L<Test::More>, L<Test::Harness>
+
+=head1 AUTHORS
+
+Richard Levitte E<lt>levitte@openssl.orgE<gt> with assitance and
+inspiration from Andy Polyakov E<lt>appro@openssl.org<gt>.
+
+=cut
+
+1;
diff --git a/openssl-1.1.0h/util/perl/OpenSSL/Test/Simple.pm b/openssl-1.1.0h/util/perl/OpenSSL/Test/Simple.pm
new file mode 100644
index 0000000..c5a84d5
--- /dev/null
+++ b/openssl-1.1.0h/util/perl/OpenSSL/Test/Simple.pm
@@ -0,0 +1,91 @@
+# Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+package OpenSSL::Test::Simple;
+
+use strict;
+use warnings;
+
+use Exporter;
+use vars qw($VERSION @ISA @EXPORT @EXPORT_OK %EXPORT_TAGS);
+$VERSION = "0.2";
+@ISA = qw(Exporter);
+@EXPORT = qw(simple_test);
+
+=head1 NAME
+
+OpenSSL::Test::Simple - a few very simple test functions
+
+=head1 SYNOPSIS
+
+ use OpenSSL::Test::Simple;
+
+ simple_test("my_test_name", "destest", "des");
+
+=head1 DESCRIPTION
+
+Sometimes, the functions in L<OpenSSL::Test> are quite tedious for some
+repetitive tasks. This module provides functions to make life easier.
+You could call them hacks if you wish.
+
+=cut
+
+use OpenSSL::Test;
+use OpenSSL::Test::Utils;
+
+=over 4
+
+=item B<simple_test NAME, PROGRAM, ALGORITHM>
+
+Runs a test named NAME, running the program PROGRAM with no arguments,
+to test the algorithm ALGORITHM.
+
+A complete recipe looks like this:
+
+ use OpenSSL::Test::Simple;
+
+ simple_test("test_bf", "bftest", "bf");
+
+=back
+
+=cut
+
+# args:
+# name (used with setup())
+# algorithm (used to check if it's at all supported)
+# name of binary (the program that does the actual test)
+sub simple_test {
+ my ($name, $prgr, @algos) = @_;
+
+ setup($name);
+
+ if (scalar(disabled(@algos))) {
+ if (scalar(@algos) == 1) {
+ plan skip_all => $algos[0]." is not supported by this OpenSSL build";
+ } else {
+ my $last = pop @algos;
+ plan skip_all => join(", ", @algos)." and $last are not supported by this OpenSSL build";
+ }
+ }
+
+ plan tests => 1;
+
+ ok(run(test([$prgr])), "running $prgr");
+}
+
+=head1 SEE ALSO
+
+L<OpenSSL::Test>
+
+=head1 AUTHORS
+
+Richard Levitte E<lt>levitte@openssl.orgE<gt> with inspiration
+from Rich Salz E<lt>rsalz@openssl.orgE<gt>.
+
+=cut
+
+1;
diff --git a/openssl-1.1.0h/util/perl/OpenSSL/Test/Utils.pm b/openssl-1.1.0h/util/perl/OpenSSL/Test/Utils.pm
new file mode 100644
index 0000000..7b0a705
--- /dev/null
+++ b/openssl-1.1.0h/util/perl/OpenSSL/Test/Utils.pm
@@ -0,0 +1,240 @@
+# Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+package OpenSSL::Test::Utils;
+
+use strict;
+use warnings;
+
+use Exporter;
+use vars qw($VERSION @ISA @EXPORT @EXPORT_OK %EXPORT_TAGS);
+$VERSION = "0.1";
+@ISA = qw(Exporter);
+@EXPORT = qw(alldisabled anydisabled disabled config available_protocols
+ have_IPv4 have_IPv6);
+
+=head1 NAME
+
+OpenSSL::Test::Utils - test utility functions
+
+=head1 SYNOPSIS
+
+ use OpenSSL::Test::Utils;
+
+ my @tls = available_protocols("tls");
+ my @dtls = available_protocols("dtls");
+ alldisabled("dh", "dsa");
+ anydisabled("dh", "dsa");
+
+ config("fips");
+
+ have_IPv4();
+ have_IPv6();
+
+=head1 DESCRIPTION
+
+This module provides utility functions for the testing framework.
+
+=cut
+
+use OpenSSL::Test qw/:DEFAULT bldtop_file/;
+
+=over 4
+
+=item B<available_protocols STRING>
+
+Returns a list of strings for all the available SSL/TLS versions if
+STRING is "tls", or for all the available DTLS versions if STRING is
+"dtls". Otherwise, it returns the empty list. The strings in the
+returned list can be used with B<alldisabled> and B<anydisabled>.
+
+=item B<alldisabled ARRAY>
+=item B<anydisabled ARRAY>
+
+In an array context returns an array with each element set to 1 if the
+corresponding feature is disabled and 0 otherwise.
+
+In a scalar context, alldisabled returns 1 if all of the features in
+ARRAY are disabled, while anydisabled returns 1 if any of them are
+disabled.
+
+=item B<config STRING>
+
+Returns an item from the %config hash in \$TOP/configdata.pm.
+
+=item B<have_IPv4>
+=item B<have_IPv6>
+
+Return true if IPv4 / IPv6 is possible to use on the current system.
+
+=back
+
+=cut
+
+our %available_protocols;
+our %disabled;
+our %config;
+my $configdata_loaded = 0;
+
+sub load_configdata {
+ # We eval it so it doesn't run at compile time of this file.
+ # The latter would have bldtop_file() complain that setup() hasn't
+ # been run yet.
+ my $configdata = bldtop_file("configdata.pm");
+ eval { require $configdata;
+ %available_protocols = %configdata::available_protocols;
+ %disabled = %configdata::disabled;
+ %config = %configdata::config;
+ };
+ $configdata_loaded = 1;
+}
+
+# args
+# list of 1s and 0s, coming from check_disabled()
+sub anyof {
+ my $x = 0;
+ foreach (@_) { $x += $_ }
+ return $x > 0;
+}
+
+# args
+# list of 1s and 0s, coming from check_disabled()
+sub allof {
+ my $x = 1;
+ foreach (@_) { $x *= $_ }
+ return $x > 0;
+}
+
+# args
+# list of strings, all of them should be names of features
+# that can be disabled.
+# returns a list of 1s (if the corresponding feature is disabled)
+# and 0s (if it isn't)
+sub check_disabled {
+ return map { exists $disabled{lc $_} ? 1 : 0 } @_;
+}
+
+# Exported functions #################################################
+
+# args:
+# list of features to check
+sub anydisabled {
+ load_configdata() unless $configdata_loaded;
+ my @ret = check_disabled(@_);
+ return @ret if wantarray;
+ return anyof(@ret);
+}
+
+# args:
+# list of features to check
+sub alldisabled {
+ load_configdata() unless $configdata_loaded;
+ my @ret = check_disabled(@_);
+ return @ret if wantarray;
+ return allof(@ret);
+}
+
+# !!! Kept for backward compatibility
+# args:
+# single string
+sub disabled {
+ anydisabled(@_);
+}
+
+sub available_protocols {
+ load_configdata() unless $configdata_loaded;
+ my $protocol_class = shift;
+ if (exists $available_protocols{lc $protocol_class}) {
+ return @{$available_protocols{lc $protocol_class}}
+ }
+ return ();
+}
+
+sub config {
+ load_configdata() unless $configdata_loaded;
+ return $config{$_[0]};
+}
+
+# IPv4 / IPv6 checker
+my $have_IPv4 = -1;
+my $have_IPv6 = -1;
+my $IP_factory;
+sub check_IP {
+ my $listenaddress = shift;
+
+ eval {
+ require IO::Socket::IP;
+ my $s = IO::Socket::IP->new(
+ LocalAddr => $listenaddress,
+ LocalPort => 0,
+ Listen=>1,
+ );
+ $s or die "\n";
+ $s->close();
+ };
+ if ($@ eq "") {
+ return 1;
+ }
+
+ eval {
+ require IO::Socket::INET6;
+ my $s = IO::Socket::INET6->new(
+ LocalAddr => $listenaddress,
+ LocalPort => 0,
+ Listen=>1,
+ );
+ $s or die "\n";
+ $s->close();
+ };
+ if ($@ eq "") {
+ return 1;
+ }
+
+ eval {
+ require IO::Socket::INET;
+ my $s = IO::Socket::INET->new(
+ LocalAddr => $listenaddress,
+ LocalPort => 0,
+ Listen=>1,
+ );
+ $s or die "\n";
+ $s->close();
+ };
+ if ($@ eq "") {
+ return 1;
+ }
+
+ return 0;
+}
+
+sub have_IPv4 {
+ if ($have_IPv4 < 0) {
+ $have_IPv4 = check_IP("127.0.0.1");
+ }
+ return $have_IPv4;
+}
+
+sub have_IPv6 {
+ if ($have_IPv6 < 0) {
+ $have_IPv6 = check_IP("::1");
+ }
+ return $have_IPv6;
+}
+
+
+=head1 SEE ALSO
+
+L<OpenSSL::Test>
+
+=head1 AUTHORS
+
+Stephen Henson E<lt>steve@openssl.orgE<gt> and
+Richard Levitte E<lt>levitte@openssl.orgE<gt>
+
+=cut
+
+1;
diff --git a/openssl-1.1.0h/util/perl/OpenSSL/Util/Pod.pm b/openssl-1.1.0h/util/perl/OpenSSL/Util/Pod.pm
new file mode 100644
index 0000000..5c0af95
--- /dev/null
+++ b/openssl-1.1.0h/util/perl/OpenSSL/Util/Pod.pm
@@ -0,0 +1,158 @@
+# Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+package OpenSSL::Util::Pod;
+
+use strict;
+use warnings;
+
+use Exporter;
+use vars qw($VERSION @ISA @EXPORT @EXPORT_OK %EXPORT_TAGS);
+$VERSION = "0.1";
+@ISA = qw(Exporter);
+@EXPORT = qw(extract_pod_info);
+@EXPORT_OK = qw();
+
+=head1 NAME
+
+OpenSSL::Util::Pod - utilities to manipulate .pod files
+
+=head1 SYNOPSIS
+
+ use OpenSSL::Util::Pod;
+
+ my %podinfo = extract_pod_info("foo.pod");
+
+ # or if the file is already opened... Note that this consumes the
+ # remainder of the file.
+
+ my %podinfo = extract_pod_info(\*STDIN);
+
+=head1 DESCRIPTION
+
+=over
+
+=item B<extract_pod_info "FILENAME", HASHREF>
+
+=item B<extract_pod_info "FILENAME">
+
+=item B<extract_pod_info GLOB, HASHREF>
+
+=item B<extract_pod_info GLOB>
+
+Extracts information from a .pod file, given a STRING (file name) or a
+GLOB (a file handle). The result is given back as a hash table.
+
+The additional hash is for extra parameters:
+
+=over
+
+=item B<section =E<gt> N>
+
+The value MUST be a number, and will be the default man section number
+to be used with the given .pod file. This number can be altered if
+the .pod file has a line like this:
+
+ =for comment openssl_manual_section: 4
+
+=item B<debug =E<gt> 0|1>
+
+If set to 1, extra debug text will be printed on STDERR
+
+=back
+
+=back
+
+=head1 RETURN VALUES
+
+=over
+
+=item B<extract_pod_info> returns a hash table with the following
+items:
+
+=over
+
+=item B<section =E<gt> N>
+
+The man section number this .pod file belongs to. Often the same as
+was given as input.
+
+=item B<names =E<gt> [ "name", ... ]>
+
+All the names extracted from the NAME section.
+
+=back
+
+=back
+
+=cut
+
+sub extract_pod_info {
+ my $input = shift;
+ my $defaults_ref = shift || {};
+ my %defaults = ( debug => 0, section => 0, %$defaults_ref );
+ my $fh = undef;
+ my $filename = undef;
+
+ # If not a file handle, then it's assume to be a file path (a string)
+ unless (ref $input eq "GLOB") {
+ $filename = $input;
+ open $fh, $input or die "Trying to read $filename: $!\n";
+ print STDERR "DEBUG: Reading $input\n" if $defaults{debug};
+ $input = $fh;
+ }
+
+ my %podinfo = ( section => $defaults{section});
+ while(<$input>) {
+ s|\R$||;
+ if (m|^=for\s+comment\s+openssl_manual_section:\s*([0-9])\s*$|) {
+ print STDERR "DEBUG: Found man section number $1\n"
+ if $defaults{debug};
+ $podinfo{section} = $1;
+ }
+
+ # Stop reading when we have reached past the NAME section.
+ last if (m|^=head1|
+ && defined $podinfo{lastsect}
+ && $podinfo{lastsect} eq "NAME");
+
+ # Collect the section name
+ if (m|^=head1\s*(.*)|) {
+ $podinfo{lastsect} = $1;
+ $podinfo{lastsect} =~ s/\s+$//;
+ print STDERR "DEBUG: Found new pod section $1\n"
+ if $defaults{debug};
+ print STDERR "DEBUG: Clearing pod section text\n"
+ if $defaults{debug};
+ $podinfo{lastsecttext} = "";
+ }
+
+ next if (m|^=| || m|^\s*$|);
+
+ # Collect the section text
+ print STDERR "DEBUG: accumulating pod section text \"$_\"\n"
+ if $defaults{debug};
+ $podinfo{lastsecttext} .= " " if $podinfo{lastsecttext};
+ $podinfo{lastsecttext} .= $_;
+ }
+
+
+ if (defined $fh) {
+ close $fh;
+ print STDERR "DEBUG: Done reading $filename\n" if $defaults{debug};
+ }
+
+ $podinfo{lastsecttext} =~ s| - .*$||;
+
+ my @names =
+ map { s|\s+||g; $_ }
+ split(m|,|, $podinfo{lastsecttext});
+
+ return ( section => $podinfo{section}, names => [ @names ] );
+}
+
+1;
diff --git a/openssl-1.1.0h/util/perl/TLSProxy/ClientHello.pm b/openssl-1.1.0h/util/perl/TLSProxy/ClientHello.pm
new file mode 100644
index 0000000..ec739d2
--- /dev/null
+++ b/openssl-1.1.0h/util/perl/TLSProxy/ClientHello.pm
@@ -0,0 +1,242 @@
+# Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+use strict;
+
+package TLSProxy::ClientHello;
+
+use vars '@ISA';
+push @ISA, 'TLSProxy::Message';
+
+sub new
+{
+ my $class = shift;
+ my ($server,
+ $data,
+ $records,
+ $startoffset,
+ $message_frag_lens) = @_;
+
+ my $self = $class->SUPER::new(
+ $server,
+ 1,
+ $data,
+ $records,
+ $startoffset,
+ $message_frag_lens);
+
+ $self->{client_version} = 0;
+ $self->{random} = [];
+ $self->{session_id_len} = 0;
+ $self->{session} = "";
+ $self->{ciphersuite_len} = 0;
+ $self->{ciphersuites} = [];
+ $self->{comp_meth_len} = 0;
+ $self->{comp_meths} = [];
+ $self->{extensions_len} = 0;
+ $self->{extension_data} = "";
+
+ return $self;
+}
+
+sub parse
+{
+ my $self = shift;
+ my $ptr = 2;
+ my ($client_version) = unpack('n', $self->data);
+ my $random = substr($self->data, $ptr, 32);
+ $ptr += 32;
+ my $session_id_len = unpack('C', substr($self->data, $ptr));
+ $ptr++;
+ my $session = substr($self->data, $ptr, $session_id_len);
+ $ptr += $session_id_len;
+ my $ciphersuite_len = unpack('n', substr($self->data, $ptr));
+ $ptr += 2;
+ my @ciphersuites = unpack('n*', substr($self->data, $ptr,
+ $ciphersuite_len));
+ $ptr += $ciphersuite_len;
+ my $comp_meth_len = unpack('C', substr($self->data, $ptr));
+ $ptr++;
+ my @comp_meths = unpack('C*', substr($self->data, $ptr, $comp_meth_len));
+ $ptr += $comp_meth_len;
+ my $extensions_len = unpack('n', substr($self->data, $ptr));
+ $ptr += 2;
+ #For now we just deal with this as a block of data. In the future we will
+ #want to parse this
+ my $extension_data = substr($self->data, $ptr);
+
+ if (length($extension_data) != $extensions_len) {
+ die "Invalid extension length\n";
+ }
+ my %extensions = ();
+ while (length($extension_data) >= 4) {
+ my ($type, $size) = unpack("nn", $extension_data);
+ my $extdata = substr($extension_data, 4, $size);
+ $extension_data = substr($extension_data, 4 + $size);
+ $extensions{$type} = $extdata;
+ }
+
+ $self->client_version($client_version);
+ $self->random($random);
+ $self->session_id_len($session_id_len);
+ $self->session($session);
+ $self->ciphersuite_len($ciphersuite_len);
+ $self->ciphersuites(\@ciphersuites);
+ $self->comp_meth_len($comp_meth_len);
+ $self->comp_meths(\@comp_meths);
+ $self->extensions_len($extensions_len);
+ $self->extension_data(\%extensions);
+
+ $self->process_extensions();
+
+ print " Client Version:".$client_version."\n";
+ print " Session ID Len:".$session_id_len."\n";
+ print " Ciphersuite len:".$ciphersuite_len."\n";
+ print " Compression Method Len:".$comp_meth_len."\n";
+ print " Extensions Len:".$extensions_len."\n";
+}
+
+#Perform any actions necessary based on the extensions we've seen
+sub process_extensions
+{
+ my $self = shift;
+ my %extensions = %{$self->extension_data};
+
+ #Clear any state from a previous run
+ TLSProxy::Record->etm(0);
+
+ if (exists $extensions{TLSProxy::Message::EXT_ENCRYPT_THEN_MAC}) {
+ TLSProxy::Record->etm(1);
+ }
+}
+
+#Reconstruct the on-the-wire message data following changes
+sub set_message_contents
+{
+ my $self = shift;
+ my $data;
+ my $extensions = "";
+
+ $data = pack('n', $self->client_version);
+ $data .= $self->random;
+ $data .= pack('C', $self->session_id_len);
+ $data .= $self->session;
+ $data .= pack('n', $self->ciphersuite_len);
+ $data .= pack("n*", @{$self->ciphersuites});
+ $data .= pack('C', $self->comp_meth_len);
+ $data .= pack("C*", @{$self->comp_meths});
+
+ foreach my $key (keys %{$self->extension_data}) {
+ my $extdata = ${$self->extension_data}{$key};
+ $extensions .= pack("n", $key);
+ $extensions .= pack("n", length($extdata));
+ $extensions .= $extdata;
+ if ($key == TLSProxy::Message::EXT_DUPLICATE_EXTENSION) {
+ $extensions .= pack("n", $key);
+ $extensions .= pack("n", length($extdata));
+ $extensions .= $extdata;
+ }
+ }
+
+ $data .= pack('n', length($extensions));
+ $data .= $extensions;
+
+ $self->data($data);
+}
+
+#Read/write accessors
+sub client_version
+{
+ my $self = shift;
+ if (@_) {
+ $self->{client_version} = shift;
+ }
+ return $self->{client_version};
+}
+sub random
+{
+ my $self = shift;
+ if (@_) {
+ $self->{random} = shift;
+ }
+ return $self->{random};
+}
+sub session_id_len
+{
+ my $self = shift;
+ if (@_) {
+ $self->{session_id_len} = shift;
+ }
+ return $self->{session_id_len};
+}
+sub session
+{
+ my $self = shift;
+ if (@_) {
+ $self->{session} = shift;
+ }
+ return $self->{session};
+}
+sub ciphersuite_len
+{
+ my $self = shift;
+ if (@_) {
+ $self->{ciphersuite_len} = shift;
+ }
+ return $self->{ciphersuite_len};
+}
+sub ciphersuites
+{
+ my $self = shift;
+ if (@_) {
+ $self->{ciphersuites} = shift;
+ }
+ return $self->{ciphersuites};
+}
+sub comp_meth_len
+{
+ my $self = shift;
+ if (@_) {
+ $self->{comp_meth_len} = shift;
+ }
+ return $self->{comp_meth_len};
+}
+sub comp_meths
+{
+ my $self = shift;
+ if (@_) {
+ $self->{comp_meths} = shift;
+ }
+ return $self->{comp_meths};
+}
+sub extensions_len
+{
+ my $self = shift;
+ if (@_) {
+ $self->{extensions_len} = shift;
+ }
+ return $self->{extensions_len};
+}
+sub extension_data
+{
+ my $self = shift;
+ if (@_) {
+ $self->{extension_data} = shift;
+ }
+ return $self->{extension_data};
+}
+sub set_extension
+{
+ my ($self, $ext_type, $ext_data) = @_;
+ $self->{extension_data}{$ext_type} = $ext_data;
+}
+sub delete_extension
+{
+ my ($self, $ext_type) = @_;
+ delete $self->{extension_data}{$ext_type};
+}
+1;
diff --git a/openssl-1.1.0h/util/perl/TLSProxy/Message.pm b/openssl-1.1.0h/util/perl/TLSProxy/Message.pm
new file mode 100644
index 0000000..0821bde
--- /dev/null
+++ b/openssl-1.1.0h/util/perl/TLSProxy/Message.pm
@@ -0,0 +1,456 @@
+# Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+use strict;
+
+package TLSProxy::Message;
+
+use constant TLS_MESSAGE_HEADER_LENGTH => 4;
+
+#Message types
+use constant {
+ MT_HELLO_REQUEST => 0,
+ MT_CLIENT_HELLO => 1,
+ MT_SERVER_HELLO => 2,
+ MT_NEW_SESSION_TICKET => 4,
+ MT_CERTIFICATE => 11,
+ MT_SERVER_KEY_EXCHANGE => 12,
+ MT_CERTIFICATE_REQUEST => 13,
+ MT_SERVER_HELLO_DONE => 14,
+ MT_CERTIFICATE_VERIFY => 15,
+ MT_CLIENT_KEY_EXCHANGE => 16,
+ MT_FINISHED => 20,
+ MT_CERTIFICATE_STATUS => 22,
+ MT_NEXT_PROTO => 67
+};
+
+#Alert levels
+use constant {
+ AL_LEVEL_WARN => 1,
+ AL_LEVEL_FATAL => 2
+};
+
+#Alert descriptions
+use constant {
+ AL_DESC_CLOSE_NOTIFY => 0,
+ AL_DESC_UNEXPECTED_MESSAGE => 10,
+ AL_DESC_NO_RENEGOTIATION => 100
+};
+
+my %message_type = (
+ MT_HELLO_REQUEST, "HelloRequest",
+ MT_CLIENT_HELLO, "ClientHello",
+ MT_SERVER_HELLO, "ServerHello",
+ MT_NEW_SESSION_TICKET, "NewSessionTicket",
+ MT_CERTIFICATE, "Certificate",
+ MT_SERVER_KEY_EXCHANGE, "ServerKeyExchange",
+ MT_CERTIFICATE_REQUEST, "CertificateRequest",
+ MT_SERVER_HELLO_DONE, "ServerHelloDone",
+ MT_CERTIFICATE_VERIFY, "CertificateVerify",
+ MT_CLIENT_KEY_EXCHANGE, "ClientKeyExchange",
+ MT_FINISHED, "Finished",
+ MT_CERTIFICATE_STATUS, "CertificateStatus",
+ MT_NEXT_PROTO, "NextProto"
+);
+
+use constant {
+ EXT_STATUS_REQUEST => 5,
+ EXT_ENCRYPT_THEN_MAC => 22,
+ EXT_EXTENDED_MASTER_SECRET => 23,
+ EXT_SESSION_TICKET => 35,
+ # This extension does not exist and isn't recognised by OpenSSL.
+ # We use it to test handling of duplicate extensions.
+ EXT_DUPLICATE_EXTENSION => 1234
+};
+
+my $payload = "";
+my $messlen = -1;
+my $mt;
+my $startoffset = -1;
+my $server = 0;
+my $success = 0;
+my $end = 0;
+my @message_rec_list = ();
+my @message_frag_lens = ();
+my $ciphersuite = 0;
+
+sub clear
+{
+ $payload = "";
+ $messlen = -1;
+ $startoffset = -1;
+ $server = 0;
+ $success = 0;
+ $end = 0;
+ @message_rec_list = ();
+ @message_frag_lens = ();
+}
+
+#Class method to extract messages from a record
+sub get_messages
+{
+ my $class = shift;
+ my $serverin = shift;
+ my $record = shift;
+ my @messages = ();
+ my $message;
+
+ @message_frag_lens = ();
+
+ if ($serverin != $server && length($payload) != 0) {
+ die "Changed peer, but we still have fragment data\n";
+ }
+ $server = $serverin;
+
+ if ($record->content_type == TLSProxy::Record::RT_CCS) {
+ if ($payload ne "") {
+ #We can't handle this yet
+ die "CCS received before message data complete\n";
+ }
+ if ($server) {
+ TLSProxy::Record->server_ccs_seen(1);
+ } else {
+ TLSProxy::Record->client_ccs_seen(1);
+ }
+ } elsif ($record->content_type == TLSProxy::Record::RT_HANDSHAKE) {
+ if ($record->len == 0 || $record->len_real == 0) {
+ print " Message truncated\n";
+ } else {
+ my $recoffset = 0;
+
+ if (length $payload > 0) {
+ #We are continuing processing a message started in a previous
+ #record. Add this record to the list associated with this
+ #message
+ push @message_rec_list, $record;
+
+ if ($messlen <= length($payload)) {
+ #Shouldn't happen
+ die "Internal error: invalid messlen: ".$messlen
+ ." payload length:".length($payload)."\n";
+ }
+ if (length($payload) + $record->decrypt_len >= $messlen) {
+ #We can complete the message with this record
+ $recoffset = $messlen - length($payload);
+ $payload .= substr($record->decrypt_data, 0, $recoffset);
+ push @message_frag_lens, $recoffset;
+ $message = create_message($server, $mt, $payload,
+ $startoffset);
+ push @messages, $message;
+
+ $payload = "";
+ } else {
+ #This is just part of the total message
+ $payload .= $record->decrypt_data;
+ $recoffset = $record->decrypt_len;
+ push @message_frag_lens, $record->decrypt_len;
+ }
+ print " Partial message data read: ".$recoffset." bytes\n";
+ }
+
+ while ($record->decrypt_len > $recoffset) {
+ #We are at the start of a new message
+ if ($record->decrypt_len - $recoffset < 4) {
+ #Whilst technically probably valid we can't cope with this
+ die "End of record in the middle of a message header\n";
+ }
+ @message_rec_list = ($record);
+ my $lenhi;
+ my $lenlo;
+ ($mt, $lenhi, $lenlo) = unpack('CnC',
+ substr($record->decrypt_data,
+ $recoffset));
+ $messlen = ($lenhi << 8) | $lenlo;
+ print " Message type: $message_type{$mt}\n";
+ print " Message Length: $messlen\n";
+ $startoffset = $recoffset;
+ $recoffset += 4;
+ $payload = "";
+
+ if ($recoffset <= $record->decrypt_len) {
+ #Some payload data is present in this record
+ if ($record->decrypt_len - $recoffset >= $messlen) {
+ #We can complete the message with this record
+ $payload .= substr($record->decrypt_data, $recoffset,
+ $messlen);
+ $recoffset += $messlen;
+ push @message_frag_lens, $messlen;
+ $message = create_message($server, $mt, $payload,
+ $startoffset);
+ push @messages, $message;
+
+ $payload = "";
+ } else {
+ #This is just part of the total message
+ $payload .= substr($record->decrypt_data, $recoffset,
+ $record->decrypt_len - $recoffset);
+ $recoffset = $record->decrypt_len;
+ push @message_frag_lens, $recoffset;
+ }
+ }
+ }
+ }
+ } elsif ($record->content_type == TLSProxy::Record::RT_APPLICATION_DATA) {
+ print " [ENCRYPTED APPLICATION DATA]\n";
+ print " [".$record->decrypt_data."]\n";
+ } elsif ($record->content_type == TLSProxy::Record::RT_ALERT) {
+ my ($alertlev, $alertdesc) = unpack('CC', $record->decrypt_data);
+ #A CloseNotify from the client indicates we have finished successfully
+ #(we assume)
+ if (!$end && !$server && $alertlev == AL_LEVEL_WARN
+ && $alertdesc == AL_DESC_CLOSE_NOTIFY) {
+ $success = 1;
+ }
+ #All alerts end the test
+ $end = 1;
+ }
+
+ return @messages;
+}
+
+#Function to work out which sub-class we need to create and then
+#construct it
+sub create_message
+{
+ my ($server, $mt, $data, $startoffset) = @_;
+ my $message;
+
+ #We only support ClientHello in this version...needs to be extended for
+ #others
+ if ($mt == MT_CLIENT_HELLO) {
+ $message = TLSProxy::ClientHello->new(
+ $server,
+ $data,
+ [@message_rec_list],
+ $startoffset,
+ [@message_frag_lens]
+ );
+ $message->parse();
+ } elsif ($mt == MT_SERVER_HELLO) {
+ $message = TLSProxy::ServerHello->new(
+ $server,
+ $data,
+ [@message_rec_list],
+ $startoffset,
+ [@message_frag_lens]
+ );
+ $message->parse();
+ } elsif ($mt == MT_SERVER_KEY_EXCHANGE) {
+ $message = TLSProxy::ServerKeyExchange->new(
+ $server,
+ $data,
+ [@message_rec_list],
+ $startoffset,
+ [@message_frag_lens]
+ );
+ $message->parse();
+ } elsif ($mt == MT_NEW_SESSION_TICKET) {
+ $message = TLSProxy::NewSessionTicket->new(
+ $server,
+ $data,
+ [@message_rec_list],
+ $startoffset,
+ [@message_frag_lens]
+ );
+ $message->parse();
+ } else {
+ #Unknown message type
+ $message = TLSProxy::Message->new(
+ $server,
+ $mt,
+ $data,
+ [@message_rec_list],
+ $startoffset,
+ [@message_frag_lens]
+ );
+ }
+
+ return $message;
+}
+
+sub end
+{
+ my $class = shift;
+ return $end;
+}
+sub success
+{
+ my $class = shift;
+ return $success;
+}
+sub fail
+{
+ my $class = shift;
+ return !$success && $end;
+}
+sub new
+{
+ my $class = shift;
+ my ($server,
+ $mt,
+ $data,
+ $records,
+ $startoffset,
+ $message_frag_lens) = @_;
+
+ my $self = {
+ server => $server,
+ data => $data,
+ records => $records,
+ mt => $mt,
+ startoffset => $startoffset,
+ message_frag_lens => $message_frag_lens
+ };
+
+ return bless $self, $class;
+}
+
+sub ciphersuite
+{
+ my $class = shift;
+ if (@_) {
+ $ciphersuite = shift;
+ }
+ return $ciphersuite;
+}
+
+#Update all the underlying records with the modified data from this message
+#Note: Does not currently support re-encrypting
+sub repack
+{
+ my $self = shift;
+ my $msgdata;
+
+ my $numrecs = $#{$self->records};
+
+ $self->set_message_contents();
+
+ my $lenhi;
+ my $lenlo;
+
+ $lenlo = length($self->data) & 0xff;
+ $lenhi = length($self->data) >> 8;
+ $msgdata = pack('CnC', $self->mt, $lenhi, $lenlo).$self->data;
+
+ if ($numrecs == 0) {
+ #The message is fully contained within one record
+ my ($rec) = @{$self->records};
+ my $recdata = $rec->decrypt_data;
+
+ my $old_length;
+
+ # We use empty message_frag_lens to indicates that pre-repacking,
+ # the message wasn't present. The first fragment length doesn't include
+ # the TLS header, so we need to check and compute the right length.
+ if (@{$self->message_frag_lens}) {
+ $old_length = ${$self->message_frag_lens}[0] +
+ TLS_MESSAGE_HEADER_LENGTH;
+ } else {
+ $old_length = 0;
+ }
+
+ my $prefix = substr($recdata, 0, $self->startoffset);
+ my $suffix = substr($recdata, $self->startoffset + $old_length);
+
+ $rec->decrypt_data($prefix.($msgdata).($suffix));
+ # TODO(openssl-team): don't keep explicit lengths.
+ # (If a length override is ever needed to construct invalid packets,
+ # use an explicit override field instead.)
+ $rec->decrypt_len(length($rec->decrypt_data));
+ $rec->len($rec->len + length($msgdata) - $old_length);
+ # Don't support re-encryption.
+ $rec->data($rec->decrypt_data);
+
+ #Update the fragment len in case we changed it above
+ ${$self->message_frag_lens}[0] = length($msgdata)
+ - TLS_MESSAGE_HEADER_LENGTH;
+ return;
+ }
+
+ #Note we don't currently support changing a fragmented message length
+ my $recctr = 0;
+ my $datadone = 0;
+ foreach my $rec (@{$self->records}) {
+ my $recdata = $rec->decrypt_data;
+ if ($recctr == 0) {
+ #This is the first record
+ my $remainlen = length($recdata) - $self->startoffset;
+ $rec->data(substr($recdata, 0, $self->startoffset)
+ .substr(($msgdata), 0, $remainlen));
+ $datadone += $remainlen;
+ } elsif ($recctr + 1 == $numrecs) {
+ #This is the last record
+ $rec->data(substr($msgdata, $datadone));
+ } else {
+ #This is a middle record
+ $rec->data(substr($msgdata, $datadone, length($rec->data)));
+ $datadone += length($rec->data);
+ }
+ $recctr++;
+ }
+}
+
+#To be overridden by sub-classes
+sub set_message_contents
+{
+}
+
+#Read only accessors
+sub server
+{
+ my $self = shift;
+ return $self->{server};
+}
+
+#Read/write accessors
+sub mt
+{
+ my $self = shift;
+ if (@_) {
+ $self->{mt} = shift;
+ }
+ return $self->{mt};
+}
+sub data
+{
+ my $self = shift;
+ if (@_) {
+ $self->{data} = shift;
+ }
+ return $self->{data};
+}
+sub records
+{
+ my $self = shift;
+ if (@_) {
+ $self->{records} = shift;
+ }
+ return $self->{records};
+}
+sub startoffset
+{
+ my $self = shift;
+ if (@_) {
+ $self->{startoffset} = shift;
+ }
+ return $self->{startoffset};
+}
+sub message_frag_lens
+{
+ my $self = shift;
+ if (@_) {
+ $self->{message_frag_lens} = shift;
+ }
+ return $self->{message_frag_lens};
+}
+sub encoded_length
+{
+ my $self = shift;
+ return TLS_MESSAGE_HEADER_LENGTH + length($self->data);
+}
+
+1;
diff --git a/openssl-1.1.0h/util/perl/TLSProxy/NewSessionTicket.pm b/openssl-1.1.0h/util/perl/TLSProxy/NewSessionTicket.pm
new file mode 100644
index 0000000..e509985
--- /dev/null
+++ b/openssl-1.1.0h/util/perl/TLSProxy/NewSessionTicket.pm
@@ -0,0 +1,81 @@
+# Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+use strict;
+
+package TLSProxy::NewSessionTicket;
+
+use vars '@ISA';
+push @ISA, 'TLSProxy::Message';
+
+sub new
+{
+ my $class = shift;
+ my ($server,
+ $data,
+ $records,
+ $startoffset,
+ $message_frag_lens) = @_;
+
+ my $self = $class->SUPER::new(
+ $server,
+ TLSProxy::Message::MT_NEW_SESSION_TICKET,
+ $data,
+ $records,
+ $startoffset,
+ $message_frag_lens);
+
+ $self->{ticket_lifetime_hint} = 0;
+ $self->{ticket} = "";
+
+ return $self;
+}
+
+sub parse
+{
+ my $self = shift;
+
+ my $ticket_lifetime_hint = unpack('N', $self->data);
+ my $ticket_len = unpack('n', $self->data);
+ my $ticket = substr($self->data, 6, $ticket_len);
+
+ $self->ticket_lifetime_hint($ticket_lifetime_hint);
+ $self->ticket($ticket);
+}
+
+
+#Reconstruct the on-the-wire message data following changes
+sub set_message_contents
+{
+ my $self = shift;
+ my $data;
+
+ $data = pack('N', $self->ticket_lifetime_hint);
+ $data .= pack('n', length($self->ticket));
+ $data .= $self->ticket;
+
+ $self->data($data);
+}
+
+#Read/write accessors
+sub ticket_lifetime_hint
+{
+ my $self = shift;
+ if (@_) {
+ $self->{ticket_lifetime_hint} = shift;
+ }
+ return $self->{ticket_lifetime_hint};
+}
+sub ticket
+{
+ my $self = shift;
+ if (@_) {
+ $self->{ticket} = shift;
+ }
+ return $self->{ticket};
+}
+1;
diff --git a/openssl-1.1.0h/util/perl/TLSProxy/Proxy.pm b/openssl-1.1.0h/util/perl/TLSProxy/Proxy.pm
new file mode 100644
index 0000000..de14362
--- /dev/null
+++ b/openssl-1.1.0h/util/perl/TLSProxy/Proxy.pm
@@ -0,0 +1,553 @@
+# Copyright 2016-2018 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+use strict;
+use POSIX ":sys_wait_h";
+
+package TLSProxy::Proxy;
+
+use File::Spec;
+use IO::Socket;
+use IO::Select;
+use TLSProxy::Record;
+use TLSProxy::Message;
+use TLSProxy::ClientHello;
+use TLSProxy::ServerHello;
+use TLSProxy::ServerKeyExchange;
+use TLSProxy::NewSessionTicket;
+use Time::HiRes qw/usleep/;
+
+my $have_IPv6 = 0;
+my $IP_factory;
+
+sub new
+{
+ my $class = shift;
+ my ($filter,
+ $execute,
+ $cert,
+ $debug) = @_;
+
+ my $self = {
+ #Public read/write
+ proxy_addr => "localhost",
+ proxy_port => 4453,
+ server_addr => "localhost",
+ server_port => 4443,
+ filter => $filter,
+ serverflags => "",
+ clientflags => "",
+ serverconnects => 1,
+ serverpid => 0,
+ clientpid => 0,
+ reneg => 0,
+
+ #Public read
+ execute => $execute,
+ cert => $cert,
+ debug => $debug,
+ cipherc => "",
+ ciphers => "AES128-SHA",
+ flight => -1,
+ direction => -1,
+ partial => ["", ""],
+ record_list => [],
+ message_list => [],
+ };
+
+ # IO::Socket::IP is on the core module list, IO::Socket::INET6 isn't.
+ # However, IO::Socket::INET6 is older and is said to be more widely
+ # deployed for the moment, and may have less bugs, so we try the latter
+ # first, then fall back on the code modules. Worst case scenario, we
+ # fall back to IO::Socket::INET, only supports IPv4.
+ eval {
+ require IO::Socket::INET6;
+ my $s = IO::Socket::INET6->new(
+ LocalAddr => "::1",
+ LocalPort => 0,
+ Listen=>1,
+ );
+ $s or die "\n";
+ $s->close();
+ };
+ if ($@ eq "") {
+ $IP_factory = sub { IO::Socket::INET6->new(@_); };
+ $have_IPv6 = 1;
+ } else {
+ eval {
+ require IO::Socket::IP;
+ my $s = IO::Socket::IP->new(
+ LocalAddr => "::1",
+ LocalPort => 0,
+ Listen=>1,
+ );
+ $s or die "\n";
+ $s->close();
+ };
+ if ($@ eq "") {
+ $IP_factory = sub { IO::Socket::IP->new(@_); };
+ $have_IPv6 = 1;
+ } else {
+ $IP_factory = sub { IO::Socket::INET->new(@_); };
+ }
+ }
+
+ # Create the Proxy socket
+ my $proxaddr = $self->{proxy_addr};
+ $proxaddr =~ s/[\[\]]//g; # Remove [ and ]
+ my @proxyargs = (
+ LocalHost => $proxaddr,
+ LocalPort => $self->{proxy_port},
+ Proto => "tcp",
+ Listen => SOMAXCONN,
+ );
+ push @proxyargs, ReuseAddr => 1
+ unless $^O eq "MSWin32";
+ $self->{proxy_sock} = $IP_factory->(@proxyargs);
+
+ if ($self->{proxy_sock}) {
+ print "Proxy started on port ".$self->{proxy_port}."\n";
+ } else {
+ warn "Failed creating proxy socket (".$proxaddr.",".$self->{proxy_port}."): $!\n";
+ }
+
+ return bless $self, $class;
+}
+
+sub DESTROY
+{
+ my $self = shift;
+
+ $self->{proxy_sock}->close() if $self->{proxy_sock};
+}
+
+sub clearClient
+{
+ my $self = shift;
+
+ $self->{cipherc} = "";
+ $self->{flight} = -1;
+ $self->{direction} = -1;
+ $self->{partial} = ["", ""];
+ $self->{record_list} = [];
+ $self->{message_list} = [];
+ $self->{clientflags} = "";
+ $self->{clientpid} = 0;
+
+ TLSProxy::Message->clear();
+ TLSProxy::Record->clear();
+}
+
+sub clear
+{
+ my $self = shift;
+
+ $self->clearClient;
+ $self->{ciphers} = "AES128-SHA";
+ $self->{serverflags} = "";
+ $self->{serverconnects} = 1;
+ $self->{serverpid} = 0;
+ $self->{reneg} = 0;
+}
+
+sub restart
+{
+ my $self = shift;
+
+ $self->clear;
+ $self->start;
+}
+
+sub clientrestart
+{
+ my $self = shift;
+
+ $self->clear;
+ $self->clientstart;
+}
+
+sub start
+{
+ my ($self) = shift;
+ my $pid;
+
+ if ($self->{proxy_sock} == 0) {
+ return 0;
+ }
+
+ $pid = fork();
+ if ($pid == 0) {
+ my $execcmd = $self->execute
+ ." s_server -max_protocol TLSv1.2 -no_comp -rev -engine ossltest -accept "
+ .($self->server_port)
+ ." -cert ".$self->cert." -naccept ".$self->serverconnects;
+ unless ($self->supports_IPv6) {
+ $execcmd .= " -4";
+ }
+ if ($self->ciphers ne "") {
+ $execcmd .= " -cipher ".$self->ciphers;
+ }
+ if ($self->serverflags ne "") {
+ $execcmd .= " ".$self->serverflags;
+ }
+ if ($self->debug) {
+ print STDERR "Server command: $execcmd\n";
+ }
+ exec($execcmd);
+ }
+ $self->serverpid($pid);
+
+ return $self->clientstart;
+}
+
+sub clientstart
+{
+ my ($self) = shift;
+ my $oldstdout;
+
+ if ($self->execute) {
+ my $pid = fork();
+ if ($pid == 0) {
+ my $echostr;
+ if ($self->reneg()) {
+ $echostr = "R";
+ } else {
+ $echostr = "test";
+ }
+ my $execcmd = "echo ".$echostr." | ".$self->execute
+ ." s_client -max_protocol TLSv1.2 -engine ossltest -connect "
+ .($self->proxy_addr).":".($self->proxy_port);
+ unless ($self->supports_IPv6) {
+ $execcmd .= " -4";
+ }
+ if ($self->cipherc ne "") {
+ $execcmd .= " -cipher ".$self->cipherc;
+ }
+ if ($self->clientflags ne "") {
+ $execcmd .= " ".$self->clientflags;
+ }
+ if ($self->debug) {
+ print STDERR "Client command: $execcmd\n";
+ }
+ exec($execcmd);
+ }
+ $self->clientpid($pid);
+ }
+
+ # Wait for incoming connection from client
+ my $client_sock;
+ if(!($client_sock = $self->{proxy_sock}->accept())) {
+ warn "Failed accepting incoming connection: $!\n";
+ return 0;
+ }
+
+ print "Connection opened\n";
+
+ # Now connect to the server
+ my $retry = 50;
+ my $server_sock;
+ #We loop over this a few times because sometimes s_server can take a while
+ #to start up
+ do {
+ my $servaddr = $self->server_addr;
+ $servaddr =~ s/[\[\]]//g; # Remove [ and ]
+ eval {
+ $server_sock = $IP_factory->(
+ PeerAddr => $servaddr,
+ PeerPort => $self->server_port,
+ MultiHomed => 1,
+ Proto => 'tcp'
+ );
+ };
+
+ $retry--;
+ #Some buggy IP factories can return a defined server_sock that hasn't
+ #actually connected, so we check peerport too
+ if ($@ || !defined($server_sock) || !defined($server_sock->peerport)) {
+ $server_sock->close() if defined($server_sock);
+ undef $server_sock;
+ if ($retry) {
+ #Sleep for a short while
+ select(undef, undef, undef, 0.1);
+ } else {
+ warn "Failed to start up server (".$servaddr.",".$self->server_port."): $!\n";
+ return 0;
+ }
+ }
+ } while (!$server_sock);
+
+ my $sel = IO::Select->new($server_sock, $client_sock);
+ my $indata;
+ my @handles = ($server_sock, $client_sock);
+
+ #Wait for either the server socket or the client socket to become readable
+ my @ready;
+ local $SIG{PIPE} = "IGNORE";
+ while(!(TLSProxy::Message->end) && (@ready = $sel->can_read)) {
+ foreach my $hand (@ready) {
+ if ($hand == $server_sock) {
+ $server_sock->sysread($indata, 16384) or goto END;
+ $indata = $self->process_packet(1, $indata);
+ $client_sock->syswrite($indata);
+ } elsif ($hand == $client_sock) {
+ $client_sock->sysread($indata, 16384) or goto END;
+ $indata = $self->process_packet(0, $indata);
+ $server_sock->syswrite($indata);
+ } else {
+ print "Err\n";
+ goto END;
+ }
+ }
+ }
+
+ END:
+ print "Connection closed\n";
+ if($server_sock) {
+ $server_sock->close();
+ }
+ if($client_sock) {
+ #Closing this also kills the child process
+ $client_sock->close();
+ }
+ if(!$self->debug) {
+ select($oldstdout);
+ }
+ $self->serverconnects($self->serverconnects - 1);
+ if ($self->serverconnects == 0) {
+ die "serverpid is zero\n" if $self->serverpid == 0;
+ print "Waiting for server process to close: "
+ .$self->serverpid."\n";
+ waitpid( $self->serverpid, 0);
+ die "exit code $? from server process\n" if $? != 0;
+ } else {
+ # Give s_server sufficient time to finish what it was doing
+ usleep(250000);
+ }
+ die "clientpid is zero\n" if $self->clientpid == 0;
+ print "Waiting for client process to close: ".$self->clientpid."\n";
+ waitpid($self->clientpid, 0);
+
+ return 1;
+}
+
+sub process_packet
+{
+ my ($self, $server, $packet) = @_;
+ my $len_real;
+ my $decrypt_len;
+ my $data;
+ my $recnum;
+
+ if ($server) {
+ print "Received server packet\n";
+ } else {
+ print "Received client packet\n";
+ }
+
+ if ($self->{direction} != $server) {
+ $self->{flight} = $self->{flight} + 1;
+ $self->{direction} = $server;
+ }
+
+ print "Packet length = ".length($packet)."\n";
+ print "Processing flight ".$self->flight."\n";
+
+ #Return contains the list of record found in the packet followed by the
+ #list of messages in those records and any partial message
+ my @ret = TLSProxy::Record->get_records($server, $self->flight, $self->{partial}[$server].$packet);
+ $self->{partial}[$server] = $ret[2];
+ push @{$self->record_list}, @{$ret[0]};
+ push @{$self->{message_list}}, @{$ret[1]};
+
+ print "\n";
+
+ if (scalar(@{$ret[0]}) == 0 or length($ret[2]) != 0) {
+ return "";
+ }
+
+ #Finished parsing. Call user provided filter here
+ if (defined $self->filter) {
+ $self->filter->($self);
+ }
+
+ #Reconstruct the packet
+ $packet = "";
+ foreach my $record (@{$self->record_list}) {
+ $packet .= $record->reconstruct_record();
+ }
+
+ print "Forwarded packet length = ".length($packet)."\n\n";
+
+ return $packet;
+}
+
+#Read accessors
+sub execute
+{
+ my $self = shift;
+ return $self->{execute};
+}
+sub cert
+{
+ my $self = shift;
+ return $self->{cert};
+}
+sub debug
+{
+ my $self = shift;
+ return $self->{debug};
+}
+sub flight
+{
+ my $self = shift;
+ return $self->{flight};
+}
+sub record_list
+{
+ my $self = shift;
+ return $self->{record_list};
+}
+sub success
+{
+ my $self = shift;
+ return $self->{success};
+}
+sub end
+{
+ my $self = shift;
+ return $self->{end};
+}
+sub supports_IPv6
+{
+ my $self = shift;
+ return $have_IPv6;
+}
+sub proxy_addr
+{
+ my $self = shift;
+ return $self->{proxy_addr};
+}
+sub proxy_port
+{
+ my $self = shift;
+ return $self->{proxy_port};
+}
+
+#Read/write accessors
+sub server_addr
+{
+ my $self = shift;
+ if (@_) {
+ $self->{server_addr} = shift;
+ }
+ return $self->{server_addr};
+}
+sub server_port
+{
+ my $self = shift;
+ if (@_) {
+ $self->{server_port} = shift;
+ }
+ return $self->{server_port};
+}
+sub filter
+{
+ my $self = shift;
+ if (@_) {
+ $self->{filter} = shift;
+ }
+ return $self->{filter};
+}
+sub cipherc
+{
+ my $self = shift;
+ if (@_) {
+ $self->{cipherc} = shift;
+ }
+ return $self->{cipherc};
+}
+sub ciphers
+{
+ my $self = shift;
+ if (@_) {
+ $self->{ciphers} = shift;
+ }
+ return $self->{ciphers};
+}
+sub serverflags
+{
+ my $self = shift;
+ if (@_) {
+ $self->{serverflags} = shift;
+ }
+ return $self->{serverflags};
+}
+sub clientflags
+{
+ my $self = shift;
+ if (@_) {
+ $self->{clientflags} = shift;
+ }
+ return $self->{clientflags};
+}
+sub serverconnects
+{
+ my $self = shift;
+ if (@_) {
+ $self->{serverconnects} = shift;
+ }
+ return $self->{serverconnects};
+}
+# This is a bit ugly because the caller is responsible for keeping the records
+# in sync with the updated message list; simply updating the message list isn't
+# sufficient to get the proxy to forward the new message.
+# But it does the trick for the one test (test_sslsessiontick) that needs it.
+sub message_list
+{
+ my $self = shift;
+ if (@_) {
+ $self->{message_list} = shift;
+ }
+ return $self->{message_list};
+}
+sub serverpid
+{
+ my $self = shift;
+ if (@_) {
+ $self->{serverpid} = shift;
+ }
+ return $self->{serverpid};
+}
+sub clientpid
+{
+ my $self = shift;
+ if (@_) {
+ $self->{clientpid} = shift;
+ }
+ return $self->{clientpid};
+}
+
+sub fill_known_data
+{
+ my $length = shift;
+ my $ret = "";
+ for (my $i = 0; $i < $length; $i++) {
+ $ret .= chr($i);
+ }
+ return $ret;
+}
+
+sub reneg
+{
+ my $self = shift;
+ if (@_) {
+ $self->{reneg} = shift;
+ }
+ return $self->{reneg};
+}
+
+1;
diff --git a/openssl-1.1.0h/util/perl/TLSProxy/Record.pm b/openssl-1.1.0h/util/perl/TLSProxy/Record.pm
new file mode 100644
index 0000000..786ba0c
--- /dev/null
+++ b/openssl-1.1.0h/util/perl/TLSProxy/Record.pm
@@ -0,0 +1,339 @@
+# Copyright 2016-2018 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+use strict;
+
+use TLSProxy::Proxy;
+
+package TLSProxy::Record;
+
+my $server_ccs_seen = 0;
+my $client_ccs_seen = 0;
+my $etm = 0;
+
+use constant TLS_RECORD_HEADER_LENGTH => 5;
+
+#Record types
+use constant {
+ RT_APPLICATION_DATA => 23,
+ RT_HANDSHAKE => 22,
+ RT_ALERT => 21,
+ RT_CCS => 20,
+ RT_UNKNOWN => 100
+};
+
+my %record_type = (
+ RT_APPLICATION_DATA, "APPLICATION DATA",
+ RT_HANDSHAKE, "HANDSHAKE",
+ RT_ALERT, "ALERT",
+ RT_CCS, "CCS",
+ RT_UNKNOWN, "UNKNOWN"
+);
+
+use constant {
+ VERS_TLS_1_3 => 772,
+ VERS_TLS_1_2 => 771,
+ VERS_TLS_1_1 => 770,
+ VERS_TLS_1_0 => 769,
+ VERS_SSL_3_0 => 768,
+ VERS_SSL_LT_3_0 => 767
+};
+
+my %tls_version = (
+ VERS_TLS_1_3, "TLS1.3",
+ VERS_TLS_1_2, "TLS1.2",
+ VERS_TLS_1_1, "TLS1.1",
+ VERS_TLS_1_0, "TLS1.0",
+ VERS_SSL_3_0, "SSL3",
+ VERS_SSL_LT_3_0, "SSL<3"
+);
+
+#Class method to extract records from a packet of data
+sub get_records
+{
+ my $class = shift;
+ my $server = shift;
+ my $flight = shift;
+ my $packet = shift;
+ my $partial = "";
+ my @record_list = ();
+ my @message_list = ();
+ my $data;
+ my $content_type;
+ my $version;
+ my $len;
+ my $len_real;
+ my $decrypt_len;
+
+ my $recnum = 1;
+ while (length ($packet) > 0) {
+ print " Record $recnum";
+ if ($server) {
+ print " (server -> client)\n";
+ } else {
+ print " (client -> server)\n";
+ }
+ #Get the record header
+ if (length($packet) < TLS_RECORD_HEADER_LENGTH
+ || length($packet) < 5 + unpack("n", substr($packet, 3, 2))) {
+ print "Partial data : ".length($packet)." bytes\n";
+ $partial = $packet;
+ $packet = "";
+ } else {
+ ($content_type, $version, $len) = unpack('CnnC*', $packet);
+ $data = substr($packet, 5, $len);
+
+ print " Content type: ".$record_type{$content_type}."\n";
+ print " Version: $tls_version{$version}\n";
+ print " Length: $len";
+ if ($len == length($data)) {
+ print "\n";
+ $decrypt_len = $len_real = $len;
+ } else {
+ print " (expected), ".length($data)." (actual)\n";
+ $decrypt_len = $len_real = length($data);
+ }
+
+ my $record = TLSProxy::Record->new(
+ $flight,
+ $content_type,
+ $version,
+ $len,
+ 0,
+ $len_real,
+ $decrypt_len,
+ substr($packet, TLS_RECORD_HEADER_LENGTH, $len_real),
+ substr($packet, TLS_RECORD_HEADER_LENGTH, $len_real)
+ );
+
+ if (($server && $server_ccs_seen)
+ || (!$server && $client_ccs_seen)) {
+ if ($etm) {
+ $record->decryptETM();
+ } else {
+ $record->decrypt();
+ }
+ }
+
+ push @record_list, $record;
+
+ #Now figure out what messages are contained within this record
+ my @messages = TLSProxy::Message->get_messages($server, $record);
+ push @message_list, @messages;
+
+ $packet = substr($packet, TLS_RECORD_HEADER_LENGTH + $len_real);
+ $recnum++;
+ }
+ }
+
+ return (\@record_list, \@message_list, $partial);
+}
+
+sub clear
+{
+ $server_ccs_seen = 0;
+ $client_ccs_seen = 0;
+}
+
+#Class level accessors
+sub server_ccs_seen
+{
+ my $class = shift;
+ if (@_) {
+ $server_ccs_seen = shift;
+ }
+ return $server_ccs_seen;
+}
+sub client_ccs_seen
+{
+ my $class = shift;
+ if (@_) {
+ $client_ccs_seen = shift;
+ }
+ return $client_ccs_seen;
+}
+#Enable/Disable Encrypt-then-MAC
+sub etm
+{
+ my $class = shift;
+ if (@_) {
+ $etm = shift;
+ }
+ return $etm;
+}
+
+sub new
+{
+ my $class = shift;
+ my ($flight,
+ $content_type,
+ $version,
+ $len,
+ $sslv2,
+ $len_real,
+ $decrypt_len,
+ $data,
+ $decrypt_data) = @_;
+
+ my $self = {
+ flight => $flight,
+ content_type => $content_type,
+ version => $version,
+ len => $len,
+ sslv2 => $sslv2,
+ len_real => $len_real,
+ decrypt_len => $decrypt_len,
+ data => $data,
+ decrypt_data => $decrypt_data,
+ orig_decrypt_data => $decrypt_data,
+ sent => 0
+ };
+
+ return bless $self, $class;
+}
+
+#Decrypt using encrypt-then-MAC
+sub decryptETM
+{
+ my ($self) = shift;
+
+ my $data = $self->data;
+
+ if($self->version >= VERS_TLS_1_1()) {
+ #TLS1.1+ has an explicit IV. Throw it away
+ $data = substr($data, 16);
+ }
+
+ #Throw away the MAC (assumes MAC is 20 bytes for now. FIXME)
+ $data = substr($data, 0, length($data) - 20);
+
+ #Find out what the padding byte is
+ my $padval = unpack("C", substr($data, length($data) - 1));
+
+ #Throw away the padding
+ $data = substr($data, 0, length($data) - ($padval + 1));
+
+ $self->decrypt_data($data);
+ $self->decrypt_len(length($data));
+
+ return $data;
+}
+
+#Standard decrypt
+sub decrypt()
+{
+ my ($self) = shift;
+
+ my $data = $self->data;
+
+ if($self->version >= VERS_TLS_1_1()) {
+ #TLS1.1+ has an explicit IV. Throw it away
+ $data = substr($data, 16);
+ }
+
+ #Find out what the padding byte is
+ my $padval = unpack("C", substr($data, length($data) - 1));
+
+ #Throw away the padding
+ $data = substr($data, 0, length($data) - ($padval + 1));
+
+ #Throw away the MAC (assumes MAC is 20 bytes for now. FIXME)
+ $data = substr($data, 0, length($data) - 20);
+
+ $self->decrypt_data($data);
+ $self->decrypt_len(length($data));
+
+ return $data;
+}
+
+#Reconstruct the on-the-wire record representation
+sub reconstruct_record
+{
+ my $self = shift;
+ my $data;
+
+ if ($self->{sent}) {
+ return "";
+ }
+ $self->{sent} = 1;
+
+ if ($self->sslv2) {
+ $data = pack('n', $self->len | 0x8000);
+ } else {
+ $data = pack('Cnn', $self->content_type, $self->version, $self->len);
+ }
+ $data .= $self->data;
+
+ return $data;
+}
+
+#Read only accessors
+sub flight
+{
+ my $self = shift;
+ return $self->{flight};
+}
+sub content_type
+{
+ my $self = shift;
+ return $self->{content_type};
+}
+sub version
+{
+ my $self = shift;
+ return $self->{version};
+}
+sub sslv2
+{
+ my $self = shift;
+ return $self->{sslv2};
+}
+sub len_real
+{
+ my $self = shift;
+ return $self->{len_real};
+}
+sub orig_decrypt_data
+{
+ my $self = shift;
+ return $self->{orig_decrypt_data};
+}
+
+#Read/write accessors
+sub decrypt_len
+{
+ my $self = shift;
+ if (@_) {
+ $self->{decrypt_len} = shift;
+ }
+ return $self->{decrypt_len};
+}
+sub data
+{
+ my $self = shift;
+ if (@_) {
+ $self->{data} = shift;
+ }
+ return $self->{data};
+}
+sub decrypt_data
+{
+ my $self = shift;
+ if (@_) {
+ $self->{decrypt_data} = shift;
+ }
+ return $self->{decrypt_data};
+}
+sub len
+{
+ my $self = shift;
+ if (@_) {
+ $self->{len} = shift;
+ }
+ return $self->{len};
+}
+1;
diff --git a/openssl-1.1.0h/util/perl/TLSProxy/ServerHello.pm b/openssl-1.1.0h/util/perl/TLSProxy/ServerHello.pm
new file mode 100644
index 0000000..79a8be9
--- /dev/null
+++ b/openssl-1.1.0h/util/perl/TLSProxy/ServerHello.pm
@@ -0,0 +1,210 @@
+# Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+use strict;
+
+package TLSProxy::ServerHello;
+
+use vars '@ISA';
+push @ISA, 'TLSProxy::Message';
+
+sub new
+{
+ my $class = shift;
+ my ($server,
+ $data,
+ $records,
+ $startoffset,
+ $message_frag_lens) = @_;
+
+ my $self = $class->SUPER::new(
+ $server,
+ TLSProxy::Message::MT_SERVER_HELLO,
+ $data,
+ $records,
+ $startoffset,
+ $message_frag_lens);
+
+ $self->{server_version} = 0;
+ $self->{random} = [];
+ $self->{session_id_len} = 0;
+ $self->{session} = "";
+ $self->{ciphersuite} = 0;
+ $self->{comp_meth} = 0;
+ $self->{extension_data} = "";
+
+ return $self;
+}
+
+sub parse
+{
+ my $self = shift;
+ my $ptr = 2;
+ my ($server_version) = unpack('n', $self->data);
+ my $random = substr($self->data, $ptr, 32);
+ $ptr += 32;
+ my $session_id_len = unpack('C', substr($self->data, $ptr));
+ $ptr++;
+ my $session = substr($self->data, $ptr, $session_id_len);
+ $ptr += $session_id_len;
+ my $ciphersuite = unpack('n', substr($self->data, $ptr));
+ $ptr += 2;
+ my $comp_meth = unpack('C', substr($self->data, $ptr));
+ $ptr++;
+ my $extensions_len = unpack('n', substr($self->data, $ptr));
+ if (!defined $extensions_len) {
+ $extensions_len = 0;
+ } else {
+ $ptr += 2;
+ }
+ #For now we just deal with this as a block of data. In the future we will
+ #want to parse this
+ my $extension_data;
+ if ($extensions_len != 0) {
+ $extension_data = substr($self->data, $ptr);
+
+ if (length($extension_data) != $extensions_len) {
+ die "Invalid extension length\n";
+ }
+ } else {
+ if (length($self->data) != $ptr) {
+ die "Invalid extension length\n";
+ }
+ $extension_data = "";
+ }
+ my %extensions = ();
+ while (length($extension_data) >= 4) {
+ my ($type, $size) = unpack("nn", $extension_data);
+ my $extdata = substr($extension_data, 4, $size);
+ $extension_data = substr($extension_data, 4 + $size);
+ $extensions{$type} = $extdata;
+ }
+
+ $self->server_version($server_version);
+ $self->random($random);
+ $self->session_id_len($session_id_len);
+ $self->session($session);
+ $self->ciphersuite($ciphersuite);
+ $self->comp_meth($comp_meth);
+ $self->extension_data(\%extensions);
+
+ $self->process_data();
+
+ print " Server Version:".$server_version."\n";
+ print " Session ID Len:".$session_id_len."\n";
+ print " Ciphersuite:".$ciphersuite."\n";
+ print " Compression Method:".$comp_meth."\n";
+ print " Extensions Len:".$extensions_len."\n";
+}
+
+#Perform any actions necessary based on the data we've seen
+sub process_data
+{
+ my $self = shift;
+
+ TLSProxy::Message->ciphersuite($self->ciphersuite);
+}
+
+#Reconstruct the on-the-wire message data following changes
+sub set_message_contents
+{
+ my $self = shift;
+ my $data;
+ my $extensions = "";
+
+ $data = pack('n', $self->server_version);
+ $data .= $self->random;
+ $data .= pack('C', $self->session_id_len);
+ $data .= $self->session;
+ $data .= pack('n', $self->ciphersuite);
+ $data .= pack('C', $self->comp_meth);
+
+ foreach my $key (keys %{$self->extension_data}) {
+ my $extdata = ${$self->extension_data}{$key};
+ $extensions .= pack("n", $key);
+ $extensions .= pack("n", length($extdata));
+ $extensions .= $extdata;
+ if ($key == TLSProxy::Message::EXT_DUPLICATE_EXTENSION) {
+ $extensions .= pack("n", $key);
+ $extensions .= pack("n", length($extdata));
+ $extensions .= $extdata;
+ }
+ }
+
+ $data .= pack('n', length($extensions));
+ $data .= $extensions;
+ $self->data($data);
+}
+
+#Read/write accessors
+sub server_version
+{
+ my $self = shift;
+ if (@_) {
+ $self->{client_version} = shift;
+ }
+ return $self->{client_version};
+}
+sub random
+{
+ my $self = shift;
+ if (@_) {
+ $self->{random} = shift;
+ }
+ return $self->{random};
+}
+sub session_id_len
+{
+ my $self = shift;
+ if (@_) {
+ $self->{session_id_len} = shift;
+ }
+ return $self->{session_id_len};
+}
+sub session
+{
+ my $self = shift;
+ if (@_) {
+ $self->{session} = shift;
+ }
+ return $self->{session};
+}
+sub ciphersuite
+{
+ my $self = shift;
+ if (@_) {
+ $self->{ciphersuite} = shift;
+ }
+ return $self->{ciphersuite};
+}
+sub comp_meth
+{
+ my $self = shift;
+ if (@_) {
+ $self->{comp_meth} = shift;
+ }
+ return $self->{comp_meth};
+}
+sub extension_data
+{
+ my $self = shift;
+ if (@_) {
+ $self->{extension_data} = shift;
+ }
+ return $self->{extension_data};
+}
+sub set_extension
+{
+ my ($self, $ext_type, $ext_data) = @_;
+ $self->{extension_data}{$ext_type} = $ext_data;
+}
+sub delete_extension
+{
+ my ($self, $ext_type) = @_;
+ delete $self->{extension_data}{$ext_type};
+}
+1;
diff --git a/openssl-1.1.0h/util/perl/TLSProxy/ServerKeyExchange.pm b/openssl-1.1.0h/util/perl/TLSProxy/ServerKeyExchange.pm
new file mode 100644
index 0000000..6e5b4cd
--- /dev/null
+++ b/openssl-1.1.0h/util/perl/TLSProxy/ServerKeyExchange.pm
@@ -0,0 +1,134 @@
+# Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+use strict;
+
+package TLSProxy::ServerKeyExchange;
+
+use vars '@ISA';
+push @ISA, 'TLSProxy::Message';
+
+sub new
+{
+ my $class = shift;
+ my ($server,
+ $data,
+ $records,
+ $startoffset,
+ $message_frag_lens) = @_;
+
+ my $self = $class->SUPER::new(
+ $server,
+ TLSProxy::Message::MT_SERVER_KEY_EXCHANGE,
+ $data,
+ $records,
+ $startoffset,
+ $message_frag_lens);
+
+ #DHE
+ $self->{p} = "";
+ $self->{g} = "";
+ $self->{pub_key} = "";
+ $self->{sig} = "";
+
+ return $self;
+}
+
+sub parse
+{
+ my $self = shift;
+
+ #Minimal SKE parsing. Only supports DHE at the moment (if its not DHE
+ #the parsing data will be trash...which is ok as long as we don't try to
+ #use it)
+
+ my $p_len = unpack('n', $self->data);
+ my $ptr = 2;
+ my $p = substr($self->data, $ptr, $p_len);
+ $ptr += $p_len;
+
+ my $g_len = unpack('n', substr($self->data, $ptr));
+ $ptr += 2;
+ my $g = substr($self->data, $ptr, $g_len);
+ $ptr += $g_len;
+
+ my $pub_key_len = unpack('n', substr($self->data, $ptr));
+ $ptr += 2;
+ my $pub_key = substr($self->data, $ptr, $pub_key_len);
+ $ptr += $pub_key_len;
+
+ #We assume its signed
+ my $sig_len = unpack('n', substr($self->data, $ptr));
+ my $sig = "";
+ if (defined $sig_len) {
+ $ptr += 2;
+ $sig = substr($self->data, $ptr, $sig_len);
+ $ptr += $sig_len;
+ }
+
+ $self->p($p);
+ $self->g($g);
+ $self->pub_key($pub_key);
+ $self->sig($sig);
+}
+
+
+#Reconstruct the on-the-wire message data following changes
+sub set_message_contents
+{
+ my $self = shift;
+ my $data;
+
+ $data = pack('n', length($self->p));
+ $data .= $self->p;
+ $data .= pack('n', length($self->g));
+ $data .= $self->g;
+ $data .= pack('n', length($self->pub_key));
+ $data .= $self->pub_key;
+ if (length($self->sig) > 0) {
+ $data .= pack('n', length($self->sig));
+ $data .= $self->sig;
+ }
+
+ $self->data($data);
+}
+
+#Read/write accessors
+#DHE
+sub p
+{
+ my $self = shift;
+ if (@_) {
+ $self->{p} = shift;
+ }
+ return $self->{p};
+}
+sub g
+{
+ my $self = shift;
+ if (@_) {
+ $self->{g} = shift;
+ }
+ return $self->{g};
+}
+sub pub_key
+{
+ my $self = shift;
+ if (@_) {
+ $self->{pub_key} = shift;
+ }
+ return $self->{pub_key};
+}
+sub sig
+{
+ my $self = shift;
+ if (@_) {
+ $self->{sig} = shift;
+ }
+ return $self->{sig};
+}
+1;
diff --git a/openssl-1.1.0h/util/perl/with_fallback.pm b/openssl-1.1.0h/util/perl/with_fallback.pm
new file mode 100644
index 0000000..2af1d5f
--- /dev/null
+++ b/openssl-1.1.0h/util/perl/with_fallback.pm
@@ -0,0 +1,25 @@
+# Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+package with_fallback;
+
+sub import {
+ use File::Basename;
+ use File::Spec::Functions;
+ foreach (@_) {
+ eval "require $_";
+ if ($@) {
+ unshift @INC, catdir(dirname(__FILE__),
+ "..", "..", "external", "perl");
+ my $transfer = "transfer::$_";
+ eval "require $transfer";
+ shift @INC;
+ warn $@ if $@;
+ }
+ }
+}
+1;
diff --git a/openssl-1.1.0h/util/point.sh b/openssl-1.1.0h/util/point.sh
new file mode 100755
index 0000000..da39899
--- /dev/null
+++ b/openssl-1.1.0h/util/point.sh
@@ -0,0 +1,10 @@
+#!/bin/sh
+
+rm -f "$2"
+if test "$OSTYPE" = msdosdjgpp || test "x$PLATFORM" = xmingw ; then
+ cp "$1" "$2"
+else
+ ln -s "$1" "$2"
+fi
+echo "$2 => $1"
+
diff --git a/openssl-1.1.0h/util/process_docs.pl b/openssl-1.1.0h/util/process_docs.pl
new file mode 100755
index 0000000..e084df7
--- /dev/null
+++ b/openssl-1.1.0h/util/process_docs.pl
@@ -0,0 +1,248 @@
+#! /usr/bin/env perl
+# Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+use strict;
+use warnings;
+
+use File::Spec::Functions;
+use File::Basename;
+use File::Copy;
+use File::Path;
+use FindBin;
+use lib "$FindBin::Bin/perl";
+use OpenSSL::Glob;
+use Getopt::Long;
+use Pod::Usage;
+
+use lib '.';
+use configdata;
+
+# We know we are in the 'util' directory and that our perl modules are
+# in util/perl
+use lib catdir(dirname($0), "perl");
+use OpenSSL::Util::Pod;
+
+my %options = ();
+GetOptions(\%options,
+ 'sourcedir=s', # Source directory
+ 'subdir=s%', # Subdirectories to look through,
+ # with associated section numbers
+ 'destdir=s', # Destination directory
+ #'in=s@', # Explicit files to process (ignores sourcedir)
+ #'section=i', # Default section used for --in files
+ 'type=s', # The result type, 'man' or 'html'
+ 'suffix:s', # Suffix to add to the extension.
+ # Only used with type=man
+ 'remove', # To remove files rather than writing them
+ 'dry-run|n', # Only output file names on STDOUT
+ 'debug|D+',
+ );
+
+unless ($options{subdir}) {
+ $options{subdir} = { apps => '1',
+ crypto => '3',
+ ssl => '3' };
+}
+unless ($options{sourcedir}) {
+ $options{sourcedir} = catdir($config{sourcedir}, "doc");
+}
+pod2usage(1) unless ( defined $options{subdir}
+ && defined $options{sourcedir}
+ && defined $options{destdir}
+ && defined $options{type}
+ && ($options{type} eq 'man'
+ || $options{type} eq 'html') );
+pod2usage(1) if ( $options{type} eq 'html'
+ && defined $options{suffix} );
+
+if ($options{debug}) {
+ print STDERR "DEBUG: options:\n";
+ print STDERR "DEBUG: --sourcedir = $options{sourcedir}\n"
+ if defined $options{sourcedir};
+ print STDERR "DEBUG: --destdir = $options{destdir}\n"
+ if defined $options{destdir};
+ print STDERR "DEBUG: --type = $options{type}\n"
+ if defined $options{type};
+ print STDERR "DEBUG: --suffix = $options{suffix}\n"
+ if defined $options{suffix};
+ foreach (keys %{$options{subdir}}) {
+ print STDERR "DEBUG: --subdir = $_=$options{subdir}->{$_}\n";
+ }
+ print STDERR "DEBUG: --remove = $options{remove}\n"
+ if defined $options{remove};
+ print STDERR "DEBUG: --debug = $options{debug}\n"
+ if defined $options{debug};
+ print STDERR "DEBUG: --dry-run = $options{\"dry-run\"}\n"
+ if defined $options{"dry-run"};
+}
+
+my $symlink_exists = eval { symlink("",""); 1 };
+
+foreach my $subdir (keys %{$options{subdir}}) {
+ my $section = $options{subdir}->{$subdir};
+ my $podsourcedir = catfile($options{sourcedir}, $subdir);
+ my $podglob = catfile($podsourcedir, "*.pod");
+
+ foreach my $podfile (glob $podglob) {
+ my $podname = basename($podfile, ".pod");
+ my $podpath = catfile($podfile);
+ my %podinfo = extract_pod_info($podpath,
+ { debug => $options{debug},
+ section => $section });
+ my @podfiles = grep { $_ ne $podname } @{$podinfo{names}};
+
+ my $updir = updir();
+ my $name = uc $podname;
+ my $suffix = { man => ".$podinfo{section}".($options{suffix} // ""),
+ html => ".html" } -> {$options{type}};
+ my $generate = { man => "pod2man --name=$name --section=$podinfo{section} --center=OpenSSL --release=$config{version} \"$podpath\"",
+ html => "pod2html \"--podroot=$options{sourcedir}\" --htmldir=$updir --podpath=apps:crypto:ssl \"--infile=$podpath\" \"--title=$podname\""
+ } -> {$options{type}};
+ my $output_dir = catdir($options{destdir}, "man$podinfo{section}");
+ my $output_file = $podname . $suffix;
+ my $output_path = catfile($output_dir, $output_file);
+
+ if (! $options{remove}) {
+ my @output;
+ print STDERR "DEBUG: Processing, using \"$generate\"\n"
+ if $options{debug};
+ unless ($options{"dry-run"}) {
+ @output = `$generate`;
+ map { s|href="http://man\.he\.net/(man\d/[^"]+)(?:\.html)?"|href="../$1.html|g; } @output
+ if $options{type} eq "html";
+ }
+ print STDERR "DEBUG: Done processing\n" if $options{debug};
+
+ if (! -d $output_dir) {
+ print STDERR "DEBUG: Creating directory $output_dir\n" if $options{debug};
+ unless ($options{"dry-run"}) {
+ mkpath $output_dir
+ or die "Trying to create directory $output_dir: $!\n";
+ }
+ }
+ print STDERR "DEBUG: Writing $output_path\n" if $options{debug};
+ unless ($options{"dry-run"}) {
+ open my $output_fh, '>', $output_path
+ or die "Trying to write to $output_path: $!\n";
+ foreach (@output) {
+ print $output_fh $_;
+ }
+ close $output_fh;
+ }
+ print STDERR "DEBUG: Done writing $output_path\n" if $options{debug};
+ } else {
+ print STDERR "DEBUG: Removing $output_path\n" if $options{debug};
+ unless ($options{"dry-run"}) {
+ while (unlink $output_path) {}
+ }
+ }
+ print "$output_path\n";
+
+ foreach (@podfiles) {
+ my $link_file = $_ . $suffix;
+ my $link_path = catfile($output_dir, $link_file);
+ if (! $options{remove}) {
+ if ($symlink_exists) {
+ print STDERR "DEBUG: Linking $link_path -> $output_file\n"
+ if $options{debug};
+ unless ($options{"dry-run"}) {
+ symlink $output_file, $link_path;
+ }
+ } else {
+ print STDERR "DEBUG: Copying $output_path to link_path\n"
+ if $options{debug};
+ unless ($options{"dry-run"}) {
+ copy $output_path, $link_path;
+ }
+ }
+ } else {
+ print STDERR "DEBUG: Removing $link_path\n" if $options{debug};
+ unless ($options{"dry-run"}) {
+ while (unlink $link_path) {}
+ }
+ }
+ print "$link_path -> $output_path\n";
+ }
+ }
+}
+
+__END__
+
+=pod
+
+=head1 NAME
+
+process_docs.pl - A script to process OpenSSL docs
+
+=head1 SYNOPSIS
+
+B<process_docs.pl>
+[B<--sourcedir>=I<dir>]
+B<--destdir>=I<dir>
+B<--type>=B<man>|B<html>
+[B<--suffix>=I<suffix>]
+[B<--remove>]
+[B<--dry-run>|B<-n>]
+[B<--debug>|B<-D>]
+
+=head1 DESCRIPTION
+
+This script looks for .pod files in the subdirectories 'apps', 'crypto'
+and 'ssl' under the given source directory.
+
+The OpenSSL configuration data file F<configdata.pm> I<must> reside in
+the current directory, I<or> perl must have the directory it resides in
+in its inclusion array. For the latter variant, a call like this would
+work:
+
+ perl -I../foo util/process_docs.pl {options ...}
+
+=head1 OPTIONS
+
+=over 4
+
+=item B<--sourcedir>=I<dir>
+
+Top directory where the source files are found.
+
+=item B<--destdir>=I<dir>
+
+Top directory where the resulting files should end up
+
+=item B<--type>=B<man>|B<html>
+
+Type of output to produce. Currently supported are man pages and HTML files.
+
+=item B<--suffix>=I<suffix>
+
+A suffix added to the extension. Only valid with B<--type>=B<man>
+
+=item B<--remove>
+
+Instead of writing the files, remove them.
+
+=item B<--dry-run>|B<-n>
+
+Do not perform any file writing, directory creation or file removal.
+
+=item B<--debug>|B<-D>
+
+Print extra debugging output.
+
+=back
+
+=head1 COPYRIGHT
+
+Copyright 2013-2016 The OpenSSL Project Authors. All Rights Reserved.
+
+Licensed under the OpenSSL license (the "License"). You may not use
+this file except in compliance with the License. You can obtain a copy
+in the file LICENSE in the source distribution or at
+https://www.openssl.org/source/license.html
+
+=cut
diff --git a/openssl-1.1.0h/util/selftest.pl b/openssl-1.1.0h/util/selftest.pl
new file mode 100644
index 0000000..d1d1159
--- /dev/null
+++ b/openssl-1.1.0h/util/selftest.pl
@@ -0,0 +1,207 @@
+#! /usr/bin/env perl
+# Copyright 2000-2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+# Run the test suite and generate a report
+
+if (! -f "Configure") {
+ print "Please run perl util/selftest.pl in the OpenSSL directory.\n";
+ exit 1;
+}
+
+my $report="testlog";
+my $os="??";
+my $version="??";
+my $platform0="??";
+my $platform="??";
+my $options="??";
+my $last="??";
+my $ok=0;
+my $cc="cc";
+my $cversion="??";
+my $sep="-----------------------------------------------------------------------------\n";
+my $not_our_fault="\nPlease ask your system administrator/vendor for more information.\n[Problems with your operating system setup should not be reported\nto the OpenSSL project.]\n";
+
+open(OUT,">$report") or die;
+
+print OUT "OpenSSL self-test report:\n\n";
+
+$uname=`uname -a`;
+$uname="??\n" if $uname eq "";
+
+$c=`sh config -t`;
+foreach $_ (split("\n",$c)) {
+ $os=$1 if (/Operating system: (.*)$/);
+ $platform0=$1 if (/Configuring for (.*)$/);
+}
+
+system "sh config" if (! -f "Makefile");
+
+if (open(IN,"<Makefile")) {
+ while (<IN>) {
+ $version=$1 if (/^VERSION=(.*)$/);
+ $platform=$1 if (/^PLATFORM=(.*)$/);
+ $options=$1 if (/^OPTIONS=(.*)$/);
+ $cc=$1 if (/^CC= *(.*)$/);
+ }
+ close(IN);
+} else {
+ print OUT "Error running config!\n";
+}
+
+$cversion=`$cc -v 2>&1`;
+$cversion=`$cc -V 2>&1` if $cversion =~ "[Uu]sage";
+$cversion=`$cc -V |head -1` if $cversion =~ "Error";
+$cversion=`$cc --version` if $cversion eq "";
+$cversion =~ s/Reading specs.*\n//;
+$cversion =~ s/usage.*\n//;
+$cversion =~ s|\R$||;
+
+if (open(IN,"<CHANGES")) {
+ while(<IN>) {
+ if (/\*\) (.{0,55})/ && !/applies to/) {
+ $last=$1;
+ last;
+ }
+ }
+ close(IN);
+}
+
+print OUT "OpenSSL version: $version\n";
+print OUT "Last change: $last...\n";
+print OUT "Options: $options\n" if $options ne "";
+print OUT "OS (uname): $uname";
+print OUT "OS (config): $os\n";
+print OUT "Target (default): $platform0\n";
+print OUT "Target: $platform\n";
+print OUT "Compiler: $cversion\n";
+print OUT "\n";
+
+print "Checking compiler...\n";
+if (open(TEST,">cctest.c")) {
+ print TEST "#include <stdio.h>\n#include <stdlib.h>\n#include <errno.h>\nmain(){printf(\"Hello world\\n\");}\n";
+ close(TEST);
+ system("$cc -o cctest cctest.c");
+ if (`./cctest` !~ /Hello world/) {
+ print OUT "Compiler doesn't work.\n";
+ print OUT $not_our_fault;
+ goto err;
+ }
+ system("ar r cctest.a /dev/null");
+ if (not -f "cctest.a") {
+ print OUT "Check your archive tool (ar).\n";
+ print OUT $not_our_fault;
+ goto err;
+ }
+} else {
+ print OUT "Can't create cctest.c\n";
+}
+if (open(TEST,">cctest.c")) {
+ print TEST "#include <stdio.h>\n#include <stdlib.h>\n#include <openssl/opensslv.h>\nmain(){printf(OPENSSL_VERSION_TEXT);}\n";
+ close(TEST);
+ system("$cc -o cctest -Iinclude cctest.c");
+ $cctest = `./cctest`;
+ if ($cctest !~ /OpenSSL $version/) {
+ if ($cctest =~ /OpenSSL/) {
+ print OUT "#include uses headers from different OpenSSL version!\n";
+ } else {
+ print OUT "Can't compile test program!\n";
+ }
+ print OUT $not_our_fault;
+ goto err;
+ }
+} else {
+ print OUT "Can't create cctest.c\n";
+}
+
+print "Running make...\n";
+if (system("make 2>&1 | tee make.log") > 255) {
+
+ print OUT "make failed!\n";
+ if (open(IN,"<make.log")) {
+ print OUT $sep;
+ while (<IN>) {
+ print OUT;
+ }
+ close(IN);
+ print OUT $sep;
+ } else {
+ print OUT "make.log not found!\n";
+ }
+ goto err;
+}
+
+# Not sure why this is here. The tests themselves can detect if their
+# particular feature isn't included, and should therefore skip themselves.
+# To skip *all* tests just because one algorithm isn't included is like
+# shooting mosquito with an elephant gun...
+# -- Richard Levitte, inspired by problem report 1089
+#
+#$_=$options;
+#s/no-asm//;
+#s/no-shared//;
+#s/no-krb5//;
+#if (/no-/)
+#{
+# print OUT "Test skipped.\n";
+# goto err;
+#}
+
+print "Running make test...\n";
+if (system("make test 2>&1 | tee maketest.log") > 255)
+ {
+ print OUT "make test failed!\n";
+} else {
+ $ok=1;
+}
+
+if ($ok and open(IN,"<maketest.log")) {
+ while (<IN>) {
+ $ok=2 if /^platform: $platform/;
+ }
+ close(IN);
+}
+
+if ($ok != 2) {
+ print OUT "Failure!\n";
+ if (open(IN,"<make.log")) {
+ print OUT $sep;
+ while (<IN>) {
+ print OUT;
+ }
+ close(IN);
+ print OUT $sep;
+ } else {
+ print OUT "make.log not found!\n";
+ }
+ if (open(IN,"<maketest.log")) {
+ while (<IN>) {
+ print OUT;
+ }
+ close(IN);
+ print OUT $sep;
+ } else {
+ print OUT "maketest.log not found!\n";
+ }
+} else {
+ print OUT "Test passed.\n";
+}
+err:
+close(OUT);
+
+print "\n";
+open(IN,"<$report") or die;
+while (<IN>) {
+ if (/$sep/) {
+ print "[...]\n";
+ last;
+ }
+ print;
+}
+print "\nTest report in file $report\n";
+
+die if $ok != 2;
diff --git a/openssl-1.1.0h/util/shlib_wrap.sh.in b/openssl-1.1.0h/util/shlib_wrap.sh.in
new file mode 100755
index 0000000..6c115ba
--- /dev/null
+++ b/openssl-1.1.0h/util/shlib_wrap.sh.in
@@ -0,0 +1,128 @@
+#!/bin/sh
+
+# To test this OpenSSL version's applications against another version's
+# shared libraries, simply set
+#
+# OPENSSL_REGRESSION=/path/to/other/OpenSSL/build/tree
+if [ -n "$OPENSSL_REGRESSION" ]; then
+ shlibwrap="$OPENSSL_REGRESSION/util/shlib_wrap.sh"
+ if [ -x "$shlibwrap" ]; then
+ # We clear OPENSSL_REGRESSION to avoid a loop, should the shlib_wrap.sh
+ # we exec also support that mechanism...
+ OPENSSL_REGRESSION= exec "$shlibwrap" "$@"
+ else
+ if [ -f "$shlibwrap" ]; then
+ echo "Not permitted to run $shlibwrap" >&2
+ else
+ echo "No $shlibwrap, perhaps OPENSSL_REGRESSION isn't properly set?" >&2
+ fi
+ exit 1
+ fi
+fi
+
+[ $# -ne 0 ] || set -x # debug mode without arguments:-)
+
+THERE="`echo $0 | sed -e 's|[^/]*$||' 2>/dev/null`.."
+[ -d "${THERE}" ] || exec "$@" # should never happen...
+
+# Alternative to this is to parse ${THERE}/Makefile...
+LIBCRYPTOSO="${THERE}/libcrypto.so"
+if [ -f "$LIBCRYPTOSO" ]; then
+ while [ -h "$LIBCRYPTOSO" ]; do
+ LIBCRYPTOSO="${THERE}/`ls -l "$LIBCRYPTOSO" | sed -e 's|.*\-> ||'`"
+ done
+ SOSUFFIX=`echo ${LIBCRYPTOSO} | sed -e 's|.*\.so||' 2>/dev/null`
+ LIBSSLSO="${THERE}/libssl.so${SOSUFFIX}"
+fi
+
+SYSNAME=`(uname -s) 2>/dev/null`;
+case "$SYSNAME" in
+SunOS|IRIX*)
+ # SunOS and IRIX run-time linkers evaluate alternative
+ # variables depending on target ABI...
+ rld_var=LD_LIBRARY_PATH
+ case "`(/usr/bin/file "$LIBCRYPTOSO") 2>/dev/null`" in
+ *ELF\ 64*SPARC*|*ELF\ 64*AMD64*)
+ [ -n "$LD_LIBRARY_PATH_64" ] && rld_var=LD_LIBRARY_PATH_64
+ LD_PRELOAD_64="$LIBCRYPTOSO $LIBSSLSO"; export LD_PRELOAD_64
+ preload_var=LD_PRELOAD_64
+ ;;
+ *ELF\ 32*SPARC*|*ELF\ 32*80386*)
+ # We only need to change LD_PRELOAD_32 and LD_LIBRARY_PATH_32
+ # on a multi-arch system. Otherwise, trust the fallbacks.
+ if [ -f /lib/64/ld.so.1 ]; then
+ [ -n "$LD_LIBRARY_PATH_32" ] && rld_var=LD_LIBRARY_PATH_32
+ LD_PRELOAD_32="$LIBCRYPTOSO $LIBSSLSO"; export LD_PRELOAD_32
+ preload_var=LD_PRELOAD_32
+ fi
+ ;;
+ # Why are newly built .so's preloaded anyway? Because run-time
+ # .so lookup path embedded into application takes precedence
+ # over LD_LIBRARY_PATH and as result application ends up linking
+ # to previously installed .so's. On IRIX instead of preloading
+ # newly built .so's we trick run-time linker to fail to find
+ # the installed .so by setting _RLD_ROOT variable.
+ *ELF\ 32*MIPS*)
+ #_RLD_LIST="$LIBCRYPTOSO:$LIBSSLSO:DEFAULT"; export _RLD_LIST
+ _RLD_ROOT=/no/such/dir; export _RLD_ROOT
+ eval $rld_var=\"/usr/lib'${'$rld_var':+:$'$rld_var'}'\"
+ preload_var=_RLD_LIST
+ ;;
+ *ELF\ N32*MIPS*)
+ [ -n "$LD_LIBRARYN32_PATH" ] && rld_var=LD_LIBRARYN32_PATH
+ #_RLDN32_LIST="$LIBCRYPTOSO:$LIBSSLSO:DEFAULT"; export _RLDN32_LIST
+ _RLDN32_ROOT=/no/such/dir; export _RLDN32_ROOT
+ eval $rld_var=\"/usr/lib32'${'$rld_var':+:$'$rld_var'}'\"
+ preload_var=_RLDN32_LIST
+ ;;
+ *ELF\ 64*MIPS*)
+ [ -n "$LD_LIBRARY64_PATH" ] && rld_var=LD_LIBRARY64_PATH
+ #_RLD64_LIST="$LIBCRYPTOSO:$LIBSSLSO:DEFAULT"; export _RLD64_LIST
+ _RLD64_ROOT=/no/such/dir; export _RLD64_ROOT
+ eval $rld_var=\"/usr/lib64'${'$rld_var':+:$'$rld_var'}'\"
+ preload_var=_RLD64_LIST
+ ;;
+ esac
+ eval $rld_var=\"${THERE}'${'$rld_var':+:$'$rld_var'}'\"; export $rld_var
+ unset rld_var
+ ;;
+*) LD_LIBRARY_PATH="${THERE}:$LD_LIBRARY_PATH" # Linux, ELF HP-UX
+ DYLD_LIBRARY_PATH="${THERE}:$DYLD_LIBRARY_PATH" # MacOS X
+ SHLIB_PATH="${THERE}:$SHLIB_PATH" # legacy HP-UX
+ LIBPATH="${THERE}:$LIBPATH" # AIX, OS/2
+ export LD_LIBRARY_PATH DYLD_LIBRARY_PATH SHLIB_PATH LIBPATH
+ # Even though $PATH is adjusted [for Windows sake], it doesn't
+ # necessarily does the trick. Trouble is that with introduction
+ # of SafeDllSearchMode in XP/2003 it's more appropriate to copy
+ # .DLLs in vicinity of executable, which is done elsewhere...
+ if [ "$OSTYPE" != msdosdjgpp ]; then
+ PATH="${THERE}:$PATH"; export PATH
+ fi
+ ;;
+esac
+
+{- output_off() if $config{ex_libs} !~ /,-rpath,/; ""; -}
+if [ -f "$LIBCRYPTOSO" -a -z "$preload_var" ]; then
+ # Following three lines are major excuse for isolating them into
+ # this wrapper script. Original reason for setting LD_PRELOAD
+ # was to make it possible to pass 'make test' when user linked
+ # with -rpath pointing to previous version installation. Wrapping
+ # it into a script makes it possible to do so on multi-ABI
+ # platforms.
+ case "$SYSNAME" in
+ *BSD|QNX) LD_PRELOAD="$LIBCRYPTOSO:$LIBSSLSO" ;; # *BSD, QNX
+ *) LD_PRELOAD="$LIBCRYPTOSO $LIBSSLSO" ;; # SunOS, Linux, ELF HP-UX
+ esac
+ _RLD_LIST="$LIBCRYPTOSO:$LIBSSLSO:DEFAULT" # Tru64, o32 IRIX
+ DYLD_INSERT_LIBRARIES="$LIBCRYPTOSO:$LIBSSLSO" # MacOS X
+ export LD_PRELOAD _RLD_LIST DYLD_INSERT_LIBRARIES
+fi
+{- output_on() if $config{ex_libs} !~ /,-rpath,/; ""; -}
+
+cmd="$1"; [ -x "$cmd" ] || cmd="$cmd${EXE_EXT}"
+shift
+if [ $# -eq 0 ]; then
+ exec "$cmd" # old sh, such as Tru64 4.x, fails to expand empty "$@"
+else
+ exec "$cmd" "$@"
+fi
diff --git a/openssl-1.1.0h/util/su-filter.pl b/openssl-1.1.0h/util/su-filter.pl
new file mode 100644
index 0000000..5996f58
--- /dev/null
+++ b/openssl-1.1.0h/util/su-filter.pl
@@ -0,0 +1,264 @@
+#! /usr/bin/env perl
+# Copyright 2015-2016 The OpenSSL Project Authors. All Rights Reserved.
+#
+# Licensed under the OpenSSL license (the "License"). You may not use
+# this file except in compliance with the License. You can obtain a copy
+# in the file LICENSE in the source distribution or at
+# https://www.openssl.org/source/license.html
+
+use strict;
+
+my $in_su = 0;
+my $indent = 0;
+my $out;
+my $braces = 0;
+my $arrcnt;
+my $data;
+my $tststr;
+my $incomm = 0;
+
+while(<>) {
+ $tststr = $_;
+ $incomm++ while $tststr =~ /\/\*/g;
+ $incomm-- while $tststr =~ /\*\//g;
+
+ if($in_su == 1) {
+ if(/}(.*);/) {
+ $out .= $_;
+ do_output($out);
+ $in_su = 0;
+ } elsif(/^ *\} [^\s]+(\[\d*\])* = \{/) {
+ $tststr = $1;
+ $arrcnt = 0;
+ $arrcnt++ while $tststr =~ /\[/g;
+ $in_su++;
+ $braces = 1;
+ /^(.* = \{)(.*)$/;
+ $data = $2;
+ $out .= $1."\n";
+ } else {
+ $out .= $_;
+ }
+ } elsif($in_su == 2) {
+ $data .= $_;
+ if(/};$/) {
+ #$data = "\n$data";
+ $data =~ s/\n */\n/g;
+ $data =~ s/};\n?//s;
+ my @strucdata = structureData($data);
+ $out .= displayData($indent, 0, \@strucdata);
+ $out .= "\n$indent};\n";
+ do_output($out);
+ $in_su = 0;
+ }
+ } elsif($incomm <= 0 && /( *)(static )?(const )?(union|struct) ([a-zA-Z_\$][\$0-9a-zA-Z_]+ )?\{/) {
+ $in_su = 1;
+ $indent = $1;
+ $out = $_;
+ next;
+ } else {
+ do_output($_);
+ }
+}
+
+
+sub structureData {
+ my $data = $_[0];
+ my @datalist = split(/(\{|\}|,|"|#|\n|\/\*|\*\/|\(|\))/, $data);
+ my $item;
+ my $dataitem = "";
+ my @struclist = ();
+ my $substruc;
+ my $inquote = 0;
+ my $inbrace = 0;
+ my $preproc = 0;
+ my $comment = 0;
+ my $inparen = 0;
+
+
+ foreach $item (@datalist) {
+ if($comment) {
+ if($item eq "*/") {
+ $comment = 0;
+ $dataitem .= "*/";
+ push @struclist, $dataitem;
+ $dataitem = "";
+ next;
+ }
+ $dataitem .= $item;
+ next;
+ }
+ if($inquote) {
+ $dataitem .= $item;
+ if($item eq "\"") {
+ $inquote--;
+ }
+ next;
+ }
+ if($preproc) {
+ if($item eq "\n") {
+ $preproc = 0;
+ push @struclist, $dataitem;
+ $dataitem = "";
+ next;
+ }
+ $dataitem .= $item;
+ next;
+ }
+ if($inbrace) {
+ if($item eq "}") {
+ $inbrace --;
+
+ if(!$inbrace) {
+ $substruc = structureData($dataitem);
+ $dataitem = $substruc;
+ next;
+ }
+ } elsif($item eq "{") {
+ $inbrace++;
+ } elsif ($item eq "\"") {
+ $inquote++;
+ }
+ $dataitem .= $item;
+ next;
+ }
+ if($inparen) {
+ if($item eq ")") {
+ $inparen--;
+ }
+ $dataitem .= $item;
+ next;
+ }
+ if($item eq "\n") {
+ next;
+ }
+ if($item eq "#") {
+ $preproc = 1;
+ push @struclist, $dataitem;
+ $dataitem = "#";
+ next;
+ }
+ if($item eq "/*") {
+ $comment = 1;
+ push @struclist, $dataitem;
+ $dataitem= "/*";
+ next;
+ }
+ if($item eq "\"") {
+ $dataitem .= $item;
+ $inquote++;
+ next;
+ }
+ if($item eq "{") {
+ $inbrace++;
+ next;
+ }
+ if($item eq ",") {
+ push @struclist, $dataitem;
+ $dataitem = "";
+ next;
+ }
+ if($item eq "(") {
+ $dataitem .= $item;
+ $inparen++;
+ next;
+ }
+ if($item =~ /^\s*$/) {
+ next;
+ }
+ if(ref $dataitem eq 'ARRAY') {
+ push @struclist, $dataitem;
+ $dataitem = "";
+ }
+ $dataitem .= $item;
+ }
+ push @struclist, $dataitem;
+ return \@struclist;
+}
+
+sub displayData {
+ my $indent = shift;
+ my $depth = shift;
+ my $data = shift;
+ my $item;
+ my $out = "";
+ my $currline = "";
+ my $first = 1;
+ my $prevpreproc = 0;
+ my $prevcomment = 0;
+
+ foreach $item (@{$data}) {
+ if($item =~ /^\/\*/) {
+ #Comment
+ $item =~ s/\n/\n$indent/g;
+ if($out =~ /\n\s*$/s) {
+ $out .= $item."\n".$indent;
+ } else {
+ $out .= "\n".$indent.$item."\n".$indent;
+ }
+ $currline = $indent;
+ $prevcomment = 1;
+ next;
+ }
+ $item =~ s/^\s+//;
+ if($item =~ /^#/) {
+ #Pre-processor directive
+ if($out =~ /\n\s*$/s) {
+ $out =~ s/\n\s*$/\n/;
+ $out .= $item."\n".$indent;
+ } else {
+ $out .= "\n".$item."\n".$indent;
+ }
+ $currline = $indent;
+ $prevpreproc = 1;
+ next;
+ }
+ if($first) {
+ $first = 0;
+ if($depth != 0) {
+ $out .= $indent;
+ $currline = $indent;
+ }
+ } else {
+ if(!$prevpreproc && !$prevcomment) {
+ $out .= ", ";
+ $currline .= ", ";
+ if($depth == 1) {
+ $out .= "\n";
+ $currline = "";
+ }
+ if($depth == 1) {
+ $out .= $indent;
+ $currline .= $indent;
+ }
+ }
+
+ }
+ $prevpreproc = 0;
+ $prevcomment = 0;
+
+ if (ref $item eq 'ARRAY') {
+ if($depth == 0) {
+ $out .= displayData("$indent ", $depth+1, $item);
+ } else {
+ $out .= "{\n".displayData("$indent ", $depth+1, $item)."\n".$indent."}";
+ $currline = $indent."}";
+ }
+ } else {
+ if(length $currline.$item > 79) {
+ $currline = $indent;
+ $out .= "\n$indent";
+ }
+ $out .= $item;
+ $currline .= $item;
+ }
+ }
+ return $out;
+}
+
+sub do_output {
+ my $out = shift;
+ # Strip any trailing whitespace
+ $out =~ s/\s+\n/\n/g;
+ print $out;
+}
diff --git a/openssl-1.1.0h/util/unlocal_shlib.com.in b/openssl-1.1.0h/util/unlocal_shlib.com.in
new file mode 100644
index 0000000..dd4fd2a
--- /dev/null
+++ b/openssl-1.1.0h/util/unlocal_shlib.com.in
@@ -0,0 +1,26 @@
+${-
+ use File::Spec::Functions qw(rel2abs);
+
+ my $bldtop = rel2abs($config{builddir});
+ our %names = ( map { $_ => $bldtop.$_.".EXE" }
+ map { $unified_info{sharednames}->{$_} || () }
+ @{$unified_info{libraries}} );
+ "" -}
+$ ! Remove the local environment created by local_shlib.com
+$
+$ OPENSSL_NAMES := OPENSSL_NAMES_'F$GETJPI("","PID")'
+$ IF F$TRNLNM("OSSL_FLAG",OPENSSL_NAMES) .EQS. "" THEN EXIT 0
+$
+$ NAMES := {- join(",", keys %names); -}
+$ I = 0
+$ LOOP:
+$ E = F$ELEMENT(I,",",NAMES)
+$ I = I + 1
+$ IF E .EQS. "," THEN GOTO ENDLOOP
+$ OLDV = F$TRNLNM(E,OPENSSL_NAMES)
+$ DEASSIGN 'E'
+$ IF OLDV .NES. "" THEN DEFINE 'E' 'OLDV'
+$ GOTO LOOP
+$ ENDLOOP:
+$
+$ DEASSIGN 'OPENSSL_NAMES' /TABLE=LNM$PROCESS_DIRECTORY