mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-11 21:57:55 +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,
|
||||
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);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user