> -----Original Message----- > From: linux-mmc-owner@xxxxxxxxxxxxxxx [mailto:linux-mmc- > owner@xxxxxxxxxxxxxxx] On Behalf Of Adrian Hunter > Sent: Monday, July 31, 2017 2:41 PM > To: Bough Chen <haibo.chen@xxxxxxx>; Ulf Hansson <ulf.hansson@xxxxxxxxxx> > Cc: linux-mmc <linux-mmc@xxxxxxxxxxxxxxx>; Alex Lemberg > <alex.lemberg@xxxxxxxxxxx>; Mateusz Nowak <mateusz.nowak@xxxxxxxxx>; > Yuliy Izrailov <Yuliy.Izrailov@xxxxxxxxxxx>; Jaehoon Chung > <jh80.chung@xxxxxxxxxxx>; Dong Aisheng <dongas86@xxxxxxxxx>; Das > Asutosh <asutoshd@xxxxxxxxxxxxxx>; Zhangfei Gao > <zhangfei.gao@xxxxxxxxx>; Dorfman Konstantin > <kdorfman@xxxxxxxxxxxxxx>; Sahitya Tummala <stummala@xxxxxxxxxxxxxx>; > Harjani Ritesh <riteshh@xxxxxxxxxxxxxx>; Venu Byravarasu > <vbyravarasu@xxxxxxxxxx>; Linus Walleij <linus.walleij@xxxxxxxxxx>; Shawn Lin > <shawn.lin@xxxxxxxxxxxxxx> > Subject: Re: [PATCH V4 10/11] mmc: cqhci: support for command queue > enabled host > > On 24/07/17 13:21, Adrian Hunter wrote: > > On 24/07/17 11:52, Bough Chen wrote: > >> [...] > >> > >>> -----Original Message----- > >>> From: Adrian Hunter [mailto:adrian.hunter@xxxxxxxxx] > >>> Sent: Friday, July 21, 2017 5:50 PM > >>> To: Ulf Hansson <ulf.hansson@xxxxxxxxxx> > >>> Cc: linux-mmc <linux-mmc@xxxxxxxxxxxxxxx>; Bough Chen > >>> <haibo.chen@xxxxxxx>; Alex Lemberg <alex.lemberg@xxxxxxxxxxx>; > >>> Mateusz Nowak <mateusz.nowak@xxxxxxxxx>; Yuliy Izrailov > >>> <Yuliy.Izrailov@xxxxxxxxxxx>; Jaehoon Chung > >>> <jh80.chung@xxxxxxxxxxx>; Dong Aisheng <dongas86@xxxxxxxxx>; Das > >>> Asutosh <asutoshd@xxxxxxxxxxxxxx>; Zhangfei Gao > >>> <zhangfei.gao@xxxxxxxxx>; Dorfman Konstantin > >>> <kdorfman@xxxxxxxxxxxxxx>; David Griego <david.griego@xxxxxxxxxx>; > >>> Sahitya Tummala <stummala@xxxxxxxxxxxxxx>; Harjani Ritesh > >>> <riteshh@xxxxxxxxxxxxxx>; Venu Byravarasu <vbyravarasu@xxxxxxxxxx>; > >>> Linus Walleij <linus.walleij@xxxxxxxxxx>; Shawn Lin > >>> <shawn.lin@xxxxxxxxxxxxxx> > >>> Subject: [PATCH V4 10/11] mmc: cqhci: support for command queue > >>> enabled host > >>> > >>> From: Venkat Gopalakrishnan <venkatg@xxxxxxxxxxxxxx> > >>> > >>> This patch adds CMDQ support for command-queue compatible hosts. > >>> > >>> Command queue is added in eMMC-5.1 specification. This enables the > >>> controller to process upto 32 requests at a time. > >>> > >>> Adrian Hunter contributed renaming to cqhci, recovery, suspend and > >>> resume, cqhci_off, cqhci_wait_for_idle, and external timeout handling. > >>> > >>> Signed-off-by: Asutosh Das <asutoshd@xxxxxxxxxxxxxx> > >>> Signed-off-by: Sujit Reddy Thumma <sthumma@xxxxxxxxxxxxxx> > >>> Signed-off-by: Konstantin Dorfman <kdorfman@xxxxxxxxxxxxxx> > >>> Signed-off-by: Venkat Gopalakrishnan <venkatg@xxxxxxxxxxxxxx> > >>> Signed-off-by: Subhash Jadavani <subhashj@xxxxxxxxxxxxxx> > >>> Signed-off-by: Ritesh Harjani <riteshh@xxxxxxxxxxxxxx> > >>> Signed-off-by: Adrian Hunter <adrian.hunter@xxxxxxxxx> > >>> --- > >>> drivers/mmc/host/Kconfig | 13 + > >>> drivers/mmc/host/Makefile | 1 + > >>> drivers/mmc/host/cqhci.c | 1146 > >>> +++++++++++++++++++++++++++++++++++++++++++++ > >>> drivers/mmc/host/cqhci.h | 240 ++++++++++ > >>> 4 files changed, 1400 insertions(+) create mode 100644 > >>> drivers/mmc/host/cqhci.c create mode 100644 > >>> drivers/mmc/host/cqhci.h > >>> > >>> diff --git a/drivers/mmc/host/Kconfig b/drivers/mmc/host/Kconfig > >>> index 2242633550df..3a164a03f2bc 100644 > >>> --- a/drivers/mmc/host/Kconfig > >>> +++ b/drivers/mmc/host/Kconfig > >>> @@ -834,6 +834,19 @@ config MMC_SUNXI > >>> This selects support for the SD/MMC Host Controller on > >>> Allwinner sunxi SoCs. > >>> > >>> +config MMC_CQHCI > >>> + tristate "Command Queue Host Controller Interface support" > >>> + depends on HAS_DMA > >>> + help > >>> + This selects the Command Queue Host Controller Interface (CQHCI) > >>> + support present in host controllers of Qualcomm Technologies, Inc > >>> + amongst others. > >>> + This controller supports eMMC devices with command queue support. > >>> + > >>> + If you have a controller with this interface, say Y or M here. > >>> + > >>> + If unsure, say N. > >>> + > >>> config MMC_TOSHIBA_PCI > >>> tristate "Toshiba Type A SD/MMC Card Interface Driver" > >>> depends on PCI > >>> diff --git a/drivers/mmc/host/Makefile b/drivers/mmc/host/Makefile > >>> index > >>> 8c46766c000c..3ae71e006890 100644 > >>> --- a/drivers/mmc/host/Makefile > >>> +++ b/drivers/mmc/host/Makefile > >>> @@ -88,6 +88,7 @@ obj-$(CONFIG_MMC_SDHCI_MSM) += > >>> sdhci-msm.o > >>> obj-$(CONFIG_MMC_SDHCI_ST) += sdhci-st.o > >>> obj-$(CONFIG_MMC_SDHCI_MICROCHIP_PIC32) += sdhci-pic32.o > >>> obj-$(CONFIG_MMC_SDHCI_BRCMSTB) += sdhci-brcmstb.o > >>> +obj-$(CONFIG_MMC_CQHCI) += cqhci.o > >>> > >>> ifeq ($(CONFIG_CB710_DEBUG),y) > >>> CFLAGS-cb710-mmc += -DDEBUG > >>> diff --git a/drivers/mmc/host/cqhci.c b/drivers/mmc/host/cqhci.c new > >>> file mode 100644 index 000000000000..302421a26230 > >>> --- /dev/null > >>> +++ b/drivers/mmc/host/cqhci.c > >>> @@ -0,0 +1,1146 @@ > >> > >> <SNIP> > >> > >>> + > >>> +static int cqhci_request(struct mmc_host *mmc, struct mmc_request > >>> +*mrq) { > >>> + int err = 0; > >>> + u64 data = 0; > >>> + u64 *task_desc = NULL; > >>> + int tag = cqhci_tag(mrq); > >>> + struct cqhci_host *cq_host = mmc->cqe_private; > >>> + unsigned long flags; > >>> + > >>> + if (!cq_host->enabled) { > >>> + pr_err("%s: cqhci: not enabled\n", mmc_hostname(mmc)); > >>> + return -EINVAL; > >>> + } > >>> + > >>> + /* First request after resume has to re-enable */ > >>> + if (!cq_host->activated) > >>> + __cqhci_enable(cq_host); > >>> + > >>> + if (!mmc->cqe_on) { > >>> + cqhci_writel(cq_host, 0, CQHCI_CTL); > >>> + mmc->cqe_on = true; > >>> + pr_debug("%s: cqhci: CQE on\n", mmc_hostname(mmc)); > >>> + if (cqhci_readl(cq_host, CQHCI_CTL) && CQHCI_HALT) { > >>> + pr_err("%s: cqhci: CQE failed to exit halt state\n", > >>> + mmc_hostname(mmc)); > >>> + } > >>> + if (cq_host->ops->enable) > >>> + cq_host->ops->enable(mmc); > >>> + } > >>> + > >>> + if (mrq->data) { > >>> + task_desc = (__le64 __force *)get_desc(cq_host, tag); > >>> + cqhci_prep_task_desc(mrq, &data, 1); > >>> + *task_desc = cpu_to_le64(data); > >>> + err = cqhci_prep_tran_desc(mrq, cq_host, tag); > >>> + if (err) { > >>> + pr_err("%s: cqhci: failed to setup tx desc: %d\n", > >>> + mmc_hostname(mmc), err); > >>> + return err; > >>> + } > >>> + } else { > >>> + cqhci_prep_dcmd_desc(mmc, mrq); > >>> + } > >>> + > >> Hi Adrian, > >> > >> For cqhci data request, I think we need to also config > SDHCI_TRNS_BLK_CNT_EN and SDHCI_TRNS_DMA, just like function > sdhci_set_transfer_mode(): set SDHCI_TRNS_BLK_CNT_EN and > SDHCI_TRNS_DMA in every request. > >> > >> Currently, we do not do this for cqhci request, if support Runtime > >> PM, when runtime resume, > >> sdhci_runtime_resume_host() --> sdhci_init(host, 0) --> > >> sdhci_do_reset(host, SDHCI_RESET_ALL) > >> sdhci_reset() will do software reset for all, this will clear some SDHCI register, > including SDHCI_TRNS_BLK_CNT_EN and SDHCI_TRNS_DMA, then when use > cqhci request, error happens. I meet cqhci wait timeout error on our i.MX8. > After set these two bits, this issue gone. > > > > CQE anyway needs to write the transfer mode bit-4 so it is a bit > > strange that it doesn't write the other bits too. Nevertheless > > anything you need to set can be done in the ->enable() callback. For example > see glk_cqe_enable(). > > > > How is it going? Yes, the ->enable() callback is a good place to set the i.mx special config, now CMDQ can works well On our i.MX8. > -- > To unsubscribe from this list: send the line "unsubscribe linux-mmc" in the > body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at > http://vger.kernel.org/majordomo-info.html ��.n��������+%������w��{.n�����{��i��)��jg��������ݢj����G�������j:+v���w�m������w�������h�����٥