mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-11-05 13:16:32 +00:00
[mips64] Emit correct addend for some PC-relative relocations
So far, LLVM has not emitted correct addend for N64 and N32 ABI. This patch fixes that. It also removes fixup from MCJIT for R_MIPS_PC16 relocation. Patch by Vladimir Radosavljevic. Differential Revision: http://reviews.llvm.org/D10565 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@240404 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -630,7 +630,7 @@ RuntimeDyldELF::evaluateMIPS64Relocation(const SectionEntry &Section,
|
|||||||
}
|
}
|
||||||
case ELF::R_MIPS_PC16: {
|
case ELF::R_MIPS_PC16: {
|
||||||
uint64_t FinalAddress = (Section.LoadAddress + Offset);
|
uint64_t FinalAddress = (Section.LoadAddress + Offset);
|
||||||
return ((Value + Addend - FinalAddress - 4) >> 2) & 0xffff;
|
return ((Value + Addend - FinalAddress) >> 2) & 0xffff;
|
||||||
}
|
}
|
||||||
case ELF::R_MIPS_PC32: {
|
case ELF::R_MIPS_PC32: {
|
||||||
uint64_t FinalAddress = (Section.LoadAddress + Offset);
|
uint64_t FinalAddress = (Section.LoadAddress + Offset);
|
||||||
|
|||||||
@@ -59,10 +59,6 @@ static unsigned adjustFixupValue(const MCFixup &Fixup, uint64_t Value,
|
|||||||
case Mips::fixup_MIPS_PCLO16:
|
case Mips::fixup_MIPS_PCLO16:
|
||||||
break;
|
break;
|
||||||
case Mips::fixup_Mips_PC16:
|
case Mips::fixup_Mips_PC16:
|
||||||
// So far we are only using this type for branches.
|
|
||||||
// For branches we start 1 instruction after the branch
|
|
||||||
// so the displacement will be one instruction size less.
|
|
||||||
Value -= 4;
|
|
||||||
// The displacement is then divided by 4 to give us an 18 bit
|
// The displacement is then divided by 4 to give us an 18 bit
|
||||||
// address range. Forcing a signed division because Value can be negative.
|
// address range. Forcing a signed division because Value can be negative.
|
||||||
Value = (int64_t)Value / 4;
|
Value = (int64_t)Value / 4;
|
||||||
@@ -135,7 +131,6 @@ static unsigned adjustFixupValue(const MCFixup &Fixup, uint64_t Value,
|
|||||||
Ctx->reportFatalError(Fixup.getLoc(), "out of range PC18 fixup");
|
Ctx->reportFatalError(Fixup.getLoc(), "out of range PC18 fixup");
|
||||||
break;
|
break;
|
||||||
case Mips::fixup_MIPS_PC21_S2:
|
case Mips::fixup_MIPS_PC21_S2:
|
||||||
Value -= 4;
|
|
||||||
// Forcing a signed division because Value can be negative.
|
// Forcing a signed division because Value can be negative.
|
||||||
Value = (int64_t) Value / 4;
|
Value = (int64_t) Value / 4;
|
||||||
// We now check if Value can be encoded as a 21-bit signed immediate.
|
// We now check if Value can be encoded as a 21-bit signed immediate.
|
||||||
@@ -143,7 +138,6 @@ static unsigned adjustFixupValue(const MCFixup &Fixup, uint64_t Value,
|
|||||||
Ctx->reportFatalError(Fixup.getLoc(), "out of range PC21 fixup");
|
Ctx->reportFatalError(Fixup.getLoc(), "out of range PC21 fixup");
|
||||||
break;
|
break;
|
||||||
case Mips::fixup_MIPS_PC26_S2:
|
case Mips::fixup_MIPS_PC26_S2:
|
||||||
Value -= 4;
|
|
||||||
// Forcing a signed division because Value can be negative.
|
// Forcing a signed division because Value can be negative.
|
||||||
Value = (int64_t) Value / 4;
|
Value = (int64_t) Value / 4;
|
||||||
// We now check if Value can be encoded as a 26-bit signed immediate.
|
// We now check if Value can be encoded as a 26-bit signed immediate.
|
||||||
|
|||||||
@@ -226,8 +226,9 @@ getBranchTargetOpValue(const MCInst &MI, unsigned OpNo,
|
|||||||
assert(MO.isExpr() &&
|
assert(MO.isExpr() &&
|
||||||
"getBranchTargetOpValue expects only expressions or immediates");
|
"getBranchTargetOpValue expects only expressions or immediates");
|
||||||
|
|
||||||
const MCExpr *Expr = MO.getExpr();
|
const MCExpr *FixupExpression = MCBinaryExpr::createAdd(
|
||||||
Fixups.push_back(MCFixup::create(0, Expr,
|
MO.getExpr(), MCConstantExpr::create(-4, Ctx), Ctx);
|
||||||
|
Fixups.push_back(MCFixup::create(0, FixupExpression,
|
||||||
MCFixupKind(Mips::fixup_Mips_PC16)));
|
MCFixupKind(Mips::fixup_Mips_PC16)));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -315,8 +316,9 @@ getBranchTarget21OpValue(const MCInst &MI, unsigned OpNo,
|
|||||||
assert(MO.isExpr() &&
|
assert(MO.isExpr() &&
|
||||||
"getBranchTarget21OpValue expects only expressions or immediates");
|
"getBranchTarget21OpValue expects only expressions or immediates");
|
||||||
|
|
||||||
const MCExpr *Expr = MO.getExpr();
|
const MCExpr *FixupExpression = MCBinaryExpr::createAdd(
|
||||||
Fixups.push_back(MCFixup::create(0, Expr,
|
MO.getExpr(), MCConstantExpr::create(-4, Ctx), Ctx);
|
||||||
|
Fixups.push_back(MCFixup::create(0, FixupExpression,
|
||||||
MCFixupKind(Mips::fixup_MIPS_PC21_S2)));
|
MCFixupKind(Mips::fixup_MIPS_PC21_S2)));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@@ -337,8 +339,9 @@ getBranchTarget26OpValue(const MCInst &MI, unsigned OpNo,
|
|||||||
assert(MO.isExpr() &&
|
assert(MO.isExpr() &&
|
||||||
"getBranchTarget26OpValue expects only expressions or immediates");
|
"getBranchTarget26OpValue expects only expressions or immediates");
|
||||||
|
|
||||||
const MCExpr *Expr = MO.getExpr();
|
const MCExpr *FixupExpression = MCBinaryExpr::createAdd(
|
||||||
Fixups.push_back(MCFixup::create(0, Expr,
|
MO.getExpr(), MCConstantExpr::create(-4, Ctx), Ctx);
|
||||||
|
Fixups.push_back(MCFixup::create(0, FixupExpression,
|
||||||
MCFixupKind(Mips::fixup_MIPS_PC26_S2)));
|
MCFixupKind(Mips::fixup_MIPS_PC26_S2)));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,41 +7,41 @@ local_label:
|
|||||||
blt $7, $8, local_label
|
blt $7, $8, local_label
|
||||||
# CHECK: slt $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2a]
|
# CHECK: slt $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2a]
|
||||||
# CHECK: bnez $1, local_label # encoding: [0x14,0x20,A,A]
|
# CHECK: bnez $1, local_label # encoding: [0x14,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
blt $7, $8, global_label
|
blt $7, $8, global_label
|
||||||
# CHECK: slt $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2a]
|
# CHECK: slt $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2a]
|
||||||
# CHECK: bnez $1, global_label # encoding: [0x14,0x20,A,A]
|
# CHECK: bnez $1, global_label # encoding: [0x14,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: global_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: global_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
blt $7, $0, local_label
|
blt $7, $0, local_label
|
||||||
# CHECK: bltz $7, local_label # encoding: [0x04,0xe0,A,A]
|
# CHECK: bltz $7, local_label # encoding: [0x04,0xe0,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
blt $0, $8, local_label
|
blt $0, $8, local_label
|
||||||
# CHECK: bgtz $8, local_label # encoding: [0x1d,0x00,A,A]
|
# CHECK: bgtz $8, local_label # encoding: [0x1d,0x00,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
blt $0, $0, local_label
|
blt $0, $0, local_label
|
||||||
# CHECK: bltz $zero, local_label # encoding: [0x04,0x00,A,A]
|
# CHECK: bltz $zero, local_label # encoding: [0x04,0x00,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
|
|
||||||
bltu $7, $8, local_label
|
bltu $7, $8, local_label
|
||||||
# CHECK: sltu $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2b]
|
# CHECK: sltu $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2b]
|
||||||
# CHECK: bnez $1, local_label # encoding: [0x14,0x20,A,A]
|
# CHECK: bnez $1, local_label # encoding: [0x14,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bltu $7, $8, global_label
|
bltu $7, $8, global_label
|
||||||
# CHECK: sltu $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2b]
|
# CHECK: sltu $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2b]
|
||||||
# CHECK: bnez $1, global_label # encoding: [0x14,0x20,A,A]
|
# CHECK: bnez $1, global_label # encoding: [0x14,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: global_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: global_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bltu $7, $0, local_label
|
bltu $7, $0, local_label
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bltu $0, $8, local_label
|
bltu $0, $8, local_label
|
||||||
# CHECK: bnez $8, local_label # encoding: [0x15,0x00,A,A]
|
# CHECK: bnez $8, local_label # encoding: [0x15,0x00,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bltu $0, $0, local_label
|
bltu $0, $0, local_label
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
@@ -49,141 +49,141 @@ local_label:
|
|||||||
ble $7, $8, local_label
|
ble $7, $8, local_label
|
||||||
# CHECK: slt $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2a]
|
# CHECK: slt $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2a]
|
||||||
# CHECK: beqz $1, local_label # encoding: [0x10,0x20,A,A]
|
# CHECK: beqz $1, local_label # encoding: [0x10,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
ble $7, $8, global_label
|
ble $7, $8, global_label
|
||||||
# CHECK: slt $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2a]
|
# CHECK: slt $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2a]
|
||||||
# CHECK: beqz $1, global_label # encoding: [0x10,0x20,A,A]
|
# CHECK: beqz $1, global_label # encoding: [0x10,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: global_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: global_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
ble $7, $0, local_label
|
ble $7, $0, local_label
|
||||||
# CHECK: blez $7, local_label # encoding: [0x18,0xe0,A,A]
|
# CHECK: blez $7, local_label # encoding: [0x18,0xe0,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
ble $0, $8, local_label
|
ble $0, $8, local_label
|
||||||
# CHECK: bgez $8, local_label # encoding: [0x05,0x01,A,A]
|
# CHECK: bgez $8, local_label # encoding: [0x05,0x01,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
ble $0, $0, local_label
|
ble $0, $0, local_label
|
||||||
# WARNING: :[[@LINE-1]]:3: warning: branch is always taken
|
# WARNING: :[[@LINE-1]]:3: warning: branch is always taken
|
||||||
# CHECK: blez $zero, local_label # encoding: [0x18,0x00,A,A]
|
# CHECK: blez $zero, local_label # encoding: [0x18,0x00,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
|
|
||||||
bleu $7, $8, local_label
|
bleu $7, $8, local_label
|
||||||
# CHECK: sltu $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2b]
|
# CHECK: sltu $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2b]
|
||||||
# CHECK: beqz $1, local_label # encoding: [0x10,0x20,A,A]
|
# CHECK: beqz $1, local_label # encoding: [0x10,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bleu $7, $8, global_label
|
bleu $7, $8, global_label
|
||||||
# CHECK: sltu $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2b]
|
# CHECK: sltu $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2b]
|
||||||
# CHECK: beqz $1, global_label # encoding: [0x10,0x20,A,A]
|
# CHECK: beqz $1, global_label # encoding: [0x10,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: global_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: global_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bleu $7, $0, local_label
|
bleu $7, $0, local_label
|
||||||
# CHECK: beqz $7, local_label # encoding: [0x10,0xe0,A,A]
|
# CHECK: beqz $7, local_label # encoding: [0x10,0xe0,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bleu $0, $8, local_label
|
bleu $0, $8, local_label
|
||||||
# WARNING: :[[@LINE-1]]:3: warning: branch is always taken
|
# WARNING: :[[@LINE-1]]:3: warning: branch is always taken
|
||||||
# CHECK: b local_label # encoding: [0x10,0x00,A,A]
|
# CHECK: b local_label # encoding: [0x10,0x00,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bleu $0, $0, local_label
|
bleu $0, $0, local_label
|
||||||
# WARNING: :[[@LINE-1]]:3: warning: branch is always taken
|
# WARNING: :[[@LINE-1]]:3: warning: branch is always taken
|
||||||
# CHECK: b local_label # encoding: [0x10,0x00,A,A]
|
# CHECK: b local_label # encoding: [0x10,0x00,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
|
|
||||||
bge $7, $8, local_label
|
bge $7, $8, local_label
|
||||||
# CHECK: slt $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2a]
|
# CHECK: slt $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2a]
|
||||||
# CHECK: beqz $1, local_label # encoding: [0x10,0x20,A,A]
|
# CHECK: beqz $1, local_label # encoding: [0x10,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bge $7, $8, global_label
|
bge $7, $8, global_label
|
||||||
# CHECK: slt $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2a]
|
# CHECK: slt $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2a]
|
||||||
# CHECK: beqz $1, global_label # encoding: [0x10,0x20,A,A]
|
# CHECK: beqz $1, global_label # encoding: [0x10,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: global_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: global_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bge $7, $0, local_label
|
bge $7, $0, local_label
|
||||||
# CHECK: bgez $7, local_label # encoding: [0x04,0xe1,A,A]
|
# CHECK: bgez $7, local_label # encoding: [0x04,0xe1,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bge $0, $8, local_label
|
bge $0, $8, local_label
|
||||||
# CHECK: blez $8, local_label # encoding: [0x19,0x00,A,A]
|
# CHECK: blez $8, local_label # encoding: [0x19,0x00,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bge $0, $0, local_label
|
bge $0, $0, local_label
|
||||||
# WARNING: :[[@LINE-1]]:3: warning: branch is always taken
|
# WARNING: :[[@LINE-1]]:3: warning: branch is always taken
|
||||||
# CHECK: bgez $zero, local_label # encoding: [0x04,0x01,A,A]
|
# CHECK: bgez $zero, local_label # encoding: [0x04,0x01,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
|
|
||||||
bgeu $7, $8, local_label
|
bgeu $7, $8, local_label
|
||||||
# CHECK: sltu $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2b]
|
# CHECK: sltu $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2b]
|
||||||
# CHECK: beqz $1, local_label # encoding: [0x10,0x20,A,A]
|
# CHECK: beqz $1, local_label # encoding: [0x10,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bgeu $7, $8, global_label
|
bgeu $7, $8, global_label
|
||||||
# CHECK: sltu $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2b]
|
# CHECK: sltu $1, $7, $8 # encoding: [0x00,0xe8,0x08,0x2b]
|
||||||
# CHECK: beqz $1, global_label # encoding: [0x10,0x20,A,A]
|
# CHECK: beqz $1, global_label # encoding: [0x10,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: global_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: global_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bgeu $7, $0, local_label
|
bgeu $7, $0, local_label
|
||||||
# WARNING: :[[@LINE-1]]:3: warning: branch is always taken
|
# WARNING: :[[@LINE-1]]:3: warning: branch is always taken
|
||||||
# CHECK: b local_label # encoding: [0x10,0x00,A,A]
|
# CHECK: b local_label # encoding: [0x10,0x00,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bgeu $0, $8, local_label
|
bgeu $0, $8, local_label
|
||||||
# CHECK: beqz $8, local_label # encoding: [0x11,0x00,A,A]
|
# CHECK: beqz $8, local_label # encoding: [0x11,0x00,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bgeu $0, $0, local_label
|
bgeu $0, $0, local_label
|
||||||
# WARNING: :[[@LINE-1]]:3: warning: branch is always taken
|
# WARNING: :[[@LINE-1]]:3: warning: branch is always taken
|
||||||
# CHECK: b local_label # encoding: [0x10,0x00,A,A]
|
# CHECK: b local_label # encoding: [0x10,0x00,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
|
|
||||||
bgt $7, $8, local_label
|
bgt $7, $8, local_label
|
||||||
# CHECK: slt $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2a]
|
# CHECK: slt $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2a]
|
||||||
# CHECK: bnez $1, local_label # encoding: [0x14,0x20,A,A]
|
# CHECK: bnez $1, local_label # encoding: [0x14,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bgt $7, $8, global_label
|
bgt $7, $8, global_label
|
||||||
# CHECK: slt $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2a]
|
# CHECK: slt $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2a]
|
||||||
# CHECK: bnez $1, global_label # encoding: [0x14,0x20,A,A]
|
# CHECK: bnez $1, global_label # encoding: [0x14,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: global_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: global_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bgt $7, $0, local_label
|
bgt $7, $0, local_label
|
||||||
# CHECK: bgtz $7, local_label # encoding: [0x1c,0xe0,A,A]
|
# CHECK: bgtz $7, local_label # encoding: [0x1c,0xe0,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bgt $0, $8, local_label
|
bgt $0, $8, local_label
|
||||||
# CHECK: bltz $8, local_label # encoding: [0x05,0x00,A,A]
|
# CHECK: bltz $8, local_label # encoding: [0x05,0x00,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bgt $0, $0, local_label
|
bgt $0, $0, local_label
|
||||||
# CHECK: bgtz $zero, local_label # encoding: [0x1c,0x00,A,A]
|
# CHECK: bgtz $zero, local_label # encoding: [0x1c,0x00,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
|
|
||||||
bgtu $7, $8, local_label
|
bgtu $7, $8, local_label
|
||||||
# CHECK: sltu $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2b]
|
# CHECK: sltu $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2b]
|
||||||
# CHECK: bnez $1, local_label # encoding: [0x14,0x20,A,A]
|
# CHECK: bnez $1, local_label # encoding: [0x14,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bgtu $7, $8, global_label
|
bgtu $7, $8, global_label
|
||||||
# CHECK: sltu $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2b]
|
# CHECK: sltu $1, $8, $7 # encoding: [0x01,0x07,0x08,0x2b]
|
||||||
# CHECK: bnez $1, global_label # encoding: [0x14,0x20,A,A]
|
# CHECK: bnez $1, global_label # encoding: [0x14,0x20,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: global_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: global_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bgtu $7, $0, local_label
|
bgtu $7, $0, local_label
|
||||||
# CHECK: bnez $7, local_label # encoding: [0x14,0xe0,A,A]
|
# CHECK: bnez $7, local_label # encoding: [0x14,0xe0,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bgtu $0, $8, local_label
|
bgtu $0, $8, local_label
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
bgtu $0, $0, local_label
|
bgtu $0, $0, local_label
|
||||||
# CHECK: bnez $zero, local_label # encoding: [0x14,0x00,A,A]
|
# CHECK: bnez $zero, local_label # encoding: [0x14,0x00,A,A]
|
||||||
# CHECK: # fixup A - offset: 0, value: local_label, kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: local_label-4, kind: fixup_Mips_PC16
|
||||||
# CHECK: nop
|
# CHECK: nop
|
||||||
|
|||||||
@@ -139,7 +139,7 @@
|
|||||||
# FP move instructions
|
# FP move instructions
|
||||||
#------------------------------------------------------------------------------
|
#------------------------------------------------------------------------------
|
||||||
# CHECK: bc1f $BB_1 # encoding: [A,A,0x00,0x45]
|
# CHECK: bc1f $BB_1 # encoding: [A,A,0x00,0x45]
|
||||||
# CHECK: # fixup A - offset: 0, value: ($BB_1), kind: fixup_Mips_PC16
|
# CHECK: # fixup A - offset: 0, value: ($BB_1)-4, kind: fixup_Mips_PC16
|
||||||
|
|
||||||
# CHECK: cfc1 $6, $0 # encoding: [0x00,0x00,0x46,0x44]
|
# CHECK: cfc1 $6, $0 # encoding: [0x00,0x00,0x46,0x44]
|
||||||
# CHECK: ctc1 $10, $31 # encoding: [0x00,0xf8,0xca,0x44]
|
# CHECK: ctc1 $10, $31 # encoding: [0x00,0xf8,0xca,0x44]
|
||||||
|
|||||||
@@ -10,22 +10,22 @@
|
|||||||
# CHECK-FIXUP: value: bar, kind: fixup_MIPS_PC19_S2
|
# CHECK-FIXUP: value: bar, kind: fixup_MIPS_PC19_S2
|
||||||
# CHECK-FIXUP: beqc $5, $6, bar # encoding: [0x20,0xa6,A,A]
|
# CHECK-FIXUP: beqc $5, $6, bar # encoding: [0x20,0xa6,A,A]
|
||||||
# CHECK-FIXUP: # fixup A - offset: 0,
|
# CHECK-FIXUP: # fixup A - offset: 0,
|
||||||
# CHECK-FIXUP: value: bar, kind: fixup_Mips_PC16
|
# CHECK-FIXUP: value: bar-4, kind: fixup_Mips_PC16
|
||||||
# CHECK-FIXUP: bnec $5, $6, bar # encoding: [0x60,0xa6,A,A]
|
# CHECK-FIXUP: bnec $5, $6, bar # encoding: [0x60,0xa6,A,A]
|
||||||
# CHECK-FIXUP: # fixup A - offset: 0,
|
# CHECK-FIXUP: # fixup A - offset: 0,
|
||||||
# CHECK-FIXUP: value: bar, kind: fixup_Mips_PC16
|
# CHECK-FIXUP: value: bar-4, kind: fixup_Mips_PC16
|
||||||
# CHECK-FIXUP: beqzc $9, bar # encoding: [0xd9,0b001AAAAA,A,A]
|
# CHECK-FIXUP: beqzc $9, bar # encoding: [0xd9,0b001AAAAA,A,A]
|
||||||
# CHECK-FIXUP: # fixup A - offset: 0,
|
# CHECK-FIXUP: # fixup A - offset: 0,
|
||||||
# CHECK-FIXUP: value: bar, kind: fixup_MIPS_PC21_S2
|
# CHECK-FIXUP: value: bar-4, kind: fixup_MIPS_PC21_S2
|
||||||
# CHECK-FIXUP: bnezc $9, bar # encoding: [0xf9,0b001AAAAA,A,A]
|
# CHECK-FIXUP: bnezc $9, bar # encoding: [0xf9,0b001AAAAA,A,A]
|
||||||
# CHECK-FIXUP: # fixup A - offset: 0,
|
# CHECK-FIXUP: # fixup A - offset: 0,
|
||||||
# CHECK-FIXUP: value: bar, kind: fixup_MIPS_PC21_S2
|
# CHECK-FIXUP: value: bar-4, kind: fixup_MIPS_PC21_S2
|
||||||
# CHECK-FIXUP: balc bar # encoding: [0b111010AA,A,A,A]
|
# CHECK-FIXUP: balc bar # encoding: [0b111010AA,A,A,A]
|
||||||
# CHECK-FIXUP: # fixup A - offset: 0,
|
# CHECK-FIXUP: # fixup A - offset: 0,
|
||||||
# CHECK-FIXUP: value: bar, kind: fixup_MIPS_PC26_S2
|
# CHECK-FIXUP: value: bar-4, kind: fixup_MIPS_PC26_S2
|
||||||
# CHECK-FIXUP: bc bar # encoding: [0b110010AA,A,A,A]
|
# CHECK-FIXUP: bc bar # encoding: [0b110010AA,A,A,A]
|
||||||
# CHECK-FIXUP: # fixup A - offset: 0,
|
# CHECK-FIXUP: # fixup A - offset: 0,
|
||||||
# CHECK-FIXUP: value: bar, kind: fixup_MIPS_PC26_S2
|
# CHECK-FIXUP: value: bar-4, kind: fixup_MIPS_PC26_S2
|
||||||
# CHECK-FIXUP: aluipc $2, %pcrel_hi(bar) # encoding: [0xec,0x5f,A,A]
|
# CHECK-FIXUP: aluipc $2, %pcrel_hi(bar) # encoding: [0xec,0x5f,A,A]
|
||||||
# CHECK-FIXUP: # fixup A - offset: 0,
|
# CHECK-FIXUP: # fixup A - offset: 0,
|
||||||
# CHECK-FIXUP: value: bar@PCREL_HI16,
|
# CHECK-FIXUP: value: bar@PCREL_HI16,
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# RUN: llvm-mc %s -triple=mips-unknown-linux -show-encoding -mcpu=mips64r6 \
|
# RUN: llvm-mc %s -triple=mips64-unknown-linux -show-encoding -mcpu=mips64r6 \
|
||||||
# RUN: | FileCheck %s -check-prefix=CHECK-FIXUP
|
# RUN: | FileCheck %s -check-prefix=CHECK-FIXUP
|
||||||
# RUN: llvm-mc %s -filetype=obj -triple=mips-unknown-linux -mcpu=mips64r6 \
|
# RUN: llvm-mc %s -filetype=obj -triple=mips64-unknown-linux -mcpu=mips64r6 \
|
||||||
# RUN: | llvm-readobj -r | FileCheck %s -check-prefix=CHECK-ELF
|
# RUN: | llvm-readobj -r | FileCheck %s -check-prefix=CHECK-ELF
|
||||||
#------------------------------------------------------------------------------
|
#------------------------------------------------------------------------------
|
||||||
# Check that the assembler can handle the documented syntax for fixups.
|
# Check that the assembler can handle the documented syntax for fixups.
|
||||||
@@ -10,22 +10,22 @@
|
|||||||
# CHECK-FIXUP: value: bar, kind: fixup_MIPS_PC19_S2
|
# CHECK-FIXUP: value: bar, kind: fixup_MIPS_PC19_S2
|
||||||
# CHECK-FIXUP: beqc $5, $6, bar # encoding: [0x20,0xa6,A,A]
|
# CHECK-FIXUP: beqc $5, $6, bar # encoding: [0x20,0xa6,A,A]
|
||||||
# CHECK-FIXUP: # fixup A - offset: 0,
|
# CHECK-FIXUP: # fixup A - offset: 0,
|
||||||
# CHECK-FIXUP: value: bar, kind: fixup_Mips_PC16
|
# CHECK-FIXUP: value: bar-4, kind: fixup_Mips_PC16
|
||||||
# CHECK-FIXUP: bnec $5, $6, bar # encoding: [0x60,0xa6,A,A]
|
# CHECK-FIXUP: bnec $5, $6, bar # encoding: [0x60,0xa6,A,A]
|
||||||
# CHECK-FIXUP: # fixup A - offset: 0,
|
# CHECK-FIXUP: # fixup A - offset: 0,
|
||||||
# CHECK-FIXUP: value: bar, kind: fixup_Mips_PC16
|
# CHECK-FIXUP: value: bar-4, kind: fixup_Mips_PC16
|
||||||
# CHECK-FIXUP: beqzc $9, bar # encoding: [0xd9,0b001AAAAA,A,A]
|
# CHECK-FIXUP: beqzc $9, bar # encoding: [0xd9,0b001AAAAA,A,A]
|
||||||
# CHECK-FIXUP: # fixup A - offset: 0,
|
# CHECK-FIXUP: # fixup A - offset: 0,
|
||||||
# CHECK-FIXUP: value: bar, kind: fixup_MIPS_PC21_S2
|
# CHECK-FIXUP: value: bar-4, kind: fixup_MIPS_PC21_S2
|
||||||
# CHECK-FIXUP: bnezc $9, bar # encoding: [0xf9,0b001AAAAA,A,A]
|
# CHECK-FIXUP: bnezc $9, bar # encoding: [0xf9,0b001AAAAA,A,A]
|
||||||
# CHECK-FIXUP: # fixup A - offset: 0,
|
# CHECK-FIXUP: # fixup A - offset: 0,
|
||||||
# CHECK-FIXUP: value: bar, kind: fixup_MIPS_PC21_S2
|
# CHECK-FIXUP: value: bar-4, kind: fixup_MIPS_PC21_S2
|
||||||
# CHECK-FIXUP: balc bar # encoding: [0b111010AA,A,A,A]
|
# CHECK-FIXUP: balc bar # encoding: [0b111010AA,A,A,A]
|
||||||
# CHECK-FIXUP: # fixup A - offset: 0,
|
# CHECK-FIXUP: # fixup A - offset: 0,
|
||||||
# CHECK-FIXUP: value: bar, kind: fixup_MIPS_PC26_S2
|
# CHECK-FIXUP: value: bar-4, kind: fixup_MIPS_PC26_S2
|
||||||
# CHECK-FIXUP: bc bar # encoding: [0b110010AA,A,A,A]
|
# CHECK-FIXUP: bc bar # encoding: [0b110010AA,A,A,A]
|
||||||
# CHECK-FIXUP: # fixup A - offset: 0,
|
# CHECK-FIXUP: # fixup A - offset: 0,
|
||||||
# CHECK-FIXUP: value: bar, kind: fixup_MIPS_PC26_S2
|
# CHECK-FIXUP: value: bar-4, kind: fixup_MIPS_PC26_S2
|
||||||
# CHECK-FIXUP: aluipc $2, %pcrel_hi(bar) # encoding: [0xec,0x5f,A,A]
|
# CHECK-FIXUP: aluipc $2, %pcrel_hi(bar) # encoding: [0xec,0x5f,A,A]
|
||||||
# CHECK-FIXUP: # fixup A - offset: 0,
|
# CHECK-FIXUP: # fixup A - offset: 0,
|
||||||
# CHECK-FIXUP: value: bar@PCREL_HI16,
|
# CHECK-FIXUP: value: bar@PCREL_HI16,
|
||||||
@@ -48,18 +48,18 @@
|
|||||||
# Check that the appropriate relocations were created.
|
# Check that the appropriate relocations were created.
|
||||||
#------------------------------------------------------------------------------
|
#------------------------------------------------------------------------------
|
||||||
# CHECK-ELF: Relocations [
|
# CHECK-ELF: Relocations [
|
||||||
# CHECK-ELF: 0x0 R_MIPS_PC19_S2 bar 0x0
|
# CHECK-ELF: 0x0 R_MIPS_PC19_S2/R_MIPS_NONE/R_MIPS_NONE bar 0x0
|
||||||
# CHECK-ELF: 0x4 R_MIPS_PC16 bar 0x0
|
# CHECK-ELF: 0x4 R_MIPS_PC16/R_MIPS_NONE/R_MIPS_NONE bar 0xFFFFFFFFFFFFFFFC
|
||||||
# CHECK-ELF: 0x8 R_MIPS_PC16 bar 0x0
|
# CHECK-ELF: 0x8 R_MIPS_PC16/R_MIPS_NONE/R_MIPS_NONE bar 0xFFFFFFFFFFFFFFFC
|
||||||
# CHECK-ELF: 0xC R_MIPS_PC21_S2 bar 0x0
|
# CHECK-ELF: 0xC R_MIPS_PC21_S2/R_MIPS_NONE/R_MIPS_NONE bar 0xFFFFFFFFFFFFFFFC
|
||||||
# CHECK-ELF: 0x10 R_MIPS_PC21_S2 bar 0x0
|
# CHECK-ELF: 0x10 R_MIPS_PC21_S2/R_MIPS_NONE/R_MIPS_NONE bar 0xFFFFFFFFFFFFFFFC
|
||||||
# CHECK-ELF: 0x14 R_MIPS_PC26_S2 bar 0x0
|
# CHECK-ELF: 0x14 R_MIPS_PC26_S2/R_MIPS_NONE/R_MIPS_NONE bar 0xFFFFFFFFFFFFFFFC
|
||||||
# CHECK-ELF: 0x18 R_MIPS_PC26_S2 bar 0x0
|
# CHECK-ELF: 0x18 R_MIPS_PC26_S2/R_MIPS_NONE/R_MIPS_NONE bar 0xFFFFFFFFFFFFFFFC
|
||||||
# CHECK-ELF: 0x1C R_MIPS_PCHI16 bar 0x0
|
# CHECK-ELF: 0x1C R_MIPS_PCHI16/R_MIPS_NONE/R_MIPS_NONE bar 0x0
|
||||||
# CHECK-ELF: 0x20 R_MIPS_PCLO16 bar 0x0
|
# CHECK-ELF: 0x20 R_MIPS_PCLO16/R_MIPS_NONE/R_MIPS_NONE bar 0x0
|
||||||
# CHECK-ELF: 0x24 R_MIPS_PC18_S3 bar 0x0
|
# CHECK-ELF: 0x24 R_MIPS_PC18_S3/R_MIPS_NONE/R_MIPS_NONE bar 0x0
|
||||||
# CHECK-ELF: 0x28 R_MIPS_PC19_S2 bar 0x0
|
# CHECK-ELF: 0x28 R_MIPS_PC19_S2/R_MIPS_NONE/R_MIPS_NONE bar 0x0
|
||||||
# CHECK-ELF: 0x2C R_MIPS_PC19_S2 bar 0x0
|
# CHECK-ELF: 0x2C R_MIPS_PC19_S2/R_MIPS_NONE/R_MIPS_NONE bar 0x0
|
||||||
# CHECK-ELF: ]
|
# CHECK-ELF: ]
|
||||||
|
|
||||||
addiupc $2,bar
|
addiupc $2,bar
|
||||||
|
|||||||
@@ -171,12 +171,12 @@
|
|||||||
beqzc $2, foo // RELOC: R_MIPS_PC21_S2 foo
|
beqzc $2, foo // RELOC: R_MIPS_PC21_S2 foo
|
||||||
// ENCBE: beqzc $2, foo # encoding: [0xd8,0b010AAAAA,A,A]
|
// ENCBE: beqzc $2, foo # encoding: [0xd8,0b010AAAAA,A,A]
|
||||||
// ENCLE: beqzc $2, foo # encoding: [A,A,0b010AAAAA,0xd8]
|
// ENCLE: beqzc $2, foo # encoding: [A,A,0b010AAAAA,0xd8]
|
||||||
// FIXUP: # fixup A - offset: 0, value: foo, kind: fixup_MIPS_PC21_S2
|
// FIXUP: # fixup A - offset: 0, value: foo-4, kind: fixup_MIPS_PC21_S2
|
||||||
|
|
||||||
bc foo // RELOC: R_MIPS_PC26_S2 foo
|
bc foo // RELOC: R_MIPS_PC26_S2 foo
|
||||||
// ENCBE: bc foo # encoding: [0b110010AA,A,A,A]
|
// ENCBE: bc foo # encoding: [0b110010AA,A,A,A]
|
||||||
// ENCLE: bc foo # encoding: [A,A,A,0b110010AA]
|
// ENCLE: bc foo # encoding: [A,A,A,0b110010AA]
|
||||||
// FIXUP: # fixup A - offset: 0, value: foo, kind: fixup_MIPS_PC26_S2
|
// FIXUP: # fixup A - offset: 0, value: foo-4, kind: fixup_MIPS_PC26_S2
|
||||||
|
|
||||||
.set mips64r6
|
.set mips64r6
|
||||||
ldpc $2, foo // RELOC: R_MIPS_PC18_S3 foo
|
ldpc $2, foo // RELOC: R_MIPS_PC18_S3 foo
|
||||||
|
|||||||
Reference in New Issue
Block a user