|
|
@@ -55,18 +55,18 @@
|
|
|
void tmio_mmc_enable_mmc_irqs(struct tmio_mmc_host *host, u32 i)
|
|
|
{
|
|
|
host->sdcard_irq_mask &= ~(i & TMIO_MASK_IRQ);
|
|
|
- sd_ctrl_write32(host, CTL_IRQ_MASK, host->sdcard_irq_mask);
|
|
|
+ sd_ctrl_write32_as_16_and_16(host, CTL_IRQ_MASK, host->sdcard_irq_mask);
|
|
|
}
|
|
|
|
|
|
void tmio_mmc_disable_mmc_irqs(struct tmio_mmc_host *host, u32 i)
|
|
|
{
|
|
|
host->sdcard_irq_mask |= (i & TMIO_MASK_IRQ);
|
|
|
- sd_ctrl_write32(host, CTL_IRQ_MASK, host->sdcard_irq_mask);
|
|
|
+ sd_ctrl_write32_as_16_and_16(host, CTL_IRQ_MASK, host->sdcard_irq_mask);
|
|
|
}
|
|
|
|
|
|
static void tmio_mmc_ack_mmc_irqs(struct tmio_mmc_host *host, u32 i)
|
|
|
{
|
|
|
- sd_ctrl_write32(host, CTL_STATUS, ~i);
|
|
|
+ sd_ctrl_write32_as_16_and_16(host, CTL_STATUS, ~i);
|
|
|
}
|
|
|
|
|
|
static void tmio_mmc_init_sg(struct tmio_mmc_host *host, struct mmc_data *data)
|
|
|
@@ -375,7 +375,7 @@ static int tmio_mmc_start_command(struct tmio_mmc_host *host, struct mmc_command
|
|
|
tmio_mmc_enable_mmc_irqs(host, irq_mask);
|
|
|
|
|
|
/* Fire off the command */
|
|
|
- sd_ctrl_write32(host, CTL_ARG_REG, cmd->arg);
|
|
|
+ sd_ctrl_write32_as_16_and_16(host, CTL_ARG_REG, cmd->arg);
|
|
|
sd_ctrl_write16(host, CTL_SD_CMD, c);
|
|
|
|
|
|
return 0;
|
|
|
@@ -530,7 +530,7 @@ static void tmio_mmc_data_irq(struct tmio_mmc_host *host)
|
|
|
goto out;
|
|
|
|
|
|
if (host->chan_tx && (data->flags & MMC_DATA_WRITE) && !host->force_pio) {
|
|
|
- u32 status = sd_ctrl_read32(host, CTL_STATUS);
|
|
|
+ u32 status = sd_ctrl_read16_and_16_as_32(host, CTL_STATUS);
|
|
|
bool done = false;
|
|
|
|
|
|
/*
|
|
|
@@ -585,7 +585,7 @@ static void tmio_mmc_cmd_irq(struct tmio_mmc_host *host,
|
|
|
*/
|
|
|
|
|
|
for (i = 3, addr = CTL_RESPONSE ; i >= 0 ; i--, addr += 4)
|
|
|
- cmd->resp[i] = sd_ctrl_read32(host, addr);
|
|
|
+ cmd->resp[i] = sd_ctrl_read16_and_16_as_32(host, addr);
|
|
|
|
|
|
if (cmd->flags & MMC_RSP_136) {
|
|
|
cmd->resp[0] = (cmd->resp[0] << 8) | (cmd->resp[1] >> 24);
|
|
|
@@ -702,14 +702,14 @@ irqreturn_t tmio_mmc_irq(int irq, void *devid)
|
|
|
struct tmio_mmc_host *host = devid;
|
|
|
unsigned int ireg, status;
|
|
|
|
|
|
- status = sd_ctrl_read32(host, CTL_STATUS);
|
|
|
+ status = sd_ctrl_read16_and_16_as_32(host, CTL_STATUS);
|
|
|
ireg = status & TMIO_MASK_IRQ & ~host->sdcard_irq_mask;
|
|
|
|
|
|
pr_debug_status(status);
|
|
|
pr_debug_status(ireg);
|
|
|
|
|
|
/* Clear the status except the interrupt status */
|
|
|
- sd_ctrl_write32(host, CTL_STATUS, TMIO_MASK_IRQ);
|
|
|
+ sd_ctrl_write32_as_16_and_16(host, CTL_STATUS, TMIO_MASK_IRQ);
|
|
|
|
|
|
if (__tmio_mmc_card_detect_irq(host, ireg, status))
|
|
|
return IRQ_HANDLED;
|
|
|
@@ -944,7 +944,7 @@ static int tmio_mmc_get_ro(struct mmc_host *mmc)
|
|
|
return ret;
|
|
|
|
|
|
ret = !((pdata->flags & TMIO_MMC_WRPROTECT_DISABLE) ||
|
|
|
- (sd_ctrl_read32(host, CTL_STATUS) & TMIO_STAT_WRPROTECT));
|
|
|
+ (sd_ctrl_read16_and_16_as_32(host, CTL_STATUS) & TMIO_STAT_WRPROTECT));
|
|
|
|
|
|
return ret;
|
|
|
}
|
|
|
@@ -964,7 +964,7 @@ static int tmio_mmc_card_busy(struct mmc_host *mmc)
|
|
|
{
|
|
|
struct tmio_mmc_host *host = mmc_priv(mmc);
|
|
|
|
|
|
- return !(sd_ctrl_read32(host, CTL_STATUS2) & TMIO_STATUS2_DAT0);
|
|
|
+ return !(sd_ctrl_read16_and_16_as_32(host, CTL_STATUS2) & TMIO_STATUS2_DAT0);
|
|
|
}
|
|
|
|
|
|
static struct mmc_host_ops tmio_mmc_ops = {
|
|
|
@@ -1113,7 +1113,7 @@ int tmio_mmc_host_probe(struct tmio_mmc_host *_host,
|
|
|
tmio_mmc_clk_stop(_host);
|
|
|
tmio_mmc_reset(_host);
|
|
|
|
|
|
- _host->sdcard_irq_mask = sd_ctrl_read32(_host, CTL_IRQ_MASK);
|
|
|
+ _host->sdcard_irq_mask = sd_ctrl_read16_and_16_as_32(_host, CTL_IRQ_MASK);
|
|
|
tmio_mmc_disable_mmc_irqs(_host, TMIO_MASK_ALL);
|
|
|
|
|
|
/* Unmask the IRQs we want to know about */
|