From 21539c6d1ee7d2ca494bde26b9f3dccfc52d8635 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 --- llvm/include/llvm/Target/TargetAsmInfo.h | 4 ++++ llvm/lib/Target/TargetAsmInfo.cpp | 12 ++++++++++++ 2 files changed, 16 insertions(+) diff --git a/llvm/include/llvm/Target/TargetAsmInfo.h b/llvm/include/llvm/Target/TargetAsmInfo.h index 7af2c03aa630..3f7dbc7206db 100644 --- a/llvm/include/llvm/Target/TargetAsmInfo.h +++ b/llvm/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/llvm/lib/Target/TargetAsmInfo.cpp b/llvm/lib/Target/TargetAsmInfo.cpp index 404e152da7b3..8e34fc30ec58 100644 --- a/llvm/lib/Target/TargetAsmInfo.cpp +++ b/llvm/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(); +}