mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-11-04 05:17:07 +00:00 
			
		
		
		
	Summary: Following on from r209907 which made personality encodings indirect, do the same for TType encodings. This fixes the case where a try/catch block needs to generate references to, for example, std::exception in the .gcc_except_table. This commit uses DW_EH_PE_sdata8 for N64 as far as is possible at the moment. However, it is possible to end up with DW_EH_PE_sdata4 when a TargetMachine is not available. There's no risk of issues with inconsistency here since the tables are self describing but it does mean there is a small chance of the PC-relative offset being out of range for particularly large programs. Reviewers: petarj Reviewed By: petarj Subscribers: srhines, joerg, tberghammer, llvm-commits Differential Revision: http://reviews.llvm.org/D9669 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@238190 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			50 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
//===-- llvm/Target/MipsTargetObjectFile.h - Mips 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_LIB_TARGET_MIPS_MIPSTARGETOBJECTFILE_H
 | 
						|
#define LLVM_LIB_TARGET_MIPS_MIPSTARGETOBJECTFILE_H
 | 
						|
 | 
						|
#include "llvm/CodeGen/TargetLoweringObjectFileImpl.h"
 | 
						|
 | 
						|
namespace llvm {
 | 
						|
class MipsTargetMachine;
 | 
						|
  class MipsTargetObjectFile : public TargetLoweringObjectFileELF {
 | 
						|
    MCSection *SmallDataSection;
 | 
						|
    MCSection *SmallBSSSection;
 | 
						|
    const MipsTargetMachine *TM;
 | 
						|
  public:
 | 
						|
 | 
						|
    void Initialize(MCContext &Ctx, const TargetMachine &TM) override;
 | 
						|
 | 
						|
    /// Return true if this global address should be placed into small data/bss
 | 
						|
    /// section.
 | 
						|
    bool IsGlobalInSmallSection(const GlobalValue *GV, const TargetMachine &TM,
 | 
						|
                                SectionKind Kind) const;
 | 
						|
    bool IsGlobalInSmallSection(const GlobalValue *GV,
 | 
						|
                                const TargetMachine &TM) const;
 | 
						|
    bool IsGlobalInSmallSectionImpl(const GlobalValue *GV,
 | 
						|
                                    const TargetMachine &TM) const;
 | 
						|
 | 
						|
    MCSection *SelectSectionForGlobal(const GlobalValue *GV, SectionKind Kind,
 | 
						|
                                      Mangler &Mang,
 | 
						|
                                      const TargetMachine &TM) const override;
 | 
						|
 | 
						|
    /// Return true if this constant should be placed into small data section.
 | 
						|
    bool IsConstantInSmallSection(const Constant *CN,
 | 
						|
                                  const TargetMachine &TM) const;
 | 
						|
 | 
						|
    MCSection *getSectionForConstant(SectionKind Kind,
 | 
						|
                                     const Constant *C) const override;
 | 
						|
 | 
						|
    unsigned SelectMipsTTypeEncoding() const override;
 | 
						|
  };
 | 
						|
} // end namespace llvm
 | 
						|
 | 
						|
#endif
 |