Received: by 2002:a05:6a10:a841:0:0:0:0 with SMTP id d1csp3412163pxy; Mon, 26 Apr 2021 00:47:09 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwLO5Lg/pTP7rFRylckvavogj05swHMQehHHv6OWc5ydLXcOrFKcnO2mT0UAAxCwaal1Wlk X-Received: by 2002:a17:90a:db8c:: with SMTP id h12mr8374463pjv.217.1619423229412; Mon, 26 Apr 2021 00:47:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1619423229; cv=none; d=google.com; s=arc-20160816; b=Uh9mQ1lMjFZhulrjMrAsiWchjDHmqrQTOuV4kVTa0rB0c4qPw8N7yMSYHO0XeS/FoH 23Zxbiw/v0rfWyMz3b7gPTq4Kuut6Ha1Vo7DR5LK0CSbOPQEj65kfOqVKld8pLfPcF+l boQIaz8pc6S1IXAoIVu+1sxvURCilVaOmnFJgPA+cHtmz4AT4EITYdTQR3JPRgYRpGPP 5gwibZuEsqqX2ToxCb8pG+6UpHdSOvu5xG+bFZLsP8WnwxQw3ixlRxXn8qbPR10FvkM9 4zRXGrdA7oFBxn7MsiAi/xOZ912SC7KncHkHGhGwUgm773Iv2ULGiWCN9/N/AjC7gbIZ sgYA== 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=hw+6wasySvTu56WdG32oFR1HH3NQFZ0+jvghkQyt8YspohhX9wglUFC0PC3jkl36p/ aoiIgNR7ml0GbaHGikxpkP5OGRNqYHGb/pOblH3sk9EUyYS0eU/yS6l/Oo8sFGCtoDb1 Ooul6haZX1HIlHRgqGkiCAx1SUJ+oSzseDMiUXFbXJict2NaD7rmgo2uebZnxK6AaR64 DANWtN2DUSaQO/N1ewMkGw6iYClsGJH8tTpDGFJqU7VbScEQfCCAOHeFEgN8+Ij6hIAl 5+WzTxgTQdnu+cZoCh+7IrAFzv07NQekSRXNe+BlmCN4r6P91Gkv62a3fO619VAEEhGd OCJw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=fZODo1uF; 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 k3si17473456pgt.359.2021.04.26.00.46.57; Mon, 26 Apr 2021 00:47:09 -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=fZODo1uF; 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 S232646AbhDZHpp (ORCPT + 99 others); Mon, 26 Apr 2021 03:45:45 -0400 Received: from mail.kernel.org ([198.145.29.99]:49330 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233310AbhDZHjU (ORCPT ); Mon, 26 Apr 2021 03:39:20 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 4D6A4613BE; Mon, 26 Apr 2021 07:37:04 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1619422624; bh=mVTZ/DVql5tiNk6QWlIhCIbgFMKMkNE/J1DwN+CRZAs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=fZODo1uFb0gzFe2uYwYVLjCqHjTWCs1iPdYhlmMStxJjI5nLnwPkYik4ENkfhQ7PN C3uz7iWPNcDBbnWGbIv/S185aq1NAMAVzOOasMYmXTQA5DKqqUxqpU0XzAW9JnevRc A9YV39+1Ea+R3EHMZ6OflXt/PXqQVNeijCnnbiII= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Russell King , Sasha Levin Subject: [PATCH 4.19 40/57] ARM: footbridge: fix PCI interrupt mapping Date: Mon, 26 Apr 2021 09:29:37 +0200 Message-Id: <20210426072821.923586511@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210426072820.568997499@linuxfoundation.org> References: <20210426072820.568997499@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