[llvm] a4e964a - [ms] [llvm-ml] Fix macro case-insensitivity

Eric Astor via llvm-commits llvm-commits at lists.llvm.org
Thu Jul 22 12:51:16 PDT 2021


Author: Eric Astor
Date: 2021-07-22T15:50:52-04:00
New Revision: a4e964a2821905728b866fb64784fbea1f67ccc1

URL: https://github.com/llvm/llvm-project/commit/a4e964a2821905728b866fb64784fbea1f67ccc1
DIFF: https://github.com/llvm/llvm-project/commit/a4e964a2821905728b866fb64784fbea1f67ccc1.diff

LOG: [ms] [llvm-ml] Fix macro case-insensitivity

We previously had issues identifying macros not registered with a lowercase name.

Reviewed By: mstorsjo, thakis

Differential Revision: https://reviews.llvm.org/D106453

Added: 
    

Modified: 
    llvm/lib/MC/MCParser/MasmParser.cpp
    llvm/test/tools/llvm-ml/macro.asm

Removed: 
    


################################################################################
diff  --git a/llvm/lib/MC/MCParser/MasmParser.cpp b/llvm/lib/MC/MCParser/MasmParser.cpp
index 92ec178e34085..7b4d6e529cc2c 100644
--- a/llvm/lib/MC/MCParser/MasmParser.cpp
+++ b/llvm/lib/MC/MCParser/MasmParser.cpp
@@ -5957,7 +5957,7 @@ bool MasmParser::parseDirectiveMacro(StringRef Name, SMLoc NameLoc) {
                    IsMacroFunction);
   DEBUG_WITH_TYPE("asm-macros", dbgs() << "Defining new macro:\n";
                   Macro.dump());
-  getContext().defineMacro(Name, std::move(Macro));
+  getContext().defineMacro(Name.lower(), std::move(Macro));
   return false;
 }
 

diff  --git a/llvm/test/tools/llvm-ml/macro.asm b/llvm/test/tools/llvm-ml/macro.asm
index 93543aaf3d9d1..3c81b89414fc7 100644
--- a/llvm/test/tools/llvm-ml/macro.asm
+++ b/llvm/test/tools/llvm-ml/macro.asm
@@ -8,7 +8,7 @@ xa1 DWORD ?
 
 .code
 
-substitution_macro macro a1:req, a2:=<7>
+SubstitutionMacro macro a1:req, a2:=<7>
   mov eax, a1
   mov eax, a1&
   mov eax, &a1
@@ -27,7 +27,7 @@ endm
 substitution_test_with_default PROC
 ; CHECK-LABEL: substitution_test_with_default:
 
-  substitution_macro 1
+  SubstitutionMacro 1
 ; CHECK: mov eax, 1
 ; CHECK-NEXT: mov eax, 1
 ; CHECK-NEXT: mov eax, 1
@@ -46,7 +46,7 @@ substitution_test_with_default ENDP
 substitution_test_with_value PROC
 ; CHECK-LABEL: substitution_test_with_value:
 
-  substitution_macro 2, 8
+  SubstitutionMacro 2, 8
 ; CHECK: mov eax, 2
 ; CHECK-NEXT: mov eax, 2
 ; CHECK-NEXT: mov eax, 2
@@ -62,7 +62,45 @@ substitution_test_with_value PROC
   ret
 substitution_test_with_value ENDP
 
-ambiguous_substitution_macro MACRO x, y
+substitution_test_lowercase PROC
+; CHECK-LABEL: substitution_test_lowercase:
+
+  substitutionmacro 2, 8
+; CHECK: mov eax, 2
+; CHECK-NEXT: mov eax, 2
+; CHECK-NEXT: mov eax, 2
+; CHECK-NEXT: mov eax, 2
+; CHECK: mov eax, dword ptr [rip + xa1]
+; CHECK-NEXT: mov eax, dword ptr [rip + x2]
+; CHECK-NEXT: mov eax, dword ptr [rip + x2]
+; CHECK: mov eax, 8
+; CHECK-NEXT: mov eax, 8
+; CHECK-NEXT: mov eax, 8
+; CHECK-NEXT: mov eax, 8
+
+  ret
+substitution_test_lowercase ENDP
+
+substitution_test_uppercase PROC
+; CHECK-LABEL: substitution_test_uppercase:
+
+  SUBSTITUTIONMACRO 2, 8
+; CHECK: mov eax, 2
+; CHECK-NEXT: mov eax, 2
+; CHECK-NEXT: mov eax, 2
+; CHECK-NEXT: mov eax, 2
+; CHECK: mov eax, dword ptr [rip + xa1]
+; CHECK-NEXT: mov eax, dword ptr [rip + x2]
+; CHECK-NEXT: mov eax, dword ptr [rip + x2]
+; CHECK: mov eax, 8
+; CHECK-NEXT: mov eax, 8
+; CHECK-NEXT: mov eax, 8
+; CHECK-NEXT: mov eax, 8
+
+  ret
+substitution_test_uppercase ENDP
+
+AmbiguousSubstitutionMacro MACRO x, y
   x&y BYTE 0
 ENDM
 
