All of lore.kernel.org
 help / color / mirror / Atom feed
* sdhci can turn off irq up to 200 ms
@ 2009-07-01 13:15 Matthieu CASTET
  2009-07-09 10:28 ` Matthieu CASTET
  0 siblings, 1 reply; 7+ messages in thread
From: Matthieu CASTET @ 2009-07-01 13:15 UTC (permalink / raw)
  To: sdhci-devel; +Cc: linux-kernel@vger.kernel.org, pierre

Hi,

sdhci code got tasklets (sdhci_tasklet_card and sdhci_tasklet_finish),
that does :
{
spin_lock_irqsave

if (cond) {
sdhci_reset
sdhci_reset
}

spin_unlock_irqrestore
}

The problem is that sdhci_reset [1] does busy pooling on a register up
to a timeout of 100 ms.
That's not low latency friendly.

On our system, we saw that sdhci_reset take 1 ms. That should be because
we enter in mdelay, even if the hardware clears the bit faster.
I wonder why there is an mdelay(1). Using cpu_relax and
time_is_after_jiffies should make sdhci_reset faster.


Matthieu

[1]
static void sdhci_reset(struct sdhci_host *host, u8 mask)
{
    unsigned long timeout;
    u32 uninitialized_var(ier);
[...]
    sdhci_writeb(host, mask, SDHCI_SOFTWARE_RESET);

    if (mask & SDHCI_RESET_ALL)
        host->clock = 0;

    /* Wait max 100 ms */
    timeout = 100;

    /* hw clears the bit when it's done */
    while (sdhci_readb(host, SDHCI_SOFTWARE_RESET) & mask) {
        if (timeout == 0) {
            printk(KERN_ERR "%s: Reset 0x%x never completed.\n",
                mmc_hostname(host->mmc), (int)mask);
            sdhci_dumpregs(host);
            return;
        }
        timeout--;
        mdelay(1);
    }
[...]
}

^ permalink raw reply	[flat|nested] 7+ messages in thread
[parent not found: <cT8cF-7kN-7@gated-at.bofh.it>]

end of thread, other threads:[~2009-09-08  8:56 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-07-01 13:15 sdhci can turn off irq up to 200 ms Matthieu CASTET
2009-07-09 10:28 ` Matthieu CASTET
2009-09-06 13:25   ` Pierre Ossman
2009-09-07  9:56     ` Matthieu CASTET
2009-09-07 16:59       ` Pierre Ossman
2009-09-08  8:56         ` Matthieu CASTET
     [not found] <cT8cF-7kN-7@gated-at.bofh.it>
     [not found] ` <cVZ3a-71r-5@gated-at.bofh.it>
2009-09-07 19:47   ` Daniel J Blueman

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.