Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp2867560pxb; Fri, 12 Feb 2021 03:35:03 -0800 (PST) X-Google-Smtp-Source: ABdhPJwdsVnmv6oQSCOIuiP4rmsVowKoEkYZP7pe8pIwRBrbwx3cLpwW6o9doV6I2xy6E4NdYDYU X-Received: by 2002:a05:6402:306c:: with SMTP id bs12mr2838838edb.348.1613129703418; Fri, 12 Feb 2021 03:35:03 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1613129703; cv=none; d=google.com; s=arc-20160816; b=EbOkkbYcksDv4M+FWWKXXST3imG3L5QXowNpnXhmCWkOmftzBTUQoBHQTneNL+xdU+ t8k/gum5yhZ2ngrSc6fK4jCvbbyfk1OsxNl2b4PYB9PVLM1K4iO+wk1MBmiBII9Vu7Wf YZ/MgAXFTCItCZuP9Xak1iTSfBkAwml0+ztZ6+AzbtVnXZPiiPRtevPZj8YVm3xDM7vL gpGbdubJFCFysrP4Y+Rz9rToeUH/k/eKBA3MxMOYdJHJ3kqLshjIPKMCHh2PEdgY8NFN aqcODN78oTf2/tOBp7iKTEr7Vms6bxzXDATuDn3sB2wlRxR8YfTHB3hwjaKtPB85QWdg kE5Q== 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:dkim-signature; bh=lyiLDwogJ1paXgGUXDm0c4v2P/Y1qePzkvGucH2e5Us=; b=x2PXh17Hjbcv+CWod6T6eHist9DAU6rHLrpv6ijNImVG7Z9u8gEvAXbOVRPUeRTxgt +XcrRO7ObuspKmpTvvi6e8Itha8J9tgTwgr1n1juKqGtQSkwcq98jXIKpxXqfua+NhQa shjlxWnmWEQyvT7ob6FEeYwTxx226ggIPD7H89/+rmwSP1h8v39+CGFBNVxd1FIZRnl+ 0HL7nyeA7YDBlGgTDHpfbP8xPTuBZ10Xige630nUsCFeaDoOmsyHj91CB6yF7oSTP88y c0Uk7Q8O02fE5FV9XZNvM5S5OdbgADp8t/Z9UF2if4Fn8zYdBYnxU9e03IBJCGYN7k6w YbRQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=GmJqnkkF; 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s22si6075081ejd.59.2021.02.12.03.34.40; Fri, 12 Feb 2021 03:35:03 -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=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=GmJqnkkF; 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229960AbhBLLd6 (ORCPT + 99 others); Fri, 12 Feb 2021 06:33:58 -0500 Received: from fllv0016.ext.ti.com ([198.47.19.142]:45484 "EHLO fllv0016.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229710AbhBLLd5 (ORCPT ); Fri, 12 Feb 2021 06:33:57 -0500 Received: from lelv0265.itg.ti.com ([10.180.67.224]) by fllv0016.ext.ti.com (8.15.2/8.15.2) with ESMTP id 11CBWCcO046265; Fri, 12 Feb 2021 05:32:12 -0600 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1613129532; bh=lyiLDwogJ1paXgGUXDm0c4v2P/Y1qePzkvGucH2e5Us=; h=Subject:To:CC:References:From:Date:In-Reply-To; b=GmJqnkkFtxBDSim9680fu9/si7iKpQ7G/hJrLVGBhnBkq2YK1fXyye6wtnbp2wgfj WgNx11Sjye3KW3Zt4PjvwHqgOvROD941P63KCIcW3GzusRKVQtLnUkomLPjbtOylis mS8zss5FnP/crsBNz6V6eaeGaEOKy2nReUMq66gs= Received: from DLEE106.ent.ti.com (dlee106.ent.ti.com [157.170.170.36]) by lelv0265.itg.ti.com (8.15.2/8.15.2) with ESMTPS id 11CBWCdg094817 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Fri, 12 Feb 2021 05:32:12 -0600 Received: from DLEE107.ent.ti.com (157.170.170.37) by DLEE106.ent.ti.com (157.170.170.36) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1979.3; Fri, 12 Feb 2021 05:32:12 -0600 Received: from fllv0040.itg.ti.com (10.64.41.20) by DLEE107.ent.ti.com (157.170.170.37) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1979.3 via Frontend Transport; Fri, 12 Feb 2021 05:32:12 -0600 Received: from [10.250.234.7] (ileax41-snat.itg.ti.com [10.172.224.153]) by fllv0040.itg.ti.com (8.15.2/8.15.2) with ESMTP id 11CBW83G057822; Fri, 12 Feb 2021 05:32:09 -0600 Subject: Re: [PATCH v14 2/4] phy: Add media type and speed serdes configuration interfaces To: Steen Hegelund , Vinod Koul CC: Alexandre Belloni , Lars Povlsen , Bjarni Jonasson , Microchip UNG Driver List , , , Andrew Lunn References: <20210210085255.2006824-1-steen.hegelund@microchip.com> <20210210085255.2006824-3-steen.hegelund@microchip.com> From: Kishon Vijay Abraham I Message-ID: <04d91f6b-775a-8389-b813-31f7b4a778cb@ti.com> Date: Fri, 12 Feb 2021 17:02:08 +0530 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: <20210210085255.2006824-3-steen.hegelund@microchip.com> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Steen, On 10/02/21 2:22 pm, Steen Hegelund wrote: > Provide new phy configuration interfaces for media type and speed that > allows allows e.g. PHYs used for ethernet to be configured with this > information. > > Signed-off-by: Lars Povlsen > Signed-off-by: Steen Hegelund > Reviewed-by: Andrew Lunn > Reviewed-by: Alexandre Belloni > --- > drivers/phy/phy-core.c | 30 ++++++++++++++++++++++++++++++ > include/linux/phy/phy.h | 26 ++++++++++++++++++++++++++ > 2 files changed, 56 insertions(+) > > diff --git a/drivers/phy/phy-core.c b/drivers/phy/phy-core.c > index 71cb10826326..ccb575b13777 100644 > --- a/drivers/phy/phy-core.c > +++ b/drivers/phy/phy-core.c > @@ -373,6 +373,36 @@ int phy_set_mode_ext(struct phy *phy, enum phy_mode mode, int submode) > } > EXPORT_SYMBOL_GPL(phy_set_mode_ext); > > +int phy_set_media(struct phy *phy, enum phy_media media) > +{ > + int ret; > + > + if (!phy || !phy->ops->set_media) > + return 0; > + > + mutex_lock(&phy->mutex); > + ret = phy->ops->set_media(phy, media); > + mutex_unlock(&phy->mutex); > + > + return ret; > +} > +EXPORT_SYMBOL_GPL(phy_set_media); > + > +int phy_set_speed(struct phy *phy, int speed) > +{ > + int ret; > + > + if (!phy || !phy->ops->set_speed) > + return 0; > + > + mutex_lock(&phy->mutex); > + ret = phy->ops->set_speed(phy, speed); > + mutex_unlock(&phy->mutex); > + > + return ret; > +} > +EXPORT_SYMBOL_GPL(phy_set_speed); Can't speed derived from mode? Do we need a separate set_speed function? Thanks Kishon > + > int phy_reset(struct phy *phy) > { > int ret; > diff --git a/include/linux/phy/phy.h b/include/linux/phy/phy.h > index e435bdb0bab3..e4fd69a1faa7 100644 > --- a/include/linux/phy/phy.h > +++ b/include/linux/phy/phy.h > @@ -44,6 +44,12 @@ enum phy_mode { > PHY_MODE_DP > }; > > +enum phy_media { > + PHY_MEDIA_DEFAULT, > + PHY_MEDIA_SR, > + PHY_MEDIA_DAC, > +}; > + > /** > * union phy_configure_opts - Opaque generic phy configuration > * > @@ -64,6 +70,8 @@ union phy_configure_opts { > * @power_on: powering on the phy > * @power_off: powering off the phy > * @set_mode: set the mode of the phy > + * @set_media: set the media type of the phy (optional) > + * @set_speed: set the speed of the phy (optional) > * @reset: resetting the phy > * @calibrate: calibrate the phy > * @release: ops to be performed while the consumer relinquishes the PHY > @@ -75,6 +83,8 @@ struct phy_ops { > int (*power_on)(struct phy *phy); > int (*power_off)(struct phy *phy); > int (*set_mode)(struct phy *phy, enum phy_mode mode, int submode); > + int (*set_media)(struct phy *phy, enum phy_media media); > + int (*set_speed)(struct phy *phy, int speed); > > /** > * @configure: > @@ -215,6 +225,8 @@ int phy_power_off(struct phy *phy); > int phy_set_mode_ext(struct phy *phy, enum phy_mode mode, int submode); > #define phy_set_mode(phy, mode) \ > phy_set_mode_ext(phy, mode, 0) > +int phy_set_media(struct phy *phy, enum phy_media media); > +int phy_set_speed(struct phy *phy, int speed); > int phy_configure(struct phy *phy, union phy_configure_opts *opts); > int phy_validate(struct phy *phy, enum phy_mode mode, int submode, > union phy_configure_opts *opts); > @@ -344,6 +356,20 @@ static inline int phy_set_mode_ext(struct phy *phy, enum phy_mode mode, > #define phy_set_mode(phy, mode) \ > phy_set_mode_ext(phy, mode, 0) > > +static inline int phy_set_media(struct phy *phy, enum phy_media media) > +{ > + if (!phy) > + return 0; > + return -ENOSYS; > +} > + > +static inline int phy_set_speed(struct phy *phy, int speed) > +{ > + if (!phy) > + return 0; > + return -ENOSYS; > +} > + > static inline enum phy_mode phy_get_mode(struct phy *phy) > { > return PHY_MODE_INVALID; >