Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp3684896pxf; Mon, 29 Mar 2021 08:41:34 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxpRqMy8H51H/R4HtZlNbqI1zHz+vP+u1LsVg+ajVUbColUc9Era9dPgqDknAkNsuRO/MI/ X-Received: by 2002:a17:906:a2d3:: with SMTP id by19mr28428060ejb.98.1617032494609; Mon, 29 Mar 2021 08:41:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617032494; cv=none; d=google.com; s=arc-20160816; b=C8uiMQZeyfM4IIuCXVhhVWq62Z0mPbyULrDq3RWOAU8zD4Ta1OjWZde1f6VTMffMZg Pw0bQyaA7HgGpCndUdZoAvRkOzVVB+Fy8fMXclegTZ0bt8yMMzfk/pcZTYCXfWjxiEgV 2DGGhlTacD9GqLpDWGYxsuRir0klQDa448R1J1MuJCFh19v8OkXrpcb0SwxOnTlcKnFf PVUKeVF2057GhCV0n1P2VjixCJj/U3jgAf1iAqIJvgqDu1Wy44UOmFd1vmEsviwCnHGQ fCrPr/8ShvJ4DWKnH6xibjHJjxNHefvV8I2M5a02/3UEit9R43BgDo+8cXVUK9s9Zi6v RSwg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from; bh=BWgNDwb/UMRkPNEZdJIIBbyoZic560VJvqNfFtFNLr8=; b=bJrohT3f600tHqakEA9GX2Ix0O8aC4fOx9wJ3KWLVX/Wkn3P9Sr16raomatm8QsLB4 rAimTT34w09/57QF6VYjM3Mn0jYVKsx6hTKDEFCzP74+Wq/5WbBzaYF2HU2oAVuREWBL 5A0Djb6XpLxUA5HnyEnJ6HNWIVPNNd33bI2DEJGzzvzoPxMwnZVhqQxtgmSiDQYL6yGL J1tk/mrw6B6KyBWr2jfte/NdbXNRS9I39hAyE5DWp85E12F9fOZb0CVHmvE2mcK3wLvF mXBgJChF7+IW0vUfpg0vE8cXaBMTjQkn8JixjZu73/gy6j/iB433pF3nOv0/IJpwXscZ pHHA== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id nc2si15372063ejc.165.2021.03.29.08.41.11; Mon, 29 Mar 2021 08:41:34 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231509AbhC2Phb (ORCPT + 99 others); Mon, 29 Mar 2021 11:37:31 -0400 Received: from bhuna.collabora.co.uk ([46.235.227.227]:51358 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231425AbhC2Pgz (ORCPT ); Mon, 29 Mar 2021 11:36:55 -0400 Received: from guri.fritz.box (unknown [IPv6:2a02:810a:880:f54:85ba:22ea:8b43:4375]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: dafna) by bhuna.collabora.co.uk (Postfix) with ESMTPSA id D4AD81F45548; Mon, 29 Mar 2021 16:36:53 +0100 (BST) From: Dafna Hirschfeld To: dri-devel@lists.freedesktop.org, linux-mediatek@lists.infradead.org, linux-kernel@vger.kernel.org Cc: dafna.hirschfeld@collabora.com, kernel@collabora.com, dafna3@gmail.com, chunkuang.hu@kernel.org, p.zabel@pengutronix.de, airlied@linux.ie, daniel@ffwll.ch, enric.balletbo@collabora.com, laurent.pinchart@ideasonboard.com Subject: [PATCH v2 3/3] drm/mediatek: in struct mtk_hdmi, replace conn field with curr_conn ptr Date: Mon, 29 Mar 2021 17:36:32 +0200 Message-Id: <20210329153632.17559-4-dafna.hirschfeld@collabora.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20210329153632.17559-1-dafna.hirschfeld@collabora.com> References: <20210329153632.17559-1-dafna.hirschfeld@collabora.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The mtk_hdmi does not support creating a bridge with a connector. Therefore the field 'conn' should be removed from the mtk_hdmi struct. It is replaced with a pointer curr_conn that points to the current connector which can be access through the global state. Signed-off-by: Dafna Hirschfeld --- drivers/gpu/drm/mediatek/mtk_hdmi.c | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/drivers/gpu/drm/mediatek/mtk_hdmi.c b/drivers/gpu/drm/mediatek/mtk_hdmi.c index 1eeb211b1536..0d95d2cfe3de 100644 --- a/drivers/gpu/drm/mediatek/mtk_hdmi.c +++ b/drivers/gpu/drm/mediatek/mtk_hdmi.c @@ -153,7 +153,7 @@ struct mtk_hdmi_conf { struct mtk_hdmi { struct drm_bridge bridge; struct drm_bridge *next_bridge; - struct drm_connector conn; + struct drm_connector *curr_conn;/* current connector (only valid when 'enabled') */ struct device *dev; const struct mtk_hdmi_conf *conf; struct phy *phy; @@ -969,7 +969,7 @@ static int mtk_hdmi_setup_avi_infoframe(struct mtk_hdmi *hdmi, ssize_t err; err = drm_hdmi_avi_infoframe_from_display_mode(&frame, - &hdmi->conn, mode); + hdmi->curr_conn, mode); if (err < 0) { dev_err(hdmi->dev, "Failed to get AVI infoframe from mode: %zd\n", err); @@ -1049,7 +1049,7 @@ static int mtk_hdmi_setup_vendor_specific_infoframe(struct mtk_hdmi *hdmi, ssize_t err; err = drm_hdmi_vendor_infoframe_from_display_mode(&frame, - &hdmi->conn, mode); + hdmi->curr_conn, mode); if (err) { dev_err(hdmi->dev, "Failed to get vendor infoframe from mode: %zd\n", err); @@ -1322,6 +1322,8 @@ static void mtk_hdmi_bridge_atomic_disable(struct drm_bridge *bridge, clk_disable_unprepare(hdmi->clk[MTK_HDMI_CLK_HDMI_PIXEL]); clk_disable_unprepare(hdmi->clk[MTK_HDMI_CLK_HDMI_PLL]); + hdmi->curr_conn = NULL; + hdmi->enabled = false; } @@ -1385,8 +1387,13 @@ static void mtk_hdmi_send_infoframe(struct mtk_hdmi *hdmi, static void mtk_hdmi_bridge_atomic_enable(struct drm_bridge *bridge, struct drm_bridge_state *old_state) { + struct drm_atomic_state *state = old_state->base.state; struct mtk_hdmi *hdmi = hdmi_ctx_from_bridge(bridge); + /* Retrieve the connector through the atomic state. */ + hdmi->curr_conn = drm_atomic_get_new_connector_for_encoder(state, + bridge->encoder); + mtk_hdmi_output_set_display_mode(hdmi, &hdmi->mode); clk_prepare_enable(hdmi->clk[MTK_HDMI_CLK_HDMI_PLL]); clk_prepare_enable(hdmi->clk[MTK_HDMI_CLK_HDMI_PIXEL]); @@ -1625,8 +1632,10 @@ static int mtk_hdmi_audio_get_eld(struct device *dev, void *data, uint8_t *buf, { struct mtk_hdmi *hdmi = dev_get_drvdata(dev); - memcpy(buf, hdmi->conn.eld, min(sizeof(hdmi->conn.eld), len)); - + if (hdmi->enabled) + memcpy(buf, hdmi->curr_conn->eld, min(sizeof(hdmi->curr_conn->eld), len)); + else + memset(buf, 0, len); return 0; } -- 2.17.1