@@ -70,7 +108,7 @@ ambiguous_substitution_test PROC
 ; CHECK-LABEL: ambiguous_substitution_test:
 
 ; should expand to ab BYTE 0
-  ambiguous_substitution_macro a, b
+  AmbiguousSubstitutionMacro a, b
 
 ; CHECK: ab:
 ; CHECK-NOT: ay:
@@ -78,7 +116,7 @@ ambiguous_substitution_test PROC
 ; CHECK-NOT: xy:
 ambiguous_substitution_test ENDP
 
-ambiguous_substitution_in_string_macro MACRO x, y
+AmbiguousSubstitutionInStringMacro MACRO x, y
   BYTE "x&y"
 ENDM
 
@@ -86,14 +124,14 @@ ambiguous_substitution_in_string_test PROC
 ; CHECK-LABEL: ambiguous_substitution_in_string_test:
 
 ; should expand to BYTE "5y"
-  ambiguous_substitution_in_string_macro 5, 7
+  AmbiguousSubstitutionInStringMacro 5, 7
 
 ; CHECK: .byte 53
 ; CHECK-NEXT: .byte 121
 ; CHECK-NOT: .byte
 ambiguous_substitution_in_string_test ENDP
 
-optional_parameter_macro MACRO a1:req, a2
+OptionalParameterMacro MACRO a1:req, a2
   mov eax, a1
 IFNB <a2>
   mov eax, a2
@@ -104,17 +142,17 @@ ENDM
 optional_parameter_test PROC
 ; CHECK-LABEL: optional_parameter_test:
 
-  optional_parameter_macro 4
+  OptionalParameterMacro 4
 ; CHECK: mov eax, 4
 ; CHECK: ret
 
-  optional_parameter_macro 5, 9
+  OptionalParameterMacro 5, 9
 ; CHECK: mov eax, 5
 ; CHECK: mov eax, 9
 ; CHECK: ret
 optional_parameter_test ENDP
 
-local_symbol_macro MACRO
+LocalSymbolMacro MACRO
   LOCAL a
 a: ret
    jmp a
@@ -123,22 +161,22 @@ ENDM
 local_symbol_test PROC
 ; CHECK-LABEL: local_symbol_test:
 
-  local_symbol_macro
+  LocalSymbolMacro
 ; CHECK: "??0000":
 ; CHECK-NEXT: ret
 ; CHECK-NEXT: jmp "??0000"
 
-  local_symbol_macro
+  LocalSymbolMacro
 ; CHECK: "??0001":
 ; CHECK-NEXT: ret
 ; CHECK-NEXT: jmp "??0001"
 local_symbol_test ENDP
 
-PURGE ambiguous_substitution_macro, local_symbol_macro,
-      optional_parameter_macro
+PURGE AmbiguousSubstitutionMacro, LocalSymbolMacro,
+      OptionalParameterMacro
 
 ; Redefinition
-local_symbol_macro MACRO
+LocalSymbolMacro MACRO
   LOCAL b
 b: xor eax, eax
    jmp b
@@ -147,7 +185,7 @@ ENDM
 purge_test PROC
 ; CHECK-LABEL: purge_test:
 
-  local_symbol_macro
+  LocalSymbolMacro
 ; CHECK: "??0002":
 ; CHECK-NEXT: xor eax, eax
 ; CHECK-NEXT: jmp "??0002"


        


More information about the llvm-commits mailing list