diff options
| author | Alex Lorenz <arphaman@gmail.com> | 2015-06-23 16:35:26 +0000 |
|---|---|---|
| committer | Alex Lorenz <arphaman@gmail.com> | 2015-06-23 16:35:26 +0000 |
| commit | f3db51de5e44f2392b91444d4bbae9c71facfb44 (patch) | |
| tree | 4c8f8721c67dadee126a6b48ee681708266cdffe /llvm/lib/CodeGen/MIRParser/MILexer.cpp | |
| parent | d86e004b7ec3f041b27171c209a8275600f4bc71 (diff) | |
| download | bcm5719-llvm-f3db51de5e44f2392b91444d4bbae9c71facfb44.tar.gz bcm5719-llvm-f3db51de5e44f2392b91444d4bbae9c71facfb44.zip | |
MIR Serialization: Serialize physical register machine operands.
This commit introduces functionality that's used to serialize machine operands.
Only the physical register operands are serialized by this commit.
Reviewers: Duncan P. N. Exon Smith
Differential Revision: http://reviews.llvm.org/D10525
llvm-svn: 240425
Diffstat (limited to 'llvm/lib/CodeGen/MIRParser/MILexer.cpp')
| -rw-r--r-- | llvm/lib/CodeGen/MIRParser/MILexer.cpp | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/MIRParser/MILexer.cpp b/llvm/lib/CodeGen/MIRParser/MILexer.cpp index 69fbba60085..1cc5956d9fb 100644 --- a/llvm/lib/CodeGen/MIRParser/MILexer.cpp +++ b/llvm/lib/CodeGen/MIRParser/MILexer.cpp @@ -68,6 +68,33 @@ static Cursor lexIdentifier(Cursor C, MIToken &Token) { return C; } +static Cursor lexPercent(Cursor C, MIToken &Token) { + auto Range = C; + C.advance(); // Skip '%' + while (isIdentifierChar(C.peek())) + C.advance(); + Token = MIToken(MIToken::NamedRegister, Range.upto(C)); + return C; +} + +static MIToken::TokenKind symbolToken(char C) { + switch (C) { + case ',': + return MIToken::comma; + case '=': + return MIToken::equal; + default: + return MIToken::Error; + } +} + +static Cursor lexSymbol(Cursor C, MIToken::TokenKind Kind, MIToken &Token) { + auto Range = C; + C.advance(); + Token = MIToken(Kind, Range.upto(C)); + return C; +} + StringRef llvm::lexMIToken( StringRef Source, MIToken &Token, function_ref<void(StringRef::iterator Loc, const Twine &)> ErrorCallback) { @@ -80,6 +107,11 @@ StringRef llvm::lexMIToken( auto Char = C.peek(); if (isalpha(Char) || Char == '_') return lexIdentifier(C, Token).remaining(); + if (Char == '%') + return lexPercent(C, Token).remaining(); + MIToken::TokenKind Kind = symbolToken(Char); + if (Kind != MIToken::Error) + return lexSymbol(C, Kind, Token).remaining(); Token = MIToken(MIToken::Error, C.remaining()); ErrorCallback(C.location(), Twine("unexpected character '") + Twine(Char) + "'"); |

