Lines Matching full:host

43 #include <linux/mmc/host.h>
258 #define sh_mmcif_host_to_dev(host) (&host->pd->dev) argument
260 static inline void sh_mmcif_bitset(struct sh_mmcif_host *host, in sh_mmcif_bitset() argument
263 writel(val | readl(host->addr + reg), host->addr + reg); in sh_mmcif_bitset()
266 static inline void sh_mmcif_bitclr(struct sh_mmcif_host *host, in sh_mmcif_bitclr() argument
269 writel(~val & readl(host->addr + reg), host->addr + reg); in sh_mmcif_bitclr()
274 struct sh_mmcif_host *host = arg; in sh_mmcif_dma_complete() local
275 struct mmc_request *mrq = host->mrq; in sh_mmcif_dma_complete()
276 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_dma_complete()
284 complete(&host->dma_complete); in sh_mmcif_dma_complete()
287 static void sh_mmcif_start_dma_rx(struct sh_mmcif_host *host) in sh_mmcif_start_dma_rx() argument
289 struct mmc_data *data = host->mrq->data; in sh_mmcif_start_dma_rx()
292 struct dma_chan *chan = host->chan_rx; in sh_mmcif_start_dma_rx()
293 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_start_dma_rx()
300 host->dma_active = true; in sh_mmcif_start_dma_rx()
307 desc->callback_param = host; in sh_mmcif_start_dma_rx()
309 sh_mmcif_bitset(host, MMCIF_CE_BUF_ACC, BUF_ACC_DMAREN); in sh_mmcif_start_dma_rx()
319 host->chan_rx = NULL; in sh_mmcif_start_dma_rx()
320 host->dma_active = false; in sh_mmcif_start_dma_rx()
323 chan = host->chan_tx; in sh_mmcif_start_dma_rx()
325 host->chan_tx = NULL; in sh_mmcif_start_dma_rx()
330 sh_mmcif_bitclr(host, MMCIF_CE_BUF_ACC, BUF_ACC_DMAREN | BUF_ACC_DMAWEN); in sh_mmcif_start_dma_rx()
337 static void sh_mmcif_start_dma_tx(struct sh_mmcif_host *host) in sh_mmcif_start_dma_tx() argument
339 struct mmc_data *data = host->mrq->data; in sh_mmcif_start_dma_tx()
342 struct dma_chan *chan = host->chan_tx; in sh_mmcif_start_dma_tx()
343 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_start_dma_tx()
350 host->dma_active = true; in sh_mmcif_start_dma_tx()
357 desc->callback_param = host; in sh_mmcif_start_dma_tx()
359 sh_mmcif_bitset(host, MMCIF_CE_BUF_ACC, BUF_ACC_DMAWEN); in sh_mmcif_start_dma_tx()
369 host->chan_tx = NULL; in sh_mmcif_start_dma_tx()
370 host->dma_active = false; in sh_mmcif_start_dma_tx()
373 chan = host->chan_rx; in sh_mmcif_start_dma_tx()
375 host->chan_rx = NULL; in sh_mmcif_start_dma_tx()
380 sh_mmcif_bitclr(host, MMCIF_CE_BUF_ACC, BUF_ACC_DMAREN | BUF_ACC_DMAWEN); in sh_mmcif_start_dma_tx()
388 sh_mmcif_request_dma_pdata(struct sh_mmcif_host *host, uintptr_t slave_id) in sh_mmcif_request_dma_pdata() argument
400 static int sh_mmcif_dma_slave_config(struct sh_mmcif_host *host, in sh_mmcif_dma_slave_config() argument
407 res = platform_get_resource(host->pd, IORESOURCE_MEM, 0); in sh_mmcif_dma_slave_config()
424 static void sh_mmcif_request_dma(struct sh_mmcif_host *host) in sh_mmcif_request_dma() argument
426 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_request_dma()
427 host->dma_active = false; in sh_mmcif_request_dma()
433 host->chan_tx = sh_mmcif_request_dma_pdata(host, in sh_mmcif_request_dma()
435 host->chan_rx = sh_mmcif_request_dma_pdata(host, in sh_mmcif_request_dma()
438 host->chan_tx = dma_request_chan(dev, "tx"); in sh_mmcif_request_dma()
439 if (IS_ERR(host->chan_tx)) in sh_mmcif_request_dma()
440 host->chan_tx = NULL; in sh_mmcif_request_dma()
441 host->chan_rx = dma_request_chan(dev, "rx"); in sh_mmcif_request_dma()
442 if (IS_ERR(host->chan_rx)) in sh_mmcif_request_dma()
443 host->chan_rx = NULL; in sh_mmcif_request_dma()
445 dev_dbg(dev, "%s: got channel TX %p RX %p\n", __func__, host->chan_tx, in sh_mmcif_request_dma()
446 host->chan_rx); in sh_mmcif_request_dma()
448 if (!host->chan_tx || !host->chan_rx || in sh_mmcif_request_dma()
449 sh_mmcif_dma_slave_config(host, host->chan_tx, DMA_MEM_TO_DEV) || in sh_mmcif_request_dma()
450 sh_mmcif_dma_slave_config(host, host->chan_rx, DMA_DEV_TO_MEM)) in sh_mmcif_request_dma()
456 if (host->chan_tx) in sh_mmcif_request_dma()
457 dma_release_channel(host->chan_tx); in sh_mmcif_request_dma()
458 if (host->chan_rx) in sh_mmcif_request_dma()
459 dma_release_channel(host->chan_rx); in sh_mmcif_request_dma()
460 host->chan_tx = host->chan_rx = NULL; in sh_mmcif_request_dma()
463 static void sh_mmcif_release_dma(struct sh_mmcif_host *host) in sh_mmcif_release_dma() argument
465 sh_mmcif_bitclr(host, MMCIF_CE_BUF_ACC, BUF_ACC_DMAREN | BUF_ACC_DMAWEN); in sh_mmcif_release_dma()
467 if (host->chan_tx) { in sh_mmcif_release_dma()
468 struct dma_chan *chan = host->chan_tx; in sh_mmcif_release_dma()
469 host->chan_tx = NULL; in sh_mmcif_release_dma()
472 if (host->chan_rx) { in sh_mmcif_release_dma()
473 struct dma_chan *chan = host->chan_rx; in sh_mmcif_release_dma()
474 host->chan_rx = NULL; in sh_mmcif_release_dma()
478 host->dma_active = false; in sh_mmcif_release_dma()
481 static void sh_mmcif_clock_control(struct sh_mmcif_host *host, unsigned int clk) in sh_mmcif_clock_control() argument
483 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_clock_control()
486 unsigned int current_clk = clk_get_rate(host->clk); in sh_mmcif_clock_control()
489 sh_mmcif_bitclr(host, MMCIF_CE_CLK_CTRL, CLK_ENABLE); in sh_mmcif_clock_control()
490 sh_mmcif_bitclr(host, MMCIF_CE_CLK_CTRL, CLK_CLEAR); in sh_mmcif_clock_control()
495 if (host->clkdiv_map) { in sh_mmcif_clock_control()
503 if (!((1 << i) & host->clkdiv_map)) in sh_mmcif_clock_control()
512 freq = clk_round_rate(host->clk, clk * div); in sh_mmcif_clock_control()
526 clk_set_rate(host->clk, best_freq); in sh_mmcif_clock_control()
534 sh_mmcif_bitset(host, MMCIF_CE_CLK_CTRL, CLK_CLEAR & clkdiv); in sh_mmcif_clock_control()
535 sh_mmcif_bitset(host, MMCIF_CE_CLK_CTRL, CLK_ENABLE); in sh_mmcif_clock_control()
538 static void sh_mmcif_sync_reset(struct sh_mmcif_host *host) in sh_mmcif_sync_reset() argument
542 tmp = 0x010f0000 & sh_mmcif_readl(host->addr, MMCIF_CE_CLK_CTRL); in sh_mmcif_sync_reset()
544 sh_mmcif_writel(host->addr, MMCIF_CE_VERSION, SOFT_RST_ON); in sh_mmcif_sync_reset()
545 sh_mmcif_writel(host->addr, MMCIF_CE_VERSION, SOFT_RST_OFF); in sh_mmcif_sync_reset()
546 if (host->ccs_enable) in sh_mmcif_sync_reset()
548 if (host->clk_ctrl2_enable) in sh_mmcif_sync_reset()
549 sh_mmcif_writel(host->addr, MMCIF_CE_CLK_CTRL2, 0x0F0F0000); in sh_mmcif_sync_reset()
550 sh_mmcif_bitset(host, MMCIF_CE_CLK_CTRL, tmp | in sh_mmcif_sync_reset()
553 sh_mmcif_bitset(host, MMCIF_CE_BUF_ACC, BUF_ACC_ATYP); in sh_mmcif_sync_reset()
556 static int sh_mmcif_error_manage(struct sh_mmcif_host *host) in sh_mmcif_error_manage() argument
558 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_error_manage()
562 host->sd_error = false; in sh_mmcif_error_manage()
564 state1 = sh_mmcif_readl(host->addr, MMCIF_CE_HOST_STS1); in sh_mmcif_error_manage()
565 state2 = sh_mmcif_readl(host->addr, MMCIF_CE_HOST_STS2); in sh_mmcif_error_manage()
570 sh_mmcif_bitset(host, MMCIF_CE_CMD_CTRL, CMD_CTRL_BREAK); in sh_mmcif_error_manage()
571 sh_mmcif_bitset(host, MMCIF_CE_CMD_CTRL, ~CMD_CTRL_BREAK); in sh_mmcif_error_manage()
573 if (!(sh_mmcif_readl(host->addr, MMCIF_CE_HOST_STS1) in sh_mmcif_error_manage()
583 sh_mmcif_sync_reset(host); in sh_mmcif_error_manage()
590 host->state, host->wait_for); in sh_mmcif_error_manage()
594 host->state, host->wait_for); in sh_mmcif_error_manage()
598 host->state, host->wait_for); in sh_mmcif_error_manage()
604 static bool sh_mmcif_next_block(struct sh_mmcif_host *host, u32 *p) in sh_mmcif_next_block() argument
606 struct mmc_data *data = host->mrq->data; in sh_mmcif_next_block()
608 host->sg_blkidx += host->blocksize; in sh_mmcif_next_block()
610 /* data->sg->length must be a multiple of host->blocksize? */ in sh_mmcif_next_block()
611 BUG_ON(host->sg_blkidx > data->sg->length); in sh_mmcif_next_block()
613 if (host->sg_blkidx == data->sg->length) { in sh_mmcif_next_block()
614 host->sg_blkidx = 0; in sh_mmcif_next_block()
615 if (++host->sg_idx < data->sg_len) in sh_mmcif_next_block()
616 host->pio_ptr = sg_virt(++data->sg); in sh_mmcif_next_block()
618 host->pio_ptr = p; in sh_mmcif_next_block()
621 return host->sg_idx != data->sg_len; in sh_mmcif_next_block()
624 static void sh_mmcif_single_read(struct sh_mmcif_host *host, in sh_mmcif_single_read() argument
627 host->blocksize = (sh_mmcif_readl(host->addr, MMCIF_CE_BLOCK_SET) & in sh_mmcif_single_read()
630 host->wait_for = MMCIF_WAIT_FOR_READ; in sh_mmcif_single_read()
633 sh_mmcif_bitset(host, MMCIF_CE_INT_MASK, MASK_MBUFREN); in sh_mmcif_single_read()
636 static bool sh_mmcif_read_block(struct sh_mmcif_host *host) in sh_mmcif_read_block() argument
638 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_read_block()
639 struct mmc_data *data = host->mrq->data; in sh_mmcif_read_block()
643 if (host->sd_error) { in sh_mmcif_read_block()
644 data->error = sh_mmcif_error_manage(host); in sh_mmcif_read_block()
649 for (i = 0; i < host->blocksize / 4; i++) in sh_mmcif_read_block()
650 *p++ = sh_mmcif_readl(host->addr, MMCIF_CE_DATA); in sh_mmcif_read_block()
653 sh_mmcif_bitset(host, MMCIF_CE_INT_MASK, MASK_MBUFRE); in sh_mmcif_read_block()
654 host->wait_for = MMCIF_WAIT_FOR_READ_END; in sh_mmcif_read_block()
659 static void sh_mmcif_multi_read(struct sh_mmcif_host *host, in sh_mmcif_multi_read() argument
667 host->blocksize = sh_mmcif_readl(host->addr, MMCIF_CE_BLOCK_SET) & in sh_mmcif_multi_read()
670 host->wait_for = MMCIF_WAIT_FOR_MREAD; in sh_mmcif_multi_read()
671 host->sg_idx = 0; in sh_mmcif_multi_read()
672 host->sg_blkidx = 0; in sh_mmcif_multi_read()
673 host->pio_ptr = sg_virt(data->sg); in sh_mmcif_multi_read()
675 sh_mmcif_bitset(host, MMCIF_CE_INT_MASK, MASK_MBUFREN); in sh_mmcif_multi_read()
678 static bool sh_mmcif_mread_block(struct sh_mmcif_host *host) in sh_mmcif_mread_block() argument
680 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_mread_block()
681 struct mmc_data *data = host->mrq->data; in sh_mmcif_mread_block()
682 u32 *p = host->pio_ptr; in sh_mmcif_mread_block()
685 if (host->sd_error) { in sh_mmcif_mread_block()
686 data->error = sh_mmcif_error_manage(host); in sh_mmcif_mread_block()
693 for (i = 0; i < host->blocksize / 4; i++) in sh_mmcif_mread_block()
694 *p++ = sh_mmcif_readl(host->addr, MMCIF_CE_DATA); in sh_mmcif_mread_block()
696 if (!sh_mmcif_next_block(host, p)) in sh_mmcif_mread_block()
699 sh_mmcif_bitset(host, MMCIF_CE_INT_MASK, MASK_MBUFREN); in sh_mmcif_mread_block()
704 static void sh_mmcif_single_write(struct sh_mmcif_host *host, in sh_mmcif_single_write() argument
707 host->blocksize = (sh_mmcif_readl(host->addr, MMCIF_CE_BLOCK_SET) & in sh_mmcif_single_write()
710 host->wait_for = MMCIF_WAIT_FOR_WRITE; in sh_mmcif_single_write()
713 sh_mmcif_bitset(host, MMCIF_CE_INT_MASK, MASK_MBUFWEN); in sh_mmcif_single_write()
716 static bool sh_mmcif_write_block(struct sh_mmcif_host *host) in sh_mmcif_write_block() argument
718 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_write_block()
719 struct mmc_data *data = host->mrq->data; in sh_mmcif_write_block()
723 if (host->sd_error) { in sh_mmcif_write_block()
724 data->error = sh_mmcif_error_manage(host); in sh_mmcif_write_block()
729 for (i = 0; i < host->blocksize / 4; i++) in sh_mmcif_write_block()
730 sh_mmcif_writel(host->addr, MMCIF_CE_DATA, *p++); in sh_mmcif_write_block()
733 sh_mmcif_bitset(host, MMCIF_CE_INT_MASK, MASK_MDTRANE); in sh_mmcif_write_block()
734 host->wait_for = MMCIF_WAIT_FOR_WRITE_END; in sh_mmcif_write_block()
739 static void sh_mmcif_multi_write(struct sh_mmcif_host *host, in sh_mmcif_multi_write() argument
747 host->blocksize = sh_mmcif_readl(host->addr, MMCIF_CE_BLOCK_SET) & in sh_mmcif_multi_write()
750 host->wait_for = MMCIF_WAIT_FOR_MWRITE; in sh_mmcif_multi_write()
751 host->sg_idx = 0; in sh_mmcif_multi_write()
752 host->sg_blkidx = 0; in sh_mmcif_multi_write()
753 host->pio_ptr = sg_virt(data->sg); in sh_mmcif_multi_write()
755 sh_mmcif_bitset(host, MMCIF_CE_INT_MASK, MASK_MBUFWEN); in sh_mmcif_multi_write()
758 static bool sh_mmcif_mwrite_block(struct sh_mmcif_host *host) in sh_mmcif_mwrite_block() argument
760 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_mwrite_block()
761 struct mmc_data *data = host->mrq->data; in sh_mmcif_mwrite_block()
762 u32 *p = host->pio_ptr; in sh_mmcif_mwrite_block()
765 if (host->sd_error) { in sh_mmcif_mwrite_block()
766 data->error = sh_mmcif_error_manage(host); in sh_mmcif_mwrite_block()
773 for (i = 0; i < host->blocksize / 4; i++) in sh_mmcif_mwrite_block()
774 sh_mmcif_writel(host->addr, MMCIF_CE_DATA, *p++); in sh_mmcif_mwrite_block()
776 if (!sh_mmcif_next_block(host, p)) in sh_mmcif_mwrite_block()
779 sh_mmcif_bitset(host, MMCIF_CE_INT_MASK, MASK_MBUFWEN); in sh_mmcif_mwrite_block()
784 static void sh_mmcif_get_response(struct sh_mmcif_host *host, in sh_mmcif_get_response() argument
788 cmd->resp[0] = sh_mmcif_readl(host->addr, MMCIF_CE_RESP3); in sh_mmcif_get_response()
789 cmd->resp[1] = sh_mmcif_readl(host->addr, MMCIF_CE_RESP2); in sh_mmcif_get_response()
790 cmd->resp[2] = sh_mmcif_readl(host->addr, MMCIF_CE_RESP1); in sh_mmcif_get_response()
791 cmd->resp[3] = sh_mmcif_readl(host->addr, MMCIF_CE_RESP0); in sh_mmcif_get_response()
793 cmd->resp[0] = sh_mmcif_readl(host->addr, MMCIF_CE_RESP0); in sh_mmcif_get_response()
796 static void sh_mmcif_get_cmd12response(struct sh_mmcif_host *host, in sh_mmcif_get_cmd12response() argument
799 cmd->resp[0] = sh_mmcif_readl(host->addr, MMCIF_CE_RESP_CMD12); in sh_mmcif_get_cmd12response()
802 static u32 sh_mmcif_set_cmd(struct sh_mmcif_host *host, in sh_mmcif_set_cmd() argument
805 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_set_cmd()
834 switch (host->bus_width) { in sh_mmcif_set_cmd()
848 switch (host->timing) { in sh_mmcif_set_cmd()
851 * MMC core will only set this timing, if the host in sh_mmcif_set_cmd()
867 sh_mmcif_bitset(host, MMCIF_CE_BLOCK_SET, in sh_mmcif_set_cmd()
885 static int sh_mmcif_data_trans(struct sh_mmcif_host *host, in sh_mmcif_data_trans() argument
888 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_data_trans()
892 sh_mmcif_multi_read(host, mrq); in sh_mmcif_data_trans()
895 sh_mmcif_multi_write(host, mrq); in sh_mmcif_data_trans()
898 sh_mmcif_single_write(host, mrq); in sh_mmcif_data_trans()
902 sh_mmcif_single_read(host, mrq); in sh_mmcif_data_trans()
910 static void sh_mmcif_start_cmd(struct sh_mmcif_host *host, in sh_mmcif_start_cmd() argument
923 if (host->ccs_enable) in sh_mmcif_start_cmd()
927 sh_mmcif_writel(host->addr, MMCIF_CE_BLOCK_SET, 0); in sh_mmcif_start_cmd()
928 sh_mmcif_writel(host->addr, MMCIF_CE_BLOCK_SET, in sh_mmcif_start_cmd()
931 opc = sh_mmcif_set_cmd(host, mrq); in sh_mmcif_start_cmd()
933 if (host->ccs_enable) in sh_mmcif_start_cmd()
934 sh_mmcif_writel(host->addr, MMCIF_CE_INT, 0xD80430C0); in sh_mmcif_start_cmd()
936 sh_mmcif_writel(host->addr, MMCIF_CE_INT, 0xD80430C0 | INT_CCS); in sh_mmcif_start_cmd()
937 sh_mmcif_writel(host->addr, MMCIF_CE_INT_MASK, mask); in sh_mmcif_start_cmd()
939 sh_mmcif_writel(host->addr, MMCIF_CE_ARG, cmd->arg); in sh_mmcif_start_cmd()
941 spin_lock_irqsave(&host->lock, flags); in sh_mmcif_start_cmd()
942 sh_mmcif_writel(host->addr, MMCIF_CE_CMD_SET, opc); in sh_mmcif_start_cmd()
944 host->wait_for = MMCIF_WAIT_FOR_CMD; in sh_mmcif_start_cmd()
945 schedule_delayed_work(&host->timeout_work, host->timeout); in sh_mmcif_start_cmd()
946 spin_unlock_irqrestore(&host->lock, flags); in sh_mmcif_start_cmd()
949 static void sh_mmcif_stop_cmd(struct sh_mmcif_host *host, in sh_mmcif_stop_cmd() argument
952 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_stop_cmd()
956 sh_mmcif_bitset(host, MMCIF_CE_INT_MASK, MASK_MCMD12DRE); in sh_mmcif_stop_cmd()
959 sh_mmcif_bitset(host, MMCIF_CE_INT_MASK, MASK_MCMD12RBE); in sh_mmcif_stop_cmd()
963 mrq->stop->error = sh_mmcif_error_manage(host); in sh_mmcif_stop_cmd()
967 host->wait_for = MMCIF_WAIT_FOR_STOP; in sh_mmcif_stop_cmd()
972 struct sh_mmcif_host *host = mmc_priv(mmc); in sh_mmcif_request() local
973 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_request()
976 spin_lock_irqsave(&host->lock, flags); in sh_mmcif_request()
977 if (host->state != STATE_IDLE) { in sh_mmcif_request()
979 __func__, host->state); in sh_mmcif_request()
980 spin_unlock_irqrestore(&host->lock, flags); in sh_mmcif_request()
986 host->state = STATE_REQUEST; in sh_mmcif_request()
987 spin_unlock_irqrestore(&host->lock, flags); in sh_mmcif_request()
989 host->mrq = mrq; in sh_mmcif_request()
991 sh_mmcif_start_cmd(host, mrq); in sh_mmcif_request()
994 static void sh_mmcif_clk_setup(struct sh_mmcif_host *host) in sh_mmcif_clk_setup() argument
996 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_clk_setup()
998 if (host->mmc->f_max) { in sh_mmcif_clk_setup()
1001 f_max = host->mmc->f_max; in sh_mmcif_clk_setup()
1003 f_min = clk_round_rate(host->clk, f_min_old / 2); in sh_mmcif_clk_setup()
1012 host->clkdiv_map = 0x3ff; in sh_mmcif_clk_setup()
1014 host->mmc->f_max = f_max >> ffs(host->clkdiv_map); in sh_mmcif_clk_setup()
1015 host->mmc->f_min = f_min >> fls(host->clkdiv_map); in sh_mmcif_clk_setup()
1017 unsigned int clk = clk_get_rate(host->clk); in sh_mmcif_clk_setup()
1019 host->mmc->f_max = clk / 2; in sh_mmcif_clk_setup()
1020 host->mmc->f_min = clk / 512; in sh_mmcif_clk_setup()
1024 host->mmc->f_max, host->mmc->f_min); in sh_mmcif_clk_setup()
1029 struct sh_mmcif_host *host = mmc_priv(mmc); in sh_mmcif_set_ios() local
1030 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_set_ios()
1033 spin_lock_irqsave(&host->lock, flags); in sh_mmcif_set_ios()
1034 if (host->state != STATE_IDLE) { in sh_mmcif_set_ios()
1036 __func__, host->state); in sh_mmcif_set_ios()
1037 spin_unlock_irqrestore(&host->lock, flags); in sh_mmcif_set_ios()
1041 host->state = STATE_IOS; in sh_mmcif_set_ios()
1042 spin_unlock_irqrestore(&host->lock, flags); in sh_mmcif_set_ios()
1048 if (!host->power) { in sh_mmcif_set_ios()
1049 clk_prepare_enable(host->clk); in sh_mmcif_set_ios()
1051 sh_mmcif_sync_reset(host); in sh_mmcif_set_ios()
1052 sh_mmcif_request_dma(host); in sh_mmcif_set_ios()
1053 host->power = true; in sh_mmcif_set_ios()
1059 if (host->power) { in sh_mmcif_set_ios()
1060 sh_mmcif_clock_control(host, 0); in sh_mmcif_set_ios()
1061 sh_mmcif_release_dma(host); in sh_mmcif_set_ios()
1063 clk_disable_unprepare(host->clk); in sh_mmcif_set_ios()
1064 host->power = false; in sh_mmcif_set_ios()
1068 sh_mmcif_clock_control(host, ios->clock); in sh_mmcif_set_ios()
1072 host->timing = ios->timing; in sh_mmcif_set_ios()
1073 host->bus_width = ios->bus_width; in sh_mmcif_set_ios()
1074 host->state = STATE_IDLE; in sh_mmcif_set_ios()
1083 static bool sh_mmcif_end_cmd(struct sh_mmcif_host *host) in sh_mmcif_end_cmd() argument
1085 struct mmc_command *cmd = host->mrq->cmd; in sh_mmcif_end_cmd()
1086 struct mmc_data *data = host->mrq->data; in sh_mmcif_end_cmd()
1087 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_end_cmd()
1090 if (host->sd_error) { in sh_mmcif_end_cmd()
1098 cmd->error = sh_mmcif_error_manage(host); in sh_mmcif_end_cmd()
1103 host->sd_error = false; in sh_mmcif_end_cmd()
1111 sh_mmcif_get_response(host, cmd); in sh_mmcif_end_cmd()
1120 init_completion(&host->dma_complete); in sh_mmcif_end_cmd()
1123 if (host->chan_rx) in sh_mmcif_end_cmd()
1124 sh_mmcif_start_dma_rx(host); in sh_mmcif_end_cmd()
1126 if (host->chan_tx) in sh_mmcif_end_cmd()
1127 sh_mmcif_start_dma_tx(host); in sh_mmcif_end_cmd()
1130 if (!host->dma_active) { in sh_mmcif_end_cmd()
1131 data->error = sh_mmcif_data_trans(host, host->mrq, cmd->opcode); in sh_mmcif_end_cmd()
1136 time = wait_for_completion_interruptible_timeout(&host->dma_complete, in sh_mmcif_end_cmd()
1137 host->timeout); in sh_mmcif_end_cmd()
1140 dma_unmap_sg(host->chan_rx->device->dev, in sh_mmcif_end_cmd()
1144 dma_unmap_sg(host->chan_tx->device->dev, in sh_mmcif_end_cmd()
1148 if (host->sd_error) { in sh_mmcif_end_cmd()
1149 dev_err(host->mmc->parent, in sh_mmcif_end_cmd()
1152 data->error = sh_mmcif_error_manage(host); in sh_mmcif_end_cmd()
1154 dev_err(host->mmc->parent, "DMA timeout!\n"); in sh_mmcif_end_cmd()
1157 dev_err(host->mmc->parent, in sh_mmcif_end_cmd()
1161 sh_mmcif_bitclr(host, MMCIF_CE_BUF_ACC, in sh_mmcif_end_cmd()
1163 host->dma_active = false; in sh_mmcif_end_cmd()
1169 dmaengine_terminate_sync(host->chan_rx); in sh_mmcif_end_cmd()
1171 dmaengine_terminate_sync(host->chan_tx); in sh_mmcif_end_cmd()
1179 struct sh_mmcif_host *host = dev_id; in sh_mmcif_irqt() local
1181 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_irqt()
1186 spin_lock_irqsave(&host->lock, flags); in sh_mmcif_irqt()
1187 wait_work = host->wait_for; in sh_mmcif_irqt()
1188 spin_unlock_irqrestore(&host->lock, flags); in sh_mmcif_irqt()
1190 cancel_delayed_work_sync(&host->timeout_work); in sh_mmcif_irqt()
1192 mutex_lock(&host->thread_lock); in sh_mmcif_irqt()
1194 mrq = host->mrq; in sh_mmcif_irqt()
1197 host->state, host->wait_for); in sh_mmcif_irqt()
1198 mutex_unlock(&host->thread_lock); in sh_mmcif_irqt()
1209 mutex_unlock(&host->thread_lock); in sh_mmcif_irqt()
1213 wait = sh_mmcif_end_cmd(host); in sh_mmcif_irqt()
1217 wait = sh_mmcif_mread_block(host); in sh_mmcif_irqt()
1221 wait = sh_mmcif_read_block(host); in sh_mmcif_irqt()
1225 wait = sh_mmcif_mwrite_block(host); in sh_mmcif_irqt()
1229 wait = sh_mmcif_write_block(host); in sh_mmcif_irqt()
1232 if (host->sd_error) { in sh_mmcif_irqt()
1233 mrq->stop->error = sh_mmcif_error_manage(host); in sh_mmcif_irqt()
1237 sh_mmcif_get_cmd12response(host, mrq->stop); in sh_mmcif_irqt()
1242 if (host->sd_error) { in sh_mmcif_irqt()
1243 mrq->data->error = sh_mmcif_error_manage(host); in sh_mmcif_irqt()
1252 schedule_delayed_work(&host->timeout_work, host->timeout); in sh_mmcif_irqt()
1254 mutex_unlock(&host->thread_lock); in sh_mmcif_irqt()
1258 if (host->wait_for != MMCIF_WAIT_FOR_STOP) { in sh_mmcif_irqt()
1265 sh_mmcif_stop_cmd(host, mrq); in sh_mmcif_irqt()
1267 schedule_delayed_work(&host->timeout_work, host->timeout); in sh_mmcif_irqt()
1268 mutex_unlock(&host->thread_lock); in sh_mmcif_irqt()
1274 host->wait_for = MMCIF_WAIT_FOR_REQUEST; in sh_mmcif_irqt()
1275 host->state = STATE_IDLE; in sh_mmcif_irqt()
1276 host->mrq = NULL; in sh_mmcif_irqt()
1277 mmc_request_done(host->mmc, mrq); in sh_mmcif_irqt()
1279 mutex_unlock(&host->thread_lock); in sh_mmcif_irqt()
1286 struct sh_mmcif_host *host = dev_id; in sh_mmcif_intr() local
1287 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_intr()
1290 state = sh_mmcif_readl(host->addr, MMCIF_CE_INT); in sh_mmcif_intr()
1291 mask = sh_mmcif_readl(host->addr, MMCIF_CE_INT_MASK); in sh_mmcif_intr()
1292 if (host->ccs_enable) in sh_mmcif_intr()
1293 sh_mmcif_writel(host->addr, MMCIF_CE_INT, ~(state & mask)); in sh_mmcif_intr()
1295 sh_mmcif_writel(host->addr, MMCIF_CE_INT, INT_CCS | ~(state & mask)); in sh_mmcif_intr()
1296 sh_mmcif_bitclr(host, MMCIF_CE_INT_MASK, state & MASK_CLEAN); in sh_mmcif_intr()
1303 host->sd_error = true; in sh_mmcif_intr()
1307 if (!host->mrq) in sh_mmcif_intr()
1309 if (!host->dma_active) in sh_mmcif_intr()
1311 else if (host->sd_error) in sh_mmcif_intr()
1312 sh_mmcif_dma_complete(host); in sh_mmcif_intr()
1323 struct sh_mmcif_host *host = container_of(d, struct sh_mmcif_host, timeout_work); in sh_mmcif_timeout_work() local
1324 struct mmc_request *mrq = host->mrq; in sh_mmcif_timeout_work()
1325 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_timeout_work()
1328 if (host->dying) in sh_mmcif_timeout_work()
1332 spin_lock_irqsave(&host->lock, flags); in sh_mmcif_timeout_work()
1333 if (host->state == STATE_IDLE) { in sh_mmcif_timeout_work()
1334 spin_unlock_irqrestore(&host->lock, flags); in sh_mmcif_timeout_work()
1339 host->wait_for, mrq->cmd->opcode); in sh_mmcif_timeout_work()
1341 host->state = STATE_TIMEOUT; in sh_mmcif_timeout_work()
1342 spin_unlock_irqrestore(&host->lock, flags); in sh_mmcif_timeout_work()
1348 switch (host->wait_for) { in sh_mmcif_timeout_work()
1350 mrq->cmd->error = sh_mmcif_error_manage(host); in sh_mmcif_timeout_work()
1353 mrq->stop->error = sh_mmcif_error_manage(host); in sh_mmcif_timeout_work()
1361 mrq->data->error = sh_mmcif_error_manage(host); in sh_mmcif_timeout_work()
1367 host->state = STATE_IDLE; in sh_mmcif_timeout_work()
1368 host->wait_for = MMCIF_WAIT_FOR_REQUEST; in sh_mmcif_timeout_work()
1369 host->mrq = NULL; in sh_mmcif_timeout_work()
1370 mmc_request_done(host->mmc, mrq); in sh_mmcif_timeout_work()
1373 static void sh_mmcif_init_ocr(struct sh_mmcif_host *host) in sh_mmcif_init_ocr() argument
1375 struct device *dev = sh_mmcif_host_to_dev(host); in sh_mmcif_init_ocr()
1377 struct mmc_host *mmc = host->mmc; in sh_mmcif_init_ocr()
1394 struct sh_mmcif_host *host; in sh_mmcif_probe() local
1417 host = mmc_priv(mmc); in sh_mmcif_probe()
1418 host->mmc = mmc; in sh_mmcif_probe()
1419 host->addr = reg; in sh_mmcif_probe()
1420 host->timeout = msecs_to_jiffies(10000); in sh_mmcif_probe()
1421 host->ccs_enable = true; in sh_mmcif_probe()
1422 host->clk_ctrl2_enable = false; in sh_mmcif_probe()
1424 host->pd = pdev; in sh_mmcif_probe()
1426 spin_lock_init(&host->lock); in sh_mmcif_probe()
1429 sh_mmcif_init_ocr(host); in sh_mmcif_probe()
1443 platform_set_drvdata(pdev, host); in sh_mmcif_probe()
1445 host->clk = devm_clk_get(dev, NULL); in sh_mmcif_probe()
1446 if (IS_ERR(host->clk)) { in sh_mmcif_probe()
1447 ret = PTR_ERR(host->clk); in sh_mmcif_probe()
1452 ret = clk_prepare_enable(host->clk); in sh_mmcif_probe()
1456 sh_mmcif_clk_setup(host); in sh_mmcif_probe()
1459 host->power = false; in sh_mmcif_probe()
1465 INIT_DELAYED_WORK(&host->timeout_work, sh_mmcif_timeout_work); in sh_mmcif_probe()
1467 sh_mmcif_sync_reset(host); in sh_mmcif_probe()
1468 sh_mmcif_writel(host->addr, MMCIF_CE_INT_MASK, MASK_ALL); in sh_mmcif_probe()
1472 sh_mmcif_irqt, 0, name, host); in sh_mmcif_probe()
1480 0, "sh_mmc:int", host); in sh_mmcif_probe()
1487 mutex_init(&host->thread_lock); in sh_mmcif_probe()
1496 sh_mmcif_readl(host->addr, MMCIF_CE_VERSION) & 0xffff, in sh_mmcif_probe()
1497 clk_get_rate(host->clk) / 1000000UL); in sh_mmcif_probe()
1500 clk_disable_unprepare(host->clk); in sh_mmcif_probe()
1504 clk_disable_unprepare(host->clk); in sh_mmcif_probe()
1514 struct sh_mmcif_host *host = platform_get_drvdata(pdev); in sh_mmcif_remove() local
1516 host->dying = true; in sh_mmcif_remove()
1517 clk_prepare_enable(host->clk); in sh_mmcif_remove()
1522 mmc_remove_host(host->mmc); in sh_mmcif_remove()
1523 sh_mmcif_writel(host->addr, MMCIF_CE_INT_MASK, MASK_ALL); in sh_mmcif_remove()
1530 cancel_delayed_work_sync(&host->timeout_work); in sh_mmcif_remove()
1532 clk_disable_unprepare(host->clk); in sh_mmcif_remove()
1533 mmc_free_host(host->mmc); in sh_mmcif_remove()
1543 struct sh_mmcif_host *host = dev_get_drvdata(dev); in sh_mmcif_suspend() local
1546 sh_mmcif_writel(host->addr, MMCIF_CE_INT_MASK, MASK_ALL); in sh_mmcif_suspend()