forked from OSchip/llvm-project
fix parsing .comm directives on systems which do not represent alignments
as a power of 2. This fixes MC/AsmParser/directive_comm.s llvm-svn: 93867
This commit is contained in:
parent
795bfb7207
commit
ab9cd3e132
|
|
@ -62,7 +62,9 @@ public:
|
|||
bool EnterIncludeFile(const std::string &Filename);
|
||||
|
||||
void PrintMessage(SMLoc Loc, const std::string &Msg, const char *Type) const;
|
||||
|
||||
|
||||
const MCAsmInfo &getMAI() const { return MAI; }
|
||||
|
||||
private:
|
||||
int getNextChar();
|
||||
AsmToken ReturnError(const char *Loc, const std::string &Msg);
|
||||
|
|
|
|||
|
|
@ -1278,6 +1278,13 @@ bool AsmParser::ParseDirectiveComm(bool IsLocal) {
|
|||
Pow2AlignmentLoc = Lexer.getLoc();
|
||||
if (ParseAbsoluteExpression(Pow2Alignment))
|
||||
return true;
|
||||
|
||||
// If this target takes alignments in bytes (not log) validate and convert.
|
||||
if (Lexer.getMAI().getAlignmentIsInBytes()) {
|
||||
if (!isPowerOf2_64(Pow2Alignment))
|
||||
return Error(Pow2AlignmentLoc, "alignment must be a power of 2");
|
||||
Pow2Alignment = Log2_64(Pow2Alignment);
|
||||
}
|
||||
}
|
||||
|
||||
if (Lexer.isNot(AsmToken::EndOfStatement))
|
||||
|
|
|
|||
Loading…
Reference in New Issue