diff options
Diffstat (limited to 'drivers/mmc')
-rw-r--r-- | drivers/mmc/omap.c | 90 | ||||
-rw-r--r-- | drivers/mmc/omap.h | 4 |
2 files changed, 47 insertions, 47 deletions
diff --git a/drivers/mmc/omap.c b/drivers/mmc/omap.c index 4bf7df8c4275..efd14cf60f89 100644 --- a/drivers/mmc/omap.c +++ b/drivers/mmc/omap.c | |||
@@ -192,16 +192,16 @@ mmc_omap_start_command(struct mmc_omap_host *host, struct mmc_command *cmd) | |||
192 | 192 | ||
193 | clk_enable(host->fclk); | 193 | clk_enable(host->fclk); |
194 | 194 | ||
195 | OMAP_MMC_WRITE(host->base, CTO, 200); | 195 | OMAP_MMC_WRITE(host, CTO, 200); |
196 | OMAP_MMC_WRITE(host->base, ARGL, cmd->arg & 0xffff); | 196 | OMAP_MMC_WRITE(host, ARGL, cmd->arg & 0xffff); |
197 | OMAP_MMC_WRITE(host->base, ARGH, cmd->arg >> 16); | 197 | OMAP_MMC_WRITE(host, ARGH, cmd->arg >> 16); |
198 | OMAP_MMC_WRITE(host->base, IE, | 198 | OMAP_MMC_WRITE(host, IE, |
199 | OMAP_MMC_STAT_A_EMPTY | OMAP_MMC_STAT_A_FULL | | 199 | OMAP_MMC_STAT_A_EMPTY | OMAP_MMC_STAT_A_FULL | |
200 | OMAP_MMC_STAT_CMD_CRC | OMAP_MMC_STAT_CMD_TOUT | | 200 | OMAP_MMC_STAT_CMD_CRC | OMAP_MMC_STAT_CMD_TOUT | |
201 | OMAP_MMC_STAT_DATA_CRC | OMAP_MMC_STAT_DATA_TOUT | | 201 | OMAP_MMC_STAT_DATA_CRC | OMAP_MMC_STAT_DATA_TOUT | |
202 | OMAP_MMC_STAT_END_OF_CMD | OMAP_MMC_STAT_CARD_ERR | | 202 | OMAP_MMC_STAT_END_OF_CMD | OMAP_MMC_STAT_CARD_ERR | |
203 | OMAP_MMC_STAT_END_OF_DATA); | 203 | OMAP_MMC_STAT_END_OF_DATA); |
204 | OMAP_MMC_WRITE(host->base, CMD, cmdreg); | 204 | OMAP_MMC_WRITE(host, CMD, cmdreg); |
205 | } | 205 | } |
206 | 206 | ||
207 | static void | 207 | static void |
@@ -297,22 +297,22 @@ mmc_omap_cmd_done(struct mmc_omap_host *host, struct mmc_command *cmd) | |||
297 | if (cmd->flags & MMC_RSP_136) { | 297 | if (cmd->flags & MMC_RSP_136) { |
298 | /* response type 2 */ | 298 | /* response type 2 */ |
299 | cmd->resp[3] = | 299 | cmd->resp[3] = |
300 | OMAP_MMC_READ(host->base, RSP0) | | 300 | OMAP_MMC_READ(host, RSP0) | |
301 | (OMAP_MMC_READ(host->base, RSP1) << 16); | 301 | (OMAP_MMC_READ(host, RSP1) << 16); |
302 | cmd->resp[2] = | 302 | cmd->resp[2] = |
303 | OMAP_MMC_READ(host->base, RSP2) | | 303 | OMAP_MMC_READ(host, RSP2) | |
304 | (OMAP_MMC_READ(host->base, RSP3) << 16); | 304 | (OMAP_MMC_READ(host, RSP3) << 16); |
305 | cmd->resp[1] = | 305 | cmd->resp[1] = |
306 | OMAP_MMC_READ(host->base, RSP4) | | 306 | OMAP_MMC_READ(host, RSP4) | |
307 | (OMAP_MMC_READ(host->base, RSP5) << 16); | 307 | (OMAP_MMC_READ(host, RSP5) << 16); |
308 | cmd->resp[0] = | 308 | cmd->resp[0] = |
309 | OMAP_MMC_READ(host->base, RSP6) | | 309 | OMAP_MMC_READ(host, RSP6) | |
310 | (OMAP_MMC_READ(host->base, RSP7) << 16); | 310 | (OMAP_MMC_READ(host, RSP7) << 16); |
311 | } else { | 311 | } else { |
312 | /* response types 1, 1b, 3, 4, 5, 6 */ | 312 | /* response types 1, 1b, 3, 4, 5, 6 */ |
313 | cmd->resp[0] = | 313 | cmd->resp[0] = |
314 | OMAP_MMC_READ(host->base, RSP6) | | 314 | OMAP_MMC_READ(host, RSP6) | |
315 | (OMAP_MMC_READ(host->base, RSP7) << 16); | 315 | (OMAP_MMC_READ(host, RSP7) << 16); |
316 | } | 316 | } |
317 | } | 317 | } |
318 | 318 | ||
@@ -387,11 +387,11 @@ static irqreturn_t mmc_omap_irq(int irq, void *dev_id) | |||
387 | int transfer_error; | 387 | int transfer_error; |
388 | 388 | ||
389 | if (host->cmd == NULL && host->data == NULL) { | 389 | if (host->cmd == NULL && host->data == NULL) { |
390 | status = OMAP_MMC_READ(host->base, STAT); | 390 | status = OMAP_MMC_READ(host, STAT); |
391 | dev_info(mmc_dev(host->mmc),"spurious irq 0x%04x\n", status); | 391 | dev_info(mmc_dev(host->mmc),"spurious irq 0x%04x\n", status); |
392 | if (status != 0) { | 392 | if (status != 0) { |
393 | OMAP_MMC_WRITE(host->base, STAT, status); | 393 | OMAP_MMC_WRITE(host, STAT, status); |
394 | OMAP_MMC_WRITE(host->base, IE, 0); | 394 | OMAP_MMC_WRITE(host, IE, 0); |
395 | } | 395 | } |
396 | return IRQ_HANDLED; | 396 | return IRQ_HANDLED; |
397 | } | 397 | } |
@@ -400,8 +400,8 @@ static irqreturn_t mmc_omap_irq(int irq, void *dev_id) | |||
400 | end_transfer = 0; | 400 | end_transfer = 0; |
401 | transfer_error = 0; | 401 | transfer_error = 0; |
402 | 402 | ||
403 | while ((status = OMAP_MMC_READ(host->base, STAT)) != 0) { | 403 | while ((status = OMAP_MMC_READ(host, STAT)) != 0) { |
404 | OMAP_MMC_WRITE(host->base, STAT, status); | 404 | OMAP_MMC_WRITE(host, STAT, status); |
405 | #ifdef CONFIG_MMC_DEBUG | 405 | #ifdef CONFIG_MMC_DEBUG |
406 | dev_dbg(mmc_dev(host->mmc), "MMC IRQ %04x (CMD %d): ", | 406 | dev_dbg(mmc_dev(host->mmc), "MMC IRQ %04x (CMD %d): ", |
407 | status, host->cmd != NULL ? host->cmd->opcode : -1); | 407 | status, host->cmd != NULL ? host->cmd->opcode : -1); |
@@ -471,8 +471,8 @@ static irqreturn_t mmc_omap_irq(int irq, void *dev_id) | |||
471 | 471 | ||
472 | if (status & OMAP_MMC_STAT_CARD_ERR) { | 472 | if (status & OMAP_MMC_STAT_CARD_ERR) { |
473 | if (host->cmd && host->cmd->opcode == MMC_STOP_TRANSMISSION) { | 473 | if (host->cmd && host->cmd->opcode == MMC_STOP_TRANSMISSION) { |
474 | u32 response = OMAP_MMC_READ(host->base, RSP6) | 474 | u32 response = OMAP_MMC_READ(host, RSP6) |
475 | | (OMAP_MMC_READ(host->base, RSP7) << 16); | 475 | | (OMAP_MMC_READ(host, RSP7) << 16); |
476 | /* STOP sometimes sets must-ignore bits */ | 476 | /* STOP sometimes sets must-ignore bits */ |
477 | if (!(response & (R1_CC_ERROR | 477 | if (!(response & (R1_CC_ERROR |
478 | | R1_ILLEGAL_COMMAND | 478 | | R1_ILLEGAL_COMMAND |
@@ -644,7 +644,7 @@ mmc_omap_prepare_dma(struct mmc_omap_host *host, struct mmc_data *data) | |||
644 | if (unlikely(count > 0xffff)) | 644 | if (unlikely(count > 0xffff)) |
645 | BUG(); | 645 | BUG(); |
646 | 646 | ||
647 | OMAP_MMC_WRITE(host->base, BUF, buf); | 647 | OMAP_MMC_WRITE(host, BUF, buf); |
648 | omap_set_dma_transfer_params(dma_ch, OMAP_DMA_DATA_TYPE_S16, | 648 | omap_set_dma_transfer_params(dma_ch, OMAP_DMA_DATA_TYPE_S16, |
649 | frame, count, OMAP_DMA_SYNC_FRAME, | 649 | frame, count, OMAP_DMA_SYNC_FRAME, |
650 | sync_dev, 0); | 650 | sync_dev, 0); |
@@ -729,11 +729,11 @@ static inline void set_cmd_timeout(struct mmc_omap_host *host, struct mmc_reques | |||
729 | { | 729 | { |
730 | u16 reg; | 730 | u16 reg; |
731 | 731 | ||
732 | reg = OMAP_MMC_READ(host->base, SDIO); | 732 | reg = OMAP_MMC_READ(host, SDIO); |
733 | reg &= ~(1 << 5); | 733 | reg &= ~(1 << 5); |
734 | OMAP_MMC_WRITE(host->base, SDIO, reg); | 734 | OMAP_MMC_WRITE(host, SDIO, reg); |
735 | /* Set maximum timeout */ | 735 | /* Set maximum timeout */ |
736 | OMAP_MMC_WRITE(host->base, CTO, 0xff); | 736 | OMAP_MMC_WRITE(host, CTO, 0xff); |
737 | } | 737 | } |
738 | 738 | ||
739 | static inline void set_data_timeout(struct mmc_omap_host *host, struct mmc_request *req) | 739 | static inline void set_data_timeout(struct mmc_omap_host *host, struct mmc_request *req) |
@@ -747,14 +747,14 @@ static inline void set_data_timeout(struct mmc_omap_host *host, struct mmc_reque | |||
747 | timeout = req->data->timeout_clks + req->data->timeout_ns / 500; | 747 | timeout = req->data->timeout_clks + req->data->timeout_ns / 500; |
748 | 748 | ||
749 | /* Check if we need to use timeout multiplier register */ | 749 | /* Check if we need to use timeout multiplier register */ |
750 | reg = OMAP_MMC_READ(host->base, SDIO); | 750 | reg = OMAP_MMC_READ(host, SDIO); |
751 | if (timeout > 0xffff) { | 751 | if (timeout > 0xffff) { |
752 | reg |= (1 << 5); | 752 | reg |= (1 << 5); |
753 | timeout /= 1024; | 753 | timeout /= 1024; |
754 | } else | 754 | } else |
755 | reg &= ~(1 << 5); | 755 | reg &= ~(1 << 5); |
756 | OMAP_MMC_WRITE(host->base, SDIO, reg); | 756 | OMAP_MMC_WRITE(host, SDIO, reg); |
757 | OMAP_MMC_WRITE(host->base, DTO, timeout); | 757 | OMAP_MMC_WRITE(host, DTO, timeout); |
758 | } | 758 | } |
759 | 759 | ||
760 | static void | 760 | static void |
@@ -766,9 +766,9 @@ mmc_omap_prepare_data(struct mmc_omap_host *host, struct mmc_request *req) | |||
766 | 766 | ||
767 | host->data = data; | 767 | host->data = data; |
768 | if (data == NULL) { | 768 | if (data == NULL) { |
769 | OMAP_MMC_WRITE(host->base, BLEN, 0); | 769 | OMAP_MMC_WRITE(host, BLEN, 0); |
770 | OMAP_MMC_WRITE(host->base, NBLK, 0); | 770 | OMAP_MMC_WRITE(host, NBLK, 0); |
771 | OMAP_MMC_WRITE(host->base, BUF, 0); | 771 | OMAP_MMC_WRITE(host, BUF, 0); |
772 | host->dma_in_use = 0; | 772 | host->dma_in_use = 0; |
773 | set_cmd_timeout(host, req); | 773 | set_cmd_timeout(host, req); |
774 | return; | 774 | return; |
@@ -777,8 +777,8 @@ mmc_omap_prepare_data(struct mmc_omap_host *host, struct mmc_request *req) | |||
777 | 777 | ||
778 | block_size = data->blksz; | 778 | block_size = data->blksz; |
779 | 779 | ||
780 | OMAP_MMC_WRITE(host->base, NBLK, data->blocks - 1); | 780 | OMAP_MMC_WRITE(host, NBLK, data->blocks - 1); |
781 | OMAP_MMC_WRITE(host->base, BLEN, block_size - 1); | 781 | OMAP_MMC_WRITE(host, BLEN, block_size - 1); |
782 | set_data_timeout(host, req); | 782 | set_data_timeout(host, req); |
783 | 783 | ||
784 | /* cope with calling layer confusion; it issues "single | 784 | /* cope with calling layer confusion; it issues "single |
@@ -820,7 +820,7 @@ mmc_omap_prepare_data(struct mmc_omap_host *host, struct mmc_request *req) | |||
820 | 820 | ||
821 | /* Revert to PIO? */ | 821 | /* Revert to PIO? */ |
822 | if (!use_dma) { | 822 | if (!use_dma) { |
823 | OMAP_MMC_WRITE(host->base, BUF, 0x1f1f); | 823 | OMAP_MMC_WRITE(host, BUF, 0x1f1f); |
824 | host->total_bytes_left = data->blocks * block_size; | 824 | host->total_bytes_left = data->blocks * block_size; |
825 | host->sg_len = sg_len; | 825 | host->sg_len = sg_len; |
826 | mmc_omap_sg_to_buf(host); | 826 | mmc_omap_sg_to_buf(host); |
@@ -872,8 +872,8 @@ static void mmc_omap_power(struct mmc_omap_host *host, int on) | |||
872 | /* GPIO 4 of TPS65010 sends SD_EN signal */ | 872 | /* GPIO 4 of TPS65010 sends SD_EN signal */ |
873 | tps65010_set_gpio_out_value(GPIO4, HIGH); | 873 | tps65010_set_gpio_out_value(GPIO4, HIGH); |
874 | else if (cpu_is_omap24xx()) { | 874 | else if (cpu_is_omap24xx()) { |
875 | u16 reg = OMAP_MMC_READ(host->base, CON); | 875 | u16 reg = OMAP_MMC_READ(host, CON); |
876 | OMAP_MMC_WRITE(host->base, CON, reg | (1 << 11)); | 876 | OMAP_MMC_WRITE(host, CON, reg | (1 << 11)); |
877 | } else | 877 | } else |
878 | if (host->power_pin >= 0) | 878 | if (host->power_pin >= 0) |
879 | omap_set_gpio_dataout(host->power_pin, 1); | 879 | omap_set_gpio_dataout(host->power_pin, 1); |
@@ -885,8 +885,8 @@ static void mmc_omap_power(struct mmc_omap_host *host, int on) | |||
885 | else if (machine_is_omap_h3()) | 885 | else if (machine_is_omap_h3()) |
886 | tps65010_set_gpio_out_value(GPIO4, LOW); | 886 | tps65010_set_gpio_out_value(GPIO4, LOW); |
887 | else if (cpu_is_omap24xx()) { | 887 | else if (cpu_is_omap24xx()) { |
888 | u16 reg = OMAP_MMC_READ(host->base, CON); | 888 | u16 reg = OMAP_MMC_READ(host, CON); |
889 | OMAP_MMC_WRITE(host->base, CON, reg & ~(1 << 11)); | 889 | OMAP_MMC_WRITE(host, CON, reg & ~(1 << 11)); |
890 | } else | 890 | } else |
891 | if (host->power_pin >= 0) | 891 | if (host->power_pin >= 0) |
892 | omap_set_gpio_dataout(host->power_pin, 0); | 892 | omap_set_gpio_dataout(host->power_pin, 0); |
@@ -942,14 +942,14 @@ static void mmc_omap_set_ios(struct mmc_host *mmc, struct mmc_ios *ios) | |||
942 | * which results in the while loop below getting stuck. | 942 | * which results in the while loop below getting stuck. |
943 | * Writing to the CON register twice seems to do the trick. */ | 943 | * Writing to the CON register twice seems to do the trick. */ |
944 | for (i = 0; i < 2; i++) | 944 | for (i = 0; i < 2; i++) |
945 | OMAP_MMC_WRITE(host->base, CON, dsor); | 945 | OMAP_MMC_WRITE(host, CON, dsor); |
946 | if (ios->power_mode == MMC_POWER_UP) { | 946 | if (ios->power_mode == MMC_POWER_UP) { |
947 | /* Send clock cycles, poll completion */ | 947 | /* Send clock cycles, poll completion */ |
948 | OMAP_MMC_WRITE(host->base, IE, 0); | 948 | OMAP_MMC_WRITE(host, IE, 0); |
949 | OMAP_MMC_WRITE(host->base, STAT, 0xffff); | 949 | OMAP_MMC_WRITE(host, STAT, 0xffff); |
950 | OMAP_MMC_WRITE(host->base, CMD, 1<<7); | 950 | OMAP_MMC_WRITE(host, CMD, 1<<7); |
951 | while (0 == (OMAP_MMC_READ(host->base, STAT) & 1)); | 951 | while (0 == (OMAP_MMC_READ(host, STAT) & 1)); |
952 | OMAP_MMC_WRITE(host->base, STAT, 1); | 952 | OMAP_MMC_WRITE(host, STAT, 1); |
953 | } | 953 | } |
954 | clk_disable(host->fclk); | 954 | clk_disable(host->fclk); |
955 | } | 955 | } |
diff --git a/drivers/mmc/omap.h b/drivers/mmc/omap.h index c954d355a5e3..11bf2ee32d6d 100644 --- a/drivers/mmc/omap.h +++ b/drivers/mmc/omap.h | |||
@@ -41,8 +41,8 @@ | |||
41 | #define OMAP_MMC_STAT_CARD_BUSY (1 << 2) | 41 | #define OMAP_MMC_STAT_CARD_BUSY (1 << 2) |
42 | #define OMAP_MMC_STAT_END_OF_CMD (1 << 0) | 42 | #define OMAP_MMC_STAT_END_OF_CMD (1 << 0) |
43 | 43 | ||
44 | #define OMAP_MMC_READ(base, reg) __raw_readw((base) + OMAP_MMC_REG_##reg) | 44 | #define OMAP_MMC_READ(host, reg) __raw_readw((host)->virt_base + OMAP_MMC_REG_##reg) |
45 | #define OMAP_MMC_WRITE(base, reg, val) __raw_writew((val), (base) + OMAP_MMC_REG_##reg) | 45 | #define OMAP_MMC_WRITE(host, reg, val) __raw_writew((val), (host)->virt_base + OMAP_MMC_REG_##reg) |
46 | 46 | ||
47 | /* | 47 | /* |
48 | * Command types | 48 | * Command types |