1444ed5c5SDimitry Andric //===-- AVRTargetObjectFile.cpp - AVR Object Files ------------------------===//
2444ed5c5SDimitry Andric //
3444ed5c5SDimitry Andric // The LLVM Compiler Infrastructure
4444ed5c5SDimitry Andric //
5444ed5c5SDimitry Andric // This file is distributed under the University of Illinois Open Source
6444ed5c5SDimitry Andric // License. See LICENSE.TXT for details.
7444ed5c5SDimitry Andric //
8444ed5c5SDimitry Andric //===----------------------------------------------------------------------===//
9444ed5c5SDimitry Andric
10444ed5c5SDimitry Andric #include "AVRTargetObjectFile.h"
11444ed5c5SDimitry Andric
12*db17bf38SDimitry Andric #include "llvm/BinaryFormat/ELF.h"
13444ed5c5SDimitry Andric #include "llvm/IR/DerivedTypes.h"
14444ed5c5SDimitry Andric #include "llvm/IR/GlobalValue.h"
15444ed5c5SDimitry Andric #include "llvm/IR/Mangler.h"
16444ed5c5SDimitry Andric #include "llvm/MC/MCContext.h"
17444ed5c5SDimitry Andric #include "llvm/MC/MCSectionELF.h"
18444ed5c5SDimitry Andric
19444ed5c5SDimitry Andric #include "AVR.h"
20444ed5c5SDimitry Andric
21444ed5c5SDimitry Andric namespace llvm {
Initialize(MCContext & Ctx,const TargetMachine & TM)22444ed5c5SDimitry Andric void AVRTargetObjectFile::Initialize(MCContext &Ctx, const TargetMachine &TM) {
23444ed5c5SDimitry Andric Base::Initialize(Ctx, TM);
24444ed5c5SDimitry Andric ProgmemDataSection =
25444ed5c5SDimitry Andric Ctx.getELFSection(".progmem.data", ELF::SHT_PROGBITS, ELF::SHF_ALLOC);
26444ed5c5SDimitry Andric }
27444ed5c5SDimitry Andric
28444ed5c5SDimitry Andric MCSection *
SelectSectionForGlobal(const GlobalObject * GO,SectionKind Kind,const TargetMachine & TM) const29d88c1a5aSDimitry Andric AVRTargetObjectFile::SelectSectionForGlobal(const GlobalObject *GO,
30d88c1a5aSDimitry Andric SectionKind Kind,
31444ed5c5SDimitry Andric const TargetMachine &TM) const {
32444ed5c5SDimitry Andric // Global values in flash memory are placed in the progmem.data section
33444ed5c5SDimitry Andric // unless they already have a user assigned section.
34d88c1a5aSDimitry Andric if (AVR::isProgramMemoryAddress(GO) && !GO->hasSection())
35444ed5c5SDimitry Andric return ProgmemDataSection;
36444ed5c5SDimitry Andric
37444ed5c5SDimitry Andric // Otherwise, we work the same way as ELF.
38d88c1a5aSDimitry Andric return Base::SelectSectionForGlobal(GO, Kind, TM);
39444ed5c5SDimitry Andric }
40444ed5c5SDimitry Andric } // end of namespace llvm
41d88c1a5aSDimitry Andric
42