[PATCH V2 1/3] mmc: dw_mmc: use mmc_regulator_get_supply to handle regulators
Bartlomiej Zolnierkiewicz
b.zolnierkie at samsung.com
Thu Oct 2 09:06:51 PDT 2014
Hi,
On Wednesday, October 01, 2014 09:04:09 AM Doug Anderson wrote:
> Hi,
>
> On Wed, Oct 1, 2014 at 7:00 AM, Bartlomiej Zolnierkiewicz
> <b.zolnierkie at samsung.com> wrote:
> >
> > Hi,
> >
> > On Wednesday, October 01, 2014 12:47:52 AM YUVARAJ CD wrote:
> >
> >> Since I am out of station, i dont have an access to my work set up.
> >> Can you send me the dts entries of sd crad and their corresponding regulator entries?
> >
> > From arch/arm/boot/dts/exynos5420-arndale-octa.dts:
> >
> > ...
> > mmc at 12200000 {
> > status = "okay";
> > broken-cd;
> > supports-highspeed;
> > card-detect-delay = <200>;
> > samsung,dw-mshc-ciu-div = <3>;
> > samsung,dw-mshc-sdr-timing = <0 4>;
> > samsung,dw-mshc-ddr-timing = <0 2>;
> > pinctrl-names = "default";
> > pinctrl-0 = <&sd0_clk &sd0_cmd &sd0_bus4 &sd0_bus8>;
> > vmmc-supply = <&ldo10_reg>;
> >
> > slot at 0 {
> > reg = <0>;
> > bus-width = <8>;
> > };
> > };
> >
> > mmc at 12220000 {
> > status = "okay";
> > supports-highspeed;
> > card-detect-delay = <200>;
> > samsung,dw-mshc-ciu-div = <3>;
> > samsung,dw-mshc-sdr-timing = <2 3>;
> > samsung,dw-mshc-ddr-timing = <1 2>;
> > pinctrl-names = "default";
> > pinctrl-0 = <&sd2_clk &sd2_cmd &sd2_cd &sd2_bus4>;
> > vmmc-supply = <&ldo10_reg>;
> >
> > slot at 0 {
> > reg = <0>;
> > bus-width = <4>;
> > };
> > };
> > ...
> > ldo10_reg: LDO10 {
> > regulator-name = "PVDD_PRE_1V8";
> > regulator-min-microvolt = <1800000>;
> > regulator-max-microvolt = <1800000>;
> > regulator-always-on;
> > };
>
> I don't have schematics for Arndale Octa, but the above is really
> fishy. "vmmc" shouldn't be 1.8V. That's the general power signal to
> MMC and should be 2.7V - 3.6V. "vqmmc" could be 1.8V in certain
> situations, but my understanding is that for maximum compatibility it
> should at least start out identical to "vmmc" (and later go down to
> 1.7V - 1.95V).
>
> My first thought would be to just remove the "vmmc-supply" from your
> DTS. I think we could land that and pick it back easily. That will
> get you something working and won't introduce any regressions because:
> 1. MMC core will give you a dummy regulator
> 2. The code will default to assuming that vmmc is 3.3V, which is what
> it used to do anyway.
> 3. The only referenced regulator is always on anyway.
>
> Separately you could specify a proper vmmc and maybe even a vqmmc.
>
> On SMDK5420 I see this for the SD card (mmc2):
> * vmmc should be "VDD_SD_2V8". From LDO19.
> * vqmmc should be "VDDQ_MMC2_AP". From LDO13.
>
> OK, I dug up the Arndale schematics. For mmc2:
> * vmmc should be PVDD_TFLASH_2V8. That's LDO19.
> * vqmmc (hooked up to VDDQ_MMC2): PVDD_APIO_MMCOFF_2V8. LDO13 just like SMDK.
>
> ...sadly it looks like Anrdale has a schematics problem that prevents
> you from doing UHS. I see that the data lines are pulled up to
> PVDD_TFLASH_2V8 (vmmc), not pulled up to PVDD_APIO_MMCOFF_2V8 (vqmmc).
> I think that means that if you ever lower vqmmc to 1.8V (as needed for
> UHS) then you'll still be pulling up to 2.8V. That's not good. You
> should probably make sure that both LDO13 and LDO19 are listed as
> being exactly 2.8V.
>
>
> Anyway, the above has (obviously) not been tested and is just based on
> a casual browsing of schematics. Please let me know how it goes.
Removing the "vmmc-supply" entry fixes the problem. Using LDO13 for vmmc
and LDO19 for vqmmc also works fine. I'll post a patch fixing the mmc2 DT
entry to Kukjin in a few minutes. Thank you for your help.
Best regards,
--
Bartlomiej Zolnierkiewicz
Samsung R&D Institute Poland
Samsung Electronics
More information about the linux-arm-kernel
mailing list