Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp2478778pxb; Mon, 19 Apr 2021 06:44:16 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx1lblwD0hvESZx0GSwqwnSghPl+q9biefuZoeP6GPruyKEXMH7BLdxulHxVaGL3L3F4YJL X-Received: by 2002:a05:6402:254f:: with SMTP id l15mr25894613edb.189.1618839856398; Mon, 19 Apr 2021 06:44:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618839856; cv=none; d=google.com; s=arc-20160816; b=K5Uvxq85G3axFBYUdaznCYXfYr6U9uVMchCbSYaVGdILn9uWhonn0UalxRyXh59wsK y1iflpgjvMhRnOgw/blz1ByTsOM/RpH/M5jWLErjtoqa8NQdO1Y/jrS4Ytk2qyQyKjrF U0sMULpKQeAV13XiJq/Ei5EH/QhUXJ6k1bA3XLBCkf2XMxY8+UW36piMIkwZJejiW7d5 WkVpwbvHImOnL5V0BNR26J1UYPrXS63jHij4lgjSToU5LMMVj1fZL51IIRyHMLoZ9rPF n9VhgUREm5yG75NEs2STYRMkqHReehTMEf2DIJkcalxqkjvNoTiiIa0scroQJgDzYtkc YeOA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=PMC3Ky6quHfBjDRqVHZpMZOosgTGk50JJvLHHQY3ICc=; b=FbX8Um+eeXFhmpFZc6NeWYBfnU474CwW0y6Eu4dQFCnZECyZq8QWQAAcuFQLLPDC/d uOcfoaXdSvBPM9VHUKDed9i2/3x3MIJdVewPJRObDymVJgvNVR5CiZGLr27cTFgGebtf mBWMTuvEVR0DJbNppcxfLopnmCqSVI40L6aknfcHziMI6t8/0ZB33xwrblvBhodm4Da/ mZNnZEm2uAznPlOuI2QjaYnC9tmCI5lUwmpk1+rqeCXlUz9RU5fTtxjEg7NbhfEPbRea ayOJU39sr7rGhmep+HNfkyCLtD5yWnf9giJ68QPd8PM35X97T1DRTh6N3uU8aQxZuROG ozZw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=s2UF9xTv; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id q23si12791629ejy.319.2021.04.19.06.43.52; Mon, 19 Apr 2021 06:44:16 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=s2UF9xTv; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242762AbhDSNjd (ORCPT + 99 others); Mon, 19 Apr 2021 09:39:33 -0400 Received: from mail.kernel.org ([198.145.29.99]:34014 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241626AbhDSN0U (ORCPT ); Mon, 19 Apr 2021 09:26:20 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 3A2FD613CD; Mon, 19 Apr 2021 13:21:20 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1618838480; bh=mVTZ/DVql5tiNk6QWlIhCIbgFMKMkNE/J1DwN+CRZAs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=s2UF9xTvDOBv2jY0I4sW+h8S8g4UclT8pBcmfTuRTpl/2w2FminO/FU7rZa9iiVzd aOo5RPWmwGKoSLGIN9UnahOiNQM/n2eFlEacG63KKpvCaBRnMPcbtL7vaBOGLXjk6x kIIgDnLQvTVTuzYlIQAFbH5WdiprBeAr9b/fL8dc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Russell King , Sasha Levin Subject: [PATCH 5.4 64/73] ARM: footbridge: fix PCI interrupt mapping Date: Mon, 19 Apr 2021 15:06:55 +0200 Message-Id: <20210419130525.902109390@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210419130523.802169214@linuxfoundation.org> References: <20210419130523.802169214@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Russell King [ Upstream commit 30e3b4f256b4e366a61658c294f6a21b8626dda7 ] Since commit 30fdfb929e82 ("PCI: Add a call to pci_assign_irq() in pci_device_probe()"), the PCI code will call the IRQ mapping function whenever a PCI driver is probed. If these are marked as __init, this causes an oops if a PCI driver is loaded or bound after the kernel has initialised. Fixes: 30fdfb929e82 ("PCI: Add a call to pci_assign_irq() in pci_device_probe()") Signed-off-by: Russell King Signed-off-by: Sasha Levin --- arch/arm/mach-footbridge/cats-pci.c | 4 ++-- arch/arm/mach-footbridge/ebsa285-pci.c | 4 ++-- arch/arm/mach-footbridge/netwinder-pci.c | 2 +- arch/arm/mach-footbridge/personal-pci.c | 5 ++--- 4 files changed, 7 insertions(+), 8 deletions(-) diff --git a/arch/arm/mach-footbridge/cats-pci.c b/arch/arm/mach-footbridge/cats-pci.c index 0b2fd7e2e9b4..90b1e9be430e 100644 --- a/arch/arm/mach-footbridge/cats-pci.c +++ b/arch/arm/mach-footbridge/cats-pci.c @@ -15,14 +15,14 @@ #include /* cats host-specific stuff */ -static int irqmap_cats[] __initdata = { IRQ_PCI, IRQ_IN0, IRQ_IN1, IRQ_IN3 }; +static int irqmap_cats[] = { IRQ_PCI, IRQ_IN0, IRQ_IN1, IRQ_IN3 }; static u8 cats_no_swizzle(struct pci_dev *dev, u8 *pin) { return 0; } -static int __init cats_map_irq(const struct pci_dev *dev, u8 slot, u8 pin) +static int cats_map_irq(const struct pci_dev *dev, u8 slot, u8 pin) { if (dev->irq >= 255) return -1; /* not a valid interrupt. */ diff --git a/arch/arm/mach-footbridge/ebsa285-pci.c b/arch/arm/mach-footbridge/ebsa285-pci.c index 6f28aaa9ca79..c3f280d08fa7 100644 --- a/arch/arm/mach-footbridge/ebsa285-pci.c +++ b/arch/arm/mach-footbridge/ebsa285-pci.c @@ -14,9 +14,9 @@ #include #include -static int irqmap_ebsa285[] __initdata = { IRQ_IN3, IRQ_IN1, IRQ_IN0, IRQ_PCI }; +static int irqmap_ebsa285[] = { IRQ_IN3, IRQ_IN1, IRQ_IN0, IRQ_PCI }; -static int __init ebsa285_map_irq(const struct pci_dev *dev, u8 slot, u8 pin) +static int ebsa285_map_irq(const struct pci_dev *dev, u8 slot, u8 pin) { if (dev->vendor == PCI_VENDOR_ID_CONTAQ && dev->device == PCI_DEVICE_ID_CONTAQ_82C693) diff --git a/arch/arm/mach-footbridge/netwinder-pci.c b/arch/arm/mach-footbridge/netwinder-pci.c index 9473aa0305e5..e8304392074b 100644 --- a/arch/arm/mach-footbridge/netwinder-pci.c +++ b/arch/arm/mach-footbridge/netwinder-pci.c @@ -18,7 +18,7 @@ * We now use the slot ID instead of the device identifiers to select * which interrupt is routed where. */ -static int __init netwinder_map_irq(const struct pci_dev *dev, u8 slot, u8 pin) +static int netwinder_map_irq(const struct pci_dev *dev, u8 slot, u8 pin) { switch (slot) { case 0: /* host bridge */ diff --git a/arch/arm/mach-footbridge/personal-pci.c b/arch/arm/mach-footbridge/personal-pci.c index 4391e433a4b2..9d19aa98a663 100644 --- a/arch/arm/mach-footbridge/personal-pci.c +++ b/arch/arm/mach-footbridge/personal-pci.c @@ -14,13 +14,12 @@ #include #include -static int irqmap_personal_server[] __initdata = { +static int irqmap_personal_server[] = { IRQ_IN0, IRQ_IN1, IRQ_IN2, IRQ_IN3, 0, 0, 0, IRQ_DOORBELLHOST, IRQ_DMA1, IRQ_DMA2, IRQ_PCI }; -static int __init personal_server_map_irq(const struct pci_dev *dev, u8 slot, - u8 pin) +static int personal_server_map_irq(const struct pci_dev *dev, u8 slot, u8 pin) { unsigned char line; -- 2.30.2