mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-19 00:14:20 +00:00
Correct ARM NOP encoding
The encoding of NOP in ARMAsmBackend.cpp is missing a trailing zero, which causes the emission of a coprocessor instruction rather than "mov r0, r0" as indicated in the comment. The test also checks for the wrong encoding. http://lists.cs.uiuc.edu/pipermail/llvm-commits/Week-of-Mon-20121203/157919.html git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@169420 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
fa8de24030
commit
f2a1c83c86
@ -220,7 +220,7 @@ void ARMAsmBackend::relaxInstruction(const MCInst &Inst, MCInst &Res) const {
|
||||
bool ARMAsmBackend::writeNopData(uint64_t Count, MCObjectWriter *OW) const {
|
||||
const uint16_t Thumb1_16bitNopEncoding = 0x46c0; // using MOV r8,r8
|
||||
const uint16_t Thumb2_16bitNopEncoding = 0xbf00; // NOP
|
||||
const uint32_t ARMv4_NopEncoding = 0xe1a0000; // using MOV r0,r0
|
||||
const uint32_t ARMv4_NopEncoding = 0xe1a00000; // using MOV r0,r0
|
||||
const uint32_t ARMv6T2_NopEncoding = 0xe320f000; // NOP
|
||||
if (isThumb()) {
|
||||
const uint16_t nopEncoding = hasNOP() ? Thumb2_16bitNopEncoding
|
||||
|
@ -7,4 +7,4 @@ x:
|
||||
.align 4
|
||||
add r0, r1, r2
|
||||
|
||||
@ CHECK: ('_section_data', '020081e0 00001a0e 00001a0e 00001a0e 020081e0')
|
||||
@ CHECK: ('_section_data', '020081e0 0000a0e1 0000a0e1 0000a0e1 020081e0')
|
||||
|
Loading…
x
Reference in New Issue
Block a user