[llvm] 872aadd - Revert "Modify dwarfdump verification to allow sub-category counts (#125062)"

Nico Weber via llvm-commits llvm-commits at lists.llvm.org
Mon Feb 10 12:09:04 PST 2025


Author: Nico Weber
Date: 2025-02-10T15:08:46-05:00
New Revision: 872aaddba92efe8a792673d6e0420966fe773093

URL: https://github.com/llvm/llvm-project/commit/872aaddba92efe8a792673d6e0420966fe773093
DIFF: https://github.com/llvm/llvm-project/commit/872aaddba92efe8a792673d6e0420966fe773093.diff

LOG: Revert "Modify dwarfdump verification  to allow sub-category counts (#125062)"

This reverts commit 13f63010784d8d55620fa7846ac2192f20f95113.
Breaks check-llvm.

Added: 
    

Modified: 
    llvm/include/llvm/DebugInfo/DWARF/DWARFVerifier.h
    llvm/lib/DebugInfo/DWARF/DWARFVerifier.cpp

Removed: 
    llvm/test/tools/llvm-dwarfdump/X86/debug-names-verify-completeness-json-output.s


################################################################################
diff  --git a/llvm/include/llvm/DebugInfo/DWARF/DWARFVerifier.h b/llvm/include/llvm/DebugInfo/DWARF/DWARFVerifier.h
index 6e79619e156cb62..7b51bb63cd15ba4 100644
--- a/llvm/include/llvm/DebugInfo/DWARF/DWARFVerifier.h
+++ b/llvm/include/llvm/DebugInfo/DWARF/DWARFVerifier.h
@@ -30,15 +30,9 @@ class DWARFDebugAbbrev;
 class DataExtractor;
 struct DWARFSection;
 
