Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp1183069pxf; Fri, 2 Apr 2021 03:40:03 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyW7+aW6BLTjbd7qNMzRn6IzElC5a8PkPTqosdsN53uAOoATjibDXskBOZByIF7Px6gptnT X-Received: by 2002:a05:6402:30bb:: with SMTP id df27mr14884219edb.147.1617360002868; Fri, 02 Apr 2021 03:40:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617360002; cv=none; d=google.com; s=arc-20160816; b=UfhWoaJzQBJX+1txj2b419pfsowVLxy6o/rfqglivrfaxEAHSVQt8SrSSF0MQTY0IP QdZ51cerCHlR81aPayZMJ+0yn/gjIleHLuOmtymYxX2JFwCokY00QppZL07YE4EjJYxk Nt6uoPBYiLjENJWf1sDUhV+k+hq4H7FaSzDMFsu3subplMyLbeNE1ua61w97V/bmxhiK e2wRK2cinLl99AFAkIj4sxf5dSbBQgzrGjBTe71X2WBzTmYavZaSy9QKxVe7CpTuP5m6 6jAXluGX+lfMchtZFFMsl5rLkDaAijzRsfxHo5s/3WwnOm3Aiwy0XdaetPdGXr2wSPT5 kjag== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=gCEsIPy/JUnE1af6lZOVCNAVEyvyfi/gtdvNqinEtaI=; b=UFBG5UFs9cTZqR+5GOSo6IbNuOBiHf3hrrIqNf2hmFFsiHDSkVJE+67qhKufQMVVs5 kK4gw9BcG2zDokrowf86Drk3hyrA3JY9GhkfLX/HWqq+3JUOlg4XQYEkzfMxNUHL1OwM h+L9pD0pV9AKq7bLmMo+N/PgdxVaZewFkRIzCRxIf3B3J3QFmz+OSodDlDrqMlJThsGO otkMOapQZUKLSLN8x4cOXfrGQvd5lTFu0YqTPqgAtuAr05HHi3Noh29APHYLwI1HEVOI dyT1P2sxYnaWzZ67RU3mycE2N81l8Ago276ZjSXKb/HQUhwNP2pQIWEQrwESHL6jo23+ dfPg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=PnzgGaeI; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y14si5894769ejw.723.2021.04.02.03.39.38; Fri, 02 Apr 2021 03:40:02 -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 (test mode) header.i=@ideasonboard.com header.s=mail header.b=PnzgGaeI; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234902AbhDBKjA (ORCPT + 99 others); Fri, 2 Apr 2021 06:39:00 -0400 Received: from perceval.ideasonboard.com ([213.167.242.64]:45166 "EHLO perceval.ideasonboard.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229599AbhDBKjA (ORCPT ); Fri, 2 Apr 2021 06:39:00 -0400 Received: from pendragon.ideasonboard.com (62-78-145-57.bb.dnainternet.fi [62.78.145.57]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 971302C1; Fri, 2 Apr 2021 12:38:57 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1617359937; bh=sZR3sSwoDUoM230emJjHnzx6XJSMp3h9iknmHtUO+6o=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=PnzgGaeI8fPjY7zLqQdiAZL2gQRYwL1i95ib4yqkJ7OKrubESUo8UW3CMttNCmK29 ntUF9VYXsSqRUcUemNLmlWBwgd/RamQ8IbN2Z8g5To+DevHUPaBzPEbhKHxmtp49aZ /cEt+POVga0378zGBuzX4DijdKe1QJXTZ8YYaSLc= Date: Fri, 2 Apr 2021 13:38:13 +0300 From: Laurent Pinchart To: Pratyush Yadav Cc: Mauro Carvalho Chehab , Rob Herring , Kishon Vijay Abraham I , Vinod Koul , Peter Ujfalusi , Maxime Ripard , Benoit Parrot , Hans Verkuil , Alexandre Courbot , Stanimir Varbanov , Helen Koike , Michael Tretter , Peter Chen , Chunfeng Yun , linux-media@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-phy@lists.infradead.org, dmaengine@vger.kernel.org, Vignesh Raghavendra , Tomi Valkeinen Subject: Re: [PATCH 03/16] phy: cdns-dphy: Allow setting mode Message-ID: References: <20210330173348.30135-1-p.yadav@ti.com> <20210330173348.30135-4-p.yadav@ti.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20210330173348.30135-4-p.yadav@ti.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Pratyush, Thank you for the patch. On Tue, Mar 30, 2021 at 11:03:35PM +0530, Pratyush Yadav wrote: > Allow callers to set the PHY mode. The main mode should always be > PHY_MODE_MIPI_DPHY but the submode can either be > PHY_MIPI_DPHY_SUBMODE_RX or PHY_MIPI_DPHY_SUBMODE_TX. Update the ops > based on the requested submode. Isn't a given DPHY instance always meant to work in one particular mode ? I can't really imagine a single instance of this IP core being integrated in a way that it can be used in either RX or TX mode. It seems better to select the mode through DT, by describing if the DPHY is an RX or TX (possibly through different compatible strings). > Signed-off-by: Pratyush Yadav > --- > drivers/phy/cadence/cdns-dphy.c | 30 ++++++++++++++++++++++++++++++ > 1 file changed, 30 insertions(+) > > diff --git a/drivers/phy/cadence/cdns-dphy.c b/drivers/phy/cadence/cdns-dphy.c > index 8656f2102a91..7d5f7b333893 100644 > --- a/drivers/phy/cadence/cdns-dphy.c > +++ b/drivers/phy/cadence/cdns-dphy.c > @@ -365,11 +365,41 @@ static int cdns_dphy_configure(struct phy *phy, union phy_configure_opts *opts) > return 0; > } > > +static int cdns_dphy_set_mode(struct phy *phy, enum phy_mode mode, int submode) > +{ > + struct cdns_dphy *dphy = phy_get_drvdata(phy); > + const struct cdns_dphy_driver_data *ddata; > + > + ddata = of_device_get_match_data(dphy->dev); > + if (!ddata) > + return -EINVAL; > + > + if (mode != PHY_MODE_MIPI_DPHY) > + return -EINVAL; > + > + if (submode == PHY_MIPI_DPHY_SUBMODE_TX) { > + if (!ddata->tx) > + return -EOPNOTSUPP; > + > + dphy->ops = ddata->tx; > + } else if (submode == PHY_MIPI_DPHY_SUBMODE_RX) { > + if (!ddata->rx) > + return -EOPNOTSUPP; > + > + dphy->ops = ddata->rx; > + } else { > + return -EOPNOTSUPP; > + } > + > + return 0; > +} > + > static const struct phy_ops cdns_dphy_ops = { > .configure = cdns_dphy_configure, > .validate = cdns_dphy_validate, > .power_on = cdns_dphy_power_on, > .power_off = cdns_dphy_power_off, > + .set_mode = cdns_dphy_set_mode, > }; > > static int cdns_dphy_probe(struct platform_device *pdev) -- Regards, Laurent Pinchart