summaryrefslogtreecommitdiffstats
path: root/llvm/lib/AsmParser
diff options
context:
space:
mode:
authorArtur Pilipenko <apilipenko@azulsystems.com>2015-09-18 12:33:31 +0000
committerArtur Pilipenko <apilipenko@azulsystems.com>2015-09-18 12:33:31 +0000
commit84bc62f7a350ab9a513f5ee28e22ac4e34b1503d (patch)
treed27231d5454dd1b275f22f235e64722afbaa40b4 /llvm/lib/AsmParser
parenteda0a48e53cdc24b911609890bdc41103afe32c0 (diff)
downloadbcm5719-llvm-84bc62f7a350ab9a513f5ee28e22ac4e34b1503d.tar.gz
bcm5719-llvm-84bc62f7a350ab9a513f5ee28e22ac4e34b1503d.zip
Support align attribute for return values
Reviewed By: reames Differential Revision: http://reviews.llvm.org/D12844 llvm-svn: 247984
Diffstat (limited to 'llvm/lib/AsmParser')
-rw-r--r--llvm/lib/AsmParser/LLParser.cpp8
1 files changed, 7 insertions, 1 deletions
diff --git a/llvm/lib/AsmParser/LLParser.cpp b/llvm/lib/AsmParser/LLParser.cpp
index b2f7af61743..d7a05fe99c8 100644
--- a/llvm/lib/AsmParser/LLParser.cpp
+++ b/llvm/lib/AsmParser/LLParser.cpp
@@ -1380,6 +1380,13 @@ bool LLParser::ParseOptionalReturnAttrs(AttrBuilder &B) {
B.addDereferenceableOrNullAttr(Bytes);
continue;
}
+ case lltok::kw_align: {
+ unsigned Alignment;
+ if (ParseOptionalAlignment(Alignment))
+ return true;
+ B.addAlignmentAttr(Alignment);
+ continue;
+ }
case lltok::kw_inreg: B.addAttribute(Attribute::InReg); break;
case lltok::kw_noalias: B.addAttribute(Attribute::NoAlias); break;
case lltok::kw_nonnull: B.addAttribute(Attribute::NonNull); break;
@@ -1387,7 +1394,6 @@ bool LLParser::ParseOptionalReturnAttrs(AttrBuilder &B) {
case lltok::kw_zeroext: B.addAttribute(Attribute::ZExt); break;
// Error handling.
- case lltok::kw_align:
case lltok::kw_byval:
case lltok::kw_inalloca:
case lltok::kw_nest:
OpenPOWER on IntegriCloud