From bd9d313d5cf263b7248665be52fb68a5e2c2bbf9 Mon Sep 17 00:00:00 2001 From: Peter Collingbourne Date: Tue, 17 Jul 2018 22:40:08 +0000 Subject: [PATCH] CodeGen: Add a target option for emitting .addrsig directives for all address-significant symbols. Differential Revision: https://reviews.llvm.org/D48143 llvm-svn: 337331 --- llvm/include/llvm/CodeGen/CommandFlags.inc | 5 +++ llvm/include/llvm/Target/TargetOptions.h | 11 ++++--- llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp | 8 +++++ llvm/test/CodeGen/X86/addrsig.ll | 36 ++++++++++++++++++++++ 4 files changed, 56 insertions(+), 4 deletions(-) create mode 100644 llvm/test/CodeGen/X86/addrsig.ll diff --git a/llvm/include/llvm/CodeGen/CommandFlags.inc b/llvm/include/llvm/CodeGen/CommandFlags.inc index 8373b3b46ca8..7d2d167289e0 100644 --- a/llvm/include/llvm/CodeGen/CommandFlags.inc +++ b/llvm/include/llvm/CodeGen/CommandFlags.inc @@ -261,6 +261,10 @@ static cl::opt EnableStackSizeSection( "stack-size-section", cl::desc("Emit a section containing stack size metadata"), cl::init(false)); +static cl::opt + EnableAddrsig("addrsig", cl::desc("Emit an address-significance table"), + cl::init(false)); + // Common utility function tightly tied to the options listed here. Initializes // a TargetOptions object with CodeGen flags and returns it. static TargetOptions InitTargetOptionsFromCodeGenFlags() { @@ -289,6 +293,7 @@ static TargetOptions InitTargetOptionsFromCodeGenFlags() { Options.ExplicitEmulatedTLS = EmulatedTLS.getNumOccurrences() > 0; Options.ExceptionModel = ExceptionModel; Options.EmitStackSizeSection = EnableStackSizeSection; + Options.EmitAddrsig = EnableAddrsig; Options.MCOptions = InitMCTargetOptionsFromFlags(); diff --git a/llvm/include/llvm/Target/TargetOptions.h b/llvm/include/llvm/Target/TargetOptions.h index 6c7c05cb0f95..07ed773de55e 100644 --- a/llvm/include/llvm/Target/TargetOptions.h +++ b/llvm/include/llvm/Target/TargetOptions.h @@ -108,10 +108,10 @@ namespace llvm { DisableIntegratedAS(false), RelaxELFRelocations(false), FunctionSections(false), DataSections(false), UniqueSectionNames(true), TrapUnreachable(false), - NoTrapAfterNoreturn(false), - EmulatedTLS(false), ExplicitEmulatedTLS(false), - EnableIPRA(false), EmitStackSizeSection(false), - EnableMachineOutliner(false), SupportsDefaultOutlining(false) {} + NoTrapAfterNoreturn(false), EmulatedTLS(false), + ExplicitEmulatedTLS(false), EnableIPRA(false), + EmitStackSizeSection(false), EnableMachineOutliner(false), + SupportsDefaultOutlining(false), EmitAddrsig(false) {} /// PrintMachineCode - This flag is enabled when the -print-machineinstrs /// option is specified on the command line, and should enable debugging @@ -238,6 +238,9 @@ namespace llvm { /// Set if the target supports default outlining behaviour. unsigned SupportsDefaultOutlining : 1; + /// Emit address-significance table. + unsigned EmitAddrsig : 1; + /// FloatABIType - This setting is set by -float-abi=xxx option is specfied /// on the command line. This setting may either be Default, Soft, or Hard. /// Default selects the target's default behavior. Soft selects the ABI for diff --git a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp index 1b1edfbd154c..30c95a7138d1 100644 --- a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp @@ -1529,6 +1529,14 @@ bool AsmPrinter::doFinalization(Module &M) { } } + if (TM.Options.EmitAddrsig) { + // Emit address-significance attributes for all globals. + OutStreamer->EmitAddrsig(); + for (const GlobalValue &GV : M.global_values()) + if (!GV.getName().startswith("llvm.") && !GV.hasAtLeastLocalUnnamedAddr()) + OutStreamer->EmitAddrsigSym(getSymbol(&GV)); + } + // Allow the target to emit any magic that it wants at the end of the file, // after everything else has gone out. EmitEndOfAsmFile(M); diff --git a/llvm/test/CodeGen/X86/addrsig.ll b/llvm/test/CodeGen/X86/addrsig.ll new file mode 100644 index 000000000000..c8759764ad6b --- /dev/null +++ b/llvm/test/CodeGen/X86/addrsig.ll @@ -0,0 +1,36 @@ +; RUN: llc < %s -mtriple=x86_64-unknown-linux | FileCheck --check-prefix=NO-ADDRSIG %s +; RUN: llc < %s -mtriple=x86_64-unknown-linux -addrsig | FileCheck %s + +; NO-ADDRSIG-NOT: .addrsig + +; CHECK: .addrsig + +; CHECK: .addrsig_sym f1 +define void @f1() { + unreachable +} + +; CHECK-NOT: .addrsig_sym f2 +define internal void @f2() local_unnamed_addr { + unreachable +} + +; CHECK-NOT: .addrsig_sym f3 +declare void @f3() unnamed_addr + +; CHECK: .addrsig_sym g1 +@g1 = global i32 0 +; CHECK-NOT: .addrsig_sym g2 +@g2 = internal local_unnamed_addr global i32 0 +; CHECK-NOT: .addrsig_sym g3 +@g3 = external unnamed_addr global i32 + +; CHECK: .addrsig_sym a1 +@a1 = alias i32, i32* @g1 +; CHECK-NOT: .addrsig_sym a2 +@a2 = internal local_unnamed_addr alias i32, i32* @g2 + +; CHECK: .addrsig_sym i1 +@i1 = ifunc void(), void()* @f1 +; CHECK-NOT: .addrsig_sym i2 +@i2 = internal local_unnamed_addr ifunc void(), void()* @f2