Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp389609ybt; Mon, 6 Jul 2020 11:48:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyFm1I8W7eaHiLPaP5Mf52GFZDXYT3IKvXKPicgxpdG2fvqjSUfvx2OxV4nFTVTUqhCKqD1 X-Received: by 2002:a50:e801:: with SMTP id e1mr56125303edn.251.1594061333541; Mon, 06 Jul 2020 11:48:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594061333; cv=none; d=google.com; s=arc-20160816; b=1GIqZVIt+IlgHVW90JP7oCZGdjBaRSpUIy8fbBRHRjRx7dA0fv9ZirxMhruhBEHQai DOYoAUVhEGag2H7E9rC3rAsre+S+O12gblY46b+gPuqfxfC8ABrn7wPgttZ7yH/l8j3K C0RBXT5/Ekr7+CK/OV9RpIz/HkMsJts7PCT36DbqanfaBI+vCMCgtQXjbLWAzSdZpNyJ qEpQ0pEPOO5hhDcxa3enYUWRGttrPHtvjR8OY9tLwfKEw5bFEOUloJr8dMYf0yWxuvQO naO2x1RvLRIDH7T91fpyxzGuR+xEX+CBfbu1kG9DgpjyKldH96qaM4YN6UAHDNmQiLzQ KO7Q== 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:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=sB+M5xN2q4aSHO4ImD3f9WDwtbdfsUY52yLNYBoRoMk=; b=J6xQ1vJwf2cExjxZA4WiLVJCPdfT6sq7P387E7lYYhx9SoRbsFXe+EjYWvIbQjKfNJ Ec/wyYW+zoUc1jmfJlN0NJDAH+0Ko6EzFg7HdJ6l+w2wfDsCcF1fMVVQtklr3prXXVso HCC7wKbvDfYYS2Bec43ALpRxNO5qKaMIK6AGQUEqlXcedmXBuzCMhPodZ52ojvD8qOwd SD5VJsbZ23fESHtkIpQDjKdeS6lgk+W1fDtP8DofqarvR+82IZIzsQCF1tj6nZkYai4T rmfjXoZhk8Ul65BlkvquJrN3nqPy8JBmOtimlieBrKHAYsmsX6Go96QW7/1ZRAn4LDTT E51g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=sOw+T1jX; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f13si14459699edy.576.2020.07.06.11.48.30; Mon, 06 Jul 2020 11:48:53 -0700 (PDT) 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=pass header.i=@gmail.com header.s=20161025 header.b=sOw+T1jX; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729796AbgGFSpo (ORCPT + 99 others); Mon, 6 Jul 2020 14:45:44 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39230 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729738AbgGFSpn (ORCPT ); Mon, 6 Jul 2020 14:45:43 -0400 Received: from mail-wm1-x343.google.com (mail-wm1-x343.google.com [IPv6:2a00:1450:4864:20::343]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 99941C061755; Mon, 6 Jul 2020 11:45:43 -0700 (PDT) Received: by mail-wm1-x343.google.com with SMTP id j18so40361364wmi.3; Mon, 06 Jul 2020 11:45:43 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=sB+M5xN2q4aSHO4ImD3f9WDwtbdfsUY52yLNYBoRoMk=; b=sOw+T1jXnmcOBApPeHZG3ZXckOn+qWGRfSFB/+A6Ssg5pNiiuu/Uy5xZJNt0DeRQei KLFmMx8fKdNYYcreXPfjn8d/XX+ndO4PsoaYYr3ziKynahHxS0gc8cO7IAKvXPMAzcZc j8kgKHF72bXfaw37A50fR5BZ7HovOHpDtVAsNGpQ+6Gu5klU1FbFnVhrQzXu7oM7zZVX q2fv/u/jO/U0JU1Ja+AA/Zc8grG1mozSe/RTqa6tijd5zgO+Vw2LjiIPUTPnMq5Wyw7w uf7ZVwamP+cD0ragN3/2JUI8b+gDDoMwNKrmPkyfUcFuz+tZd9zdUohX/RXov1gmPtxh NQaQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=sB+M5xN2q4aSHO4ImD3f9WDwtbdfsUY52yLNYBoRoMk=; b=Qm0rb2sixucqhxCkkD3WQaMSz7m0o7KBAbsZeCIgJ1Tknef8hjn7GN2J7PFRWaXqtU MRtXdb2akauQ3Rz+Gc6ATmjvxZloOetH0UkCaBwnfBfFZ2K5w91ptp6/MSK7gx4ILV1Z 2XC2D2Vw4VfHJgm9dG9ck85LtPj5U2ntRs3jv9S9GWbm+gFnN/f4TCfKFbHT/i8ML54W 0G+Ut6mbtPZhJxI7Gsr4+hLryfBuqpYTl96HTbEu4+tfKop1SttvviDojGdWI0/UG8lH TRFU8Nu5iGQg7ccBPrpdRvDR6nwARg8PDk1hYqhVgT/Kgg4sMKcI9TgyZKcgby3BURBA y3xA== X-Gm-Message-State: AOAM530aDC8swvAD0S4qom5Ehc6KbmHTG8rXc4W7TWE2mAAe6Q4qBGBq wUPEdmD+U4j2mM7/XzybZwSWT8Q+ X-Received: by 2002:a7b:c38c:: with SMTP id s12mr518917wmj.136.1594061142041; Mon, 06 Jul 2020 11:45:42 -0700 (PDT) Received: from [192.168.1.3] (ip68-111-84-250.oc.oc.cox.net. [68.111.84.250]) by smtp.gmail.com with ESMTPSA id 12sm393621wmg.6.2020.07.06.11.45.39 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 06 Jul 2020 11:45:41 -0700 (PDT) Subject: Re: [PATCH net-next v2 3/3] net: ethtool: Remove PHYLIB direct dependency To: Jakub Kicinski Cc: netdev@vger.kernel.org, Andrew Lunn , Heiner Kallweit , Russell King , "David S. Miller" , Michal Kubecek , open list References: <20200706042758.168819-1-f.fainelli@gmail.com> <20200706042758.168819-4-f.fainelli@gmail.com> <20200706114000.223e27eb@kicinski-fedora-pc1c0hjn.dhcp.thefacebook.com> From: Florian Fainelli Message-ID: <262dbde0-2a0e-6820-fd69-157b7f05a8c4@gmail.com> Date: Mon, 6 Jul 2020 11:45:38 -0700 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:68.0) Gecko/20100101 Firefox/68.0 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: <20200706114000.223e27eb@kicinski-fedora-pc1c0hjn.dhcp.thefacebook.com> 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 7/6/2020 11:40 AM, Jakub Kicinski wrote: > On Sun, 5 Jul 2020 21:27:58 -0700 Florian Fainelli wrote: >> + ops = ethtool_phy_ops; >> + if (!ops || !ops->start_cable_test) { > > nit: don't think member-by-member checking is necessary. We don't > expect there to be any alternative versions of the ops, right? There could be, a network device driver not using PHYLIB could register its own operations and only implement a subset of these operations. > >> + ret = -EOPNOTSUPP; >> + goto out_rtnl; >> + } >> + >> ret = ethnl_ops_begin(dev); >> if (ret < 0) >> goto out_rtnl; >> >> - ret = phy_start_cable_test(dev->phydev, info->extack); >> + ret = ops->start_cable_test(dev->phydev, info->extack); > > nit: my personal preference would be to hide checking the ops and > calling the member in a static inline helper. > > Note that we should be able to remove this from phy.h now: I would prefer to keep thsose around in case a network device driver cannot punt entirely onto PHYLIB and instead needs to wrap those calls around. > > #if IS_ENABLED(CONFIG_PHYLIB) > int phy_start_cable_test(struct phy_device *phydev, > struct netlink_ext_ack *extack); > int phy_start_cable_test_tdr(struct phy_device *phydev, > struct netlink_ext_ack *extack, > const struct phy_tdr_config *config); > #else > static inline > int phy_start_cable_test(struct phy_device *phydev, > struct netlink_ext_ack *extack) > { > NL_SET_ERR_MSG(extack, "Kernel not compiled with PHYLIB support"); > return -EOPNOTSUPP; > } > static inline > int phy_start_cable_test_tdr(struct phy_device *phydev, > struct netlink_ext_ack *extack, > const struct phy_tdr_config *config) > { > NL_SET_ERR_MSG(extack, "Kernel not compiled with PHYLIB support"); > return -EOPNOTSUPP; > } > #endif > > > We could even risk a direct call: > > #if IS_REACHABLE(CONFIG_PHYLIB) > static inline int do_x() > { > return __do_x(); > } > #else > static inline int do_x() > { > if (!ops) > return -EOPNOTSUPP; > return ops->do_x(); > } > #endif > > But that's perhaps doing too much... Fine either way with me, let us see what Michal and Andrew think about that. -- Florian