From 7513bfcbfe73f5ef99ab416d10d58f5395edab88 Mon Sep 17 00:00:00 2001 From: Krystine Sherwin <93062060+KrystalDelusion@users.noreply.github.com> Date: Thu, 30 Nov 2023 09:16:12 +1300 Subject: [PATCH] quicklogic: fix double width read --- tests/arch/common/blockram.v | 41 +++++++++++-------- .../quicklogic/qlf_k6n10f/gen_memories.py | 2 +- 2 files changed, 25 insertions(+), 18 deletions(-) diff --git a/tests/arch/common/blockram.v b/tests/arch/common/blockram.v index c37074382..43a6864d2 100644 --- a/tests/arch/common/blockram.v +++ b/tests/arch/common/blockram.v @@ -71,27 +71,34 @@ endmodule // sync_ram_sdp_wwr module sync_ram_sdp_wrr #(parameter DATA_WIDTH=8, ADDRESS_WIDTH=10) // rd=16, ra=9 - (input wire clk, write_enable, - input wire [DATA_WIDTH-1:0] data_in, - input wire [ADDRESS_WIDTH-1:0] address_in_w, - input wire [ADDRESS_WIDTH-2:0] address_in_r, - output wire [(DATA_WIDTH*1)-1:0] data_out); +( + input wire clk_w, clk_r, write_enable, + input wire [DATA_WIDTH-1:0] data_in, + input wire [ADDRESS_WIDTH-1:0] address_in_w, + input wire [ADDRESS_WIDTH_R-1:0] address_in_r, + output wire [WORD-1:0] data_out +); + localparam ADDRESS_WIDTH_R = ADDRESS_WIDTH-1; + localparam HWORD = DATA_WIDTH; + localparam WORD = 2*DATA_WIDTH; + localparam DEPTH = 2**ADDRESS_WIDTH_R; - localparam WORD = (DATA_WIDTH-1); - localparam DEPTH = (2**ADDRESS_WIDTH-1); + reg [WORD-1:0] data_out_r; + reg [WORD-1:0] memory [0:DEPTH-1]; - reg [WORD:0] data_out_r0; - reg [WORD:0] data_out_r1; - reg [WORD:0] memory [0:DEPTH]; + always @(posedge clk_w) begin + if (write_enable) + if (address_in_w[0]) // upper HWORD + memory[address_in_w>>1][WORD-1:HWORD] <= data_in; + else // lower HWORD + memory[address_in_w>>1][HWORD-1:0] <= data_in; + end - always @(posedge clk) begin - if (write_enable) - memory[address_in_w] <= data_in; - data_out_r0 <= memory[address_in_r<<1+0]; - data_out_r1 <= memory[address_in_r<<1+1]; - end + always @(posedge clk_r) begin + data_out_r <= memory[address_in_r]; + end - assign data_out = {data_out_r0, data_out_r1}; + assign data_out = data_out_r; endmodule // sync_ram_sdp_wrr diff --git a/tests/arch/quicklogic/qlf_k6n10f/gen_memories.py b/tests/arch/quicklogic/qlf_k6n10f/gen_memories.py index 54f29125b..e4becb77d 100644 --- a/tests/arch/quicklogic/qlf_k6n10f/gen_memories.py +++ b/tests/arch/quicklogic/qlf_k6n10f/gen_memories.py @@ -36,7 +36,7 @@ blockram_tests: "list[tuple[list[tuple[str, int]], str, list[str]]]" = [ ([("ADDRESS_WIDTH", 11), ("DATA_WIDTH", 9)], "sync_ram_sdp_wwr", ["-assert-count 1 t:TDP36K"]), # 2x read width (1024x36bit read / 2048x18bit write = 1TDP36K) ([("ADDRESS_WIDTH", 11), ("DATA_WIDTH", 18)], "sync_ram_sdp_wrr", ["-assert-count 1 t:TDP36K"]), - ([("ADDRESS_WIDTH", 10), ("DATA_WIDTH", 36)], "sync_ram_sdp_wrr", ["-assert-count 1 t:TDP36K"]), + ([("ADDRESS_WIDTH", 12), ("DATA_WIDTH", 9)], "sync_ram_sdp_wrr", ["-assert-count 1 t:TDP36K"]), # two disjoint 18K memories can share a single TDP36K ([("ADDRESS_WIDTH_A", 10), ("DATA_WIDTH_A", 18),