mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	The same situation that effected ARM effects PPC with regards to placing the
LSDA into the TEXT section. We need to generate non-lazy pointers to it on Mach-O. However, the object the NLP points to may be local to the translation unit. If so, then the NLP needs to have the value of that object specified instead of "0", which the linker interprets as "external". git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@98325 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -812,7 +812,15 @@ bool PPCDarwinAsmPrinter::doFinalization(Module &M) { | ||||
|       //   .indirect_symbol _foo | ||||
|       MachineModuleInfoImpl::StubValueTy &MCSym = Stubs[i].second; | ||||
|       OutStreamer.EmitSymbolAttribute(MCSym.getPointer(), MCSA_IndirectSymbol); | ||||
|       OutStreamer.EmitIntValue(0, isPPC64 ? 8 : 4/*size*/, 0/*addrspace*/); | ||||
|  | ||||
|       if (MCSym.getInt()) | ||||
|         // External to current translation unit. | ||||
|         OutStreamer.EmitIntValue(0, isPPC64 ? 8 : 4/*size*/, 0/*addrspace*/); | ||||
|       else | ||||
|         // Internal to current translation unit. | ||||
|         OutStreamer.EmitValue(MCSymbolRefExpr::Create(MCSym.getPointer(), | ||||
|                                                       OutContext), | ||||
|                               isPPC64 ? 8 : 4/*size*/, 0/*addrspace*/); | ||||
|     } | ||||
|  | ||||
|     Stubs.clear(); | ||||
|   | ||||
| @@ -24,6 +24,7 @@ add_llvm_target(PowerPCCodeGen | ||||
|   PPCRegisterInfo.cpp | ||||
|   PPCSubtarget.cpp | ||||
|   PPCTargetMachine.cpp | ||||
|   PPCTargetObjectFile.cpp | ||||
|   ) | ||||
|  | ||||
| target_link_libraries (LLVMPowerPCCodeGen LLVMSelectionDAG) | ||||
|   | ||||
| @@ -13,9 +13,10 @@ | ||||
|  | ||||
| #include "PPCISelLowering.h" | ||||
| #include "PPCMachineFunctionInfo.h" | ||||
| #include "PPCPerfectShuffle.h" | ||||
| #include "PPCPredicates.h" | ||||
| #include "PPCTargetMachine.h" | ||||
| #include "PPCPerfectShuffle.h" | ||||
| #include "PPCTargetObjectFile.h" | ||||
| #include "llvm/ADT/STLExtras.h" | ||||
| #include "llvm/ADT/VectorExtras.h" | ||||
| #include "llvm/CodeGen/CallingConvLower.h" | ||||
| @@ -59,11 +60,11 @@ cl::desc("enable preincrement load/store generation on PPC (experimental)"), | ||||
|  | ||||
| static TargetLoweringObjectFile *CreateTLOF(const PPCTargetMachine &TM) { | ||||
|   if (TM.getSubtargetImpl()->isDarwin()) | ||||
|     return new TargetLoweringObjectFileMachO(); | ||||
|     return new PPCMachOTargetObjectFile(); | ||||
|  | ||||
|   return new TargetLoweringObjectFileELF(); | ||||
| } | ||||
|  | ||||
|  | ||||
| PPCTargetLowering::PPCTargetLowering(PPCTargetMachine &TM) | ||||
|   : TargetLowering(TM, CreateTLOF(TM)), PPCSubTarget(*TM.getSubtargetImpl()) { | ||||
|  | ||||
|   | ||||
							
								
								
									
										33
									
								
								lib/Target/PowerPC/PPCTargetObjectFile.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								lib/Target/PowerPC/PPCTargetObjectFile.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| //===-- llvm/Target/PPCTargetObjectFile.cpp - PPC 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 "PPCTargetObjectFile.h" | ||||
| #include "PPCSubtarget.h" | ||||
| #include "llvm/MC/MCSectionMachO.h" | ||||
| #include "llvm/Support/Dwarf.h" | ||||
| #include "llvm/Target/TargetMachine.h" | ||||
| using namespace llvm; | ||||
| using namespace dwarf; | ||||
|  | ||||
| //===----------------------------------------------------------------------===// | ||||
| //                              Mach-O Target | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| void PPCMachOTargetObjectFile::Initialize(MCContext &Ctx, | ||||
|                                           const TargetMachine &TM) { | ||||
|   TargetLoweringObjectFileMachO::Initialize(Ctx, TM); | ||||
|  | ||||
|   // Exception Handling. | ||||
|   LSDASection = getMachOSection("__TEXT", "__gcc_except_tab", 0, | ||||
|                                 SectionKind::getReadOnlyWithRel()); | ||||
| } | ||||
|  | ||||
| unsigned PPCMachOTargetObjectFile::getTTypeEncoding() const { | ||||
|   return DW_EH_PE_indirect | DW_EH_PE_pcrel | DW_EH_PE_sdata4; | ||||
| } | ||||
							
								
								
									
										34
									
								
								lib/Target/PowerPC/PPCTargetObjectFile.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								lib/Target/PowerPC/PPCTargetObjectFile.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | ||||
| //===-- llvm/Target/PPCTargetObjectFile.h - PowerPC 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_PPC_TARGETOBJECTFILE_H | ||||
| #define LLVM_TARGET_PPC_TARGETOBJECTFILE_H | ||||
|  | ||||
| #include "llvm/CodeGen/TargetLoweringObjectFileImpl.h" | ||||
|  | ||||
| namespace llvm { | ||||
|  | ||||
| class MCContext; | ||||
| class TargetMachine; | ||||
|  | ||||
| // FIXME: This subclass isn't 100% necessary. It will become obsolete once we | ||||
| //        can place all LSDAs into the TEXT section. See | ||||
| //        <rdar://problem/6804645>. | ||||
| class PPCMachOTargetObjectFile : public TargetLoweringObjectFileMachO { | ||||
| public: | ||||
|   PPCMachOTargetObjectFile() : TargetLoweringObjectFileMachO() {} | ||||
|  | ||||
|   virtual void Initialize(MCContext &Ctx, const TargetMachine &TM); | ||||
|  | ||||
|   virtual unsigned getTTypeEncoding() const; | ||||
| }; | ||||
|  | ||||
| } // end namespace llvm | ||||
|  | ||||
| #endif | ||||
		Reference in New Issue
	
	Block a user