diff options
author | Alex Lorenz <arphaman@gmail.com> | 2015-08-07 20:48:30 +0000 |
---|---|---|
committer | Alex Lorenz <arphaman@gmail.com> | 2015-08-07 20:48:30 +0000 |
commit | 61420f790d0725c9a4c406f162c2c6cab0fcfe62 (patch) | |
tree | e2302e58a1d20f31197abdd9ceed43d9d1f3c126 /llvm/lib/CodeGen | |
parent | 83127739ff89d3e689b8c15bacf538331b960039 (diff) | |
download | bcm5719-llvm-61420f790d0725c9a4c406f162c2c6cab0fcfe62.tar.gz bcm5719-llvm-61420f790d0725c9a4c406f162c2c6cab0fcfe62.zip |
MIR Serialization: Serialize the base alignment for the machine memory operands.
llvm-svn: 244357
Diffstat (limited to 'llvm/lib/CodeGen')
-rw-r--r-- | llvm/lib/CodeGen/MIRParser/MILexer.cpp | 1 | ||||
-rw-r--r-- | llvm/lib/CodeGen/MIRParser/MILexer.h | 1 | ||||
-rw-r--r-- | llvm/lib/CodeGen/MIRParser/MIParser.cpp | 17 | ||||
-rw-r--r-- | llvm/lib/CodeGen/MIRPrinter.cpp | 3 |
4 files changed, 18 insertions, 4 deletions
diff --git a/llvm/lib/CodeGen/MIRParser/MILexer.cpp b/llvm/lib/CodeGen/MIRParser/MILexer.cpp index 99029a93c7b..f8640de8f6f 100644 --- a/llvm/lib/CodeGen/MIRParser/MILexer.cpp +++ b/llvm/lib/CodeGen/MIRParser/MILexer.cpp @@ -200,6 +200,7 @@ static MIToken::TokenKind getIdentifierKind(StringRef Identifier) { .Case("volatile", MIToken::kw_volatile) .Case("non-temporal", MIToken::kw_non_temporal) .Case("invariant", MIToken::kw_invariant) + .Case("align", MIToken::kw_align) .Default(MIToken::Identifier); } diff --git a/llvm/lib/CodeGen/MIRParser/MILexer.h b/llvm/lib/CodeGen/MIRParser/MILexer.h index 752344ed050..8448c228a7f 100644 --- a/llvm/lib/CodeGen/MIRParser/MILexer.h +++ b/llvm/lib/CodeGen/MIRParser/MILexer.h @@ -69,6 +69,7 @@ struct MIToken { kw_volatile, kw_non_temporal, kw_invariant, + kw_align, // Identifier tokens Identifier, diff --git a/llvm/lib/CodeGen/MIRParser/MIParser.cpp b/llvm/lib/CodeGen/MIRParser/MIParser.cpp index 8874aaedfcf..fe39d157297 100644 --- a/llvm/lib/CodeGen/MIRParser/MIParser.cpp +++ b/llvm/lib/CodeGen/MIRParser/MIParser.cpp @@ -1128,13 +1128,24 @@ bool MIParser::parseMachineMemoryOperand(MachineMemOperand *&Dest) { int64_t Offset = 0; if (parseOffset(Offset)) return true; - // TODO: Parse the base alignment. + unsigned BaseAlignment = Size; + if (Token.is(MIToken::comma)) { + lex(); + if (Token.isNot(MIToken::kw_align)) + return error("expected 'align'"); + lex(); + if (Token.isNot(MIToken::IntegerLiteral)) + return error("expected an integer literal after 'align'"); + if (getUnsigned(BaseAlignment)) + return true; + lex(); + } // TODO: Parse the attached metadata nodes. if (expectAndConsume(MIToken::rparen)) return true; - Dest = - MF.getMachineMemOperand(MachinePointerInfo(V, Offset), Flags, Size, Size); + Dest = MF.getMachineMemOperand(MachinePointerInfo(V, Offset), Flags, Size, + BaseAlignment); return false; } diff --git a/llvm/lib/CodeGen/MIRPrinter.cpp b/llvm/lib/CodeGen/MIRPrinter.cpp index 4710f168d3a..6327ff28ba8 100644 --- a/llvm/lib/CodeGen/MIRPrinter.cpp +++ b/llvm/lib/CodeGen/MIRPrinter.cpp @@ -679,7 +679,8 @@ void MIPrinter::print(const MachineMemOperand &Op) { printIRValueReference(*Val); // TODO: Print PseudoSourceValue. printOffset(Op.getOffset()); - // TODO: Print the base alignment. + if (Op.getBaseAlignment() != Op.getSize()) + OS << ", align " << Op.getBaseAlignment(); // TODO: Print the metadata attributes. OS << ')'; } |