Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3377862yba; Mon, 29 Apr 2019 00:53:53 -0700 (PDT) X-Google-Smtp-Source: APXvYqxBebMLLmLk4g7A4n3zct7fHca7eIfRe7yCocHLZAP4OP9oa5AstDFPM6AkkW791N4X8j8u X-Received: by 2002:a63:295:: with SMTP id 143mr415103pgc.279.1556524432932; Mon, 29 Apr 2019 00:53:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556524432; cv=none; d=google.com; s=arc-20160816; b=k1lm41jvLHw8VsSjKACVKc3xuLD4qcg5OcoN4QkvR6MVcOKVjFgtA9jQ5hLBDioHzk wpiYitk+pUM9q0vmLt1OrFrWirhuxZieU15xyyzc40+5htnW/aMjoA2J8jSbjQGx5uSE wVzLT2wxfYlh8Ux+dauvWCoAuaFYqvbHsQq5ZvR66ZwT+Re5kKCDSspqXmLmfPm6WN6u +XppL1Ckca1HnLLy7DsXpvHiyQ32Rwg2ujgSm0F5LwywR1gORdnbB4zK0Xl1KzYAVqca YJ39xKT/hPI2davQ15/PrA0Xtb9f+Ca4xZ+qRwgk/GiOYvOncgqYcETXTp9Wtlv6abQc yxhA== 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=/+GdzCUbXbc9TnjbK+IzgC3Rn7LJK/U+L3O1XBIq//I=; b=jYDAn+SwjMqQvMCYHo/XPB0dXm8tIPdpcLEPNzc4+g2mEisIrrubHAkRuSZBmHYzM8 sElUdwc0f8vObs5vUNo76elZZ6AwZep75a++wHOJu2ixm76zx4PYfEAiA3s4JJlL+Qte hPxMbsirmGpy9WZUzvtf+fsrNyWfhU8eBUcilOMwnKmX7gaea8BJyHXEPgrYiUxlDt+J O/2WOvx8QdUdQz+KB52PqyJVVn6B49zmNkfHy0j42UOY9dEUEp+n1VM9akCYDGdVYZCf NgfLFPFCmSwt9XHGEDoElNeSAD6WQULnDjnKBtY+bXdrxfMVJQ2vqdak+J+6nYDoLMUs Fphg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=E8jD+2dg; 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 r80si33543912pfa.128.2019.04.29.00.53.36; Mon, 29 Apr 2019 00:53:52 -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=E8jD+2dg; 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 S1727526AbfD2Hwm (ORCPT + 99 others); Mon, 29 Apr 2019 03:52:42 -0400 Received: from mail-wm1-f67.google.com ([209.85.128.67]:55250 "EHLO mail-wm1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726718AbfD2Hwm (ORCPT ); Mon, 29 Apr 2019 03:52:42 -0400 Received: by mail-wm1-f67.google.com with SMTP id c1so949353wml.4 for ; Mon, 29 Apr 2019 00:52:41 -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:mime-version :content-transfer-encoding; bh=/+GdzCUbXbc9TnjbK+IzgC3Rn7LJK/U+L3O1XBIq//I=; b=E8jD+2dgpZNlzi2mli6iSqHgtX8ej4k2fD+p50X7E9LOuOgNBJ8gjAiK/IBRlJ+3OM /ezhla4lzKCiT7PZUIbPtAXYRSXzCpZOCkroWKcKrh8BWQv4R5GbvbhvcB1fx7/d8FSy G4CAF6FAJedyge2rIG6AwicnNEPM8G73yQvzHGrBoS+jwiRcXIKSh6VbwpVAZ0l4VTNI wok7bVcf5eQrVfmQTxDMGjxS30rWsNi12GwMpYTMAgbocRh2CqzeZWkF+rgUFVyywy24 Im77RGr1kKsu0YTlS+T2nujXKe01K7Q05lij2Nt6vydzWaZfM69r7GVKjGUj5UymDHbh +GdQ== 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:mime-version :content-transfer-encoding; bh=/+GdzCUbXbc9TnjbK+IzgC3Rn7LJK/U+L3O1XBIq//I=; b=EUWXQIsiz4Ti0IkSH8OfjocEX4TQv/53F6wYhBoH43i5RXJLfvFszQNZjhtWnu4O9I NtKgor6rFVPoKYw2M7WgDuNtpdLJfAmlcGuGLZ1MrblK+qykxT3AihoFL5PRTZAAoXaJ Pgf1eeWSRM5/Vez9JFtZge9tjD5/AcTyY5sdUT7K/AhNSideTp4ZfXzwlnxD9HkjOmZj CelLrFaYpBKusO81cjTn3TIesorp2hUU10Rv+i83DmQrcFKKith4WQMfJZcJaYIhKxE2 USEeza9DCpgoMAli+7bYAa4SQjuWfXtXmngqhkSKFGF1ZnoebSOkSQILcUOYnR8RPXVM 93aw== X-Gm-Message-State: APjAAAXzbNWhr6H5jbS5+ebabhWG+NNUGdRqbBhK5nIYOfu5EQZ9reCn NUwthe4Uox66pHxPkMr2cJqipA== X-Received: by 2002:a1c:495:: with SMTP id 143mr8270669wme.109.1556524360393; Mon, 29 Apr 2019 00:52:40 -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 q4sm5118457wrg.24.2019.04.29.00.52.39 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Mon, 29 Apr 2019 00:52:39 -0700 (PDT) From: Neil Armstrong To: dri-devel@lists.freedesktop.org Cc: Neil Armstrong , linux-amlogic@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH] drm/meson: Add support for XBGR8888 & ABGR8888 formats Date: Mon, 29 Apr 2019 09:52:38 +0200 Message-Id: <20190429075238.7884-1-narmstrong@baylibre.com> X-Mailer: git-send-email 2.21.0 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 Add missing XBGR8888 & ABGR8888 formats variants from the primary plane. Fixes: bbbe775ec5b5 ("drm: Add support for Amlogic Meson Graphic Controller") Signed-off-by: Neil Armstrong --- drivers/gpu/drm/meson/meson_plane.c | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/drivers/gpu/drm/meson/meson_plane.c b/drivers/gpu/drm/meson/meson_plane.c index bf8f1fab63aa..b8f6b08a89a6 100644 --- a/drivers/gpu/drm/meson/meson_plane.c +++ b/drivers/gpu/drm/meson/meson_plane.c @@ -165,6 +165,13 @@ static void meson_plane_atomic_update(struct drm_plane *plane, priv->viu.osd1_blk0_cfg[0] |= OSD_BLK_MODE_32 | OSD_COLOR_MATRIX_32_ARGB; break; + case DRM_FORMAT_XBGR8888: + /* For XRGB, replace the pixel's alpha by 0xFF */ + writel_bits_relaxed(OSD_REPLACE_EN, OSD_REPLACE_EN, + priv->io_base + _REG(VIU_OSD1_CTRL_STAT2)); + priv->viu.osd1_blk0_cfg[0] |= OSD_BLK_MODE_32 | + OSD_COLOR_MATRIX_32_ABGR; + break; case DRM_FORMAT_ARGB8888: /* For ARGB, use the pixel's alpha */ writel_bits_relaxed(OSD_REPLACE_EN, 0, @@ -172,6 +179,13 @@ static void meson_plane_atomic_update(struct drm_plane *plane, priv->viu.osd1_blk0_cfg[0] |= OSD_BLK_MODE_32 | OSD_COLOR_MATRIX_32_ARGB; break; + case DRM_FORMAT_ABGR8888: + /* For ARGB, use the pixel's alpha */ + writel_bits_relaxed(OSD_REPLACE_EN, 0, + priv->io_base + _REG(VIU_OSD1_CTRL_STAT2)); + priv->viu.osd1_blk0_cfg[0] |= OSD_BLK_MODE_32 | + OSD_COLOR_MATRIX_32_ABGR; + break; case DRM_FORMAT_RGB888: priv->viu.osd1_blk0_cfg[0] |= OSD_BLK_MODE_24 | OSD_COLOR_MATRIX_24_RGB; @@ -356,7 +370,9 @@ static const struct drm_plane_funcs meson_plane_funcs = { static const uint32_t supported_drm_formats[] = { DRM_FORMAT_ARGB8888, + DRM_FORMAT_ABGR8888, DRM_FORMAT_XRGB8888, + DRM_FORMAT_XBGR8888, DRM_FORMAT_RGB888, DRM_FORMAT_RGB565, }; -- 2.21.0