Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2655731pxj; Mon, 14 Jun 2021 04:10:27 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx/B5tj4YEx6J+XT9lQYaZPZqCHxlAtwuoz8KrPW0Ma57/wZkd0XI+yzKHcBjDTlCzkF8+k X-Received: by 2002:a05:6402:510e:: with SMTP id m14mr16350916edd.225.1623669027408; Mon, 14 Jun 2021 04:10:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623669027; cv=none; d=google.com; s=arc-20160816; b=pzAcxBiIJfp0jKSdONgsiY/4sk38gPIs9OMOw+OtfvokwqA3T+ALPtDGB34jTGtMst xoS84VNVzies3hFz4T7oJtY6Rc0AtmuoIIm7WGqOeWVBF01wnoIlMgVH3RFCaA34C2rX 1w0XnwYJPAM9ezIleryW96gcQoKpgrzWE3/Kf3BJCBoEaVn8OH2JW1njwaWZSFucNHRR cZauUdYdPADMIFSC21jeCRcjNQAZtY4dALDcrMYtu7IhBq9RwlDgMo5hj3TJOsPIyqae oSz1HeBLX4J3cEhzRhuoVIFURxHpKunnpz4K/itzLIYCrLegv8IFVXpn+GoTFzqAYFgj xMfQ== 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=KxXUzutMi31Agpf6UtCswWfagxuQDwT5m30cKVByeX8=; b=WBzxXCd/lAixd15dflBgQ8t2+RCc+Zu2bC0Xs4V3pc+pD9I3vUmey04b4b2Gzqqdld MLejhFjXLQDjVuG+KNnGIetTQrGaXJqbOSVEUDTberXKeeAEl/7V/Ne6R5oxBsPqYdzL dH6gXMk891o3x/Z5UcRJaVSKjgNefC5p+bTrzjl4c/1T0Bj3b4chn8FgZvlEh09HhHJU tELKg31kO6L0Ydj0iMP510spGScjAlw+2f/2dwcaEqM1f+92q7SPt+sY+ZI8mjyei1UI ETidyWj64xKdD6Q9gS4rZb0S7seMIDNgGXCZusNx6EpD3FHP3Ei1cAyL5O14v+WXpzJG mhBQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=CkS2Lcsm; 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 p22si11661327edq.409.2021.06.14.04.10.05; Mon, 14 Jun 2021 04:10:27 -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=CkS2Lcsm; 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 S235297AbhFNLJY (ORCPT + 99 others); Mon, 14 Jun 2021 07:09:24 -0400 Received: from mail.kernel.org ([198.145.29.99]:35516 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233959AbhFNK6l (ORCPT ); Mon, 14 Jun 2021 06:58:41 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 1708C6142D; Mon, 14 Jun 2021 10:41:59 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1623667320; bh=snku4en0Eu155KqUZ2dmB9MsramNl5r2KoFv8VKWZxk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=CkS2LcsmEWYuZAeg0PvBfkPYFjCPbfIgbgoLQH1gbaJJMHUPqB0zFM3FlIp3DYh2w voZbjTILGGjZQhyIk382ss/KXpANxFo7j9YY0nsAviqlsEtYOSte/H2vzltOyh5NbW MS/3UlHOngFzHbxGiLUKHeBo5IYZMuacswblNj8A= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, =?UTF-8?q?=C3=8D=C3=B1igo=20Huguet?= , "David S. Miller" , Sasha Levin Subject: [PATCH 5.10 025/131] net:sfc: fix non-freed irq in legacy irq mode Date: Mon, 14 Jun 2021 12:26:26 +0200 Message-Id: <20210614102653.858757533@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210614102652.964395392@linuxfoundation.org> References: <20210614102652.964395392@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: Íñigo Huguet [ Upstream commit 8f03eeb6e0a0a0b8d617ee0a4bce729e47130036 ] SFC driver can be configured via modparam to work using MSI-X, MSI or legacy IRQ interrupts. In the last one, the interrupt was not properly released on module remove. It was not freed because the flag irqs_hooked was not set during initialization in the case of using legacy IRQ. Example of (trimmed) trace during module remove without this fix: remove_proc_entry: removing non-empty directory 'irq/125', leaking at least '0000:3b:00.1' WARNING: CPU: 39 PID: 3658 at fs/proc/generic.c:715 remove_proc_entry+0x15c/0x170 ...trimmed... Call Trace: unregister_irq_proc+0xe3/0x100 free_desc+0x29/0x70 irq_free_descs+0x47/0x70 mp_unmap_irq+0x58/0x60 acpi_unregister_gsi_ioapic+0x2a/0x40 acpi_pci_irq_disable+0x78/0xb0 pci_disable_device+0xd1/0x100 efx_pci_remove+0xa1/0x1e0 [sfc] pci_device_remove+0x38/0xa0 __device_release_driver+0x177/0x230 driver_detach+0xcb/0x110 bus_remove_driver+0x58/0xd0 pci_unregister_driver+0x2a/0xb0 efx_exit_module+0x24/0xf40 [sfc] __do_sys_delete_module.constprop.0+0x171/0x280 ? exit_to_user_mode_prepare+0x83/0x1d0 do_syscall_64+0x3d/0x80 entry_SYSCALL_64_after_hwframe+0x44/0xae RIP: 0033:0x7f9f9385800b ...trimmed... Signed-off-by: Íñigo Huguet Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- drivers/net/ethernet/sfc/nic.c | 1 + 1 file changed, 1 insertion(+) diff --git a/drivers/net/ethernet/sfc/nic.c b/drivers/net/ethernet/sfc/nic.c index d1e908846f5d..22fbb0ae77fb 100644 --- a/drivers/net/ethernet/sfc/nic.c +++ b/drivers/net/ethernet/sfc/nic.c @@ -90,6 +90,7 @@ int efx_nic_init_interrupt(struct efx_nic *efx) efx->pci_dev->irq); goto fail1; } + efx->irqs_hooked = true; return 0; } -- 2.30.2