summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndy Polyakov <appro@openssl.org>2016-02-10 15:11:40 +0100
committerAndy Polyakov <appro@openssl.org>2016-02-11 21:07:44 +0100
commitfd7dc201d3b9d43972de6a0e659f7ef6421c99cc (patch)
treef3ba1c5660e81a4428515dbfc7f38060f2e934ff
parentd44bb1c31ca00f4359090daa15659c0dd1a08f0d (diff)
perlasm/x86_64-xlate.pl: pass pure constants verbatim.
RT#3885 Reviewed-by: Rich Salz <rsalz@openssl.org>
-rwxr-xr-xcrypto/perlasm/x86_64-xlate.pl7
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;