Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp567566pxb; Thu, 5 Nov 2020 07:24:56 -0800 (PST) X-Google-Smtp-Source: ABdhPJzW4mdIEiOTxI4HZnDomj1WIZhjfr3BH1cedidTWFmcCHqxgj8z9fgk+9KqlY513p2v2JpH X-Received: by 2002:a17:906:5247:: with SMTP id y7mr2712158ejm.503.1604589896021; Thu, 05 Nov 2020 07:24:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604589896; cv=none; d=google.com; s=arc-20160816; b=r3O5ZaxU/cRsokXi3FkKZ5jJeEP14Sx65mD7RpuZwEt7vA6pK+5opN/WxZ3xHlR962 51cAqbYdcMkXnJSJjVBj00zQXca8wTK6yQUYzXDRMIUltcSG2KH8xhknmFhe86gnP2N1 DnlBqOgLPqC5Jj25XA1duE1NJ3aeG0SlYru7nQly3YCxrqpJiJ/KoHuk3gS7oaFFMMQ6 QWhloGvIxLrQfdg5oxO9/Gkk5p+0u1R2mhovk5duYaQZ4vuvfYV+xyMc/R3jGkiuo80a B8RvF0d3QGTDXWp8XZK7M8/uPm+wXapo6fgxiwp3ltjMNi2+VuAdABk/M+w+SO2e2ocB /LpQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:organization :from:references:cc:to:subject:ironport-sdr:dkim-signature; bh=wnaZT5vUd5p3WzPQDcpKmqiMib48YMwDCes5sRR4UHw=; b=GUsi43HnscyCxuuNa++l1WHWW1hH6Xct08hvTGAxvsygCHrmSkCTo5HSWn6J+3gMWC 4v0fgJyJ2Ts/anOfag37xVq396+fp98niSS4GVE7yeXjchwKrfrON5cnrCzw1TEzzvo6 KoyqDJ5l7bhBIVCA1R2H4gOfIFAyCZre2Ys8La0EApO5AhDes3VCmDG+RvzeD6qJMslt wWB1kXYKfvOcAvPn3m85GBpSstvmptSyHfwktpRyobEuvUaLZovg1q9vZEmISal1e9t/ IqGYnoSWfO7IZ31nw8sv2Fte0Kr6ziPHrda7iVqVQv45bGCTgTZVNGDjXba5YRPdzk9B QDJA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@microchip.com header.s=mchp header.b=C1C75RdW; 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=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=microchip.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r6si1371246edi.184.2020.11.05.07.24.33; Thu, 05 Nov 2020 07:24:56 -0800 (PST) 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=fail header.i=@microchip.com header.s=mchp header.b=C1C75RdW; 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=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=microchip.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731232AbgKEPW0 (ORCPT + 99 others); Thu, 5 Nov 2020 10:22:26 -0500 Received: from esa6.microchip.iphmx.com ([216.71.154.253]:8483 "EHLO esa6.microchip.iphmx.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731204AbgKEPW0 (ORCPT ); Thu, 5 Nov 2020 10:22:26 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=microchip.com; i=@microchip.com; q=dns/txt; s=mchp; t=1604589745; x=1636125745; h=subject:to:cc:references:from:message-id:date: mime-version:in-reply-to:content-transfer-encoding; bh=8Nee0VCzpk0Vgp0nXh8FG89MS98QQe0yg6mbF5jma2Q=; b=C1C75RdWAhR01vy01CP5fDyakF2YC/M4Z9El5QXrcwyVnQHWhi+2UzAu /8AjLzxrLVDRZpDW8el1pI1o+UaNugZ9XD+KzVumWP7yCBOjOKzngi0HB 1joQxoDf3zXa7d5X78HIHlOzZ3Pnxg6PDHXA4nTgRn663bGvN/u7vJZZt 2WasOPeGYoRqAJIuGPnQYXmSehTTIOMdSHwUfhMu6eBJcrjdC+X3uBlHX N1aZ53rTxkzD6sdBB6g3kZLvhTgfg5d6TvN0+0JCBZNJYBeYtXHNtHprX vXkJ0t7KZZcZpQucy7t5o8JtnFZ5FiOSvLYFLYv4NDD1hWeFiFARrWTuR A==; IronPort-SDR: YEpKQPsDcnaR5QPmdVQeMheN9WFfnUtorYWNbGEfQOvcKZFyiOWnugCGRND5AuUStOGEKzGAEk fzRFhdf/x7+zS4bDx2HZy5xzG/V/OKXa29ptuQ5lAWaAHTncNQNgIYJiDbIrgqUej0SsVvvDjV pk5ak9f81gQqDqNi8bsngbf74STF0R2ONX0otRj6U5iUHhedMmLYEn0Gw5lib4xOhWU8XldXSQ Pz/IpXLwuSxS7o4COwvnlKXUib7JNDE25UwgBzBgB9Ens4P5CIG8QFcWJ+xtFhoJmVKHt67LYb Lec= X-IronPort-AV: E=Sophos;i="5.77,453,1596524400"; d="scan'208";a="32571915" Received: from smtpout.microchip.com (HELO email.microchip.com) ([198.175.253.82]) by esa6.microchip.iphmx.com with ESMTP/TLS/AES256-SHA256; 05 Nov 2020 08:22:24 -0700 Received: from chn-vm-ex01.mchp-main.com (10.10.85.143) by chn-vm-ex03.mchp-main.com (10.10.85.151) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1979.3; Thu, 5 Nov 2020 08:22:24 -0700 Received: from [10.171.246.99] (10.10.115.15) by chn-vm-ex01.mchp-main.com (10.10.85.143) with Microsoft SMTP Server id 15.1.1979.3 via Frontend Transport; Thu, 5 Nov 2020 08:22:19 -0700 Subject: Re: [PATCH] net: macb: fix NULL dereference due to no pcs_config method To: Parshuram Thombare , , , , CC: , , , , , , References: <1604587039-5646-1-git-send-email-pthombar@cadence.com> From: Nicolas Ferre Organization: microchip Message-ID: <6873cf12-456b-c121-037b-d2c5a6138cb3@microchip.com> Date: Thu, 5 Nov 2020 16:22:18 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: <1604587039-5646-1-git-send-email-pthombar@cadence.com> Content-Type: text/plain; charset="windows-1252"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 05/11/2020 at 15:37, Parshuram Thombare wrote: > This patch fixes NULL pointer dereference due to NULL pcs_config > in pcs_ops. > > Fixes: e4e143e26ce8 ("net: macb: add support for high speed interface") What is this tag? In linux-next? As patch is not yet in Linus' tree, you cannot refer to it like this. > Reported-by: Nicolas Ferre > Link: https://lkml.org/lkml/2020/11/4/482 You might need to change this to a "lore" link: https://lore.kernel.org/netdev/2db854c7-9ffb-328a-f346-f68982723d29@microchip.com/ > Signed-off-by: Parshuram Thombare This fix looks a bit weird to me. What about proposing a patch to Russell like the chunk that you already identified in function phylink_major_config()? > --- > drivers/net/ethernet/cadence/macb_main.c | 17 +++++++++++++++-- > 1 file changed, 15 insertions(+), 2 deletions(-) > > diff --git a/drivers/net/ethernet/cadence/macb_main.c b/drivers/net/ethernet/cadence/macb_main.c > index b7bc160..130a5af 100644 > --- a/drivers/net/ethernet/cadence/macb_main.c > +++ b/drivers/net/ethernet/cadence/macb_main.c > @@ -633,6 +633,15 @@ static void macb_pcs_an_restart(struct phylink_pcs *pcs) > /* Not supported */ > } > > +static int macb_pcs_config(struct phylink_pcs *pcs, > + unsigned int mode, > + phy_interface_t interface, > + const unsigned long *advertising, > + bool permit_pause_to_mac) > +{ > + return 0; > +} Russell, is the requirement for this void function intended? > + > static const struct phylink_pcs_ops macb_phylink_usx_pcs_ops = { > .pcs_get_state = macb_usx_pcs_get_state, > .pcs_config = macb_usx_pcs_config, > @@ -642,6 +651,7 @@ static const struct phylink_pcs_ops macb_phylink_usx_pcs_ops = { > static const struct phylink_pcs_ops macb_phylink_pcs_ops = { > .pcs_get_state = macb_pcs_get_state, > .pcs_an_restart = macb_pcs_an_restart, > + .pcs_config = macb_pcs_config, > }; > > static void macb_mac_config(struct phylink_config *config, unsigned int mode, > @@ -776,10 +786,13 @@ static int macb_mac_prepare(struct phylink_config *config, unsigned int mode, > > if (interface == PHY_INTERFACE_MODE_10GBASER) > bp->phylink_pcs.ops = &macb_phylink_usx_pcs_ops; > - else > + else if (interface == PHY_INTERFACE_MODE_SGMII) > bp->phylink_pcs.ops = &macb_phylink_pcs_ops; Do you confirm that all SGMII type interfaces need phylink_pcs.ops? > + else > + bp->phylink_pcs.ops = NULL; > > - phylink_set_pcs(bp->phylink, &bp->phylink_pcs); > + if (bp->phylink_pcs.ops) > + phylink_set_pcs(bp->phylink, &bp->phylink_pcs); > > return 0; > } Regards, Nicolas -- Nicolas Ferre