Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp3760416ybl; Tue, 20 Aug 2019 01:43:54 -0700 (PDT) X-Google-Smtp-Source: APXvYqyCBtBlPtvJNnJWt3blJx5aHQB66UmnTqpzvmYhF0KCYXShJPJnce2u5Wfj7A6AVVlO5Zgf X-Received: by 2002:a17:902:b28:: with SMTP id 37mr27024173plq.2.1566290634696; Tue, 20 Aug 2019 01:43:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566290634; cv=none; d=google.com; s=arc-20160816; b=ahhGM1v8r7s8rinB3UV9loZDXmabcA9I+ZT1f+EmaDbTadUyp4m18mNG75zFfvczu5 CLNxQPS+Jy69zK5S+AiyfCMmChjBeWGb8IscqhGlJx2FoKnP49CuNNaaVks+LBGHrvjX C0siZ/lVZKHyhMWVa6d03L4wjd0jKAUZWgC0s9uqy1eExf5xQW648NwS5DBJW3rKRB8t DMz+RdtT3nuqnJqkOHCdIqLna2BMP1s4HutnU5sXbLEUOka/RltWzrWcPfCJzDYNdyjj TABazQc+7YRHhqJe6so5Yj+DYzoVcDE/DYGJ6YcVM3JAAm2iNR5ncV1+WYxt+BN+unT/ hceg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=Ycv/jEAcG3fpQBCVUPoq40RlT152vTGJJ9rC2v/DC0k=; b=im1JFPlkvNbpyZACv0ovvnQsuqChVxCd4ON2xpmtqkI5B5Lw6RADLlp0bnJh0172FP x6hu7DSJ22a+eayQCpMUlYX+7LTOEKvZL0Tj36aAD9WCF4Aj2jHI00zjw1+aeAxbE2Fk ku9p2fHrdqvIvlwy15Zdc4PsTGzVB5EyHDX9RMPYl3kUjMoO+vXQQX/2fJKhYzcZYbKx yN4rgo2NHQ7Gwk3jvfI0AQ06MrJGWIw89l0ElzXP8lr7cIoyCGbhCGU4n4HK6PIsJPCu /ulOSJP2h5pj91N3UDxzzorf/sdDjyPdNAdbf9WaF5uFH/vYBjpH+fEsT7jDEHkOsNJb DX7A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=f0FCu+Ya; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d18si12467218pfn.202.2019.08.20.01.43.39; Tue, 20 Aug 2019 01:43:54 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=f0FCu+Ya; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729650AbfHTIlt (ORCPT + 99 others); Tue, 20 Aug 2019 04:41:49 -0400 Received: from mail-wm1-f65.google.com ([209.85.128.65]:51809 "EHLO mail-wm1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729362AbfHTIlU (ORCPT ); Tue, 20 Aug 2019 04:41:20 -0400 Received: by mail-wm1-f65.google.com with SMTP id k1so1569484wmi.1 for ; Tue, 20 Aug 2019 01:41:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=Ycv/jEAcG3fpQBCVUPoq40RlT152vTGJJ9rC2v/DC0k=; b=f0FCu+YadoOWZOTl9Q8ohbQYHrR/ljKMMnNVHieeC41h1iNxHf8GVQge9XGOmeNHAQ 4ZIo/RnvS/rn2ixKimc4ElXf5cZWHA7gU97MTm/HcvNnzWnzAERVaZ082klnN9fxKdGA cwTBAydF9wPfXYgyltwV57QcP277fVJZNEGIdppn4mCe2S3zxG9aeExprdISzUZfwnJA tbmmELvVM9IzDrKG6PgPV7hdzgxjEXqhsyajUz6FJEvqirxI/AWB9L33SHVNebMyYVpH LMwgQDGDA1onUh9PJ3imhw++67Oah+1OVTk9iOyRsZqHGbdzvbWmyqcGjZu7GqQ6I1Zj Eipw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=Ycv/jEAcG3fpQBCVUPoq40RlT152vTGJJ9rC2v/DC0k=; b=TCQBJoa2CaP4IsI27HHPi5W30FfY4K9OeWKPUDCYz8q+Hx0wwQxSUo7xuVUkzxNI2v au3SrPROcmsyaa4kpKn+EmKWktJY5i7HjASYOCYeWFFaTNnPfdtQXatVKuf+dg0HtCoF TMbo2SWKqw1hnnJEOVZfJeRstD+DDvcnY1DXSdpxhUfEAdQx+lXBxHNhTd50VTtTxdIM hfiODM5ta6gAZYjJt6duCuycSlhie/Raf6PU12q/WnL3wXe15b86AD1VsFEyYso48p9Z W0wdjoHx5uqa9HCNT4/xhw7MWpYkOcez5Yfpm4a2Y27x0YZPaTlUhHCJ/e7P0WY4tnSf V+ew== X-Gm-Message-State: APjAAAX2eoYxzJvVnBPZ/cSnHM4ZMffnAADVr4N9sIsPabdfuomjVCNI MG3M1lJDarEaxciG5WjXcxP+8A== X-Received: by 2002:a7b:cb8e:: with SMTP id m14mr25350146wmi.10.1566290478169; Tue, 20 Aug 2019 01:41:18 -0700 (PDT) Received: from bender.baylibre.local (lmontsouris-657-1-212-31.w90-63.abo.wanadoo.fr. [90.63.244.31]) by smtp.gmail.com with ESMTPSA id g2sm34275648wru.27.2019.08.20.01.41.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 20 Aug 2019 01:41:17 -0700 (PDT) From: Neil Armstrong To: a.hajda@samsung.com, Laurent.pinchart@ideasonboard.com, jonas@kwiboo.se, jernej.skrabec@siol.net, boris.brezillon@collabora.com Cc: Neil Armstrong , linux-amlogic@lists.infradead.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Subject: [RFC 05/11] drm/bridge: synopsys: dw-hdmi: use negociated bus formats Date: Tue, 20 Aug 2019 10:41:03 +0200 Message-Id: <20190820084109.24616-6-narmstrong@baylibre.com> X-Mailer: git-send-email 2.22.0 In-Reply-To: <20190820084109.24616-1-narmstrong@baylibre.com> References: <20190820084109.24616-1-narmstrong@baylibre.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Use the negociated bus formats from the atomic check function if the input and output formats are non NULL, otherwise fallback to the plat_data->input_bus_format or the default MEDIA_BUS_FMT_RGB888_1X24 bus format. Signed-off-by: Neil Armstrong --- drivers/gpu/drm/bridge/synopsys/dw-hdmi.c | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c b/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c index 121c2167ee20..316823abdd00 100644 --- a/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c +++ b/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c @@ -1968,11 +1968,10 @@ static int dw_hdmi_setup(struct dw_hdmi *hdmi, struct drm_display_mode *mode) hdmi->hdmi_data.video_mode.mpixelrepetitionoutput = 0; hdmi->hdmi_data.video_mode.mpixelrepetitioninput = 0; - /* TOFIX: Get input format from plat data or fallback to RGB888 */ if (hdmi->plat_data->input_bus_format) hdmi->hdmi_data.enc_in_bus_format = hdmi->plat_data->input_bus_format; - else + else if (!hdmi->hdmi_data.enc_in_bus_format) hdmi->hdmi_data.enc_in_bus_format = MEDIA_BUS_FMT_RGB888_1X24; /* TOFIX: Get input encoding from plat data or fallback to none */ @@ -1982,8 +1981,8 @@ static int dw_hdmi_setup(struct dw_hdmi *hdmi, struct drm_display_mode *mode) else hdmi->hdmi_data.enc_in_encoding = V4L2_YCBCR_ENC_DEFAULT; - /* TOFIX: Default to RGB888 output format */ - hdmi->hdmi_data.enc_out_bus_format = MEDIA_BUS_FMT_RGB888_1X24; + if (!hdmi->hdmi_data.enc_out_bus_format) + hdmi->hdmi_data.enc_out_bus_format = MEDIA_BUS_FMT_RGB888_1X24; hdmi->hdmi_data.pix_repet_factor = 0; hdmi->hdmi_data.hdcp_enable = 0; @@ -2224,6 +2223,8 @@ static int dw_hdmi_bridge_atomic_check(struct drm_bridge *bridge, dev_dbg(hdmi->dev, "selected output format %x\n", bridge_state->output_bus_cfg.fmt); + hdmi->hdmi_data.enc_out_bus_format = bridge_state->output_bus_cfg.fmt; + ret = drm_atomic_bridge_choose_input_bus_cfg(bridge_state, crtc_state, conn_state); if (ret) @@ -2232,6 +2233,8 @@ static int dw_hdmi_bridge_atomic_check(struct drm_bridge *bridge, dev_dbg(hdmi->dev, "selected input format %x\n", bridge_state->input_bus_cfg.fmt); + hdmi->hdmi_data.enc_in_bus_format = bridge_state->input_bus_cfg.fmt; + return 0; } -- 2.22.0