mirror of https://github.com/YosysHQ/yosys.git
initialized iCE40 brams (mode 0)
This commit is contained in:
parent
4cc4400514
commit
b4d7a590e8
|
@ -1,5 +1,5 @@
|
|||
bram $__ICE40_RAM4K_M0
|
||||
init 0
|
||||
init 1
|
||||
abits 8
|
||||
dbits 16
|
||||
groups 2
|
||||
|
|
|
@ -1,8 +1,179 @@
|
|||
|
||||
module \$__ICE40_RAM4K (
|
||||
output [15:0] RDATA,
|
||||
input RCLK, RCLKE, RE,
|
||||
input [10:0] RADDR,
|
||||
input WCLK, WCLKE, WE,
|
||||
input [10:0] WADDR,
|
||||
input [15:0] MASK, WDATA
|
||||
);
|
||||
parameter integer READ_MODE = 0;
|
||||
parameter integer WRITE_MODE = 0;
|
||||
parameter [0:0] NEGCLK_R = 0;
|
||||
parameter [0:0] NEGCLK_W = 0;
|
||||
|
||||
parameter [255:0] INIT_0 = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
parameter [255:0] INIT_1 = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
parameter [255:0] INIT_2 = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
parameter [255:0] INIT_3 = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
parameter [255:0] INIT_4 = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
parameter [255:0] INIT_5 = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
parameter [255:0] INIT_6 = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
parameter [255:0] INIT_7 = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
parameter [255:0] INIT_8 = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
parameter [255:0] INIT_9 = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
parameter [255:0] INIT_A = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
parameter [255:0] INIT_B = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
parameter [255:0] INIT_C = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
parameter [255:0] INIT_D = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
parameter [255:0] INIT_E = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
parameter [255:0] INIT_F = 256'h0000000000000000000000000000000000000000000000000000000000000000;
|
||||
|
||||
generate
|
||||
case ({NEGCLK_R, NEGCLK_W})
|
||||
2'b00:
|
||||
SB_RAM40_4K #(
|
||||
.READ_MODE(READ_MODE),
|
||||
.WRITE_MODE(WRITE_MODE),
|
||||
.INIT_0(INIT_0),
|
||||
.INIT_1(INIT_1),
|
||||
.INIT_2(INIT_2),
|
||||
.INIT_3(INIT_3),
|
||||
.INIT_4(INIT_4),
|
||||
.INIT_5(INIT_5),
|
||||
.INIT_6(INIT_6),
|
||||
.INIT_7(INIT_7),
|
||||
.INIT_8(INIT_8),
|
||||
.INIT_9(INIT_9),
|
||||
.INIT_A(INIT_A),
|
||||
.INIT_B(INIT_B),
|
||||
.INIT_C(INIT_C),
|
||||
.INIT_D(INIT_D),
|
||||
.INIT_E(INIT_E),
|
||||
.INIT_F(INIT_F)
|
||||
) _TECHMAP_REPLACE_ (
|
||||
.RDATA(RDATA),
|
||||
.RCLK (RCLK ),
|
||||
.RCLKE(RCLKE),
|
||||
.RE (RE ),
|
||||
.RADDR(RADDR),
|
||||
.WCLK (WCLK ),
|
||||
.WCLKE(WCLKE),
|
||||
.WE (WE ),
|
||||
.WADDR(WADDR),
|
||||
.MASK (MASK ),
|
||||
.WDATA(WDATA)
|
||||
);
|
||||
2'b01:
|
||||
SB_RAM40_4KNW #(
|
||||
.READ_MODE(READ_MODE),
|
||||
.WRITE_MODE(WRITE_MODE),
|
||||
.INIT_0(INIT_0),
|
||||
.INIT_1(INIT_1),
|
||||
.INIT_2(INIT_2),
|
||||
.INIT_3(INIT_3),
|
||||
.INIT_4(INIT_4),
|
||||
.INIT_5(INIT_5),
|
||||
.INIT_6(INIT_6),
|
||||
.INIT_7(INIT_7),
|
||||
.INIT_8(INIT_8),
|
||||
.INIT_9(INIT_9),
|
||||
.INIT_A(INIT_A),
|
||||
.INIT_B(INIT_B),
|
||||
.INIT_C(INIT_C),
|
||||
.INIT_D(INIT_D),
|
||||
.INIT_E(INIT_E),
|
||||
.INIT_F(INIT_F)
|
||||
) _TECHMAP_REPLACE_ (
|
||||
.RDATA(RDATA),
|
||||
.RCLK (RCLK ),
|
||||
.RCLKE(RCLKE),
|
||||
.RE (RE ),
|
||||
.RADDR(RADDR),
|
||||
.WCLK (WCLK ),
|
||||
.WCLKE(WCLKE),
|
||||
.WE (WE ),
|
||||
.WADDR(WADDR),
|
||||
.MASK (MASK ),
|
||||
.WDATA(WDATA)
|
||||
);
|
||||
2'b10:
|
||||
SB_RAM40_4KNR #(
|
||||
.READ_MODE(READ_MODE),
|
||||
.WRITE_MODE(WRITE_MODE),
|
||||
.INIT_0(INIT_0),
|
||||
.INIT_1(INIT_1),
|
||||
.INIT_2(INIT_2),
|
||||
.INIT_3(INIT_3),
|
||||
.INIT_4(INIT_4),
|
||||
.INIT_5(INIT_5),
|
||||
.INIT_6(INIT_6),
|
||||
.INIT_7(INIT_7),
|
||||
.INIT_8(INIT_8),
|
||||
.INIT_9(INIT_9),
|
||||
.INIT_A(INIT_A),
|
||||
.INIT_B(INIT_B),
|
||||
.INIT_C(INIT_C),
|
||||
.INIT_D(INIT_D),
|
||||
.INIT_E(INIT_E),
|
||||
.INIT_F(INIT_F)
|
||||
) _TECHMAP_REPLACE_ (
|
||||
.RDATA(RDATA),
|
||||
.RCLK (RCLK ),
|
||||
.RCLKE(RCLKE),
|
||||
.RE (RE ),
|
||||
.RADDR(RADDR),
|
||||
.WCLK (WCLK ),
|
||||
.WCLKE(WCLKE),
|
||||
.WE (WE ),
|
||||
.WADDR(WADDR),
|
||||
.MASK (MASK ),
|
||||
.WDATA(WDATA)
|
||||
);
|
||||
2'b11:
|
||||
SB_RAM40_4KNRNW #(
|
||||
.READ_MODE(READ_MODE),
|
||||
.WRITE_MODE(WRITE_MODE),
|
||||
.INIT_0(INIT_0),
|
||||
.INIT_1(INIT_1),
|
||||
.INIT_2(INIT_2),
|
||||
.INIT_3(INIT_3),
|
||||
.INIT_4(INIT_4),
|
||||
.INIT_5(INIT_5),
|
||||
.INIT_6(INIT_6),
|
||||
.INIT_7(INIT_7),
|
||||
.INIT_8(INIT_8),
|
||||
.INIT_9(INIT_9),
|
||||
.INIT_A(INIT_A),
|
||||
.INIT_B(INIT_B),
|
||||
.INIT_C(INIT_C),
|
||||
.INIT_D(INIT_D),
|
||||
.INIT_E(INIT_E),
|
||||
.INIT_F(INIT_F)
|
||||
) _TECHMAP_REPLACE_ (
|
||||
.RDATA(RDATA),
|
||||
.RCLK (RCLK ),
|
||||
.RCLKE(RCLKE),
|
||||
.RE (RE ),
|
||||
.RADDR(RADDR),
|
||||
.WCLK (WCLK ),
|
||||
.WCLKE(WCLKE),
|
||||
.WE (WE ),
|
||||
.WADDR(WADDR),
|
||||
.MASK (MASK ),
|
||||
.WDATA(WDATA)
|
||||
);
|
||||
endcase
|
||||
endgenerate
|
||||
endmodule
|
||||
|
||||
|
||||
module \$__ICE40_RAM4K_M0 (CLK2, CLK3, A1ADDR, A1DATA, B1ADDR, B1DATA, B1EN);
|
||||
parameter [0:0] CLKPOL2 = 1;
|
||||
parameter [0:0] CLKPOL3 = 1;
|
||||
|
||||
parameter [4095:0] INIT = 4096'bx;
|
||||
|
||||
input CLK2;
|
||||
input CLK3;
|
||||
|
||||
|
@ -16,30 +187,40 @@ module \$__ICE40_RAM4K_M0 (CLK2, CLK3, A1ADDR, A1DATA, B1ADDR, B1DATA, B1EN);
|
|||
wire [10:0] A1ADDR_11 = A1ADDR;
|
||||
wire [10:0] B1ADDR_11 = B1ADDR;
|
||||
|
||||
generate
|
||||
case ({CLKPOL2, CLKPOL3})
|
||||
2'b00:
|
||||
SB_RAM40_4KNRNW #(.WRITE_MODE(0), .READ_MODE(0)) _TECHMAP_REPLACE_ (
|
||||
.RDATA(A1DATA), .RADDR(A1ADDR_11), .RCLK(CLK2), .RCLKE(1'b1), .RE(1'b1),
|
||||
.WDATA(B1DATA), .WADDR(B1ADDR_11), .MASK(~B1EN), .WCLK(CLK3), .WCLKE(1'b1), .WE(|B1EN)
|
||||
);
|
||||
2'b01:
|
||||
SB_RAM40_4KNR #(.WRITE_MODE(0), .READ_MODE(0)) _TECHMAP_REPLACE_ (
|
||||
.RDATA(A1DATA), .RADDR(A1ADDR_11), .RCLK(CLK2), .RCLKE(1'b1), .RE(1'b1),
|
||||
.WDATA(B1DATA), .WADDR(B1ADDR_11), .MASK(~B1EN), .WCLK(CLK3), .WCLKE(1'b1), .WE(|B1EN)
|
||||
);
|
||||
2'b10:
|
||||
SB_RAM40_4KNW #(.WRITE_MODE(0), .READ_MODE(0)) _TECHMAP_REPLACE_ (
|
||||
.RDATA(A1DATA), .RADDR(A1ADDR_11), .RCLK(CLK2), .RCLKE(1'b1), .RE(1'b1),
|
||||
.WDATA(B1DATA), .WADDR(B1ADDR_11), .MASK(~B1EN), .WCLK(CLK3), .WCLKE(1'b1), .WE(|B1EN)
|
||||
);
|
||||
2'b11:
|
||||
SB_RAM40_4K #(.WRITE_MODE(0), .READ_MODE(0)) _TECHMAP_REPLACE_ (
|
||||
.RDATA(A1DATA), .RADDR(A1ADDR_11), .RCLK(CLK2), .RCLKE(1'b1), .RE(1'b1),
|
||||
.WDATA(B1DATA), .WADDR(B1ADDR_11), .MASK(~B1EN), .WCLK(CLK3), .WCLKE(1'b1), .WE(|B1EN)
|
||||
);
|
||||
endcase
|
||||
endgenerate
|
||||
\$__ICE40_RAM4K #(
|
||||
.READ_MODE(0),
|
||||
.WRITE_MODE(0),
|
||||
.NEGCLK_R(!CLKPOL2),
|
||||
.NEGCLK_W(!CLKPOL3),
|
||||
.INIT_0(INIT[ 0*256 +: 256]),
|
||||
.INIT_1(INIT[ 1*256 +: 256]),
|
||||
.INIT_2(INIT[ 2*256 +: 256]),
|
||||
.INIT_3(INIT[ 3*256 +: 256]),
|
||||
.INIT_4(INIT[ 4*256 +: 256]),
|
||||
.INIT_5(INIT[ 5*256 +: 256]),
|
||||
.INIT_6(INIT[ 6*256 +: 256]),
|
||||
.INIT_7(INIT[ 7*256 +: 256]),
|
||||
.INIT_8(INIT[ 8*256 +: 256]),
|
||||
.INIT_9(INIT[ 9*256 +: 256]),
|
||||
.INIT_A(INIT[10*256 +: 256]),
|
||||
.INIT_B(INIT[11*256 +: 256]),
|
||||
.INIT_C(INIT[12*256 +: 256]),
|
||||
.INIT_D(INIT[13*256 +: 256]),
|
||||
.INIT_E(INIT[14*256 +: 256]),
|
||||
.INIT_F(INIT[15*256 +: 256])
|
||||
) _TECHMAP_REPLACE_ (
|
||||
.RDATA(A1DATA),
|
||||
.RADDR(A1ADDR_11),
|
||||
.RCLK(CLK2),
|
||||
.RCLKE(1'b1),
|
||||
.RE(1'b1),
|
||||
.WDATA(B1DATA),
|
||||
.WADDR(B1ADDR_11),
|
||||
.MASK(~B1EN),
|
||||
.WCLK(CLK3),
|
||||
.WCLKE(1'b1),
|
||||
.WE(|B1EN)
|
||||
);
|
||||
endmodule
|
||||
|
||||
module \$__ICE40_RAM4K_M123 (CLK2, CLK3, A1ADDR, A1DATA, B1ADDR, B1DATA, B1EN);
|
||||
|
@ -86,29 +267,38 @@ module \$__ICE40_RAM4K_M123 (CLK2, CLK3, A1ADDR, A1DATA, B1ADDR, B1DATA, B1EN);
|
|||
end
|
||||
endgenerate
|
||||
|
||||
generate
|
||||
case ({CLKPOL2, CLKPOL3})
|
||||
2'b00:
|
||||
SB_RAM40_4KNRNW #(.WRITE_MODE(MODE), .READ_MODE(MODE)) _TECHMAP_REPLACE_ (
|
||||
.RDATA(A1DATA_16), .RADDR(A1ADDR_11), .RCLK(CLK2), .RCLKE(1'b1), .RE(1'b1),
|
||||
.WDATA(B1DATA_16), .WADDR(B1ADDR_11), .WCLK(CLK3), .WCLKE(1'b1), .WE(B1EN)
|
||||
);
|
||||
2'b01:
|
||||
SB_RAM40_4KNR #(.WRITE_MODE(MODE), .READ_MODE(MODE)) _TECHMAP_REPLACE_ (
|
||||
.RDATA(A1DATA_16), .RADDR(A1ADDR_11), .RCLK(CLK2), .RCLKE(1'b1), .RE(1'b1),
|
||||
.WDATA(B1DATA_16), .WADDR(B1ADDR_11), .WCLK(CLK3), .WCLKE(1'b1), .WE(B1EN)
|
||||
);
|
||||
2'b10:
|
||||
SB_RAM40_4RNW #(.WRITE_MODE(MODE), .READ_MODE(MODE)) _TECHMAP_REPLACE_ (
|
||||
.RDATA(A1DATA_16), .RADDR(A1ADDR_11), .RCLK(CLK2), .RCLKE(1'b1), .RE(1'b1),
|
||||
.WDATA(B1DATA_16), .WADDR(B1ADDR_11), .WCLK(CLK3), .WCLKE(1'b1), .WE(B1EN)
|
||||
);
|
||||
2'b11:
|
||||
SB_RAM40_4K #(.WRITE_MODE(MODE), .READ_MODE(MODE)) _TECHMAP_REPLACE_ (
|
||||
.RDATA(A1DATA_16), .RADDR(A1ADDR_11), .RCLK(CLK2), .RCLKE(1'b1), .RE(1'b1),
|
||||
.WDATA(B1DATA_16), .WADDR(B1ADDR_11), .WCLK(CLK3), .WCLKE(1'b1), .WE(B1EN)
|
||||
);
|
||||
endcase
|
||||
endgenerate
|
||||
\$__ICE40_RAM4K #(
|
||||
.READ_MODE(MODE),
|
||||
.WRITE_MODE(MODE),
|
||||
.NEGCLK_R(!CLKPOL2),
|
||||
.NEGCLK_W(!CLKPOL3),
|
||||
// .INIT_0(INIT[ 0*256 +: 256]),
|
||||
// .INIT_1(INIT[ 1*256 +: 256]),
|
||||
// .INIT_2(INIT[ 2*256 +: 256]),
|
||||
// .INIT_3(INIT[ 3*256 +: 256]),
|
||||
// .INIT_4(INIT[ 4*256 +: 256]),
|
||||
// .INIT_5(INIT[ 5*256 +: 256]),
|
||||
// .INIT_6(INIT[ 6*256 +: 256]),
|
||||
// .INIT_7(INIT[ 7*256 +: 256]),
|
||||
// .INIT_8(INIT[ 8*256 +: 256]),
|
||||
// .INIT_9(INIT[ 9*256 +: 256]),
|
||||
// .INIT_A(INIT[10*256 +: 256]),
|
||||
// .INIT_B(INIT[11*256 +: 256]),
|
||||
// .INIT_C(INIT[12*256 +: 256]),
|
||||
// .INIT_D(INIT[13*256 +: 256]),
|
||||
// .INIT_E(INIT[14*256 +: 256]),
|
||||
// .INIT_F(INIT[15*256 +: 256])
|
||||
) _TECHMAP_REPLACE_ (
|
||||
.RDATA(A1DATA_16),
|
||||
.RADDR(A1ADDR_11),
|
||||
.RCLK(CLK2),
|
||||
.RCLKE(1'b1),
|
||||
.RE(1'b1),
|
||||
.WDATA(B1DATA_16),
|
||||
.WADDR(B1ADDR_11),
|
||||
.WCLK(CLK3),
|
||||
.WCLKE(1'b1),
|
||||
.WE(|B1EN)
|
||||
);
|
||||
endmodule
|
||||
|
||||
|
|
|
@ -5,8 +5,15 @@ set -ex
|
|||
for abits in 7 8 9 10 11 12; do
|
||||
for dbits in 2 4 8 16 24 32; do
|
||||
id="test_bram_${abits}_${dbits}"
|
||||
sed -e "s/ABITS = ./ABITS = $abits/g; s/DBITS = ./DBITS = $dbits/g;" < test_bram.v > ${id}.v
|
||||
sed -e "s/ABITS = ./ABITS = $abits/g; s/DBITS = ./DBITS = $dbits/g;" < test_bram_tb.v > ${id}_tb.v
|
||||
if [ $((RANDOM % 2)) -eq 0 ]; then
|
||||
iadr=0
|
||||
idat=0
|
||||
else
|
||||
iadr=$((RANDOM % (1 << abits)))
|
||||
idat=$((RANDOM % (1 << dbits)))
|
||||
fi
|
||||
sed -re "s/(ABITS = )0/\1$abits/g; s/(DBITS = )0/\1$dbits/g; s/(INIT_ADDR = )0/\1$iadr/g; s/(INIT_DATA = )0/\1$idat/g;" < test_bram.v > ${id}.v
|
||||
sed -re "s/(ABITS = )0/\1$abits/g; s/(DBITS = )0/\1$dbits/g; s/(INIT_ADDR = )0/\1$iadr/g; s/(INIT_DATA = )0/\1$idat/g;" < test_bram_tb.v > ${id}_tb.v
|
||||
../../../yosys -ql ${id}_syn.log -p "synth_ice40" -o ${id}_syn.v ${id}.v
|
||||
# iverilog -s bram_tb -o ${id}_tb ${id}_syn.v ${id}_tb.v /opt/lscc/iCEcube2.2014.08/verilog/sb_ice_syn.v
|
||||
iverilog -s bram_tb -o ${id}_tb ${id}_syn.v ${id}_tb.v ../cells_sim.v
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
module bram #(
|
||||
parameter ABITS = 8, DBITS = 8
|
||||
parameter ABITS = 8, DBITS = 8,
|
||||
parameter INIT_ADDR = 0, INIT_DATA = 0
|
||||
) (
|
||||
input clk,
|
||||
|
||||
|
@ -12,6 +13,11 @@ module bram #(
|
|||
);
|
||||
reg [DBITS-1:0] memory [0:2**ABITS-1];
|
||||
|
||||
initial begin
|
||||
if (INIT_ADDR || INIT_DATA)
|
||||
memory[INIT_ADDR] <= INIT_DATA;
|
||||
end
|
||||
|
||||
always @(posedge clk) begin
|
||||
if (WR_EN) memory[WR_ADDR] <= WR_DATA;
|
||||
RD_DATA <= memory[RD_ADDR];
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
module bram_tb #(
|
||||
parameter ABITS = 8, DBITS = 8
|
||||
parameter ABITS = 8, DBITS = 8,
|
||||
parameter INIT_ADDR = 0, INIT_DATA = 0
|
||||
);
|
||||
reg clk;
|
||||
reg [ABITS-1:0] WR_ADDR;
|
||||
|
@ -63,6 +64,9 @@ module bram_tb #(
|
|||
// $dumpfile("testbench.vcd");
|
||||
// $dumpvars(0, bram_tb);
|
||||
|
||||
if (INIT_ADDR || INIT_DATA)
|
||||
memory[INIT_ADDR] <= INIT_DATA;
|
||||
|
||||
xorshift64_next;
|
||||
xorshift64_next;
|
||||
xorshift64_next;
|
||||
|
@ -85,7 +89,7 @@ module bram_tb #(
|
|||
WR_ADDR = getaddr(i < 256 ? i[7:4] : xorshift64_state[63:60]);
|
||||
xorshift64_next;
|
||||
|
||||
RD_ADDR = getaddr(i < 256 ? i[3:0] : xorshift64_state[59:56]);
|
||||
RD_ADDR = i == 0 ? INIT_ADDR : getaddr(i < 256 ? i[3:0] : xorshift64_state[59:56]);
|
||||
WR_EN = xorshift64_state[55] && ((WR_ADDR & 'hff) != (RD_ADDR & 'hff));
|
||||
xorshift64_next;
|
||||
|
||||
|
|
Loading…
Reference in New Issue