mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-03 09:21:13 +00:00
Patch for Mips direct object generation.
When WriteFragmentData() case FT_align called Asm.getBackend().writeNopData() is called, nothing is done since Mips implementation of writeNopData just returned "true". For some reason this has not caused problems in 32 bit mode, but in 64 bit mode it caused an assert when processing multiple function units. The test case included will assert without this patch. It runs twice with different flags to prevent false positives due to changes in code generation over time. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@160084 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
d6a27413c2
commit
1d82115042
@ -216,6 +216,14 @@ public:
|
||||
///
|
||||
/// \return - True on success.
|
||||
bool writeNopData(uint64_t Count, MCObjectWriter *OW) const {
|
||||
// Check for a less than instruction size number of bytes
|
||||
// FIXME: 16 bit instructions are not handled yet here.
|
||||
// We shouldn't be using a hard coded number for instruction size.
|
||||
if (Count % 4) return false;
|
||||
|
||||
uint64_t NumNops = Count / 4;
|
||||
for (uint64_t i = 0; i != NumNops; ++i)
|
||||
OW->Write32(0);
|
||||
return true;
|
||||
}
|
||||
}; // class MipsAsmBackend
|
||||
|
Loading…
Reference in New Issue
Block a user