From: Marek Szyprowski <m.szyprowski@samsung.com>
To: 'Ben Dooks' <ben@simtec.co.uk>
Cc: linux-mmc@vger.kernel.org, linux-samsung-soc@vger.kernel.org,
linux-arm-kernel@lists.infradead.org, kgene.kim@samsung.com,
broonie@opensource.wolfsonmicro.com, kyungmin.park@samsung.com,
ben-linux@fluff.org, akpm@linux-foundation.org
Subject: RE: [PATCHv2 1/4] sdhci-s3c: add support for the non standard minimal clock value
Date: Thu, 29 Jul 2010 07:30:36 +0200 [thread overview]
Message-ID: <00b001cb2edf$33d6a200$9b83e600$%szyprowski@samsung.com> (raw)
In-Reply-To: <4C505F44.20100@simtec.co.uk>
Hello,
On Wednesday, July 28, 2010 6:48 PM Ben Dooks wrote:
> On 28/07/10 15:19, Marek Szyprowski wrote:
> > S3C SDHCI host controller can change the source for generating mmc clock.
> > By default host bus clock is used, what causes some problems on machines
> > with 133MHz bus, because the SDHCI divider cannot be as high get proper
> > clock value for identification mode. This is not a problem for the
> > controller, because it can generate lower frequencies from other clock
> > sources. This patch adds a new quirk to SDHCI driver to calculate the
> > minimal supported clock frequency.
> >
> > This fixes the flood of the following warnings on Samsung S5PV210 SoCs:
> > mmc0: Minimum clock frequency too high for identification mode
> >
> > Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com>
> > Signed-off-by: Kyungmin Park <kyungmin.park@samsung.com>
> > ---
> >
> > Changes since V1:
> > - rebased onto latest -mm kernel tree
> >
> > ---
> > drivers/mmc/host/sdhci-of-esdhc.c | 1 +
> > drivers/mmc/host/sdhci-s3c.c | 29 +++++++++++++++++++++++++++++
> > drivers/mmc/host/sdhci.c | 2 +-
> > drivers/mmc/host/sdhci.h | 2 ++
> > 4 files changed, 33 insertions(+), 1 deletions(-)
> >
> > diff --git a/drivers/mmc/host/sdhci-of-esdhc.c b/drivers/mmc/host/sdhci-
> of-esdhc.c
> > index e9f99fe..763b364 100644
> > --- a/drivers/mmc/host/sdhci-of-esdhc.c
> > +++ b/drivers/mmc/host/sdhci-of-esdhc.c
> > @@ -124,6 +124,7 @@ struct sdhci_of_data sdhci_esdhc = {
> > SDHCI_QUIRK_BROKEN_CARD_DETECTION |
> > SDHCI_QUIRK_NO_BUSY_IRQ |
> > SDHCI_QUIRK_NONSTANDARD_CLOCK |
> > + SDHCI_QUIRK_NONSTANDARD_MINCLOCK |
> > SDHCI_QUIRK_DATA_TIMEOUT_USES_SDCLK |
> > SDHCI_QUIRK_PIO_NEEDS_DELAY |
> > SDHCI_QUIRK_RESTORE_IRQS_AFTER_RESET |
> > diff --git a/drivers/mmc/host/sdhci-s3c.c b/drivers/mmc/host/sdhci-s3c.c
> > index d7058ee..5218f2b 100644
> > --- a/drivers/mmc/host/sdhci-s3c.c
> > +++ b/drivers/mmc/host/sdhci-s3c.c
> > @@ -203,9 +203,36 @@ static void sdhci_s3c_set_clock(struct sdhci_host
> *host, unsigned int clock)
> > }
> > }
> >
> > +/**
> > + * sdhci_s3c_get_min_clock - callback to get minimal supported clock
> value
> > + * @host: The SDHCI host being queried
> > + *
> > + * To init mmc host properly a minimal clock value is needed. For high
> system
> > + * bus clock's values the standard formula gives values out of allowed
> range.
> > + * The clock still can be set to lower values, if clock source other
> then
> > + * system bus is selected.
> > +*/
> > +static unsigned int sdhci_s3c_get_min_clock(struct sdhci_host *host)
> > +{
> > + struct sdhci_s3c *ourhost = to_s3c(host);
> > + unsigned int delta, min = UINT_MAX;
> > + int src;
> > +
> > + for (src = 0; src < MAX_BUS_CLK; src++) {
> > + delta = sdhci_s3c_consider_clock(ourhost, src, 0);
> > + if (delta == UINT_MAX)
> > + continue;
> > + /* delta is a negative value in this case */
> > + if (-delta < min)
> > + min = -delta;
> > + }
> > + return min;
> > +}
> > +
> > static struct sdhci_ops sdhci_s3c_ops = {
> > .get_max_clock = sdhci_s3c_get_max_clk,
> > .set_clock = sdhci_s3c_set_clock,
> > + .get_min_clock = sdhci_s3c_get_min_clock,
> > };
> >
> > static int __devinit sdhci_s3c_probe(struct platform_device *pdev)
> > @@ -309,6 +336,8 @@ static int __devinit sdhci_s3c_probe(struct
> platform_device *pdev)
> > host->quirks = 0;
> > host->irq = irq;
> >
> > + host->quirks |= SDHCI_QUIRK_NONSTANDARD_MINCLOCK;
> > +
> > /* Setup quirks for the controller */
> > host->quirks |= SDHCI_QUIRK_NO_ENDATTR_IN_NOPDESC;
> >
> > diff --git a/drivers/mmc/host/sdhci.c b/drivers/mmc/host/sdhci.c
> > index 07b2695..682b285 100644
> > --- a/drivers/mmc/host/sdhci.c
> > +++ b/drivers/mmc/host/sdhci.c
> > @@ -1776,7 +1776,7 @@ int sdhci_add_host(struct sdhci_host *host)
> > * Set host parameters.
> > */
> > mmc->ops = &sdhci_ops;
> > - if (host->quirks & SDHCI_QUIRK_NONSTANDARD_CLOCK &&
> > + if (host->quirks & SDHCI_QUIRK_NONSTANDARD_MINCLOCK &&
> > host->ops->get_min_clock)
> > mmc->f_min = host->ops->get_min_clock(host);
>
> We're begining to run out of quirk space, given these fields will
> be initialised to NULL if not used, then why not just check for
> the op being present?
Ok, I can remove the quirk and just check if the op is present. However
having a separate quirk makes the code easier to understand (quirk shows
that the particular implementation differs from the standard).
Best regards
--
Marek Szyprowski
Samsung Poland R&D Center
next prev parent reply other threads:[~2010-07-29 5:32 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-07-28 14:19 [PATCH] SDHCI-S3C updates Marek Szyprowski
2010-07-28 14:19 ` [PATCHv2 1/4] sdhci-s3c: add support for the non standard minimal clock value Marek Szyprowski
2010-07-28 16:48 ` Ben Dooks
2010-07-29 5:30 ` Marek Szyprowski [this message]
2010-07-28 14:19 ` [PATCH 2/4] sdhci-s3c: enable SDHCI_QUIRK_NO_HISPD_BIT quirk Marek Szyprowski
2010-07-28 14:19 ` [PATCHv5 3/4] sdhci-s3c: add support for new card detection methods (driver part) Marek Szyprowski
2010-07-28 14:39 ` Maurus Cuelenaere
2010-07-29 5:22 ` Marek Szyprowski
2010-07-28 17:03 ` Ben Dooks
2010-07-29 5:40 ` Marek Szyprowski
2010-07-28 14:19 ` [PATCH 4/4] sdhci-s3c: add regulator support Marek Szyprowski
2010-07-28 14:48 ` Maurus Cuelenaere
2010-07-28 15:41 ` Mark Brown
2010-07-28 17:06 ` Maurus Cuelenaere
2010-07-28 17:14 ` Mark Brown
2010-07-29 5:28 ` Marek Szyprowski
2010-07-28 17:39 ` Mark Brown
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='00b001cb2edf$33d6a200$9b83e600$%szyprowski@samsung.com' \
--to=m.szyprowski@samsung.com \
--cc=akpm@linux-foundation.org \
--cc=ben-linux@fluff.org \
--cc=ben@simtec.co.uk \
--cc=broonie@opensource.wolfsonmicro.com \
--cc=kgene.kim@samsung.com \
--cc=kyungmin.park@samsung.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-mmc@vger.kernel.org \
--cc=linux-samsung-soc@vger.kernel.org \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).