[PATCH] D101660: [AsmParser][SystemZ][z/OS] Reject character and string literals for HLASM
Anirudh Prasad via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Apr 30 13:18:44 PDT 2021
anirudhp created this revision.
Herald added a subscriber: hiraditya.
anirudhp requested review of this revision.
Herald added a project: LLVM.
Herald added a subscriber: llvm-commits.
- As per the HLASM support we are providing, i.e. support only for the first parameter of the inline asm block, only pertaining to Z machine instructions defined in LLVM, character literals and string literals are not supported (see Figure 4 - https://www-01.ibm.com/servers/resourcelink/svc00100.nsf/pages/zOSV2R3sc264940/$file/asmr1023.pdf for more information)
- This patch explicitly rejects the usage of char literals and string literals (for example "abc 'a'") when the relevant field is set
- This is achieved by introducing a field called `LexHLASMStrings` in MCAsmLexer similar to `LexMasmStrings`
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D101660
Files:
llvm/include/llvm/MC/MCParser/MCAsmLexer.h
llvm/lib/MC/MCParser/AsmLexer.cpp
llvm/unittests/MC/SystemZ/SystemZAsmLexerTest.cpp
Index: llvm/unittests/MC/SystemZ/SystemZAsmLexerTest.cpp
===================================================================
--- llvm/unittests/MC/SystemZ/SystemZAsmLexerTest.cpp
+++ llvm/unittests/MC/SystemZ/SystemZAsmLexerTest.cpp
@@ -700,4 +700,36 @@
EXPECT_EQ(ParsePrimaryExpr, true);
EXPECT_EQ(Parser->hasPendingError(), true);
}
+
+TEST_F(SystemZAsmLexerTest, CheckRejectCharLiterals) {
+ StringRef AsmStr = "abc 'd'";
+
+ // Setup.
+ setupCallToAsmParser(AsmStr);
+ Parser->getLexer().setLexHLASMStrings(true);
+
+ // Lex initially to get the string.
+ Parser->getLexer().Lex();
+
+ SmallVector<AsmToken::TokenKind> ExpectedTokens(
+ {AsmToken::Identifier, AsmToken::Error, AsmToken::Error,
+ AsmToken::EndOfStatement, AsmToken::Eof});
+ lexAndCheckTokens(AsmStr, ExpectedTokens);
+}
+
+TEST_F(SystemZAsmLexerTest, CheckRejectStringLiterals) {
+ StringRef AsmStr = "abc \"ef\"";
+
+ // Setup.
+ setupCallToAsmParser(AsmStr);
+ Parser->getLexer().setLexHLASMStrings(true);
+
+ // Lex initially to get the string.
+ Parser->getLexer().Lex();
+
+ SmallVector<AsmToken::TokenKind> ExpectedTokens(
+ {AsmToken::Identifier, AsmToken::Error, AsmToken::Identifier,
+ AsmToken::Error, AsmToken::EndOfStatement, AsmToken::Eof});
+ lexAndCheckTokens(AsmStr, ExpectedTokens);
+}
} // end anonymous namespace
Index: llvm/lib/MC/MCParser/AsmLexer.cpp
===================================================================
--- llvm/lib/MC/MCParser/AsmLexer.cpp
+++ llvm/lib/MC/MCParser/AsmLexer.cpp
@@ -567,6 +567,9 @@
AsmToken AsmLexer::LexSingleQuote() {
int CurChar = getNextChar();
+ if (LexHLASMStrings)
+ return ReturnError(TokStart, "invalid usage of character literals");
+
if (LexMasmStrings) {
while (CurChar != EOF) {
if (CurChar != '\'') {
@@ -621,6 +624,9 @@
/// LexQuote: String: "..."
AsmToken AsmLexer::LexQuote() {
int CurChar = getNextChar();
+ if (LexHLASMStrings)
+ return ReturnError(TokStart, "invalid usage of string literals");
+
if (LexMasmStrings) {
while (CurChar != EOF) {
if (CurChar != '"') {
Index: llvm/include/llvm/MC/MCParser/MCAsmLexer.h
===================================================================
--- llvm/include/llvm/MC/MCParser/MCAsmLexer.h
+++ llvm/include/llvm/MC/MCParser/MCAsmLexer.h
@@ -57,6 +57,7 @@
bool UseMasmDefaultRadix = false;
unsigned DefaultRadix = 10;
bool LexHLASMIntegers = false;
+ bool LexHLASMStrings = false;
AsmCommentConsumer *CommentConsumer = nullptr;
MCAsmLexer();
@@ -180,6 +181,11 @@
/// Set whether to lex HLASM-flavour integers. For now this is only [0-9]*
void setLexHLASMIntegers(bool V) { LexHLASMIntegers = V; }
+
+ /// Set whether to "lex" HLASM-flavour character and string literals. For now,
+ /// setting this option to true, will disable lexing for character and string
+ /// literals.
+ void setLexHLASMStrings(bool V) { LexHLASMStrings = V; }
};
} // end namespace llvm
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D101660.342015.patch
Type: text/x-patch
Size: 2977 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20210430/414d0bb7/attachment.bin>
More information about the llvm-commits
mailing list