Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp742786pxu; Fri, 23 Oct 2020 12:07:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxZRaQlU6zoOIyAjUdM7AKbR7sfLoDaokMOff8tpDcPpbGXEtG40O7ngasArET8mLoR0dsp X-Received: by 2002:a17:906:7016:: with SMTP id n22mr3701865ejj.402.1603480024662; Fri, 23 Oct 2020 12:07:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603480024; cv=none; d=google.com; s=arc-20160816; b=A8EeE1t5dQxssEfdKajeJexoTbhV0S2ORg4LYCv3hsZ7PNI6RNfbJsp/HVsBmIHnIG dQYUKJwvzY/nv/F67pznBqR4H71izjF7gMMXmdDds1WUoGNSOaFNBD2+J3dfE00xA151 in70RwJa+YPiv5Wru+GIouYK0Tsv5CfelorEQuXUJJr91GqNZD52odFxahHGMhPCMLCY GUEyii0vphCvbsBIRf0IF//QaxjNMzyJ/VG1BiaEmdEMPUSVJFKcUhe5iSJwvJVny1zf jzDVri343jGZySRIGEJUKL1SQ0+ljnvhbrWOImWcpLBGXnE/mwg6thUAz+QVztVX6mKb O2hg== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=ppTdzX346og0WCU18XZlEW8VZBF/qyw6BFWNaSDhJ/4=; b=Lx9xhFsoKmXhoZq7IIRsqcxEpnge8p2YFxgNCn+hQRVLJpFzwTOXiF9kYiM+iIJ3tZ S7pbqsyPlrf6xa6p3qoswoYn1ZXOFUzJA61eZEqfr3418vw4NdnfUuxdcNJ0vpknk61K HJTuQFi/+gSYMdd9NfxDiWcbgdlCV896zH2utr/jgH7vmEa+rguZeI7zpKwnVcWwU6Ni OMt6QrjtHQ1xtuXJKev+ZzAW61qmxa/XMqcA2zMmiEDQpeuSjpRpMDnBKGMqTUwswhi3 TXRm/A3ZYSBQ9DXLRoOLmnT5+UulJ1u9QRZlH5s/LKFvB8EXa4ABhUZ36KcvoSPdj+dl LR6A== ARC-Authentication-Results: i=1; mx.google.com; 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 s13si1441136ejv.213.2020.10.23.12.06.41; Fri, 23 Oct 2020 12:07:04 -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; 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 S1754323AbgJWSLO (ORCPT + 99 others); Fri, 23 Oct 2020 14:11:14 -0400 Received: from mslow2.mail.gandi.net ([217.70.178.242]:51848 "EHLO mslow2.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754311AbgJWSLN (ORCPT ); Fri, 23 Oct 2020 14:11:13 -0400 Received: from relay8-d.mail.gandi.net (unknown [217.70.183.201]) by mslow2.mail.gandi.net (Postfix) with ESMTP id 8F9D23B056D; Fri, 23 Oct 2020 17:46:36 +0000 (UTC) X-Originating-IP: 93.29.109.196 Received: from localhost.localdomain (196.109.29.93.rev.sfr.net [93.29.109.196]) (Authenticated sender: paul.kocialkowski@bootlin.com) by relay8-d.mail.gandi.net (Postfix) with ESMTPSA id 2E9101BF203; Fri, 23 Oct 2020 17:46:13 +0000 (UTC) From: Paul Kocialkowski To: linux-media@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, devel@driverdev.osuosl.org, linux-sunxi@googlegroups.com Cc: Mauro Carvalho Chehab , Rob Herring , Maxime Ripard , Chen-Yu Tsai , Yong Deng , Kishon Vijay Abraham I , Vinod Koul , Helen Koike , Greg Kroah-Hartman , Philipp Zabel , Paul Kocialkowski , Hans Verkuil , Sakari Ailus , Thomas Petazzoni , Hans Verkuil , kevin.lhopital@hotmail.com Subject: [PATCH 01/14] phy: Distinguish between Rx and Tx for MIPI D-PHY with submodes Date: Fri, 23 Oct 2020 19:45:33 +0200 Message-Id: <20201023174546.504028-2-paul.kocialkowski@bootlin.com> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20201023174546.504028-1-paul.kocialkowski@bootlin.com> References: <20201023174546.504028-1-paul.kocialkowski@bootlin.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org As some D-PHY controllers support both Rx and Tx mode, we need a way for users to explicitly request one or the other. For instance, Rx mode can be used along with MIPI CSI-2 while Tx mode can be used with MIPI DSI. Introduce new MIPI D-PHY PHY submodes to use with PHY_MODE_MIPI_DPHY. The default (zero value) is kept to Tx so only the rkisp1 driver, which uses D-PHY in Rx mode, needs to be adapted. Signed-off-by: Paul Kocialkowski --- drivers/staging/media/rkisp1/rkisp1-isp.c | 3 ++- include/linux/phy/phy-mipi-dphy.h | 13 +++++++++++++ 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/drivers/staging/media/rkisp1/rkisp1-isp.c b/drivers/staging/media/rkisp1/rkisp1-isp.c index 6ec1e9816e9f..0afbce00121e 100644 --- a/drivers/staging/media/rkisp1/rkisp1-isp.c +++ b/drivers/staging/media/rkisp1/rkisp1-isp.c @@ -902,7 +902,8 @@ static int rkisp1_mipi_csi2_start(struct rkisp1_isp *isp, phy_mipi_dphy_get_default_config(pixel_clock, isp->sink_fmt->bus_width, sensor->lanes, cfg); - phy_set_mode(sensor->dphy, PHY_MODE_MIPI_DPHY); + phy_set_mode_ext(cdev->dphy, PHY_MODE_MIPI_DPHY, + PHY_MIPI_DPHY_SUBMODE_RX); phy_configure(sensor->dphy, &opts); phy_power_on(sensor->dphy); diff --git a/include/linux/phy/phy-mipi-dphy.h b/include/linux/phy/phy-mipi-dphy.h index a877ffee845d..0f57ef46a8b5 100644 --- a/include/linux/phy/phy-mipi-dphy.h +++ b/include/linux/phy/phy-mipi-dphy.h @@ -6,6 +6,19 @@ #ifndef __PHY_MIPI_DPHY_H_ #define __PHY_MIPI_DPHY_H_ +/** + * enum phy_mipi_dphy_submode - MIPI D-PHY sub-mode + * + * A MIPI D-PHY can be used to transmit or receive data. + * Since some controllers can support both, the direction to enable is specified + * with the PHY sub-mode. Transmit is assumed by default with phy_set_mode. + */ + +enum phy_mipi_dphy_submode { + PHY_MIPI_DPHY_SUBMODE_TX = 0, + PHY_MIPI_DPHY_SUBMODE_RX, +}; + /** * struct phy_configure_opts_mipi_dphy - MIPI D-PHY configuration set * -- 2.28.0