|
12 | 12 | #include "llvm/SandboxIR/Function.h"
|
13 | 13 | #include "llvm/SandboxIR/Instruction.h"
|
14 | 14 | #include "llvm/Support/SourceMgr.h"
|
| 15 | +#include "gmock/gmock-matchers.h" |
15 | 16 | #include "gtest/gtest.h"
|
16 | 17 |
|
17 | 18 | using namespace llvm;
|
@@ -90,4 +91,161 @@ define void @foo(i8 %v0) {
|
90 | 91 | auto BBIt = BB->begin();
|
91 | 92 | for (auto &I : Intvl)
|
92 | 93 | EXPECT_EQ(&I, &*BBIt++);
|
| 94 | + { |
| 95 | + // Check equality. |
| 96 | + EXPECT_TRUE(Empty == Empty); |
| 97 | + EXPECT_FALSE(Empty == One); |
| 98 | + EXPECT_TRUE(One == One); |
| 99 | + sandboxir::Interval<sandboxir::Instruction> Intvl1(I0, I2); |
| 100 | + sandboxir::Interval<sandboxir::Instruction> Intvl2(I0, I2); |
| 101 | + EXPECT_TRUE(Intvl1 == Intvl1); |
| 102 | + EXPECT_TRUE(Intvl1 == Intvl2); |
| 103 | + } |
| 104 | + { |
| 105 | + // Check inequality. |
| 106 | + EXPECT_FALSE(Empty != Empty); |
| 107 | + EXPECT_TRUE(Empty != One); |
| 108 | + EXPECT_FALSE(One != One); |
| 109 | + sandboxir::Interval<sandboxir::Instruction> Intvl1(I0, I2); |
| 110 | + sandboxir::Interval<sandboxir::Instruction> Intvl2(I0, I2); |
| 111 | + EXPECT_FALSE(Intvl1 != Intvl1); |
| 112 | + EXPECT_FALSE(Intvl1 != Intvl2); |
| 113 | + } |
| 114 | + { |
| 115 | + // Check disjoint(). |
| 116 | + EXPECT_TRUE(Empty.disjoint(Empty)); |
| 117 | + EXPECT_TRUE(One.disjoint(Empty)); |
| 118 | + EXPECT_TRUE(Empty.disjoint(One)); |
| 119 | + sandboxir::Interval<sandboxir::Instruction> Intvl1(I0, I2); |
| 120 | + sandboxir::Interval<sandboxir::Instruction> Intvl2(I1, Ret); |
| 121 | + EXPECT_FALSE(Intvl1.disjoint(Intvl2)); |
| 122 | + sandboxir::Interval<sandboxir::Instruction> Intvl3(I2, I2); |
| 123 | + EXPECT_FALSE(Intvl1.disjoint(Intvl3)); |
| 124 | + EXPECT_TRUE(Intvl1.disjoint(Empty)); |
| 125 | + } |
| 126 | +} |
| 127 | + |
| 128 | +// Helper function for returning a vector of instruction pointers from a range |
| 129 | +// of references. |
| 130 | +template <typename RangeT> |
| 131 | +static SmallVector<sandboxir::Instruction *> getPtrVec(RangeT Range) { |
| 132 | + SmallVector<sandboxir::Instruction *> PtrVec; |
| 133 | + for (sandboxir::Instruction &I : Range) |
| 134 | + PtrVec.push_back(&I); |
| 135 | + return PtrVec; |
| 136 | +} |
| 137 | + |
| 138 | +TEST_F(IntervalTest, Difference) { |
| 139 | + parseIR(C, R"IR( |
| 140 | +define void @foo(i8 %v0) { |
| 141 | + %I0 = add i8 %v0, %v0 |
| 142 | + %I1 = add i8 %v0, %v0 |
| 143 | + %I2 = add i8 %v0, %v0 |
| 144 | + ret void |
| 145 | +} |
| 146 | +)IR"); |
| 147 | + Function &LLVMF = *M->getFunction("foo"); |
| 148 | + sandboxir::Context Ctx(C); |
| 149 | + auto &F = *Ctx.createFunction(&LLVMF); |
| 150 | + auto *BB = &*F.begin(); |
| 151 | + auto It = BB->begin(); |
| 152 | + auto *I0 = &*It++; |
| 153 | + auto *I1 = &*It++; |
| 154 | + auto *I2 = &*It++; |
| 155 | + auto *Ret = &*It++; |
| 156 | + |
| 157 | + { |
| 158 | + // Check [I0,Ret] - [] |
| 159 | + sandboxir::Interval<sandboxir::Instruction> I0Ret(I0, Ret); |
| 160 | + sandboxir::Interval<sandboxir::Instruction> Empty; |
| 161 | + auto Diffs = I0Ret - Empty; |
| 162 | + EXPECT_EQ(Diffs.size(), 1u); |
| 163 | + const sandboxir::Interval<sandboxir::Instruction> &Diff = Diffs[0]; |
| 164 | + EXPECT_THAT(getPtrVec(Diff), testing::ElementsAre(I0, I1, I2, Ret)); |
| 165 | + } |
| 166 | + { |
| 167 | + // Check [] - [I0,Ret] |
| 168 | + sandboxir::Interval<sandboxir::Instruction> Empty; |
| 169 | + sandboxir::Interval<sandboxir::Instruction> I0Ret(I0, Ret); |
| 170 | + auto Diffs = Empty - I0Ret; |
| 171 | + EXPECT_EQ(Diffs.size(), 1u); |
| 172 | + const sandboxir::Interval<sandboxir::Instruction> &Diff = Diffs[0]; |
| 173 | + EXPECT_TRUE(Diff.empty()); |
| 174 | + } |
| 175 | + { |
| 176 | + // Check [I0,Ret] - [I0]. |
| 177 | + sandboxir::Interval<sandboxir::Instruction> I0Ret(I0, Ret); |
| 178 | + sandboxir::Interval<sandboxir::Instruction> I0I0(I0, I0); |
| 179 | + auto Diffs = I0Ret - I0I0; |
| 180 | + EXPECT_EQ(Diffs.size(), 1u); |
| 181 | + const sandboxir::Interval<sandboxir::Instruction> &Diff = Diffs[0]; |
| 182 | + EXPECT_THAT(getPtrVec(Diff), testing::ElementsAre(I1, I2, Ret)); |
| 183 | + } |
| 184 | + { |
| 185 | + // Check [I0,Ret] - [I1]. |
| 186 | + sandboxir::Interval<sandboxir::Instruction> I0Ret(I0, Ret); |
| 187 | + sandboxir::Interval<sandboxir::Instruction> I1I1(I1, I1); |
| 188 | + auto Diffs = I0Ret - I1I1; |
| 189 | + EXPECT_EQ(Diffs.size(), 2u); |
| 190 | + const sandboxir::Interval<sandboxir::Instruction> &Diff0 = Diffs[0]; |
| 191 | + EXPECT_THAT(getPtrVec(Diff0), testing::ElementsAre(I0)); |
| 192 | + const sandboxir::Interval<sandboxir::Instruction> &Diff1 = Diffs[1]; |
| 193 | + EXPECT_THAT(getPtrVec(Diff1), testing::ElementsAre(I2, Ret)); |
| 194 | + } |
| 195 | +} |
| 196 | + |
| 197 | +TEST_F(IntervalTest, Intersection) { |
| 198 | + parseIR(C, R"IR( |
| 199 | +define void @foo(i8 %v0) { |
| 200 | + %I0 = add i8 %v0, %v0 |
| 201 | + %I1 = add i8 %v0, %v0 |
| 202 | + %I2 = add i8 %v0, %v0 |
| 203 | + ret void |
| 204 | +} |
| 205 | +)IR"); |
| 206 | + Function &LLVMF = *M->getFunction("foo"); |
| 207 | + sandboxir::Context Ctx(C); |
| 208 | + auto &F = *Ctx.createFunction(&LLVMF); |
| 209 | + auto *BB = &*F.begin(); |
| 210 | + auto It = BB->begin(); |
| 211 | + auto *I0 = &*It++; |
| 212 | + auto *I1 = &*It++; |
| 213 | + [[maybe_unused]] auto *I2 = &*It++; |
| 214 | + auto *Ret = &*It++; |
| 215 | + |
| 216 | + { |
| 217 | + // Check [I0,Ret] ^ [] |
| 218 | + sandboxir::Interval<sandboxir::Instruction> I0Ret(I0, Ret); |
| 219 | + sandboxir::Interval<sandboxir::Instruction> Empty; |
| 220 | + auto Intersection = I0Ret.intersection(Empty); |
| 221 | + EXPECT_TRUE(Intersection.empty()); |
| 222 | + } |
| 223 | + { |
| 224 | + // Check [] ^ [I0,Ret] |
| 225 | + sandboxir::Interval<sandboxir::Instruction> Empty; |
| 226 | + sandboxir::Interval<sandboxir::Instruction> I0Ret(I0, Ret); |
| 227 | + auto Intersection = Empty.intersection(I0Ret); |
| 228 | + EXPECT_TRUE(Intersection.empty()); |
| 229 | + } |
| 230 | + { |
| 231 | + // Check [I0,Ret] ^ [I0] |
| 232 | + sandboxir::Interval<sandboxir::Instruction> I0Ret(I0, Ret); |
| 233 | + sandboxir::Interval<sandboxir::Instruction> I0I0(I0, I0); |
| 234 | + auto Intersection = I0Ret.intersection(I0I0); |
| 235 | + EXPECT_THAT(getPtrVec(Intersection), testing::ElementsAre(I0)); |
| 236 | + } |
| 237 | + { |
| 238 | + // Check [I0] ^ [I0,Ret] |
| 239 | + sandboxir::Interval<sandboxir::Instruction> I0I0(I0, I0); |
| 240 | + sandboxir::Interval<sandboxir::Instruction> I0Ret(I0, Ret); |
| 241 | + auto Intersection = I0I0.intersection(I0Ret); |
| 242 | + EXPECT_THAT(getPtrVec(Intersection), testing::ElementsAre(I0)); |
| 243 | + } |
| 244 | + { |
| 245 | + // Check [I0,Ret] ^ [I1]. |
| 246 | + sandboxir::Interval<sandboxir::Instruction> I0Ret(I0, Ret); |
| 247 | + sandboxir::Interval<sandboxir::Instruction> I1I1(I1, I1); |
| 248 | + auto Intersection = I0Ret.intersection(I1I1); |
| 249 | + EXPECT_THAT(getPtrVec(Intersection), testing::ElementsAre(I1)); |
| 250 | + } |
93 | 251 | }
|
0 commit comments