mirror of
https://github.com/YosysHQ/yosys
synced 2025-04-13 04:28:18 +00:00
Add quick-and-dirty specify tests
This commit is contained in:
parent
d9c4644e88
commit
09841c2ac1
28
tests/various/specify.v
Normal file
28
tests/various/specify.v
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
module test (
|
||||||
|
input EN, CLK,
|
||||||
|
input [3:0] D,
|
||||||
|
output reg [3:0] Q
|
||||||
|
);
|
||||||
|
always @(posedge CLK)
|
||||||
|
if (EN) Q <= D;
|
||||||
|
|
||||||
|
specify
|
||||||
|
if (EN) (CLK *> (Q : D)) = (1, 2:3:4);
|
||||||
|
$setup(D, posedge CLK &&& EN, 5);
|
||||||
|
$hold(posedge CLK, D &&& EN, 6);
|
||||||
|
endspecify
|
||||||
|
endmodule
|
||||||
|
|
||||||
|
module test2 (
|
||||||
|
input A, B,
|
||||||
|
output Q
|
||||||
|
);
|
||||||
|
xor (Q, A, B);
|
||||||
|
specify
|
||||||
|
//specparam T_rise = 1;
|
||||||
|
//specparam T_fall = 2;
|
||||||
|
`define T_rise 1
|
||||||
|
`define T_fall 2
|
||||||
|
(A => Q) = (`T_rise,`T_fall);
|
||||||
|
endspecify
|
||||||
|
endmodule
|
25
tests/various/specify.ys
Normal file
25
tests/various/specify.ys
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
read_verilog -specify specify.v
|
||||||
|
prep
|
||||||
|
cd test
|
||||||
|
select t:$specify2 -assert-count 0
|
||||||
|
select t:$specify3 -assert-count 1
|
||||||
|
select t:$specrule -assert-count 2
|
||||||
|
cd test2
|
||||||
|
select t:$specify2 -assert-count 1
|
||||||
|
select t:$specify3 -assert-count 0
|
||||||
|
select t:$specrule -assert-count 0
|
||||||
|
write_verilog specify.out
|
||||||
|
design -stash gold
|
||||||
|
|
||||||
|
read_verilog -specify specify.out
|
||||||
|
cd test
|
||||||
|
select t:$specify2 -assert-count 0
|
||||||
|
select t:$specify3 -assert-count 1
|
||||||
|
select t:$specrule -assert-count 2
|
||||||
|
cd test2
|
||||||
|
select t:$specify2 -assert-count 1
|
||||||
|
select t:$specify3 -assert-count 0
|
||||||
|
select t:$specrule -assert-count 0
|
||||||
|
design -stash gate
|
||||||
|
|
||||||
|
# TODO: How to check $specify and $specrule-s are equivalent?
|
Loading…
Reference in a new issue