[RESEND PATCH v2 0/3] Tegra30 clockframework
Peter De Schrijver
pdeschrijver at nvidia.com
Tue Jan 10 11:39:05 EST 2012
On Mon, Jan 09, 2012 at 10:30:05PM +0100, Stephen Warren wrote:
> Peter De Schrijver wrote at Monday, January 09, 2012 8:35 AM:
> > This patchset introduces the tegra30 clockframework. Clocks which require
> > voltage scaling are not included in this version. The implementation doesn't
> > use the generic clock code yet. It's the intention to move to it, once the
> > semantics are fully clarified.
> >
> > ---
> >
> > Changes in v2:
> > * Fix parent clocks for TWD. This makes the SMP configuration booting again.
>
> Peter,
>
> This version seems to still boot as well as without these patches.
>
> I hacked some AUXDATA into board-dt-tegra30.c in an attempt to get SDHCI
> working, but found that:
>
> a) sdhci_add_host() fails due to:
>
> mmc0: Hardware doesn't specify timeout clock frequency.
>
> I haven't investigated why this happens.
>
I had a look at it, but I haven't found the rootcause.
> b) More directly related to these patches, when sdhci_add_host() fails,
> sdhci_tegra_probe() calls clk_disable() and clk_put() on its clock. One
> of these hangs somehow. I assume that's a bug in this clock patch?
>
Sortof. The rootcause for this one is that pll_p gets disabled when
sdhci_tegra_probe() calls clk_disable(). pll_p also provides the input clock
for UARTD however, so the next printk() call will hang the system. The reason
for this is that no kernel driver has actually enabled the UARTD clock at that
point, and thus pll_p hasn't been turned on from a clock framework point of
view.
Workaround is to enable UARTD in board-dt-tegra30 like we do for tegra20. I
guess we need a better solution to cope with a different UART being the
console UART. (See next mail)
Cheers,
Peter.
More information about the linux-arm-kernel
mailing list