From 33cc0cfd46779d7dcdea20b552f57be429f0547b Mon Sep 17 00:00:00 2001 From: Matt Morehouse Date: Fri, 29 Oct 2021 10:37:34 -0700 Subject: [PATCH] [X86] Don't affect jump tables under +tagged-globals. `classifyLocalReference(nullptr)` is called to get the appropriate relocation type for jump tables. We should not use @GOTPCREL for this case. The new test cases trigger assertions without this patch. Reviewed By: eugenis Differential Revision: https://reviews.llvm.org/D112832 --- llvm/lib/Target/X86/X86Subtarget.cpp | 4 ++-- llvm/test/CodeGen/X86/tagged-globals-pic.ll | 23 +++++++++++++++++++ .../test/CodeGen/X86/tagged-globals-static.ll | 23 +++++++++++++++++++ 3 files changed, 48 insertions(+), 2 deletions(-) diff --git a/llvm/lib/Target/X86/X86Subtarget.cpp b/llvm/lib/Target/X86/X86Subtarget.cpp index 45732fafdcc2..503bf5a4634a 100644 --- a/llvm/lib/Target/X86/X86Subtarget.cpp +++ b/llvm/lib/Target/X86/X86Subtarget.cpp @@ -70,8 +70,8 @@ X86Subtarget::classifyLocalReference(const GlobalValue *GV) const { // Tagged globals have non-zero upper bits, which makes direct references // require a 64-bit immediate. On the small code model this causes relocation // errors, so we go through the GOT instead. - if (AllowTaggedGlobals && TM.getCodeModel() == CodeModel::Small && - !isa_and_nonnull(GV)) + if (AllowTaggedGlobals && TM.getCodeModel() == CodeModel::Small && GV && + !isa(GV)) return X86II::MO_GOTPCREL; // If we're not PIC, it's not very interesting. diff --git a/llvm/test/CodeGen/X86/tagged-globals-pic.ll b/llvm/test/CodeGen/X86/tagged-globals-pic.ll index 98bf75a5326a..016cf61e91b9 100644 --- a/llvm/test/CodeGen/X86/tagged-globals-pic.ll +++ b/llvm/test/CodeGen/X86/tagged-globals-pic.ll @@ -42,4 +42,27 @@ define void ()* @func_addr() #0 { ret void ()* @func } +; Jump tables shouldn't go through the GOT. +define i32 @jump_table(i32 %x) #0 { + ; CHECK-LABEL: jump_table: + ; CHECK-NOT: @GOT + + switch i32 %x, label %default [ + i32 0, label %1 + i32 1, label %2 + i32 2, label %3 + i32 3, label %4 + ] +1: + ret i32 7 +2: + ret i32 42 +3: + ret i32 3 +4: + ret i32 8 +default: + ret i32 %x +} + attributes #0 = { "target-features"="+tagged-globals" } diff --git a/llvm/test/CodeGen/X86/tagged-globals-static.ll b/llvm/test/CodeGen/X86/tagged-globals-static.ll index af2fae227ed4..5cfb2c71c464 100644 --- a/llvm/test/CodeGen/X86/tagged-globals-static.ll +++ b/llvm/test/CodeGen/X86/tagged-globals-static.ll @@ -42,4 +42,27 @@ define void ()* @func_addr() #0 { ret void ()* @func } +; Jump tables shouldn't go through the GOT. +define i32 @jump_table(i32 %x) #0 { + ; CHECK-LABEL: jump_table: + ; CHECK-NOT: @GOT + + switch i32 %x, label %default [ + i32 0, label %1 + i32 1, label %2 + i32 2, label %3 + i32 3, label %4 + ] +1: + ret i32 7 +2: + ret i32 42 +3: + ret i32 3 +4: + ret i32 8 +default: + ret i32 %x +} + attributes #0 = { "target-features"="+tagged-globals" }