371 lines
16 KiB
C++
371 lines
16 KiB
C++
//===- VecUtilsTest.cpp --------------------------------------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/Transforms/Vectorize/SandboxVectorizer/VecUtils.h"
|
|
#include "llvm/Analysis/AliasAnalysis.h"
|
|
#include "llvm/Analysis/AssumptionCache.h"
|
|
#include "llvm/Analysis/BasicAliasAnalysis.h"
|
|
#include "llvm/Analysis/LoopInfo.h"
|
|
#include "llvm/Analysis/ScalarEvolution.h"
|
|
#include "llvm/Analysis/TargetLibraryInfo.h"
|
|
#include "llvm/AsmParser/Parser.h"
|
|
#include "llvm/IR/DataLayout.h"
|
|
#include "llvm/IR/Dominators.h"
|
|
#include "llvm/SandboxIR/Context.h"
|
|
#include "llvm/SandboxIR/Function.h"
|
|
#include "llvm/SandboxIR/Type.h"
|
|
#include "llvm/Support/SourceMgr.h"
|
|
#include "gtest/gtest.h"
|
|
|
|
using namespace llvm;
|
|
|
|
struct VecUtilsTest : public testing::Test {
|
|
LLVMContext C;
|
|
std::unique_ptr<Module> M;
|
|
std::unique_ptr<AssumptionCache> AC;
|
|
std::unique_ptr<TargetLibraryInfoImpl> TLII;
|
|
std::unique_ptr<TargetLibraryInfo> TLI;
|
|
std::unique_ptr<DominatorTree> DT;
|
|
std::unique_ptr<LoopInfo> LI;
|
|
std::unique_ptr<ScalarEvolution> SE;
|
|
void parseIR(const char *IR) {
|
|
SMDiagnostic Err;
|
|
M = parseAssemblyString(IR, Err, C);
|
|
if (!M)
|
|
Err.print("VecUtilsTest", errs());
|
|
}
|
|
ScalarEvolution &getSE(llvm::Function &LLVMF) {
|
|
TLII = std::make_unique<TargetLibraryInfoImpl>();
|
|
TLI = std::make_unique<TargetLibraryInfo>(*TLII);
|
|
AC = std::make_unique<AssumptionCache>(LLVMF);
|
|
DT = std::make_unique<DominatorTree>(LLVMF);
|
|
LI = std::make_unique<LoopInfo>(*DT);
|
|
SE = std::make_unique<ScalarEvolution>(LLVMF, *TLI, *AC, *DT, *LI);
|
|
return *SE;
|
|
}
|
|
};
|
|
|
|
TEST_F(VecUtilsTest, GetNumElements) {
|
|
sandboxir::Context Ctx(C);
|
|
auto *ElemTy = sandboxir::Type::getInt32Ty(Ctx);
|
|
EXPECT_EQ(sandboxir::VecUtils::getNumElements(ElemTy), 1);
|
|
auto *VTy = sandboxir::FixedVectorType::get(ElemTy, 2);
|
|
EXPECT_EQ(sandboxir::VecUtils::getNumElements(VTy), 2);
|
|
auto *VTy1 = sandboxir::FixedVectorType::get(ElemTy, 1);
|
|
EXPECT_EQ(sandboxir::VecUtils::getNumElements(VTy1), 1);
|
|
}
|
|
|
|
TEST_F(VecUtilsTest, GetElementType) {
|
|
sandboxir::Context Ctx(C);
|
|
auto *ElemTy = sandboxir::Type::getInt32Ty(Ctx);
|
|
EXPECT_EQ(sandboxir::VecUtils::getElementType(ElemTy), ElemTy);
|
|
auto *VTy = sandboxir::FixedVectorType::get(ElemTy, 2);
|
|
EXPECT_EQ(sandboxir::VecUtils::getElementType(VTy), ElemTy);
|
|
}
|
|
|
|
TEST_F(VecUtilsTest, AreConsecutive_gep_float) {
|
|
parseIR(R"IR(
|
|
define void @foo(ptr %ptr) {
|
|
%gep0 = getelementptr inbounds float, ptr %ptr, i64 0
|
|
%gep1 = getelementptr inbounds float, ptr %ptr, i64 1
|
|
%gep2 = getelementptr inbounds float, ptr %ptr, i64 2
|
|
%gep3 = getelementptr inbounds float, ptr %ptr, i64 3
|
|
|
|
%ld0 = load float, ptr %gep0
|
|
%ld1 = load float, ptr %gep1
|
|
%ld2 = load float, ptr %gep2
|
|
%ld3 = load float, ptr %gep3
|
|
|
|
%v2ld0 = load <2 x float>, ptr %gep0
|
|
%v2ld1 = load <2 x float>, ptr %gep1
|
|
%v2ld2 = load <2 x float>, ptr %gep2
|
|
%v2ld3 = load <2 x float>, ptr %gep3
|
|
|
|
%v3ld0 = load <3 x float>, ptr %gep0
|
|
%v3ld1 = load <3 x float>, ptr %gep1
|
|
%v3ld2 = load <3 x float>, ptr %gep2
|
|
%v3ld3 = load <3 x float>, ptr %gep3
|
|
ret void
|
|
}
|
|
)IR");
|
|
Function &LLVMF = *M->getFunction("foo");
|
|
const DataLayout &DL = M->getDataLayout();
|
|
auto &SE = getSE(LLVMF);
|
|
|
|
sandboxir::Context Ctx(C);
|
|
auto &F = *Ctx.createFunction(&LLVMF);
|
|
|
|
auto &BB = *F.begin();
|
|
auto It = std::next(BB.begin(), 4);
|
|
auto *L0 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *L1 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *L2 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *L3 = cast<sandboxir::LoadInst>(&*It++);
|
|
|
|
auto *V2L0 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V2L1 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V2L2 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V2L3 = cast<sandboxir::LoadInst>(&*It++);
|
|
|
|
auto *V3L0 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V3L1 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V3L2 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V3L3 = cast<sandboxir::LoadInst>(&*It++);
|
|
|
|
// Scalar
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(L0, L1, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(L1, L2, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(L2, L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L1, L0, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L2, L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L3, L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L0, L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L0, L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L1, L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L2, L0, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L3, L1, SE, DL));
|
|
|
|
// Check 2-wide loads
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V2L0, V2L2, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V2L1, V2L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L0, V2L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L1, V2L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L2, V2L3, SE, DL));
|
|
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L3, V2L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L3, V2L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L3, V2L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L3, V2L1, SE, DL));
|
|
|
|
// Check 3-wide loads
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V3L0, V3L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L0, V3L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L1, V3L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L2, V3L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L1, V3L0, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L2, V3L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L3, V3L2, SE, DL));
|
|
|
|
// Check mixes of vectors and scalar
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(L0, V2L1, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(L1, V2L2, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V2L0, L2, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V3L0, L3, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V2L0, V3L2, SE, DL));
|
|
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L0, V2L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L0, V3L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L0, V2L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L0, V3L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L0, L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L0, L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L0, V2L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L0, V2L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L1, L0, SE, DL));
|
|
}
|
|
|
|
TEST_F(VecUtilsTest, AreConsecutive_gep_i8) {
|
|
parseIR(R"IR(
|
|
define void @foo(ptr %ptr) {
|
|
%gep0 = getelementptr inbounds i8, ptr %ptr, i64 0
|
|
%gep1 = getelementptr inbounds i8, ptr %ptr, i64 4
|
|
%gep2 = getelementptr inbounds i8, ptr %ptr, i64 8
|
|
%gep3 = getelementptr inbounds i8, ptr %ptr, i64 12
|
|
|
|
%ld0 = load float, ptr %gep0
|
|
%ld1 = load float, ptr %gep1
|
|
%ld2 = load float, ptr %gep2
|
|
%ld3 = load float, ptr %gep3
|
|
|
|
%v2ld0 = load <2 x float>, ptr %gep0
|
|
%v2ld1 = load <2 x float>, ptr %gep1
|
|
%v2ld2 = load <2 x float>, ptr %gep2
|
|
%v2ld3 = load <2 x float>, ptr %gep3
|
|
|
|
%v3ld0 = load <3 x float>, ptr %gep0
|
|
%v3ld1 = load <3 x float>, ptr %gep1
|
|
%v3ld2 = load <3 x float>, ptr %gep2
|
|
%v3ld3 = load <3 x float>, ptr %gep3
|
|
ret void
|
|
}
|
|
)IR");
|
|
Function &LLVMF = *M->getFunction("foo");
|
|
const DataLayout &DL = M->getDataLayout();
|
|
auto &SE = getSE(LLVMF);
|
|
|
|
sandboxir::Context Ctx(C);
|
|
auto &F = *Ctx.createFunction(&LLVMF);
|
|
auto &BB = *F.begin();
|
|
auto It = std::next(BB.begin(), 4);
|
|
auto *L0 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *L1 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *L2 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *L3 = cast<sandboxir::LoadInst>(&*It++);
|
|
|
|
auto *V2L0 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V2L1 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V2L2 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V2L3 = cast<sandboxir::LoadInst>(&*It++);
|
|
|
|
auto *V3L0 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V3L1 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V3L2 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V3L3 = cast<sandboxir::LoadInst>(&*It++);
|
|
|
|
// Scalar
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(L0, L1, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(L1, L2, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(L2, L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L1, L0, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L2, L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L3, L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L0, L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L0, L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L1, L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L2, L0, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L3, L1, SE, DL));
|
|
|
|
// Check 2-wide loads
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V2L0, V2L2, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V2L1, V2L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L0, V2L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L1, V2L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L2, V2L3, SE, DL));
|
|
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L3, V2L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L3, V2L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L3, V2L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L3, V2L1, SE, DL));
|
|
|
|
// Check 3-wide loads
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V3L0, V3L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L0, V3L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L1, V3L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L2, V3L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L1, V3L0, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L2, V3L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L3, V3L2, SE, DL));
|
|
|
|
// Check mixes of vectors and scalar
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(L0, V2L1, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(L1, V2L2, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V2L0, L2, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V3L0, L3, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V2L0, V3L2, SE, DL));
|
|
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L0, V2L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L0, V3L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L0, V2L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L0, V3L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L0, L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L0, L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L0, V2L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L0, V2L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L1, L0, SE, DL));
|
|
}
|
|
|
|
TEST_F(VecUtilsTest, AreConsecutive_gep_i1) {
|
|
parseIR(R"IR(
|
|
define void @foo(ptr %ptr) {
|
|
%gep0 = getelementptr inbounds i1, ptr %ptr, i64 0
|
|
%gep1 = getelementptr inbounds i2, ptr %ptr, i64 4
|
|
%gep2 = getelementptr inbounds i3, ptr %ptr, i64 8
|
|
%gep3 = getelementptr inbounds i7, ptr %ptr, i64 12
|
|
|
|
%ld0 = load float, ptr %gep0
|
|
%ld1 = load float, ptr %gep1
|
|
%ld2 = load float, ptr %gep2
|
|
%ld3 = load float, ptr %gep3
|
|
|
|
%v2ld0 = load <2 x float>, ptr %gep0
|
|
%v2ld1 = load <2 x float>, ptr %gep1
|
|
%v2ld2 = load <2 x float>, ptr %gep2
|
|
%v2ld3 = load <2 x float>, ptr %gep3
|
|
|
|
%v3ld0 = load <3 x float>, ptr %gep0
|
|
%v3ld1 = load <3 x float>, ptr %gep1
|
|
%v3ld2 = load <3 x float>, ptr %gep2
|
|
%v3ld3 = load <3 x float>, ptr %gep3
|
|
ret void
|
|
}
|
|
)IR");
|
|
Function &LLVMF = *M->getFunction("foo");
|
|
const DataLayout &DL = M->getDataLayout();
|
|
auto &SE = getSE(LLVMF);
|
|
|
|
sandboxir::Context Ctx(C);
|
|
auto &F = *Ctx.createFunction(&LLVMF);
|
|
auto &BB = *F.begin();
|
|
auto It = std::next(BB.begin(), 4);
|
|
auto *L0 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *L1 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *L2 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *L3 = cast<sandboxir::LoadInst>(&*It++);
|
|
|
|
auto *V2L0 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V2L1 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V2L2 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V2L3 = cast<sandboxir::LoadInst>(&*It++);
|
|
|
|
auto *V3L0 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V3L1 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V3L2 = cast<sandboxir::LoadInst>(&*It++);
|
|
auto *V3L3 = cast<sandboxir::LoadInst>(&*It++);
|
|
|
|
// Scalar
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(L0, L1, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(L1, L2, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(L2, L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L1, L0, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L2, L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L3, L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L0, L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L0, L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L1, L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L2, L0, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L3, L1, SE, DL));
|
|
|
|
// Check 2-wide loads
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V2L0, V2L2, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V2L1, V2L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L0, V2L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L1, V2L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L2, V2L3, SE, DL));
|
|
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L3, V2L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L3, V2L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L3, V2L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L3, V2L1, SE, DL));
|
|
|
|
// Check 3-wide loads
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V3L0, V3L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L0, V3L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L1, V3L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L2, V3L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L1, V3L0, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L2, V3L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L3, V3L2, SE, DL));
|
|
|
|
// Check mixes of vectors and scalar
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(L0, V2L1, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(L1, V2L2, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V2L0, L2, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V3L0, L3, SE, DL));
|
|
EXPECT_TRUE(sandboxir::VecUtils::areConsecutive(V2L0, V3L2, SE, DL));
|
|
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L0, V2L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L0, V3L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(L0, V2L3, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L0, V3L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L0, L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L0, L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L0, V2L1, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V3L0, V2L2, SE, DL));
|
|
EXPECT_FALSE(sandboxir::VecUtils::areConsecutive(V2L1, L0, SE, DL));
|
|
}
|