Received: by 2002:a05:7412:6592:b0:d7:7d3a:4fe2 with SMTP id m18csp2476589rdg; Mon, 14 Aug 2023 04:02:34 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHVh+429wOc/U/Ap7Q9weyAxDNE4v+UQ0r0aJu/NRzHQb/oykmgTBuz9mM84yI7mdzzaVMx X-Received: by 2002:a17:90a:db55:b0:268:36a2:bd0 with SMTP id u21-20020a17090adb5500b0026836a20bd0mr6112327pjx.8.1692010954267; Mon, 14 Aug 2023 04:02:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1692010954; cv=none; d=google.com; s=arc-20160816; b=nGsSitCXYNWMM2h9FSlL4gS7r9C7YwedfiEzdiNCrHmK6j+EId8tXdlmwEqDOpicin 4KJqsDqLcAYk1AcBdR4NMprSYnVlG69fDtm9PJpEgfBote7a54l489ila6Eq4BO1b8qM 4hiLj8z3S58UZ40KA8ebyrLggtcXkBfHIS7czpzYZBS8d6GRoX/Ufka6ubwEyHHQEeqh 60FoN9CP1qZ20d5BVgy9gzmmbLPbN+Jv63ebXzlCYPMa7UQvH7GfzxQPIzcVX2BZwN8q 1auK7yjrt282l3GnUDcyNUsHk8DauqHsJtZptAUB1p+tvYwb4F/YULbT+lQNZoTj6m08 WZrA== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=x9GIkI+02jFm9GaovqHGnU7H+AqY3jsX4KEby4kRqP0=; fh=5VnmXmoZBR4+6qVIfQDiLcsiW+SDqIu0KJ6MYk3TKH8=; b=z8+wh4V/lI2I5FF6xTPavaIVPv8lprY046T6gr1xg0KruBdrtNQ8K8PedXTI5D4gFw 3TXYWRiAVWQ8C5zVf+yQcKJpSlJo643IMFWzKkeC8IwsKptDhYsybZ+mFZP4ZxiZYl9v Cs92IPIstMxwFC2toPIk/iFcvEfFcI+9/5AxaaIxz6QTXEt/ULZRK7RgAFSGDOPkRMxq 166aJcfjsgNcQ7uIBB7PR7qpeLSmr+l8XgB/hU1zZ/Aqlar5naOrCAph06jKiY/a6XXn buxnSJqum+Cs4M5qvWekOD8VU1CHofbmesu9GBs7ZwRrAKx3l8RoR26U1gQbugR7RZ/j n83A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bgdev-pl.20221208.gappssmtp.com header.s=20221208 header.b=uitaqFVv; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id z20-20020a17090ad79400b0026824d6cb0fsi4893781pju.164.2023.08.14.04.02.20; Mon, 14 Aug 2023 04:02:34 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@bgdev-pl.20221208.gappssmtp.com header.s=20221208 header.b=uitaqFVv; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234725AbjHNJhC (ORCPT + 99 others); Mon, 14 Aug 2023 05:37:02 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58038 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234699AbjHNJgq (ORCPT ); Mon, 14 Aug 2023 05:36:46 -0400 Received: from mail-wm1-x333.google.com (mail-wm1-x333.google.com [IPv6:2a00:1450:4864:20::333]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7E0E2E73 for ; Mon, 14 Aug 2023 02:36:29 -0700 (PDT) Received: by mail-wm1-x333.google.com with SMTP id 5b1f17b1804b1-3fe2048c910so37656665e9.1 for ; Mon, 14 Aug 2023 02:36:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bgdev-pl.20221208.gappssmtp.com; s=20221208; t=1692005788; x=1692610588; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=x9GIkI+02jFm9GaovqHGnU7H+AqY3jsX4KEby4kRqP0=; b=uitaqFVvR6wG+2WZxZnkMJsbIyf80+jIPR57rXBxpxxKezVlMzJKTeUBYqcHrfaKlO hrp7aqI4YGAn8CplW3KnRMOYvF/HPhiP+ar40CrfhJrKkBOjD5jjozVwn5GvtfmZmra8 +jsuiDnH//FbniWJ0t5T8gOYrPGZC4L43txWOhyP6azrObVGJ7n2KsXvfZqGY46CPBjk 9ODpZZejIlfw9nq6gj1CG1oHAWUtAcj6hTOaZrZgvCVmdwiB0H70LwcApl+a1DHwGXmY GB7hp0lceP+YVqEbga7HVcupnwQjyha4U0713nOcu2uf7hPGZKH1lT5Dll/XwMtfa2AW e+9w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1692005788; x=1692610588; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=x9GIkI+02jFm9GaovqHGnU7H+AqY3jsX4KEby4kRqP0=; b=isPFth6x4mbjCK/YNinKaptx0XJu+Db41qmauxE2rxjG1Lln6khfXskDwpYBxw8fzw 9pBSkUJVMokgAIKK5jwTX8UZuWyMCiwLcAjtDqTurvOlII9Q/Ti11cr5vsshnTlb/JsA gkFnpZh97qhTKtI552UckbV80kHrdVmHHSOdM+UUZ6PYSayqhAct0NwJV60VErT4o6vC 6Xobi6T9TI+N+3iSB6JGIPrj5AzEd7E9MHYLrHcORiZ30Yk32pj2ghfnQIic+nkomv1s nzspttHvEy1lunVC8anRiRSVr+pqHNkj8/P9Wjedd/IKlzSHHPea0DrukxGESiK6KsDk qpgQ== X-Gm-Message-State: AOJu0YygtAIFaT7HNSieMVJlQGMXl0rAGKnVbmcBuew2Vuyr0lg31UQc SQv2RuDy/6I88h1iO1E0INiv7Q== X-Received: by 2002:adf:ff92:0:b0:317:ed01:dc48 with SMTP id j18-20020adfff92000000b00317ed01dc48mr6349175wrr.9.1692005788084; Mon, 14 Aug 2023 02:36:28 -0700 (PDT) Received: from brgl-uxlite.home ([2a01:cb1d:334:ac00:d0cb:d23e:f2fb:62b4]) by smtp.gmail.com with ESMTPSA id d17-20020adfe851000000b003197839d68asm2422140wrn.97.2023.08.14.02.36.27 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 14 Aug 2023 02:36:27 -0700 (PDT) From: Bartosz Golaszewski To: Thomas Gleixner , Marc Zyngier Cc: linux-kernel@vger.kernel.org, Bartosz Golaszewski Subject: [PATCH 2/2] genirq: proc: fix a procfs entry leak Date: Mon, 14 Aug 2023 11:36:21 +0200 Message-Id: <20230814093621.23209-3-brgl@bgdev.pl> X-Mailer: git-send-email 2.39.2 In-Reply-To: <20230814093621.23209-1-brgl@bgdev.pl> References: <20230814093621.23209-1-brgl@bgdev.pl> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,RCVD_IN_DNSWL_BLOCKED,SPF_HELO_NONE,SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Bartosz Golaszewski When removing the proc entry for a desc that still has active users, we will leak the irqaction entries. Let's remove them in unregister_irq_proc(). Signed-off-by: Bartosz Golaszewski --- kernel/irq/proc.c | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/kernel/irq/proc.c b/kernel/irq/proc.c index 83ed403991c6..b284604a091a 100644 --- a/kernel/irq/proc.c +++ b/kernel/irq/proc.c @@ -390,6 +390,15 @@ void register_irq_proc(unsigned int irq, struct irq_desc *desc) mutex_unlock(®ister_lock); } +static void unregister_action_proc(struct irqaction *action) +{ + if (!action) + return; + + unregister_action_proc(action->secondary); + unregister_handler_proc(action); +} + void unregister_irq_proc(unsigned int irq, struct irq_desc *desc) { char name [MAX_NAMELEN]; @@ -408,6 +417,12 @@ void unregister_irq_proc(unsigned int irq, struct irq_desc *desc) #endif remove_proc_entry("spurious", desc->dir); + /* + * If at this point, this irq desc is still requested, we need to + * remove the proc handler entries or we'll leak them. + */ + unregister_action_proc(desc->action); + sprintf(name, "%u", irq); remove_proc_entry(name, root_irq_dir); } -- 2.39.2