Received: by 2002:a05:7412:d1aa:b0:fc:a2b0:25d7 with SMTP id ba42csp241634rdb; Mon, 29 Jan 2024 00:06:23 -0800 (PST) X-Google-Smtp-Source: AGHT+IFLNHwkzhMhS+NFPc+Cw6Qv3+6WiZDw8f4peO4YRPjn3wfoJzgUYYxsi/pTWnuSPs1fLmZy X-Received: by 2002:a05:6359:1b05:b0:176:c733:9857 with SMTP id up5-20020a0563591b0500b00176c7339857mr2181134rwb.43.1706515583234; Mon, 29 Jan 2024 00:06:23 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1706515583; cv=pass; d=google.com; s=arc-20160816; b=e8OcBG0Q1lQMKDM5TxBFXeCKIeUMuzijS1Dm2/zsguV4rUSfNUWST7pUyYG/Cayf7G GS4gYSmbE2gFpb/O6+rr2/TazNTsbLL4Z5EZU9+QyWgSK2+l9fyMcSj54t8t4vyTsVcv h++D0vl6Dw/BxJSA6S3I5WdfMlDkeKBdQ1dYzHYqkeNOD7u7lWX5DWGj1DhjvlO7LSlb IGfPoBFvbsfdtmjh5qmk9RoxAoSPVPznDB4LM38ZupFQ04TOCSX3zFBWTuvWtQySIOme rSdnjbaM7Iu3yJFLhakRE2fS1qsFsxx3QajZKQCYE/25YTnFvtH1oZ51o+hBs8j68F/K 9alA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=in-reply-to:content-disposition:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:message-id:subject:cc :to:from:date:dkim-signature; bh=J6XKhZscTxsQU4GzOsBbdyY4KIBVonjhMKJORrtVihc=; fh=XThiicf1Jt6nWpN6TR/6Oz+gw7d9dWfod4/tQS8I6fs=; b=ELQS1EeMzHhMd15s1T59EHjbE5+2w1l/28TXT4itSXbUWgronoIRvTyBSIHq98fuN3 6vHpkvQaj69aGM7MkHeU6GL/lC+UbDRGL6lBB48YlcRPIeRWAs03J3/QNXG+C/Dl0T7M ZlI3cBj9mS8zmBDjp1gH01P8d221R0rRFzArb9N7LgFew7mL89eggebpHXSNi40A+7iI NHbkElYuNduclBJKL+4nEF1e4v0ru6pa/q/jOF0Bw7v4vNOd4VnPdATFCF6EERWVxyyI rQgCJCEeV5CdmdraiHham2mVPuPCpeaKYG5zq5lqftjyqJhQ333rm7dBurCINewfQnvg mdXw== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=jCbTeCkS; arc=pass (i=1 spf=pass spfdomain=linaro.org dkim=pass dkdomain=linaro.org dmarc=pass fromdomain=linaro.org); spf=pass (google.com: domain of linux-kernel+bounces-42323-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-42323-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id k190-20020a633dc7000000b0058974d3c296si5376018pga.815.2024.01.29.00.06.22 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 29 Jan 2024 00:06:23 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-42323-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=jCbTeCkS; arc=pass (i=1 spf=pass spfdomain=linaro.org dkim=pass dkdomain=linaro.org dmarc=pass fromdomain=linaro.org); spf=pass (google.com: domain of linux-kernel+bounces-42323-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-42323-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id B5F67282DCA for ; Mon, 29 Jan 2024 08:06:22 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id BAC5D52F8C; Mon, 29 Jan 2024 08:06:10 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=linaro.org header.i=@linaro.org header.b="jCbTeCkS" Received: from mail-ed1-f45.google.com (mail-ed1-f45.google.com [209.85.208.45]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 5530252F6C for ; Mon, 29 Jan 2024 08:06:06 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.208.45 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706515569; cv=none; b=JJHDDv8TJVZ+nmM23hD4z0zitCDBGqvsnApBijiun7AGk84xmSFiM53MhMQiyxnzMa4zoHazXfgvRKYVjLgqDE9+qcLo3BLXgTZrHYG+39PqiBkxxc5frOnTzgar7smBZ8ODRLfrbyoa5F0IVdWipbEB/9J3k0S5P3B0gs5KocA= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1706515569; c=relaxed/simple; bh=4pXk49IB5CwKgTL61jTjpDJ1jl+8OkYK/AUXSjEopmU=; h=Date:From:To:Cc:Subject:Message-ID:References:MIME-Version: Content-Type:Content-Disposition:In-Reply-To; b=Q5cceYuxQ3H7apZjdzIiHyVJO50WezEZI0zC80m95Kcr4BVzkqfks9aCWkzUGzDWHuc0zxvRKK3Hcptz78/b1DkD4XR57YaTX6QWcfx++gX9rjo+xuj8knDrIK2vHlLoBnncbm6y/KbwBb9q8Bq7Diz8cmcK+Ot5UjRNQCKNG60= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linaro.org; spf=pass smtp.mailfrom=linaro.org; dkim=pass (2048-bit key) header.d=linaro.org header.i=@linaro.org header.b=jCbTeCkS; arc=none smtp.client-ip=209.85.208.45 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linaro.org Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=linaro.org Received: by mail-ed1-f45.google.com with SMTP id 4fb4d7f45d1cf-55ef4a66008so787504a12.3 for ; Mon, 29 Jan 2024 00:06:06 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1706515564; x=1707120364; darn=vger.kernel.org; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:from:to:cc:subject:date:message-id:reply-to; bh=J6XKhZscTxsQU4GzOsBbdyY4KIBVonjhMKJORrtVihc=; b=jCbTeCkSPAGBhEos4VXyrHZ48xzrMK+wE7Z44sf34zLuY+DNC6z353BOZL2/oOpe3q mF5oTV4oBY/yDIdEUt1XVLLzxa6zk+MnP6aXDcgvCYfusqHyP9DG1u1bRA/T67Niej4Q d7HRG/Ue0Yhm/VdJg/0iV6smGNBhMNLzM5e7yz1PrlpifGOYYumT+/E5nz0Wnf4kwZjo GbefK2uNJQYc++D3jOFSfEKvwl4e9dHKpCv9A9mkRD+RJPPjPUaVbvqLb5SRL1eWJesS V7RU9YG7RT5MtCOpuIRTZv1WrqG8Kvx520DzRohZw4Sxjf8okyyOZUUHIXuChphvBNpS MfXQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1706515564; x=1707120364; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=J6XKhZscTxsQU4GzOsBbdyY4KIBVonjhMKJORrtVihc=; b=mpQRGM+NSmZxwLyA/MNil+FR8+a5j0fqqTGIlxIBYwFxyOhqh8MKRMJknsMif665Up Ap+17a9T50o5lhLC2HyLram2smFlEhwiljczb8PLwdZY2br4wmtwOEAikiMKfvJc8yby x+jFw1gqt37r91p6i4tY6v+0CboUnQBwULdXgt3UdkCinyLREBhX+JVzXw5uGMdMngwU xO6e9kDGVsQ5y6boYdqGe960Ax3dwqdbIUM1mr+VQu6KFVJdvEUAiTee/wIugqXQXS3U 5JdRB1aKKjFInN6yI0/ZCLYUbvXlYBEvjNoTpnRaTljcif2v/TwJe+icGfn/+CmX4g9q kCBw== X-Gm-Message-State: AOJu0YzpbYWPgRo/deQ1qJxWhnV3KTaa5yG0nnH91nxJZFFTt5l90yLo CwpvuzAwmf3nbV8O39BTxwXy9MET83lafk2IOmr9UhWAhFFQmLwgRNixvakXguK5pDVZknwujK9 p X-Received: by 2002:a05:6402:358b:b0:55d:2ecf:7ba7 with SMTP id y11-20020a056402358b00b0055d2ecf7ba7mr4019567edc.2.1706515564435; Mon, 29 Jan 2024 00:06:04 -0800 (PST) Received: from linaro.org ([79.115.23.25]) by smtp.gmail.com with ESMTPSA id m3-20020a50cc03000000b0055cda996b63sm3387507edi.20.2024.01.29.00.06.03 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 29 Jan 2024 00:06:04 -0800 (PST) Date: Mon, 29 Jan 2024 10:06:02 +0200 From: Abel Vesa To: Dmitry Baryshkov Cc: Vinod Koul , Kishon Vijay Abraham I , Bjorn Andersson , Konrad Dybcio , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Johan Hovold , linux-phy@lists.infradead.org, linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org, devicetree@vger.kernel.org Subject: Re: [PATCH v3 2/2] phy: qcom: edp: Add set_mode op for configuring eDP/DP submode Message-ID: References: <20240129-x1e80100-phy-edp-compatible-refactor-v3-0-e71f3359c535@linaro.org> <20240129-x1e80100-phy-edp-compatible-refactor-v3-2-e71f3359c535@linaro.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: On 24-01-29 06:05:09, Dmitry Baryshkov wrote: > On Mon, 29 Jan 2024 at 02:26, Abel Vesa wrote: > > > > Future platforms should not use different compatibles to differentiate > > between eDP and DP mode. Instead, they should use a single compatible as the > > IP block is the same. It will be the job of the controller to set the submode > > of the PHY accordingly. > > > > The existing platforms will remain with separate compatibles for each mode. > > > > Signed-off-by: Abel Vesa > > --- > > drivers/phy/qualcomm/phy-qcom-edp.c | 71 ++++++++++++++++++++++++++----------- > > 1 file changed, 51 insertions(+), 20 deletions(-) > > > > diff --git a/drivers/phy/qualcomm/phy-qcom-edp.c b/drivers/phy/qualcomm/phy-qcom-edp.c > > index 8e5078304646..af941d6c5588 100644 > > --- a/drivers/phy/qualcomm/phy-qcom-edp.c > > +++ b/drivers/phy/qualcomm/phy-qcom-edp.c > > @@ -14,6 +14,7 @@ > > #include > > #include > > #include > > +#include > > #include > > #include > > #include > > @@ -68,19 +69,21 @@ > > > > #define TXn_TRAN_DRVR_EMP_EN 0x0078 > > > > -struct qcom_edp_cfg { > > - bool is_dp; > > - > > - /* DP PHY swing and pre_emphasis tables */ > > +struct qcom_edp_swing_pre_emph_cfg { > > const u8 (*swing_hbr_rbr)[4][4]; > > const u8 (*swing_hbr3_hbr2)[4][4]; > > const u8 (*pre_emphasis_hbr_rbr)[4][4]; > > const u8 (*pre_emphasis_hbr3_hbr2)[4][4]; > > }; > > > > +struct qcom_edp_phy_cfg { > > + bool is_edp; > > + const struct qcom_edp_swing_pre_emph_cfg *swing_pre_emph_cfg; > > +}; > > + > > struct qcom_edp { > > struct device *dev; > > - const struct qcom_edp_cfg *cfg; > > + const struct qcom_edp_phy_cfg *cfg; > > > > struct phy *phy; > > > > @@ -96,6 +99,8 @@ struct qcom_edp { > > > > struct clk_bulk_data clks[2]; > > struct regulator_bulk_data supplies[2]; > > + > > + bool is_edp; > > }; > > > > static const u8 dp_swing_hbr_rbr[4][4] = { > > @@ -126,8 +131,7 @@ static const u8 dp_pre_emp_hbr2_hbr3[4][4] = { > > { 0x04, 0xff, 0xff, 0xff } > > }; > > > > -static const struct qcom_edp_cfg dp_phy_cfg = { > > - .is_dp = true, > > +static const struct qcom_edp_swing_pre_emph_cfg dp_phy_swing_pre_emph_cfg = { > > .swing_hbr_rbr = &dp_swing_hbr_rbr, > > .swing_hbr3_hbr2 = &dp_swing_hbr2_hbr3, > > .pre_emphasis_hbr_rbr = &dp_pre_emp_hbr_rbr, > > @@ -162,18 +166,28 @@ static const u8 edp_pre_emp_hbr2_hbr3[4][4] = { > > { 0x00, 0xff, 0xff, 0xff } > > }; > > > > -static const struct qcom_edp_cfg edp_phy_cfg = { > > - .is_dp = false, > > +static const struct qcom_edp_swing_pre_emph_cfg edp_phy_swing_pre_emph_cfg = { > > .swing_hbr_rbr = &edp_swing_hbr_rbr, > > .swing_hbr3_hbr2 = &edp_swing_hbr2_hbr3, > > .pre_emphasis_hbr_rbr = &edp_pre_emp_hbr_rbr, > > .pre_emphasis_hbr3_hbr2 = &edp_pre_emp_hbr2_hbr3, > > }; > > > > +static const struct qcom_edp_phy_cfg sc7280_dp_phy_cfg = { > > +}; > > + > > +static const struct qcom_edp_phy_cfg sc8280xp_dp_phy_cfg = { > > + .swing_pre_emph_cfg = &dp_phy_swing_pre_emph_cfg, > > +}; > > + > > +static const struct qcom_edp_phy_cfg sc8280xp_edp_phy_cfg = { > > + .is_edp = true, > > + .swing_pre_emph_cfg = &edp_phy_swing_pre_emph_cfg, > > +}; > > + > > static int qcom_edp_phy_init(struct phy *phy) > > { > > struct qcom_edp *edp = phy_get_drvdata(phy); > > - const struct qcom_edp_cfg *cfg = edp->cfg; > > int ret; > > u8 cfg8; > > > > @@ -200,7 +214,7 @@ static int qcom_edp_phy_init(struct phy *phy) > > DP_PHY_PD_CTL_PLL_PWRDN | DP_PHY_PD_CTL_DP_CLAMP_EN, > > edp->edp + DP_PHY_PD_CTL); > > > > - if (cfg && cfg->is_dp) > > + if (edp->cfg->swing_pre_emph_cfg && !edp->is_edp) > > I think (!edp->is_edp) should be enough here. Actually, in case of DP, the cfg8 needs to be 0xb7 for sc8280xp, while for sc7280 it should be 0x37. So to differentiate between first and second we check if the config provides a swing_pre_emph_cfg > > > cfg8 = 0xb7; > > else > > cfg8 = 0x37; > > @@ -234,7 +248,7 @@ static int qcom_edp_phy_init(struct phy *phy) > > > > static int qcom_edp_set_voltages(struct qcom_edp *edp, const struct phy_configure_opts_dp *dp_opts) > > { > > - const struct qcom_edp_cfg *cfg = edp->cfg; > > + const struct qcom_edp_swing_pre_emph_cfg *cfg = edp->cfg->swing_pre_emph_cfg; > > unsigned int v_level = 0; > > unsigned int p_level = 0; > > u8 ldo_config; > > @@ -245,6 +259,9 @@ static int qcom_edp_set_voltages(struct qcom_edp *edp, const struct phy_configur > > if (!cfg) > > return 0; > > > > + if (edp->is_edp) > > + cfg = &edp_phy_swing_pre_emph_cfg; > > + > > for (i = 0; i < dp_opts->lanes; i++) { > > v_level = max(v_level, dp_opts->voltage[i]); > > p_level = max(p_level, dp_opts->pre[i]); > > @@ -261,7 +278,7 @@ static int qcom_edp_set_voltages(struct qcom_edp *edp, const struct phy_configur > > if (swing == 0xff || emph == 0xff) > > return -EINVAL; > > > > - ldo_config = (cfg && cfg->is_dp) ? 0x1 : 0x0; > > + ldo_config = edp->is_edp ? 0x0 : 0x1; > > > > writel(ldo_config, edp->tx0 + TXn_LDO_CONFIG); > > writel(swing, edp->tx0 + TXn_TX_DRV_LVL); > > @@ -447,10 +464,9 @@ static int qcom_edp_set_vco_div(const struct qcom_edp *edp, unsigned long *pixel > > static int qcom_edp_phy_power_on(struct phy *phy) > > { > > const struct qcom_edp *edp = phy_get_drvdata(phy); > > - const struct qcom_edp_cfg *cfg = edp->cfg; > > u32 bias0_en, drvr0_en, bias1_en, drvr1_en; > > unsigned long pixel_freq; > > - u8 ldo_config; > > + u8 ldo_config = 0x0; > > int timeout; > > int ret; > > u32 val; > > @@ -468,7 +484,8 @@ static int qcom_edp_phy_power_on(struct phy *phy) > > return timeout; > > > > > > - ldo_config = (cfg && cfg->is_dp) ? 0x1 : 0x0; > > + if (edp->cfg->swing_pre_emph_cfg && !edp->cfg->is_edp) > > I'd assume this should be `if (!edp->is_edp)`, see qcom_edp_set_voltages() > Yep. will fix. > > + ldo_config = 0x1; > > > > writel(ldo_config, edp->tx0 + TXn_LDO_CONFIG); > > writel(ldo_config, edp->tx1 + TXn_LDO_CONFIG); > > @@ -589,6 +606,18 @@ static int qcom_edp_phy_power_off(struct phy *phy) > > return 0; > > } > > > > +static int qcom_edp_phy_set_mode(struct phy *phy, enum phy_mode mode, int submode) > > +{ > > + struct qcom_edp *edp = phy_get_drvdata(phy); > > + > > + if (mode != PHY_MODE_DP) > > + return -EINVAL; > > + > > + edp->is_edp = submode == PHY_SUBMODE_EDP ? true : false; > > + > > + return 0; > > +} > > + > > static int qcom_edp_phy_exit(struct phy *phy) > > { > > struct qcom_edp *edp = phy_get_drvdata(phy); > > @@ -604,6 +633,7 @@ static const struct phy_ops qcom_edp_ops = { > > .configure = qcom_edp_phy_configure, > > .power_on = qcom_edp_phy_power_on, > > .power_off = qcom_edp_phy_power_off, > > + .set_mode = qcom_edp_phy_set_mode, > > .exit = qcom_edp_phy_exit, > > .owner = THIS_MODULE, > > }; > > @@ -781,6 +811,7 @@ static int qcom_edp_phy_probe(struct platform_device *pdev) > > > > edp->dev = dev; > > edp->cfg = of_device_get_match_data(&pdev->dev); > > + edp->is_edp = edp->cfg->is_edp; > > > > edp->edp = devm_platform_ioremap_resource(pdev, 0); > > if (IS_ERR(edp->edp)) > > @@ -839,10 +870,10 @@ static int qcom_edp_phy_probe(struct platform_device *pdev) > > } > > > > static const struct of_device_id qcom_edp_phy_match_table[] = { > > - { .compatible = "qcom,sc7280-edp-phy" }, > > - { .compatible = "qcom,sc8180x-edp-phy" }, > > - { .compatible = "qcom,sc8280xp-dp-phy", .data = &dp_phy_cfg }, > > - { .compatible = "qcom,sc8280xp-edp-phy", .data = &edp_phy_cfg }, > > + { .compatible = "qcom,sc7280-edp-phy" , .data = &sc7280_dp_phy_cfg, }, > > + { .compatible = "qcom,sc8180x-edp-phy", .data = &sc7280_dp_phy_cfg, }, > > + { .compatible = "qcom,sc8280xp-dp-phy", .data = &sc8280xp_dp_phy_cfg, }, > > + { .compatible = "qcom,sc8280xp-edp-phy", .data = &sc8280xp_edp_phy_cfg, }, > > { } > > }; > > MODULE_DEVICE_TABLE(of, qcom_edp_phy_match_table); > > > > -- > > 2.34.1 > > > > > -- > With best wishes > Dmitry