summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen
diff options
context:
space:
mode:
authorAlex Lorenz <arphaman@gmail.com>2015-08-07 20:48:30 +0000
committerAlex Lorenz <arphaman@gmail.com>2015-08-07 20:48:30 +0000
commit61420f790d0725c9a4c406f162c2c6cab0fcfe62 (patch)
treee2302e58a1d20f31197abdd9ceed43d9d1f3c126 /llvm/lib/CodeGen
parent83127739ff89d3e689b8c15bacf538331b960039 (diff)
downloadbcm5719-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.cpp1
-rw-r--r--llvm/lib/CodeGen/MIRParser/MILexer.h1
-rw-r--r--llvm/lib/CodeGen/MIRParser/MIParser.cpp17
-rw-r--r--llvm/lib/CodeGen/MIRPrinter.cpp3
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 << ')';
}
OpenPOWER on IntegriCloud