Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp7355884yba; Thu, 2 May 2019 08:31:36 -0700 (PDT) X-Google-Smtp-Source: APXvYqw6pKiBY9/FeyoKSm7/+FK3OggcjKhLlSLLlDpHcYzCYqfOk3FKcbH/MbuKcugmoOaKwMaj X-Received: by 2002:a63:6b49:: with SMTP id g70mr4650356pgc.176.1556811096385; Thu, 02 May 2019 08:31:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556811096; cv=none; d=google.com; s=arc-20160816; b=lGppaNadNerZvhwEvkVcH/rGodmztyx885h7WgKjG/LttyWxdQLQ74e24ttKYq7Y2V qHqbQjae4znd9dkMKw9fmwl5S5k53Iij37Pj7YUpaptVyp3xjCuBtJcikcB5Im3t8v7P +ZR+3d1ED0TqeGomhDqq/eJD7/tDwmhOEdcLwyOiy8UzHir534c6ewKt/05JJUeo2Vo1 YuC4KDpKLXFrwTIs7Edq7wDi1JCuR0cV3Qm9BTcW+ITkkAyuyylwhc5a2VV5naU6u2v7 B62lEBsQMpK1RVXTd52i4HMJQwzdenxcMvql4VsL4JikVWttVR4zBapPjlO5MMob0mh2 NYHg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=JA+1bmL8iAWvWzwCVn4ke5aLH3JwKEZEHHpA3UmFk1Q=; b=ge5yu9XAUz6uT/1N7YQmH/DDxxpD9chd0slwCZpIvnro5eKrGKPe1baCkuFXp19loy 855jBH39XjkHr+RG1uDfu1Qz0j0Tx/e6nK3mkJxTHttnBaZQrm3lDn9T5cE3Z/M5F3br gsdnLX1oO2k5fnY4RpJ384XRnS+QMhicq+fNlVAnRfGQZtJJDBnEFaWqqnfII5dfroYX cpRK6IM4tZf+PXyT/lvWhR6DzwqotrMm9HACAEbVx4MDNzCwHMH9QVLv39c2FxqxXkRh 26RLbgYg7AjDlsW2639PM1QRig15FxNEjlqRHsmeOIpusTzjV+DqNg/BGDfIi9rqZP8/ qiHw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="oU/hxVKm"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d16si6481000pgb.97.2019.05.02.08.31.20; Thu, 02 May 2019 08:31:36 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="oU/hxVKm"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727021AbfEBP2l (ORCPT + 99 others); Thu, 2 May 2019 11:28:41 -0400 Received: from mail.kernel.org ([198.145.29.99]:45968 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728263AbfEBP2k (ORCPT ); Thu, 2 May 2019 11:28:40 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 9A18A20449; Thu, 2 May 2019 15:28:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1556810919; bh=IrfZlWArowlj4XAYmIMnowmF9GVSWBoqIzTFQcWYWMc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=oU/hxVKm0mMMvYx4xkhTUhrbaOCk+NZ8yZv63bhcBOKPTlGIcePk9APcUAAd4ML1G 0PeDKehRAv8kUwr+dUkhIKse49oEe4z5JlJphW5ovmmKDqFq3wItxxlfDX1OkJUiT8 33QIfFohww/dJNZWI9dCJg+KCBVXWP7w9kfa7aMY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= , Pavel Machek , Jacek Anaszewski , "Sasha Levin (Microsoft)" Subject: [PATCH 4.19 58/72] leds: trigger: netdev: fix refcnt leak on interface rename Date: Thu, 2 May 2019 17:21:20 +0200 Message-Id: <20190502143337.986275826@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190502143333.437607839@linuxfoundation.org> References: <20190502143333.437607839@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org [ Upstream commit 4cb6560514fa19d556954b88128f3846fee66a03 ] Renaming a netdev-trigger-tracked interface was resulting in an unbalanced dev_hold(). Example: > iw phy phy0 interface add foo type __ap > echo netdev > trigger > echo foo > device_name > ip link set foo name bar > iw dev bar del [ 237.355366] unregister_netdevice: waiting for bar to become free. Usage count = 1 [ 247.435362] unregister_netdevice: waiting for bar to become free. Usage count = 1 [ 257.545366] unregister_netdevice: waiting for bar to become free. Usage count = 1 Above problem was caused by trigger checking a dev->name which obviously changes after renaming an interface. It meant missing all further events including the NETDEV_UNREGISTER which is required for calling dev_put(). This change fixes that by: 1) Comparing device struct *address* for notification-filtering purposes 2) Dropping unneeded NETDEV_CHANGENAME code (no behavior change) Fixes: 06f502f57d0d ("leds: trigger: Introduce a NETDEV trigger") Signed-off-by: Rafał Miłecki Acked-by: Pavel Machek Signed-off-by: Jacek Anaszewski Signed-off-by: Sasha Levin (Microsoft) --- drivers/leds/trigger/ledtrig-netdev.c | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) diff --git a/drivers/leds/trigger/ledtrig-netdev.c b/drivers/leds/trigger/ledtrig-netdev.c index 3dd3ed46d473..167a94c02d05 100644 --- a/drivers/leds/trigger/ledtrig-netdev.c +++ b/drivers/leds/trigger/ledtrig-netdev.c @@ -301,11 +301,11 @@ static int netdev_trig_notify(struct notifier_block *nb, container_of(nb, struct led_netdev_data, notifier); if (evt != NETDEV_UP && evt != NETDEV_DOWN && evt != NETDEV_CHANGE - && evt != NETDEV_REGISTER && evt != NETDEV_UNREGISTER - && evt != NETDEV_CHANGENAME) + && evt != NETDEV_REGISTER && evt != NETDEV_UNREGISTER) return NOTIFY_DONE; - if (strcmp(dev->name, trigger_data->device_name)) + if (!(dev == trigger_data->net_dev || + (evt == NETDEV_REGISTER && !strcmp(dev->name, trigger_data->device_name)))) return NOTIFY_DONE; cancel_delayed_work_sync(&trigger_data->work); @@ -320,12 +320,9 @@ static int netdev_trig_notify(struct notifier_block *nb, dev_hold(dev); trigger_data->net_dev = dev; break; - case NETDEV_CHANGENAME: case NETDEV_UNREGISTER: - if (trigger_data->net_dev) { - dev_put(trigger_data->net_dev); - trigger_data->net_dev = NULL; - } + dev_put(trigger_data->net_dev); + trigger_data->net_dev = NULL; break; case NETDEV_UP: case NETDEV_CHANGE: -- 2.19.1