From cd43416a78b0cdd194cc35099959f182cdbba015 Mon Sep 17 00:00:00 2001 From: Luka Perkov Date: Wed, 23 Oct 2013 22:16:03 +0000 Subject: imx6: pcie driver fixups Add upstream patches needed for PCIe through a switch. Signed-off-by: Tim Harvey SVN-Revision: 38511 --- ...0032-PCI-imx6-fix-imprecise-abort-handler.patch | 36 ++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 target/linux/imx6/patches-3.10/0032-PCI-imx6-fix-imprecise-abort-handler.patch (limited to 'target/linux/imx6/patches-3.10/0032-PCI-imx6-fix-imprecise-abort-handler.patch') diff --git a/target/linux/imx6/patches-3.10/0032-PCI-imx6-fix-imprecise-abort-handler.patch b/target/linux/imx6/patches-3.10/0032-PCI-imx6-fix-imprecise-abort-handler.patch new file mode 100644 index 0000000..5cef411 --- /dev/null +++ b/target/linux/imx6/patches-3.10/0032-PCI-imx6-fix-imprecise-abort-handler.patch @@ -0,0 +1,36 @@ +From 8590081d5328fe59d4f72aaadafb47fb91d8dc7c Mon Sep 17 00:00:00 2001 +From: Tim Harvey +Date: Thu, 17 Oct 2013 15:52:16 -0700 +Subject: [PATCH] PCI: imx6: fix imprecise abort handler + +An imprecise abort is triggered when a port behind a switch is accessed +and no device is present. At enumeration, imprecise aborts are not enabled +thus this ends up getting deferred until the kernel has completed init. At +that point we must not adjust PC - the handler must do nothing, but a handler +must exist. + +This fixes random crashes that occur right after freeing init. +This is against linux-pci/host-imx6. + +Acked-by: Marek Vasut +Tested-by: Marek Vasut +Signed-off-by: Tim Harvey +--- + drivers/pci/host/pci-imx6.c | 6 ------ + 1 file changed, 6 deletions(-) + +--- a/drivers/pci/host/pci-imx6.c ++++ b/drivers/pci/host/pci-imx6.c +@@ -200,12 +200,6 @@ static int pcie_phy_write(void __iomem * + static int imx6q_pcie_abort_handler(unsigned long addr, + unsigned int fsr, struct pt_regs *regs) + { +- /* +- * If it was an imprecise abort, then we need to correct the +- * return address to be _after_ the instruction. +- */ +- if (fsr & (1 << 10)) +- regs->ARM_pc += 4; + return 0; + } + -- cgit v1.1