From 5bc572ad96cae09622831abf194c0f37509f6d3c Mon Sep 17 00:00:00 2001 From: Anton Korobeynikov Date: Wed, 9 Jul 2008 13:18:02 +0000 Subject: [PATCH] Add default section name resolution routine llvm-svn: 53292 --- include/llvm/Target/TargetAsmInfo.h | 4 ++++ lib/Target/TargetAsmInfo.cpp | 12 ++++++++++++ 2 files changed, 16 insertions(+) diff --git a/include/llvm/Target/TargetAsmInfo.h b/include/llvm/Target/TargetAsmInfo.h index 7af2c03aa63..3f7dbc7206d 100644 --- a/include/llvm/Target/TargetAsmInfo.h +++ b/include/llvm/Target/TargetAsmInfo.h @@ -471,6 +471,10 @@ namespace llvm { SectionFlagsForGlobal(const GlobalValue *GV = NULL, const char* name = NULL) const; + /// SectionForGlobal - This hooks returns proper section name for given + /// global with all necessary flags and marks. + const char* SectionForGlobal(const GlobalValue *GV) const; + // Accessors. // const char *getTextSection() const { diff --git a/lib/Target/TargetAsmInfo.cpp b/lib/Target/TargetAsmInfo.cpp index 404e152da7b..8e34fc30ec5 100644 --- a/lib/Target/TargetAsmInfo.cpp +++ b/lib/Target/TargetAsmInfo.cpp @@ -254,3 +254,15 @@ TargetAsmInfo::SectionFlagsForGlobal(const GlobalValue *GV, return flags; } + +const char* +TargetAsmInfo::SectionForGlobal(const GlobalValue *GV) const { + SectionKind::Kind kind = SectionKindForGlobal(GV); + + if (kind == SectionKind::Text) + return getTextSection(); + else if (kind == SectionKind::BSS && getBSSSection()) + return getBSSSection(); + + return getDataSection(); +}