mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-03 11:11:14 +00:00
fusee: sdmmc: use v3 compatibility mode for it's simpler DMA
we may want to change this at some point to get 64-bit addressing?
This commit is contained in:
parent
ef1923ebab
commit
01e3761d4c
2 changed files with 9 additions and 35 deletions
|
@ -26,7 +26,8 @@ CFLAGS = \
|
||||||
-fdata-sections \
|
-fdata-sections \
|
||||||
-std=gnu11 \
|
-std=gnu11 \
|
||||||
-Werror \
|
-Werror \
|
||||||
-Wall
|
-Wall \
|
||||||
|
-fstrict-volatile-bitfields
|
||||||
|
|
||||||
LDFLAGS = -specs=linker.specs -g $(ARCH)
|
LDFLAGS = -specs=linker.specs -g $(ARCH)
|
||||||
|
|
||||||
|
|
|
@ -147,7 +147,7 @@ enum sdmmc_register_bits {
|
||||||
MMC_DMA_BOUNDARY_MAXIMUM = (0x3 << 12),
|
MMC_DMA_BOUNDARY_MAXIMUM = (0x3 << 12),
|
||||||
MMC_DMA_BOUNDARY_512K = (0x3 << 12),
|
MMC_DMA_BOUNDARY_512K = (0x3 << 12),
|
||||||
MMC_DMA_BOUNDARY_16K = (0x2 << 12),
|
MMC_DMA_BOUNDARY_16K = (0x2 << 12),
|
||||||
MMC_TRANSFER_BLOCK_512B = (0x1FF << 0),
|
MMC_TRANSFER_BLOCK_512B = (0x200 << 0),
|
||||||
|
|
||||||
/* Command register */
|
/* Command register */
|
||||||
MMC_COMMAND_NUMBER_SHIFT = 8,
|
MMC_COMMAND_NUMBER_SHIFT = 8,
|
||||||
|
@ -465,18 +465,6 @@ static int sdmmc_hardware_init(struct mmc *mmc)
|
||||||
// Clear SDHCI_PROG_CLOCK_MODE
|
// Clear SDHCI_PROG_CLOCK_MODE
|
||||||
regs->clock_control &= ~(0x20);
|
regs->clock_control &= ~(0x20);
|
||||||
|
|
||||||
// Set SDHCI_CTRL2_HOST_V4_ENABLE
|
|
||||||
regs->host_control2 |= 0x1000;
|
|
||||||
|
|
||||||
// SDHCI_CAN_64BIT must be set
|
|
||||||
if (!(regs->capabilities & 0x10000000)) {
|
|
||||||
mmc_print(mmc, "missing CAN_64bit capability");
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set SDHCI_CTRL2_64BIT_ENABLE
|
|
||||||
regs->host_control2 |= 0x2000;
|
|
||||||
|
|
||||||
// Clear SDHCI_CTRL_SDMA and SDHCI_CTRL_ADMA2
|
// Clear SDHCI_CTRL_SDMA and SDHCI_CTRL_ADMA2
|
||||||
regs->host_control &= 0xE7;
|
regs->host_control &= 0xE7;
|
||||||
|
|
||||||
|
@ -782,13 +770,15 @@ static int sdmmc_handle_cpu_transfer(struct mmc *mmc, uint16_t blocks, bool is_w
|
||||||
static void sdmmc_prepare_command_data(struct mmc *mmc, uint16_t blocks, bool is_write, int argument)
|
static void sdmmc_prepare_command_data(struct mmc *mmc, uint16_t blocks, bool is_write, int argument)
|
||||||
{
|
{
|
||||||
if (blocks) {
|
if (blocks) {
|
||||||
|
uint16_t block_size = sdmmc_get_block_size(mmc, is_write);
|
||||||
|
|
||||||
// If we're using DMA, target our bounce buffer.
|
// If we're using DMA, target our bounce buffer.
|
||||||
if (mmc->use_dma)
|
if (mmc->use_dma)
|
||||||
mmc->regs->dma_address = (uint32_t)sdmmc_bounce_buffer;
|
mmc->regs->dma_address = (uint32_t)sdmmc_bounce_buffer;
|
||||||
|
|
||||||
// Set up the DMA block size and count.
|
// Set up the DMA block size and count.
|
||||||
// This is synchronized with the size of our bounce buffer.
|
// This is synchronized with the size of our bounce buffer.
|
||||||
mmc->regs->block_size = sdmmc_bounce_dma_boundary | MMC_TRANSFER_BLOCK_512B;
|
mmc->regs->block_size = sdmmc_bounce_dma_boundary | block_size;
|
||||||
mmc->regs->block_count = blocks;
|
mmc->regs->block_count = blocks;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -944,9 +934,6 @@ static int sdmmc_send_command(struct mmc *mmc, enum sdmmc_command command,
|
||||||
uint32_t total_data_to_xfer = sdmmc_get_block_size(mmc, is_write) * blocks_to_transfer;
|
uint32_t total_data_to_xfer = sdmmc_get_block_size(mmc, is_write) * blocks_to_transfer;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
// XXX: get rid of
|
|
||||||
mmc_print(mmc, "issuing CMD%d", command);
|
|
||||||
|
|
||||||
// If this transfer would have us send more than we can, fail out.
|
// If this transfer would have us send more than we can, fail out.
|
||||||
if (total_data_to_xfer > sizeof(sdmmc_bounce_buffer)) {
|
if (total_data_to_xfer > sizeof(sdmmc_bounce_buffer)) {
|
||||||
mmc_print(mmc, "ERROR: transfer is larger than our maximum DMA transfer size!");
|
mmc_print(mmc, "ERROR: transfer is larger than our maximum DMA transfer size!");
|
||||||
|
@ -1034,18 +1021,6 @@ static int sdmmc_send_command(struct mmc *mmc, enum sdmmc_command command,
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// XXX: get rid of this
|
|
||||||
printk("read result (%d):\n", total_data_to_xfer);
|
|
||||||
for (int i = 0; i < 64; ++i) {
|
|
||||||
|
|
||||||
if(i % 8 == 0) {
|
|
||||||
printk("\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
printk("%02x ", ((uint8_t *)data_buffer)[i]);
|
|
||||||
}
|
|
||||||
printk("\n");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Disable resporting psuedo-interrupts.
|
// Disable resporting psuedo-interrupts.
|
||||||
|
@ -1303,7 +1278,7 @@ static int sdmmc_set_up_block_transfer_size(struct mmc *mmc)
|
||||||
*/
|
*/
|
||||||
static int sdmmc_optimize_transfer_mode(struct mmc *mmc)
|
static int sdmmc_optimize_transfer_mode(struct mmc *mmc)
|
||||||
{
|
{
|
||||||
// TODO: FIXME
|
// FIXME: use this to setup higher data widths
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1419,12 +1394,10 @@ int sdmmc_init(struct mmc *mmc, enum sdmmc_controller controller)
|
||||||
mmc->card_type = MMC_CARD_EMMC;
|
mmc->card_type = MMC_CARD_EMMC;
|
||||||
|
|
||||||
// Default to a timeout of 1S.
|
// Default to a timeout of 1S.
|
||||||
// FIXME: lower
|
|
||||||
// FIXME: abstract
|
|
||||||
mmc->timeout = 1000000;
|
mmc->timeout = 1000000;
|
||||||
|
|
||||||
// FIXME: make this configurable?
|
// Use DMA, by default.
|
||||||
mmc->use_dma = false;
|
mmc->use_dma = true;
|
||||||
|
|
||||||
// Default to relative address of zero.
|
// Default to relative address of zero.
|
||||||
mmc->relative_address = 0;
|
mmc->relative_address = 0;
|
||||||
|
|
Loading…
Reference in a new issue