perlasm/x86_64-xlate.pl: work around problem with hex constants in masm.
authorAndy Polyakov <appro@openssl.org>
Thu, 4 May 2017 13:54:29 +0000 (15:54 +0200)
committerAndy Polyakov <appro@openssl.org>
Fri, 5 May 2017 14:56:38 +0000 (16:56 +0200)
Perl, multiple versions, for some reason occasionally takes issue with
letter b[?] in ox([0-9a-f]+) regex. As result some constants, such as
0xb1 came out wrong when generating code for MASM. Fixes GH#3241.

Reviewed-by: Rich Salz <rsalz@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/3385)

(cherry picked from commit c47aea8af1e28e46e1ad5e2e7468b49fec3f4f29)

crypto/perlasm/x86_64-xlate.pl

index 425cd292e7deec2c086f69f0ee108e5514b19b4f..6eaefcfd93dd852d8ec763eff4d3004055043901 100755 (executable)
@@ -217,8 +217,9 @@ my %globals;
            }
            sprintf "\$%s",$self->{value};
        } else {
-           $self->{value} =~ s/0x([0-9a-f]+)/0$1h/ig if ($masm);
-           sprintf "%s",$self->{value};
+           my $value = $self->{value};
+           $value =~ s/0x([0-9a-f]+)/0$1h/ig if ($masm);
+           sprintf "%s",$value;
        }
     }
 }