2023-01-01 22:28:56 +00:00
|
|
|
`timescale 1ns / 1ps
|
|
|
|
|
|
|
|
module Test_PriorityEncoder();
|
|
|
|
logic[7:0] data_in;
|
|
|
|
logic[2:0] data_out;
|
2023-02-01 16:20:37 +00:00
|
|
|
logic valid;
|
|
|
|
PriorityEncoder#(.N(3)) encoder(
|
|
|
|
.data_in(data_in),
|
|
|
|
.data_out(data_out),
|
|
|
|
.valid(valid)
|
|
|
|
);
|
2023-01-01 22:28:56 +00:00
|
|
|
initial begin
|
|
|
|
data_in = 'b00000001;
|
|
|
|
for (int i = 0; i < 8; i++) begin
|
2023-02-01 16:20:37 +00:00
|
|
|
assert (data_out == i[2:0] + 1 || valid == 1) else $error("[One-hot] Failed at %d", i);
|
2023-01-01 22:28:56 +00:00
|
|
|
#1
|
|
|
|
data_in = data_in << 'd1;
|
|
|
|
end
|
|
|
|
#1
|
|
|
|
data_in = 'b00101111;
|
|
|
|
assert (data_out == 'd5) else $error("[Manual entry] Failed at " + 5);
|
|
|
|
#1
|
|
|
|
data_in = 'b10101010;
|
|
|
|
assert (data_out == 'd7) else $error("[Manual entry] Failed at " + 7);
|
2023-02-01 16:20:37 +00:00
|
|
|
$finish;
|
2023-01-01 22:28:56 +00:00
|
|
|
end
|
|
|
|
endmodule
|