mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-26 23:32:58 +00:00
CPR fixes
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@14960 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
bff3984e25
commit
7330248482
@ -288,14 +288,13 @@ void V8ISel::copyConstantToRegister(MachineBasicBlock *MBB,
|
|||||||
} else if (isa<ConstantPointerNull>(C)) {
|
} else if (isa<ConstantPointerNull>(C)) {
|
||||||
// Copy zero (null pointer) to the register.
|
// Copy zero (null pointer) to the register.
|
||||||
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg (V8::G0).addSImm (0);
|
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg (V8::G0).addSImm (0);
|
||||||
} else if (ConstantPointerRef *CPR = dyn_cast<ConstantPointerRef>(C)) {
|
} else if (GlobalValue *GV = dyn_cast<GlobalValue>(C)) {
|
||||||
// Copy it with a SETHI/OR pair; the JIT + asmwriter should recognize
|
// Copy it with a SETHI/OR pair; the JIT + asmwriter should recognize
|
||||||
// that SETHI %reg,global == SETHI %reg,%hi(global) and
|
// that SETHI %reg,global == SETHI %reg,%hi(global) and
|
||||||
// OR %reg,global,%reg == OR %reg,%lo(global),%reg.
|
// OR %reg,global,%reg == OR %reg,%lo(global),%reg.
|
||||||
unsigned TmpReg = makeAnotherReg (C->getType ());
|
unsigned TmpReg = makeAnotherReg (C->getType ());
|
||||||
BuildMI (*MBB, IP, V8::SETHIi, 1, TmpReg).addGlobalAddress (CPR->getValue());
|
BuildMI (*MBB, IP, V8::SETHIi, 1, TmpReg).addGlobalAddress(GV);
|
||||||
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg (TmpReg)
|
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg(TmpReg).addGlobalAddress(GV);
|
||||||
.addGlobalAddress (CPR->getValue ());
|
|
||||||
} else {
|
} else {
|
||||||
std::cerr << "Offending constant: " << *C << "\n";
|
std::cerr << "Offending constant: " << *C << "\n";
|
||||||
assert (0 && "Can't copy this kind of constant into register yet");
|
assert (0 && "Can't copy this kind of constant into register yet");
|
||||||
|
@ -143,10 +143,10 @@ void V8Printer::emitConstantValueOnly(const Constant *CV) {
|
|||||||
O << (unsigned long long)CI->getValue();
|
O << (unsigned long long)CI->getValue();
|
||||||
else if (const ConstantUInt *CI = dyn_cast<ConstantUInt>(CV))
|
else if (const ConstantUInt *CI = dyn_cast<ConstantUInt>(CV))
|
||||||
O << CI->getValue();
|
O << CI->getValue();
|
||||||
else if (const ConstantPointerRef *CPR = dyn_cast<ConstantPointerRef>(CV))
|
else if (const GlobalValue *GV = dyn_cast<GlobalValue>(CV))
|
||||||
// This is a constant address for a global variable or function. Use the
|
// This is a constant address for a global variable or function. Use the
|
||||||
// name of the variable or function as the address value.
|
// name of the variable or function as the address value.
|
||||||
O << Mang->getValueName(CPR->getValue());
|
O << Mang->getValueName(GV);
|
||||||
else if (const ConstantExpr *CE = dyn_cast<ConstantExpr>(CV)) {
|
else if (const ConstantExpr *CE = dyn_cast<ConstantExpr>(CV)) {
|
||||||
const TargetData &TD = TM.getTargetData();
|
const TargetData &TD = TM.getTargetData();
|
||||||
switch(CE->getOpcode()) {
|
switch(CE->getOpcode()) {
|
||||||
|
@ -288,14 +288,13 @@ void V8ISel::copyConstantToRegister(MachineBasicBlock *MBB,
|
|||||||
} else if (isa<ConstantPointerNull>(C)) {
|
} else if (isa<ConstantPointerNull>(C)) {
|
||||||
// Copy zero (null pointer) to the register.
|
// Copy zero (null pointer) to the register.
|
||||||
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg (V8::G0).addSImm (0);
|
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg (V8::G0).addSImm (0);
|
||||||
} else if (ConstantPointerRef *CPR = dyn_cast<ConstantPointerRef>(C)) {
|
} else if (GlobalValue *GV = dyn_cast<GlobalValue>(C)) {
|
||||||
// Copy it with a SETHI/OR pair; the JIT + asmwriter should recognize
|
// Copy it with a SETHI/OR pair; the JIT + asmwriter should recognize
|
||||||
// that SETHI %reg,global == SETHI %reg,%hi(global) and
|
// that SETHI %reg,global == SETHI %reg,%hi(global) and
|
||||||
// OR %reg,global,%reg == OR %reg,%lo(global),%reg.
|
// OR %reg,global,%reg == OR %reg,%lo(global),%reg.
|
||||||
unsigned TmpReg = makeAnotherReg (C->getType ());
|
unsigned TmpReg = makeAnotherReg (C->getType ());
|
||||||
BuildMI (*MBB, IP, V8::SETHIi, 1, TmpReg).addGlobalAddress (CPR->getValue());
|
BuildMI (*MBB, IP, V8::SETHIi, 1, TmpReg).addGlobalAddress(GV);
|
||||||
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg (TmpReg)
|
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg(TmpReg).addGlobalAddress(GV);
|
||||||
.addGlobalAddress (CPR->getValue ());
|
|
||||||
} else {
|
} else {
|
||||||
std::cerr << "Offending constant: " << *C << "\n";
|
std::cerr << "Offending constant: " << *C << "\n";
|
||||||
assert (0 && "Can't copy this kind of constant into register yet");
|
assert (0 && "Can't copy this kind of constant into register yet");
|
||||||
|
@ -288,14 +288,13 @@ void V8ISel::copyConstantToRegister(MachineBasicBlock *MBB,
|
|||||||
} else if (isa<ConstantPointerNull>(C)) {
|
} else if (isa<ConstantPointerNull>(C)) {
|
||||||
// Copy zero (null pointer) to the register.
|
// Copy zero (null pointer) to the register.
|
||||||
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg (V8::G0).addSImm (0);
|
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg (V8::G0).addSImm (0);
|
||||||
} else if (ConstantPointerRef *CPR = dyn_cast<ConstantPointerRef>(C)) {
|
} else if (GlobalValue *GV = dyn_cast<GlobalValue>(C)) {
|
||||||
// Copy it with a SETHI/OR pair; the JIT + asmwriter should recognize
|
// Copy it with a SETHI/OR pair; the JIT + asmwriter should recognize
|
||||||
// that SETHI %reg,global == SETHI %reg,%hi(global) and
|
// that SETHI %reg,global == SETHI %reg,%hi(global) and
|
||||||
// OR %reg,global,%reg == OR %reg,%lo(global),%reg.
|
// OR %reg,global,%reg == OR %reg,%lo(global),%reg.
|
||||||
unsigned TmpReg = makeAnotherReg (C->getType ());
|
unsigned TmpReg = makeAnotherReg (C->getType ());
|
||||||
BuildMI (*MBB, IP, V8::SETHIi, 1, TmpReg).addGlobalAddress (CPR->getValue());
|
BuildMI (*MBB, IP, V8::SETHIi, 1, TmpReg).addGlobalAddress(GV);
|
||||||
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg (TmpReg)
|
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg(TmpReg).addGlobalAddress(GV);
|
||||||
.addGlobalAddress (CPR->getValue ());
|
|
||||||
} else {
|
} else {
|
||||||
std::cerr << "Offending constant: " << *C << "\n";
|
std::cerr << "Offending constant: " << *C << "\n";
|
||||||
assert (0 && "Can't copy this kind of constant into register yet");
|
assert (0 && "Can't copy this kind of constant into register yet");
|
||||||
|
@ -143,10 +143,10 @@ void V8Printer::emitConstantValueOnly(const Constant *CV) {
|
|||||||
O << (unsigned long long)CI->getValue();
|
O << (unsigned long long)CI->getValue();
|
||||||
else if (const ConstantUInt *CI = dyn_cast<ConstantUInt>(CV))
|
else if (const ConstantUInt *CI = dyn_cast<ConstantUInt>(CV))
|
||||||
O << CI->getValue();
|
O << CI->getValue();
|
||||||
else if (const ConstantPointerRef *CPR = dyn_cast<ConstantPointerRef>(CV))
|
else if (const GlobalValue *GV = dyn_cast<GlobalValue>(CV))
|
||||||
// This is a constant address for a global variable or function. Use the
|
// This is a constant address for a global variable or function. Use the
|
||||||
// name of the variable or function as the address value.
|
// name of the variable or function as the address value.
|
||||||
O << Mang->getValueName(CPR->getValue());
|
O << Mang->getValueName(GV);
|
||||||
else if (const ConstantExpr *CE = dyn_cast<ConstantExpr>(CV)) {
|
else if (const ConstantExpr *CE = dyn_cast<ConstantExpr>(CV)) {
|
||||||
const TargetData &TD = TM.getTargetData();
|
const TargetData &TD = TM.getTargetData();
|
||||||
switch(CE->getOpcode()) {
|
switch(CE->getOpcode()) {
|
||||||
|
@ -288,14 +288,13 @@ void V8ISel::copyConstantToRegister(MachineBasicBlock *MBB,
|
|||||||
} else if (isa<ConstantPointerNull>(C)) {
|
} else if (isa<ConstantPointerNull>(C)) {
|
||||||
// Copy zero (null pointer) to the register.
|
// Copy zero (null pointer) to the register.
|
||||||
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg (V8::G0).addSImm (0);
|
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg (V8::G0).addSImm (0);
|
||||||
} else if (ConstantPointerRef *CPR = dyn_cast<ConstantPointerRef>(C)) {
|
} else if (GlobalValue *GV = dyn_cast<GlobalValue>(C)) {
|
||||||
// Copy it with a SETHI/OR pair; the JIT + asmwriter should recognize
|
// Copy it with a SETHI/OR pair; the JIT + asmwriter should recognize
|
||||||
// that SETHI %reg,global == SETHI %reg,%hi(global) and
|
// that SETHI %reg,global == SETHI %reg,%hi(global) and
|
||||||
// OR %reg,global,%reg == OR %reg,%lo(global),%reg.
|
// OR %reg,global,%reg == OR %reg,%lo(global),%reg.
|
||||||
unsigned TmpReg = makeAnotherReg (C->getType ());
|
unsigned TmpReg = makeAnotherReg (C->getType ());
|
||||||
BuildMI (*MBB, IP, V8::SETHIi, 1, TmpReg).addGlobalAddress (CPR->getValue());
|
BuildMI (*MBB, IP, V8::SETHIi, 1, TmpReg).addGlobalAddress(GV);
|
||||||
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg (TmpReg)
|
BuildMI (*MBB, IP, V8::ORri, 2, R).addReg(TmpReg).addGlobalAddress(GV);
|
||||||
.addGlobalAddress (CPR->getValue ());
|
|
||||||
} else {
|
} else {
|
||||||
std::cerr << "Offending constant: " << *C << "\n";
|
std::cerr << "Offending constant: " << *C << "\n";
|
||||||
assert (0 && "Can't copy this kind of constant into register yet");
|
assert (0 && "Can't copy this kind of constant into register yet");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user