From patchwork Fri Jan 18 14:51:10 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Paul Kocialkowski X-Patchwork-Id: 10770527 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id 7D43991E for ; Fri, 18 Jan 2019 14:52:35 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 60CF32EB57 for ; Fri, 18 Jan 2019 14:52:35 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id 4D18A2EB53; Fri, 18 Jan 2019 14:52:35 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-5.2 required=2.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,MAILING_LIST_MULTI,RCVD_IN_DNSWL_MED autolearn=ham version=3.3.1 Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.wl.linuxfoundation.org (Postfix) with ESMTPS id C7D822EAFB for ; Fri, 18 Jan 2019 14:52:34 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender: Content-Transfer-Encoding:Content-Type:Cc:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:MIME-Version:Message-Id:Date:Subject:To :From:Reply-To:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To:References: List-Owner; bh=Gd+7JfXmEBKHekvJlJYJR03XVVHBrFNRFbHd1NhCelc=; b=PzFanaDQ+eL1sp NayqodZP/q6B7HBlwwGOa3QFELj/JkOEcznn2zpDoo1kIvBxgSdqaIU0TZPIPHAShrAs3wvsUZk/G 8yTlGR1m7jj0D4Nr7ZzKMAPrFygJW6d+IiPwpMc6yaoD+jYC15BAqi5ZwT9nsZ1c5okJr0VTovK/3 WPv+W2r6pMs+xQBftmMDHWtaj02SLpbRiRbTv4gj7owW5wz8eXJ5jdtO71MjxFn2ANxdi3ilzfUkW nZYTdwVbwiXoWBxYbmPJ+vOAEBqYpaZbhB07QJFhMo5RbnSb00QDSyUtqK2Eb5Ee2vMeUT5ApNHSD 0CfJDk3Z/AdHL39HNZFA==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.90_1 #2 (Red Hat Linux)) id 1gkVVW-0007jS-Qt; Fri, 18 Jan 2019 14:52:30 +0000 Received: from mail.bootlin.com ([62.4.15.54]) by bombadil.infradead.org with esmtp (Exim 4.90_1 #2 (Red Hat Linux)) id 1gkVUk-0006nS-I9 for linux-arm-kernel@lists.infradead.org; Fri, 18 Jan 2019 14:51:51 +0000 Received: by mail.bootlin.com (Postfix, from userid 110) id 2DBD8207B0; Fri, 18 Jan 2019 15:51:41 +0100 (CET) Received: from localhost.localdomain (aaubervilliers-681-1-37-87.w90-88.abo.wanadoo.fr [90.88.156.87]) by mail.bootlin.com (Postfix) with ESMTPSA id CF326207B0; Fri, 18 Jan 2019 15:51:40 +0100 (CET) From: Paul Kocialkowski To: dri-devel@lists.freedesktop.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-sunxi@googlegroups.com Subject: [PATCH RESEND v5 00/23] drm/sun4i: Support for linear and tiled YUV formats with the frontend Date: Fri, 18 Jan 2019 15:51:10 +0100 Message-Id: <20190118145133.21281-1-paul.kocialkowski@bootlin.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20190118_065143_759074_A02A67BD X-CRM114-Status: GOOD ( 11.48 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Thomas Petazzoni , Maxime Ripard , Maarten Lankhorst , Paul Kocialkowski , David Airlie , Chen-Yu Tsai , Daniel Vetter , Sean Paul Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+patchwork-linux-arm=patchwork.kernel.org@lists.infradead.org X-Virus-Scanned: ClamAV using ClamSMTP This series implements support for YUV formats using the display engine frontend in the sun4i DRM driver, with various fixes along the way. Scaling is supported for every format handled by the frontend. The tiling mode used by the VPU on Allwinner platforms is also supported by this series and a dedicated fourcc modifier is introduced, along with a specific ioctl for allocating tiled buffers. New common fourcc helpers are also introduced in this series, especially related to YUV formats. This was tested on the A33, A20 and A10 platforms and all supported features work properly on them. Framebuffer offsets and source positions are not supported at this point. Changes in v5 resend: * Added collected Acked-by tags. Changes since v4: * Added support for the A10 SoC; * Rebased on latest drm-misc and removed merged patches. Changes since v3: * Made the BT.601 CSC coefficients common; * Moved the tiling mode comment next to the associated macro; * Added collected Acked-by tags. Changes since v2: * Removed DRM format helpers taking the format fourcc; * Passed the DRM format info structure when needed instead of iterating through the list; * Removed the sun4i-specific ioctl for allocating tiled buffers, which will be rebranded as a generic one in an upcoming patch; * Improved comment for X1 tiled offset and simplified its calculation; * Corrected author email and added SoB where needed; * Rebased on latest drm-misc next. Changes since v1: * Extended source selected cleanup to both YUV and video channels; * Split and reworded comment about backend scaling; * Sorted newly-introduced lists alphabetically; * Simplified functions to check if a format is supported; * Reworked frontend selection logic as discussed; * Made YUV helpers common, with fourcc and drm_info fashions; * Changed the CREATE_TILED ioctl flags to match the CREATE_DUMB ioctl; * Reworked YUV dimensions calculations to use drm_format_info; * Dropped MB32 part in modifier to match V4L2 definition name; * Improved the description of the tiling modifier; * Avoided splitting CSC coefficients to avoid introducing a new module; * Fixed building the driver as modules; * Various code simplifications and cleanups; * Split commits into logical changes. Maxime Ripard (5): drm/sun4i: Move access control before setting the register as documented drm/sun4i: frontend: Add a quirk structure drm/sun4i: Set the coef_rdy bit right after the coef have been set drm/sun4i: Make COEF_RDY conditional drm/sun4i: frontend: Move the FIR filter phases to our quirks Paul Kocialkowski (18): drm/fourcc: Add format info helpers for checking YUV planes disposition drm/fourcc: Add format info helpers for checking YUV sub-sampling drm/sun4i: backend: Use explicit fourcc helpers for packed YUV422 check drm/sun4i: frontend: Pass DRM format info to input format helpers drm/sun4i: frontend: Determine input format based on colorspace drm/sun4i: Move the BT.601 CSC coefficients to the frontend drm/sun4i: frontend: Configure and enable YUV to RGB CSC when needed drm/sun4i: frontend: Add support for packed YUV422 input formats drm/sun4i: frontend: Add support for semi-planar YUV input formats drm/sun4i: frontend: Add support for planar YUV input formats drm/fourcc: Add definitions for Allwinner vendor and VPU tiled format drm/sun4i: frontend: Add support for tiled YUV input mode configuration drm/sun4i: Add buffer stride and offset configuration for tiling mode drm/sun4i: frontend: Add and use helper for checking tiling support drm/sun4i: layer: Add tiled modifier support and helper drm/sun4i: drv: Allow framebuffer modifiers in mode config drm/sun4i: frontend: Hook-in support for the A10, with specific quirks drm/sun4i: frontend: Hook-in support for the A20 drivers/gpu/drm/sun4i/sun4i_backend.c | 25 +- drivers/gpu/drm/sun4i/sun4i_drv.c | 1 + drivers/gpu/drm/sun4i/sun4i_frontend.c | 350 ++++++++++++++++++++++--- drivers/gpu/drm/sun4i/sun4i_frontend.h | 52 ++++ drivers/gpu/drm/sun4i/sun4i_layer.c | 28 +- include/drm/drm_fourcc.h | 117 +++++++++ include/uapi/drm/drm_fourcc.h | 16 ++ 7 files changed, 534 insertions(+), 55 deletions(-)