mirror of
https://github.com/verilator/verilator.git
synced 2025-01-03 21:27:35 +00:00
Normalize types in constraints (#5407)
Signed-off-by: Krzysztof Bieganski <kbieganski@antmicro.com>
This commit is contained in:
parent
d40f7f5167
commit
f623db7d68
@ -337,11 +337,15 @@ bool VlRandomizer::next(VlRNG& rngr) {
|
|||||||
|
|
||||||
f << "(set-option :produce-models true)\n";
|
f << "(set-option :produce-models true)\n";
|
||||||
f << "(set-logic QF_BV)\n";
|
f << "(set-logic QF_BV)\n";
|
||||||
|
f << "(define-fun __Vbv ((b Bool)) (_ BitVec 1) (ite b #b1 #b0))\n";
|
||||||
|
f << "(define-fun __Vbool ((v (_ BitVec 1))) Bool (= #b1 v))\n";
|
||||||
for (const auto& var : m_vars) {
|
for (const auto& var : m_vars) {
|
||||||
f << "(declare-fun " << var.second->name() << " () (_ BitVec " << var.second->width()
|
f << "(declare-fun " << var.second->name() << " () (_ BitVec " << var.second->width()
|
||||||
<< "))\n";
|
<< "))\n";
|
||||||
}
|
}
|
||||||
for (const std::string& constraint : m_constraints) { f << "(assert " << constraint << ")\n"; }
|
for (const std::string& constraint : m_constraints) {
|
||||||
|
f << "(assert (= #b1 " << constraint << "))\n";
|
||||||
|
}
|
||||||
f << "(check-sat)\n";
|
f << "(check-sat)\n";
|
||||||
|
|
||||||
bool sat = parseSolution(f);
|
bool sat = parseSolution(f);
|
||||||
|
@ -420,7 +420,7 @@ public:
|
|||||||
const V3Number& ths) override;
|
const V3Number& ths) override;
|
||||||
string emitVerilog() override { return "%k(%l %f? %r %k: %t)"; }
|
string emitVerilog() override { return "%k(%l %f? %r %k: %t)"; }
|
||||||
string emitC() override { return "VL_COND_%nq%lq%rq%tq(%nw, %P, %li, %ri, %ti)"; }
|
string emitC() override { return "VL_COND_%nq%lq%rq%tq(%nw, %P, %li, %ri, %ti)"; }
|
||||||
string emitSMT() const override { return "(ite %l %r %t)"; }
|
string emitSMT() const override { return "(ite (__Vbool %l) %r %t)"; }
|
||||||
bool cleanOut() const override { return false; } // clean if e1 & e2 clean
|
bool cleanOut() const override { return false; } // clean if e1 & e2 clean
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
bool cleanRhs() const override { return false; }
|
bool cleanRhs() const override { return false; }
|
||||||
@ -2583,7 +2583,7 @@ public:
|
|||||||
}
|
}
|
||||||
string emitVerilog() override { return "%k(%l %f==? %r)"; }
|
string emitVerilog() override { return "%k(%l %f==? %r)"; }
|
||||||
string emitC() override { return "VL_EQ_%lq(%lW, %P, %li, %ri)"; }
|
string emitC() override { return "VL_EQ_%lq(%lW, %P, %li, %ri)"; }
|
||||||
string emitSMT() const override { return "(= %l %r)"; }
|
string emitSMT() const override { return "(__Vbv (= %l %r))"; }
|
||||||
string emitSimpleOperator() override { return "=="; }
|
string emitSimpleOperator() override { return "=="; }
|
||||||
bool cleanOut() const override { return true; }
|
bool cleanOut() const override { return true; }
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
@ -2706,7 +2706,7 @@ public:
|
|||||||
}
|
}
|
||||||
string emitVerilog() override { return "%k(%l %f> %r)"; }
|
string emitVerilog() override { return "%k(%l %f> %r)"; }
|
||||||
string emitC() override { return "VL_GT_%lq(%lW, %P, %li, %ri)"; }
|
string emitC() override { return "VL_GT_%lq(%lW, %P, %li, %ri)"; }
|
||||||
string emitSMT() const override { return "(bvugt %l %r)"; }
|
string emitSMT() const override { return "(__Vbv (bvugt %l %r))"; }
|
||||||
string emitSimpleOperator() override { return ">"; }
|
string emitSimpleOperator() override { return ">"; }
|
||||||
bool cleanOut() const override { return true; }
|
bool cleanOut() const override { return true; }
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
@ -2777,7 +2777,7 @@ public:
|
|||||||
}
|
}
|
||||||
string emitVerilog() override { return "%k(%l %f> %r)"; }
|
string emitVerilog() override { return "%k(%l %f> %r)"; }
|
||||||
string emitC() override { return "VL_GTS_%nq%lq%rq(%lw, %P, %li, %ri)"; }
|
string emitC() override { return "VL_GTS_%nq%lq%rq(%lw, %P, %li, %ri)"; }
|
||||||
string emitSMT() const override { return "(bvsgt %l %r)"; }
|
string emitSMT() const override { return "(__Vbv (bvsgt %l %r))"; }
|
||||||
string emitSimpleOperator() override { return ""; }
|
string emitSimpleOperator() override { return ""; }
|
||||||
bool cleanOut() const override { return true; }
|
bool cleanOut() const override { return true; }
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
@ -2801,7 +2801,7 @@ public:
|
|||||||
}
|
}
|
||||||
string emitVerilog() override { return "%k(%l %f>= %r)"; }
|
string emitVerilog() override { return "%k(%l %f>= %r)"; }
|
||||||
string emitC() override { return "VL_GTE_%lq(%lW, %P, %li, %ri)"; }
|
string emitC() override { return "VL_GTE_%lq(%lW, %P, %li, %ri)"; }
|
||||||
string emitSMT() const override { return "(bvuge %l %r)"; }
|
string emitSMT() const override { return "(__Vbv (bvuge %l %r))"; }
|
||||||
string emitSimpleOperator() override { return ">="; }
|
string emitSimpleOperator() override { return ">="; }
|
||||||
bool cleanOut() const override { return true; }
|
bool cleanOut() const override { return true; }
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
@ -2872,7 +2872,7 @@ public:
|
|||||||
}
|
}
|
||||||
string emitVerilog() override { return "%k(%l %f>= %r)"; }
|
string emitVerilog() override { return "%k(%l %f>= %r)"; }
|
||||||
string emitC() override { return "VL_GTES_%nq%lq%rq(%lw, %P, %li, %ri)"; }
|
string emitC() override { return "VL_GTES_%nq%lq%rq(%lw, %P, %li, %ri)"; }
|
||||||
string emitSMT() const override { return "(bvsge %l %r)"; }
|
string emitSMT() const override { return "(__Vbv (bvsge %l %r))"; }
|
||||||
string emitSimpleOperator() override { return ""; }
|
string emitSimpleOperator() override { return ""; }
|
||||||
bool cleanOut() const override { return true; }
|
bool cleanOut() const override { return true; }
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
@ -2896,7 +2896,7 @@ public:
|
|||||||
}
|
}
|
||||||
string emitVerilog() override { return "%k(%l %f&& %r)"; }
|
string emitVerilog() override { return "%k(%l %f&& %r)"; }
|
||||||
string emitC() override { return "VL_LOGAND_%nq%lq%rq(%nw,%lw,%rw, %P, %li, %ri)"; }
|
string emitC() override { return "VL_LOGAND_%nq%lq%rq(%nw,%lw,%rw, %P, %li, %ri)"; }
|
||||||
string emitSMT() const override { return "(and %l %r)"; }
|
string emitSMT() const override { return "(bvand %l %r)"; }
|
||||||
string emitSimpleOperator() override { return "&&"; }
|
string emitSimpleOperator() override { return "&&"; }
|
||||||
bool cleanOut() const override { return true; }
|
bool cleanOut() const override { return true; }
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
@ -2920,7 +2920,7 @@ public:
|
|||||||
}
|
}
|
||||||
string emitVerilog() override { return "%k(%l %f-> %r)"; }
|
string emitVerilog() override { return "%k(%l %f-> %r)"; }
|
||||||
string emitC() override { return "VL_LOGIF_%nq%lq%rq(%nw,%lw,%rw, %P, %li, %ri)"; }
|
string emitC() override { return "VL_LOGIF_%nq%lq%rq(%nw,%lw,%rw, %P, %li, %ri)"; }
|
||||||
string emitSMT() const override { return "(=> %l %r)"; }
|
string emitSMT() const override { return "(__Vbv (=> (__Vbool %l) (__Vbool %r)))"; }
|
||||||
string emitSimpleOperator() override { return "->"; }
|
string emitSimpleOperator() override { return "->"; }
|
||||||
bool cleanOut() const override { return true; }
|
bool cleanOut() const override { return true; }
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
@ -2944,7 +2944,7 @@ public:
|
|||||||
}
|
}
|
||||||
string emitVerilog() override { return "%k(%l %f|| %r)"; }
|
string emitVerilog() override { return "%k(%l %f|| %r)"; }
|
||||||
string emitC() override { return "VL_LOGOR_%nq%lq%rq(%nw,%lw,%rw, %P, %li, %ri)"; }
|
string emitC() override { return "VL_LOGOR_%nq%lq%rq(%nw,%lw,%rw, %P, %li, %ri)"; }
|
||||||
string emitSMT() const override { return "(or %l %r)"; }
|
string emitSMT() const override { return "(bvor %l %r)"; }
|
||||||
string emitSimpleOperator() override { return "||"; }
|
string emitSimpleOperator() override { return "||"; }
|
||||||
bool cleanOut() const override { return true; }
|
bool cleanOut() const override { return true; }
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
@ -2968,7 +2968,7 @@ public:
|
|||||||
}
|
}
|
||||||
string emitVerilog() override { return "%k(%l %f< %r)"; }
|
string emitVerilog() override { return "%k(%l %f< %r)"; }
|
||||||
string emitC() override { return "VL_LT_%lq(%lW, %P, %li, %ri)"; }
|
string emitC() override { return "VL_LT_%lq(%lW, %P, %li, %ri)"; }
|
||||||
string emitSMT() const override { return "(bvult %l %r)"; }
|
string emitSMT() const override { return "(__Vbv (bvult %l %r))"; }
|
||||||
string emitSimpleOperator() override { return "<"; }
|
string emitSimpleOperator() override { return "<"; }
|
||||||
bool cleanOut() const override { return true; }
|
bool cleanOut() const override { return true; }
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
@ -3039,7 +3039,7 @@ public:
|
|||||||
}
|
}
|
||||||
string emitVerilog() override { return "%k(%l %f< %r)"; }
|
string emitVerilog() override { return "%k(%l %f< %r)"; }
|
||||||
string emitC() override { return "VL_LTS_%nq%lq%rq(%lw, %P, %li, %ri)"; }
|
string emitC() override { return "VL_LTS_%nq%lq%rq(%lw, %P, %li, %ri)"; }
|
||||||
string emitSMT() const override { return "(bvslt %l %r)"; }
|
string emitSMT() const override { return "(__Vbv (bvslt %l %r))"; }
|
||||||
string emitSimpleOperator() override { return ""; }
|
string emitSimpleOperator() override { return ""; }
|
||||||
bool cleanOut() const override { return true; }
|
bool cleanOut() const override { return true; }
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
@ -3063,7 +3063,7 @@ public:
|
|||||||
}
|
}
|
||||||
string emitVerilog() override { return "%k(%l %f<= %r)"; }
|
string emitVerilog() override { return "%k(%l %f<= %r)"; }
|
||||||
string emitC() override { return "VL_LTE_%lq(%lW, %P, %li, %ri)"; }
|
string emitC() override { return "VL_LTE_%lq(%lW, %P, %li, %ri)"; }
|
||||||
string emitSMT() const override { return "(bvule %l %r)"; }
|
string emitSMT() const override { return "(__Vbv (bvule %l %r))"; }
|
||||||
string emitSimpleOperator() override { return "<="; }
|
string emitSimpleOperator() override { return "<="; }
|
||||||
bool cleanOut() const override { return true; }
|
bool cleanOut() const override { return true; }
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
@ -3134,7 +3134,7 @@ public:
|
|||||||
}
|
}
|
||||||
string emitVerilog() override { return "%k(%l %f<= %r)"; }
|
string emitVerilog() override { return "%k(%l %f<= %r)"; }
|
||||||
string emitC() override { return "VL_LTES_%nq%lq%rq(%lw, %P, %li, %ri)"; }
|
string emitC() override { return "VL_LTES_%nq%lq%rq(%lw, %P, %li, %ri)"; }
|
||||||
string emitSMT() const override { return "(bvsle %l %r)"; }
|
string emitSMT() const override { return "(__Vbv (bvsle %l %r))"; }
|
||||||
string emitSimpleOperator() override { return ""; }
|
string emitSimpleOperator() override { return ""; }
|
||||||
bool cleanOut() const override { return true; }
|
bool cleanOut() const override { return true; }
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
@ -3637,7 +3637,7 @@ public:
|
|||||||
}
|
}
|
||||||
string emitVerilog() override { return "%k(%l %f== %r)"; }
|
string emitVerilog() override { return "%k(%l %f== %r)"; }
|
||||||
string emitC() override { return "VL_EQ_%lq(%lW, %P, %li, %ri)"; }
|
string emitC() override { return "VL_EQ_%lq(%lW, %P, %li, %ri)"; }
|
||||||
string emitSMT() const override { return "(= %l %r)"; }
|
string emitSMT() const override { return "(__Vbv (= %l %r))"; }
|
||||||
string emitSimpleOperator() override { return "=="; }
|
string emitSimpleOperator() override { return "=="; }
|
||||||
bool cleanOut() const override { return true; }
|
bool cleanOut() const override { return true; }
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
@ -3779,7 +3779,7 @@ public:
|
|||||||
string emitVerilog() override { return "%k(%l %f!= %r)"; }
|
string emitVerilog() override { return "%k(%l %f!= %r)"; }
|
||||||
string emitC() override { return "VL_NEQ_%lq(%lW, %P, %li, %ri)"; }
|
string emitC() override { return "VL_NEQ_%lq(%lW, %P, %li, %ri)"; }
|
||||||
string emitSimpleOperator() override { return "!="; }
|
string emitSimpleOperator() override { return "!="; }
|
||||||
string emitSMT() const override { return "(not (= %l %r))"; }
|
string emitSMT() const override { return "(__Vbv (not (= %l %r)))"; }
|
||||||
bool cleanOut() const override { return true; }
|
bool cleanOut() const override { return true; }
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
bool cleanRhs() const override { return true; }
|
bool cleanRhs() const override { return true; }
|
||||||
@ -5150,7 +5150,7 @@ public:
|
|||||||
void numberOperate(V3Number& out, const V3Number& lhs) override { out.opLogNot(lhs); }
|
void numberOperate(V3Number& out, const V3Number& lhs) override { out.opLogNot(lhs); }
|
||||||
string emitVerilog() override { return "%f(! %l)"; }
|
string emitVerilog() override { return "%f(! %l)"; }
|
||||||
string emitC() override { return "VL_LOGNOT_%nq%lq(%nw,%lw, %P, %li)"; }
|
string emitC() override { return "VL_LOGNOT_%nq%lq(%nw,%lw, %P, %li)"; }
|
||||||
string emitSMT() const override { return "(not %l)"; }
|
string emitSMT() const override { return "(__Vbv (not (__Vbool %l)))"; }
|
||||||
string emitSimpleOperator() override { return "!"; }
|
string emitSimpleOperator() override { return "!"; }
|
||||||
bool cleanOut() const override { return true; }
|
bool cleanOut() const override { return true; }
|
||||||
bool cleanLhs() const override { return true; }
|
bool cleanLhs() const override { return true; }
|
||||||
|
@ -551,7 +551,7 @@ class ConstraintExprVisitor final : public VNVisitor {
|
|||||||
if (!exprsp->nextp()) return exprsp;
|
if (!exprsp->nextp()) return exprsp;
|
||||||
|
|
||||||
std::ostringstream fmt;
|
std::ostringstream fmt;
|
||||||
fmt << "(and";
|
fmt << "(bvand";
|
||||||
for (AstNode* itemp = exprsp; itemp; itemp = itemp->nextp()) fmt << " %@";
|
for (AstNode* itemp = exprsp; itemp; itemp = itemp->nextp()) fmt << " %@";
|
||||||
fmt << ')';
|
fmt << ')';
|
||||||
return new AstSFormatF{fl, fmt.str(), false, exprsp};
|
return new AstSFormatF{fl, fmt.str(), false, exprsp};
|
||||||
@ -695,7 +695,7 @@ class ConstraintExprVisitor final : public VNVisitor {
|
|||||||
AstNode* const cstmtp = new AstText{fl, "ret += \" \" + "};
|
AstNode* const cstmtp = new AstText{fl, "ret += \" \" + "};
|
||||||
cstmtp->addNext(itemp);
|
cstmtp->addNext(itemp);
|
||||||
cstmtp->addNext(new AstText{fl, ";"});
|
cstmtp->addNext(new AstText{fl, ";"});
|
||||||
AstNode* const exprsp = new AstText{fl, "([&]{ std::string ret = \"(and\";"};
|
AstNode* const exprsp = new AstText{fl, "([&]{ std::string ret = \"(bvand\";"};
|
||||||
exprsp->addNext(new AstBegin{
|
exprsp->addNext(new AstBegin{
|
||||||
fl, "",
|
fl, "",
|
||||||
new AstForeach{fl, nodep->arrayp()->unlinkFrBack(), new AstCStmt{fl, cstmtp}},
|
new AstForeach{fl, nodep->arrayp()->unlinkFrBack(), new AstCStmt{fl, cstmtp}},
|
||||||
|
@ -34,9 +34,9 @@ class Packet;
|
|||||||
constraint one_c { one == 1; }
|
constraint one_c { one == 1; }
|
||||||
constraint sel { d[15:8] == 8'h55; }
|
constraint sel { d[15:8] == 8'h55; }
|
||||||
constraint ifelse {
|
constraint ifelse {
|
||||||
if (one == 1) out0 == 'h333;
|
if (one) out0 == 'h333;
|
||||||
|
|
||||||
if (one == 0) tiny != tiny;
|
if (!one) tiny != tiny;
|
||||||
else out1 == 'h333;
|
else out1 == 'h333;
|
||||||
if (one == 1) out2 == 'h333;
|
if (one == 1) out2 == 'h333;
|
||||||
else tiny != tiny;
|
else tiny != tiny;
|
||||||
@ -58,6 +58,11 @@ class Packet;
|
|||||||
else
|
else
|
||||||
if (one == 1) tiny != tiny;
|
if (one == 1) tiny != tiny;
|
||||||
else { tiny != tiny; }
|
else { tiny != tiny; }
|
||||||
|
|
||||||
|
if (one && zero) tiny != tiny;
|
||||||
|
if (~one && zero) tiny != tiny;
|
||||||
|
if (zero || (one & zero)) tiny != tiny;
|
||||||
|
if (zero && (one | zero)) tiny != tiny;
|
||||||
}
|
}
|
||||||
|
|
||||||
endclass
|
endclass
|
||||||
|
Loading…
Reference in New Issue
Block a user