From: Bartlomiej Zolnierkiewicz <b.zolnierkie@samsung.com>
To: Jaehoon Chung <jh80.chung@samsung.com>
Cc: Ulf Hansson <ulf.hansson@linaro.org>,
Yuvaraj Kumar C D <yuvaraj.cd@gmail.com>,
linux-samsung-soc <linux-samsung-soc@vger.kernel.org>,
"linux-arm-kernel@lists.infradead.org"
<linux-arm-kernel@lists.infradead.org>,
Doug Anderson <dianders@google.com>,
Doug Anderson <dianders@chromium.org>,
Chris Ball <cjb@laptop.org>,
"tgih.jun@samsung.com" <tgih.jun@samsung.com>,
linux-mmc <linux-mmc@vger.kernel.org>,
Sonny Rao <sonnyrao@chromium.org>,
Tomasz Figa <tomasz.figa@gmail.com>,
Kukjin Kim <kgene.kim@samsung.com>,
sunil joshi <joshi@samsung.com>,
Prashanth G <prashanth.g@samsung.com>,
ALIM AKHTAR <alim.akhtar@samsung.com>,
Javier Martinez Canillas <javier.martinez@collabora.co.uk>,
ABHILASH KESAVAN <a.kesavan@samsung.com>,
Yuvaraj Kumar C D <yuvaraj.cd@samsung.com>,
CPGS <cpgs@samsung.com>
Subject: Re: [PATCH V2 1/3] mmc: dw_mmc: use mmc_regulator_get_supply to handle regulators
Date: Wed, 01 Oct 2014 15:57:54 +0200 [thread overview]
Message-ID: <3515419.FCCWMziJlh@amdc1032> (raw)
In-Reply-To: <542A3E60.1000401@samsung.com>
Hi,
On Tuesday, September 30, 2014 02:23:44 PM Jaehoon Chung wrote:
> Hi
>
> On 09/29/2014 09:31 PM, Bartlomiej Zolnierkiewicz wrote:
> >
> > Hi,
> >
> > On Friday, August 29, 2014 01:34:44 PM Ulf Hansson wrote:
> >> On 22 August 2014 15:47, Yuvaraj Kumar C D <yuvaraj.cd@gmail.com> wrote:
> >>> This patch makes use of mmc_regulator_get_supply() to handle
> >>> the vmmc and vqmmc regulators.Also it moves the code handling
> >>> the these regulators to dw_mci_set_ios().It turned on the vmmc
> >>> and vqmmc during MMC_POWER_UP and MMC_POWER_ON,and turned off
> >>> during MMC_POWER_OFF.
> >>>
> >>> Signed-off-by: Yuvaraj Kumar C D <yuvaraj.cd@samsung.com>
> >>
> >> Thanks! Applied for next.
> >
> > Unfortunately this patch breaks mmc1 card (Kingston 32GB micro SDHC)
> > detection on Exynos5420 Arndale Octa for me:
> >
> > [ 10.797979] dwmmc_exynos 12220000.mmc: no support for card's volts
> > [ 10.797998] mmc1: error -22 whilst initialising SD card
>
> OCR value is not matched. Which values are supported about the mmc_host's value and card's value?
> Could you share the value?
Sure. I've added dev_info()s at the beginning of mmc_select_voltage():
+ dev_warn(mmc_dev(host), "card's volts: 0x%0x\n", ocr);
+ dev_warn(mmc_dev(host), "host's volts: 0x%0x\n", host->ocr_avail);
and got following results:
[ 10.851678] dwmmc_exynos 12220000.mmc: card's volts: 0xff8000
[ 10.851691] dwmmc_exynos 12220000.mmc: host's volts: 0x80
Best regards,
--
Bartlomiej Zolnierkiewicz
Samsung R&D Institute Poland
Samsung Electronics
> Best Regards,
> Jaehoon Chung
>
> >
> > Without the patch:
> >
> > [ 10.866926] mmc_host mmc1: Bus speed (slot 0) = 50000000Hz (slot req 50000000Hz, actual 50000000HZ div = 0)
> > [ 10.866977] mmc1: new high speed SDHC card at address 1234
> > [ 10.868730] mmcblk1: mmc1:1234 SA32G 29.3 GiB
> > [ 10.915054] mmcblk1: p1 p2 p3
> >
> > The config is attached (exynos_defconfig doesn't work correctly for
> > this board yet).
> >
> > Best regards,
> > --
> > Bartlomiej Zolnierkiewicz
> > Samsung R&D Institute Poland
> > Samsung Electronics
> >
> >> Kind regards
> >> Uffe
> >>
> >>> ---
> >>> changes from v1:
> >>> 1.Used mmc_regulator_set_ocr() instead of regulator_enable() for vmmc.
> >>> 2.Turned on vmmc and vqmmc during MMC_POWER_UP.
> >>> 3. Removed the flags DW_MMC_CARD_POWERED and DW_MMC_IO_POWERED which
> >>> added during the initial version of this patch.
> >>> 4. Added error message, if it failed to turn on regulator's.
> >>>
> >>> drivers/mmc/host/dw_mmc.c | 72 +++++++++++++++++++++-----------------------
> >>> include/linux/mmc/dw_mmc.h | 2 +-
> >>> 2 files changed, 36 insertions(+), 38 deletions(-)
> >>>
> >>> diff --git a/drivers/mmc/host/dw_mmc.c b/drivers/mmc/host/dw_mmc.c
> >>> index 7f227e9..aadb0d6 100644
> >>> --- a/drivers/mmc/host/dw_mmc.c
> >>> +++ b/drivers/mmc/host/dw_mmc.c
> >>> @@ -936,6 +936,7 @@ static void dw_mci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
> >>> struct dw_mci_slot *slot = mmc_priv(mmc);
> >>> const struct dw_mci_drv_data *drv_data = slot->host->drv_data;
> >>> u32 regs;
> >>> + int ret;
> >>>
> >>> switch (ios->bus_width) {
> >>> case MMC_BUS_WIDTH_4:
> >>> @@ -974,12 +975,38 @@ static void dw_mci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
> >>>
> >>> switch (ios->power_mode) {
> >>> case MMC_POWER_UP:
> >>> + if (!IS_ERR(mmc->supply.vmmc)) {
> >>> + ret = mmc_regulator_set_ocr(mmc, mmc->supply.vmmc,
> >>> + ios->vdd);
> >>> + if (ret) {
> >>> + dev_err(slot->host->dev,
> >>> + "failed to enable vmmc regulator\n");
> >>> + /*return, if failed turn on vmmc*/
> >>> + return;
> >>> + }
> >>> + }
> >>> + if (!IS_ERR(mmc->supply.vqmmc) && !slot->host->vqmmc_enabled) {
> >>> + ret = regulator_enable(mmc->supply.vqmmc);
> >>> + if (ret < 0)
> >>> + dev_err(slot->host->dev,
> >>> + "failed to enable vqmmc regulator\n");
> >>> + else
> >>> + slot->host->vqmmc_enabled = true;
> >>> + }
> >>> set_bit(DW_MMC_CARD_NEED_INIT, &slot->flags);
> >>> regs = mci_readl(slot->host, PWREN);
> >>> regs |= (1 << slot->id);
> >>> mci_writel(slot->host, PWREN, regs);
> >>> break;
> >>> case MMC_POWER_OFF:
> >>> + if (!IS_ERR(mmc->supply.vmmc))
> >>> + mmc_regulator_set_ocr(mmc, mmc->supply.vmmc, 0);
> >>> +
> >>> + if (!IS_ERR(mmc->supply.vqmmc) && slot->host->vqmmc_enabled) {
> >>> + regulator_disable(mmc->supply.vqmmc);
> >>> + slot->host->vqmmc_enabled = false;
> >>> + }
> >>> +
> >>> regs = mci_readl(slot->host, PWREN);
> >>> regs &= ~(1 << slot->id);
> >>> mci_writel(slot->host, PWREN, regs);
> >>> @@ -2110,7 +2137,13 @@ static int dw_mci_init_slot(struct dw_mci *host, unsigned int id)
> >>> mmc->f_max = freq[1];
> >>> }
> >>>
> >>> - mmc->ocr_avail = MMC_VDD_32_33 | MMC_VDD_33_34;
> >>> + /*if there are external regulators, get them*/
> >>> + ret = mmc_regulator_get_supply(mmc);
> >>> + if (ret == -EPROBE_DEFER)
> >>> + goto err_setup_bus;
> >>> +
> >>> + if (!mmc->ocr_avail)
> >>> + mmc->ocr_avail = MMC_VDD_32_33 | MMC_VDD_33_34;
> >>>
> >>> if (host->pdata->caps)
> >>> mmc->caps = host->pdata->caps;
> >>> @@ -2176,7 +2209,7 @@ static int dw_mci_init_slot(struct dw_mci *host, unsigned int id)
> >>>
> >>> err_setup_bus:
> >>> mmc_free_host(mmc);
> >>> - return -EINVAL;
> >>> + return ret;
> >>> }
> >>>
> >>> static void dw_mci_cleanup_slot(struct dw_mci_slot *slot, unsigned int id)
> >>> @@ -2469,24 +2502,6 @@ int dw_mci_probe(struct dw_mci *host)
> >>> }
> >>> }
> >>>
> >>> - host->vmmc = devm_regulator_get_optional(host->dev, "vmmc");
> >>> - if (IS_ERR(host->vmmc)) {
> >>> - ret = PTR_ERR(host->vmmc);
> >>> - if (ret == -EPROBE_DEFER)
> >>> - goto err_clk_ciu;
> >>> -
> >>> - dev_info(host->dev, "no vmmc regulator found: %d\n", ret);
> >>> - host->vmmc = NULL;
> >>> - } else {
> >>> - ret = regulator_enable(host->vmmc);
> >>> - if (ret) {
> >>> - if (ret != -EPROBE_DEFER)
> >>> - dev_err(host->dev,
> >>> - "regulator_enable fail: %d\n", ret);
> >>> - goto err_clk_ciu;
> >>> - }
> >>> - }
> >>> -
> >>> host->quirks = host->pdata->quirks;
> >>>
> >>> spin_lock_init(&host->lock);
> >>> @@ -2630,8 +2645,6 @@ err_workqueue:
> >>> err_dmaunmap:
> >>> if (host->use_dma && host->dma_ops->exit)
> >>> host->dma_ops->exit(host);
> >>> - if (host->vmmc)
> >>> - regulator_disable(host->vmmc);
> >>>
> >>> err_clk_ciu:
> >>> if (!IS_ERR(host->ciu_clk))
> >>> @@ -2667,9 +2680,6 @@ void dw_mci_remove(struct dw_mci *host)
> >>> if (host->use_dma && host->dma_ops->exit)
> >>> host->dma_ops->exit(host);
> >>>
> >>> - if (host->vmmc)
> >>> - regulator_disable(host->vmmc);
> >>> -
> >>> if (!IS_ERR(host->ciu_clk))
> >>> clk_disable_unprepare(host->ciu_clk);
> >>>
> >>> @@ -2686,9 +2696,6 @@ EXPORT_SYMBOL(dw_mci_remove);
> >>> */
> >>> int dw_mci_suspend(struct dw_mci *host)
> >>> {
> >>> - if (host->vmmc)
> >>> - regulator_disable(host->vmmc);
> >>> -
> >>> return 0;
> >>> }
> >>> EXPORT_SYMBOL(dw_mci_suspend);
> >>> @@ -2697,15 +2704,6 @@ int dw_mci_resume(struct dw_mci *host)
> >>> {
> >>> int i, ret;
> >>>
> >>> - if (host->vmmc) {
> >>> - ret = regulator_enable(host->vmmc);
> >>> - if (ret) {
> >>> - dev_err(host->dev,
> >>> - "failed to enable regulator: %d\n", ret);
> >>> - return ret;
> >>> - }
> >>> - }
> >>> -
> >>> if (!dw_mci_ctrl_reset(host, SDMMC_CTRL_ALL_RESET_FLAGS)) {
> >>> ret = -ENODEV;
> >>> return ret;
> >>> diff --git a/include/linux/mmc/dw_mmc.h b/include/linux/mmc/dw_mmc.h
> >>> index 29ce014..84e2827 100644
> >>> --- a/include/linux/mmc/dw_mmc.h
> >>> +++ b/include/linux/mmc/dw_mmc.h
> >>> @@ -188,7 +188,7 @@ struct dw_mci {
> >>> /* Workaround flags */
> >>> u32 quirks;
> >>>
> >>> - struct regulator *vmmc; /* Power regulator */
> >>> + bool vqmmc_enabled;
> >>> unsigned long irq_flags; /* IRQ flags */
> >>> int irq;
> >>> };
> >>> --
> >>> 1.7.10.4
WARNING: multiple messages have this Message-ID (diff)
From: b.zolnierkie@samsung.com (Bartlomiej Zolnierkiewicz)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH V2 1/3] mmc: dw_mmc: use mmc_regulator_get_supply to handle regulators
Date: Wed, 01 Oct 2014 15:57:54 +0200 [thread overview]
Message-ID: <3515419.FCCWMziJlh@amdc1032> (raw)
In-Reply-To: <542A3E60.1000401@samsung.com>
Hi,
On Tuesday, September 30, 2014 02:23:44 PM Jaehoon Chung wrote:
> Hi
>
> On 09/29/2014 09:31 PM, Bartlomiej Zolnierkiewicz wrote:
> >
> > Hi,
> >
> > On Friday, August 29, 2014 01:34:44 PM Ulf Hansson wrote:
> >> On 22 August 2014 15:47, Yuvaraj Kumar C D <yuvaraj.cd@gmail.com> wrote:
> >>> This patch makes use of mmc_regulator_get_supply() to handle
> >>> the vmmc and vqmmc regulators.Also it moves the code handling
> >>> the these regulators to dw_mci_set_ios().It turned on the vmmc
> >>> and vqmmc during MMC_POWER_UP and MMC_POWER_ON,and turned off
> >>> during MMC_POWER_OFF.
> >>>
> >>> Signed-off-by: Yuvaraj Kumar C D <yuvaraj.cd@samsung.com>
> >>
> >> Thanks! Applied for next.
> >
> > Unfortunately this patch breaks mmc1 card (Kingston 32GB micro SDHC)
> > detection on Exynos5420 Arndale Octa for me:
> >
> > [ 10.797979] dwmmc_exynos 12220000.mmc: no support for card's volts
> > [ 10.797998] mmc1: error -22 whilst initialising SD card
>
> OCR value is not matched. Which values are supported about the mmc_host's value and card's value?
> Could you share the value?
Sure. I've added dev_info()s at the beginning of mmc_select_voltage():
+ dev_warn(mmc_dev(host), "card's volts: 0x%0x\n", ocr);
+ dev_warn(mmc_dev(host), "host's volts: 0x%0x\n", host->ocr_avail);
and got following results:
[ 10.851678] dwmmc_exynos 12220000.mmc: card's volts: 0xff8000
[ 10.851691] dwmmc_exynos 12220000.mmc: host's volts: 0x80
Best regards,
--
Bartlomiej Zolnierkiewicz
Samsung R&D Institute Poland
Samsung Electronics
> Best Regards,
> Jaehoon Chung
>
> >
> > Without the patch:
> >
> > [ 10.866926] mmc_host mmc1: Bus speed (slot 0) = 50000000Hz (slot req 50000000Hz, actual 50000000HZ div = 0)
> > [ 10.866977] mmc1: new high speed SDHC card at address 1234
> > [ 10.868730] mmcblk1: mmc1:1234 SA32G 29.3 GiB
> > [ 10.915054] mmcblk1: p1 p2 p3
> >
> > The config is attached (exynos_defconfig doesn't work correctly for
> > this board yet).
> >
> > Best regards,
> > --
> > Bartlomiej Zolnierkiewicz
> > Samsung R&D Institute Poland
> > Samsung Electronics
> >
> >> Kind regards
> >> Uffe
> >>
> >>> ---
> >>> changes from v1:
> >>> 1.Used mmc_regulator_set_ocr() instead of regulator_enable() for vmmc.
> >>> 2.Turned on vmmc and vqmmc during MMC_POWER_UP.
> >>> 3. Removed the flags DW_MMC_CARD_POWERED and DW_MMC_IO_POWERED which
> >>> added during the initial version of this patch.
> >>> 4. Added error message, if it failed to turn on regulator's.
> >>>
> >>> drivers/mmc/host/dw_mmc.c | 72 +++++++++++++++++++++-----------------------
> >>> include/linux/mmc/dw_mmc.h | 2 +-
> >>> 2 files changed, 36 insertions(+), 38 deletions(-)
> >>>
> >>> diff --git a/drivers/mmc/host/dw_mmc.c b/drivers/mmc/host/dw_mmc.c
> >>> index 7f227e9..aadb0d6 100644
> >>> --- a/drivers/mmc/host/dw_mmc.c
> >>> +++ b/drivers/mmc/host/dw_mmc.c
> >>> @@ -936,6 +936,7 @@ static void dw_mci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
> >>> struct dw_mci_slot *slot = mmc_priv(mmc);
> >>> const struct dw_mci_drv_data *drv_data = slot->host->drv_data;
> >>> u32 regs;
> >>> + int ret;
> >>>
> >>> switch (ios->bus_width) {
> >>> case MMC_BUS_WIDTH_4:
> >>> @@ -974,12 +975,38 @@ static void dw_mci_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
> >>>
> >>> switch (ios->power_mode) {
> >>> case MMC_POWER_UP:
> >>> + if (!IS_ERR(mmc->supply.vmmc)) {
> >>> + ret = mmc_regulator_set_ocr(mmc, mmc->supply.vmmc,
> >>> + ios->vdd);
> >>> + if (ret) {
> >>> + dev_err(slot->host->dev,
> >>> + "failed to enable vmmc regulator\n");
> >>> + /*return, if failed turn on vmmc*/
> >>> + return;
> >>> + }
> >>> + }
> >>> + if (!IS_ERR(mmc->supply.vqmmc) && !slot->host->vqmmc_enabled) {
> >>> + ret = regulator_enable(mmc->supply.vqmmc);
> >>> + if (ret < 0)
> >>> + dev_err(slot->host->dev,
> >>> + "failed to enable vqmmc regulator\n");
> >>> + else
> >>> + slot->host->vqmmc_enabled = true;
> >>> + }
> >>> set_bit(DW_MMC_CARD_NEED_INIT, &slot->flags);
> >>> regs = mci_readl(slot->host, PWREN);
> >>> regs |= (1 << slot->id);
> >>> mci_writel(slot->host, PWREN, regs);
> >>> break;
> >>> case MMC_POWER_OFF:
> >>> + if (!IS_ERR(mmc->supply.vmmc))
> >>> + mmc_regulator_set_ocr(mmc, mmc->supply.vmmc, 0);
> >>> +
> >>> + if (!IS_ERR(mmc->supply.vqmmc) && slot->host->vqmmc_enabled) {
> >>> + regulator_disable(mmc->supply.vqmmc);
> >>> + slot->host->vqmmc_enabled = false;
> >>> + }
> >>> +
> >>> regs = mci_readl(slot->host, PWREN);
> >>> regs &= ~(1 << slot->id);
> >>> mci_writel(slot->host, PWREN, regs);
> >>> @@ -2110,7 +2137,13 @@ static int dw_mci_init_slot(struct dw_mci *host, unsigned int id)
> >>> mmc->f_max = freq[1];
> >>> }
> >>>
> >>> - mmc->ocr_avail = MMC_VDD_32_33 | MMC_VDD_33_34;
> >>> + /*if there are external regulators, get them*/
> >>> + ret = mmc_regulator_get_supply(mmc);
> >>> + if (ret == -EPROBE_DEFER)
> >>> + goto err_setup_bus;
> >>> +
> >>> + if (!mmc->ocr_avail)
> >>> + mmc->ocr_avail = MMC_VDD_32_33 | MMC_VDD_33_34;
> >>>
> >>> if (host->pdata->caps)
> >>> mmc->caps = host->pdata->caps;
> >>> @@ -2176,7 +2209,7 @@ static int dw_mci_init_slot(struct dw_mci *host, unsigned int id)
> >>>
> >>> err_setup_bus:
> >>> mmc_free_host(mmc);
> >>> - return -EINVAL;
> >>> + return ret;
> >>> }
> >>>
> >>> static void dw_mci_cleanup_slot(struct dw_mci_slot *slot, unsigned int id)
> >>> @@ -2469,24 +2502,6 @@ int dw_mci_probe(struct dw_mci *host)
> >>> }
> >>> }
> >>>
> >>> - host->vmmc = devm_regulator_get_optional(host->dev, "vmmc");
> >>> - if (IS_ERR(host->vmmc)) {
> >>> - ret = PTR_ERR(host->vmmc);
> >>> - if (ret == -EPROBE_DEFER)
> >>> - goto err_clk_ciu;
> >>> -
> >>> - dev_info(host->dev, "no vmmc regulator found: %d\n", ret);
> >>> - host->vmmc = NULL;
> >>> - } else {
> >>> - ret = regulator_enable(host->vmmc);
> >>> - if (ret) {
> >>> - if (ret != -EPROBE_DEFER)
> >>> - dev_err(host->dev,
> >>> - "regulator_enable fail: %d\n", ret);
> >>> - goto err_clk_ciu;
> >>> - }
> >>> - }
> >>> -
> >>> host->quirks = host->pdata->quirks;
> >>>
> >>> spin_lock_init(&host->lock);
> >>> @@ -2630,8 +2645,6 @@ err_workqueue:
> >>> err_dmaunmap:
> >>> if (host->use_dma && host->dma_ops->exit)
> >>> host->dma_ops->exit(host);
> >>> - if (host->vmmc)
> >>> - regulator_disable(host->vmmc);
> >>>
> >>> err_clk_ciu:
> >>> if (!IS_ERR(host->ciu_clk))
> >>> @@ -2667,9 +2680,6 @@ void dw_mci_remove(struct dw_mci *host)
> >>> if (host->use_dma && host->dma_ops->exit)
> >>> host->dma_ops->exit(host);
> >>>
> >>> - if (host->vmmc)
> >>> - regulator_disable(host->vmmc);
> >>> -
> >>> if (!IS_ERR(host->ciu_clk))
> >>> clk_disable_unprepare(host->ciu_clk);
> >>>
> >>> @@ -2686,9 +2696,6 @@ EXPORT_SYMBOL(dw_mci_remove);
> >>> */
> >>> int dw_mci_suspend(struct dw_mci *host)
> >>> {
> >>> - if (host->vmmc)
> >>> - regulator_disable(host->vmmc);
> >>> -
> >>> return 0;
> >>> }
> >>> EXPORT_SYMBOL(dw_mci_suspend);
> >>> @@ -2697,15 +2704,6 @@ int dw_mci_resume(struct dw_mci *host)
> >>> {
> >>> int i, ret;
> >>>
> >>> - if (host->vmmc) {
> >>> - ret = regulator_enable(host->vmmc);
> >>> - if (ret) {
> >>> - dev_err(host->dev,
> >>> - "failed to enable regulator: %d\n", ret);
> >>> - return ret;
> >>> - }
> >>> - }
> >>> -
> >>> if (!dw_mci_ctrl_reset(host, SDMMC_CTRL_ALL_RESET_FLAGS)) {
> >>> ret = -ENODEV;
> >>> return ret;
> >>> diff --git a/include/linux/mmc/dw_mmc.h b/include/linux/mmc/dw_mmc.h
> >>> index 29ce014..84e2827 100644
> >>> --- a/include/linux/mmc/dw_mmc.h
> >>> +++ b/include/linux/mmc/dw_mmc.h
> >>> @@ -188,7 +188,7 @@ struct dw_mci {
> >>> /* Workaround flags */
> >>> u32 quirks;
> >>>
> >>> - struct regulator *vmmc; /* Power regulator */
> >>> + bool vqmmc_enabled;
> >>> unsigned long irq_flags; /* IRQ flags */
> >>> int irq;
> >>> };
> >>> --
> >>> 1.7.10.4
next prev parent reply other threads:[~2014-10-01 13:57 UTC|newest]
Thread overview: 92+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-08-22 13:47 [PATCH V2 0/3] Adding UHS support for dw_mmc driver Yuvaraj Kumar C D
2014-08-22 13:47 ` Yuvaraj Kumar C D
2014-08-22 13:47 ` [PATCH V2 1/3] mmc: dw_mmc: use mmc_regulator_get_supply to handle regulators Yuvaraj Kumar C D
2014-08-22 13:47 ` Yuvaraj Kumar C D
2014-08-25 12:32 ` Jaehoon Chung
2014-08-25 12:32 ` Jaehoon Chung
2014-08-25 15:06 ` Doug Anderson
2014-08-25 15:06 ` Doug Anderson
2014-08-29 11:34 ` Ulf Hansson
2014-08-29 11:34 ` Ulf Hansson
2014-09-29 12:31 ` Bartlomiej Zolnierkiewicz
2014-09-29 12:31 ` Bartlomiej Zolnierkiewicz
2014-09-30 5:23 ` Jaehoon Chung
2014-09-30 5:23 ` Jaehoon Chung
2014-10-01 13:57 ` Bartlomiej Zolnierkiewicz [this message]
2014-10-01 13:57 ` Bartlomiej Zolnierkiewicz
2014-10-01 14:14 ` Bartlomiej Zolnierkiewicz
2014-10-01 14:14 ` Bartlomiej Zolnierkiewicz
2014-09-30 17:22 ` Doug Anderson
2014-09-30 17:22 ` Doug Anderson
2014-10-01 13:06 ` Bartlomiej Zolnierkiewicz
2014-10-01 13:06 ` Bartlomiej Zolnierkiewicz
2014-10-01 15:38 ` Doug Anderson
2014-10-01 15:38 ` Doug Anderson
2014-08-22 13:47 ` [PATCH V2 2/3] mmc: dw_mmc: Support voltage changes Yuvaraj Kumar C D
2014-08-22 13:47 ` Yuvaraj Kumar C D
2014-08-22 15:35 ` Ulf Hansson
2014-08-22 15:35 ` Ulf Hansson
2014-08-22 20:38 ` Doug Anderson
2014-08-22 20:38 ` Doug Anderson
2014-08-25 8:31 ` Ulf Hansson
2014-08-25 8:31 ` Ulf Hansson
2014-08-25 20:59 ` Doug Anderson
2014-08-25 20:59 ` Doug Anderson
2014-08-29 11:43 ` Ulf Hansson
2014-08-29 11:43 ` Ulf Hansson
2014-09-29 12:49 ` Bartlomiej Zolnierkiewicz
2014-09-29 12:49 ` Bartlomiej Zolnierkiewicz
2014-08-22 13:47 ` [PATCH V2 3/3] mmc: dw_mmc: Dont cut off vqmmc and vmmc Yuvaraj Kumar C D
2014-08-22 13:47 ` Yuvaraj Kumar C D
2014-08-22 15:31 ` Ulf Hansson
2014-08-22 15:31 ` Ulf Hansson
2014-08-22 18:27 ` Sonny Rao
2014-08-22 18:27 ` Sonny Rao
2014-08-25 8:13 ` Ulf Hansson
2014-08-25 8:13 ` Ulf Hansson
2014-08-25 8:50 ` Jaehoon Chung
2014-08-25 8:50 ` Jaehoon Chung
2014-08-25 15:25 ` Doug Anderson
2014-08-25 15:25 ` Doug Anderson
2014-08-27 3:48 ` Jaehoon Chung
2014-08-27 3:48 ` Jaehoon Chung
2014-08-27 4:14 ` Doug Anderson
2014-08-27 4:14 ` Doug Anderson
2014-08-27 4:47 ` Jaehoon Chung
2014-08-27 4:47 ` Jaehoon Chung
2014-08-27 15:49 ` Doug Anderson
2014-08-27 15:49 ` Doug Anderson
2014-08-28 4:54 ` Yuvaraj Kumar
2014-08-28 4:54 ` Yuvaraj Kumar
2014-08-28 8:43 ` Jaehoon Chung
2014-08-28 8:43 ` Jaehoon Chung
2014-08-28 15:52 ` Doug Anderson
2014-08-28 15:52 ` Doug Anderson
2014-08-25 15:20 ` Doug Anderson
2014-08-25 15:20 ` Doug Anderson
2014-08-26 7:37 ` Ulf Hansson
2014-08-26 7:37 ` Ulf Hansson
2014-08-26 20:32 ` Doug Anderson
2014-08-26 20:32 ` Doug Anderson
2014-08-27 11:17 ` Ulf Hansson
2014-08-27 11:17 ` Ulf Hansson
2014-08-27 11:20 ` Ulf Hansson
2014-08-27 11:20 ` Ulf Hansson
2014-08-27 15:52 ` Doug Anderson
2014-08-27 15:52 ` Doug Anderson
2014-08-28 7:25 ` Ulf Hansson
2014-08-28 7:25 ` Ulf Hansson
2014-08-28 15:50 ` Doug Anderson
2014-08-28 15:50 ` Doug Anderson
2014-08-28 17:50 ` Sonny Rao
2014-08-28 17:50 ` Sonny Rao
2014-08-29 4:08 ` Doug Anderson
2014-08-29 4:08 ` Doug Anderson
2014-08-27 3:55 ` Jaehoon Chung
2014-08-27 3:55 ` Jaehoon Chung
[not found] <01.09.14890.83F4B245@epcpsbge5.samsung.com>
2014-10-01 14:00 ` [PATCH V2 1/3] mmc: dw_mmc: use mmc_regulator_get_supply to handle regulators Bartlomiej Zolnierkiewicz
2014-10-01 14:00 ` Bartlomiej Zolnierkiewicz
2014-10-01 16:04 ` Doug Anderson
2014-10-01 16:04 ` Doug Anderson
2014-10-02 16:06 ` Bartlomiej Zolnierkiewicz
2014-10-02 16:06 ` Bartlomiej Zolnierkiewicz
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=3515419.FCCWMziJlh@amdc1032 \
--to=b.zolnierkie@samsung.com \
--cc=a.kesavan@samsung.com \
--cc=alim.akhtar@samsung.com \
--cc=cjb@laptop.org \
--cc=cpgs@samsung.com \
--cc=dianders@chromium.org \
--cc=dianders@google.com \
--cc=javier.martinez@collabora.co.uk \
--cc=jh80.chung@samsung.com \
--cc=joshi@samsung.com \
--cc=kgene.kim@samsung.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-mmc@vger.kernel.org \
--cc=linux-samsung-soc@vger.kernel.org \
--cc=prashanth.g@samsung.com \
--cc=sonnyrao@chromium.org \
--cc=tgih.jun@samsung.com \
--cc=tomasz.figa@gmail.com \
--cc=ulf.hansson@linaro.org \
--cc=yuvaraj.cd@gmail.com \
--cc=yuvaraj.cd@samsung.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.