mirror of
https://github.com/RPCSX/llvm.git
synced 2025-03-03 02:17:41 +00:00
Static relocation model Thumb jump table interworking.
Make sure the low bit of the PC is set when loading an address directly for jump tables in static relocation model. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@138912 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b45b11bce1
commit
de98273189
@ -923,6 +923,11 @@ void ARMAsmPrinter::EmitJumpTable(const MachineInstr *MI) {
|
|||||||
Expr = MCBinaryExpr::CreateSub(Expr, MCSymbolRefExpr::Create(JTISymbol,
|
Expr = MCBinaryExpr::CreateSub(Expr, MCSymbolRefExpr::Create(JTISymbol,
|
||||||
OutContext),
|
OutContext),
|
||||||
OutContext);
|
OutContext);
|
||||||
|
// If we're generating a table of Thumb addresses in static relocation
|
||||||
|
// model, we need to add one to keep interworking correctly.
|
||||||
|
else if (AFI->isThumbFunction())
|
||||||
|
Expr = MCBinaryExpr::CreateAdd(Expr, MCConstantExpr::Create(1,OutContext),
|
||||||
|
OutContext);
|
||||||
OutStreamer.EmitValue(Expr, 4);
|
OutStreamer.EmitValue(Expr, 4);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user