[llvm] d2cbd5f - [SandboxIR][Region][NFC] Change visibility of Region::add()/remove() (#129277)

via llvm-commits llvm-commits at lists.llvm.org
Fri Feb 28 14:03:27 PST 2025


Author: vporpo
Date: 2025-02-28T14:03:23-08:00
New Revision: d2cbd5fe6b6e280b71994c30da878751bc2a435a

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

LOG: [SandboxIR][Region][NFC] Change visibility of Region::add()/remove() (#129277)

The vectorizer's passes should not be allowed to manually add/remove
elements. This should only be done automatically by the callbacks.

Added: 
    

Modified: 
    llvm/include/llvm/SandboxIR/Region.h
    llvm/unittests/SandboxIR/RegionTest.cpp

Removed: 
    


################################################################################
diff  --git a/llvm/include/llvm/SandboxIR/Region.h b/llvm/include/llvm/SandboxIR/Region.h
index ecc6c2049ef8d..1a051941e5598 100644
--- a/llvm/include/llvm/SandboxIR/Region.h
+++ b/llvm/include/llvm/SandboxIR/Region.h
@@ -114,8 +114,12 @@ class Region {
   /// ID (for later deregistration) of the "erase instruction" callback.
   Context::CallbackID EraseInstCB;
 
-  // TODO: Add cost modeling.
-  // TODO: Add a way to encode/decode region info to/from metadata.
+  /// Adds I to the set.
+  void add(Instruction *I);
+  /// Removes I from the set.
+  void remove(Instruction *I);
+  friend class Context; // The callbacks need to call add() and remove().
+  friend class RegionInternalsAttorney; // For unit tests.
 
   /// Set \p I as the \p Idx'th element in the auxiliary vector.
   /// NOTE: This is for internal use, it does not set the metadata.
@@ -130,11 +134,6 @@ class Region {
   ~Region();
 
   Context &getContext() const { return Ctx; }
-
-  /// Adds I to the set.
-  void add(Instruction *I);
-  /// Removes I from the set.
-  void remove(Instruction *I);
   /// Returns true if I is in the Region.
   bool contains(Instruction *I) const { return Insts.contains(I); }
   /// Returns true if the Region has no instructions.
@@ -170,6 +169,13 @@ class Region {
 #endif
 };
 
+/// A helper client-attorney class for unit tests.
+class RegionInternalsAttorney {
+public:
+  static void add(Region &Rgn, Instruction *I) { Rgn.add(I); }
+  static void remove(Region &Rgn, Instruction *I) { Rgn.remove(I); }
+};
+
 } // namespace llvm::sandboxir
 
 #endif // LLVM_SANDBOXIR_REGION_H

diff  --git a/llvm/unittests/SandboxIR/RegionTest.cpp b/llvm/unittests/SandboxIR/RegionTest.cpp
index 992c3f2cbd2ea..c3390dfcdbc8e 100644
--- a/llvm/unittests/SandboxIR/RegionTest.cpp
+++ b/llvm/unittests/SandboxIR/RegionTest.cpp
@@ -55,31 +55,31 @@ define i8 @foo(i8 %v0, i8 %v1) {
 
   // Check add / remove / empty.
   EXPECT_TRUE(Rgn.empty());
-  Rgn.add(T0);
+  sandboxir::RegionInternalsAttorney::add(Rgn, T0);
   EXPECT_FALSE(Rgn.empty());
-  Rgn.remove(T0);
+  sandboxir::RegionInternalsAttorney::remove(Rgn, T0);
   EXPECT_TRUE(Rgn.empty());
 
   // Check iteration.
-  Rgn.add(T0);
-  Rgn.add(T1);
-  Rgn.add(Ret);
+  sandboxir::RegionInternalsAttorney::add(Rgn, T0);
+  sandboxir::RegionInternalsAttorney::add(Rgn, T1);
+  sandboxir::RegionInternalsAttorney::add(Rgn, Ret);
   // Use an ordered matcher because we're supposed to preserve the insertion
   // order for determinism.
   EXPECT_THAT(Rgn.insts(), testing::ElementsAre(T0, T1, Ret));
 
   // Check contains
   EXPECT_TRUE(Rgn.contains(T0));
-  Rgn.remove(T0);
+  sandboxir::RegionInternalsAttorney::remove(Rgn, T0);
   EXPECT_FALSE(Rgn.contains(T0));
 
 #ifndef NDEBUG
   // Check equality comparison. Insert in reverse order into `Other` to check
   // that comparison is order-independent.
   sandboxir::Region Other(Ctx, *TTI);
-  Other.add(Ret);
+  sandboxir::RegionInternalsAttorney::add(Other, Ret);
   EXPECT_NE(Rgn, Other);
-  Other.add(T1);
+  sandboxir::RegionInternalsAttorney::add(Other, T1);
   EXPECT_EQ(Rgn, Other);
 #endif
 }
@@ -102,8 +102,8 @@ define i8 @foo(i8 %v0, i8 %v1, ptr %ptr) {
   auto *T1 = cast<sandboxir::Instruction>(&*It++);
   auto *Ret = cast<sandboxir::Instruction>(&*It++);
   sandboxir::Region Rgn(Ctx, *TTI);
-  Rgn.add(T0);
-  Rgn.add(T1);
+  sandboxir::RegionInternalsAttorney::add(Rgn, T0);
+  sandboxir::RegionInternalsAttorney::add(Rgn, T1);
 
   // Test creation.
   auto *NewI = sandboxir::StoreInst::create(T0, Ptr, /*Align=*/std::nullopt,
@@ -186,9 +186,9 @@ define i8 @foo(i8 %v0, i8 %v1) {
   auto *T2 = cast<sandboxir::Instruction>(&*It++);
   [[maybe_unused]] auto *Ret = cast<sandboxir::Instruction>(&*It++);
   sandboxir::Region Rgn(Ctx, *TTI);
-  Rgn.add(T0);
+  sandboxir::RegionInternalsAttorney::add(Rgn, T0);
   sandboxir::Region Rgn2(Ctx, *TTI);
-  Rgn2.add(T2);
+  sandboxir::RegionInternalsAttorney::add(Rgn2, T2);
 
   std::string output;
   llvm::raw_string_ostream RSO(output);
@@ -230,8 +230,8 @@ define i8 @foo(i8 %v0, i8 %v1) {
   auto *T1 = cast<sandboxir::Instruction>(&*It++);
 
   sandboxir::Region Rgn(Ctx, *TTI);
-  Rgn.add(T0);
-  Rgn.add(T1);
+  sandboxir::RegionInternalsAttorney::add(Rgn, T0);
+  sandboxir::RegionInternalsAttorney::add(Rgn, T1);
 
   SmallVector<std::unique_ptr<sandboxir::Region>> Regions =
       sandboxir::Region::createRegionsFromMD(*F, *TTI);
@@ -276,19 +276,19 @@ define void @foo(i8 %v0, i8 %v1, i8 %v2) {
     return TTI->getInstructionCost(LLVMI, Operands, CostKind);
   };
   // Add `Add0` to the region, should be counted in "After".
-  Rgn.add(Add0);
+  sandboxir::RegionInternalsAttorney::add(Rgn, Add0);
   EXPECT_EQ(SB.getBeforeCost(), 0);
   EXPECT_EQ(SB.getAfterCost(), GetCost(LLVMAdd0));
   // Same for `Add1`.
-  Rgn.add(Add1);
+  sandboxir::RegionInternalsAttorney::add(Rgn, Add1);
   EXPECT_EQ(SB.getBeforeCost(), 0);
   EXPECT_EQ(SB.getAfterCost(), GetCost(LLVMAdd0) + GetCost(LLVMAdd1));
   // Remove `Add0`, should be subtracted from "After".
-  Rgn.remove(Add0);
+  sandboxir::RegionInternalsAttorney::remove(Rgn, Add0);
   EXPECT_EQ(SB.getBeforeCost(), 0);
   EXPECT_EQ(SB.getAfterCost(), GetCost(LLVMAdd1));
   // Remove `Add2` which was never in the region, should counted in "Before".
-  Rgn.remove(Add2);
+  sandboxir::RegionInternalsAttorney::remove(Rgn, Add2);
   EXPECT_EQ(SB.getBeforeCost(), GetCost(LLVMAdd2));
   EXPECT_EQ(SB.getAfterCost(), GetCost(LLVMAdd1));
 }
@@ -446,11 +446,11 @@ define i8 @foo(i8 %v0, i8 %v1) {
   auto *T1 = cast<sandboxir::Instruction>(&*It++);
 
   sandboxir::Region Rgn(Ctx, *TTI);
-  Rgn.add(T0);
-  Rgn.add(T1);
 #ifndef NDEBUG
   EXPECT_DEATH(Rgn.setAux({T0, T0}), ".*already.*");
 #endif
+  sandboxir::RegionInternalsAttorney::add(Rgn, T0);
+  sandboxir::RegionInternalsAttorney::add(Rgn, T1);
   Rgn.setAux({T1, T0});
 
   SmallVector<std::unique_ptr<sandboxir::Region>> Regions =


        


More information about the llvm-commits mailing list