mirror of
https://github.com/archlinuxarm/PKGBUILDs.git
synced 2025-01-17 23:34:07 +00:00
enable MMC_MVSDIO and patch it to restore pre-DTB IRQ handling
This commit is contained in:
parent
2f748f11fd
commit
19905520cd
3 changed files with 135 additions and 3 deletions
|
@ -8,16 +8,18 @@ _srcname=linux
|
|||
_kernelname=${pkgbase#linux}
|
||||
_desc="ARMv5 based platforms"
|
||||
pkgver=3.13.0
|
||||
pkgrel=1
|
||||
pkgrel=2
|
||||
arch=('arm')
|
||||
url="http://www.kernel.org/"
|
||||
license=('GPL2')
|
||||
makedepends=('xmlto' 'docbook-xsl' 'kmod' 'inetutils' 'bc' 'git')
|
||||
options=('!strip')
|
||||
source=("http://www.x386.net/misc/linux-3.13.mvebu.tar.gz"
|
||||
'fix-kirkwood-dtb-irq-handling.patch'
|
||||
'config')
|
||||
md5sums=('587794c64ee027245e5ed6af6a7c99af'
|
||||
'be6a3a3eb9c9dbe82f18afe2ae3588d2')
|
||||
'ed92734a4efae8cb68d84c8531fc9fee'
|
||||
'ac1dbeaf123e54e17fad21cfbcc4d242')
|
||||
|
||||
prepare() {
|
||||
cd "${srcdir}/${_srcname}"
|
||||
|
@ -29,6 +31,8 @@ prepare() {
|
|||
|
||||
# don't run depmod on 'make install'. We'll do this ourselves in packaging
|
||||
sed -i '2iexit 0' scripts/depmod.sh
|
||||
|
||||
patch -p1 -i ../fix-kirkwood-dtb-irq-handling.patch
|
||||
}
|
||||
|
||||
build() {
|
||||
|
|
|
@ -3469,7 +3469,7 @@ CONFIG_MMC_BLOCK_BOUNCE=y
|
|||
# CONFIG_MMC_SDHCI_PXAV2 is not set
|
||||
CONFIG_MMC_MXS=y
|
||||
# CONFIG_MMC_TIFM_SD is not set
|
||||
# CONFIG_MMC_MVSDIO is not set
|
||||
CONFIG_MMC_MVSDIO=m
|
||||
# CONFIG_MMC_CB710 is not set
|
||||
# CONFIG_MMC_VIA_SDMMC is not set
|
||||
# CONFIG_MMC_DW is not set
|
||||
|
|
128
core/linux-armv5-test/fix-kirkwood-dtb-irq-handling.patch
Normal file
128
core/linux-armv5-test/fix-kirkwood-dtb-irq-handling.patch
Normal file
|
@ -0,0 +1,128 @@
|
|||
mvsdio reports method of card detection with dev_notice, while for
|
||||
removable cards it may be sane, for non-removable cards it is not.
|
||||
Also, as the user cannot do anything about it, silence the message
|
||||
by reducing it from dev_notice to dev_dbg.
|
||||
|
||||
Signed-off-by: Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com>
|
||||
---
|
||||
Cc: Nicolas Pitre <nico@fluxnic.net>
|
||||
Cc: Chris Ball <cjb@laptop.org>
|
||||
Cc: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
|
||||
Cc: Jason Cooper <jason@lakedaemon.net>
|
||||
Cc: Andrew Lunn <andrew@lunn.ch>
|
||||
Cc: linux-mmc@vger.kernel.org
|
||||
Cc: linux-arm-kernel@lists.infradead.org
|
||||
Cc: linux-kernel@vger.kernel.org
|
||||
---
|
||||
drivers/mmc/host/mvsdio.c | 5 ++---
|
||||
1 files changed, 2 insertions(+), 3 deletions(-)
|
||||
diff --git a/drivers/mmc/host/mvsdio.c b/drivers/mmc/host/mvsdio.c
|
||||
index 25f51be..d17b399 100644
|
||||
--- a/drivers/mmc/host/mvsdio.c
|
||||
+++ b/drivers/mmc/host/mvsdio.c
|
||||
@@ -816,10 +816,9 @@ static int __init mvsd_probe(struct platform_device *pdev)
|
||||
goto out;
|
||||
|
||||
if (!(mmc->caps & MMC_CAP_NEEDS_POLL))
|
||||
- dev_notice(&pdev->dev, "using GPIO for card detection\n");
|
||||
+ dev_dbg(&pdev->dev, "using GPIO for card detection\n");
|
||||
else
|
||||
- dev_notice(&pdev->dev,
|
||||
- "lacking card detect (fall back to polling)\n");
|
||||
+ dev_dbg(&pdev->dev, "lacking card detect, fall back to polling\n");
|
||||
return 0;
|
||||
|
||||
out:
|
||||
--
|
||||
1.7.2.5
|
||||
|
||||
Non-DT irq handlers were working through irq causes from most-significant
|
||||
to least-significant bit, while DT irqchip driver does it the other way
|
||||
round. This revealed some more HW issues on Kirkwood peripheral IP, where
|
||||
spurious sdio irqs can happen although IP's irq enable registers are all
|
||||
zero. Although, not directly related with the described issue, reverse
|
||||
irq bit handling back to original order by replacing ffs() with fls().
|
||||
|
||||
Signed-off-by: Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com>
|
||||
---
|
||||
Cc: Thomas Gleixner <tglx@linutronix.de>
|
||||
Cc: Jason Cooper <jason@lakedaemon.net>
|
||||
Cc: Andrew Lunn <andrew@lunn.ch>
|
||||
Cc: Russell King <linux@arm.linux.org.uk>
|
||||
Cc: linux-arm-kernel@lists.infradead.org
|
||||
Cc: linux-kernel@vger.kernel.org
|
||||
---
|
||||
drivers/irqchip/irq-orion.c | 4 ++--
|
||||
1 files changed, 2 insertions(+), 2 deletions(-)
|
||||
diff --git a/drivers/irqchip/irq-orion.c b/drivers/irqchip/irq-orion.c
|
||||
index e51d400..de30d5c 100644
|
||||
--- a/drivers/irqchip/irq-orion.c
|
||||
+++ b/drivers/irqchip/irq-orion.c
|
||||
@@ -42,7 +42,7 @@ __exception_irq_entry orion_handle_irq(struct pt_regs *regs)
|
||||
u32 stat = readl_relaxed(gc->reg_base + ORION_IRQ_CAUSE) &
|
||||
gc->mask_cache;
|
||||
while (stat) {
|
||||
- u32 hwirq = ffs(stat) - 1;
|
||||
+ u32 hwirq = __fls(stat);
|
||||
u32 irq = irq_find_mapping(orion_irq_domain,
|
||||
gc->irq_base + hwirq);
|
||||
handle_IRQ(irq, regs);
|
||||
@@ -116,7 +116,7 @@ static void orion_bridge_irq_handler(unsigned int irq, struct irq_desc *desc)
|
||||
gc->mask_cache;
|
||||
|
||||
while (stat) {
|
||||
- u32 hwirq = ffs(stat) - 1;
|
||||
+ u32 hwirq = __fls(stat);
|
||||
|
||||
generic_handle_irq(irq_find_mapping(d, gc->irq_base + hwirq));
|
||||
stat &= ~(1 << hwirq);
|
||||
--
|
||||
1.7.2.5
|
||||
|
||||
SDIO controllers found on Marvell Kirkwood SoCs seem to cause a late,
|
||||
spurious irq although all interrupts have been disabled. This irq
|
||||
doesn't do any harm, neither to HW nor driver. To avoid some
|
||||
"unexpected irq" warning later, we workaround above issue by bailing
|
||||
out of irq handler early, if we didn't expect any.
|
||||
|
||||
Signed-off-by: Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com>
|
||||
---
|
||||
Cc: Nicolas Pitre <nico@fluxnic.net>
|
||||
Cc: Chris Ball <cjb@laptop.org>
|
||||
Cc: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
|
||||
Cc: Jason Cooper <jason@lakedaemon.net>
|
||||
Cc: Andrew Lunn <andrew@lunn.ch>
|
||||
Cc: linux-mmc@vger.kernel.org
|
||||
Cc: linux-arm-kernel@lists.infradead.org
|
||||
Cc: linux-kernel@vger.kernel.org
|
||||
---
|
||||
drivers/mmc/host/mvsdio.c | 15 +++++++++++++++
|
||||
1 files changed, 15 insertions(+), 0 deletions(-)
|
||||
diff --git a/drivers/mmc/host/mvsdio.c b/drivers/mmc/host/mvsdio.c
|
||||
index 06c5b0b..25f51be 100644
|
||||
--- a/drivers/mmc/host/mvsdio.c
|
||||
+++ b/drivers/mmc/host/mvsdio.c
|
||||
@@ -354,6 +354,21 @@ static irqreturn_t mvsd_irq(int irq, void *dev)
|
||||
intr_status, mvsd_read(MVSD_NOR_INTR_EN),
|
||||
mvsd_read(MVSD_HW_STATE));
|
||||
|
||||
+ /*
|
||||
+ * It looks like, SDIO IP can issue one late, spurious irq
|
||||
+ * although all irqs should be disabled. To work around this,
|
||||
+ * bail out early, if we didn't expect any irqs to occur.
|
||||
+ */
|
||||
+ if (!mvsd_read(MVSD_NOR_INTR_EN) && !mvsd_read(MVSD_ERR_INTR_EN)) {
|
||||
+ dev_dbg(host->dev,
|
||||
+ "spurious irq detected intr 0x%04x intr_en 0x%04x erri 0x%04x erri_en 0x%04x\n",
|
||||
+ mvsd_read(MVSD_NOR_INTR_STATUS),
|
||||
+ mvsd_read(MVSD_NOR_INTR_EN),
|
||||
+ mvsd_read(MVSD_ERR_INTR_STATUS),
|
||||
+ mvsd_read(MVSD_ERR_INTR_EN));
|
||||
+ return IRQ_HANDLED;
|
||||
+ }
|
||||
+
|
||||
spin_lock(&host->lock);
|
||||
|
||||
/* PIO handling, if needed. Messy business... */
|
||||
--
|
||||
1.7.2.5
|
Loading…
Reference in a new issue