From: Georg Gast <georg@schorsch-tech.de>
To: Tom Cook <tom.k.cook@gmail.com>
Cc: linux-rt-users@vger.kernel.org
Subject: Re: Searching a Bug on Raspberry Pi
Date: Sun, 30 Jun 2013 06:42:07 +0200 [thread overview]
Message-ID: <51CFB71F.5090401@schorsch-tech.de> (raw)
In-Reply-To: <CAFSh4Uz7B8L5Y0nsp1bW4pgPkyqHtXDSM0R-PiRLZQfd+URFYw@mail.gmail.com>
Hi Tom,
the problem occurs even if i set enable_llm=0. The while loop is now not
touched and the rpi deadlocks too.
As far as i understand it, the sdhci.c is the base for all sdhci card
readers and the sdhci-*.c implement the ops for the specific hardware.
My problem is, that i dont have an other sdhci card reader here. It wont
be possible to boot from, but i could try to read from it on a rt
kernel. If i compile the sdhci_bcm2708 as a module, i could not get a
device info from the rpi reader. Maybe an other reader works, then the
real problem sits in sdhci_bcm2708.c (or at bad luck, it shows an bigger
problem in sdhci.c).
Georg
Am 29.06.2013 23:36, schrieb Tom Cook:
> This is as far as I've got too. I think you need to make the while loop
> conditional on CONFIG_PREEMPT_RT_FULL but I haven't had a chance to try it.
>
> Tom
>
> On 29 Jun 2013 21:16, "Georg Gast" <georg@schorsch-tech.de
> <mailto:georg@schorsch-tech.de>> wrote:
>
> Hi there!
>
> Currently i try to locate a bug in drivers/mmc/host/sdhci.c on
> RaspberryPi. I know it is not the mainline kernel...
>
> Currently i use Kernel 3.8.13 and RT Patch 3.8.13-rt12 on the kernel
> found at git://github.com/raspberrypi/__linux.git
> <http://github.com/raspberrypi/linux.git> on branch rpi-3.8.y.
>
> The bug shows up at booting and after 3 seconds of booting as it
> wants to mount the rootfs in a deadlock. as i compiled sdhci_bcm2708
> as a module i can boot the kernel and system as i pushed the system
> to a usb stick. As far as good.
>
> Now i try to find the bug, if the rootfs is on the sdcard. I narrowd
> the deadlock down to the following lines:
>
> void sdhci_spin_lock_irqsave(struct sdhci_host *host,unsigned long
> *flags)
> {
> return;
> #ifdef CONFIG_PREEMPT
> if(enable_llm)
> {
> while(sdhci_locked)
> {
> preempt_schedule();
> }
> spin_lock_irqsave(&host->lock,__*flags);
> disable_irq(host->irq);
> if(host->second_irq)
> disable_irq(host->second_irq);
> local_irq_enable();
> }
> else
> #endif
> spin_lock_irqsave(&host->lock,__*flags);
> }
>
> void sdhci_spin_unlock_irqrestore(__struct sdhci_host *host,unsigned
> long flags)
> {
> return;
> #ifdef CONFIG_PREEMPT
> if(enable_llm)
> {
> local_irq_disable();
> if(host->second_irq)
> enable_irq(host->second_irq);
> enable_irq(host->irq);
> }
> #endif
> spin_unlock_irqrestore(&host->__lock,flags);
> }
>
> in drivers/mmc/host/sdhci.c . The both return statements are added
> by me. Now i can boot the RT Preempt kernel but it is for sure not
> the right fix.
>
> My problem is, that i dont know how those both functions should work
> with the rt preempt patch.
>
> What can you suggest me to fix that deadlock? I already bought the
> book "Linux Kernel Development" but i dont know how the kernel works
> exaktly with the PREEMPT patch. Can you point me to a site which
> shows how RTPREEMPT works in the irqsave/restore functions or can
> you please describe it to me?
>
> Thank you
> Georg
> --
> To unsubscribe from this list: send the line "unsubscribe
> linux-rt-users" in
> the body of a message to majordomo@vger.kernel.org
> <mailto:majordomo@vger.kernel.org>
> More majordomo info at http://vger.kernel.org/__majordomo-info.html
> <http://vger.kernel.org/majordomo-info.html>
>
next prev parent reply other threads:[~2013-06-30 4:44 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-06-29 20:14 Searching a Bug on Raspberry Pi Georg Gast
[not found] ` <CAFSh4Uz7B8L5Y0nsp1bW4pgPkyqHtXDSM0R-PiRLZQfd+URFYw@mail.gmail.com>
2013-06-30 4:42 ` Georg Gast [this message]
2013-07-04 10:45 ` Jeremy Jongepier
-- strict thread matches above, loose matches on Subject: below --
2013-06-29 18:28 Georg Gast
2013-07-04 12:14 ` Kirill Tkhai
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=51CFB71F.5090401@schorsch-tech.de \
--to=georg@schorsch-tech.de \
--cc=linux-rt-users@vger.kernel.org \
--cc=tom.k.cook@gmail.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.