Static relocation model Thumb jump table interworking.
authorJim Grosbach <grosbach@apple.com>
Wed, 31 Aug 2011 22:23:09 +0000 (22:23 +0000)
committerJim Grosbach <grosbach@apple.com>
Wed, 31 Aug 2011 22:23:09 +0000 (22:23 +0000)
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

lib/Target/ARM/ARMAsmPrinter.cpp

index ce238a1bebf5c0c1a53354ba194c3aa70a487ef9..13d2ad504e5291dec9b2cc1b0698d68b167b70ec 100644 (file)
@@ -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);
   }
 }