Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1297933imu; Wed, 16 Jan 2019 16:40:16 -0800 (PST) X-Google-Smtp-Source: ALg8bN7gBk8kAEKKQYEEKlyhvQTBhlmYyYjfctrrHNEMC+DYq3f6UpQ/+4rUkyLMuHE9uK5Xm8ai X-Received: by 2002:a62:7f93:: with SMTP id a141mr12764738pfd.96.1547685616386; Wed, 16 Jan 2019 16:40:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1547685616; cv=none; d=google.com; s=arc-20160816; b=TjbSwhsFA3zKBgmEEizCiXeYD4LfWxavbA4XGa6H6rgMfd3+g8Ukq/BoIU0l8M537m 37R2veS/Rss1c2hB5lYjPzCtsjEizMGW3butNeH1AJXfCYXvTDeK3F66qN282dD/EZG9 t/omMFG41mD8q5gYqc5U64oXTtHjYZqIOyLa5GTF75M90Yv7OG3rkIoPWdFS/Ju076RS zOKCWatA8WCktMEZTrsoC7N6aa7Ea3n0s3gpQe7b5Ru1W8zoAln4yiJ9wcd2SyiUjXSL OwqTlYKEaidGD/WDoBluEK+0JCBmc+9RylfKkn8jhQIPYCzsLJYIZsJbnI3/fHuMHcjT 1YMA== 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 :content-language:in-reply-to:mime-version:date:message-id:from :references:cc:to:subject; bh=t9snzn5ddM0Rq+waX3TAuURzKDOALVvdLscA9dTBdPs=; b=Cc/vV/S7GF4e4xmdZrOXc/YshT2Se6cJtFrRsr6y7lSxD7WSVSFSspmEyAiqEzhlrx l23YEl7Bc42i7zC7CchOzS/gMThx0rahIEMtRB3/xO2s3Nsv/O1YDauK2DbEl0RN3GIW 2HSfZkk2KIgFOBQcrkiYr6fwJcX2o/fx0C8K0Pfdb38EpQraHKUQf6xTsh2EguF6nVrZ KLj5aO8M4uLvUEFZeKzLC80hdFhXux9728T/zRulMvjASORmHJnOQMQPM4Be0LDNmnPc CuhtwYyuomDVw9ipCqZ9w7e1vc0519fQW0EDbfzKeM8bVxsgjeW8M+V+xQelu9Dhh0Ms yjHQ== ARC-Authentication-Results: i=1; mx.google.com; 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 v21si7270978plo.417.2019.01.16.16.40.01; Wed, 16 Jan 2019 16:40:16 -0800 (PST) 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; 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 S1731148AbfAPVmJ (ORCPT + 99 others); Wed, 16 Jan 2019 16:42:09 -0500 Received: from mx2.mailbox.org ([80.241.60.215]:61610 "EHLO mx2.mailbox.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729361AbfAPVmJ (ORCPT ); Wed, 16 Jan 2019 16:42:09 -0500 Received: from smtp1.mailbox.org (smtp1.mailbox.org [IPv6:2001:67c:2050:105:465:1:1:0]) (using TLSv1.2 with cipher ECDHE-RSA-CHACHA20-POLY1305 (256/256 bits)) (No client certificate requested) by mx2.mailbox.org (Postfix) with ESMTPS id 4E5AEA1152; Wed, 16 Jan 2019 22:42:06 +0100 (CET) X-Virus-Scanned: amavisd-new at heinlein-support.de Received: from smtp1.mailbox.org ([80.241.60.240]) by spamfilter02.heinlein-hosting.de (spamfilter02.heinlein-hosting.de [80.241.56.116]) (amavisd-new, port 10030) with ESMTP id kV-ni1ASqHSL; Wed, 16 Jan 2019 22:42:05 +0100 (CET) Subject: Re: [PATCH 1/3] net: dsa: lantiq_gswip: fix use-after-free on failed probe To: Johan Hovold Cc: Andrew Lunn , Vivien Didelot , Florian Fainelli , "David S. Miller" , netdev@vger.kernel.org, linux-kernel@vger.kernel.org, stable References: <20190116102335.30433-1-johan@kernel.org> <20190116102335.30433-2-johan@kernel.org> From: Hauke Mehrtens Message-ID: Date: Wed, 16 Jan 2019 22:42:04 +0100 MIME-Version: 1.0 In-Reply-To: <20190116102335.30433-2-johan@kernel.org> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 1/16/19 11:23 AM, Johan Hovold wrote: > Make sure to disable and deregister the switch on late probe errors to > avoid use-after-free when the device-resource-managed switch is freed. > > Fixes: 14fceff4771e ("net: dsa: Add Lantiq / Intel DSA driver for vrx200") > Cc: stable # 4.20 > Cc: Hauke Mehrtens > Signed-off-by: Johan Hovold Acked-by: Hauke Mehrtens > --- > drivers/net/dsa/lantiq_gswip.c | 5 ++++- > 1 file changed, 4 insertions(+), 1 deletion(-) > > diff --git a/drivers/net/dsa/lantiq_gswip.c b/drivers/net/dsa/lantiq_gswip.c > index 693a67f45bef..b06c41c98de9 100644 > --- a/drivers/net/dsa/lantiq_gswip.c > +++ b/drivers/net/dsa/lantiq_gswip.c > @@ -1099,7 +1099,7 @@ static int gswip_probe(struct platform_device *pdev) > dev_err(dev, "wrong CPU port defined, HW only supports port: %i", > priv->hw_info->cpu_port); > err = -EINVAL; > - goto mdio_bus; > + goto disable_switch; > } > > platform_set_drvdata(pdev, priv); > @@ -1109,6 +1109,9 @@ static int gswip_probe(struct platform_device *pdev) > (version & GSWIP_VERSION_MOD_MASK) >> GSWIP_VERSION_MOD_SHIFT); > return 0; > > +disable_switch: > + gswip_mdio_mask(priv, GSWIP_MDIO_GLOB_ENABLE, 0, GSWIP_MDIO_GLOB); > + dsa_unregister_switch(priv->ds); > mdio_bus: > if (mdio_np) > mdiobus_unregister(priv->ds->slave_mii_bus); >