2013-09-10 11:16:13 +00:00
|
|
|
// DESCRIPTION: Verilator: Verilog Test module
|
|
|
|
//
|
2020-03-21 15:24:24 +00:00
|
|
|
// This file ONLY is placed under the Creative Commons Public Domain, for
|
|
|
|
// any use, without warranty, 2013 by Wilson Snyder.
|
|
|
|
// SPDX-License-Identifier: CC0-1.0
|
2013-09-10 11:16:13 +00:00
|
|
|
|
|
|
|
module t (/*AUTOARG*/
|
|
|
|
// Inputs
|
|
|
|
clk
|
|
|
|
);
|
|
|
|
input clk;
|
|
|
|
|
|
|
|
reg [7:0] x;
|
|
|
|
wire [3:0] en;
|
|
|
|
wire sel;
|
|
|
|
wire a;
|
2017-09-11 23:18:58 +00:00
|
|
|
|
2013-09-10 11:16:13 +00:00
|
|
|
// bug675
|
|
|
|
generate
|
|
|
|
genvar g_k;
|
|
|
|
for ( g_k = 0; g_k < 8; g_k = g_k + 1 )
|
|
|
|
begin: g_index
|
2022-05-01 14:10:00 +00:00
|
|
|
always @* begin
|
|
|
|
// Note this isn't a genif, but normal if
|
|
|
|
// verilator lint_off SELRANGE
|
|
|
|
if(g_k<4) begin
|
2013-09-10 11:16:13 +00:00
|
|
|
x[g_k] = (sel == 1'b1) ? 1'b1 : (en[g_k] == 1'b0) ? 1'b1 : a;
|
|
|
|
end
|
2022-05-01 14:10:00 +00:00
|
|
|
else begin
|
2013-09-10 11:16:13 +00:00
|
|
|
x[g_k] = (sel == 1'b0) ? 1'b1 : (en[g_k-4] == 1'b0) ? 1'b1 : a;
|
|
|
|
end
|
2022-05-01 14:10:00 +00:00
|
|
|
// verilator lint_on SELRANGE
|
2013-09-10 11:16:13 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
endgenerate
|
2017-09-11 23:18:58 +00:00
|
|
|
|
2013-09-10 11:16:13 +00:00
|
|
|
endmodule
|