|
|
@ -1,5 +1,5 @@
|
|
|
|
//--------------------------------------------------------------------------------
|
|
|
|
//--------------------------------------------------------------------------------
|
|
|
|
// Auto-generated by Migen (3ffd64c) & LiteX (b55af215) on 2021-04-22 14:46:05
|
|
|
|
// Auto-generated by Migen (35203d6) & LiteX (79ac0931) on 2021-08-10 08:40:47
|
|
|
|
//--------------------------------------------------------------------------------
|
|
|
|
//--------------------------------------------------------------------------------
|
|
|
|
module litesdcard_core(
|
|
|
|
module litesdcard_core(
|
|
|
|
input wire clk,
|
|
|
|
input wire clk,
|
|
|
@ -37,14 +37,15 @@ wire sys_clk;
|
|
|
|
wire sys_rst;
|
|
|
|
wire sys_rst;
|
|
|
|
wire por_clk;
|
|
|
|
wire por_clk;
|
|
|
|
reg int_rst = 1'd1;
|
|
|
|
reg int_rst = 1'd1;
|
|
|
|
reg reset_storage = 1'd0;
|
|
|
|
reg soc_rst = 1'd0;
|
|
|
|
|
|
|
|
wire cpu_rst;
|
|
|
|
|
|
|
|
reg [1:0] reset_storage = 2'd0;
|
|
|
|
reg reset_re = 1'd0;
|
|
|
|
reg reset_re = 1'd0;
|
|
|
|
reg [31:0] scratch_storage = 32'd305419896;
|
|
|
|
reg [31:0] scratch_storage = 32'd305419896;
|
|
|
|
reg scratch_re = 1'd0;
|
|
|
|
reg scratch_re = 1'd0;
|
|
|
|
wire [31:0] bus_errors_status;
|
|
|
|
wire [31:0] bus_errors_status;
|
|
|
|
wire bus_errors_we;
|
|
|
|
wire bus_errors_we;
|
|
|
|
reg bus_errors_re = 1'd0;
|
|
|
|
reg bus_errors_re = 1'd0;
|
|
|
|
wire reset;
|
|
|
|
|
|
|
|
reg bus_error = 1'd0;
|
|
|
|
reg bus_error = 1'd0;
|
|
|
|
reg [31:0] bus_errors = 32'd0;
|
|
|
|
reg [31:0] bus_errors = 32'd0;
|
|
|
|
wire [29:0] wb_ctrl_adr_1;
|
|
|
|
wire [29:0] wb_ctrl_adr_1;
|
|
|
@ -573,13 +574,15 @@ wire sdblock2mem_fifo_source_ready;
|
|
|
|
wire sdblock2mem_fifo_source_first;
|
|
|
|
wire sdblock2mem_fifo_source_first;
|
|
|
|
wire sdblock2mem_fifo_source_last;
|
|
|
|
wire sdblock2mem_fifo_source_last;
|
|
|
|
wire [7:0] sdblock2mem_fifo_source_payload_data;
|
|
|
|
wire [7:0] sdblock2mem_fifo_source_payload_data;
|
|
|
|
|
|
|
|
wire sdblock2mem_fifo_re;
|
|
|
|
|
|
|
|
reg sdblock2mem_fifo_readable = 1'd0;
|
|
|
|
wire sdblock2mem_fifo_syncfifo_we;
|
|
|
|
wire sdblock2mem_fifo_syncfifo_we;
|
|
|
|
wire sdblock2mem_fifo_syncfifo_writable;
|
|
|
|
wire sdblock2mem_fifo_syncfifo_writable;
|
|
|
|
wire sdblock2mem_fifo_syncfifo_re;
|
|
|
|
wire sdblock2mem_fifo_syncfifo_re;
|
|
|
|
wire sdblock2mem_fifo_syncfifo_readable;
|
|
|
|
wire sdblock2mem_fifo_syncfifo_readable;
|
|
|
|
wire [9:0] sdblock2mem_fifo_syncfifo_din;
|
|
|
|
wire [9:0] sdblock2mem_fifo_syncfifo_din;
|
|
|
|
wire [9:0] sdblock2mem_fifo_syncfifo_dout;
|
|
|
|
wire [9:0] sdblock2mem_fifo_syncfifo_dout;
|
|
|
|
reg [9:0] sdblock2mem_fifo_level = 10'd0;
|
|
|
|
reg [9:0] sdblock2mem_fifo_level0 = 10'd0;
|
|
|
|
reg sdblock2mem_fifo_replace = 1'd0;
|
|
|
|
reg sdblock2mem_fifo_replace = 1'd0;
|
|
|
|
reg [8:0] sdblock2mem_fifo_produce = 9'd0;
|
|
|
|
reg [8:0] sdblock2mem_fifo_produce = 9'd0;
|
|
|
|
reg [8:0] sdblock2mem_fifo_consume = 9'd0;
|
|
|
|
reg [8:0] sdblock2mem_fifo_consume = 9'd0;
|
|
|
@ -590,6 +593,8 @@ wire [9:0] sdblock2mem_fifo_wrport_dat_w;
|
|
|
|
wire sdblock2mem_fifo_do_read;
|
|
|
|
wire sdblock2mem_fifo_do_read;
|
|
|
|
wire [8:0] sdblock2mem_fifo_rdport_adr;
|
|
|
|
wire [8:0] sdblock2mem_fifo_rdport_adr;
|
|
|
|
wire [9:0] sdblock2mem_fifo_rdport_dat_r;
|
|
|
|
wire [9:0] sdblock2mem_fifo_rdport_dat_r;
|
|
|
|
|
|
|
|
wire sdblock2mem_fifo_rdport_re;
|
|
|
|
|
|
|
|
wire [9:0] sdblock2mem_fifo_level1;
|
|
|
|
wire [7:0] sdblock2mem_fifo_fifo_in_payload_data;
|
|
|
|
wire [7:0] sdblock2mem_fifo_fifo_in_payload_data;
|
|
|
|
wire sdblock2mem_fifo_fifo_in_first;
|
|
|
|
wire sdblock2mem_fifo_fifo_in_first;
|
|
|
|
wire sdblock2mem_fifo_fifo_in_last;
|
|
|
|
wire sdblock2mem_fifo_fifo_in_last;
|
|
|
@ -720,13 +725,15 @@ wire sdmem2block_fifo_source_ready;
|
|
|
|
wire sdmem2block_fifo_source_first;
|
|
|
|
wire sdmem2block_fifo_source_first;
|
|
|
|
wire sdmem2block_fifo_source_last;
|
|
|
|
wire sdmem2block_fifo_source_last;
|
|
|
|
wire [7:0] sdmem2block_fifo_source_payload_data;
|
|
|
|
wire [7:0] sdmem2block_fifo_source_payload_data;
|
|
|
|
|
|
|
|
wire sdmem2block_fifo_re;
|
|
|
|
|
|
|
|
reg sdmem2block_fifo_readable = 1'd0;
|
|
|
|
wire sdmem2block_fifo_syncfifo_we;
|
|
|
|
wire sdmem2block_fifo_syncfifo_we;
|
|
|
|
wire sdmem2block_fifo_syncfifo_writable;
|
|
|
|
wire sdmem2block_fifo_syncfifo_writable;
|
|
|
|
wire sdmem2block_fifo_syncfifo_re;
|
|
|
|
wire sdmem2block_fifo_syncfifo_re;
|
|
|
|
wire sdmem2block_fifo_syncfifo_readable;
|
|
|
|
wire sdmem2block_fifo_syncfifo_readable;
|
|
|
|
wire [9:0] sdmem2block_fifo_syncfifo_din;
|
|
|
|
wire [9:0] sdmem2block_fifo_syncfifo_din;
|
|
|
|
wire [9:0] sdmem2block_fifo_syncfifo_dout;
|
|
|
|
wire [9:0] sdmem2block_fifo_syncfifo_dout;
|
|
|
|
reg [9:0] sdmem2block_fifo_level = 10'd0;
|
|
|
|
reg [9:0] sdmem2block_fifo_level0 = 10'd0;
|
|
|
|
reg sdmem2block_fifo_replace = 1'd0;
|
|
|
|
reg sdmem2block_fifo_replace = 1'd0;
|
|
|
|
reg [8:0] sdmem2block_fifo_produce = 9'd0;
|
|
|
|
reg [8:0] sdmem2block_fifo_produce = 9'd0;
|
|
|
|
reg [8:0] sdmem2block_fifo_consume = 9'd0;
|
|
|
|
reg [8:0] sdmem2block_fifo_consume = 9'd0;
|
|
|
@ -737,6 +744,8 @@ wire [9:0] sdmem2block_fifo_wrport_dat_w;
|
|
|
|
wire sdmem2block_fifo_do_read;
|
|
|
|
wire sdmem2block_fifo_do_read;
|
|
|
|
wire [8:0] sdmem2block_fifo_rdport_adr;
|
|
|
|
wire [8:0] sdmem2block_fifo_rdport_adr;
|
|
|
|
wire [9:0] sdmem2block_fifo_rdport_dat_r;
|
|
|
|
wire [9:0] sdmem2block_fifo_rdport_dat_r;
|
|
|
|
|
|
|
|
wire sdmem2block_fifo_rdport_re;
|
|
|
|
|
|
|
|
wire [9:0] sdmem2block_fifo_level1;
|
|
|
|
wire [7:0] sdmem2block_fifo_fifo_in_payload_data;
|
|
|
|
wire [7:0] sdmem2block_fifo_fifo_in_payload_data;
|
|
|
|
wire sdmem2block_fifo_fifo_in_first;
|
|
|
|
wire sdmem2block_fifo_fifo_in_first;
|
|
|
|
wire sdmem2block_fifo_fifo_in_last;
|
|
|
|
wire sdmem2block_fifo_fifo_in_last;
|
|
|
@ -894,9 +903,9 @@ wire litesdcardcore_interface0_bank_bus_we;
|
|
|
|
wire [31:0] litesdcardcore_interface0_bank_bus_dat_w;
|
|
|
|
wire [31:0] litesdcardcore_interface0_bank_bus_dat_w;
|
|
|
|
reg [31:0] litesdcardcore_interface0_bank_bus_dat_r = 32'd0;
|
|
|
|
reg [31:0] litesdcardcore_interface0_bank_bus_dat_r = 32'd0;
|
|
|
|
reg litesdcardcore_csrbank0_reset0_re = 1'd0;
|
|
|
|
reg litesdcardcore_csrbank0_reset0_re = 1'd0;
|
|
|
|
wire litesdcardcore_csrbank0_reset0_r;
|
|
|
|
wire [1:0] litesdcardcore_csrbank0_reset0_r;
|
|
|
|
reg litesdcardcore_csrbank0_reset0_we = 1'd0;
|
|
|
|
reg litesdcardcore_csrbank0_reset0_we = 1'd0;
|
|
|
|
wire litesdcardcore_csrbank0_reset0_w;
|
|
|
|
wire [1:0] litesdcardcore_csrbank0_reset0_w;
|
|
|
|
reg litesdcardcore_csrbank0_scratch0_re = 1'd0;
|
|
|
|
reg litesdcardcore_csrbank0_scratch0_re = 1'd0;
|
|
|
|
wire [31:0] litesdcardcore_csrbank0_scratch0_r;
|
|
|
|
wire [31:0] litesdcardcore_csrbank0_scratch0_r;
|
|
|
|
reg litesdcardcore_csrbank0_scratch0_we = 1'd0;
|
|
|
|
reg litesdcardcore_csrbank0_scratch0_we = 1'd0;
|
|
|
@ -1133,15 +1142,14 @@ assign sdmem2block_source_source_ready0 = sdcore_sink_sink_ready0;
|
|
|
|
assign sdcore_sink_sink_first0 = sdmem2block_source_source_first0;
|
|
|
|
assign sdcore_sink_sink_first0 = sdmem2block_source_source_first0;
|
|
|
|
assign sdcore_sink_sink_last0 = sdmem2block_source_source_last0;
|
|
|
|
assign sdcore_sink_sink_last0 = sdmem2block_source_source_last0;
|
|
|
|
assign sdcore_sink_sink_payload_data0 = sdmem2block_source_source_payload_data0;
|
|
|
|
assign sdcore_sink_sink_payload_data0 = sdmem2block_source_source_payload_data0;
|
|
|
|
assign card_detect_trigger = card_detect_irq;
|
|
|
|
|
|
|
|
assign block2mem_dma_trigger = sdblock2mem_irq;
|
|
|
|
assign block2mem_dma_trigger = sdblock2mem_irq;
|
|
|
|
assign mem2block_dma_trigger = sdmem2block_irq;
|
|
|
|
assign mem2block_dma_trigger = sdmem2block_irq;
|
|
|
|
|
|
|
|
assign card_detect_trigger = card_detect_irq;
|
|
|
|
assign cmd_done_trigger = sdcore_csrfield_done0;
|
|
|
|
assign cmd_done_trigger = sdcore_csrfield_done0;
|
|
|
|
assign irq = sdirq_irq;
|
|
|
|
assign irq = sdirq_irq;
|
|
|
|
assign sys_clk = clk;
|
|
|
|
assign sys_clk = clk;
|
|
|
|
assign por_clk = clk;
|
|
|
|
assign por_clk = clk;
|
|
|
|
assign sys_rst = int_rst;
|
|
|
|
assign sys_rst = int_rst;
|
|
|
|
assign reset = reset_re;
|
|
|
|
|
|
|
|
assign bus_errors_status = bus_errors;
|
|
|
|
assign bus_errors_status = bus_errors;
|
|
|
|
assign card_detect_status0 = sdcard_cd;
|
|
|
|
assign card_detect_status0 = sdcard_cd;
|
|
|
|
assign sdpads_clk = ((((init_pads_out_payload_clk | cmdw_pads_out_payload_clk) | cmdr_pads_out_payload_clk) | dataw_pads_out_payload_clk) | datar_pads_out_payload_clk);
|
|
|
|
assign sdpads_clk = ((((init_pads_out_payload_clk | cmdw_pads_out_payload_clk) | cmdr_pads_out_payload_clk) | dataw_pads_out_payload_clk) | datar_pads_out_payload_clk);
|
|
|
@ -1211,13 +1219,13 @@ always @(*) begin
|
|
|
|
end
|
|
|
|
end
|
|
|
|
assign clocker_clk0 = ((~clocker_clk1) & clocker_ce_latched);
|
|
|
|
assign clocker_clk0 = ((~clocker_clk1) & clocker_ce_latched);
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
|
subfragments_sdphyinit_next_state <= 1'd0;
|
|
|
|
|
|
|
|
init_count_sdphyinit_next_value <= 8'd0;
|
|
|
|
|
|
|
|
init_count_sdphyinit_next_value_ce <= 1'd0;
|
|
|
|
|
|
|
|
init_pads_out_payload_clk <= 1'd0;
|
|
|
|
init_pads_out_payload_clk <= 1'd0;
|
|
|
|
init_pads_out_payload_cmd_o <= 1'd0;
|
|
|
|
init_pads_out_payload_cmd_o <= 1'd0;
|
|
|
|
init_pads_out_payload_cmd_oe <= 1'd0;
|
|
|
|
init_pads_out_payload_cmd_oe <= 1'd0;
|
|
|
|
|
|
|
|
subfragments_sdphyinit_next_state <= 1'd0;
|
|
|
|
|
|
|
|
init_count_sdphyinit_next_value <= 8'd0;
|
|
|
|
init_pads_out_payload_data_o <= 4'd0;
|
|
|
|
init_pads_out_payload_data_o <= 4'd0;
|
|
|
|
|
|
|
|
init_count_sdphyinit_next_value_ce <= 1'd0;
|
|
|
|
init_pads_out_payload_data_oe <= 1'd0;
|
|
|
|
init_pads_out_payload_data_oe <= 1'd0;
|
|
|
|
subfragments_sdphyinit_next_state <= subfragments_sdphyinit_state;
|
|
|
|
subfragments_sdphyinit_next_state <= subfragments_sdphyinit_state;
|
|
|
|
case (subfragments_sdphyinit_state)
|
|
|
|
case (subfragments_sdphyinit_state)
|
|
|
@ -1246,13 +1254,13 @@ always @(*) begin
|
|
|
|
end
|
|
|
|
end
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
|
cmdw_done <= 1'd0;
|
|
|
|
cmdw_done <= 1'd0;
|
|
|
|
|
|
|
|
subfragments_sdphycmdw_next_state <= 2'd0;
|
|
|
|
cmdw_pads_out_payload_clk <= 1'd0;
|
|
|
|
cmdw_pads_out_payload_clk <= 1'd0;
|
|
|
|
|
|
|
|
cmdw_count_sdphycmdw_next_value <= 8'd0;
|
|
|
|
|
|
|
|
cmdw_count_sdphycmdw_next_value_ce <= 1'd0;
|
|
|
|
cmdw_pads_out_payload_cmd_o <= 1'd0;
|
|
|
|
cmdw_pads_out_payload_cmd_o <= 1'd0;
|
|
|
|
cmdw_pads_out_payload_cmd_oe <= 1'd0;
|
|
|
|
cmdw_pads_out_payload_cmd_oe <= 1'd0;
|
|
|
|
cmdw_sink_ready <= 1'd0;
|
|
|
|
cmdw_sink_ready <= 1'd0;
|
|
|
|
subfragments_sdphycmdw_next_state <= 2'd0;
|
|
|
|
|
|
|
|
cmdw_count_sdphycmdw_next_value <= 8'd0;
|
|
|
|
|
|
|
|
cmdw_count_sdphycmdw_next_value_ce <= 1'd0;
|
|
|
|
|
|
|
|
subfragments_sdphycmdw_next_state <= subfragments_sdphycmdw_state;
|
|
|
|
subfragments_sdphycmdw_next_state <= subfragments_sdphycmdw_state;
|
|
|
|
case (subfragments_sdphycmdw_state)
|
|
|
|
case (subfragments_sdphycmdw_state)
|
|
|
|
1'd1: begin
|
|
|
|
1'd1: begin
|
|
|
@ -1356,24 +1364,24 @@ assign cmdr_cmdr_converter_source_valid = cmdr_cmdr_converter_strobe_all;
|
|
|
|
assign cmdr_cmdr_converter_load_part = (cmdr_cmdr_converter_sink_valid & cmdr_cmdr_converter_sink_ready);
|
|
|
|
assign cmdr_cmdr_converter_load_part = (cmdr_cmdr_converter_sink_valid & cmdr_cmdr_converter_sink_ready);
|
|
|
|
assign cmdr_cmdr_buf_sink_ready = ((~cmdr_cmdr_buf_source_valid) | cmdr_cmdr_buf_source_ready);
|
|
|
|
assign cmdr_cmdr_buf_sink_ready = ((~cmdr_cmdr_buf_source_valid) | cmdr_cmdr_buf_source_ready);
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
|
cmdr_pads_out_payload_clk <= 1'd0;
|
|
|
|
|
|
|
|
cmdr_pads_out_payload_cmd_o <= 1'd0;
|
|
|
|
|
|
|
|
cmdr_pads_out_payload_cmd_oe <= 1'd0;
|
|
|
|
|
|
|
|
cmdr_cmdr_source_source_ready0 <= 1'd0;
|
|
|
|
|
|
|
|
subfragments_sdphycmdr_next_state <= 3'd0;
|
|
|
|
subfragments_sdphycmdr_next_state <= 3'd0;
|
|
|
|
cmdr_sink_ready <= 1'd0;
|
|
|
|
|
|
|
|
cmdr_timeout_sdphycmdr_next_value0 <= 32'd0;
|
|
|
|
cmdr_timeout_sdphycmdr_next_value0 <= 32'd0;
|
|
|
|
|
|
|
|
cmdr_pads_out_payload_clk <= 1'd0;
|
|
|
|
cmdr_timeout_sdphycmdr_next_value_ce0 <= 1'd0;
|
|
|
|
cmdr_timeout_sdphycmdr_next_value_ce0 <= 1'd0;
|
|
|
|
|
|
|
|
cmdr_pads_out_payload_cmd_o <= 1'd0;
|
|
|
|
cmdr_count_sdphycmdr_next_value1 <= 8'd0;
|
|
|
|
cmdr_count_sdphycmdr_next_value1 <= 8'd0;
|
|
|
|
|
|
|
|
cmdr_pads_out_payload_cmd_oe <= 1'd0;
|
|
|
|
cmdr_count_sdphycmdr_next_value_ce1 <= 1'd0;
|
|
|
|
cmdr_count_sdphycmdr_next_value_ce1 <= 1'd0;
|
|
|
|
cmdr_source_valid <= 1'd0;
|
|
|
|
cmdr_cmdr_source_source_ready0 <= 1'd0;
|
|
|
|
cmdr_busy_sdphycmdr_next_value2 <= 1'd0;
|
|
|
|
cmdr_busy_sdphycmdr_next_value2 <= 1'd0;
|
|
|
|
cmdr_busy_sdphycmdr_next_value_ce2 <= 1'd0;
|
|
|
|
cmdr_busy_sdphycmdr_next_value_ce2 <= 1'd0;
|
|
|
|
|
|
|
|
cmdr_sink_ready <= 1'd0;
|
|
|
|
|
|
|
|
cmdr_cmdr_reset_sdphycmdr_next_value3 <= 1'd0;
|
|
|
|
|
|
|
|
cmdr_cmdr_reset_sdphycmdr_next_value_ce3 <= 1'd0;
|
|
|
|
|
|
|
|
cmdr_source_valid <= 1'd0;
|
|
|
|
cmdr_source_last <= 1'd0;
|
|
|
|
cmdr_source_last <= 1'd0;
|
|
|
|
cmdr_source_payload_data <= 8'd0;
|
|
|
|
cmdr_source_payload_data <= 8'd0;
|
|
|
|
cmdr_cmdr_reset_sdphycmdr_next_value3 <= 1'd0;
|
|
|
|
|
|
|
|
cmdr_source_payload_status <= 3'd0;
|
|
|
|
cmdr_source_payload_status <= 3'd0;
|
|
|
|
cmdr_cmdr_reset_sdphycmdr_next_value_ce3 <= 1'd0;
|
|
|
|
|
|
|
|
subfragments_sdphycmdr_next_state <= subfragments_sdphycmdr_state;
|
|
|
|
subfragments_sdphycmdr_next_state <= subfragments_sdphycmdr_state;
|
|
|
|
case (subfragments_sdphycmdr_state)
|
|
|
|
case (subfragments_sdphycmdr_state)
|
|
|
|
1'd1: begin
|
|
|
|
1'd1: begin
|
|
|
@ -1519,23 +1527,23 @@ assign dataw_crc_converter_source_valid = dataw_crc_converter_strobe_all;
|
|
|
|
assign dataw_crc_converter_load_part = (dataw_crc_converter_sink_valid & dataw_crc_converter_sink_ready);
|
|
|
|
assign dataw_crc_converter_load_part = (dataw_crc_converter_sink_valid & dataw_crc_converter_sink_ready);
|
|
|
|
assign dataw_crc_buf_sink_ready = ((~dataw_crc_buf_source_valid) | dataw_crc_buf_source_ready);
|
|
|
|
assign dataw_crc_buf_sink_ready = ((~dataw_crc_buf_source_valid) | dataw_crc_buf_source_ready);
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
|
dataw_count_sdphydataw_next_value_ce3 <= 1'd0;
|
|
|
|
|
|
|
|
dataw_pads_out_payload_clk <= 1'd0;
|
|
|
|
|
|
|
|
dataw_crc_reset <= 1'd0;
|
|
|
|
|
|
|
|
dataw_pads_out_payload_cmd_o <= 1'd0;
|
|
|
|
|
|
|
|
dataw_pads_out_payload_cmd_oe <= 1'd0;
|
|
|
|
|
|
|
|
dataw_pads_out_payload_data_o <= 4'd0;
|
|
|
|
|
|
|
|
dataw_pads_out_payload_data_oe <= 1'd0;
|
|
|
|
|
|
|
|
subfragments_sdphydataw_next_state <= 3'd0;
|
|
|
|
subfragments_sdphydataw_next_state <= 3'd0;
|
|
|
|
dataw_accepted1_sdphydataw_next_value0 <= 1'd0;
|
|
|
|
dataw_accepted1_sdphydataw_next_value0 <= 1'd0;
|
|
|
|
dataw_sink_ready <= 1'd0;
|
|
|
|
|
|
|
|
dataw_accepted1_sdphydataw_next_value_ce0 <= 1'd0;
|
|
|
|
dataw_accepted1_sdphydataw_next_value_ce0 <= 1'd0;
|
|
|
|
|
|
|
|
dataw_pads_out_payload_clk <= 1'd0;
|
|
|
|
|
|
|
|
dataw_crc_reset <= 1'd0;
|
|
|
|
dataw_crc_error1_sdphydataw_next_value1 <= 1'd0;
|
|
|
|
dataw_crc_error1_sdphydataw_next_value1 <= 1'd0;
|
|
|
|
|
|
|
|
dataw_pads_out_payload_cmd_o <= 1'd0;
|
|
|
|
dataw_crc_error1_sdphydataw_next_value_ce1 <= 1'd0;
|
|
|
|
dataw_crc_error1_sdphydataw_next_value_ce1 <= 1'd0;
|
|
|
|
dataw_stop <= 1'd0;
|
|
|
|
dataw_pads_out_payload_cmd_oe <= 1'd0;
|
|
|
|
dataw_write_error1_sdphydataw_next_value2 <= 1'd0;
|
|
|
|
dataw_write_error1_sdphydataw_next_value2 <= 1'd0;
|
|
|
|
|
|
|
|
dataw_pads_out_payload_data_o <= 4'd0;
|
|
|
|
dataw_write_error1_sdphydataw_next_value_ce2 <= 1'd0;
|
|
|
|
dataw_write_error1_sdphydataw_next_value_ce2 <= 1'd0;
|
|
|
|
|
|
|
|
dataw_pads_out_payload_data_oe <= 1'd0;
|
|
|
|
dataw_count_sdphydataw_next_value3 <= 8'd0;
|
|
|
|
dataw_count_sdphydataw_next_value3 <= 8'd0;
|
|
|
|
|
|
|
|
dataw_count_sdphydataw_next_value_ce3 <= 1'd0;
|
|
|
|
|
|
|
|
dataw_sink_ready <= 1'd0;
|
|
|
|
|
|
|
|
dataw_stop <= 1'd0;
|
|
|
|
subfragments_sdphydataw_next_state <= subfragments_sdphydataw_state;
|
|
|
|
subfragments_sdphydataw_next_state <= subfragments_sdphydataw_state;
|
|
|
|
case (subfragments_sdphydataw_state)
|
|
|
|
case (subfragments_sdphydataw_state)
|
|
|
|
1'd1: begin
|
|
|
|
1'd1: begin
|
|
|
@ -1670,16 +1678,16 @@ always @(*) begin
|
|
|
|
datar_source_payload_data <= 8'd0;
|
|
|
|
datar_source_payload_data <= 8'd0;
|
|
|
|
datar_source_payload_status <= 3'd0;
|
|
|
|
datar_source_payload_status <= 3'd0;
|
|
|
|
datar_stop <= 1'd0;
|
|
|
|
datar_stop <= 1'd0;
|
|
|
|
datar_pads_out_payload_clk <= 1'd0;
|
|
|
|
|
|
|
|
subfragments_sdphydatar_next_state <= 3'd0;
|
|
|
|
subfragments_sdphydatar_next_state <= 3'd0;
|
|
|
|
datar_count_sdphydatar_next_value0 <= 10'd0;
|
|
|
|
datar_count_sdphydatar_next_value0 <= 10'd0;
|
|
|
|
datar_count_sdphydatar_next_value_ce0 <= 1'd0;
|
|
|
|
datar_count_sdphydatar_next_value_ce0 <= 1'd0;
|
|
|
|
datar_datar_source_source_ready0 <= 1'd0;
|
|
|
|
|
|
|
|
datar_timeout_sdphydatar_next_value1 <= 32'd0;
|
|
|
|
datar_timeout_sdphydatar_next_value1 <= 32'd0;
|
|
|
|
datar_timeout_sdphydatar_next_value_ce1 <= 1'd0;
|
|
|
|
datar_timeout_sdphydatar_next_value_ce1 <= 1'd0;
|
|
|
|
datar_datar_reset_sdphydatar_next_value2 <= 1'd0;
|
|
|
|
datar_datar_reset_sdphydatar_next_value2 <= 1'd0;
|
|
|
|
datar_sink_ready <= 1'd0;
|
|
|
|
|
|
|
|
datar_datar_reset_sdphydatar_next_value_ce2 <= 1'd0;
|
|
|
|
datar_datar_reset_sdphydatar_next_value_ce2 <= 1'd0;
|
|
|
|
|
|
|
|
datar_pads_out_payload_clk <= 1'd0;
|
|
|
|
|
|
|
|
datar_datar_source_source_ready0 <= 1'd0;
|
|
|
|
|
|
|
|
datar_sink_ready <= 1'd0;
|
|
|
|
subfragments_sdphydatar_next_state <= subfragments_sdphydatar_state;
|
|
|
|
subfragments_sdphydatar_next_state <= subfragments_sdphydatar_state;
|
|
|
|
case (subfragments_sdphydatar_state)
|
|
|
|
case (subfragments_sdphydatar_state)
|
|
|
|
1'd1: begin
|
|
|
|
1'd1: begin
|
|
|
@ -1906,14 +1914,14 @@ always @(*) begin
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
|
subfragments_sdcore_crc16inserter_next_state <= 1'd0;
|
|
|
|
sdcore_crc16_inserter_sink_ready <= 1'd0;
|
|
|
|
sdcore_crc16_inserter_count_sdcore_crc16inserter_next_value <= 3'd0;
|
|
|
|
|
|
|
|
sdcore_crc16_inserter_count_sdcore_crc16inserter_next_value_ce <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_crc16_inserter_source_valid <= 1'd0;
|
|
|
|
sdcore_crc16_inserter_source_valid <= 1'd0;
|
|
|
|
sdcore_crc16_inserter_source_first <= 1'd0;
|
|
|
|
sdcore_crc16_inserter_source_first <= 1'd0;
|
|
|
|
sdcore_crc16_inserter_source_last <= 1'd0;
|
|
|
|
sdcore_crc16_inserter_source_last <= 1'd0;
|
|
|
|
sdcore_crc16_inserter_source_payload_data <= 8'd0;
|
|
|
|
sdcore_crc16_inserter_source_payload_data <= 8'd0;
|
|
|
|
sdcore_crc16_inserter_sink_ready <= 1'd0;
|
|
|
|
subfragments_sdcore_crc16inserter_next_state <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_crc16_inserter_count_sdcore_crc16inserter_next_value <= 3'd0;
|
|
|
|
|
|
|
|
sdcore_crc16_inserter_count_sdcore_crc16inserter_next_value_ce <= 1'd0;
|
|
|
|
subfragments_sdcore_crc16inserter_next_state <= subfragments_sdcore_crc16inserter_state;
|
|
|
|
subfragments_sdcore_crc16inserter_next_state <= subfragments_sdcore_crc16inserter_state;
|
|
|
|
case (subfragments_sdcore_crc16inserter_state)
|
|
|
|
case (subfragments_sdcore_crc16inserter_state)
|
|
|
|
1'd1: begin
|
|
|
|
1'd1: begin
|
|
|
@ -2064,47 +2072,47 @@ assign sdcore_fifo_syncfifo_dout = sdcore_fifo_rdport_dat_r;
|
|
|
|
assign sdcore_fifo_syncfifo_writable = (sdcore_fifo_level != 4'd8);
|
|
|
|
assign sdcore_fifo_syncfifo_writable = (sdcore_fifo_level != 4'd8);
|
|
|
|
assign sdcore_fifo_syncfifo_readable = (sdcore_fifo_level != 1'd0);
|
|
|
|
assign sdcore_fifo_syncfifo_readable = (sdcore_fifo_level != 1'd0);
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
|
sdcore_cmd_response_status_sdcore_fsm_next_value8 <= 128'd0;
|
|
|
|
sdcore_cmd_error_sdcore_fsm_next_value4 <= 1'd0;
|
|
|
|
sdcore_cmd_response_status_sdcore_fsm_next_value_ce8 <= 1'd0;
|
|
|
|
sdcore_cmd_error_sdcore_fsm_next_value_ce4 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_cmd_timeout_sdcore_fsm_next_value5 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_cmd_timeout_sdcore_fsm_next_value_ce5 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_data_error_sdcore_fsm_next_value6 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_data_error_sdcore_fsm_next_value_ce6 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_data_timeout_sdcore_fsm_next_value7 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_data_timeout_sdcore_fsm_next_value_ce7 <= 1'd0;
|
|
|
|
cmdr_sink_valid <= 1'd0;
|
|
|
|
cmdr_sink_valid <= 1'd0;
|
|
|
|
cmdr_sink_payload_cmd_type <= 2'd0;
|
|
|
|
cmdr_sink_payload_cmd_type <= 2'd0;
|
|
|
|
cmdr_sink_payload_data_type <= 2'd0;
|
|
|
|
cmdr_sink_payload_data_type <= 2'd0;
|
|
|
|
cmdr_sink_payload_length <= 8'd0;
|
|
|
|
cmdr_sink_payload_length <= 8'd0;
|
|
|
|
cmdr_source_ready <= 1'd0;
|
|
|
|
cmdr_source_ready <= 1'd0;
|
|
|
|
dataw_sink_valid <= 1'd0;
|
|
|
|
dataw_sink_valid <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_cmd_response_status_sdcore_fsm_next_value8 <= 128'd0;
|
|
|
|
|
|
|
|
sdcore_cmd_response_status_sdcore_fsm_next_value_ce8 <= 1'd0;
|
|
|
|
dataw_sink_first <= 1'd0;
|
|
|
|
dataw_sink_first <= 1'd0;
|
|
|
|
dataw_sink_last <= 1'd0;
|
|
|
|
dataw_sink_last <= 1'd0;
|
|
|
|
dataw_sink_payload_data <= 8'd0;
|
|
|
|
dataw_sink_payload_data <= 8'd0;
|
|
|
|
subfragments_sdcore_fsm_next_state <= 3'd0;
|
|
|
|
|
|
|
|
cmdw_sink_valid <= 1'd0;
|
|
|
|
cmdw_sink_valid <= 1'd0;
|
|
|
|
sdcore_cmd_done_sdcore_fsm_next_value0 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_cmd_done_sdcore_fsm_next_value_ce0 <= 1'd0;
|
|
|
|
|
|
|
|
datar_sink_valid <= 1'd0;
|
|
|
|
datar_sink_valid <= 1'd0;
|
|
|
|
cmdw_sink_last <= 1'd0;
|
|
|
|
cmdw_sink_last <= 1'd0;
|
|
|
|
sdcore_data_done_sdcore_fsm_next_value1 <= 1'd0;
|
|
|
|
datar_sink_last <= 1'd0;
|
|
|
|
sdcore_data_done_sdcore_fsm_next_value_ce1 <= 1'd0;
|
|
|
|
|
|
|
|
cmdw_sink_payload_data <= 8'd0;
|
|
|
|
cmdw_sink_payload_data <= 8'd0;
|
|
|
|
cmdw_sink_payload_cmd_type <= 2'd0;
|
|
|
|
|
|
|
|
datar_sink_payload_block_length <= 10'd0;
|
|
|
|
datar_sink_payload_block_length <= 10'd0;
|
|
|
|
sdcore_cmd_count_sdcore_fsm_next_value2 <= 3'd0;
|
|
|
|
cmdw_sink_payload_cmd_type <= 2'd0;
|
|
|
|
datar_source_ready <= 1'd0;
|
|
|
|
datar_source_ready <= 1'd0;
|
|
|
|
sdcore_cmd_count_sdcore_fsm_next_value_ce2 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_crc16_inserter_source_ready <= 1'd0;
|
|
|
|
sdcore_crc16_inserter_source_ready <= 1'd0;
|
|
|
|
sdcore_data_count_sdcore_fsm_next_value3 <= 32'd0;
|
|
|
|
|
|
|
|
sdcore_data_count_sdcore_fsm_next_value_ce3 <= 1'd0;
|
|
|
|
|
|
|
|
datar_sink_last <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_cmd_error_sdcore_fsm_next_value4 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_cmd_error_sdcore_fsm_next_value_ce4 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_cmd_timeout_sdcore_fsm_next_value5 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_cmd_timeout_sdcore_fsm_next_value_ce5 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_data_error_sdcore_fsm_next_value6 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_sink_sink_valid1 <= 1'd0;
|
|
|
|
sdcore_sink_sink_valid1 <= 1'd0;
|
|
|
|
sdcore_data_error_sdcore_fsm_next_value_ce6 <= 1'd0;
|
|
|
|
subfragments_sdcore_fsm_next_state <= 3'd0;
|
|
|
|
|
|
|
|
sdcore_cmd_done_sdcore_fsm_next_value0 <= 1'd0;
|
|
|
|
sdcore_sink_sink_first1 <= 1'd0;
|
|
|
|
sdcore_sink_sink_first1 <= 1'd0;
|
|
|
|
sdcore_data_timeout_sdcore_fsm_next_value7 <= 1'd0;
|
|
|
|
sdcore_cmd_done_sdcore_fsm_next_value_ce0 <= 1'd0;
|
|
|
|
sdcore_sink_sink_last1 <= 1'd0;
|
|
|
|
sdcore_sink_sink_last1 <= 1'd0;
|
|
|
|
sdcore_data_timeout_sdcore_fsm_next_value_ce7 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_sink_sink_payload_data1 <= 8'd0;
|
|
|
|
sdcore_sink_sink_payload_data1 <= 8'd0;
|
|
|
|
|
|
|
|
sdcore_data_done_sdcore_fsm_next_value1 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_data_done_sdcore_fsm_next_value_ce1 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_cmd_count_sdcore_fsm_next_value2 <= 3'd0;
|
|
|
|
|
|
|
|
sdcore_cmd_count_sdcore_fsm_next_value_ce2 <= 1'd0;
|
|
|
|
|
|
|
|
sdcore_data_count_sdcore_fsm_next_value3 <= 32'd0;
|
|
|
|
|
|
|
|
sdcore_data_count_sdcore_fsm_next_value_ce3 <= 1'd0;
|
|
|
|
subfragments_sdcore_fsm_next_state <= subfragments_sdcore_fsm_state;
|
|
|
|
subfragments_sdcore_fsm_next_state <= subfragments_sdcore_fsm_state;
|
|
|
|
case (subfragments_sdcore_fsm_state)
|
|
|
|
case (subfragments_sdcore_fsm_state)
|
|
|
|
1'd1: begin
|
|
|
|
1'd1: begin
|
|
|
@ -2255,10 +2263,10 @@ end
|
|
|
|
assign sdblock2mem_start = (sdblock2mem_sink_sink_valid0 & sdblock2mem_sink_sink_first);
|
|
|
|
assign sdblock2mem_start = (sdblock2mem_sink_sink_valid0 & sdblock2mem_sink_sink_first);
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
|
sdblock2mem_fifo_sink_last <= 1'd0;
|
|
|
|
sdblock2mem_fifo_sink_last <= 1'd0;
|
|
|
|
sdblock2mem_fifo_sink_valid <= 1'd0;
|
|
|
|
|
|
|
|
sdblock2mem_fifo_sink_first <= 1'd0;
|
|
|
|
|
|
|
|
sdblock2mem_sink_sink_ready0 <= 1'd0;
|
|
|
|
sdblock2mem_sink_sink_ready0 <= 1'd0;
|
|
|
|
sdblock2mem_fifo_sink_payload_data <= 8'd0;
|
|
|
|
sdblock2mem_fifo_sink_payload_data <= 8'd0;
|
|
|
|
|
|
|
|
sdblock2mem_fifo_sink_valid <= 1'd0;
|
|
|
|
|
|
|
|
sdblock2mem_fifo_sink_first <= 1'd0;
|
|
|
|
if ((sdblock2mem_wishbonedmawriter_enable_storage & (sdblock2mem_start | sdblock2mem_connect))) begin
|
|
|
|
if ((sdblock2mem_wishbonedmawriter_enable_storage & (sdblock2mem_start | sdblock2mem_connect))) begin
|
|
|
|
sdblock2mem_fifo_sink_valid <= sdblock2mem_sink_sink_valid0;
|
|
|
|
sdblock2mem_fifo_sink_valid <= sdblock2mem_sink_sink_valid0;
|
|
|
|
sdblock2mem_sink_sink_ready0 <= sdblock2mem_fifo_sink_ready;
|
|
|
|
sdblock2mem_sink_sink_ready0 <= sdblock2mem_fifo_sink_ready;
|
|
|
@ -2286,11 +2294,13 @@ assign sdblock2mem_fifo_syncfifo_we = sdblock2mem_fifo_sink_valid;
|
|
|
|
assign sdblock2mem_fifo_fifo_in_first = sdblock2mem_fifo_sink_first;
|
|
|
|
assign sdblock2mem_fifo_fifo_in_first = sdblock2mem_fifo_sink_first;
|
|
|
|
assign sdblock2mem_fifo_fifo_in_last = sdblock2mem_fifo_sink_last;
|
|
|
|
assign sdblock2mem_fifo_fifo_in_last = sdblock2mem_fifo_sink_last;
|
|
|
|
assign sdblock2mem_fifo_fifo_in_payload_data = sdblock2mem_fifo_sink_payload_data;
|
|
|
|
assign sdblock2mem_fifo_fifo_in_payload_data = sdblock2mem_fifo_sink_payload_data;
|
|
|
|
assign sdblock2mem_fifo_source_valid = sdblock2mem_fifo_syncfifo_readable;
|
|
|
|
assign sdblock2mem_fifo_source_valid = sdblock2mem_fifo_readable;
|
|
|
|
assign sdblock2mem_fifo_source_first = sdblock2mem_fifo_fifo_out_first;
|
|
|
|
assign sdblock2mem_fifo_source_first = sdblock2mem_fifo_fifo_out_first;
|
|
|
|
assign sdblock2mem_fifo_source_last = sdblock2mem_fifo_fifo_out_last;
|
|
|
|
assign sdblock2mem_fifo_source_last = sdblock2mem_fifo_fifo_out_last;
|
|
|
|
assign sdblock2mem_fifo_source_payload_data = sdblock2mem_fifo_fifo_out_payload_data;
|
|
|
|
assign sdblock2mem_fifo_source_payload_data = sdblock2mem_fifo_fifo_out_payload_data;
|
|
|
|
assign sdblock2mem_fifo_syncfifo_re = sdblock2mem_fifo_source_ready;
|
|
|
|
assign sdblock2mem_fifo_re = sdblock2mem_fifo_source_ready;
|
|
|
|
|
|
|
|
assign sdblock2mem_fifo_syncfifo_re = (sdblock2mem_fifo_syncfifo_readable & ((~sdblock2mem_fifo_readable) | sdblock2mem_fifo_re));
|
|
|
|
|
|
|
|
assign sdblock2mem_fifo_level1 = (sdblock2mem_fifo_level0 + sdblock2mem_fifo_readable);
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
|
sdblock2mem_fifo_wrport_adr <= 9'd0;
|
|
|
|
sdblock2mem_fifo_wrport_adr <= 9'd0;
|
|
|
|
if (sdblock2mem_fifo_replace) begin
|
|
|
|
if (sdblock2mem_fifo_replace) begin
|
|
|
@ -2304,8 +2314,9 @@ assign sdblock2mem_fifo_wrport_we = (sdblock2mem_fifo_syncfifo_we & (sdblock2mem
|
|
|
|
assign sdblock2mem_fifo_do_read = (sdblock2mem_fifo_syncfifo_readable & sdblock2mem_fifo_syncfifo_re);
|
|
|
|
assign sdblock2mem_fifo_do_read = (sdblock2mem_fifo_syncfifo_readable & sdblock2mem_fifo_syncfifo_re);
|
|
|
|
assign sdblock2mem_fifo_rdport_adr = sdblock2mem_fifo_consume;
|
|
|
|
assign sdblock2mem_fifo_rdport_adr = sdblock2mem_fifo_consume;
|
|
|
|
assign sdblock2mem_fifo_syncfifo_dout = sdblock2mem_fifo_rdport_dat_r;
|
|
|
|
assign sdblock2mem_fifo_syncfifo_dout = sdblock2mem_fifo_rdport_dat_r;
|
|
|
|
assign sdblock2mem_fifo_syncfifo_writable = (sdblock2mem_fifo_level != 10'd512);
|
|
|
|
assign sdblock2mem_fifo_rdport_re = sdblock2mem_fifo_do_read;
|
|
|
|
assign sdblock2mem_fifo_syncfifo_readable = (sdblock2mem_fifo_level != 1'd0);
|
|
|
|
assign sdblock2mem_fifo_syncfifo_writable = (sdblock2mem_fifo_level0 != 10'd512);
|
|
|
|
|
|
|
|
assign sdblock2mem_fifo_syncfifo_readable = (sdblock2mem_fifo_level0 != 1'd0);
|
|
|
|
assign sdblock2mem_source_source_valid = sdblock2mem_converter_source_valid;
|
|
|
|
assign sdblock2mem_source_source_valid = sdblock2mem_converter_source_valid;
|
|
|
|
assign sdblock2mem_converter_source_ready = sdblock2mem_source_source_ready;
|
|
|
|
assign sdblock2mem_converter_source_ready = sdblock2mem_source_source_ready;
|
|
|
|
assign sdblock2mem_source_source_first = sdblock2mem_converter_source_first;
|
|
|
|
assign sdblock2mem_source_source_first = sdblock2mem_converter_source_first;
|
|
|
@ -2326,15 +2337,15 @@ assign sdblock2mem_wishbonedmawriter_length = sdblock2mem_wishbonedmawriter_leng
|
|
|
|
assign sdblock2mem_wishbonedmawriter_offset_status = sdblock2mem_wishbonedmawriter_offset;
|
|
|
|
assign sdblock2mem_wishbonedmawriter_offset_status = sdblock2mem_wishbonedmawriter_offset;
|
|
|
|
assign sdblock2mem_wishbonedmawriter_reset = (~sdblock2mem_wishbonedmawriter_enable_storage);
|
|
|
|
assign sdblock2mem_wishbonedmawriter_reset = (~sdblock2mem_wishbonedmawriter_enable_storage);
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
|
sdblock2mem_sink_sink_last1 <= 1'd0;
|
|
|
|
|
|
|
|
sdblock2mem_sink_sink_payload_address <= 32'd0;
|
|
|
|
|
|
|
|
sdblock2mem_sink_sink_payload_data1 <= 32'd0;
|
|
|
|
|
|
|
|
subfragments_next_state <= 2'd0;
|
|
|
|
|
|
|
|
sdblock2mem_wishbonedmawriter_offset_next_value <= 32'd0;
|
|
|
|
|
|
|
|
sdblock2mem_wishbonedmawriter_offset_next_value_ce <= 1'd0;
|
|
|
|
|
|
|
|
sdblock2mem_wishbonedmawriter_done_status <= 1'd0;
|
|
|
|
sdblock2mem_wishbonedmawriter_done_status <= 1'd0;
|
|
|
|
sdblock2mem_wishbonedmawriter_sink_ready <= 1'd0;
|
|
|
|
sdblock2mem_wishbonedmawriter_sink_ready <= 1'd0;
|
|
|
|
sdblock2mem_sink_sink_valid1 <= 1'd0;
|
|
|
|
sdblock2mem_sink_sink_valid1 <= 1'd0;
|
|
|
|
|
|
|
|
subfragments_next_state <= 2'd0;
|
|
|
|
|
|
|
|
sdblock2mem_wishbonedmawriter_offset_next_value <= 32'd0;
|
|
|
|
|
|
|
|
sdblock2mem_wishbonedmawriter_offset_next_value_ce <= 1'd0;
|
|
|
|
|
|
|
|
sdblock2mem_sink_sink_last1 <= 1'd0;
|
|
|
|
|
|
|
|
sdblock2mem_sink_sink_payload_address <= 32'd0;
|
|
|
|
|
|
|
|
sdblock2mem_sink_sink_payload_data1 <= 32'd0;
|
|
|
|
subfragments_next_state <= subfragments_state;
|
|
|
|
subfragments_next_state <= subfragments_state;
|
|
|
|
case (subfragments_state)
|
|
|
|
case (subfragments_state)
|
|
|
|
1'd1: begin
|
|
|
|
1'd1: begin
|
|
|
@ -2393,18 +2404,18 @@ assign sdmem2block_dma_length = sdmem2block_dma_length_storage[31:2];
|
|
|
|
assign sdmem2block_dma_offset_status = sdmem2block_dma_offset;
|
|
|
|
assign sdmem2block_dma_offset_status = sdmem2block_dma_offset;
|
|
|
|
assign sdmem2block_dma_reset = (~sdmem2block_dma_enable_storage);
|
|
|
|
assign sdmem2block_dma_reset = (~sdmem2block_dma_enable_storage);
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
|
sdmem2block_dma_data_sdmem2blockdma_fsm_next_value <= 32'd0;
|
|
|
|
|
|
|
|
sdmem2block_dma_sink_ready <= 1'd0;
|
|
|
|
|
|
|
|
sdmem2block_dma_data_sdmem2blockdma_fsm_next_value_ce <= 1'd0;
|
|
|
|
|
|
|
|
interface1_bus_sel <= 4'd0;
|
|
|
|
|
|
|
|
interface1_bus_cyc <= 1'd0;
|
|
|
|
interface1_bus_cyc <= 1'd0;
|
|
|
|
interface1_bus_stb <= 1'd0;
|
|
|
|
interface1_bus_stb <= 1'd0;
|
|
|
|
sdmem2block_dma_source_valid <= 1'd0;
|
|
|
|
sdmem2block_dma_source_valid <= 1'd0;
|
|
|
|
interface1_bus_we <= 1'd0;
|
|
|
|
interface1_bus_we <= 1'd0;
|
|
|
|
subfragments_sdmem2blockdma_fsm_next_state <= 1'd0;
|
|
|
|
|
|
|
|
sdmem2block_dma_source_last <= 1'd0;
|
|
|
|
sdmem2block_dma_source_last <= 1'd0;
|
|
|
|
sdmem2block_dma_source_payload_data <= 32'd0;
|
|
|
|
sdmem2block_dma_source_payload_data <= 32'd0;
|
|
|
|
|
|
|
|
subfragments_sdmem2blockdma_fsm_next_state <= 1'd0;
|
|
|
|
|
|
|
|
sdmem2block_dma_data_sdmem2blockdma_fsm_next_value <= 32'd0;
|
|
|
|
|
|
|
|
sdmem2block_dma_data_sdmem2blockdma_fsm_next_value_ce <= 1'd0;
|
|
|
|
interface1_bus_adr <= 32'd0;
|
|
|
|
interface1_bus_adr <= 32'd0;
|
|
|
|
|
|
|
|
sdmem2block_dma_sink_ready <= 1'd0;
|
|
|
|
|
|
|
|
interface1_bus_sel <= 4'd0;
|
|
|
|
subfragments_sdmem2blockdma_fsm_next_state <= subfragments_sdmem2blockdma_fsm_state;
|
|
|
|
subfragments_sdmem2blockdma_fsm_next_state <= subfragments_sdmem2blockdma_fsm_state;
|
|
|
|
case (subfragments_sdmem2blockdma_fsm_state)
|
|
|
|
case (subfragments_sdmem2blockdma_fsm_state)
|
|
|
|
1'd1: begin
|
|
|
|
1'd1: begin
|
|
|
@ -2431,12 +2442,12 @@ always @(*) begin
|
|
|
|
endcase
|
|
|
|
endcase
|
|
|
|
end
|
|
|
|
end
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
|
sdmem2block_dma_sink_valid <= 1'd0;
|
|
|
|
|
|
|
|
sdmem2block_dma_done_status <= 1'd0;
|
|
|
|
|
|
|
|
sdmem2block_dma_offset_sdmem2blockdma_resetinserter_next_value <= 32'd0;
|
|
|
|
|
|
|
|
sdmem2block_dma_offset_sdmem2blockdma_resetinserter_next_value_ce <= 1'd0;
|
|
|
|
|
|
|
|
sdmem2block_dma_sink_last <= 1'd0;
|
|
|
|
sdmem2block_dma_sink_last <= 1'd0;
|
|
|
|
|
|
|
|
sdmem2block_dma_offset_sdmem2blockdma_resetinserter_next_value <= 32'd0;
|
|
|
|
sdmem2block_dma_sink_payload_address <= 32'd0;
|
|
|
|
sdmem2block_dma_sink_payload_address <= 32'd0;
|
|
|
|
|
|
|
|
sdmem2block_dma_offset_sdmem2blockdma_resetinserter_next_value_ce <= 1'd0;
|
|
|
|
|
|
|
|
sdmem2block_dma_done_status <= 1'd0;
|
|
|
|
|
|
|
|
sdmem2block_dma_sink_valid <= 1'd0;
|
|
|
|
subfragments_sdmem2blockdma_resetinserter_next_state <= 2'd0;
|
|
|
|
subfragments_sdmem2blockdma_resetinserter_next_state <= 2'd0;
|
|
|
|
subfragments_sdmem2blockdma_resetinserter_next_state <= subfragments_sdmem2blockdma_resetinserter_state;
|
|
|
|
subfragments_sdmem2blockdma_resetinserter_next_state <= subfragments_sdmem2blockdma_resetinserter_state;
|
|
|
|
case (subfragments_sdmem2blockdma_resetinserter_state)
|
|
|
|
case (subfragments_sdmem2blockdma_resetinserter_state)
|
|
|
@ -2503,11 +2514,13 @@ assign sdmem2block_fifo_syncfifo_we = sdmem2block_fifo_sink_valid;
|
|
|
|
assign sdmem2block_fifo_fifo_in_first = sdmem2block_fifo_sink_first;
|
|
|
|
assign sdmem2block_fifo_fifo_in_first = sdmem2block_fifo_sink_first;
|
|
|
|
assign sdmem2block_fifo_fifo_in_last = sdmem2block_fifo_sink_last;
|
|
|
|
assign sdmem2block_fifo_fifo_in_last = sdmem2block_fifo_sink_last;
|
|
|
|
assign sdmem2block_fifo_fifo_in_payload_data = sdmem2block_fifo_sink_payload_data;
|
|
|
|
assign sdmem2block_fifo_fifo_in_payload_data = sdmem2block_fifo_sink_payload_data;
|
|
|
|
assign sdmem2block_fifo_source_valid = sdmem2block_fifo_syncfifo_readable;
|
|
|
|
assign sdmem2block_fifo_source_valid = sdmem2block_fifo_readable;
|
|
|
|
assign sdmem2block_fifo_source_first = sdmem2block_fifo_fifo_out_first;
|
|
|
|
assign sdmem2block_fifo_source_first = sdmem2block_fifo_fifo_out_first;
|
|
|
|
assign sdmem2block_fifo_source_last = sdmem2block_fifo_fifo_out_last;
|
|
|
|
assign sdmem2block_fifo_source_last = sdmem2block_fifo_fifo_out_last;
|
|
|
|
assign sdmem2block_fifo_source_payload_data = sdmem2block_fifo_fifo_out_payload_data;
|
|
|
|
assign sdmem2block_fifo_source_payload_data = sdmem2block_fifo_fifo_out_payload_data;
|
|
|
|
assign sdmem2block_fifo_syncfifo_re = sdmem2block_fifo_source_ready;
|
|
|
|
assign sdmem2block_fifo_re = sdmem2block_fifo_source_ready;
|
|
|
|
|
|
|
|
assign sdmem2block_fifo_syncfifo_re = (sdmem2block_fifo_syncfifo_readable & ((~sdmem2block_fifo_readable) | sdmem2block_fifo_re));
|
|
|
|
|
|
|
|
assign sdmem2block_fifo_level1 = (sdmem2block_fifo_level0 + sdmem2block_fifo_readable);
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
|
sdmem2block_fifo_wrport_adr <= 9'd0;
|
|
|
|
sdmem2block_fifo_wrport_adr <= 9'd0;
|
|
|
|
if (sdmem2block_fifo_replace) begin
|
|
|
|
if (sdmem2block_fifo_replace) begin
|
|
|
@ -2521,8 +2534,9 @@ assign sdmem2block_fifo_wrport_we = (sdmem2block_fifo_syncfifo_we & (sdmem2block
|
|
|
|
assign sdmem2block_fifo_do_read = (sdmem2block_fifo_syncfifo_readable & sdmem2block_fifo_syncfifo_re);
|
|
|
|
assign sdmem2block_fifo_do_read = (sdmem2block_fifo_syncfifo_readable & sdmem2block_fifo_syncfifo_re);
|
|
|
|
assign sdmem2block_fifo_rdport_adr = sdmem2block_fifo_consume;
|
|
|
|
assign sdmem2block_fifo_rdport_adr = sdmem2block_fifo_consume;
|
|
|
|
assign sdmem2block_fifo_syncfifo_dout = sdmem2block_fifo_rdport_dat_r;
|
|
|
|
assign sdmem2block_fifo_syncfifo_dout = sdmem2block_fifo_rdport_dat_r;
|
|
|
|
assign sdmem2block_fifo_syncfifo_writable = (sdmem2block_fifo_level != 10'd512);
|
|
|
|
assign sdmem2block_fifo_rdport_re = sdmem2block_fifo_do_read;
|
|
|
|
assign sdmem2block_fifo_syncfifo_readable = (sdmem2block_fifo_level != 1'd0);
|
|
|
|
assign sdmem2block_fifo_syncfifo_writable = (sdmem2block_fifo_level0 != 10'd512);
|
|
|
|
|
|
|
|
assign sdmem2block_fifo_syncfifo_readable = (sdmem2block_fifo_level0 != 1'd0);
|
|
|
|
assign eventmanager_card_detect0 = card_detect_status1;
|
|
|
|
assign eventmanager_card_detect0 = card_detect_status1;
|
|
|
|
assign eventmanager_card_detect1 = card_detect_pending;
|
|
|
|
assign eventmanager_card_detect1 = card_detect_pending;
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
@ -2566,8 +2580,8 @@ always @(*) begin
|
|
|
|
litesdcardcore_next_state <= 1'd0;
|
|
|
|
litesdcardcore_next_state <= 1'd0;
|
|
|
|
litesdcardcore_litesdcardcore_adr <= 14'd0;
|
|
|
|
litesdcardcore_litesdcardcore_adr <= 14'd0;
|
|
|
|
litesdcardcore_litesdcardcore_we <= 1'd0;
|
|
|
|
litesdcardcore_litesdcardcore_we <= 1'd0;
|
|
|
|
litesdcardcore_litesdcardcore_wishbone_ack <= 1'd0;
|
|
|
|
|
|
|
|
litesdcardcore_litesdcardcore_dat_w <= 32'd0;
|
|
|
|
litesdcardcore_litesdcardcore_dat_w <= 32'd0;
|
|
|
|
|
|
|
|
litesdcardcore_litesdcardcore_wishbone_ack <= 1'd0;
|
|
|
|
litesdcardcore_next_state <= litesdcardcore_state;
|
|
|
|
litesdcardcore_next_state <= litesdcardcore_state;
|
|
|
|
case (litesdcardcore_state)
|
|
|
|
case (litesdcardcore_state)
|
|
|
|
1'd1: begin
|
|
|
|
1'd1: begin
|
|
|
@ -2623,9 +2637,9 @@ assign wb_dma_cyc_1 = (litesdcardcore_shared_cyc & litesdcardcore_slave_sel);
|
|
|
|
assign litesdcardcore_shared_err = wb_dma_err_1;
|
|
|
|
assign litesdcardcore_shared_err = wb_dma_err_1;
|
|
|
|
assign litesdcardcore_wait = ((litesdcardcore_shared_stb & litesdcardcore_shared_cyc) & (~litesdcardcore_shared_ack));
|
|
|
|
assign litesdcardcore_wait = ((litesdcardcore_shared_stb & litesdcardcore_shared_cyc) & (~litesdcardcore_shared_ack));
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
|
|
|
|
|
litesdcardcore_error <= 1'd0;
|
|
|
|
litesdcardcore_shared_dat_r <= 32'd0;
|
|
|
|
litesdcardcore_shared_dat_r <= 32'd0;
|
|
|
|
litesdcardcore_shared_ack <= 1'd0;
|
|
|
|
litesdcardcore_shared_ack <= 1'd0;
|
|
|
|
litesdcardcore_error <= 1'd0;
|
|
|
|
|
|
|
|
litesdcardcore_shared_ack <= wb_dma_ack_1;
|
|
|
|
litesdcardcore_shared_ack <= wb_dma_ack_1;
|
|
|
|
litesdcardcore_shared_dat_r <= ({32{litesdcardcore_slave_sel_r}} & wb_dma_dat_r_1);
|
|
|
|
litesdcardcore_shared_dat_r <= ({32{litesdcardcore_slave_sel_r}} & wb_dma_dat_r_1);
|
|
|
|
if (litesdcardcore_done) begin
|
|
|
|
if (litesdcardcore_done) begin
|
|
|
@ -2636,7 +2650,7 @@ always @(*) begin
|
|
|
|
end
|
|
|
|
end
|
|
|
|
assign litesdcardcore_done = (litesdcardcore_count == 1'd0);
|
|
|
|
assign litesdcardcore_done = (litesdcardcore_count == 1'd0);
|
|
|
|
assign litesdcardcore_csrbank0_sel = (litesdcardcore_interface0_bank_bus_adr[13:9] == 1'd0);
|
|
|
|
assign litesdcardcore_csrbank0_sel = (litesdcardcore_interface0_bank_bus_adr[13:9] == 1'd0);
|
|
|
|
assign litesdcardcore_csrbank0_reset0_r = litesdcardcore_interface0_bank_bus_dat_w[0];
|
|
|
|
assign litesdcardcore_csrbank0_reset0_r = litesdcardcore_interface0_bank_bus_dat_w[1:0];
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
|
litesdcardcore_csrbank0_reset0_re <= 1'd0;
|
|
|
|
litesdcardcore_csrbank0_reset0_re <= 1'd0;
|
|
|
|
litesdcardcore_csrbank0_reset0_we <= 1'd0;
|
|
|
|
litesdcardcore_csrbank0_reset0_we <= 1'd0;
|
|
|
@ -2663,7 +2677,14 @@ always @(*) begin
|
|
|
|
litesdcardcore_csrbank0_bus_errors_we <= (~litesdcardcore_interface0_bank_bus_we);
|
|
|
|
litesdcardcore_csrbank0_bus_errors_we <= (~litesdcardcore_interface0_bank_bus_we);
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
assign litesdcardcore_csrbank0_reset0_w = reset_storage;
|
|
|
|
always @(*) begin
|
|
|
|
|
|
|
|
soc_rst <= 1'd0;
|
|
|
|
|
|
|
|
if (reset_re) begin
|
|
|
|
|
|
|
|
soc_rst <= reset_storage[0];
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
assign cpu_rst = reset_storage[1];
|
|
|
|
|
|
|
|
assign litesdcardcore_csrbank0_reset0_w = reset_storage[1:0];
|
|
|
|
assign litesdcardcore_csrbank0_scratch0_w = scratch_storage[31:0];
|
|
|
|
assign litesdcardcore_csrbank0_scratch0_w = scratch_storage[31:0];
|
|
|
|
assign litesdcardcore_csrbank0_bus_errors_w = bus_errors_status[31:0];
|
|
|
|
assign litesdcardcore_csrbank0_bus_errors_w = bus_errors_status[31:0];
|
|
|
|
assign bus_errors_we = litesdcardcore_csrbank0_bus_errors_we;
|
|
|
|
assign bus_errors_we = litesdcardcore_csrbank0_bus_errors_we;
|
|
|
@ -3016,8 +3037,8 @@ always @(*) begin
|
|
|
|
end
|
|
|
|
end
|
|
|
|
assign init_initialize_r = litesdcardcore_interface5_bank_bus_dat_w[0];
|
|
|
|
assign init_initialize_r = litesdcardcore_interface5_bank_bus_dat_w[0];
|
|
|
|
always @(*) begin
|
|
|
|
always @(*) begin
|
|
|
|
init_initialize_we <= 1'd0;
|
|
|
|
|
|
|
|
init_initialize_re <= 1'd0;
|
|
|
|
init_initialize_re <= 1'd0;
|
|
|
|
|
|
|
|
init_initialize_we <= 1'd0;
|
|
|
|
if ((litesdcardcore_csrbank5_sel & (litesdcardcore_interface5_bank_bus_adr[8:0] == 2'd2))) begin
|
|
|
|
if ((litesdcardcore_csrbank5_sel & (litesdcardcore_interface5_bank_bus_adr[8:0] == 2'd2))) begin
|
|
|
|
init_initialize_re <= litesdcardcore_interface5_bank_bus_we;
|
|
|
|
init_initialize_re <= litesdcardcore_interface5_bank_bus_we;
|
|
|
|
init_initialize_we <= (~litesdcardcore_interface5_bank_bus_we);
|
|
|
|
init_initialize_we <= (~litesdcardcore_interface5_bank_bus_we);
|
|
|
@ -3555,6 +3576,13 @@ always @(posedge sys_clk) begin
|
|
|
|
end
|
|
|
|
end
|
|
|
|
sdblock2mem_done_d <= sdblock2mem_wishbonedmawriter_done_status;
|
|
|
|
sdblock2mem_done_d <= sdblock2mem_wishbonedmawriter_done_status;
|
|
|
|
sdblock2mem_irq <= (sdblock2mem_wishbonedmawriter_done_status & (~sdblock2mem_done_d));
|
|
|
|
sdblock2mem_irq <= (sdblock2mem_wishbonedmawriter_done_status & (~sdblock2mem_done_d));
|
|
|
|
|
|
|
|
if (sdblock2mem_fifo_syncfifo_re) begin
|
|
|
|
|
|
|
|
sdblock2mem_fifo_readable <= 1'd1;
|
|
|
|
|
|
|
|
end else begin
|
|
|
|
|
|
|
|
if (sdblock2mem_fifo_re) begin
|
|
|
|
|
|
|
|
sdblock2mem_fifo_readable <= 1'd0;
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
if (((sdblock2mem_fifo_syncfifo_we & sdblock2mem_fifo_syncfifo_writable) & (~sdblock2mem_fifo_replace))) begin
|
|
|
|
if (((sdblock2mem_fifo_syncfifo_we & sdblock2mem_fifo_syncfifo_writable) & (~sdblock2mem_fifo_replace))) begin
|
|
|
|
sdblock2mem_fifo_produce <= (sdblock2mem_fifo_produce + 1'd1);
|
|
|
|
sdblock2mem_fifo_produce <= (sdblock2mem_fifo_produce + 1'd1);
|
|
|
|
end
|
|
|
|
end
|
|
|
@ -3563,11 +3591,11 @@ always @(posedge sys_clk) begin
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if (((sdblock2mem_fifo_syncfifo_we & sdblock2mem_fifo_syncfifo_writable) & (~sdblock2mem_fifo_replace))) begin
|
|
|
|
if (((sdblock2mem_fifo_syncfifo_we & sdblock2mem_fifo_syncfifo_writable) & (~sdblock2mem_fifo_replace))) begin
|
|
|
|
if ((~sdblock2mem_fifo_do_read)) begin
|
|
|
|
if ((~sdblock2mem_fifo_do_read)) begin
|
|
|
|
sdblock2mem_fifo_level <= (sdblock2mem_fifo_level + 1'd1);
|
|
|
|
sdblock2mem_fifo_level0 <= (sdblock2mem_fifo_level0 + 1'd1);
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end else begin
|
|
|
|
end else begin
|
|
|
|
if (sdblock2mem_fifo_do_read) begin
|
|
|
|
if (sdblock2mem_fifo_do_read) begin
|
|
|
|
sdblock2mem_fifo_level <= (sdblock2mem_fifo_level - 1'd1);
|
|
|
|
sdblock2mem_fifo_level0 <= (sdblock2mem_fifo_level0 - 1'd1);
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if (sdblock2mem_converter_source_ready) begin
|
|
|
|
if (sdblock2mem_converter_source_ready) begin
|
|
|
@ -3649,6 +3677,13 @@ always @(posedge sys_clk) begin
|
|
|
|
sdmem2block_converter_mux <= (sdmem2block_converter_mux + 1'd1);
|
|
|
|
sdmem2block_converter_mux <= (sdmem2block_converter_mux + 1'd1);
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
if (sdmem2block_fifo_syncfifo_re) begin
|
|
|
|
|
|
|
|
sdmem2block_fifo_readable <= 1'd1;
|
|
|
|
|
|
|
|
end else begin
|
|
|
|
|
|
|
|
if (sdmem2block_fifo_re) begin
|
|
|
|
|
|
|
|
sdmem2block_fifo_readable <= 1'd0;
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
if (((sdmem2block_fifo_syncfifo_we & sdmem2block_fifo_syncfifo_writable) & (~sdmem2block_fifo_replace))) begin
|
|
|
|
if (((sdmem2block_fifo_syncfifo_we & sdmem2block_fifo_syncfifo_writable) & (~sdmem2block_fifo_replace))) begin
|
|
|
|
sdmem2block_fifo_produce <= (sdmem2block_fifo_produce + 1'd1);
|
|
|
|
sdmem2block_fifo_produce <= (sdmem2block_fifo_produce + 1'd1);
|
|
|
|
end
|
|
|
|
end
|
|
|
@ -3657,11 +3692,11 @@ always @(posedge sys_clk) begin
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if (((sdmem2block_fifo_syncfifo_we & sdmem2block_fifo_syncfifo_writable) & (~sdmem2block_fifo_replace))) begin
|
|
|
|
if (((sdmem2block_fifo_syncfifo_we & sdmem2block_fifo_syncfifo_writable) & (~sdmem2block_fifo_replace))) begin
|
|
|
|
if ((~sdmem2block_fifo_do_read)) begin
|
|
|
|
if ((~sdmem2block_fifo_do_read)) begin
|
|
|
|
sdmem2block_fifo_level <= (sdmem2block_fifo_level + 1'd1);
|
|
|
|
sdmem2block_fifo_level0 <= (sdmem2block_fifo_level0 + 1'd1);
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end else begin
|
|
|
|
end else begin
|
|
|
|
if (sdmem2block_fifo_do_read) begin
|
|
|
|
if (sdmem2block_fifo_do_read) begin
|
|
|
|
sdmem2block_fifo_level <= (sdmem2block_fifo_level - 1'd1);
|
|
|
|
sdmem2block_fifo_level0 <= (sdmem2block_fifo_level0 - 1'd1);
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if (card_detect_clear) begin
|
|
|
|
if (card_detect_clear) begin
|
|
|
@ -3722,7 +3757,7 @@ always @(posedge sys_clk) begin
|
|
|
|
endcase
|
|
|
|
endcase
|
|
|
|
end
|
|
|
|
end
|
|
|
|
if (litesdcardcore_csrbank0_reset0_re) begin
|
|
|
|
if (litesdcardcore_csrbank0_reset0_re) begin
|
|
|
|
reset_storage <= litesdcardcore_csrbank0_reset0_r;
|
|
|
|
reset_storage[1:0] <= litesdcardcore_csrbank0_reset0_r;
|
|
|
|
end
|
|
|
|
end
|
|
|
|
reset_re <= litesdcardcore_csrbank0_reset0_re;
|
|
|
|
reset_re <= litesdcardcore_csrbank0_reset0_re;
|
|
|
|
if (litesdcardcore_csrbank0_scratch0_re) begin
|
|
|
|
if (litesdcardcore_csrbank0_scratch0_re) begin
|
|
|
@ -3932,7 +3967,7 @@ always @(posedge sys_clk) begin
|
|
|
|
clocker_re <= litesdcardcore_csrbank5_clocker_divider0_re;
|
|
|
|
clocker_re <= litesdcardcore_csrbank5_clocker_divider0_re;
|
|
|
|
dataw_re <= litesdcardcore_csrbank5_dataw_status_re;
|
|
|
|
dataw_re <= litesdcardcore_csrbank5_dataw_status_re;
|
|
|
|
if (sys_rst) begin
|
|
|
|
if (sys_rst) begin
|
|
|
|
reset_storage <= 1'd0;
|
|
|
|
reset_storage <= 2'd0;
|
|
|
|
reset_re <= 1'd0;
|
|
|
|
reset_re <= 1'd0;
|
|
|
|
scratch_storage <= 32'd305419896;
|
|
|
|
scratch_storage <= 32'd305419896;
|
|
|
|
scratch_re <= 1'd0;
|
|
|
|
scratch_re <= 1'd0;
|
|
|
@ -4015,7 +4050,8 @@ always @(posedge sys_clk) begin
|
|
|
|
sdcore_data_error <= 1'd0;
|
|
|
|
sdcore_data_error <= 1'd0;
|
|
|
|
sdcore_data_timeout <= 1'd0;
|
|
|
|
sdcore_data_timeout <= 1'd0;
|
|
|
|
sdblock2mem_irq <= 1'd0;
|
|
|
|
sdblock2mem_irq <= 1'd0;
|
|
|
|
sdblock2mem_fifo_level <= 10'd0;
|
|
|
|
sdblock2mem_fifo_readable <= 1'd0;
|
|
|
|
|
|
|
|
sdblock2mem_fifo_level0 <= 10'd0;
|
|
|
|
sdblock2mem_fifo_produce <= 9'd0;
|
|
|
|
sdblock2mem_fifo_produce <= 9'd0;
|
|
|
|
sdblock2mem_fifo_consume <= 9'd0;
|
|
|
|
sdblock2mem_fifo_consume <= 9'd0;
|
|
|
|
sdblock2mem_converter_source_payload_data <= 32'd0;
|
|
|
|
sdblock2mem_converter_source_payload_data <= 32'd0;
|
|
|
@ -4049,7 +4085,8 @@ always @(posedge sys_clk) begin
|
|
|
|
sdmem2block_dma_offset_re <= 1'd0;
|
|
|
|
sdmem2block_dma_offset_re <= 1'd0;
|
|
|
|
sdmem2block_dma_offset <= 32'd0;
|
|
|
|
sdmem2block_dma_offset <= 32'd0;
|
|
|
|
sdmem2block_converter_mux <= 2'd0;
|
|
|
|
sdmem2block_converter_mux <= 2'd0;
|
|
|
|
sdmem2block_fifo_level <= 10'd0;
|
|
|
|
sdmem2block_fifo_readable <= 1'd0;
|
|
|
|
|
|
|
|
sdmem2block_fifo_level0 <= 10'd0;
|
|
|
|
sdmem2block_fifo_produce <= 9'd0;
|
|
|
|
sdmem2block_fifo_produce <= 9'd0;
|
|
|
|
sdmem2block_fifo_consume <= 9'd0;
|
|
|
|
sdmem2block_fifo_consume <= 9'd0;
|
|
|
|
sdmem2block_count <= 9'd0;
|
|
|
|
sdmem2block_count <= 9'd0;
|
|
|
@ -4095,6 +4132,7 @@ assign sdcore_fifo_rdport_dat_r = storage[sdcore_fifo_rdport_adr];
|
|
|
|
|
|
|
|
|
|
|
|
reg [9:0] storage_1[0:511];
|
|
|
|
reg [9:0] storage_1[0:511];
|
|
|
|
reg [9:0] memdat_1;
|
|
|
|
reg [9:0] memdat_1;
|
|
|
|
|
|
|
|
reg [9:0] memdat_2;
|
|
|
|
always @(posedge sys_clk) begin
|
|
|
|
always @(posedge sys_clk) begin
|
|
|
|
if (sdblock2mem_fifo_wrport_we)
|
|
|
|
if (sdblock2mem_fifo_wrport_we)
|
|
|
|
storage_1[sdblock2mem_fifo_wrport_adr] <= sdblock2mem_fifo_wrport_dat_w;
|
|
|
|
storage_1[sdblock2mem_fifo_wrport_adr] <= sdblock2mem_fifo_wrport_dat_w;
|
|
|
@ -4102,24 +4140,29 @@ always @(posedge sys_clk) begin
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
always @(posedge sys_clk) begin
|
|
|
|
always @(posedge sys_clk) begin
|
|
|
|
|
|
|
|
if (sdblock2mem_fifo_rdport_re)
|
|
|
|
|
|
|
|
memdat_2 <= storage_1[sdblock2mem_fifo_rdport_adr];
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
assign sdblock2mem_fifo_wrport_dat_r = memdat_1;
|
|
|
|
assign sdblock2mem_fifo_wrport_dat_r = memdat_1;
|
|
|
|
assign sdblock2mem_fifo_rdport_dat_r = storage_1[sdblock2mem_fifo_rdport_adr];
|
|
|
|
assign sdblock2mem_fifo_rdport_dat_r = memdat_2;
|
|
|
|
|
|
|
|
|
|
|
|
reg [9:0] storage_2[0:511];
|
|
|
|
reg [9:0] storage_2[0:511];
|
|
|
|
reg [9:0] memdat_2;
|
|
|
|
reg [9:0] memdat_3;
|
|
|
|
|
|
|
|
reg [9:0] memdat_4;
|
|
|
|
always @(posedge sys_clk) begin
|
|
|
|
always @(posedge sys_clk) begin
|
|
|
|
if (sdmem2block_fifo_wrport_we)
|
|
|
|
if (sdmem2block_fifo_wrport_we)
|
|
|
|
storage_2[sdmem2block_fifo_wrport_adr] <= sdmem2block_fifo_wrport_dat_w;
|
|
|
|
storage_2[sdmem2block_fifo_wrport_adr] <= sdmem2block_fifo_wrport_dat_w;
|
|
|
|
memdat_2 <= storage_2[sdmem2block_fifo_wrport_adr];
|
|
|
|
memdat_3 <= storage_2[sdmem2block_fifo_wrport_adr];
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
always @(posedge sys_clk) begin
|
|
|
|
always @(posedge sys_clk) begin
|
|
|
|
|
|
|
|
if (sdmem2block_fifo_rdport_re)
|
|
|
|
|
|
|
|
memdat_4 <= storage_2[sdmem2block_fifo_rdport_adr];
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
assign sdmem2block_fifo_wrport_dat_r = memdat_2;
|
|
|
|
assign sdmem2block_fifo_wrport_dat_r = memdat_3;
|
|
|
|
assign sdmem2block_fifo_rdport_dat_r = storage_2[sdmem2block_fifo_rdport_adr];
|
|
|
|
assign sdmem2block_fifo_rdport_dat_r = memdat_4;
|
|
|
|
|
|
|
|
|
|
|
|
IOBUF IOBUF(
|
|
|
|
IOBUF IOBUF(
|
|
|
|
.I(xilinxsdrtristateimpl0__o),
|
|
|
|
.I(xilinxsdrtristateimpl0__o),
|