perlasm/x86_64-xlate.pl: pass pure constants verbatim.
authorAndy Polyakov <appro@openssl.org>
Wed, 10 Feb 2016 14:11:40 +0000 (15:11 +0100)
committerAndy Polyakov <appro@openssl.org>
Thu, 11 Feb 2016 20:26:44 +0000 (21:26 +0100)
RT#3885

Reviewed-by: Rich Salz <rsalz@openssl.org>
(cherry picked from commit fd7dc201d3b9d43972de6a0e659f7ef6421c99cc)

crypto/perlasm/x86_64-xlate.pl

index 9c70b8c2c6e9d730229300d12fee7ab1d45354cd..ee04221c7e1da73f94c0d232168ca75a5499f91e 100755 (executable)
@@ -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;