diff options
| author | Chad Rosier <mcrosier@apple.com> | 2013-02-13 01:03:13 +0000 |
|---|---|---|
| committer | Chad Rosier <mcrosier@apple.com> | 2013-02-13 01:03:13 +0000 |
| commit | b2144ce644f7a26e2fed4c172b502a4a93d59c4a (patch) | |
| tree | e95c479411078b8e155adfef20724a6c943bfefd /llvm/lib/MC | |
| parent | 4299cf83a34c4927be723b378f9c1ebf6d6ae510 (diff) | |
| download | bcm5719-llvm-b2144ce644f7a26e2fed4c172b502a4a93d59c4a.tar.gz bcm5719-llvm-b2144ce644f7a26e2fed4c172b502a4a93d59c4a.zip | |
[ms-inline-asm] Make sure the AsmRewrite list is sorted in lexical order.
rdar://13202662
llvm-svn: 175021
Diffstat (limited to 'llvm/lib/MC')
| -rw-r--r-- | llvm/lib/MC/MCParser/AsmParser.cpp | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/llvm/lib/MC/MCParser/AsmParser.cpp b/llvm/lib/MC/MCParser/AsmParser.cpp index 7aa381242cb..0644ea341a3 100644 --- a/llvm/lib/MC/MCParser/AsmParser.cpp +++ b/llvm/lib/MC/MCParser/AsmParser.cpp @@ -4029,6 +4029,10 @@ bool AsmParser::ParseDirectiveMSAlign(SMLoc IDLoc, ParseStatementInfo &Info) { return false; } +bool AsmStringSort (AsmRewrite A, AsmRewrite B) { + return A.Loc.getPointer() < B.Loc.getPointer(); +} + bool AsmParser::ParseMSInlineAsm(void *AsmLoc, std::string &AsmString, unsigned &NumOutputs, unsigned &NumInputs, SmallVectorImpl<std::pair<void *, bool> > &OpDecls, @@ -4153,6 +4157,7 @@ bool AsmParser::ParseMSInlineAsm(void *AsmLoc, std::string &AsmString, AsmRewriteKind PrevKind = AOK_Imm; raw_string_ostream OS(AsmStringIR); const char *Start = SrcMgr.getMemoryBuffer(0)->getBufferStart(); + std::sort (AsmStrRewrites.begin(), AsmStrRewrites.end(), AsmStringSort); for (SmallVectorImpl<struct AsmRewrite>::iterator I = AsmStrRewrites.begin(), E = AsmStrRewrites.end(); I != E; ++I) { const char *Loc = (*I).Loc.getPointer(); |

