Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp4448050ybv; Tue, 25 Feb 2020 20:31:17 -0800 (PST) X-Google-Smtp-Source: APXvYqyakpbec4AeEWJ+R7NLyUdNgVWEnIrzqpp0odnle7bfBFghE5nSx5Y6WF5YdFeadYuruLJD X-Received: by 2002:a54:468b:: with SMTP id k11mr1599782oic.134.1582691477125; Tue, 25 Feb 2020 20:31:17 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582691477; cv=none; d=google.com; s=arc-20160816; b=LC/b0yPXk8gtt0jX8mSsFYhCF+cz3q9TTFE0T2/UAQ5AIfM8Y1ZGv/jGibpQKXjVY6 iTpG4hgcv4kLkhw64jrnMY5pvVSh7t34zu/v5h2iofIMWGT3l+8/vRtj5wALk71M+k3B 7kQ/lxR/u0R/EkQm1mc+W0Ft3HMQ/eGoKXyizHeBknTQmyf205is1327zpDMc/gwL8hJ QatrsbP3PaBvHziLINaE19L5ZVk6vFT/+zM598fyeM+e93QKv7NXHA8cnCKWqczUjIk+ dbk1AMcizTPEhF10FEudq+Iu4bstFeCj+TXVKRAQR8AZYcyV/6TKK+duZaMy2VsdpJfF 6B3A== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=EBs+WyA9SoX0izZ/2YmeENtSC3EofRpkHiHuspGvF2k=; b=jBZyC0Rx62qecxu3hDNDmM3fqIpL3FJ+0BzBcJl/PV7cJjJ98YPURtdqB68nSUC9L8 IEXPleOSC4glWhncfNgMojYyKaPvu1rlIkR3HzCxo6ZKEN2F016mqljSCffbQf25fkvg RqB131HnHV131TprGDEKgJp5weZpoW+mqDJb/hsYVlqOU/s5rWgBZdA3pq37YY3dTK1E qZWhcXDyLJfnwnzpixDfKrpUmgkOU++s4oqe0QHZu/cXK+6/rP3fHGZmbEpvRYWbfLkO ODa4fSGLgQ89AJIVSQU9QhKNdxWamkjXghZh4YwvRz8ykwf4cXK1Y62OqiQ99JcCj2n/ YpWg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@crapouillou.net header.s=mail header.b=IWlayfR7; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=crapouillou.net Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d10si633315oti.226.2020.02.25.20.31.04; Tue, 25 Feb 2020 20:31:17 -0800 (PST) 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=fail header.i=@crapouillou.net header.s=mail header.b=IWlayfR7; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=crapouillou.net Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726112AbgBZEaz (ORCPT + 99 others); Tue, 25 Feb 2020 23:30:55 -0500 Received: from outils.crapouillou.net ([89.234.176.41]:33598 "EHLO crapouillou.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726039AbgBZEay (ORCPT ); Tue, 25 Feb 2020 23:30:54 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=crapouillou.net; s=mail; t=1582691453; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:references; bh=EBs+WyA9SoX0izZ/2YmeENtSC3EofRpkHiHuspGvF2k=; b=IWlayfR7Bunx4LFkE4p/wAp7BSODGzofuzBCHue4eX+xxz559in2m6Opf0JBNiCgI3FL3B y6iNKebknpDSFT0C8kuXLbA+I9wNvGVD9/WYBH37JmnzN+DlrbUyVHl2AoxbIDekC17JTr rtCiqoTGTX927hJ5zMIpjEQ+yD3ph2w= From: Paul Cercueil To: Daniel Vetter , David Airlie Cc: od@zcrc.me, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, Paul Cercueil Subject: [PATCH v2 1/3] gpu/drm: ingenic: Add trick to support 16bpp on 24-bit panels Date: Wed, 26 Feb 2020 01:30:39 -0300 Message-Id: <20200226043041.289764-1-paul@crapouillou.net> 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 If the panel interface is 24-bit but our primary plane is 16bpp, configure as if the panel was 18-bit. This tricks permits the display of 16bpp data on a 24-bit panel by wiring each color component to the MSBs of the 24-bit interface. v2: Check bytes-per-pixel count instead of fourcc format Signed-off-by: Paul Cercueil --- drivers/gpu/drm/ingenic/ingenic-drm.c | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/drivers/gpu/drm/ingenic/ingenic-drm.c b/drivers/gpu/drm/ingenic/ingenic-drm.c index 6d47ef7b148c..5493a80d7d2f 100644 --- a/drivers/gpu/drm/ingenic/ingenic-drm.c +++ b/drivers/gpu/drm/ingenic/ingenic-drm.c @@ -400,6 +400,8 @@ static void ingenic_drm_encoder_atomic_mode_set(struct drm_encoder *encoder, struct drm_display_mode *mode = &crtc_state->adjusted_mode; struct drm_connector *conn = conn_state->connector; struct drm_display_info *info = &conn->display_info; + struct drm_plane_state *plane_state = crtc_state->crtc->primary->state; + const struct drm_format_info *finfo = NULL; unsigned int cfg; priv->panel_is_sharp = info->bus_flags & DRM_BUS_FLAG_SHARP_SIGNALS; @@ -435,7 +437,21 @@ static void ingenic_drm_encoder_atomic_mode_set(struct drm_encoder *encoder, cfg |= JZ_LCD_CFG_MODE_GENERIC_18BIT; break; case MEDIA_BUS_FMT_RGB888_1X24: - cfg |= JZ_LCD_CFG_MODE_GENERIC_24BIT; + if (plane_state && plane_state->fb) + finfo = plane_state->fb->format; + + /* + * If the panel interface is 24-bit but our + * primary plane is 16bpp, configure as if the + * panel was 18-bit. This tricks permits the + * display of 16bpp data on a 24-bit panel by + * wiring each color component to the MSBs of + * the 24-bit interface. + */ + if (finfo && finfo->cpp[0] < 3) + cfg |= JZ_LCD_CFG_MODE_GENERIC_18BIT; + else + cfg |= JZ_LCD_CFG_MODE_GENERIC_24BIT; break; case MEDIA_BUS_FMT_RGB888_3X8: cfg |= JZ_LCD_CFG_MODE_8BIT_SERIAL; -- 2.25.0