summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/AVR/AVRTargetObjectFile.cpp
diff options
context:
space:
mode:
authorDylan McKay <dylanmckay34@gmail.com>2016-01-07 10:53:15 +0000
committerDylan McKay <dylanmckay34@gmail.com>2016-01-07 10:53:15 +0000
commit5c96de3ad73c3b3755449312efdfad8e94362031 (patch)
treec570749b5976989e664ab48643171ba54aeb2187 /llvm/lib/Target/AVR/AVRTargetObjectFile.cpp
parent904d5fe4968d9a6c79a31627c70633fe625a7fc3 (diff)
downloadbcm5719-llvm-5c96de3ad73c3b3755449312efdfad8e94362031.tar.gz
bcm5719-llvm-5c96de3ad73c3b3755449312efdfad8e94362031.zip
Added AVRTargetObjectFile class and AVR.h
llvm-svn: 257049
Diffstat (limited to 'llvm/lib/Target/AVR/AVRTargetObjectFile.cpp')
-rw-r--r--llvm/lib/Target/AVR/AVRTargetObjectFile.cpp40
1 files changed, 40 insertions, 0 deletions
diff --git a/llvm/lib/Target/AVR/AVRTargetObjectFile.cpp b/llvm/lib/Target/AVR/AVRTargetObjectFile.cpp
new file mode 100644
index 00000000000..85f03e818e8
--- /dev/null
+++ b/llvm/lib/Target/AVR/AVRTargetObjectFile.cpp
@@ -0,0 +1,40 @@
+//===-- AVRTargetObjectFile.cpp - AVR Object Files ------------------------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#include "AVRTargetObjectFile.h"
+
+#include "llvm/IR/DerivedTypes.h"
+#include "llvm/IR/GlobalValue.h"
+#include "llvm/IR/Mangler.h"
+#include "llvm/MC/MCContext.h"
+#include "llvm/MC/MCSectionELF.h"
+#include "llvm/Support/ELF.h"
+
+#include "AVR.h"
+
+namespace llvm {
+void AVRTargetObjectFile::Initialize(MCContext &Ctx, const TargetMachine &TM) {
+ Base::Initialize(Ctx, TM);
+ ProgmemDataSection =
+ Ctx.getELFSection(".progmem.data", ELF::SHT_PROGBITS, ELF::SHF_ALLOC);
+}
+
+MCSection *
+AVRTargetObjectFile::SelectSectionForGlobal(const GlobalValue *GV,
+ SectionKind Kind, Mangler &Mang,
+ const TargetMachine &TM) const {
+ // Global values in flash memory are placed in the progmem.data section
+ // unless they already have a user assigned section.
+ if (AVR::isProgramMemoryAddress(GV) && !GV->hasSection())
+ return ProgmemDataSection;
+
+ // Otherwise, we work the same way as ELF.
+ return Base::SelectSectionForGlobal(GV, Kind, Mang, TM);
+}
+} // end of namespace llvm
OpenPOWER on IntegriCloud