| /* A simple Yosys plugin. (Copy&paste from http://stackoverflow.com/questions/32093541/how-does-the-yosys-consteval-api-work) |
| |
| Usage example: |
| |
| $ cat > evaldemo.v <<EOT |
| module main(input [1:0] A, input [7:0] B, C, D, output [7:0] Y); |
| assign Y = A == 0 ? B : A == 1 ? C : A == 2 ? D : 42; |
| endmodule |
| EOT |
| |
| $ yosys-config --build evaldemo.so evaldemo.cc |
| $ yosys -m evaldemo.so -p evaldemo evaldemo.v |
| */ |
| |
| #include "kernel/yosys.h" |
| #include "kernel/consteval.h" |
| |
| USING_YOSYS_NAMESPACE |
| PRIVATE_NAMESPACE_BEGIN |
| |
| struct EvalDemoPass : public Pass |
| { |
| EvalDemoPass() : Pass("evaldemo") { } |
| |
| void execute(vector<string>, Design *design) YS_OVERRIDE |
| { |
| Module *module = design->top_module(); |
| |
| if (module == nullptr) |
| log_error("No top module found!\n"); |
| |
| Wire *wire_a = module->wire("\\A"); |
| Wire *wire_y = module->wire("\\Y"); |
| |
| if (wire_a == nullptr) |
| log_error("No wire A found!\n"); |
| |
| if (wire_y == nullptr) |
| log_error("No wire Y found!\n"); |
| |
| ConstEval ce(module); |
| for (int v = 0; v < 4; v++) { |
| ce.push(); |
| ce.set(wire_a, Const(v, GetSize(wire_a))); |
| SigSpec sig_y = wire_y, sig_undef; |
| if (ce.eval(sig_y, sig_undef)) |
| log("Eval results for A=%d: Y=%s\n", v, log_signal(sig_y)); |
| else |
| log("Eval failed for A=%d: Missing value for %s\n", v, log_signal(sig_undef)); |
| ce.pop(); |
| } |
| } |
| } EvalDemoPass; |
| |
| PRIVATE_NAMESPACE_END |