-struct AggregationData {
-  unsigned OverallCount;
-  std::map<std::string, unsigned> DetailedCounts;
-  AggregationData() = default;
-};
-
 class OutputCategoryAggregator {
 private:
-  std::map<std::string, AggregationData> Aggregation;
+  std::map<std::string, unsigned> Aggregation;
   bool IncludeDetail;
 
 public:
@@ -46,13 +40,8 @@ class OutputCategoryAggregator {
       : IncludeDetail(includeDetail) {}
   void ShowDetail(bool showDetail) { IncludeDetail = showDetail; }
   size_t GetNumCategories() const { return Aggregation.size(); }
-  void Report(StringRef category, std::function<void()> detailCallback);
-  void Report(StringRef category, StringRef sub_category,
-              std::function<void()> detailCallback);
+  void Report(StringRef s, std::function<void()> detailCallback);
   void EnumerateResults(std::function<void(StringRef, unsigned)> handleCounts);
-  void EnumerateDetailedResultsFor(
-      StringRef category,
-      std::function<void(StringRef, unsigned)> handleCounts);
 };
 
 /// A class that verifies DWARF debug information given a DWARF Context.

diff  --git a/llvm/lib/DebugInfo/DWARF/DWARFVerifier.cpp b/llvm/lib/DebugInfo/DWARF/DWARFVerifier.cpp
index 211d7362065633e..107e79cc5a05ae4 100644
--- a/llvm/lib/DebugInfo/DWARF/DWARFVerifier.cpp
+++ b/llvm/lib/DebugInfo/DWARF/DWARFVerifier.cpp
@@ -1941,14 +1941,12 @@ unsigned DWARFVerifier::verifyNameIndexCompleteness(
     if (none_of(NI.equal_range(Name), [&](const DWARFDebugNames::Entry &E) {
           return E.getDIEUnitOffset() == DieUnitOffset;
         })) {
-      ErrorCategory.Report(
-          "Name Index DIE entry missing name",
-          llvm::dwarf::TagString(Die.getTag()), [&]() {
-            error() << formatv(
-                "Name Index @ {0:x}: Entry for DIE @ {1:x} ({2}) with "
-                "name {3} missing.\n",
-                NI.getUnitOffset(), Die.getOffset(), Die.getTag(), Name);
-          });
+      ErrorCategory.Report("Name Index DIE entry missing name", [&]() {
+        error() << formatv(
+            "Name Index @ {0:x}: Entry for DIE @ {1:x} ({2}) with "
+            "name {3} missing.\n",
+            NI.getUnitOffset(), Die.getOffset(), Die.getTag(), Name);
+      });
       ++NumErrors;
     }
   }
@@ -2170,35 +2168,15 @@ bool DWARFVerifier::verifyDebugStrOffsets(
 
 void OutputCategoryAggregator::Report(
     StringRef s, std::function<void(void)> detailCallback) {
-  this->Report(s, "", detailCallback);
-}
-
-void OutputCategoryAggregator::Report(
-    StringRef category, StringRef sub_category,
-    std::function<void(void)> detailCallback) {
-  std::string category_str = std::string(category);
-  AggregationData *Agg = &Aggregation[category_str];
-  Agg->OverallCount++;
-  if (!sub_category.empty()) {
-    Agg->DetailedCounts[std::string(sub_category)]++;
-  }
+  Aggregation[std::string(s)]++;
   if (IncludeDetail)
     detailCallback();
 }
 
 void OutputCategoryAggregator::EnumerateResults(
     std::function<void(StringRef, unsigned)> handleCounts) {
-  for (auto &&[name, aggData] : Aggregation) {
-    handleCounts(name, aggData.OverallCount);
-  }
-}
-void OutputCategoryAggregator::EnumerateDetailedResultsFor(
-    StringRef category, std::function<void(StringRef, unsigned)> handleCounts) {
-  auto Agg = Aggregation.find(std::string(category));
-  if (Agg != Aggregation.end()) {
-    for (auto &&[name, count] : Agg->second.DetailedCounts) {
-      handleCounts(name, count);
-    }
+  for (auto &&[name, count] : Aggregation) {
+    handleCounts(name, count);
   }
 }
 
@@ -2225,12 +2203,6 @@ void DWARFVerifier::summarize() {
     ErrorCategory.EnumerateResults([&](StringRef Category, unsigned Count) {
       llvm::json::Object Val;
       Val.try_emplace("count", Count);
-      llvm::json::Object Details;
-      ErrorCategory.EnumerateDetailedResultsFor(
-          Category, [&](StringRef SubCategory, unsigned SubCount) {
-            Details.try_emplace(SubCategory, SubCount);
-          });
-      Val.try_emplace("details", std::move(Details));
       Categories.try_emplace(Category, std::move(Val));
       ErrorCount += Count;
     });

diff  --git a/llvm/test/tools/llvm-dwarfdump/X86/debug-names-verify-completeness-json-output.s b/llvm/test/tools/llvm-dwarfdump/X86/debug-names-verify-completeness-json-output.s
deleted file mode 100644
index 9c9658308c2f908..000000000000000
--- a/llvm/test/tools/llvm-dwarfdump/X86/debug-names-verify-completeness-json-output.s
+++ /dev/null
@@ -1,172 +0,0 @@
-# RUN: llvm-mc -triple x86_64-pc-linux %s -filetype=obj -o - | not llvm-dwarfdump -verify --verify-json=%t.json -
-# RUN: FileCheck %s --input-file %t.json
-
-# CHECK: {"error-categories":{"Name Index DIE entry missing name":{"count":10,"details":{"DW_TAG_inlined_subroutine":1,"DW_TAG_label":1,"DW_TAG_namespace":2,"DW_TAG_subprogram":2,"DW_TAG_variable":4}}},"error-count":10}
-# CHECK-NOT: error: Name Index @ 0x0: Entry for DIE @ {{.*}} (DW_TAG_variable) with name var_block_addr missing.
-
-        .section        .debug_loc,"", at progbits
-.Ldebug_loc0:
-        .quad   0
-        .quad   1
-        .short  .Lloc0_end-.Lloc0_start # Loc expr size
-.Lloc0_start:
-        .byte   3                       # DW_OP_addr
-        .quad 0x47
-.Lloc0_end:
-        .quad   0
-        .quad   0
-
-        .section        .debug_abbrev,"", at progbits
-        .byte   1                       # Abbreviation Code
-        .byte   17                      # DW_TAG_compile_unit
-        .byte   1                       # DW_CHILDREN_yes
-        .byte   37                      # DW_AT_producer
-        .byte   8                       # DW_FORM_string
-        .byte   17                      # DW_AT_low_pc
-        .byte   1                       # DW_FORM_addr
-        .byte   18                      # DW_AT_high_pc
-        .byte   6                       # DW_FORM_data4
-        .byte   0                       # EOM(1)
-        .byte   0                       # EOM(2)
-
-        .byte   2                       # Abbreviation Code
-        .byte   52                      # DW_TAG_variable
-        .byte   0                       # DW_CHILDREN_no
-        .byte   3                       # DW_AT_name
-        .byte   8                       # DW_FORM_string
-        .byte   2                       # DW_AT_location
-        .byte   24                      # DW_FORM_exprloc
-        .byte   0                       # EOM(1)
-        .byte   0                       # EOM(2)
-
-        .byte   3                       # Abbreviation Code
-        .byte   46                      # DW_TAG_subprogram
-        .byte   1                       # DW_CHILDREN_yes
-        .byte   3                       # DW_AT_name
-        .byte   8                       # DW_FORM_string
-        .byte   110                     # DW_AT_linkage_name
-        .byte   8                       # DW_FORM_string
-        .byte   82                      # DW_AT_entry_pc
-        .byte   1                       # DW_FORM_addr
-        .byte   0                       # EOM(1)
-        .byte   0                       # EOM(2)
-
-        .byte   4                       # Abbreviation Code
-        .byte   57                      # DW_TAG_namespace
-        .byte   1                       # DW_CHILDREN_yes
-        .byte   3                       # DW_AT_name
-        .byte   8                       # DW_FORM_string
-        .byte   0                       # EOM(1)
-        .byte   0                       # EOM(2)
-
-        .byte   5                       # Abbreviation Code
-        .byte   52                      # DW_TAG_variable
-        .byte   0                       # DW_CHILDREN_no
-        .byte   3                       # DW_AT_name
-        .byte   8                       # DW_FORM_string
-        .byte   2                       # DW_AT_location
-        .byte   23                      # DW_FORM_sec_offset
-        .byte   0                       # EOM(1)
-        .byte   0                       # EOM(2)
-
-        .byte   6                       # Abbreviation Code
-        .byte   57                      # DW_TAG_namespace
-        .byte   1                       # DW_CHILDREN_yes
-        .byte   0                       # EOM(1)
-        .byte   0                       # EOM(2)
-
-        .byte   7                       # Abbreviation Code
-        .byte   29                      # DW_TAG_inlined_subroutine
-        .byte   0                       # DW_CHILDREN_no
-        .byte   3                       # DW_AT_name
-        .byte   8                       # DW_FORM_string
-        .byte   17                      # DW_AT_low_pc
-        .byte   1                       # DW_FORM_addr
-        .byte   18                      # DW_AT_high_pc
-        .byte   1                       # DW_FORM_addr
-        .byte   0                       # EOM(1)
-        .byte   0                       # EOM(2)
-
-        .byte   8                       # Abbreviation Code
-        .byte   10                      # DW_TAG_label
-        .byte   0                       # DW_CHILDREN_no
-        .byte   3                       # DW_AT_name
-        .byte   8                       # DW_FORM_string
-        .byte   82                      # DW_AT_entry_pc
-        .byte   1                       # DW_FORM_addr
-        .byte   0                       # EOM(1)
-        .byte   0                       # EOM(2)
-
-        .byte   0                       # EOM(3)
-        .section        .debug_info,"", at progbits
-
-.Lcu_begin0:
-        .long   .Lcu_end0-.Lcu_start0   # Length of Unit
-.Lcu_start0:
-        .short  4                       # DWARF version number
-        .long   .debug_abbrev           # Offset Into Abbrev. Section
-        .byte   8                       # Address Size (in bytes)
-        .byte   1                       # Abbrev [1] DW_TAG_compile_unit
-        .asciz  "hand-written DWARF"    # DW_AT_producer
-        .quad   0x0                     # DW_AT_low_pc
-        .long   0x100                   # DW_AT_high_pc
-
-        .byte   4                       # Abbrev [4] DW_TAG_namespace
-        .asciz  "namesp"                # DW_AT_name
-        .byte   2                       # Abbrev [2] DW_TAG_variable
-        .asciz  "var_block_addr"        # DW_AT_name
-        .byte   9                       # DW_AT_location
-        .byte   3                       # DW_OP_addr
-        .quad   0x47
-        .byte   0                       # End Of Children Mark
-
-        .byte   6                       # Abbrev [6] DW_TAG_namespace
-        .byte   5                       # Abbrev [5] DW_TAG_variable
-        .asciz  "var_loc_addr"          # DW_AT_name
-        .long   .Ldebug_loc0            # DW_AT_location
-        .byte   0                       # End Of Children Mark
-
-        .byte   2                       # Abbrev [2] DW_TAG_variable
-        .asciz  "var_loc_tls"           # DW_AT_name
-        .byte   1                       # DW_AT_location
-        .byte   0x9b                    # DW_OP_form_tls_address
-
-        .byte   2                       # Abbrev [2] DW_TAG_variable
-        .asciz  "var_loc_gnu_tls"       # DW_AT_name
-        .byte   1                       # DW_AT_location
-        .byte   0xe0                    # DW_OP_GNU_push_tls_address
-
-        .byte   3                       # Abbrev [3] DW_TAG_subprogram
-        .asciz  "fun_name"              # DW_AT_name
-        .asciz  "_Z8fun_name"           # DW_AT_linkage_name
-        .quad   0x47                    # DW_AT_entry_pc
-        .byte   7                       # Abbrev [7] DW_TAG_inlined_subroutine
-        .asciz  "fun_inline"            # DW_AT_name
-        .quad   0x48                    # DW_AT_low_pc
-        .quad   0x49                    # DW_AT_high_pc
-        .byte   8                       # Abbrev [8] DW_TAG_label
-        .asciz  "label"                 # DW_AT_name
-        .quad   0x4a                    # DW_AT_entry_pc
-        .byte   0                       # End Of Children Mark
-
-        .byte   0                       # End Of Children Mark
-.Lcu_end0:
-
-        .section        .debug_names,"", at progbits
-        .long   .Lnames_end0-.Lnames_start0 # Header: contribution length
-.Lnames_start0:
-        .short  5                       # Header: version
-        .short  0                       # Header: padding
-        .long   1                       # Header: compilation unit count
-        .long   0                       # Header: local type unit count
-        .long   0                       # Header: foreign type unit count
-        .long   0                       # Header: bucket count
-        .long   0                       # Header: name count
-        .long   .Lnames_abbrev_end0-.Lnames_abbrev_start0 # Header: abbreviation table size
-        .long   0                       # Header: augmentation length
-        .long   .Lcu_begin0             # Compilation unit 0
-.Lnames_abbrev_start0:
-        .byte   0                       # End of abbrev list
-.Lnames_abbrev_end0:
-.Lnames_entries0:
-.Lnames_end0:


        


More information about the llvm-commits mailing list