Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp2472577pxb; Mon, 19 Apr 2021 06:35:41 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy3gxP/AaAQvmaYPEO4sbCBS4XAN35wnOxLXtUbwtPlCpE91sywDF/Zc5D604Z/kitBvWiW X-Received: by 2002:aa7:c3d8:: with SMTP id l24mr4255461edr.319.1618839341214; Mon, 19 Apr 2021 06:35:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618839341; cv=none; d=google.com; s=arc-20160816; b=Z4r3mIS2DeGSsTX2enu6sEpJh5RVJfxAGCoR+i7Bxx0lABjfs490BqVDVCheoXUqaS AcKUcIg6w6WP0+RjOO+3ZzLhY5Nh9VmrJwo4Py55jK0HEXpZ1XzfcdTQjWbjkrBaAtmi GydbjN4Qa+j2xWv4O0Nk1L9VWcJsrvgHfFChdx38wr2P0vZtvM9Vg1ttO27Z5zTT5lPs YebOM6lhkBTdtMLLNqYAxd1dIOC5OFURNI3qq2KQokdElkzYY/XyOAS497aYGQ53VX6x FIwqKQEYO88piTJb/cPxz3nN4QzCBCvNirtdgLFw4wCzPy7jUkoBlhhlcCN8l0TyLDzE 5gAQ== 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=EyfIs3+HfZC1xUQ9EWDDbXLKLRRmSdTqy1MdW22iLkZ0wI4PYjpMW0BwppWNhgc2YK nFNIOP9DkdcA9KAqn+yS2HrM9Xiw4CdIFJrTV6hSbfPSHYk7iKY5VUbaNmRPtvSaUj3m Xoscy+I0rgkCh7wG69c/7hUF8SGJKRCi7HLn6sen3vPhoUyK+lRtR5+I/Rda9NV16dUT 6/GFmFbVrt59Hw5KAAkct6XEx+VrOJcGhc00R1C04HVHTWbxexseprpHYTvBnevmNbJS KfGeA8GE9jqHGdWJ0d0edCDTRdaukGb+Ty7imIDWRvSm0uQeOfZYHQMMypMDgAahoEx7 au/g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=zl6OMvkQ; 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 t1si1724706eje.466.2021.04.19.06.35.01; Mon, 19 Apr 2021 06:35:41 -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=zl6OMvkQ; 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 S242511AbhDSN3T (ORCPT + 99 others); Mon, 19 Apr 2021 09:29:19 -0400 Received: from mail.kernel.org ([198.145.29.99]:59636 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S241501AbhDSNUs (ORCPT ); Mon, 19 Apr 2021 09:20:48 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 84FA4613CD; Mon, 19 Apr 2021 13:17:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1618838224; bh=mVTZ/DVql5tiNk6QWlIhCIbgFMKMkNE/J1DwN+CRZAs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=zl6OMvkQZaNBujUsnpzszbORza5x8ouIKIZqXPt1trL2VlMLywH4eQVFdULx5eSks MUcqsIyUj5wo8/TfWlQqoeMOC0HMnR2HaPgLwkSaGEDF188rw0XPnFxz85Y3Ovib5e 0bgz6s3Y8/CuSkzU278tDrDaL8SAW2FUvztazFnM= 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.10 088/103] ARM: footbridge: fix PCI interrupt mapping Date: Mon, 19 Apr 2021 15:06:39 +0200 Message-Id: <20210419130530.822634070@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210419130527.791982064@linuxfoundation.org> References: <20210419130527.791982064@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