Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1298232imu; Wed, 16 Jan 2019 16:40:40 -0800 (PST) X-Google-Smtp-Source: ALg8bN4NR4IOXTbI5zh9vPhFINL1rbd0NOUs5jgKONOqu1lQOngAkuMby94hMkFgeMzIBvtAhWfJ X-Received: by 2002:a17:902:8541:: with SMTP id d1mr12875910plo.205.1547685640446; Wed, 16 Jan 2019 16:40:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1547685640; cv=none; d=google.com; s=arc-20160816; b=KUg9pxV3THj10CU2Qo0iL9QYs1u51xm0PeLNTxGn6MtBX9P86HWFVmWDAIWTdHi5Ic YiV7H37t+zXh/Mle/jBk9+ujRjLuTw7w4lN4urkyS8LRuYFM1b5vFytGXYQBUbawu2wh EF4ZJzLjjNV21GeRclrSvtBUpBrpbOMGJjUKGlr9wTmxIvKSGdKkPMzYVrAPsCZosqP+ Ka+5YAh2XaCERSxPiul2nWI3XlnQs8Jyj4GnzySlgVj11/3M4GjIfAwZeaRhHQCDXDUk 5BErYpSwDVkXCpow9oh7yOp1yhcbC3xGuK/wzjwOwGVLFt+dHPzN6fafMImTYGmr3F7l /2+Q== 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=HguRVbxNw4OvoyLEb0G/45vcWS1lI2N0rKUxrsuoUQU=; b=cBg63OkmrsD1+QgD4HHr76cMoHPbqbWByAnmeVLXZ0EjIZ8p4JRMoapjJ7PNEv9aDV GwcC0Zb3v1zA5c738cXhyKX1+vF6VWe3jEAmzvk+GqkHalNvcsHcPAX4spQn/+PPX2YI +KRbi7VefdjEhwddz8ElNVCqIBn0ABoZmoIeq7bq5eDFrMcZ75Ak0FZnIL16fs8aCPtp mpCUqm9z0LN72+c7p32Nwej66sYzrk3e1rgeGP0errRwOelxNFjLukCR0g9NJ5vK9pM3 3UJHxNndp06O5wqNzd6ACJOytJX6K1TmBDdJ+dd1GUXmB1rcdVjWidNE9OxKSxYxKXdu iFMg== 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 c10si8064881pla.173.2019.01.16.16.40.22; Wed, 16 Jan 2019 16:40:40 -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 S1731092AbfAPVoE (ORCPT + 99 others); Wed, 16 Jan 2019 16:44:04 -0500 Received: from mx2.mailbox.org ([80.241.60.215]:64320 "EHLO mx2.mailbox.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730413AbfAPVoE (ORCPT ); Wed, 16 Jan 2019 16:44:04 -0500 Received: from smtp1.mailbox.org (smtp1.mailbox.org [80.241.60.240]) (using TLSv1.2 with cipher ECDHE-RSA-CHACHA20-POLY1305 (256/256 bits)) (No client certificate requested) by mx2.mailbox.org (Postfix) with ESMTPS id 544BFA1197; Wed, 16 Jan 2019 22:44:01 +0100 (CET) X-Virus-Scanned: amavisd-new at heinlein-support.de Received: from smtp1.mailbox.org ([80.241.60.240]) by hefe.heinlein-support.de (hefe.heinlein-support.de [91.198.250.172]) (amavisd-new, port 10030) with ESMTP id b6WWOh3NJk6u; Wed, 16 Jan 2019 22:44:00 +0100 (CET) Subject: Re: [PATCH 1/3] net: dsa: lantiq_gswip: fix use-after-free on failed probe To: Andrew Lunn , Johan Hovold Cc: 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> <20190116150009.GE25731@lunn.ch> From: Hauke Mehrtens Message-ID: <1e158c63-c578-1eb3-916e-d6d5a477270e@hauke-m.de> Date: Wed, 16 Jan 2019 22:43:58 +0100 MIME-Version: 1.0 In-Reply-To: <20190116150009.GE25731@lunn.ch> 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 4:00 PM, Andrew Lunn wrote: > On Wed, Jan 16, 2019 at 11:23:33AM +0100, 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 >> --- >> 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); > > This is correct. But it would be nice if somebody in the future could > move the disabling of the switch to the inverse of the gswip_setup() > function to make the code symmetrical. Should we add an uninit callback? Hauke