FPGA/Cx4: optimize non-sector-aligned SD DMA reads
This commit is contained in:
parent
3243143c39
commit
059966f06a
@ -125,7 +125,9 @@ sd_dma snes_sd_dma(
|
|||||||
.SD_DMA_NEXTADDR(SD_DMA_NEXTADDR),
|
.SD_DMA_NEXTADDR(SD_DMA_NEXTADDR),
|
||||||
.SD_DMA_PARTIAL(SD_DMA_PARTIAL),
|
.SD_DMA_PARTIAL(SD_DMA_PARTIAL),
|
||||||
.SD_DMA_PARTIAL_START(SD_DMA_PARTIAL_START),
|
.SD_DMA_PARTIAL_START(SD_DMA_PARTIAL_START),
|
||||||
.SD_DMA_PARTIAL_END(SD_DMA_PARTIAL_END)
|
.SD_DMA_PARTIAL_END(SD_DMA_PARTIAL_END),
|
||||||
|
.SD_DMA_START_MID_BLOCK(SD_DMA_START_MID_BLOCK),
|
||||||
|
.SD_DMA_END_MID_BLOCK(SD_DMA_END_MID_BLOCK)
|
||||||
);
|
);
|
||||||
|
|
||||||
wire SD_DMA_TO_ROM = (SD_DMA_STATUS && (SD_DMA_TGT == 2'b00));
|
wire SD_DMA_TO_ROM = (SD_DMA_STATUS && (SD_DMA_TGT == 2'b00));
|
||||||
@ -215,6 +217,8 @@ mcu_cmd snes_mcu_cmd(
|
|||||||
.SD_DMA_PARTIAL(SD_DMA_PARTIAL),
|
.SD_DMA_PARTIAL(SD_DMA_PARTIAL),
|
||||||
.SD_DMA_PARTIAL_START(SD_DMA_PARTIAL_START),
|
.SD_DMA_PARTIAL_START(SD_DMA_PARTIAL_START),
|
||||||
.SD_DMA_PARTIAL_END(SD_DMA_PARTIAL_END),
|
.SD_DMA_PARTIAL_END(SD_DMA_PARTIAL_END),
|
||||||
|
.SD_DMA_START_MID_BLOCK(SD_DMA_START_MID_BLOCK),
|
||||||
|
.SD_DMA_END_MID_BLOCK(SD_DMA_END_MID_BLOCK),
|
||||||
.dac_addr_out(dac_addr),
|
.dac_addr_out(dac_addr),
|
||||||
.DAC_STATUS(DAC_STATUS),
|
.DAC_STATUS(DAC_STATUS),
|
||||||
// .dac_volume_out(dac_volume),
|
// .dac_volume_out(dac_volume),
|
||||||
|
|||||||
@ -29,7 +29,9 @@ module sd_dma(
|
|||||||
output [7:0] SD_DMA_SRAM_DATA,
|
output [7:0] SD_DMA_SRAM_DATA,
|
||||||
input SD_DMA_PARTIAL,
|
input SD_DMA_PARTIAL,
|
||||||
input [10:0] SD_DMA_PARTIAL_START,
|
input [10:0] SD_DMA_PARTIAL_START,
|
||||||
input [10:0] SD_DMA_PARTIAL_END
|
input [10:0] SD_DMA_PARTIAL_END,
|
||||||
|
input SD_DMA_START_MID_BLOCK,
|
||||||
|
input SD_DMA_END_MID_BLOCK
|
||||||
);
|
);
|
||||||
|
|
||||||
reg [10:0] SD_DMA_STARTr;
|
reg [10:0] SD_DMA_STARTr;
|
||||||
@ -85,7 +87,9 @@ always @(posedge CLK) begin
|
|||||||
end
|
end
|
||||||
|
|
||||||
always @(posedge CLK) begin
|
always @(posedge CLK) begin
|
||||||
if(cyclecnt == 1042) SD_DMA_DONEr <= 1;
|
if(cyclecnt == 1042
|
||||||
|
|| ((SD_DMA_END_MID_BLOCK & SD_DMA_PARTIALr) && cyclecnt == SD_DMA_PARTIAL_END))
|
||||||
|
SD_DMA_DONEr <= 1;
|
||||||
else SD_DMA_DONEr <= 0;
|
else SD_DMA_DONEr <= 0;
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -100,8 +104,10 @@ always @(posedge CLK) begin
|
|||||||
end
|
end
|
||||||
|
|
||||||
always @(posedge CLK) begin
|
always @(posedge CLK) begin
|
||||||
if(SD_DMA_EN_rising || !SD_DMA_STATUSr) cyclecnt <= 0;
|
if(SD_DMA_EN_rising)
|
||||||
else if(clkcnt[1:0] == 2'b11) cyclecnt <= cyclecnt + 1;
|
cyclecnt <= (SD_DMA_PARTIALr && SD_DMA_START_MID_BLOCK) ? SD_DMA_PARTIAL_START : 0;
|
||||||
|
else if(!SD_DMA_STATUSr) cyclecnt <= 0;
|
||||||
|
else if(clkcnt[1:0] == 2'b10) cyclecnt <= cyclecnt + 1;
|
||||||
end
|
end
|
||||||
|
|
||||||
// we have 8 clk cycles to complete one RAM write
|
// we have 8 clk cycles to complete one RAM write
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user