mirror of
https://github.com/fail0verflow/mini.git
synced 2024-11-24 20:26:55 +01:00
fix for dma problems?
This commit is contained in:
parent
3fc45b7dd8
commit
e14be86d6c
9
sdhc.c
9
sdhc.c
@ -697,13 +697,15 @@ static s32 __sd_cmd(sdhci_t *sdhci, u32 cmd, u32 type, u32 arg, u32 blk_cnt, voi
|
|||||||
{
|
{
|
||||||
__sd_dumpregs(sdhci);
|
__sd_dumpregs(sdhci);
|
||||||
sdhc_debug(sdhci->reg_base, "transfer completed. disabling interrupts again and returning.");
|
sdhc_debug(sdhci->reg_base, "transfer completed. disabling interrupts again and returning.");
|
||||||
__sd_write16(sdhci->reg_base + SDHC_NORMAL_INTERRUPT_STATUS, 0);
|
__sd_write16(sdhci->reg_base + SDHC_NORMAL_INTERRUPT_STATUS, INTERRUPT_TRANSFER_COMPLETE | INTERRUPT_DMA);
|
||||||
__sd_write16(sdhci->reg_base + SDHC_NORMAL_INTERRUPT_ENABLE, 0);
|
__sd_write16(sdhci->reg_base + SDHC_NORMAL_INTERRUPT_ENABLE, 0);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
else if(retval & INTERRUPT_DMA)
|
else if(retval & INTERRUPT_DMA)
|
||||||
{
|
{
|
||||||
blk_cnt = blk_cnt > (SDMA_BLOCK_SIZE / SDHC_BLOCK_SIZE) ? blk_cnt - (SDMA_BLOCK_SIZE / SDHC_BLOCK_SIZE) : 0;
|
u32 blk_left = __sd_read16(sdhci->reg_base + SDHC_BLOCK_COUNT);
|
||||||
|
blk_left = blk_cnt - blk_left;
|
||||||
|
ptr = buffer + blk_cnt * SDHC_BLOCK_SIZE;
|
||||||
__sd_dumpregs(sdhci);
|
__sd_dumpregs(sdhci);
|
||||||
sdhc_debug(sdhci->reg_base, "DMA interrupt set, updating next SDMA address");
|
sdhc_debug(sdhci->reg_base, "DMA interrupt set, updating next SDMA address");
|
||||||
sdhc_debug(sdhci->reg_base, "sd blocks left: %d, addr: %p -> %p", blk_cnt, ptr, ptr + SDMA_BLOCK_SIZE);
|
sdhc_debug(sdhci->reg_base, "sd blocks left: %d, addr: %p -> %p", blk_cnt, ptr, ptr + SDMA_BLOCK_SIZE);
|
||||||
@ -715,8 +717,7 @@ static s32 __sd_cmd(sdhci_t *sdhci, u32 cmd, u32 type, u32 arg, u32 blk_cnt, voi
|
|||||||
return SDHC_EIO;
|
return SDHC_EIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
__sd_write16(sdhci->reg_base + SDHC_NORMAL_INTERRUPT_STATUS, 0);
|
__sd_write16(sdhci->reg_base + SDHC_NORMAL_INTERRUPT_STATUS, INTERRUPT_DMA);
|
||||||
ptr += SDMA_BLOCK_SIZE;
|
|
||||||
__sd_write32(sdhci->reg_base + SDHC_SDMA_ADDR, (u32 )ptr);
|
__sd_write32(sdhci->reg_base + SDHC_SDMA_ADDR, (u32 )ptr);
|
||||||
|
|
||||||
sdhc_debug(sdhci->reg_base, "next DMA transfer started.");
|
sdhc_debug(sdhci->reg_base, "next DMA transfer started.");
|
||||||
|
Loading…
Reference in New Issue
Block a user