mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-12 15:05:06 +00:00
d6b43a317e
TargetLoweringObjectFileELF. Use this to support it on X86. Unlike ARM, on X86 it is not easy to find out if .init_array should be used or not, so the decision is made via TargetOptions and defaults to off. Add a command line option to llc that enables it. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@158692 91177308-0d34-0410-b5e6-96231b3b80d8
39 lines
962 B
C++
39 lines
962 B
C++
//===-- llvm/Target/ARMTargetObjectFile.h - ARM 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_ARM_TARGETOBJECTFILE_H
|
|
#define LLVM_TARGET_ARM_TARGETOBJECTFILE_H
|
|
|
|
#include "llvm/CodeGen/TargetLoweringObjectFileImpl.h"
|
|
|
|
namespace llvm {
|
|
|
|
class MCContext;
|
|
class TargetMachine;
|
|
|
|
class ARMElfTargetObjectFile : public TargetLoweringObjectFileELF {
|
|
protected:
|
|
const MCSection *AttributesSection;
|
|
public:
|
|
ARMElfTargetObjectFile() :
|
|
TargetLoweringObjectFileELF(),
|
|
AttributesSection(NULL)
|
|
{}
|
|
|
|
virtual void Initialize(MCContext &Ctx, const TargetMachine &TM);
|
|
|
|
virtual const MCSection *getAttributesSection() const {
|
|
return AttributesSection;
|
|
}
|
|
};
|
|
|
|
} // end namespace llvm
|
|
|
|
#endif
|