Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp714991rwb; Tue, 29 Nov 2022 04:34:31 -0800 (PST) X-Google-Smtp-Source: AA0mqf4kOkYDF9PRRoGM9VaOAdDF+Ehlk2gcvRGvxXgFqQkcEZVqolJ6na3jnQxkSw7NmN9K9Lhx X-Received: by 2002:aa7:8d5a:0:b0:560:eec2:d0ab with SMTP id s26-20020aa78d5a000000b00560eec2d0abmr58182719pfe.43.1669725271545; Tue, 29 Nov 2022 04:34:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1669725271; cv=none; d=google.com; s=arc-20160816; b=z6qQDydGqRm40olQ8YFO7FsrD3As+7qaiyPpMnwOuLAFPEvtmSx+/Mi52Y9rnJNUPz 8qKXjR1PyxlqACF0Tk6SB+t8mFHKRhHYkmIUp5Ftd/L/oqbf7vLG/Bxdp60TTl6Jg0qG 15IICEIJbLkQNOe79i4PwYEdlMsYea30wsrS23Dp5p2giWdr7Xkf5GQ95FGux+/FrIuv xNRGJnEGljNkX8H/wxpJi31SEXYuvchlMvF+ToBiWDd3W9Q0NMwiIA16dicoUTc3S2Sb HxSA+xnHf83qCgpEN5zoAbbZ5So92jfDTGYE8vvBLsShKQFyiXLZ4CMkuiHSIzKgqMEU kNiw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:date:cc:to:from:subject :message-id:dkim-signature; bh=9CBLyH0RXTvLwjlM6E/Boj09BZZIY990XDzCnn9wbPw=; b=0em7Ycm/57LlD+d0Fg/+YNPSETASfme21RyU6M9IUK1wFOrEP7/QULRJmeQkl1wDgq tzY/nXe2Uic5Un5xkgC/XuVMQyY54btRSoE7JODYCGN5Lt2qmJWUIgvQsdIFzunJTXSE 2S7pTDDDNPEEgGzACijZCkWloLkFShFc/Fi2G03smlAs+F688yYMCkd3DAImb/hBa+GY FbXAsqxjXC2PgWEVKioYNrVgRuhLx+9YhbIvuGoIcIELRHLo6RVON6UevukbGYp+fMDT lJ/98Q2reQ6E4VUEPZ6L7Fl2sR2gV7wZxYOoeQHhNn7zKwXkSjXsEovC7QG4eQlAWGMs eSdA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=e8BVelmn; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id lw14-20020a17090b180e00b00213193e7047si1691601pjb.185.2022.11.29.04.34.18; Tue, 29 Nov 2022 04:34:31 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=e8BVelmn; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232523AbiK2Lv7 (ORCPT + 83 others); Tue, 29 Nov 2022 06:51:59 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52000 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229923AbiK2Lvy (ORCPT ); Tue, 29 Nov 2022 06:51:54 -0500 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 49FF45ADFB for ; Tue, 29 Nov 2022 03:50:53 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1669722652; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=9CBLyH0RXTvLwjlM6E/Boj09BZZIY990XDzCnn9wbPw=; b=e8BVelmnLEGQ0haPfpSlPio1EF+KPaHoLzzT37CdUGNY3bCNICSxJFMGCGqnXHEA7Qa8bs Oo+UyaCdO0o3CYXPEC7V5NJMdHhn0zYB6/bdcrabtTxJYEuSnmLXYnpuCGCmF0lGMurmaT nshhMBCsBBSghCC/y+95GaW6iRLCKJQ= Received: from mail-qv1-f71.google.com (mail-qv1-f71.google.com [209.85.219.71]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_128_GCM_SHA256) id us-mta-372-bPvQrx-TOc-eDOMaL38UoA-1; Tue, 29 Nov 2022 06:50:51 -0500 X-MC-Unique: bPvQrx-TOc-eDOMaL38UoA-1 Received: by mail-qv1-f71.google.com with SMTP id nn2-20020a056214358200b004bb7bc3dfdcso19396666qvb.23 for ; Tue, 29 Nov 2022 03:50:50 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:mime-version:user-agent:references :in-reply-to:date:cc:to:from:subject:message-id:x-gm-message-state :from:to:cc:subject:date:message-id:reply-to; bh=9CBLyH0RXTvLwjlM6E/Boj09BZZIY990XDzCnn9wbPw=; b=nLQMk1z9J6pAT/bEmTnpa/G3sQpPVOlDRNB5u7y1rbPGZ1TUsUMhCE4iqWct5DYtxS lcOEK75OCpM2pmy7ajeZ/sSfH7A2UwcgONwAKfbUuPb7kY0NOuckvWyEWMGLZkUmwzGR U72Z8AXgT3TDr4P5S97DznNEMMuMU6Bb+hUCG5eUO+OFQMMl5LwQFUMxlJVViTYW/bbO RW4P+FUkSj53SxUUv5zXhWpfIdBXrDvkzTKpCq0l76CQieUuo37ozDLhLFSiXGAXu2j8 4Wfb33giyI/F/IdIeLRgNSBWQRdqtY55s+22OJ3DrtQFvHnXVHzExwDxUgM/vZEpqYte oZBA== X-Gm-Message-State: ANoB5pnJD8dqa3k2P4ecDSZo4+o3HX0YZoMUSJ3Oo+IP7LQip1EQCi+s 2e6sW24Bsi6LNPVnGxs+0Tx9doB0W1Peh3yjcdenWZ6vqB8IpvpzPc7UVPWxy8iJ9sOgsHW4xqR taeDYDItMV7kA/8m1YeIU8Rb5 X-Received: by 2002:ac8:4788:0:b0:3a5:9191:da4c with SMTP id k8-20020ac84788000000b003a59191da4cmr33745041qtq.540.1669722650526; Tue, 29 Nov 2022 03:50:50 -0800 (PST) X-Received: by 2002:ac8:4788:0:b0:3a5:9191:da4c with SMTP id k8-20020ac84788000000b003a59191da4cmr33745022qtq.540.1669722650264; Tue, 29 Nov 2022 03:50:50 -0800 (PST) Received: from gerbillo.redhat.com (146-241-120-203.dyn.eolo.it. [146.241.120.203]) by smtp.gmail.com with ESMTPSA id v68-20020a372f47000000b006fa84082b6dsm10183195qkh.128.2022.11.29.03.50.48 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 29 Nov 2022 03:50:49 -0800 (PST) Message-ID: Subject: Re: [v2][PATCH 1/1] net: phy: Add link between phy dev and mac dev From: Paolo Abeni To: Xiaolei Wang , andrew@lunn.ch, hkallweit1@gmail.com, linux@armlinux.org.uk, davem@davemloft.net, edumazet@google.com, kuba@kernel.org Cc: netdev@vger.kernel.org, linux-kernel@vger.kernel.org Date: Tue, 29 Nov 2022 12:50:46 +0100 In-Reply-To: <20221125041206.1883833-2-xiaolei.wang@windriver.com> References: <20221125041206.1883833-1-xiaolei.wang@windriver.com> <20221125041206.1883833-2-xiaolei.wang@windriver.com> Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.42.4 (3.42.4-2.fc35) MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 2022-11-25 at 12:12 +0800, Xiaolei Wang wrote: > If the external phy used by current mac interface is > managed by another mac interface, it means that this > network port cannot work independently, especially > when the system suspend and resume, the following > trace may appear, so we should create a device link > between phy dev and mac dev. > > WARNING: CPU: 0 PID: 24 at drivers/net/phy/phy.c:983 phy_error+0x20/0x68 > Modules linked in: > CPU: 0 PID: 24 Comm: kworker/0:2 Not tainted 6.1.0-rc3-00011-g5aaef24b5c6d-dirty #34 > Hardware name: Freescale i.MX6 SoloX (Device Tree) > Workqueue: events_power_efficient phy_state_machine > unwind_backtrace from show_stack+0x10/0x14 > show_stack from dump_stack_lvl+0x68/0x90 > dump_stack_lvl from __warn+0xb4/0x24c > __warn from warn_slowpath_fmt+0x5c/0xd8 > warn_slowpath_fmt from phy_error+0x20/0x68 > phy_error from phy_state_machine+0x22c/0x23c > phy_state_machine from process_one_work+0x288/0x744 > process_one_work from worker_thread+0x3c/0x500 > worker_thread from kthread+0xf0/0x114 > kthread from ret_from_fork+0x14/0x28 > Exception stack(0xf0951fb0 to 0xf0951ff8) > > Signed-off-by: Xiaolei Wang > --- > drivers/net/phy/phy_device.c | 12 ++++++++++++ > include/linux/phy.h | 2 ++ > 2 files changed, 14 insertions(+) > > diff --git a/drivers/net/phy/phy_device.c b/drivers/net/phy/phy_device.c > index 57849ac0384e..ca6d12f37066 100644 > --- a/drivers/net/phy/phy_device.c > +++ b/drivers/net/phy/phy_device.c > @@ -1511,6 +1511,15 @@ int phy_attach_direct(struct net_device *dev, struct phy_device *phydev, > phy_resume(phydev); > phy_led_triggers_register(phydev); > > + /** > + * If the external phy used by current mac interface is managed by > + * another mac interface, so we should create a device link between > + * phy dev and mac dev. > + */ > + if (phydev->mdio.bus->parent && dev->dev.parent != phydev->mdio.bus->parent) > + phydev->devlink = device_link_add(dev->dev.parent, &phydev->mdio.dev, > + DL_FLAG_PM_RUNTIME | DL_FLAG_STATELESS); > + > return err; > > error: > @@ -1748,6 +1757,9 @@ void phy_detach(struct phy_device *phydev) > struct module *ndev_owner = NULL; > struct mii_bus *bus; > > + if (phydev->devlink) > + device_link_del(phydev->devlink); > + > if (phydev->sysfs_links) { > if (dev) > sysfs_remove_link(&dev->dev.kobj, "phydev"); > diff --git a/include/linux/phy.h b/include/linux/phy.h > index ddf66198f751..f7f8b909fed0 100644 > --- a/include/linux/phy.h > +++ b/include/linux/phy.h > @@ -617,6 +617,8 @@ struct phy_device { > /* And management functions */ > struct phy_driver *drv; > > + struct device_link *devlink; Sorry for the late nit picking, but could you please add the kdoc documentation for this new field? Also, please specify explicitly the net-next target tree on repost, as per Florian's request. Thanks, Paolo