mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-02 07:32:52 +00:00
Allow large immediates for branch instructions in 32bit mode.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@215240 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
f0b70e2fbc
commit
996a304351
@ -432,9 +432,23 @@ public:
|
|||||||
bool isS17Imm() const { return Kind == Expression ||
|
bool isS17Imm() const { return Kind == Expression ||
|
||||||
(Kind == Immediate && isInt<17>(getImm())); }
|
(Kind == Immediate && isInt<17>(getImm())); }
|
||||||
bool isTLSReg() const { return Kind == TLSRegister; }
|
bool isTLSReg() const { return Kind == TLSRegister; }
|
||||||
bool isDirectBr() const { return Kind == Expression ||
|
bool isDirectBr() const {
|
||||||
(Kind == Immediate && isInt<26>(getImm()) &&
|
if (Kind == Expression)
|
||||||
(getImm() & 3) == 0); }
|
return true;
|
||||||
|
if (Kind != Immediate)
|
||||||
|
return false;
|
||||||
|
// Operand must be 64-bit aligned, signed 27-bit immediate.
|
||||||
|
if ((getImm() & 3) != 0)
|
||||||
|
return false;
|
||||||
|
if (isInt<26>(getImm()))
|
||||||
|
return true;
|
||||||
|
if (!IsPPC64) {
|
||||||
|
// In 32-bit mode, large 32-bit quantities wrap around.
|
||||||
|
if (isUInt<32>(getImm()) && isInt<26>(static_cast<int32_t>(getImm())))
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
bool isCondBr() const { return Kind == Expression ||
|
bool isCondBr() const { return Kind == Expression ||
|
||||||
(Kind == Immediate && isInt<16>(getImm()) &&
|
(Kind == Immediate && isInt<16>(getImm()) &&
|
||||||
(getImm() & 3) == 0); }
|
(getImm() & 3) == 0); }
|
||||||
|
6
test/MC/PowerPC/ppc32-ba.s
Normal file
6
test/MC/PowerPC/ppc32-ba.s
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
# RUN: llvm-mc -triple powerpc-unknown-unknown --show-encoding %s | FileCheck %s
|
||||||
|
|
||||||
|
# Check that large immediates in 32bit mode are accepted.
|
||||||
|
|
||||||
|
# CHECK: ba -33554432 # encoding: [0x4a,0x00,0x00,0x02]
|
||||||
|
ba 0xfe000000
|
Loading…
Reference in New Issue
Block a user