diff options
author | Andy Polyakov <appro@openssl.org> | 2016-02-10 15:11:40 +0100 |
---|---|---|
committer | Andy Polyakov <appro@openssl.org> | 2016-02-11 21:07:44 +0100 |
commit | fd7dc201d3b9d43972de6a0e659f7ef6421c99cc (patch) | |
tree | f3ba1c5660e81a4428515dbfc7f38060f2e934ff /crypto/perlasm | |
parent | d44bb1c31ca00f4359090daa15659c0dd1a08f0d (diff) | |
download | openssl-new-fd7dc201d3b9d43972de6a0e659f7ef6421c99cc.tar.gz |
perlasm/x86_64-xlate.pl: pass pure constants verbatim.
RT#3885
Reviewed-by: Rich Salz <rsalz@openssl.org>
Diffstat (limited to 'crypto/perlasm')
-rwxr-xr-x | crypto/perlasm/x86_64-xlate.pl | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/crypto/perlasm/x86_64-xlate.pl b/crypto/perlasm/x86_64-xlate.pl index 87f6956252..1f5bced8e1 100755 --- a/crypto/perlasm/x86_64-xlate.pl +++ b/crypto/perlasm/x86_64-xlate.pl @@ -198,8 +198,11 @@ my %globals; if ($gas) { # Solaris /usr/ccs/bin/as can't handle multiplications # in $self->{value} - $self->{value} =~ s/(?<![\w\$\.])(0x?[0-9a-f]+)/oct($1)/egi; - $self->{value} =~ s/([0-9]+\s*[\*\/\%]\s*[0-9]+)/eval($1)/eg; + my $value = $self->{value}; + $value =~ s/(?<![\w\$\.])(0x?[0-9a-f]+)/oct($1)/egi; + if ($value =~ s/([0-9]+\s*[\*\/\%]\s*[0-9]+)/eval($1)/eg) { + $self->{value} = $value; + } sprintf "\$%s",$self->{value}; } else { $self->{value} =~ s/(0b[0-1]+)/oct($1)/eig; |