1
0
mirror of https://github.com/exaloop/codon.git synced 2025-06-03 15:03:52 +08:00

245 lines
8.5 KiB
C++
Raw Normal View History

2021-09-27 14:02:44 -04:00
#include "test.h"
2021-10-10 19:41:52 -04:00
#include "codon/sir/util/matching.h"
2021-09-27 14:02:44 -04:00
using namespace codon::ir;
2021-09-27 14:02:44 -04:00
TEST_F(SIRCoreTest, MatchingEquivalentVar) {
auto *first = module->Nr<Var>(module->getIntType());
auto *second = module->Nr<Var>(module->getIntType());
ASSERT_TRUE(util::match(first, second));
ASSERT_TRUE(
util::match(first, module->Nr<util::AnyVar>(module->Nr<util::AnyType>("baz"))));
}
TEST_F(SIRCoreTest, MatchingNonEquivalentVar) {
auto *first = module->Nr<Var>(module->getIntType());
auto *second = module->Nr<Var>(module->getFloatType());
ASSERT_FALSE(util::match(first, second));
}
TEST_F(SIRCoreTest, MatchingEquivalentFunc) {
{
auto *first = module->Nr<BodiedFunc>();
first->realize(module->unsafeGetDummyFuncType(), {});
auto *second = module->Nr<BodiedFunc>();
second->realize(module->unsafeGetDummyFuncType(), {});
JIT (#6) * Add JIT engine * More engine updates * Fix takeModule() * Parser JIT support [wip] * Fix class definition * Parser JIT support [wip] * Parser JIT support [wip] * Fix LLVM context conflict * Parser JIT support [wip] * Fix JIT engine * Parser JIT support [wip] * Doc fix * JIT fix * Fix JIT exceptions * Refactor * Add JIT status codes * Add compiler class * Better logging * Better logging * Update .gitignore * Add Jupyter Xeus support * Update JIT * Remove print * Update errors * Fix assert * Fix asserts * Update docgen signature * Update file system interface * Update plugin errors * Use numeric_limits * JIT refactor [wip] * Set JIT flag on LLVMVisitor * Update module opt * JIT imports * First Jupyter integration * Update JIT API to return outputs as string * Capture runtime exception output * Fix libbacktrace build * Initial Jupyter support * Format * Fix print * Support run-mode backtraces * Fix multithreaded backtrace * Update backtraces * Upgrade OpenMP * Add libunwind * Fix build * Fix build * Fix build * Fix build * Fix OpenMP & tests * Use libbacktrace instead of libunwind * Add debug listener * Remove unused include * Remove unused class * Fix backtraces * Update backtrace config * Fix debug info generation * Refactor backtraces * Fix ASAN flag * Fix JIT * Fix JIT backtraces * Fix JIT backtrace * Fix Jupyter, fix xeus build flags * Fix JIT output capture * Fix Jupyter * Fix Jupyter Python support * Add __repr_pretty__ support * Update JIT output capturing * Better backtrace method names * Support plugins in JIT mode Co-authored-by: Ibrahim Numanagić <ibrahimpasa@gmail.com>
2021-11-30 11:50:28 -05:00
first->setJIT();
second->setJIT();
2021-09-27 14:02:44 -04:00
ASSERT_TRUE(util::match(first, second));
}
{
auto *first = module->Nr<ExternalFunc>();
first->realize(module->unsafeGetDummyFuncType(), {});
auto *second = module->Nr<ExternalFunc>();
second->realize(module->unsafeGetDummyFuncType(), {});
first->setUnmangledName("baz");
second->setUnmangledName("baz");
ASSERT_TRUE(util::match(first, second));
}
{
auto *first = module->Nr<LLVMFunc>();
first->realize(module->unsafeGetDummyFuncType(), {});
auto *second = module->Nr<LLVMFunc>();
second->realize(module->unsafeGetDummyFuncType(), {});
ASSERT_TRUE(util::match(first, second));
}
}
TEST_F(SIRCoreTest, MatchingNonEquivalentFunc) {
{
auto *first = module->Nr<BodiedFunc>();
first->realize(module->unsafeGetDummyFuncType(), {});
auto *second = module->Nr<BodiedFunc>();
second->realize(module->unsafeGetDummyFuncType(), {});
JIT (#6) * Add JIT engine * More engine updates * Fix takeModule() * Parser JIT support [wip] * Fix class definition * Parser JIT support [wip] * Parser JIT support [wip] * Fix LLVM context conflict * Parser JIT support [wip] * Fix JIT engine * Parser JIT support [wip] * Doc fix * JIT fix * Fix JIT exceptions * Refactor * Add JIT status codes * Add compiler class * Better logging * Better logging * Update .gitignore * Add Jupyter Xeus support * Update JIT * Remove print * Update errors * Fix assert * Fix asserts * Update docgen signature * Update file system interface * Update plugin errors * Use numeric_limits * JIT refactor [wip] * Set JIT flag on LLVMVisitor * Update module opt * JIT imports * First Jupyter integration * Update JIT API to return outputs as string * Capture runtime exception output * Fix libbacktrace build * Initial Jupyter support * Format * Fix print * Support run-mode backtraces * Fix multithreaded backtrace * Update backtraces * Upgrade OpenMP * Add libunwind * Fix build * Fix build * Fix build * Fix build * Fix OpenMP & tests * Use libbacktrace instead of libunwind * Add debug listener * Remove unused include * Remove unused class * Fix backtraces * Update backtrace config * Fix debug info generation * Refactor backtraces * Fix ASAN flag * Fix JIT * Fix JIT backtraces * Fix JIT backtrace * Fix Jupyter, fix xeus build flags * Fix JIT output capture * Fix Jupyter * Fix Jupyter Python support * Add __repr_pretty__ support * Update JIT output capturing * Better backtrace method names * Support plugins in JIT mode Co-authored-by: Ibrahim Numanagić <ibrahimpasa@gmail.com>
2021-11-30 11:50:28 -05:00
first->setJIT();
2021-09-27 14:02:44 -04:00
ASSERT_FALSE(util::match(first, second));
}
{
auto *first = module->Nr<ExternalFunc>();
first->realize(module->unsafeGetDummyFuncType(), {});
auto *second = module->Nr<ExternalFunc>();
second->realize(module->unsafeGetDummyFuncType(), {});
first->setUnmangledName("baz");
second->setUnmangledName("bar");
ASSERT_FALSE(util::match(first, second));
}
{
auto *first = module->Nr<LLVMFunc>();
first->realize(module->unsafeGetDummyFuncType(), {});
auto *second = module->Nr<LLVMFunc>();
second->realize(module->unsafeGetDummyFuncType(), {});
first->setLLVMLiterals({types::Generic(1)});
ASSERT_FALSE(util::match(first, second));
}
}
TEST_F(SIRCoreTest, MatchingAnyValue) {
auto *first = module->Nr<VarValue>(module->Nr<Var>(module->getIntType()));
ASSERT_TRUE(util::match(first, module->Nr<util::AnyValue>()));
}
TEST_F(SIRCoreTest, MatchingVarValue) {
auto *first = module->Nr<VarValue>(module->Nr<Var>(module->getIntType()));
auto *second = module->Nr<VarValue>(module->Nr<Var>(module->getIntType()));
ASSERT_TRUE(util::match(first, second));
first->setVar(module->Nr<Var>(module->getFloatType()));
ASSERT_FALSE(util::match(first, second));
}
TEST_F(SIRCoreTest, MatchingPointerValue) {
auto *first = module->Nr<PointerValue>(module->Nr<Var>(module->getIntType()));
auto *second = module->Nr<PointerValue>(module->Nr<Var>(module->getIntType()));
ASSERT_TRUE(util::match(first, second));
first->setVar(module->Nr<Var>(module->getFloatType()));
ASSERT_FALSE(util::match(first, second));
}
TEST_F(SIRCoreTest, MatchingSeriesFlow) {
auto *first = module->Nr<SeriesFlow>();
auto *second = module->Nr<SeriesFlow>();
first->push_back(module->Nr<IntConst>(1, module->getIntType()));
second->push_back(module->Nr<IntConst>(1, module->getIntType()));
ASSERT_TRUE(util::match(first, second));
second->push_back(module->Nr<IntConst>(1, module->getIntType()));
ASSERT_FALSE(util::match(first, second));
}
TEST_F(SIRCoreTest, MatchingIfFlow) {
auto *cond = module->Nr<BoolConst>(true, module->getBoolType());
auto *tVal = module->Nr<SeriesFlow>();
auto *first = module->Nr<IfFlow>(cond, tVal);
auto *second = module->Nr<IfFlow>(cv->clone(cond), cast<Flow>(cv->clone(tVal)));
ASSERT_TRUE(util::match(first, second));
second->setFalseBranch(cast<Flow>(cv->clone(tVal)));
ASSERT_FALSE(util::match(first, second));
}
TEST_F(SIRCoreTest, MatchingForFlow) {
auto *body = module->Nr<SeriesFlow>();
auto *var = module->Nr<Var>(module->getIntType());
auto *iter = module->Nr<StringConst>("hello", module->getStringType());
auto *first = module->Nr<ForFlow>(iter, body, var);
auto *second =
module->Nr<ForFlow>(cv->clone(iter), cast<Flow>(cv->clone(body)), cv->clone(var));
ASSERT_TRUE(util::match(first, second));
second->setIter(module->Nr<StringConst>("foo", module->getStringType()));
ASSERT_FALSE(util::match(first, second));
}
TEST_F(SIRCoreTest, MatchingIntConst) {
auto *first = module->Nr<IntConst>(0, module->getIntType());
auto *second = module->Nr<IntConst>(0, module->getIntType());
ASSERT_TRUE(util::match(first, second));
first->setVal(2);
ASSERT_FALSE(util::match(first, second));
}
TEST_F(SIRCoreTest, MatchingFloatConst) {
auto *first = module->Nr<FloatConst>(0.0, module->getFloatType());
auto *second = module->Nr<FloatConst>(0.0, module->getFloatType());
ASSERT_TRUE(util::match(first, second));
first->setVal(2.0);
ASSERT_FALSE(util::match(first, second));
}
TEST_F(SIRCoreTest, MatchingBoolConst) {
auto *first = module->Nr<BoolConst>(false, module->getBoolType());
auto *second = module->Nr<BoolConst>(false, module->getBoolType());
ASSERT_TRUE(util::match(first, second));
first->setVal(true);
ASSERT_FALSE(util::match(first, second));
}
TEST_F(SIRCoreTest, MatchingStringConst) {
auto *first = module->Nr<StringConst>("hi", module->getStringType());
auto *second = module->Nr<StringConst>("hi", module->getStringType());
ASSERT_TRUE(util::match(first, second));
first->setVal("bye");
ASSERT_FALSE(util::match(first, second));
}
TEST_F(SIRCoreTest, MatchingAssignInstr) {
auto *var = module->Nr<Var>(module->getIntType());
auto *val = module->Nr<IntConst>(1, module->getIntType());
auto *first = module->Nr<AssignInstr>(var, val);
auto *second = module->Nr<AssignInstr>(cv->clone(var), cv->clone(val));
ASSERT_TRUE(util::match(first, second));
second->setRhs(module->Nr<IntConst>(5, module->getIntType()));
ASSERT_FALSE(util::match(first, second));
}
TEST_F(SIRCoreTest, MatchingExtractInstr) {
auto FIELD = "foo";
auto *type = cast<types::RecordType>(module->unsafeGetMemberedType("**internal**"));
type->realize({module->getIntType()}, {FIELD});
auto *var = module->Nr<Var>(type);
auto *val = module->Nr<VarValue>(var);
auto *first = module->Nr<ExtractInstr>(val, FIELD);
auto *second = module->Nr<ExtractInstr>(cv->clone(val), FIELD);
ASSERT_TRUE(util::match(first, second));
second->setField("");
ASSERT_FALSE(util::match(first, second));
}
TEST_F(SIRCoreTest, MatchingInsertInstr) {
auto FIELD = "foo";
auto *type = cast<types::RecordType>(module->unsafeGetMemberedType("**internal**"));
type->realize({module->getIntType()}, {FIELD});
auto *var = module->Nr<Var>(type);
auto *val = module->Nr<VarValue>(var);
auto *toInsert = module->Nr<IntConst>(1, module->getIntType());
auto *first = module->Nr<InsertInstr>(val, FIELD, toInsert);
auto *second = module->Nr<InsertInstr>(cv->clone(val), FIELD, cv->clone(toInsert));
ASSERT_TRUE(util::match(first, second));
second->setField("");
ASSERT_FALSE(util::match(first, second));
}
TEST_F(SIRCoreTest, MatchingCallInstr) {
auto *type = module->unsafeGetDummyFuncType();
auto *func = module->Nr<BodiedFunc>();
func->realize(type, {});
auto *func2 = module->Nr<BodiedFunc>();
func2->realize(module->unsafeGetFuncType("baz", module->getIntType(), {}), {});
auto *funcVal = module->Nr<VarValue>(func);
auto *first = module->Nr<CallInstr>(funcVal);
auto *second = module->Nr<CallInstr>(cv->clone(funcVal));
ASSERT_TRUE(util::match(first, second));
second->setCallee(module->Nr<VarValue>(func2));
ASSERT_FALSE(util::match(first, second));
}
TEST_F(SIRCoreTest, MatchingTernaryInstr) {
auto *trueValue = module->Nr<BoolConst>(true, module->getBoolType());
auto *falseValue = module->Nr<BoolConst>(false, module->getBoolType());
auto *cond = module->Nr<BoolConst>(true, module->getBoolType());
auto *first = module->Nr<TernaryInstr>(cond, trueValue, falseValue);
auto *second = module->Nr<TernaryInstr>(cv->clone(cond), cv->clone(trueValue),
cv->clone(falseValue));
ASSERT_TRUE(util::match(first, second));
second->setFalseValue(module->Nr<BoolConst>(true, module->getBoolType()));
ASSERT_FALSE(util::match(first, second));
}