Received: by 2002:a05:7412:419a:b0:f3:1519:9f41 with SMTP id i26csp3606767rdh; Mon, 27 Nov 2023 20:43:00 -0800 (PST) X-Google-Smtp-Source: AGHT+IG8bM6luDQ0WXZZVhQeaL3Jfo1Z9tRn7uHQRDWN5dRVEu5DdBTvhT/5kC6Zay1s2v0VmtM+ X-Received: by 2002:a05:6808:3319:b0:3a7:330d:93da with SMTP id ca25-20020a056808331900b003a7330d93damr20786838oib.19.1701146579945; Mon, 27 Nov 2023 20:42:59 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1701146579; cv=none; d=google.com; s=arc-20160816; b=f4gwhj7ASKEkR1UBwkukAGflITF9IVGhHG/xNHDoR9IxlcQL/cO39scNAi6rIu+36L CrRt8jrEXVEX6s2zHmPdwEa94X0zQfdB2z7W6z3+Eq0ek3WnMLGObAK7l50jE4ydnqVp jfaihz03/EcJTFxcJ48/7n3qqaIwkRMw8iq5dZDMSRzHTtlj7ZDoWpWyuO0B/uBFzXgc xw5Ac6/xE5o7rhOdvvoRcaaXJTG3iXyVKmuFuKDtkNDkXH4+gA2e6ocMGVMwGRlLzEDv e2apdiluSIyRf2zCDpsENbzibS0zGxfROg7ZTHRddQ5ZSDtDQ1iWlVrERQEXH6x1Cz2p qFOg== 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:from:references :cc:to:subject:reply-to:dkim-signature; bh=6qv/nhkVe9kw+UVFtxebwNFRGl9GVaetLZvjjatGHLI=; fh=rWaWhQyGhdFXLwXkdK81PgLeR2s160JbANv/YdWQ5pI=; b=f37nyowqwCWyhLCZmR16LcX2Y/pMK3nLHFgUc7N0pF39RjDQaIegqZW05UNkHmcU95 SKMOaR7D3xVYkQUOt4yIfg8bLR8sJbAM+gobI8x/1jx7zwOYbzSvg6GaQRd1PrAvtYq8 MXtZb1pAhUyIpmDRJopH5pUUvYu5TtQFO/R/HV+ANFcW4sbht3IjY0uWzlvW/VzspjMN IAvzbPR1ZgvLdx1Bt9Rn5l5EUbo18tMTp92N7bCd2mw4JyPHOpXSVPsi1Z/jG0aOfhhf Jke1EctVkDrsvtkEHPCfeb5QC4E3yC4Y4cIdJp1iipJieVcYyPoFFnry+MDVZ30rl/W8 zmRg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@denx.de header.s=phobos-20191101 header.b=IhkaUsjq; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:5 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=denx.de Return-Path: Received: from groat.vger.email (groat.vger.email. [2620:137:e000::3:5]) by mx.google.com with ESMTPS id h1-20020a056a00170100b006cd908c0599si3410521pfc.369.2023.11.27.20.42.59 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 27 Nov 2023 20:42:59 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:5 as permitted sender) client-ip=2620:137:e000::3:5; Authentication-Results: mx.google.com; dkim=pass header.i=@denx.de header.s=phobos-20191101 header.b=IhkaUsjq; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:5 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=denx.de Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by groat.vger.email (Postfix) with ESMTP id 1BAFD8060061; Mon, 27 Nov 2023 20:42:57 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at groat.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234562AbjK1El5 (ORCPT + 99 others); Mon, 27 Nov 2023 23:41:57 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35756 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229789AbjK1El4 (ORCPT ); Mon, 27 Nov 2023 23:41:56 -0500 Received: from phobos.denx.de (phobos.denx.de [85.214.62.61]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 736531AA; Mon, 27 Nov 2023 20:42:02 -0800 (PST) Received: from [192.168.1.107] (89-186-112-232.pool.digikabel.hu [89.186.112.232]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: hs@denx.de) by phobos.denx.de (Postfix) with ESMTPSA id 4934B87516; Tue, 28 Nov 2023 05:41:58 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=denx.de; s=phobos-20191101; t=1701146520; bh=6qv/nhkVe9kw+UVFtxebwNFRGl9GVaetLZvjjatGHLI=; h=Reply-To:Subject:To:Cc:References:From:Date:In-Reply-To:From; b=IhkaUsjqWZECkl4fwg0URQWwo1xqctlgqI7ObtVTXqkSfvoA6Reu2gWxTY2dooyTz wy5RnryJcpQLf6bhz9CLSOl2SX5RJ0Fvf1GtRvSoyjmXI6NBIUpqBgqMWWzZDh2lCn wt879N/8YxOrz2q6Rd801QlM+P4GrQlo0FdKSx+rURMcutswDNGkQMwHA+Ea4PVFkj Ho905n56TNcqICxMSt7yv30uegPsr11Fx+NJhhBYxXbUTYuDvTzei0EjfBix1FhjcY WHk+OVF/YNqp7dWeZco2iW8Z8NMWp5c/a2X99WYkFuNDS2YHNOiEC2sCmJYflBWgm8 X9zhq2MRnN+nw== Reply-To: hs@denx.de Subject: Re: [PATCH] net: fec: fix probing of fec1 when fec0 is not probed yet To: Wei Fang , Andrew Lunn , Heiko Schocher Cc: "netdev@vger.kernel.org" , Clark Wang , "David S. Miller" , Eric Dumazet , Jakub Kicinski , dl-linux-imx , Paolo Abeni , Shenwei Wang , "linux-kernel@vger.kernel.org" , Alexander Sverdlin References: <20231123132744.62519-1-hs@denx.de> <132aca53-6570-41a4-b2b2-0907d74f9b31@lunn.ch> <227dc52c-c555-34e4-d534-1a749af15425@denx.de> From: Heiko Schocher Message-ID: Date: Tue, 28 Nov 2023 05:41:43 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.8.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=gbk Content-Language: en-US Content-Transfer-Encoding: 8bit X-Virus-Scanned: clamav-milter 0.103.8 at phobos.denx.de X-Virus-Status: Clean X-Spam-Status: No, score=-2.7 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on groat.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (groat.vger.email [0.0.0.0]); Mon, 27 Nov 2023 20:42:57 -0800 (PST) Hello Wei, On 27.11.23 07:55, Wei Fang wrote: >> -----Original Message----- >> From: Heiko Schocher >> Sent: 2023??11??24?? 13:19 >> To: Wei Fang ; Andrew Lunn ; Heiko >> Schocher >> Cc: netdev@vger.kernel.org; Clark Wang ; David S. >> Miller ; Eric Dumazet ; >> Jakub Kicinski ; dl-linux-imx ; Paolo >> Abeni ; Shenwei Wang ; >> linux-kernel@vger.kernel.org; Alexander Sverdlin >> >> Subject: Re: [PATCH] net: fec: fix probing of fec1 when fec0 is not probed yet >> >> Hello Wei, >> >> On 24.11.23 03:33, Wei Fang wrote: >>>> -----Original Message----- >>>> From: Andrew Lunn >>>> Sent: 2023??11??24?? 4:09 >>>> To: Heiko Schocher >>>> Cc: netdev@vger.kernel.org; Heiko Schocher ; Clark Wang >>>> ; David S. Miller ; Eric >>>> Dumazet ; Jakub Kicinski ; >>>> dl-linux-imx ; Paolo Abeni ; >>>> Shenwei Wang ; Wei Fang >> ; >>>> linux-kernel@vger.kernel.org >>>> Subject: Re: [PATCH] net: fec: fix probing of fec1 when fec0 is not >>>> probed yet >>>> >>>> On Thu, Nov 23, 2023 at 02:27:43PM +0100, Heiko Schocher wrote: >>>>> it is possible that fec1 is probed before fec0. On SoCs with >>>>> FEC_QUIRK_SINGLE_MDIO set (which means fec1 uses mii from fec0) init >>>>> of mii fails for fec1 when fec0 is not yet probed, as fec0 setups >>>>> mii bus. In this case fec_enet_mii_init for fec1 returns with >>>>> -ENODEV, and so fec1 never comes up. >>>>> >>>>> Return here with -EPROBE_DEFER so interface gets later probed again. >>>>> >>>>> Found this on imx8qxp based board, using 2 ethernet interfaces, and >>>>> from time to time, fec1 interface came not up. >>>>> >>>>> Signed-off-by: Heiko Schocher >>>>> --- >>>>> >>>>> drivers/net/ethernet/freescale/fec_main.c | 2 +- >>>>> 1 file changed, 1 insertion(+), 1 deletion(-) >>>>> >>>>> diff --git a/drivers/net/ethernet/freescale/fec_main.c >>>>> b/drivers/net/ethernet/freescale/fec_main.c >>>>> index c3b7694a7485..d956f95e7a65 100644 >>>>> --- a/drivers/net/ethernet/freescale/fec_main.c >>>>> +++ b/drivers/net/ethernet/freescale/fec_main.c >>>>> @@ -2445,7 +2445,7 @@ static int fec_enet_mii_init(struct >>>> platform_device *pdev) >>>>> mii_cnt++; >>>>> return 0; >>>>> } >>>>> - return -ENOENT; >>>>> + return -EPROBE_DEFER; >>>> >>>> I think this has been tried before. >>>> >>> Yes, there was indeed a similar patch [1] before. but this issue seems >>> to only exist in downstream tree, because there is a local patch which is not >> in the upstream. >>> >>> /* board only enable one mii bus in default */ >>> if (!of_get_property(np, "fsl,mii-exclusive", NULL)) >>> fep->quirks |= FEC_QUIRK_SINGLE_MDIO; >> >> Yes, sorry for overseeing this ... but there are SoCs in upstream which set >> FEC_QUIRK_SINGLE_MDIO and so mii bus from for example fec0 is used on >> other fecX devices, correct? >> > Yes, i.MX28 still uses FEC_QUIRK_SINGLE_MDIO flag in the upstream, But the > current patch doesn't seem to completely solve this issue. > > If fec1 is probed before fec0, I think its fep->dev_id should be equal to 0, so it will > not go to the following statement. Indeed... and than fep->dev_id is interchanged too... I wonder why not using: fep->dev_id = of_alias_get_id(np, "ethernet"); in fec_probe function for getting the dev_id. With that no problems with "wrong" dev_id and also my change makes sense... But you are correct, currently patch is useless. > if ((fep->quirks & FEC_QUIRK_SINGLE_MDIO) && fep->dev_id > 0) { > /* fec1 uses fec0 mii_bus */ > if (mii_cnt && fec0_mii_bus) { > fep->mii_bus = fec0_mii_bus; > mii_cnt++; > return 0; > } > return -ENOENT; > } > > I'm considering removing the FEC_QUIRK_SINGLE_MDIO flag from upstream > in the future as it's not necessary. But not now as I am busy with other projects. Hmm.. and what is on platforms which have this usecase? bye, Heiko -- DENX Software Engineering GmbH, Managing Director: Erika Unter HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany Phone: +49-8142-66989-52 Fax: +49-8142-66989-80 Email: hs@denx.de