From: Richard Levitte Date: Sat, 30 Jan 2016 02:25:40 +0000 (+0100) Subject: unified build scheme: add a "unified" template for Unix Makefile X-Git-Tag: OpenSSL_1_1_0-pre3~139 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=567a9e6fe0ff3badfa22cf018d87c94ed5a8aeb3;p=oweals%2Fopenssl.git unified build scheme: add a "unified" template for Unix Makefile This also adds all the raw sections needed for some files. Reviewed-by: Rich Salz --- diff --git a/Configurations/unix-Makefile.tmpl b/Configurations/unix-Makefile.tmpl new file mode 100644 index 0000000000..5e9e10bcad --- /dev/null +++ b/Configurations/unix-Makefile.tmpl @@ -0,0 +1,750 @@ +## +## Makefile for OpenSSL +## +## {- join("\n## ", @autowarntext) -} +{- + sub windowsdll { $config{target} =~ /^(?:Cygwin|mingw)/ } + sub shlib_ext { $target{shared_extension} || ".so" } + sub shlib_ext_simple { (my $x = $target{shared_extension}) + =~ s/\.\$\(SHLIB_MAJOR\)\.\$\(SHLIB_MINOR\)//; + $x } +-} +PLATFORM={- $config{target} -} +OPTIONS={- $config{options} -} +CONFIGURE_ARGS=({- join(", ",quotify_l(@{$config{perlargv}})) -}) +SRCDIR={- $config{sourcedir} -} +BLDDIR={- $config{builddir} -} + +VERSION={- $config{version} -} +MAJOR={- $config{major} -} +MINOR={- $config{minor} -} +SHLIB_VERSION_NUMBER={- $config{shlib_version_number} -} +SHLIB_VERSION_HISTORY={- $config{shlib_version_history} -} +SHLIB_MAJOR={- $config{shlib_major} -} +SHLIB_MINOR={- $config{shlib_minor} -} +SHLIB_TARGET={- $target{shared_target} -} + +EXE_EXT={- $target{exe_extension} || "" -} +LIB_EXT={- $target{lib_extension} || ".a" -} +SHLIB_EXT={- shlib_ext() -} +SHLIB_EXT_SIMPLE={- shlib_ext_simple() -} +OBJ_EXT={- $target{obj_extension} || ".o" -} +DEP_EXT={- $target{dep_extension} || ".d" -} + +LIBS={- join(" ", map { $_."\$(LIB_EXT)" } @{$unified_info{libraries}}) -} +SHLIBS={- join(" ", map { $_."\$(SHLIB_EXT)" } map { $unified_info{sharednames}->{$_} || () } @{$unified_info{libraries}}) -} +ENGINES={- join(" ", map { $_."\$(SHLIB_EXT_SIMPLE)" } @{$unified_info{engines}}) -} +PROGRAMS={- join(" ", map { $_."\$(EXE_EXT)" } grep { !m|^test/| } @{$unified_info{programs}}) -} +TESTPROGS={- join(" ", map { $_."\$(EXE_EXT)" } grep { m|^test/| } @{$unified_info{programs}}) -} +SCRIPTS={- join(" ", @{$unified_info{scripts}}) -} +BIN_SCRIPTS=$(BLDDIR)/tools/c_rehash +MISC_SCRIPTS=$(SRCDIR)/tools/c_hash $(SRCDIR)/tools/c_info \ + $(SRCDIR)/tools/c_issuer $(SRCDIR)/tools/c_name \ + $(BLDDIR)/apps/CA.pl $(SRCDIR)/apps/tsget + +# INSTALL_PREFIX is for package builders so that they can configure +# for, say, /usr/ and yet have everything installed to /tmp/somedir/usr/. +# Normally it is left empty. +INSTALL_PREFIX={- $config{install_prefix} -} + +# Do not edit these manually. Use Configure with --prefix or --openssldir +# to change this! Short explanation in the top comment in Configure +INSTALLTOP={- # $prefix is used in the OPENSSLDIR perl snippet + # + our $prefix = $config{prefix} || "/usr/local"; + $prefix -} +OPENSSLDIR={- # + # The logic here is that if no --openssldir was given, + # OPENSSLDIR will get the value from $prefix plus "/ssl". + # If --openssldir was given and the value is an absolute + # path, OPENSSLDIR will get its value without change. + # If the value from --openssldir is a relative path, + # OPENSSLDIR will get $prefix with the --openssldir + # value appended as a subdirectory. + # + use File::Spec::Functions; + our $openssldir = + $config{openssldir} ? + (file_name_is_absolute($config{openssldir}) ? + $config{openssldir} + : catdir($prefix, $config{openssldir})) + : catdir($prefix, "ssl"); + $openssldir -} +LIBDIR={- # + # if $prefix/lib$target{multilib} is not an existing + # directory, then assume that it's not searched by linker + # automatically, in which case adding $target{multilib} suffix + # causes more grief than we're ready to tolerate, so don't... + our $multilib = + -d "$prefix/lib$target{multilib}" ? $target{multilib} : ""; + our $libdir = $config{libdir} || "lib$multilib"; + $libdir -} +ENGINESDIR={- use File::Spec::Functions; + catdir($prefix,$libdir,"engines") -} + +MANDIR=$(OPENSSLDIR)/man +HTMLDIR=$(OPENSSLDIR)/html + +MANSUFFIX=ssl +HTMLSUFFIX=html + + + +CROSS_COMPILE= {- $config{cross_compile_prefix} -} +CC= $(CROSS_COMPILE){- $target{cc} -} +CFLAGS={- join(" ",(map { "-D".$_} @{$config{defines}}),"-DOPENSSLDIR=\"\\\"\$(OPENSSLDIR)\\\"\"","-DENGINESDIR=\"\\\"\$(ENGINESDIR)\\\"\"") -} {- $config{cflags} -} +DEPFLAGS= {- join(" ",map { "-D".$_} @{$config{depdefines}}) -} +LDFLAGS= {- $config{lflags} -} +PLIB_LDFLAGS= {- $config{plib_lflags} -} +EX_LIBS= {- $config{ex_libs} -} +SHARED_LDFLAGS={- $target{shared_ldflag} + # Unlike other OSes (like Solaris, Linux, Tru64, + # IRIX) BSD run-time linkers (tested OpenBSD, NetBSD + # and FreeBSD) "demand" RPATH set on .so objects. + # Apparently application RPATH is not global and + # does not apply to .so linked with other .so. + # Problem manifests itself when libssl.so fails to + # load libcrypto.so. One can argue that we should + # engrave this into Makefile.shared rules or into + # BSD-* config lines above. Meanwhile let's try to + # be cautious and pass -rpath to linker only when + # $prefix is not /usr. + . ($config{target} =~ m|^BSD-| && $prefix !~ m|^/usr/.*$| + ? " -Wl,-rpath,\$\$(LIBRPATH)" : "") -} + +PERL={- $config{perl} -} + +ARFLAGS= {- $target{arflags} -} +AR=$(CROSS_COMPILE){- $target{ar} || "ar" -} $(ARFLAGS) r +RANLIB= {- $target{ranlib} -} +NM= $(CROSS_COMPILE){- $target{nm} || "nm" -} +RM= rm -f +TAR= {- $target{tar} || "tar" -} +TARFLAGS= {- $target{tarflags} -} + +BASENAME= openssl +NAME= $(BASENAME)-$(VERSION) +TARFILE= ../$(NAME).tar + +# We let the C compiler driver to take care of .s files. This is done in +# order to be excused from maintaining a separate set of architecture +# dependent assembler flags. E.g. if you throw -mcpu=ultrasparc at SPARC +# gcc, then the driver will automatically translate it to -xarch=v8plus +# and pass it down to assembler. +AS=$(CC) -c +ASFLAG=$(CFLAGS) +PERLASM_SCHEME= {- $target{perlasm_scheme} -} + +# For x86 assembler: Set PROCESSOR to 386 if you want to support +# the 80386. +PROCESSOR= {- $config{processor} -} + +# The main targets ################################################### + +all: Makefile libcrypto.pc libssl.pc openssl.pc $(ENGINES) $(PROGRAMS) $(SCRIPTS) $(TESTPROGS) + +test tests: $(TESTPROGS) rehash + ( cd test; \ + SRCTOP=../$(SRCDIR) \ + BLDTOP=../$(BLDDIR) \ + $(PERL) ../$(SRCDIR)/test/run_tests.pl $(TESTS) ) + +list-tests: + @TOP=$(SRCDIR) PERL=$(PERL) $(PERL) $(SRCDIR)/test/run_tests.pl list + +libclean: + -rm -f `find $(BLDDIR) -name '*$(LIB_EXT)' -o -name '*$(SHLIB_EXT)'` + +install: install_sw install_docs + +uninstall: uninstall_docs uninstall_sw + +clean: libclean + rm -f $(PROGRAMS) $(TESTPROGS) + rm -f `find $(BLDDIR) -name '*$(DEP_EXT)'` + rm -f `find $(BLDDIR) -name '*$(OBJ_EXT)'` + rm -f $(BLDDIR)/core $(BLDDIR)/rehash.time + rm -f $(BLDDIR)/tags $(BLDDIR)/TAGS + rm -f $(BLDDIR)/openssl.pc $(BLDDIR)/libcrypto.pc $(BLDDIR)/libssl.pc + -rm -f `find $(BLDDIR) -type l` + rm -f $(TARFILE) + +DCLEAN_CMD=sed -e '/^DO NOT DELETE.*/,$$d' +dclean: + $(DCLEAN_CMD) < Makefile >Makefile.new + mv -f Makefile.new Makefile + +DEPS={- join(" ", map { (my $x = $_) =~ s|\.o$|\$(DEP_EXT)|; $x; } + grep { $unified_info{sources}->{$_}->[0] =~ /\.c$/ } + keys %{$unified_info{sources}}); -} +depend: $(DEPS) + ( $(DCLEAN_CMD) < Makefile; \ + echo '# DO NOT DELETE THIS LINE -- make depend depends on it.'; \ + echo; \ + cat `find . -name '*$(DEP_EXT)'` ) > Makefile.new + mv -f Makefile.new Makefile + +# Install helper targets ############################################# + +install_sw: all install_dev install_engines install_runtime + +uninstall_sw: uninstall_dev uninstall_engines uninstall_runtime + +install_docs: install_man_docs install_html_docs + +uninstall_docs: uninstall_man_docs uninstall_html_docs + +install_dev: + @[ -n "$(INSTALLTOP)" ] || (echo INSTALLTOP should not be empty; exit 1) + @echo "*** Installing development files" + @$(PERL) $(SRCDIR)/util/mkdir-p.pl $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl + @set -e; for i in $(SRCDIR)/include/openssl/*.h \ + $(BLDDIR)/include/openssl/*.h; do \ + fn=`basename $$i`; \ + echo "install $$i -> $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$fn"; \ + cp $$i $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$fn; \ + chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$fn; \ + done + @$(PERL) $(SRCDIR)/util/mkdir-p.pl $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR) + @set -e; for l in $(LIBS); do \ + fn=`basename $$l`; \ + echo "install $$l -> $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn"; \ + cp $$l $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn.new; \ + $(RANLIB) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn.new; \ + chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn.new; \ + mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn.new \ + $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn; \ + done + @ : {- output_off() if $config{no_shared}; "" -} + @set -e; for s in $(SHLIBS); do \ + fn=`basename $$s`; \ + echo "install $$s -> $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn"; \ + cp $$s $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn.new; \ + chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn.new; \ + mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn.new \ + $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn; \ + if [ "$(SHLIB_EXT)" != "$(SHLIB_EXT_SIMPLE)" ]; then \ + echo "link $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn2 -> $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn"; \ + fn2=`basename $$fn $(SHLIB_EXT)`$(SHLIB_EXT_SIMPLE); \ + ln -sf $$fn $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn2; \ + fi; \ + done + @ : {- output_on() -} + @$(PERL) $(SRCDIR)/util/mkdir-p.pl $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig + @echo "install libcrypto.pc -> $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/libcrypto.pc" + @cp libcrypto.pc $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig + @chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/libcrypto.pc + @echo "install libssl.pc -> $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/libssl.pc" + @cp libssl.pc $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig + @chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/libssl.pc + @echo "install openssl.pc -> $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/openssl.pc" + @cp openssl.pc $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig + @chmod 644 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/openssl.pc + +uninstall_dev: + @echo "*** Uninstalling development files" + @set -e; for i in $(SRCDIR)/include/openssl/*.h \ + $(BLDDIR)/include/openssl/*.h; do \ + fn=`basename $$i`; \ + echo "$(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$fn"; \ + $(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/include/openssl/$$fn; \ + done + @set -e; for l in $(LIBS); do \ + fn=`basename $$l`; \ + echo "$(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn"; \ + $(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn; \ + done + @set -e; for s in $(SHLIBS); do \ + fn=`basename $$s`; \ + if [ "$(SHLIB_EXT)" != "$(SHLIB_EXT_SIMPLE)" ]; then \ + fn2=`basename $$fn $(SHLIB_EXT)`$(SHLIB_EXT_SIMPLE); \ + echo "$(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn2"; \ + $(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn2; \ + fi; \ + echo "$(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn"; \ + $(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/$$fn; \ + done + @echo "$(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/libcrypto.pc" + @$(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/libcrypto.pc + @echo "$(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/libssl.pc" + @$(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/libssl.pc + @echo "$(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/openssl.pc" + @$(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/pkgconfig/openssl.pc + +install_engines: + @[ -n "$(INSTALLTOP)" ] || (echo INSTALLTOP should not be empty; exit 1) + @$(PERL) $(SRCDIR)/util/mkdir-p.pl $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/engines/ + @echo "*** Installing engines" + @set -e; for e in $(ENGINES); do \ + fn=`basename $$e`; \ + echo "install $$e -> $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn"; \ + cp $$e $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/engines/$$fn.new; \ + chmod 755 $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/engines/$$fn.new; \ + mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/engines/$$fn.new \ + $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/engines/$$fn; \ + done + +uninstall_engines: + @echo "*** Uninstalling engines" + @set -e; for e in $(ENGINES); do \ + fn=`basename $$e`; \ + echo "$(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn"; \ + $(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/$(LIBDIR)/engines/$$fn; \ + done + +install_runtime: + @[ -n "$(INSTALLTOP)" ] || (echo INSTALLTOP should not be empty; exit 1) + @$(PERL) $(SRCDIR)/util/mkdir-p.pl $(INSTALL_PREFIX)$(INSTALLTOP)/bin + @$(PERL) $(SRCDIR)/util/mkdir-p.pl $(INSTALL_PREFIX)$(OPENSSLDIR)/misc + @echo "*** Installing runtime files" + @set -e; for x in $(PROGRAMS); do \ + fn=`basename $$x`; \ + echo "install $$x -> $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn"; \ + cp $$x $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn.new; \ + chmod 755 $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn.new; \ + mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn.new \ + $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn; \ + done + @set -e; for x in $(BIN_SCRIPTS); do \ + fn=`basename $$x`; \ + echo "install $$x -> $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn"; \ + cp $$x $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn.new; \ + chmod 755 $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn.new; \ + mv -f $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn.new \ + $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn; \ + done + @set -e; for x in $(MISC_SCRIPTS); do \ + fn=`basename $$x`; \ + echo "install $$x -> $(INSTALL_PREFIX)$(OPENSSLDIR)/misc/$$fn"; \ + cp $$x $(INSTALL_PREFIX)$(OPENSSLDIR)/misc/$$fn.new; \ + chmod 755 $(INSTALL_PREFIX)$(OPENSSLDIR)/misc/$$fn.new; \ + mv -f $(INSTALL_PREFIX)$(OPENSSLDIR)/misc/$$fn.new \ + $(INSTALL_PREFIX)$(OPENSSLDIR)/misc/$$fn; \ + done + @echo "install $(SRCDIR)/apps/openssl.cnf -> $(INSTALL_PREFIX)$(OPENSSLDIR)/openssl.cnf" + @cp $(SRCDIR)/apps/openssl.cnf $(INSTALL_PREFIX)$(OPENSSLDIR)/openssl.cnf.new + @chmod 644 $(INSTALL_PREFIX)$(OPENSSLDIR)/openssl.cnf.new + @mv -f $(INSTALL_PREFIX)$(OPENSSLDIR)/openssl.cnf.new $(INSTALL_PREFIX)$(OPENSSLDIR)/openssl.cnf + +uninstall_runtime: + @echo "*** Uninstalling runtime files" + @set -e; for x in $(PROGRAMS); \ + do \ + fn=`basename $$x`; \ + echo "$(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn"; \ + $(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn; \ + done; + @set -e; for x in $(BIN_SCRIPTS); \ + do \ + fn=`basename $$x`; \ + echo "$(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn"; \ + $(RM) $(INSTALL_PREFIX)$(INSTALLTOP)/bin/$$fn; \ + done + @set -e; for x in $(MISC_SCRIPTS); \ + do \ + fn=`basename $$x`; \ + echo "$(RM) $(INSTALL_PREFIX)$(OPENSSLDIR)/misc/$$fn"; \ + $(RM) $(INSTALL_PREFIX)$(OPENSSLDIR)/misc/$$fn; \ + done + $(RM) $(INSTALL_PREFIX)$(OPENSSLDIR)/openssl.cnf + +# A method to extract all names from a .pod file +# The first sed extracts everything between "=head1 NAME" and the next =head1 +# The second sed joins all the lines into one +# The third sed removes the description and turns all commas into spaces +# Voilà, you have a space separated list of names! +EXTRACT_NAMES=sed -e '1,/^=head1 *NAME *$$/d;/^=head1/,$$d' | \ + sed -e ':a;{N;s/\n/ /;ba}' | \ + sed -e 's/ - .*$$//;s/,/ /g' +PROCESS_PODS=\ + set -e; \ + here=`cd $(SRCDIR); pwd`; \ + point=$$here/util/point.sh; \ + for ds in apps:1 crypto:3 ssl:3; do \ + defdir=`echo $$ds | cut -f1 -d:`; \ + defsec=`echo $$ds | cut -f2 -d:`; \ + for p in $(SRCDIR)/doc/$$defdir/*.pod; do \ + SEC=`sed -ne 's/^=for *comment *openssl_manual_section: *\([0-9]\) *$$/\1/p' $$p`; \ + [ -z "$$SEC" ] && SEC=$$defsec; \ + fn=`basename $$p .pod`; \ + NAME=`echo $$fn | tr [a-z] [A-Z]`; \ + suf=`eval "echo $$OUTSUFFIX"`; \ + top=`eval "echo $$OUTTOP"`; \ + $(PERL) $(SRCDIR)/util/mkdir-p.pl $$top/man$$SEC; \ + echo "install $$p -> $$top/man$$SEC/$$fn$$suf"; \ + cat $$p | eval "$$GENERATE" \ + > $$top/man$$SEC/$$fn$$suf; \ + names=`cat $$p | $(EXTRACT_NAMES)`; \ + ( cd $$top/man$$SEC; \ + for n in $$names; do \ + if [ "$$n" != "$$fn" ]; then \ + echo "link $$top/man$$SEC/$$n$$suf -> $$top/man$$SEC/$$fn$$suf"; \ + PLATFORM=$(PLATFORM) $$point $$fn$$suf $$n$$suf; \ + fi; \ + done ); \ + done; \ + done +UNINSTALL_DOCS=\ + set -e; \ + here=`cd $(SRCDIR); pwd`; \ + for ds in apps:1 crypto:3 ssl:3; do \ + defdir=`echo $$ds | cut -f1 -d:`; \ + defsec=`echo $$ds | cut -f2 -d:`; \ + for p in $(SRCDIR)/doc/$$defdir/*.pod; do \ + SEC=`sed -ne 's/^=for *comment *openssl_manual_section: *\([0-9]\) *$$/\1/p' $$p`; \ + [ -z "$$SEC" ] && SEC=$$defsec; \ + fn=`basename $$p .pod`; \ + suf=`eval "echo $$OUTSUFFIX"`; \ + top=`eval "echo $$OUTTOP"`; \ + echo "$(RM) $$top/man$$SEC/$$fn$$suf"; \ + $(RM) $$top/man$$SEC/$$fn$$suf; \ + names=`cat $$p | $(EXTRACT_NAMES)`; \ + for n in $$names; do \ + if [ "$$n" != "$$fn" ]; then \ + echo "$(RM) $$top/man$$SEC/$$n$$suf"; \ + $(RM) $$top/man$$SEC/$$n$$suf; \ + fi; \ + done; \ + done; \ + done + +install_man_docs: + @[ -n "$(INSTALLTOP)" ] || (echo INSTALLTOP should not be empty; exit 1) + @echo "*** Installing manpages" + @\ + OUTSUFFIX='.$${SEC}$(MANSUFFIX)'; \ + OUTTOP="$(INSTALL_PREFIX)$(MANDIR)"; \ + GENERATE='pod2man --name=$$NAME --section=$$SEC --center=OpenSSL --release=$(VERSION)'; \ + $(PROCESS_PODS) + +uninstall_man_docs: + @echo "*** Uninstalling manpages" + @\ + OUTSUFFIX='.$${SEC}$(MANSUFFIX)'; \ + OUTTOP="$(INSTALL_PREFIX)$(MANDIR)"; \ + $(UNINSTALL_DOCS) + +install_html_docs: + @[ -n "$(INSTALLTOP)" ] || (echo INSTALLTOP should not be empty; exit 1) + @echo "*** Installing HTML manpages" + @\ + OUTSUFFIX='.$(HTMLSUFFIX)'; \ + OUTTOP="$(INSTALL_PREFIX)$(HTMLDIR)"; \ + GENERATE="pod2html --podroot=$(SRCDIR)/doc --htmldir=.. \ + --podpath=apps:crypto:ssl \ + | sed -e 's|href=\"http://man.he.net/man|href=\"../man|g'"; \ + $(PROCESS_PODS) + +uninstall_html_docs: + @echo "*** Uninstalling manpages" + @\ + OUTSUFFIX='.$(HTMLSUFFIX)'; \ + OUTTOP="$(INSTALL_PREFIX)$(HTMLDIR)"; \ + $(UNINSTALL_DOCS) + + +# Developer targets (note: these are only available on Unix) ######### + +update: errors ordinals tags test_ordinals + +# Test coverage is a good idea for the future +#coverage: $(PROGRAMS) $(TESTPROGRAMS) +# ... + +# Currently disabled, util/selftest.pl needs a rewrite +#report: +# SRCDIR=$(SRCDIR) @$(PERL) util/selftest.pl + +lint: + lint -DLINT $(INCLUDES) $(SRCS) + +errors: + ( cd $(SRCDIR); $(PERL) util/ck_errf.pl -strict */*.c */*/*.c ) + ( cd $(SRCDIR); $(PERL) util/mkerr.pl -recurse -write ) + ( cd $(SRCDIR)/engines; \ + for e in *.ec; do \ + $(PERL) ../util/mkerr.pl -conf $$e \ + -nostatic -staticloader -write *.c; \ + done ) + ( cd $(SRCDIR)/crypto/ct; \ + $(PERL) ../../util/mkerr.pl -conf ct.ec -hprefix internal/ -write *.c ) + +ordinals: + ( b=`pwd`; cd $(SRCDIR); $(PERL) -I$$b util/mkdef.pl crypto update ) + ( b=`pwd`; cd $(SRCDIR); $(PERL) -I$$b util/mkdef.pl ssl update ) + +test_ordinals: + ( cd test; \ + SRCTOP=../$(SRCDIR) \ + BLDTOP=../$(BLDDIR) \ + $(PERL) ../$(SRCDIR)/test/run_tests.pl test_ordinals ) + +tags TAGS: FORCE + rm -f TAGS tags + -ctags -R . + -etags `find . -name '*.[ch]' -o -name '*.pm'` + +# Release targets (note: only available on Unix) ##################### + +tar: + TMPDIR=/var/tmp/openssl-copy.$$$$; \ + DISTDIR=openssl-$(VERSION); \ + mkdir -p $$TMPDIR/$$DISTDIR; \ + (cd $(SRCDIR); \ + git ls-tree -r --name-only --full-tree HEAD \ + | while read F; do \ + mkdir -p $$TMPDIR/$$DISTDIR/`dirname $$F`; \ + cp $$F $$TMPDIR/$$DISTDIR/$$F; \ + done); \ + (cd $$TMPDIR; \ + [ -n "$(PREPARE_CMD)" ] && $(PREPARE_CMD); \ + find $$TMPDIR/$$DISTDIR -type d -print | xargs chmod 755; \ + find $$TMPDIR/$$DISTDIR -type f -print | xargs chmod a+r; \ + find $$TMPDIR/$$DISTDIR -type f -perm -0100 -print | xargs chmod a+x; \ + $(TAR) $(TARFLAGS) --owner 0 --group 0 -cvf - $$DISTDIR) \ + | (cd $(SRCDIR); gzip --best > $(TARFILE).gz); \ + rm -rf $$TMPDIR + cd $(SRCDIR); ls -l $(TARFILE).gz + +dist: + @$(MAKE) PREPARE_CMD='./Configure dist' tar + +# Helper targets ##################################################### + +rehash: link-utils copy-certs + @if [ -z "$(CROSS_COMPILE)" ]; then \ + (OPENSSL="$(BLDDIR)/util/shlib_wrap.sh apps/openssl"; \ + [ -x "$(BLDDIR)/openssl.exe" ] && OPENSSL="$(BLDDIR)/openssl.exe" || :; \ + OPENSSL_DEBUG_MEMORY=on; OPENSSL_CONF=/dev/null ; \ + export OPENSSL OPENSSL_DEBUG_MEMORY OPENSSL_CONF; \ + $$OPENSSL rehash certs/demo \ + || $(PERL) tools/c_rehash certs/demo) && \ + touch rehash.time; \ + else :; fi + +link-utils: $(BLDDIR)/util/opensslwrap.sh $(BLDDIR)/util/shlib_wrap.sh + +$(BLDDIR)/util/opensslwrap.sh: Makefile + @if [ "$(SRCDIR)" != "$(BLDDIR)" ]; then \ + mkdir -p "$(BLDDIR)/util"; \ + ln -sf "../$(SRCDIR)/util/opensslwrap.sh" "$(BLDDIR)/util"; \ + fi +$(BLDDIR)/util/shlib_wrap.sh: Makefile + @if [ "$(SRCDIR)" != "$(BLDDIR)" ]; then \ + mkdir -p "$(BLDDIR)/util"; \ + ln -sf "../$(SRCDIR)/util/shlib_wrap.sh" "$(BLDDIR)/util"; \ + fi + +copy-certs: FORCE + @if [ "$(SRCDIR)" != "$(BLDDIR)" ]; then \ + cp -R "$(SRCDIR)/certs" "$(BLDDIR)/"; \ + fi + +FORCE : + +# Building targets ################################################### + +libcrypto.pc libssl.pc openssl.pc: Makefile $(LIBS) +libcrypto.pc: + @ ( echo 'prefix=$(INSTALLTOP)'; \ + echo 'exec_prefix=$${prefix}'; \ + echo 'libdir=$${exec_prefix}/$(LIBDIR)'; \ + echo 'includedir=$${prefix}/include'; \ + echo ''; \ + echo 'Name: OpenSSL-libcrypto'; \ + echo 'Description: OpenSSL cryptography library'; \ + echo 'Version: '$(VERSION); \ + echo 'Libs: -L$${libdir} -lcrypto'; \ + echo 'Libs.private: $(EX_LIBS)'; \ + echo 'Cflags: -I$${includedir}' ) > libcrypto.pc + +libssl.pc: + @ ( echo 'prefix=$(INSTALLTOP)'; \ + echo 'exec_prefix=$${prefix}'; \ + echo 'libdir=$${exec_prefix}/$(LIBDIR)'; \ + echo 'includedir=$${prefix}/include'; \ + echo ''; \ + echo 'Name: OpenSSL-libssl'; \ + echo 'Description: Secure Sockets Layer and cryptography libraries'; \ + echo 'Version: '$(VERSION); \ + echo 'Requires.private: libcrypto'; \ + echo 'Libs: -L$${libdir} -lssl'; \ + echo 'Libs.private: $(EX_LIBS)'; \ + echo 'Cflags: -I$${includedir}' ) > libssl.pc + +openssl.pc: + @ ( echo 'prefix=$(INSTALLTOP)'; \ + echo 'exec_prefix=$${prefix}'; \ + echo 'libdir=$${exec_prefix}/$(LIBDIR)'; \ + echo 'includedir=$${prefix}/include'; \ + echo ''; \ + echo 'Name: OpenSSL'; \ + echo 'Description: Secure Sockets Layer and cryptography libraries and tools'; \ + echo 'Version: '$(VERSION); \ + echo 'Requires: libssl libcrypto' ) > openssl.pc + +# Note on the use of $(MFLAGS): this was an older variant of MAKEFLAGS which +# wasn't passed down automatically. It's quite safe to use it like we do +# below; if it doesn't exist, the result will be empty and 'make' will pick +# up $(MAKEFLAGS) which is passed down as an environment variable. +Makefile: {- $config{build_file_template} -} $(SRCDIR)/Configure $(SRCDIR)/config + @echo "Makefile is older than {- $config{build_file_template} -}, $(SRCDIR)/Configure or $(SRCDIR)/config." + @echo "Reconfiguring..." + $(SRCDIR)/Configure reconf + @echo "**************************************************" + @echo "*** ***" + @echo "*** Please run the same make command again ***" + @echo "*** ***" + @echo "**************************************************" + @false + +{- + use File::Basename; + use File::Spec::Functions qw/:DEFAULT abs2rel rel2abs/; + sub src2dep { + my %args = @_; + my $dep = $args{obj}.'$(DEP_EXT)'; + my $obj = $args{obj}.'$(OBJ_EXT)'; + my $srcs = join(" ", @{$args{srcs}}); + my $incs = join(" ", map { " -I".$_ } @{$args{incs}}); + my $makedepprog = $config{makedepprog}; + if ($makedepprog eq "makedepend") { + return <<"EOF"; +$dep : $srcs + rm -f \$\@.tmp; touch \$\@.tmp + \$(MAKEDEPEND) -f\$\@.tmp -o"|$obj"\ + -- -DOPENSSL_DOING_MAKEDEPEND \$(DEPFLAGS)$incs \ + -- $srcs + sed -e 's/^.*|//' -e 's/ \\/\\(\\\\.\\|[^ ]\\)*//g' -e '/: *\$/d' -e '/^\\(#.*\\| *\\)\$/d' \$\@.tmp > \$\@ + rm \$\@.tmp +EOF + } + return <<"EOF"; +$dep : $srcs Makefile + \$(CC) -DOPENSSL_DOING_MAKEDEPEND \$(DEPFLAGS)$incs -MM -MF \$\@ -MQ $obj $srcs +EOF + } + sub src2obj { + my %args = @_; + my $obj = $args{obj}.'$(OBJ_EXT)'; + my $srcs = join(" ", @{$args{srcs}}); + my $deps = join(" ", @{$args{srcs}}, @{$args{deps}}); + my $incs = join(" ", map { " -I".$_ } @{$args{incs}}); + return <<"EOF"; +$obj : $deps + \$(CC) \$(CFLAGS)$incs -c -o \$\@ $srcs +EOF + } + # On Unix, we build shlibs from static libs, so we're ignoring the + # object file array. We *know* this routine is only called when we've + # configure 'shared'. + sub libobj2shlib { + my %args = @_; + my $lib = $args{lib}; + my $shlib = $args{shlib}; + my $libd = dirname($lib); + my $libn = basename($lib); + (my $libname = $libn) =~ s/^lib//; + my $shlibdeps = join("", map { my $d = dirname($_); + my $f = basename($_); + (my $l = $f) =~ s/^lib//; + " -L$d -l$l" } @{$args{deps}}); + my $deps = join(" ",map { $_."\$(SHLIB_EXT_SIMPLE)" } @{$args{deps}}); + my $shlib_target = $target{shared_target}; + my $ordinalsfile = defined($args{ordinals}) ? $args{ordinals}->[1] : ""; + my $targets = + "$shlib".shlib_ext() . + (shlib_ext() ne shlib_ext_simple() + ? " $shlib".shlib_ext_simple() : ""); + return <<"EOF" +$targets : $lib\$(LIB_EXT) $deps $ordinalsfile + \$(MAKE) -f \$(SRCDIR)/Makefile.shared -e \\ + PERL=\$(PERL) SRCDIR="\$(SRCDIR)" DSTDIR="$libd" \\ + INSTALLTOP="\$(INSTALLTOP)" LIBDIR="\$(LIBDIR)" \\ + LIBDEPS="\$(PLIB_LDFLAGS) $shlibdeps \$(EX_LIBS)" \\ + LIBNAME=$libname LIBVERSION=\$(SHLIB_MAJOR).\$(SHLIB_MINOR) \\ + LIBCOMPATVERSIONS=";\$(SHLIB_VERSION_HISTORY)" \\ + CC="\$(CC)" CFLAGS="\$(CFLAGS)" LDFLAGS="\$(LDFLAGS)" \\ + SHARED_LDFLAGS="\$(SHARED_LDFLAGS)" SHLIB_EXT=\$(SHLIB_EXT) \\ + link_a.$shlib_target +EOF + } + sub obj2dynlib { + my %args = @_; + my $lib = $args{lib}; + my $libd = dirname($lib); + my $libn = basename($lib); + (my $libname = $libn) =~ s/^lib//; + my $shlibdeps = join("", map { my $d = dirname($_); + my $f = basename($_); + (my $l = $f) =~ s/^lib//; + " -L$d -l$l" } @{$args{deps}}); + my $deps = join(" ",map { $_."\$(SHLIB_EXT_SIMPLE)" } @{$args{deps}}); + my $shlib_target = $target{shared_target}; + my $objs = join(" ", map { $_."\$(OBJ_EXT)" } @{$args{objs}}); + return <<"EOF"; +$lib\$(SHLIB_EXT_SIMPLE): $objs $deps + \$(MAKE) -f \$(SRCDIR)/Makefile.shared -e \\ + PERL=\$(PERL) SRCDIR="\$(SRCDIR)" DSTDIR="$libd" \\ + LIBDEPS="\$(PLIB_LDFLAGS) $shlibdeps \$(EX_LIBS)" \\ + LIBNAME=$libname LDFLAGS="\$(LDFLAGS)" \\ + CC="\$(CC)" CFLAGS="\$(CFLAGS)" \\ + SHARED_LDFLAGS="\$(SHARED_LDFLAGS)" \\ + SHLIB_EXT=\$(SHLIB_EXT_SIMPLE) \\ + LIBEXTRAS="$objs" \\ + link_o.$shlib_target +EOF + } + sub obj2lib { + my %args = @_; + my $lib = $args{lib}; + my $objs = join(" ", map { $_."\$(OBJ_EXT)" } @{$args{objs}}); + return <<"EOF"; +$lib\$(LIB_EXT) : $objs + \$(AR) \$\@ $objs + \$(RANLIB) \$\@ || echo Never mind. +EOF + } + sub obj2bin { + my %args = @_; + my $bin = $args{bin}; + my $bind = dirname($bin); + my $binn = basename($bin); + my $objs = join(" ", map { $_."\$(OBJ_EXT)" } @{$args{objs}}); + my $deps = join(" ", + (map { $_."\$(OBJ_EXT)" } @{$args{objs}}), + (map { $_.($config{no_shared} ? "\$(LIB_EXT)" : "\$(SHLIB_EXT)" ) } + @{$args{deps}})); + my $libdeps = join("", map { my $d = dirname($_); + my $f = basename($_); + $d = "." if $d eq $f; + (my $l = $f) =~ s/^lib//; + " -L$d -l$l" } @{$args{deps}}); + my $shlib_target = $config{no_shared} ? "" : $target{shared_target}; + return <<"EOF"; +$bin\$(EXE_EXT) : $deps + \$(RM) $bin\$(EXE_EXT) + \$(MAKE) -f \$(SRCDIR)/Makefile.shared -e \\ + PERL=\$(PERL) SRCDIR=\$(SRCDIR) \\ + APPNAME=$bin OBJECTS="$objs" \\ + LIBDEPS="\$(PLIB_LDFLAGS) \$(LDFLAGS) $libdeps \$(EX_LIBS)" \\ + CC="\$(CC)" CFLAGS="\$(CFLAGS)" LDFLAGS="\$(LDFLAGS)" \\ + LIBRPATH="\$(INSTALLTOP)/\$(LIBDIR)" \\ + link_app.$shlib_target +EOF + } + sub in2script { + my %args = @_; + my $script = $args{script}; + my $sources = join(" ", @{$args{sources}}); + my $dofile = abs2rel(rel2abs(catfile($config{sourcedir}, + "util", "dofile.pl")), + rel2abs($config{builddir})); + return <<"EOF"; +$script : $sources + \$(PERL) "-I\$(BLDDIR)" -Mconfigdata "$dofile" $sources > "$script" + chmod a+x $script +EOF + } + "" # Important! This becomes part of the template result. +-} diff --git a/apps/build.info b/apps/build.info index f365aee56f..b1cdc34111 100644 --- a/apps/build.info +++ b/apps/build.info @@ -15,3 +15,9 @@ DEPEND[openssl]=../libssl SCRIPTS=CA.pl SOURCE[CA.pl]=CA.pl.in + +BEGINRAW[Makefile] +{- $builddir -}/progs.h: {- $sourcedir -}/progs.pl {- $builddir -}/../Makefile + $(RM) {- $builddir -}/progs.h + $(PERL) {- $sourcedir -}/progs.pl $(COMMANDS) >{- $builddir -}/progs.h +ENDRAW[Makefile] diff --git a/crypto/aes/build.info b/crypto/aes/build.info index c8a8c5dfc5..6484da6c53 100644 --- a/crypto/aes/build.info +++ b/crypto/aes/build.info @@ -2,3 +2,62 @@ LIBS=../../libcrypto SOURCE[../../libcrypto]=\ aes_misc.c aes_ecb.c aes_cfb.c aes_ofb.c \ aes_ige.c aes_wrap.c {- $target{aes_asm_src} -} + +BEGINRAW[Makefile] +##### AES assembler implementations + +{- $builddir -}/aes-ia64.s: {- $sourcedir -}/asm/aes-ia64.S + $(CC) $(CFLAGS) -E asm/aes-ia64.S > $@ + +{- $builddir -}/aes-586.s: {- $sourcedir -}/asm/aes-586.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/asm/aes-586.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ +{- $builddir -}/vpaes-x86.s: {- $sourcedir -}/asm/vpaes-x86.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/asm/vpaes-x86.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ +{- $builddir -}/aesni-x86.s: {- $sourcedir -}/asm/aesni-x86.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/asm/aesni-x86.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ + +{- $builddir -}/aes-x86_64.s: {- $sourcedir -}/asm/aes-x86_64.pl + $(PERL) {- $sourcedir -}/asm/aes-x86_64.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/vpaes-x86_64.s: {- $sourcedir -}/asm/vpaes-x86_64.pl + $(PERL) {- $sourcedir -}/asm/vpaes-x86_64.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/bsaes-x86_64.s: {- $sourcedir -}/asm/bsaes-x86_64.pl + $(PERL) {- $sourcedir -}/asm/bsaes-x86_64.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/aesni-x86_64.s: {- $sourcedir -}/asm/aesni-x86_64.pl + $(PERL) {- $sourcedir -}/asm/aesni-x86_64.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/aesni-sha1-x86_64.s: {- $sourcedir -}/asm/aesni-sha1-x86_64.pl + $(PERL) {- $sourcedir -}/asm/aesni-sha1-x86_64.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/aesni-sha256-x86_64.s: {- $sourcedir -}/asm/aesni-sha256-x86_64.pl + $(PERL) {- $sourcedir -}/asm/aesni-sha256-x86_64.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/aesni-mb-x86_64.s: {- $sourcedir -}/asm/aesni-mb-x86_64.pl + $(PERL) {- $sourcedir -}/asm/aesni-mb-x86_64.pl $(PERLASM_SCHEME) > $@ + +{- $builddir -}/aes-sparcv9.s: {- $sourcedir -}/asm/aes-sparcv9.pl + $(PERL) {- $sourcedir -}/asm/aes-sparcv9.pl $(CFLAGS) > $@ +{- $builddir -}/aest4-sparcv9.s: {- $sourcedir -}/asm/aest4-sparcv9.pl {- $sourcetop -}/crypto/perlasm/sparcv9_modes.pl + $(PERL) {- $sourcedir -}/asm/aest4-sparcv9.pl $(CFLAGS) > $@ + +{- $builddir -}/aes-ppc.s: {- $sourcedir -}/asm/aes-ppc.pl + $(PERL) {- $sourcedir -}/asm/aes-ppc.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/vpaes-ppc.s: {- $sourcedir -}/asm/vpaes-ppc.pl + $(PERL) {- $sourcedir -}/asm/vpaes-ppc.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/aesp8-ppc.s: {- $sourcedir -}/asm/aesp8-ppc.pl + $(PERL) {- $sourcedir -}/asm/aesp8-ppc.pl $(PERLASM_SCHEME) $@ + +{- $builddir -}/aes-parisc.s: {- $sourcedir -}/asm/aes-parisc.pl + $(PERL) {- $sourcedir -}/asm/aes-parisc.pl $(PERLASM_SCHEME) $@ + +{- $builddir -}/aes-mips.S: {- $sourcedir -}/asm/aes-mips.pl + $(PERL) {- $sourcedir -}/asm/aes-mips.pl $(PERLASM_SCHEME) $@ + +{- $builddir -}/aesv8-armx.S: {- $sourcedir -}/asm/aesv8-armx.pl + $(PERL) {- $sourcedir -}/asm/aesv8-armx.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/vpaes-armv8.S: {- $sourcedir -}/asm/vpaes-armv8.pl + $(PERL) {- $sourcedir -}/asm/vpaes-armv8.pl $(PERLASM_SCHEME) $@ + +# GNU make "catch all" +{- $builddir -}/aes-%.S: {- $sourcedir -}/asm/aes-%.pl + $(PERL) $< $(PERLASM_SCHEME) $@ +{- $builddir -}/bsaes-%.S: {- $sourcedir -}/asm/bsaes-%.pl + $(PERL) $< $(PERLASM_SCHEME) $@ + +ENDRAW[Makefile] diff --git a/crypto/bf/build.info b/crypto/bf/build.info index d471b3178f..b4aa7f9d74 100644 --- a/crypto/bf/build.info +++ b/crypto/bf/build.info @@ -1,2 +1,9 @@ LIBS=../../libcrypto SOURCE[../../libcrypto]=bf_skey.c bf_ecb.c bf_enc.c bf_cfb64.c bf_ofb64.c + +BEGINRAW[Makefile] +##### BF assembler implementations + +{- $builddir -}/bf-586.s: {- $sourcedir -}/asm/bf-586.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl {- $sourcetop -}/crypto/perlasm/cbc.pl + $(PERL) {- $sourcedir -}/asm/bf-586.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ +ENDRAW[Makefile] diff --git a/crypto/bn/build.info b/crypto/bn/build.info index 7525b86fd9..66f62dcac9 100644 --- a/crypto/bn/build.info +++ b/crypto/bn/build.info @@ -6,3 +6,93 @@ SOURCE[../../libcrypto]=\ {- $target{bn_asm_src} -} \ bn_recp.c bn_mont.c bn_mpi.c bn_exp2.c bn_gf2m.c bn_nist.c \ bn_depr.c bn_const.c bn_x931p.c bn_intern.c bn_dh.c bn_srp.c + +BEGINRAW[Makefile] +##### BN assembler implementations + +{- $builddir -}/bn-586.s: {- $sourcedir -}/asm/bn-586.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/asm/bn-586.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ +{- $builddir -}/co-586.s: {- $sourcedir -}/asm/co-586.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/asm/co-586.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ +{- $builddir -}/x86-mont.s: {- $sourcedir -}/asm/x86-mont.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/asm/x86-mont.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ +{- $builddir -}/x86-gf2m.s: {- $sourcedir -}/asm/x86-gf2m.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/asm/x86-gf2m.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ + +{- $builddir -}/sparcv8.o: {- $sourcedir -}/asm/sparcv8.S + $(CC) $(CFLAGS) -c {- $sourcedir -}/asm/sparcv8.S +{- $builddir -}/bn-sparcv9.o: {- $sourcedir -}/asm/sparcv8plus.S + $(CC) $(CFLAGS) -c -o $@ {- $sourcedir -}/asm/sparcv8plus.S +{- $builddir -}/sparcv9a-mont.s: {- $sourcedir -}/asm/sparcv9a-mont.pl + $(PERL) {- $sourcedir -}/asm/sparcv9a-mont.pl $(CFLAGS) > $@ +{- $builddir -}/sparcv9-mont.s: {- $sourcedir -}/asm/sparcv9-mont.pl + $(PERL) {- $sourcedir -}/asm/sparcv9-mont.pl $(CFLAGS) > $@ +{- $builddir -}/vis3-mont.s: {- $sourcedir -}/asm/vis3-mont.pl + $(PERL) {- $sourcedir -}/asm/vis3-mont.pl $(CFLAGS) > $@ +{- $builddir -}/sparct4-mont.S: {- $sourcedir -}/asm/sparct4-mont.pl + $(PERL) {- $sourcedir -}/asm/sparct4-mont.pl $(CFLAGS) > $@ +{- $builddir -}/sparcv9-gf2m.S: {- $sourcedir -}/asm/sparcv9-gf2m.pl + $(PERL) {- $sourcedir -}/asm/sparcv9-gf2m.pl $(CFLAGS) > $@ + +{- $builddir -}/bn-mips3.o: {- $sourcedir -}/asm/mips3.s + @if [ "$(CC)" = "gcc" ]; then \ + ABI=`expr "$(CFLAGS)" : ".*-mabi=\([n3264]*\)"` && \ + as -$$ABI -O -o $@ {- $sourcedir -}/asm/mips3.s; \ + else $(CC) -c $(CFLAGS) -o $@ {- $sourcedir -}/asm/mips3.s; fi + +{- $builddir -}/bn-mips.s: {- $sourcedir -}/asm/mips.pl + $(PERL) {- $sourcedir -}/asm/mips.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/mips-mont.s: {- $sourcedir -}/asm/mips-mont.pl + $(PERL) {- $sourcedir -}/asm/mips-mont.pl $(PERLASM_SCHEME) $@ + +{- $builddir -}/bn-s390x.o: {- $sourcedir -}/asm/s390x.S + $(CC) $(CFLAGS) -c -o $@ {- $sourcedir -}/asm/s390x.S +{- $builddir -}/s390x-gf2m.s: {- $sourcedir -}/asm/s390x-gf2m.pl + $(PERL) {- $sourcedir -}/asm/s390x-gf2m.pl $(PERLASM_SCHEME) $@ + +{- $builddir -}/x86_64-mont.s: {- $sourcedir -}/asm/x86_64-mont.pl + $(PERL) {- $sourcedir -}/asm/x86_64-mont.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/x86_64-mont5.s: {- $sourcedir -}/asm/x86_64-mont5.pl + $(PERL) {- $sourcedir -}/asm/x86_64-mont5.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/x86_64-gf2m.s: {- $sourcedir -}/asm/x86_64-gf2m.pl + $(PERL) {- $sourcedir -}/asm/x86_64-gf2m.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/rsaz-x86_64.s: {- $sourcedir -}/asm/rsaz-x86_64.pl + $(PERL) {- $sourcedir -}/asm/rsaz-x86_64.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/rsaz-avx2.s: {- $sourcedir -}/asm/rsaz-avx2.pl + $(PERL) {- $sourcedir -}/asm/rsaz-avx2.pl $(PERLASM_SCHEME) > $@ + +{- $builddir -}/bn-ia64.s: {- $sourcedir -}/asm/ia64.S + $(CC) $(CFLAGS) -E {- $sourcedir -}/asm/ia64.S > $@ +{- $builddir -}/ia64-mont.s: {- $sourcedir -}/asm/ia64-mont.pl + $(PERL) {- $sourcedir -}/asm/ia64-mont.pl $@ $(CFLAGS) + +# GNU assembler fails to compile PA-RISC2 modules, insist on calling +# vendor assembler... +{- $builddir -}/pa-risc2W.o: {- $sourcedir -}/asm/pa-risc2W.s + $(PERL) $(TOP)/util/fipsas.pl $(TOP) $< /usr/ccs/bin/as -o pa-risc2W.o {- $sourcedir -}/asm/pa-risc2W.s +{- $builddir -}/pa-risc2.o: {- $sourcedir -}/asm/pa-risc2.s + $(PERL) $(TOP)/util/fipsas.pl $(TOP) $< /usr/ccs/bin/as -o pa-risc2.o {- $sourcedir -}/asm/pa-risc2.s + +{- $builddir -}/parisc-mont.s: {- $sourcedir -}/asm/parisc-mont.pl + $(PERL) {- $sourcedir -}/asm/parisc-mont.pl $(PERLASM_SCHEME) $@ + +# ppc - AIX, Linux, MacOS X... +{- $builddir -}/bn-ppc.s: {- $sourcedir -}/asm/ppc.pl; $(PERL) {- $sourcedir -}/asm/ppc.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/ppc-mont.s: {- $sourcedir -}/asm/ppc-mont.pl;$(PERL) {- $sourcedir -}/asm/ppc-mont.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/ppc64-mont.s: {- $sourcedir -}/asm/ppc64-mont.pl;$(PERL) {- $sourcedir -}/asm/ppc64-mont.pl $(PERLASM_SCHEME) $@ + +{- $builddir -}/alpha-mont.s: {- $sourcedir -}/asm/alpha-mont.pl + (preproc=$$$$.$@.S; trap "rm $$preproc" INT; \ + $(PERL) {- $sourcedir -}/asm/alpha-mont.pl > $$preproc && \ + $(CC) -E -P $$preproc > $@ && rm $$preproc) + +# GNU make "catch all" +{- $builddir -}/%-mont.S: {- $sourcedir -}/asm/%-mont.pl + $(PERL) $< $(PERLASM_SCHEME) $@ +{- $builddir -}/%-gf2m.S: {- $sourcedir -}/asm/%-gf2m.pl + $(PERL) $< $(PERLASM_SCHEME) $@ + +{- $builddir -}/armv4-mont.o: {- $builddir -}/armv4-mont.S +{- $builddir -}/armv4-gf2m.o: {- $builddir -}/armv4-gf2m.S +{- $builddir -}/armv8-mont.o: {- $builddir -}/armv8-mont.S +ENDRAW[Makefile] diff --git a/crypto/build.info b/crypto/build.info index 90f301a327..5259432baf 100644 --- a/crypto/build.info +++ b/crypto/build.info @@ -8,3 +8,39 @@ EXTRA= ../ms/uplink-x86.pl ../ms/uplink.c ../ms/applink.c \ ppccpuid.pl pariscid.pl alphacpuid.pl arm64cpuid.pl armv4cpuid.pl DEPEND[cversion.o]=buildinf.h + +BEGINRAW[Makefile] +crypto/buildinf.h : Makefile + $(PERL) $(SRCDIR)/util/mkbuildinf.pl "$(CC) $(CFLAGS)" "$(PLATFORM)" > crypto/buildinf.h + +##### APPLINK, UPLINK and CPUID assembler implementations + +{- $builddir -}/applink.o: $(SRCDIR)/ms/applink.c + $(CC) $(CFLAGS) -c -o $@ $(TOP)/ms/applink.c + +{- $builddir -}/uplink.o: $(SRCDIR)/ms/uplink.c {- $builddir -}/applink.o + $(CC) $(CFLAGS) -c -o $@ $(TOP)/ms/uplink.c + +{- $builddir -}/uplink-x86.s: $(SRCDIR)/ms/uplink-x86.pl + $(PERL) $(TOP)/ms/uplink-x86.pl $(PERLASM_SCHEME) > $@ + +{- $builddir -}/x86cpuid.s: {- $sourcedir -}/x86cpuid.pl {- $sourcedir -}/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/x86cpuid.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ + +{- $builddir -}/x86_64cpuid.s: {- $sourcedir -}/x86_64cpuid.pl + $(PERL) {- $sourcedir -}/x86_64cpuid.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/ia64cpuid.s: {- $sourcedir -}/ia64cpuid.S + $(CC) $(CFLAGS) -E {- $sourcedir -}/ia64cpuid.S > $@ +{- $builddir -}/ppccpuid.s: {- $sourcedir -}/ppccpuid.pl + $(PERL) {- $sourcedir -}/ppccpuid.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/pariscid.s: {- $sourcedir -}/pariscid.pl + $(PERL) {- $sourcedir -}/pariscid.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/alphacpuid.s: {- $sourcedir -}/alphacpuid.pl + (preproc=$$$$.$@.S; trap "rm $$preproc" INT; \ + $(PERL) {- $sourcedir -}/alphacpuid.pl > $$preproc && \ + $(CC) -E -P $$preproc > $@ && rm $$preproc) +{- $builddir -}/arm64cpuid.S: {- $sourcedir -}/arm64cpuid.pl + $(PERL) {- $sourcedir -}/arm64cpuid.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/armv4cpuid.S: {- $sourcedir -}/armv4cpuid.pl + $(PERL) {- $sourcedir -}/armv4cpuid.pl $(PERLASM_SCHEME) > $@ +ENDRAW[Makefile] diff --git a/crypto/camellia/build.info b/crypto/camellia/build.info index aeffc10b37..abd86b792a 100644 --- a/crypto/camellia/build.info +++ b/crypto/camellia/build.info @@ -2,3 +2,12 @@ LIBS=../../libcrypto SOURCE[../../libcrypto]=\ cmll_ecb.c cmll_ofb.c cmll_cfb.c cmll_ctr.c \ {- $target{cmll_asm_src} -} + +BEGINRAW[Makefile] +{- $builddir -}/cmll-x86.s: {- $sourcedir -}/asm/cmll-x86.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/asm/cmll-x86.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ +{- $builddir -}/cmll-x86_64.s: {- $sourcedir -}/asm/cmll-x86_64.pl + $(PERL) {- $sourcedir -}/asm/cmll-x86_64.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/cmllt4-sparcv9.s: {- $sourcedir -}/asm/cmllt4-sparcv9.pl {- $sourcetop -}/crypto/perlasm/sparcv9_modes.pl + $(PERL) {- $sourcedir -}/asm/cmllt4-sparcv9.pl $(CFLAGS) > $@ +ENDRAW[Makefile] diff --git a/crypto/cast/build.info b/crypto/cast/build.info index 27271c813b..6c32fb122e 100644 --- a/crypto/cast/build.info +++ b/crypto/cast/build.info @@ -1,3 +1,10 @@ LIBS=../../libcrypto SOURCE[../../libcrypto]=\ c_skey.c c_ecb.c {- $target{cast_asm_src} -} c_cfb64.c c_ofb64.c + +BEGINRAW[Makefile] +##### CAST assembler implementations + +{- $builddir -}/cast-586.s: {- $sourcedir -}/asm/cast-586.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl {- $sourcetop -}/crypto/perlasm/cbc.pl + $(PERL) {- $sourcedir -}/asm/cast-586.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ +ENDRAW[Makefile] diff --git a/crypto/chacha/build.info b/crypto/chacha/build.info index 47e0536c93..c56c6243e6 100644 --- a/crypto/chacha/build.info +++ b/crypto/chacha/build.info @@ -1,2 +1,14 @@ LIBS=../../libcrypto SOURCE[../../libcrypto]={- $target{chacha_asm_src} -} + +BEGINRAW[Makefile(unix)] +##### CHACHA assembler implementations + +{- $builddir -}/chacha-x86.s: {- $sourcedir -}/asm/chacha-x86.pl + $(PERL) {- $sourcedir -}/asm/chacha-x86.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ +{- $builddir -}/chacha-x86_64.s: {- $sourcedir -}/asm/chacha-x86_64.pl + $(PERL) {- $sourcedir -}/asm/chacha-x86_64.pl $(PERLASM_SCHEME) > $@ + +{- $builddir -}/chacha-%.S: {- $sourcedir -}/asm/chacha-%.pl + $(PERL) $< $(PERLASM_SCHEME) $@ +ENDRAW[Makefile(unix)] diff --git a/crypto/des/build.info b/crypto/des/build.info index 5113867deb..5fabddf182 100644 --- a/crypto/des/build.info +++ b/crypto/des/build.info @@ -7,3 +7,17 @@ SOURCE[../../libcrypto]=\ {- $target{des_asm_src} -} \ fcrypt.c xcbc_enc.c rpc_enc.c cbc_cksm.c \ read2pwd.c + +BEGINRAW[Makefile] +##### DES assembler implementations + +{- $builddir -}/des_enc-sparc.S: {- $sourcedir -}/asm/des_enc.m4 + m4 -B 8192 {- $sourcedir -}/asm/des_enc.m4 > $@ +{- $builddir -}/dest4-sparcv9.s: {- $sourcedir -}/asm/dest4-sparcv9.pl + $(PERL) {- $sourcedir -}/asm/dest4-sparcv9.pl $(CFLAGS) > $@ + +{- $builddir -}/des-586.s: {- $sourcedir -}/asm/des-586.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl {- $sourcetop -}/crypto/perlasm/cbc.pl + $(PERL) {- $sourcedir -}/asm/des-586.pl $(PERLASM_SCHEME) $(CFLAGS) > $@ +{- $builddir -}/crypt586.s: {- $sourcedir -}/asm/crypt586.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl {- $sourcetop -}/crypto/perlasm/cbc.pl + $(PERL) {- $sourcedir -}/asm/crypt586.pl $(PERLASM_SCHEME) $(CFLAGS) > $@ +ENDRAW[Makefile] diff --git a/crypto/ec/build.info b/crypto/ec/build.info index 1e68559701..8ba6db0cb0 100644 --- a/crypto/ec/build.info +++ b/crypto/ec/build.info @@ -6,3 +6,20 @@ SOURCE[../../libcrypto]=\ ecp_nistp224.c ecp_nistp256.c ecp_nistp521.c ecp_nistputil.c \ ecp_oct.c ec2_oct.c ec_oct.c ec_kmeth.c ecdh_ossl.c ecdh_kdf.c \ ecdsa_ossl.c ecdsa_sign.c ecdsa_vrf.c {- $target{ec_asm_src} -} + +BEGINRAW[Makefile] +{- $builddir -}/ecp_nistz256-x86.s: {- $sourcedir -}/asm/ecp_nistz256-x86.pl + $(PERL) {- $sourcedir -}/asm/ecp_nistz256-x86.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ + +{- $builddir -}/ecp_nistz256-x86_64.s: {- $sourcedir -}/asm/ecp_nistz256-x86_64.pl + $(PERL) {- $sourcedir -}/asm/ecp_nistz256-x86_64.pl $(PERLASM_SCHEME) > $@ + +{- $builddir -}/ecp_nistz256-avx2.s: {- $sourcedir -}/asm/ecp_nistz256-avx2.pl + $(PERL) {- $sourcedir -}/asm/ecp_nistz256-avx2.pl $(PERLASM_SCHEME) > $@ + +{- $builddir -}/ecp_nistz256-sparcv9.S: {- $sourcedir -}/asm/ecp_nistz256-sparcv9.pl + $(PERL) {- $sourcedir -}/asm/ecp_nistz256-sparcv9.pl $(CFLAGS) > $@ + +{- $builddir -}/ecp_nistz256-%.S: {- $sourcedir -}/asm/ecp_nistz256-%.pl + $(PERL) $< $(PERLASM_SCHEME) $@ +ENDRAW[Makefile] diff --git a/crypto/md5/build.info b/crypto/md5/build.info index 3a038534e7..eff8c6f404 100644 --- a/crypto/md5/build.info +++ b/crypto/md5/build.info @@ -1,3 +1,18 @@ LIBS=../../libcrypto SOURCE[../../libcrypto]=\ md5_dgst.c md5_one.c {- $target{md5_asm_src} -} + +BEGINRAW[Makefile] +{- $builddir -}/md5-586.s: {- $sourcedir -}/asm/md5-586.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/asm/md5-586.pl $(PERLASM_SCHEME) $(CFLAGS) > $@ + +{- $builddir -}/md5-x86_64.s: {- $sourcedir -}/asm/md5-x86_64.pl + $(PERL) {- $sourcedir -}/asm/md5-x86_64.pl $(PERLASM_SCHEME) > $@ + +{- $builddir -}/md5-ia64.s: {- $sourcedir -}/asm/md5-ia64.S + $(CC) $(CFLAGS) -E {- $sourcedir -}/asm/md5-ia64.S | \ + $(PERL) -ne 's/;\s+/;\n/g; print;' > $@ + +{- $builddir -}/md5-sparcv9.S: {- $sourcedir -}/asm/md5-sparcv9.pl + $(PERL) {- $sourcedir -}/asm/md5-sparcv9.pl $@ $(CFLAGS) +ENDRAW[Makefile] diff --git a/crypto/modes/build.info b/crypto/modes/build.info index 98ca3458ae..d10a97de82 100644 --- a/crypto/modes/build.info +++ b/crypto/modes/build.info @@ -3,3 +3,30 @@ SOURCE[../../libcrypto]=\ cbc128.c ctr128.c cts128.c cfb128.c ofb128.c gcm128.c \ ccm128.c xts128.c wrap128.c ocb128.c \ {- $target{modes_asm_src} -} + +BEGINRAW[Makefile] +{- $builddir -}/ghash-ia64.s: {- $sourcedir -}/asm/ghash-ia64.pl + $(PERL) {- $sourcedir -}/asm/ghash-ia64.pl $@ $(CFLAGS) +{- $builddir -}/ghash-x86.s: {- $sourcedir -}/asm/ghash-x86.pl + $(PERL) {- $sourcedir -}/asm/ghash-x86.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ +{- $builddir -}/ghash-x86_64.s: {- $sourcedir -}/asm/ghash-x86_64.pl + $(PERL) {- $sourcedir -}/asm/ghash-x86_64.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/aesni-gcm-x86_64.s: {- $sourcedir -}/asm/aesni-gcm-x86_64.pl + $(PERL) {- $sourcedir -}/asm/aesni-gcm-x86_64.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/ghash-sparcv9.s: {- $sourcedir -}/asm/ghash-sparcv9.pl + $(PERL) {- $sourcedir -}/asm/ghash-sparcv9.pl $@ $(CFLAGS) +{- $builddir -}/ghash-alpha.s: {- $sourcedir -}/asm/ghash-alpha.pl + (preproc=$$$$.$@.S; trap "rm $$preproc" INT; \ + $(PERL) {- $sourcedir -}/asm/ghash-alpha.pl > $$preproc && \ + $(CC) -E -P $$preproc > $@ && rm $$preproc) +{- $builddir -}/ghash-parisc.s: {- $sourcedir -}/asm/ghash-parisc.pl + $(PERL) {- $sourcedir -}/asm/ghash-parisc.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/ghashv8-armx.S: {- $sourcedir -}/asm/ghashv8-armx.pl + $(PERL) {- $sourcedir -}/asm/ghashv8-armx.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/ghashp8-ppc.s: {- $sourcedir -}/asm/ghashp8-ppc.pl + $(PERL) {- $sourcedir -}/asm/ghashp8-ppc.pl $(PERLASM_SCHEME) $@ + +# GNU make "catch all" +{- $builddir -}/ghash-%.S: {- $sourcedir -}/asm/ghash-%.pl + $(PERL) $< $(PERLASM_SCHEME) $@ +ENDRAW[Makefile] diff --git a/crypto/poly1305/build.info b/crypto/poly1305/build.info index 35d4fa8fa0..0b59b9fe67 100644 --- a/crypto/poly1305/build.info +++ b/crypto/poly1305/build.info @@ -1,3 +1,15 @@ LIBS=../../libcrypto SOURCE[../../libcrypto]=\ poly1305.c {- $target{poly1305_asm_src} -} + +BEGINRAW[Makefile(unix)] +{- $builddir -}/poly1305-sparcv9.S: {- $sourcedir -}/asm/poly1305-sparcv9.pl + $(PERL) {- $sourcedir -}/asm/poly1305-sparcv9.pl > $@ +{- $builddir -}/poly1305-x86.s: {- $sourcedir -}/asm/poly1305-x86.pl + $(PERL) {- $sourcedir -}/asm/poly1305-x86.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ +{- $builddir -}/poly1305-x86_64.s: {- $sourcedir -}/asm/poly1305-x86_64.pl + $(PERL) {- $sourcedir -}/asm/poly1305-x86_64.pl $(PERLASM_SCHEME) > $@ + +{- $builddir -}/poly1305-%.S: {- $sourcedir -}/asm/poly1305-%.pl + $(PERL) $< $(PERLASM_SCHEME) $@ +ENDRAW[Makefile(unix)] diff --git a/crypto/rc4/build.info b/crypto/rc4/build.info index 9e77a81478..f2c4e2a68b 100644 --- a/crypto/rc4/build.info +++ b/crypto/rc4/build.info @@ -1,3 +1,30 @@ LIBS=../../libcrypto SOURCE[../../libcrypto]=\ {- $target{rc4_asm_src} -} + +BEGINRAW[Makefile] +{- $builddir -}/rc4-586.s: {- $sourcedir -}/asm/rc4-586.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/asm/rc4-586.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ + +{- $builddir -}/rc4-x86_64.s: {- $sourcedir -}/asm/rc4-x86_64.pl + $(PERL) {- $sourcedir -}/asm/rc4-x86_64.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/rc4-md5-x86_64.s: {- $sourcedir -}/asm/rc4-md5-x86_64.pl + $(PERL) {- $sourcedir -}/asm/rc4-md5-x86_64.pl $(PERLASM_SCHEME) > $@ + +{- $builddir -}/rc4-ia64.S: {- $sourcedir -}/asm/rc4-ia64.pl + $(PERL) {- $sourcedir -}/asm/rc4-ia64.pl $(CFLAGS) > $@ + +{- $builddir -}/rc4-parisc.s: {- $sourcedir -}/asm/rc4-parisc.pl + $(PERL) {- $sourcedir -}/asm/rc4-parisc.pl $(PERLASM_SCHEME) $@ + +{- $builddir -}/rc4-ia64.s: rc4-ia64.S + @case `awk '/^#define RC4_INT/{print$$NF}' $(TOP)/include/openssl/opensslconf.h` in \ + int) set -x; $(CC) $(CFLAGS) -DSZ=4 -E rc4-ia64.S > $@ ;; \ + char) set -x; $(CC) $(CFLAGS) -DSZ=1 -E rc4-ia64.S > $@ ;; \ + *) exit 1 ;; \ + esac + +# GNU make "catch all" +{- $builddir -}/rc4-%.s: {- $sourcedir -}/asm/rc4-%.pl + $(PERL) $< $(PERLASM_SCHEME) $@ +ENDRAW[Makefile] diff --git a/crypto/rc5/build.info b/crypto/rc5/build.info index 956d21f9dc..af38f9285e 100644 --- a/crypto/rc5/build.info +++ b/crypto/rc5/build.info @@ -1,3 +1,10 @@ LIBS=../../libcrypto SOURCE[../../libcrypto]=\ rc5_skey.c rc5_ecb.c {- $target{rc5_asm_src} -} rc5cfb64.c rc5ofb64.c + +BEGINRAW[Makefile] +##### RC5 assembler implementations + +{- $builddir -}/rc5-586.s: {- $sourcedir -}/asm/rc5-586.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl {- $sourcetop -}/crypto/perlasm/cbc.pl + $(PERL) {- $sourcedir -}/asm/rc5-586.pl $(PERLASM_SCHEME) $(CFLAGS) > $@ +ENDRAW[Makefile] diff --git a/crypto/ripemd/build.info b/crypto/ripemd/build.info index c5dd4c4b8e..5f63598555 100644 --- a/crypto/ripemd/build.info +++ b/crypto/ripemd/build.info @@ -1,3 +1,10 @@ LIBS=../../libcrypto SOURCE[../../libcrypto]=\ rmd_dgst.c rmd_one.c {- $target{rmd160_asm_src} -} + +BEGINRAW[Makefile] +##### RMD160 assembler implementations + +{- $builddir -}/rmd-586.s: {- $sourcedir -}/asm/rmd-586.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/asm/rmd-586.pl $(PERLASM_SCHEME) $(CFLAGS) > $@ +ENDRAW[Makefile] diff --git a/crypto/sha/build.info b/crypto/sha/build.info index eef0e46183..1af0497a17 100644 --- a/crypto/sha/build.info +++ b/crypto/sha/build.info @@ -1,3 +1,80 @@ LIBS=../../libcrypto SOURCE[../../libcrypto]=\ sha1dgst.c sha1_one.c sha256.c sha512.c {- $target{sha1_asm_src} -} + +BEGINRAW[Makefile] +##### SHA assembler implementations + +{- $builddir -}/sha1-586.s: {- $sourcedir -}/asm/sha1-586.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/asm/sha1-586.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ +{- $builddir -}/sha256-586.s: {- $sourcedir -}/asm/sha256-586.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/asm/sha256-586.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ +{- $builddir -}/sha512-586.s: {- $sourcedir -}/asm/sha512-586.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/asm/sha512-586.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ + +{- $builddir -}/sha1-ia64.s: {- $sourcedir -}/asm/sha1-ia64.pl + (cd asm; $(PERL) sha1-ia64.pl ../$@ $(CFLAGS)) +{- $builddir -}/sha256-ia64.s: {- $sourcedir -}/asm/sha512-ia64.pl + (cd asm; $(PERL) sha512-ia64.pl ../$@ $(CFLAGS)) +{- $builddir -}/sha512-ia64.s: {- $sourcedir -}/asm/sha512-ia64.pl + (cd asm; $(PERL) sha512-ia64.pl ../$@ $(CFLAGS)) + +{- $builddir -}/sha256-armv4.S: {- $sourcedir -}/asm/sha256-armv4.pl + $(PERL) $< $(PERLASM_SCHEME) $@ + +{- $builddir -}/sha1-alpha.s: {- $sourcedir -}/asm/sha1-alpha.pl + (preproc=$$$$.$@.S; trap "rm $$preproc" INT; \ + $(PERL) {- $sourcedir -}/asm/sha1-alpha.pl > $$preproc && \ + $(CC) -E -P $$preproc > $@ && rm $$preproc) + +# Solaris make has to be explicitly told +{- $builddir -}/sha1-x86_64.s: {- $sourcedir -}/asm/sha1-x86_64.pl + $(PERL) {- $sourcedir -}/asm/sha1-x86_64.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/sha1-mb-x86_64.s: {- $sourcedir -}/asm/sha1-mb-x86_64.pl + $(PERL) {- $sourcedir -}/asm/sha1-mb-x86_64.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/sha256-x86_64.s:{- $sourcedir -}/asm/sha512-x86_64.pl + $(PERL) {- $sourcedir -}/asm/sha512-x86_64.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/sha256-mb-x86_64.s: {- $sourcedir -}/asm/sha256-mb-x86_64.pl + $(PERL) {- $sourcedir -}/asm/sha256-mb-x86_64.pl $(PERLASM_SCHEME) > $@ +{- $builddir -}/sha512-x86_64.s:{- $sourcedir -}/asm/sha512-x86_64.pl + $(PERL) {- $sourcedir -}/asm/sha512-x86_64.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/sha1-sparcv9.S: {- $sourcedir -}/asm/sha1-sparcv9.pl + $(PERL) {- $sourcedir -}/asm/sha1-sparcv9.pl $@ $(CFLAGS) +{- $builddir -}/sha256-sparcv9.S:{- $sourcedir -}/asm/sha512-sparcv9.pl + $(PERL) {- $sourcedir -}/asm/sha512-sparcv9.pl $@ $(CFLAGS) +{- $builddir -}/sha512-sparcv9.S:{- $sourcedir -}/asm/sha512-sparcv9.pl + $(PERL) {- $sourcedir -}/asm/sha512-sparcv9.pl $@ $(CFLAGS) + +{- $builddir -}/sha1-ppc.s: {- $sourcedir -}/asm/sha1-ppc.pl + $(PERL) {- $sourcedir -}/asm/sha1-ppc.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/sha256-ppc.s: {- $sourcedir -}/asm/sha512-ppc.pl + $(PERL) {- $sourcedir -}/asm/sha512-ppc.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/sha512-ppc.s: {- $sourcedir -}/asm/sha512-ppc.pl + $(PERL) {- $sourcedir -}/asm/sha512-ppc.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/sha256p8-ppc.s: {- $sourcedir -}/asm/sha512p8-ppc.pl + $(PERL) {- $sourcedir -}/asm/sha512p8-ppc.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/sha512p8-ppc.s: {- $sourcedir -}/asm/sha512p8-ppc.pl + $(PERL) {- $sourcedir -}/asm/sha512p8-ppc.pl $(PERLASM_SCHEME) $@ + +{- $builddir -}/sha1-parisc.s: {- $sourcedir -}/asm/sha1-parisc.pl + $(PERL) {- $sourcedir -}/asm/sha1-parisc.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/sha256-parisc.s:{- $sourcedir -}/asm/sha512-parisc.pl + $(PERL) {- $sourcedir -}/asm/sha512-parisc.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/sha512-parisc.s:{- $sourcedir -}/asm/sha512-parisc.pl + $(PERL) {- $sourcedir -}/asm/sha512-parisc.pl $(PERLASM_SCHEME) $@ + +{- $builddir -}/sha1-mips.S: {- $sourcedir -}/asm/sha1-mips.pl + $(PERL) {- $sourcedir -}/asm/sha1-mips.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/sha256-mips.S: {- $sourcedir -}/asm/sha512-mips.pl + $(PERL) {- $sourcedir -}/asm/sha512-mips.pl $(PERLASM_SCHEME) $@ +{- $builddir -}/sha512-mips.S: {- $sourcedir -}/asm/sha512-mips.pl + $(PERL) {- $sourcedir -}/asm/sha512-mips.pl $(PERLASM_SCHEME) $@ + +# GNU make "catch all" +{- $builddir -}/sha1-%.S: {- $sourcedir -}/asm/sha1-%.pl + $(PERL) $< $(PERLASM_SCHEME) $@ +{- $builddir -}/sha256-%.S: {- $sourcedir -}/asm/sha512-%.pl + $(PERL) $< $(PERLASM_SCHEME) $@ +{- $builddir -}/sha512-%.S: {- $sourcedir -}/asm/sha512-%.pl + $(PERL) $< $(PERLASM_SCHEME) $@ +ENDRAW[Makefile] diff --git a/crypto/whrlpool/build.info b/crypto/whrlpool/build.info index 64f1407f32..6b996a8c81 100644 --- a/crypto/whrlpool/build.info +++ b/crypto/whrlpool/build.info @@ -1,2 +1,10 @@ LIBS=../../libcrypto SOURCE[../../libcrypto]=wp_dgst.c {- $target{wp_asm_src} -} + +BEGINRAW[Makefile] +{- $builddir -}/wp-mmx.s: {- $sourcedir -}/asm/wp-mmx.pl {- $sourcetop -}/crypto/perlasm/x86asm.pl + $(PERL) {- $sourcedir -}/asm/wp-mmx.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ + +{- $builddir -}/wp-x86_64.s: {- $sourcedir -}/asm/wp-x86_64.pl + $(PERL) {- $sourcedir -}/asm/wp-x86_64.pl $(PERLASM_SCHEME) > $@ +ENDRAW[Makefile] diff --git a/engines/build.info b/engines/build.info index 0c8e04b052..b5362ac9c5 100644 --- a/engines/build.info +++ b/engines/build.info @@ -20,3 +20,10 @@ ELSE DEPEND[libossltest]=../libcrypto INCLUDE[libossltest]={- rel2abs(catdir($builddir,"../include")) -} ../include ENDIF + +BEGINRAW[Makefile] +{- $builddir -}/e_padlock-x86.s: {- $sourcedir -}/asm/e_padlock-x86.pl + $(PERL) {- $sourcedir -}/asm/e_padlock-x86.pl $(PERLASM_SCHEME) $(CFLAGS) $(PROCESSOR) > $@ +{- $builddir -}/e_padlock-x86_64.s: {- $sourcedir -}/asm/e_padlock-x86_64.pl + $(PERL) {- $sourcedir -}/asm/e_padlock-x86_64.pl $(PERLASM_SCHEME) > $@ +ENDRAW[Makefile]