aboutsummaryrefslogtreecommitdiffstats
path: root/tests/arch/common/lutram.v
blob: 9534b76198a5b505e7c9ba489fd44d2cf211bb73 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
module lutram_1w1r
#(parameter D_WIDTH=8, A_WIDTH=6)
(
	input [D_WIDTH-1:0] data_a,
	input [A_WIDTH:1] addr_a,
	input we_a, clk,
	output reg [D_WIDTH-1:0] q_a
);
	// Declare the RAM variable
	reg [D_WIDTH-1:0] ram[(2**A_WIDTH)-1:0];

	// Port A
	always @ (posedge clk)
	begin
		if (we_a)
			ram[addr_a] <= data_a;
		q_a <= ram[addr_a];
	end
endmodule


module lutram_1w3r
#(parameter D_WIDTH=8, A_WIDTH=5)
(
	input [D_WIDTH-1:0] data_a, data_b, data_c,
	input [A_WIDTH:1] addr_a, addr_b, addr_c,
	input we_a, clk,
	output reg [D_WIDTH-1:0] q_a, q_b, q_c
);
	// Declare the RAM variable
	reg [D_WIDTH-1:0] ram[(2**A_WIDTH)-1:0];

	// Port A
	always @ (posedge clk)
	begin
		if (we_a)
			ram[addr_a] <= data_a;
		q_a <= ram[addr_a];
		q_b <= ram[addr_b];
		q_c <= ram[addr_c];
	end
endmodule