Remove filename argument to x86 asm_init.
The assembler already knows the actual path to the generated file and, in other perlasm architectures, is left to manage debug symbols itself. Notably, in OpenSSL 1.1.x's new build system, which allows a separate build directory, converting .pl to .s as the scripts currently do result in the wrong paths. This also avoids inconsistencies from some of the files using $0 and some passing in the filename. Reviewed-by: Richard Levitte <levitte@openssl.org> Reviewed-by: Andy Polyakov <appro@openssl.org> (Merged from https://github.com/openssl/openssl/pull/3431)
This commit is contained in:
parent
07fbdfe94d
commit
e195c8a256
33 changed files with 35 additions and 38 deletions
|
@ -202,7 +202,7 @@ $output = pop;
|
||||||
open OUT,">$output";
|
open OUT,">$output";
|
||||||
*STDOUT=*OUT;
|
*STDOUT=*OUT;
|
||||||
|
|
||||||
&asm_init($ARGV[0],"aes-586.pl",$x86only = $ARGV[$#ARGV] eq "386");
|
&asm_init($ARGV[0],$x86only = $ARGV[$#ARGV] eq "386");
|
||||||
&static_label("AES_Te");
|
&static_label("AES_Te");
|
||||||
&static_label("AES_Td");
|
&static_label("AES_Td");
|
||||||
|
|
||||||
|
|
|
@ -80,7 +80,7 @@ $output = pop;
|
||||||
open OUT,">$output";
|
open OUT,">$output";
|
||||||
*STDOUT=*OUT;
|
*STDOUT=*OUT;
|
||||||
|
|
||||||
&asm_init($ARGV[0],$0);
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
&external_label("OPENSSL_ia32cap_P");
|
&external_label("OPENSSL_ia32cap_P");
|
||||||
&static_label("key_const");
|
&static_label("key_const");
|
||||||
|
|
|
@ -62,7 +62,7 @@ $output = pop;
|
||||||
open OUT,">$output";
|
open OUT,">$output";
|
||||||
*STDOUT=*OUT;
|
*STDOUT=*OUT;
|
||||||
|
|
||||||
&asm_init($ARGV[0],"vpaes-x86.pl",$x86only = $ARGV[$#ARGV] eq "386");
|
&asm_init($ARGV[0],$x86only = $ARGV[$#ARGV] eq "386");
|
||||||
|
|
||||||
$PREFIX="vpaes";
|
$PREFIX="vpaes";
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,7 @@ require "cbc.pl";
|
||||||
$output = pop;
|
$output = pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"bf-586.pl",$ARGV[$#ARGV] eq "386");
|
&asm_init($ARGV[0],$ARGV[$#ARGV] eq "386");
|
||||||
|
|
||||||
$BF_ROUNDS=16;
|
$BF_ROUNDS=16;
|
||||||
$BF_OFF=($BF_ROUNDS+2)*4;
|
$BF_OFF=($BF_ROUNDS+2)*4;
|
||||||
|
|
|
@ -14,7 +14,7 @@ require "x86asm.pl";
|
||||||
$output = pop;
|
$output = pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],$0);
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
$sse2=0;
|
$sse2=0;
|
||||||
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
||||||
|
|
|
@ -13,7 +13,7 @@ require "x86asm.pl";
|
||||||
$output = pop;
|
$output = pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],$0);
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
&bn_mul_comba("bn_mul_comba8",8);
|
&bn_mul_comba("bn_mul_comba8",8);
|
||||||
&bn_mul_comba("bn_mul_comba4",4);
|
&bn_mul_comba("bn_mul_comba4",4);
|
||||||
|
|
|
@ -91,7 +91,7 @@ require "x86asm.pl";
|
||||||
$output = pop;
|
$output = pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"via-mont.pl");
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
# int bn_mul_mont(BN_ULONG *rp, const BN_ULONG *ap, const BN_ULONG *bp, const BN_ULONG *np,const BN_ULONG *n0, int num);
|
# int bn_mul_mont(BN_ULONG *rp, const BN_ULONG *ap, const BN_ULONG *bp, const BN_ULONG *np,const BN_ULONG *n0, int num);
|
||||||
$func="bn_mul_mont_padlock";
|
$func="bn_mul_mont_padlock";
|
||||||
|
|
|
@ -46,7 +46,7 @@ require "x86asm.pl";
|
||||||
$output = pop;
|
$output = pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],$0,$x86only = $ARGV[$#ARGV] eq "386");
|
&asm_init($ARGV[0],$x86only = $ARGV[$#ARGV] eq "386");
|
||||||
|
|
||||||
$sse2=0;
|
$sse2=0;
|
||||||
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
||||||
|
|
|
@ -40,7 +40,7 @@ require "x86asm.pl";
|
||||||
$output = pop;
|
$output = pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],$0);
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
$sse2=0;
|
$sse2=0;
|
||||||
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
||||||
|
|
|
@ -20,7 +20,7 @@ require("x86/comba.pl");
|
||||||
$output = pop;
|
$output = pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],$0);
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
&bn_mul_add_words("bn_mul_add_words");
|
&bn_mul_add_words("bn_mul_add_words");
|
||||||
&bn_mul_words("bn_mul_words");
|
&bn_mul_words("bn_mul_words");
|
||||||
|
|
|
@ -52,7 +52,7 @@ $OPENSSL=1;
|
||||||
$output = pop;
|
$output = pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"cmll-586.pl",$ARGV[$#ARGV] eq "386");
|
&asm_init($ARGV[0],$ARGV[$#ARGV] eq "386");
|
||||||
|
|
||||||
@T=("eax","ebx","ecx","edx");
|
@T=("eax","ebx","ecx","edx");
|
||||||
$idx="esi";
|
$idx="esi";
|
||||||
|
|
|
@ -21,7 +21,7 @@ require "cbc.pl";
|
||||||
$output=pop;
|
$output=pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"cast-586.pl",$ARGV[$#ARGV] eq "386");
|
&asm_init($ARGV[0],$ARGV[$#ARGV] eq "386");
|
||||||
|
|
||||||
$CAST_ROUNDS=16;
|
$CAST_ROUNDS=16;
|
||||||
$L="edi";
|
$L="edi";
|
||||||
|
|
|
@ -43,7 +43,7 @@ require "x86asm.pl";
|
||||||
$output=pop;
|
$output=pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"chacha-x86.pl",$ARGV[$#ARGV] eq "386");
|
&asm_init($ARGV[0],$ARGV[$#ARGV] eq "386");
|
||||||
|
|
||||||
$xmm=$ymm=0;
|
$xmm=$ymm=0;
|
||||||
for (@ARGV) { $xmm=1 if (/-DOPENSSL_IA32_SSE2/); }
|
for (@ARGV) { $xmm=1 if (/-DOPENSSL_IA32_SSE2/); }
|
||||||
|
|
|
@ -16,7 +16,7 @@ require "x86asm.pl";
|
||||||
$output=pop;
|
$output=pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"crypt586.pl");
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
$L="edi";
|
$L="edi";
|
||||||
$R="esi";
|
$R="esi";
|
||||||
|
|
|
@ -23,7 +23,7 @@ require "desboth.pl";
|
||||||
$output=pop;
|
$output=pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"des-586.pl");
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
$L="edi";
|
$L="edi";
|
||||||
$R="esi";
|
$R="esi";
|
||||||
|
|
|
@ -45,7 +45,7 @@ require "x86asm.pl";
|
||||||
$output=pop;
|
$output=pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"ecp_nistz256-x86.pl",$ARGV[$#ARGV] eq "386");
|
&asm_init($ARGV[0],$ARGV[$#ARGV] eq "386");
|
||||||
|
|
||||||
$sse2=0;
|
$sse2=0;
|
||||||
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
||||||
|
|
|
@ -21,7 +21,7 @@ require "x86asm.pl";
|
||||||
$output=pop;
|
$output=pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],$0);
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
$A="eax";
|
$A="eax";
|
||||||
$B="ebx";
|
$B="ebx";
|
||||||
|
|
|
@ -139,7 +139,7 @@ require "x86asm.pl";
|
||||||
$output=pop;
|
$output=pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"ghash-x86.pl",$x86only = $ARGV[$#ARGV] eq "386");
|
&asm_init($ARGV[0],$x86only = $ARGV[$#ARGV] eq "386");
|
||||||
|
|
||||||
$sse2=0;
|
$sse2=0;
|
||||||
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
||||||
|
|
|
@ -9,7 +9,7 @@ require "x86asm.pl";
|
||||||
|
|
||||||
The first thing we do is setup the file and type of assembler
|
The first thing we do is setup the file and type of assembler
|
||||||
|
|
||||||
&asm_init($ARGV[0],$0);
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
The first argument is the 'type'. Currently
|
The first argument is the 'type'. Currently
|
||||||
'cpp', 'sol', 'a.out', 'elf' or 'win32'.
|
'cpp', 'sol', 'a.out', 'elf' or 'win32'.
|
||||||
|
@ -62,7 +62,7 @@ So a very simple version of this function could be coded as
|
||||||
push(@INC,"perlasm","../../perlasm");
|
push(@INC,"perlasm","../../perlasm");
|
||||||
require "x86asm.pl";
|
require "x86asm.pl";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"cacl.pl");
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
&external_label("other");
|
&external_label("other");
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
|
|
||||||
|
|
||||||
# require 'x86asm.pl';
|
# require 'x86asm.pl';
|
||||||
# &asm_init(<flavor>,"des-586.pl"[,$i386only]);
|
# &asm_init(<flavor>[,$i386only]);
|
||||||
# &function_begin("foo");
|
# &function_begin("foo");
|
||||||
# ...
|
# ...
|
||||||
# &function_end("foo");
|
# &function_end("foo");
|
||||||
|
@ -259,9 +259,8 @@ sub ::asm_finish
|
||||||
}
|
}
|
||||||
|
|
||||||
sub ::asm_init
|
sub ::asm_init
|
||||||
{ my ($type,$fn,$cpu)=@_;
|
{ my ($type,$cpu)=@_;
|
||||||
|
|
||||||
$filename=$fn;
|
|
||||||
$i386=$cpu;
|
$i386=$cpu;
|
||||||
|
|
||||||
$elf=$cpp=$coff=$aout=$macosx=$win32=$netware=$mwerks=$android=0;
|
$elf=$cpp=$coff=$aout=$macosx=$win32=$netware=$mwerks=$android=0;
|
||||||
|
@ -301,8 +300,7 @@ EOF
|
||||||
$pic=0;
|
$pic=0;
|
||||||
for (@ARGV) { $pic=1 if (/\-[fK]PIC/i); }
|
for (@ARGV) { $pic=1 if (/\-[fK]PIC/i); }
|
||||||
|
|
||||||
$filename =~ s/\.pl$//;
|
&file();
|
||||||
&file($filename);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub ::hidden {}
|
sub ::hidden {}
|
||||||
|
|
|
@ -104,7 +104,7 @@ sub ::BC { @_; }
|
||||||
sub ::DWC { @_; }
|
sub ::DWC { @_; }
|
||||||
|
|
||||||
sub ::file
|
sub ::file
|
||||||
{ push(@out,".file\t\"$_[0].s\"\n.text\n"); }
|
{ push(@out,".text\n"); }
|
||||||
|
|
||||||
sub ::function_begin_B
|
sub ::function_begin_B
|
||||||
{ my $func=shift;
|
{ my $func=shift;
|
||||||
|
|
|
@ -85,7 +85,6 @@ sub ::DWC { "@_"; }
|
||||||
|
|
||||||
sub ::file
|
sub ::file
|
||||||
{ my $tmp=<<___;
|
{ my $tmp=<<___;
|
||||||
TITLE $_[0].asm
|
|
||||||
IF \@Version LT 800
|
IF \@Version LT 800
|
||||||
ECHO MASM version 8.00 or later is strongly recommended.
|
ECHO MASM version 8.00 or later is strongly recommended.
|
||||||
ENDIF
|
ENDIF
|
||||||
|
|
|
@ -50,7 +50,7 @@ require "x86asm.pl";
|
||||||
$output=pop;
|
$output=pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"poly1305-x86.pl",$ARGV[$#ARGV] eq "386");
|
&asm_init($ARGV[0],$ARGV[$#ARGV] eq "386");
|
||||||
|
|
||||||
$sse2=$avx=0;
|
$sse2=$avx=0;
|
||||||
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
||||||
|
|
|
@ -73,7 +73,7 @@ require "x86asm.pl";
|
||||||
$output=pop;
|
$output=pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"rc4-586.pl",$x86only = $ARGV[$#ARGV] eq "386");
|
&asm_init($ARGV[0],$x86only = $ARGV[$#ARGV] eq "386");
|
||||||
|
|
||||||
$xx="eax";
|
$xx="eax";
|
||||||
$yy="ebx";
|
$yy="ebx";
|
||||||
|
|
|
@ -15,7 +15,7 @@ require "cbc.pl";
|
||||||
$output = pop;
|
$output = pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"rc5-586.pl");
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
$RC5_MAX_ROUNDS=16;
|
$RC5_MAX_ROUNDS=16;
|
||||||
$RC5_32_OFF=($RC5_MAX_ROUNDS+2)*4;
|
$RC5_32_OFF=($RC5_MAX_ROUNDS+2)*4;
|
||||||
|
|
|
@ -19,7 +19,7 @@ require "x86asm.pl";
|
||||||
$output=pop;
|
$output=pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],$0);
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
$A="ecx";
|
$A="ecx";
|
||||||
$B="esi";
|
$B="esi";
|
||||||
|
|
|
@ -127,7 +127,7 @@ require "x86asm.pl";
|
||||||
$output=pop;
|
$output=pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"sha1-586.pl",$ARGV[$#ARGV] eq "386");
|
&asm_init($ARGV[0],$ARGV[$#ARGV] eq "386");
|
||||||
|
|
||||||
$xmm=$ymm=0;
|
$xmm=$ymm=0;
|
||||||
for (@ARGV) { $xmm=1 if (/-DOPENSSL_IA32_SSE2/); }
|
for (@ARGV) { $xmm=1 if (/-DOPENSSL_IA32_SSE2/); }
|
||||||
|
|
|
@ -76,7 +76,7 @@ require "x86asm.pl";
|
||||||
$output=pop;
|
$output=pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"sha512-586.pl",$ARGV[$#ARGV] eq "386");
|
&asm_init($ARGV[0],$ARGV[$#ARGV] eq "386");
|
||||||
|
|
||||||
$xmm=$avx=0;
|
$xmm=$avx=0;
|
||||||
for (@ARGV) { $xmm=1 if (/-DOPENSSL_IA32_SSE2/); }
|
for (@ARGV) { $xmm=1 if (/-DOPENSSL_IA32_SSE2/); }
|
||||||
|
|
|
@ -62,7 +62,7 @@ require "x86asm.pl";
|
||||||
$output=pop;
|
$output=pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"sha512-586.pl",$ARGV[$#ARGV] eq "386");
|
&asm_init($ARGV[0],$ARGV[$#ARGV] eq "386");
|
||||||
|
|
||||||
$sse2=0;
|
$sse2=0;
|
||||||
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
||||||
|
|
|
@ -59,7 +59,7 @@ require "x86asm.pl";
|
||||||
$output=pop;
|
$output=pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"wp-mmx.pl");
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
sub L() { &data_byte(@_); }
|
sub L() { &data_byte(@_); }
|
||||||
sub LL()
|
sub LL()
|
||||||
|
|
|
@ -14,7 +14,7 @@ $output = pop;
|
||||||
open OUT,">$output";
|
open OUT,">$output";
|
||||||
*STDOUT=*OUT;
|
*STDOUT=*OUT;
|
||||||
|
|
||||||
&asm_init($ARGV[0],"x86cpuid");
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
for (@ARGV) { $sse2=1 if (/-DOPENSSL_IA32_SSE2/); }
|
||||||
|
|
||||||
|
|
|
@ -45,7 +45,7 @@ require "x86asm.pl";
|
||||||
$output=pop;
|
$output=pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],$0);
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
%PADLOCK_PREFETCH=(ecb=>128, cbc=>64); # prefetch errata
|
%PADLOCK_PREFETCH=(ecb=>128, cbc=>64); # prefetch errata
|
||||||
$PADLOCK_CHUNK=512; # Must be a power of 2 larger than 16
|
$PADLOCK_CHUNK=512; # Must be a power of 2 larger than 16
|
||||||
|
|
|
@ -15,7 +15,7 @@ require "uplink-common.pl";
|
||||||
$output = pop;
|
$output = pop;
|
||||||
open STDOUT,">$output";
|
open STDOUT,">$output";
|
||||||
|
|
||||||
&asm_init($ARGV[0],"uplink-x86");
|
&asm_init($ARGV[0]);
|
||||||
|
|
||||||
&external_label("OPENSSL_Uplink");
|
&external_label("OPENSSL_Uplink");
|
||||||
&public_label("OPENSSL_UplinkTable");
|
&public_label("OPENSSL_UplinkTable");
|
||||||
|
|
Loading…
Reference in a new issue