[llvm] r200373 - [Sparc] Use %r_disp32 for pc_rel entries in gcc_except_table and eh_frame.

Jakob Stoklund Olesen stoklund at 2pi.dk
Tue Jan 28 21:10:32 PST 2014


Nice!

> On 28 Jan 2014, at 20:51, Venkatraman Govindaraju <venkatra at cs.wisc.edu> wrote:
> 
> Author: venkatra
> Date: Tue Jan 28 22:51:35 2014
> New Revision: 200373
> 
> URL: http://llvm.org/viewvc/llvm-project?rev=200373&view=rev
> Log:
> [Sparc] Use %r_disp32 for pc_rel entries in gcc_except_table and eh_frame.
> 
> Otherwise, assembler (gas) fails to assemble them with error message "operation
> combines symbols in different segments". This is because MC computes
> pc_rel entries with subtract expression between labels from different sections.
> 
> Added:
>    llvm/trunk/lib/Target/Sparc/SparcTargetObjectFile.cpp
>    llvm/trunk/lib/Target/Sparc/SparcTargetObjectFile.h
> Modified:
>    llvm/trunk/lib/Target/Sparc/CMakeLists.txt
>    llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCAsmInfo.cpp
>    llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCAsmInfo.h
>    llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCExpr.cpp
>    llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCExpr.h
>    llvm/trunk/lib/Target/Sparc/SparcISelLowering.cpp
>    llvm/trunk/test/CodeGen/SPARC/exception.ll
> 
> Modified: llvm/trunk/lib/Target/Sparc/CMakeLists.txt
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/Sparc/CMakeLists.txt?rev=200373&r1=200372&r2=200373&view=diff
> ==============================================================================
> --- llvm/trunk/lib/Target/Sparc/CMakeLists.txt (original)
> +++ llvm/trunk/lib/Target/Sparc/CMakeLists.txt Tue Jan 28 22:51:35 2014
> @@ -27,6 +27,7 @@ add_llvm_target(SparcCodeGen
>   SparcJITInfo.cpp
>   SparcCodeEmitter.cpp
>   SparcMCInstLower.cpp
> +  SparcTargetObjectFile.cpp
>   )
> 
> add_subdirectory(TargetInfo)
> 
> Modified: llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCAsmInfo.cpp
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCAsmInfo.cpp?rev=200373&r1=200372&r2=200373&view=diff
> ==============================================================================
> --- llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCAsmInfo.cpp (original)
> +++ llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCAsmInfo.cpp Tue Jan 28 22:51:35 2014
> @@ -12,7 +12,9 @@
> //===----------------------------------------------------------------------===//
> 
> #include "SparcMCAsmInfo.h"
> +#include "SparcMCExpr.h"
> #include "llvm/ADT/Triple.h"
> +#include "llvm/MC/MCStreamer.h"
> 
> using namespace llvm;
> 
> @@ -42,4 +44,15 @@ SparcELFMCAsmInfo::SparcELFMCAsmInfo(Str
>   UsesELFSectionDirectiveForBSS = true;
> }
> 
> +const MCExpr*
> +SparcELFMCAsmInfo::getExprForPersonalitySymbol(const MCSymbol *Sym,
> +                                               unsigned Encoding,
> +                                               MCStreamer &Streamer) const {
> +  if (Encoding & dwarf::DW_EH_PE_pcrel) {
> +    MCContext &Ctx = Streamer.getContext();
> +    return SparcMCExpr::Create(SparcMCExpr::VK_Sparc_R_DISP32,
> +                               MCSymbolRefExpr::Create(Sym, Ctx), Ctx);
> +  }
> 
> +  return MCAsmInfo::getExprForPersonalitySymbol(Sym, Encoding, Streamer);
> +}
> 
> Modified: llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCAsmInfo.h
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCAsmInfo.h?rev=200373&r1=200372&r2=200373&view=diff
> ==============================================================================
> --- llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCAsmInfo.h (original)
> +++ llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCAsmInfo.h Tue Jan 28 22:51:35 2014
> @@ -17,13 +17,16 @@
> #include "llvm/MC/MCAsmInfoELF.h"
> 
> namespace llvm {
> -  class StringRef;
> +class StringRef;
> 
> -  class SparcELFMCAsmInfo : public MCAsmInfoELF {
> -    virtual void anchor();
> -  public:
> -    explicit SparcELFMCAsmInfo(StringRef TT);
> -  };
> +class SparcELFMCAsmInfo : public MCAsmInfoELF {
> +  virtual void anchor();
> +public:
> +  explicit SparcELFMCAsmInfo(StringRef TT);
> +  virtual const MCExpr* getExprForPersonalitySymbol(const MCSymbol *Sym,
> +                                                    unsigned Encoding,
> +                                                    MCStreamer &Streamer) const;
> +};
> 
> } // namespace llvm
> 
> 
> Modified: llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCExpr.cpp
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCExpr.cpp?rev=200373&r1=200372&r2=200373&view=diff
> ==============================================================================
> --- llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCExpr.cpp (original)
> +++ llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCExpr.cpp Tue Jan 28 22:51:35 2014
> @@ -41,6 +41,7 @@ void SparcMCExpr::PrintImpl(raw_ostream
>   case VK_Sparc_L44:      OS << "%l44("; break;
>   case VK_Sparc_HH:       OS << "%hh(";  break;
>   case VK_Sparc_HM:       OS << "%hm(";  break;
> +  case VK_Sparc_R_DISP32: OS << "%r_disp32("; break;
>   case VK_Sparc_TLS_GD_HI22:   OS << "%tgd_hi22(";   break;
>   case VK_Sparc_TLS_GD_LO10:   OS << "%tgd_lo10(";   break;
>   case VK_Sparc_TLS_GD_ADD:    OS << "%tgd_add(";    break;
> @@ -77,6 +78,7 @@ SparcMCExpr::VariantKind SparcMCExpr::pa
>     .Case("l44", VK_Sparc_L44)
>     .Case("hh",  VK_Sparc_HH)
>     .Case("hm",  VK_Sparc_HM)
> +    .Case("r_disp32",   VK_Sparc_R_DISP32)
>     .Case("tgd_hi22",   VK_Sparc_TLS_GD_HI22)
>     .Case("tgd_lo10",   VK_Sparc_TLS_GD_LO10)
>     .Case("tgd_add",    VK_Sparc_TLS_GD_ADD)
> @@ -101,6 +103,8 @@ SparcMCExpr::VariantKind SparcMCExpr::pa
> bool
> SparcMCExpr::EvaluateAsRelocatableImpl(MCValue &Res,
>                                          const MCAsmLayout *Layout) const {
> +  if (!Layout)
> +    return false;
>   return getSubExpr()->EvaluateAsRelocatable(Res, *Layout);
> }
> 
> 
> Modified: llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCExpr.h
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCExpr.h?rev=200373&r1=200372&r2=200373&view=diff
> ==============================================================================
> --- llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCExpr.h (original)
> +++ llvm/trunk/lib/Target/Sparc/MCTargetDesc/SparcMCExpr.h Tue Jan 28 22:51:35 2014
> @@ -31,6 +31,7 @@ public:
>     VK_Sparc_L44,
>     VK_Sparc_HH,
>     VK_Sparc_HM,
> +    VK_Sparc_R_DISP32,
>     VK_Sparc_TLS_GD_HI22,
>     VK_Sparc_TLS_GD_LO10,
>     VK_Sparc_TLS_GD_ADD,
> 
> Modified: llvm/trunk/lib/Target/Sparc/SparcISelLowering.cpp
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/Sparc/SparcISelLowering.cpp?rev=200373&r1=200372&r2=200373&view=diff
> ==============================================================================
> --- llvm/trunk/lib/Target/Sparc/SparcISelLowering.cpp (original)
> +++ llvm/trunk/lib/Target/Sparc/SparcISelLowering.cpp Tue Jan 28 22:51:35 2014
> @@ -17,6 +17,7 @@
> #include "SparcMachineFunctionInfo.h"
> #include "SparcRegisterInfo.h"
> #include "SparcTargetMachine.h"
> +#include "SparcTargetObjectFile.h"
> #include "llvm/CodeGen/CallingConvLower.h"
> #include "llvm/CodeGen/MachineFrameInfo.h"
> #include "llvm/CodeGen/MachineFunction.h"
> @@ -1363,7 +1364,7 @@ static SPCC::CondCodes FPCondCCodeToFCC(
> }
> 
> SparcTargetLowering::SparcTargetLowering(TargetMachine &TM)
> -  : TargetLowering(TM, new TargetLoweringObjectFileELF()) {
> +  : TargetLowering(TM, new SparcELFTargetObjectFile()) {
>   Subtarget = &TM.getSubtarget<SparcSubtarget>();
> 
>   // Set up the register classes.
> 
> Added: llvm/trunk/lib/Target/Sparc/SparcTargetObjectFile.cpp
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/Sparc/SparcTargetObjectFile.cpp?rev=200373&view=auto
> ==============================================================================
> --- llvm/trunk/lib/Target/Sparc/SparcTargetObjectFile.cpp (added)
> +++ llvm/trunk/lib/Target/Sparc/SparcTargetObjectFile.cpp Tue Jan 28 22:51:35 2014
> @@ -0,0 +1,43 @@
> +//===------- SparcTargetObjectFile.cpp - Sparc Object Info Impl -----------===//
> +//
> +//                     The LLVM Compiler Infrastructure
> +//
> +// This file is distributed under the University of Illinois Open Source
> +// License. See LICENSE.TXT for details.
> +//
> +//===----------------------------------------------------------------------===//
> +
> +#include "SparcTargetObjectFile.h"
> +#include "MCTargetDesc/SparcMCExpr.h"
> +#include "llvm/CodeGen/MachineModuleInfoImpls.h"
> +#include "llvm/Support/Dwarf.h"
> +
> +using namespace llvm;
> +
> +
> +const MCExpr *SparcELFTargetObjectFile::
> +getTTypeGlobalReference(const GlobalValue *GV, Mangler *Mang,
> +                        MachineModuleInfo *MMI, unsigned Encoding,
> +                        MCStreamer &Streamer) const {
> +
> +  if (Encoding & dwarf::DW_EH_PE_pcrel) {
> +    MachineModuleInfoELF &ELFMMI = MMI->getObjFileInfo<MachineModuleInfoELF>();
> +
> +    MCSymbol *SSym = getSymbolWithGlobalValueBase(*Mang, GV, ".DW.stub");
> +
> +    // Add information about the stub reference to ELFMMI so that the stub
> +    // gets emitted by the asmprinter.
> +    MachineModuleInfoImpl::StubValueTy &StubSym = ELFMMI.getGVStubEntry(SSym);
> +    if (StubSym.getPointer() == 0) {
> +      MCSymbol *Sym = getSymbol(*Mang, GV);
> +      StubSym = MachineModuleInfoImpl::StubValueTy(Sym, !GV->hasLocalLinkage());
> +    }
> +
> +    MCContext &Ctx = getContext();
> +    return SparcMCExpr::Create(SparcMCExpr::VK_Sparc_R_DISP32,
> +                               MCSymbolRefExpr::Create(SSym, Ctx), Ctx);
> +  }
> +
> +  return TargetLoweringObjectFileELF::
> +    getTTypeGlobalReference(GV, Mang, MMI, Encoding, Streamer);
> +}
> 
> Added: llvm/trunk/lib/Target/Sparc/SparcTargetObjectFile.h
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/Sparc/SparcTargetObjectFile.h?rev=200373&view=auto
> ==============================================================================
> --- llvm/trunk/lib/Target/Sparc/SparcTargetObjectFile.h (added)
> +++ llvm/trunk/lib/Target/Sparc/SparcTargetObjectFile.h Tue Jan 28 22:51:35 2014
> @@ -0,0 +1,34 @@
> +//===-- SparcTargetObjectFile.h - Sparc Object Info -------------*- C++ -*-===//
> +//
> +//                     The LLVM Compiler Infrastructure
> +//
> +// This file is distributed under the University of Illinois Open Source
> +// License. See LICENSE.TXT for details.
> +//
> +//===----------------------------------------------------------------------===//
> +
> +#ifndef LLVM_TARGET_SPARC_TARGETOBJECTFILE_H
> +#define LLVM_TARGET_SPARC_TARGETOBJECTFILE_H
> +
> +#include "llvm/CodeGen/TargetLoweringObjectFileImpl.h"
> +
> +namespace llvm {
> +
> +class MCContext;
> +class TargetMachine;
> +
> +class SparcELFTargetObjectFile : public TargetLoweringObjectFileELF {
> +public:
> +  SparcELFTargetObjectFile() :
> +    TargetLoweringObjectFileELF()
> +  {}
> +
> +  const MCExpr *
> +  getTTypeGlobalReference(const GlobalValue *GV, Mangler *Mang,
> +                          MachineModuleInfo *MMI, unsigned Encoding,
> +                          MCStreamer &Streamer) const;
> +};
> +
> +} // end namespace llvm
> +
> +#endif
> 
> Modified: llvm/trunk/test/CodeGen/SPARC/exception.ll
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/SPARC/exception.ll?rev=200373&r1=200372&r2=200373&view=diff
> ==============================================================================
> --- llvm/trunk/test/CodeGen/SPARC/exception.ll (original)
> +++ llvm/trunk/test/CodeGen/SPARC/exception.ll Tue Jan 28 22:51:35 2014
> @@ -1,7 +1,9 @@
> ; RUN: llc < %s -march=sparc   -relocation-model=static | FileCheck -check-prefix=V8ABS %s
> ; RUN: llc < %s -march=sparc   -relocation-model=pic    | FileCheck -check-prefix=V8PIC %s
> +; RUN: llc < %s -march=sparc   -relocation-model=pic -disable-cfi    | FileCheck -check-prefix=V8PIC_NOCFI %s
> ; RUN: llc < %s -march=sparcv9 -relocation-model=static | FileCheck -check-prefix=V9ABS %s
> ; RUN: llc < %s -march=sparcv9 -relocation-model=pic    | FileCheck -check-prefix=V9PIC %s
> +; RUN: llc < %s -march=sparcv9 -relocation-model=pic -disable-cfi    | FileCheck -check-prefix=V9PIC_NOCFI %s
> 
> 
> %struct.__fundamental_type_info_pseudo = type { %struct.__type_info_pseudo }
> @@ -40,11 +42,23 @@
> ; V8PIC:        .cfi_register 15, 31
> ; V8PIC:        .section .gcc_except_table
> ; V8PIC-NOT:    .section
> -; V8PIC:        .word .L_ZTIi.DW.stub-
> +; V8PIC:        .word %r_disp32(.L_ZTIi.DW.stub)
> ; V8PIC:        .data
> ; V8PIC: .L_ZTIi.DW.stub:
> ; V8PIC-NEXT:   .word _ZTIi
> 
> +; V8PIC_NOCFI-LABEL: main:
> +; V8PIC_NOCFI:        .section .gcc_except_table
> +; V8PIC_NOCFI-NOT:    .section
> +; V8PIC_NOCFI:        .word %r_disp32(.L_ZTIi.DW.stub)
> +; V8PIC_NOCFI:        .data
> +; V8PIC_NOCFI: .L_ZTIi.DW.stub:
> +; V8PIC_NOCFI-NEXT:   .word _ZTIi
> +; V8PIC_NOCFI:        .section .eh_frame
> +; V8PIC_NOCFI-NOT:    .section
> +; V8PIC_NOCFI:        .word %r_disp32(DW.ref.__gxx_personality_v0)
> +
> +
> ; V9ABS-LABEL: main:
> ; V9ABS:        .cfi_startproc
> ; V9ABS:        .cfi_personality 0, __gxx_personality_v0
> @@ -65,11 +79,22 @@
> ; V9PIC:        .cfi_register 15, 31
> ; V9PIC:        .section .gcc_except_table
> ; V9PIC-NOT:    .section
> -; V9PIC:        .word .L_ZTIi.DW.stub-
> +; V9PIC:        .word %r_disp32(.L_ZTIi.DW.stub)
> ; V9PIC:        .data
> ; V9PIC: .L_ZTIi.DW.stub:
> ; V9PIC-NEXT:   .xword _ZTIi
> 
> +; V9PIC_NOCFI-LABEL: main:
> +; V9PIC_NOCFI:        .section .gcc_except_table
> +; V9PIC_NOCFI-NOT:    .section
> +; V9PIC_NOCFI:        .word %r_disp32(.L_ZTIi.DW.stub)
> +; V9PIC_NOCFI:        .data
> +; V9PIC_NOCFI: .L_ZTIi.DW.stub:
> +; V9PIC_NOCFI-NEXT:   .xword _ZTIi
> +; V9PIC_NOCFI:        .section .eh_frame
> +; V9PIC_NOCFI-NOT:    .section
> +; V9PIC_NOCFI:        .word %r_disp32(DW.ref.__gxx_personality_v0)
> +
> define i32 @main(i32 %argc, i8** nocapture readnone %argv) unnamed_addr #0 {
> entry:
>   %0 = icmp eq i32 %argc, 2
> 
> 
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits




More information about the llvm-commits mailing list