[PATCH] D133456: [V2] MC: make section classification a bit more thorough

Saleem Abdulrasool via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Wed Sep 7 14:52:52 PDT 2022


compnerd created this revision.
compnerd added reviewers: echristo, MatzeB, MaskRay.
compnerd added a project: LLVM.
Herald added subscribers: StephenFan, hiraditya, emaste.
Herald added a project: All.
compnerd requested review of this revision.

This does *NOT* change the emitted section flags in any way.  This only
impacts the internal classification of sections.

Extend the section classification in LLVM for ELF targets.  This has one
important change: we now classify sections as text by default rather
than readonly.  This matches the behaviour for GAS better.

Ensure that any section that has a writable attribute set is not treated
as readonly.  We also special case any section named `.debug_` which is
reserved for DWARF as metadata.  In the case none of the attributes are
set (or because no attributes were provided), consult the section name
for classification.  We match the well known names and classify the
section accordingly.  Any remaining section is now classified as text.

This change allows us to classify sections in the MC layer more
precisely which is needed for subsequent changes for handling target
specific behaviour.

Re-apply the change that was reverted with additional changes to
classify section prefixes appropriately and differentiate the TLS
sections, addressing the FIXME and post-commit review comments by
@MaskRay.


Repository:
  rG LLVM Github Monorepo

https://reviews.llvm.org/D133456

Files:
  llvm/lib/MC/MCContext.cpp
  llvm/test/MC/ELF/section-classification.ll


Index: llvm/test/MC/ELF/section-classification.ll
===================================================================
--- /dev/null
+++ llvm/test/MC/ELF/section-classification.ll
@@ -0,0 +1,15 @@
+; We run this test explicitly converting from `.ll` to `.s` to `.o` to test the
+; classification of the section and the incorrect handling for the padding flag.
+
+; RUN: llc -filetype asm -o - %s | llvm-mc -filetype obj -o /dev/null -
+; REQUIRES: asserts
+
+target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux-gnu"
+
+%struct.C = type { i32 }
+
+$_ZZ6getRefvE8instance = comdat any
+
+ at _ZZ6getRefvE8instance = linkonce_odr dso_local global %struct.C zeroinitializer, comdat, align 4
+ at llvm.compiler.used = appending global [1 x ptr] [ptr @_ZZ6getRefvE8instance], section "llvm.metadata"
Index: llvm/lib/MC/MCContext.cpp
===================================================================
--- llvm/lib/MC/MCContext.cpp
+++ llvm/lib/MC/MCContext.cpp
@@ -564,8 +564,33 @@
     Kind = SectionKind::getExecuteOnly();
   else if (Flags & ELF::SHF_EXECINSTR)
     Kind = SectionKind::getText();
-  else
+  else if (~Flags & ELF::SHF_WRITE)
     Kind = SectionKind::getReadOnly();
+  else if (Flags & ELF::SHF_TLS)
+    Kind = (Type & ELF::SHT_NOBITS) ? SectionKind::getThreadBSS()
+                                    : SectionKind::getThreadData();
+  else
+    Kind =
+        llvm::StringSwitch<SectionKind>(CachedName)
+            .Case(".bss", SectionKind::getBSS())
+            .StartsWith(".bss.", SectionKind::getBSS())
+            .StartsWith(".gnu.linkonce.b.", SectionKind::getBSS())
+            .StartsWith(".llvm.linkonce.b.", SectionKind::getBSS())
+            .Case(".data", SectionKind::getData())
+            .Case(".data1", SectionKind::getData())
+            .Case(".data.rel.ro", SectionKind::getReadOnlyWithRel())
+            .Case(".rodata", SectionKind::getReadOnly())
+            .Case(".rodata1", SectionKind::getReadOnly())
+            .Case(".tbss", SectionKind::getThreadBSS())
+            .StartsWith(".tbss.", SectionKind::getThreadData())
+            .StartsWith(".gnu.linkonce.tb.", SectionKind::getThreadData())
+            .StartsWith(".llvm.linkonce.tb.", SectionKind::getThreadData())
+            .Case(".tdata", SectionKind::getThreadData())
+            .StartsWith(".tdata.", SectionKind::getThreadData())
+            .StartsWith(".gnu.linkonce.td.", SectionKind::getThreadData())
+            .StartsWith(".llvm.linkonce.td.", SectionKind::getThreadData())
+            .StartsWith(".debug_", SectionKind::getMetadata())
+            .Default(SectionKind::getText());
 
   MCSectionELF *Result =
       createELFSectionImpl(CachedName, Type, Flags, Kind, EntrySize, GroupSym,


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D133456.458570.patch
Type: text/x-patch
Size: 2804 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20220907/760c7b26/attachment.bin>


More information about the llvm-commits mailing list