Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp396279ybb; Wed, 25 Mar 2020 01:51:03 -0700 (PDT) X-Google-Smtp-Source: ADFU+vtqznkSo8oHREQcKMXqOFFNDDsg9zt+UvZPxSRl/KYbg5bYG7OaaSo5f/yKcerfSyF5X88H X-Received: by 2002:aca:4e08:: with SMTP id c8mr1719531oib.143.1585126263629; Wed, 25 Mar 2020 01:51:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585126263; cv=none; d=google.com; s=arc-20160816; b=mvB3/ces10afIwPs+L1jki4LiPZA7ag2b1jQOx52MQfYwl6qf/k3gEpdAFWaGWFmpU a+0eL6x8mLEqxodkTUlg7y5SQVD0kSwf8oOlBCwtSSPnaqmfKE01SlIs0oZFthdStaQs bnLJO/gw6+4aHG+123ZTXJfVsORuZd/x9oEcfanH5QTxRNTGVnyOXa7y/aaSy44x0quG GGgZxrghDR8TaL9ng/cw73NySC5ORp748XjUClKxS9Q2dmBxxHMr+xwupdGzH/46W/zY o/20/dErj1/qwrVJNh65HlV0H0nd36n6+4D7Nlt8Z4zb/9tFLjvUHBXq+grlE8IB9zr5 exHQ== 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=WoXHfuXYzc7+p6uA7OR0OLG4JPoyNaGh9u2qRQoG7QA=; b=eTzX+ZJO2BxKPr2D6noxn1/v9imYdfRS/h33lYtKlBdgWu+qTyhu2iEV3W+FTE/fGI YvavyD8/axfCF3F2/9IlB9vSGRVKIzFo4/MnRYaEzZ9JnyzJN7VDeyAdDuMlAcjVjfeK qg9OhiNkWFxb2gnUpnedW5snZd4oo3lCXdhPshWthSNT5D42RQ59UlnF2wyVY0PIf+Rr 2gG1QJTZs9UWuK7jqFMCU9E+wh6kZS76PECYGnp0kIKnkMgLyhhfeZG1mf9yPnJHW73/ 9y2C7YKGa7WG4DWSbxX7Gi7+8VE7f8ok9TAa1s5J9uzBuRjnUUjgLSWNv3yLLhN9O4GL HkCA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=klP7C+Qx; 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 d20si10437561oti.311.2020.03.25.01.50.49; Wed, 25 Mar 2020 01:51:03 -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=klP7C+Qx; 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 S1727458AbgCYIud (ORCPT + 99 others); Wed, 25 Mar 2020 04:50:33 -0400 Received: from mail-wr1-f66.google.com ([209.85.221.66]:45414 "EHLO mail-wr1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727281AbgCYIuc (ORCPT ); Wed, 25 Mar 2020 04:50:32 -0400 Received: by mail-wr1-f66.google.com with SMTP id t7so1751386wrw.12 for ; Wed, 25 Mar 2020 01:50:29 -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=WoXHfuXYzc7+p6uA7OR0OLG4JPoyNaGh9u2qRQoG7QA=; b=klP7C+QxkpkwvekqXQb/Ju4yyTjbf+2WirsTFD+RvppuVSgw8RLF4oDkiJV5Vk4lMd xqXSWWCekWRsLvvY6YJd8ek781hrgVRUnrwPML6G++2ZxVBfd7aiFZY/dnxdJCZ1Alz/ C3xF4AHS7bnfY5t5mSinwvd8ZGuwTBNPL142jGG5FwxBD6S0Mj0AhGVekurjgwDehbwx wTAti/zk4YsU/j2wJHyfzaT8sKWSpFa4nF0dUBGhV5rwRSVH34qF7ROPfO/SZrYiB+Wj SpjhV6zueQA3Spsi+OJoE82nK0zOOYF9+7m+1eEFFf6hIXTT0bQHCmzUzl3wcxdSVZEm rQtA== 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=WoXHfuXYzc7+p6uA7OR0OLG4JPoyNaGh9u2qRQoG7QA=; b=hg7B1KeftRV1ugCWONkD+SrCbwuwod+IkrQYyjY3QfaqMwK5zSds59zduCTvkyL0LH Iq1LnxiQpf7/jCDtfiPiQ1xlqsUwa0z2s50yqeFfp7s5CC6io/OzevMYWvXYxoEcQ/Jf i2aIcqps6/eQKlrHw0kLxAqaKZ27XNEt6kj2ECisyZxWxpmIgd3smVS/P3GKpcHEhHTV EnH0zlKzJvVPsNPeDmpn2SS17fwbrW4ucAlOIAZlI/lWUmjeyhFv906gBlU5xe8u5vBB BKw1ROnSWU+WGhL2Oyes/sR5q55ZWnFDfoTKeNPYx+8FOq2xg4txN87WUMB6MNzInpHv A86w== X-Gm-Message-State: ANhLgQ3Lg3P+kH8zOJcu7Se+o3IfHqXyA9h02TgP7HHkodTqiG9bPDyY 58IFfCt/ZIBUT6trr9WtctsLEg== X-Received: by 2002:a5d:630e:: with SMTP id i14mr2218077wru.260.1585126229049; Wed, 25 Mar 2020 01:50:29 -0700 (PDT) Received: from bender.baylibre.local ([2a01:e35:2ec0:82b0:5c5f:613e:f775:b6a2]) by smtp.gmail.com with ESMTPSA id o16sm33892229wrs.44.2020.03.25.01.50.27 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 25 Mar 2020 01:50:28 -0700 (PDT) From: Neil Armstrong To: daniel@ffwll.ch, dri-devel@lists.freedesktop.org Cc: ppaalanen@gmail.com, mjourdan@baylibre.com, brian.starkey@arm.com, Neil Armstrong , linux-amlogic@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH v4 0/8] drm/meson: add support for Amlogic Video FBC Date: Wed, 25 Mar 2020 09:50:17 +0100 Message-Id: <20200325085025.30631-1-narmstrong@baylibre.com> X-Mailer: git-send-email 2.22.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 Amlogic uses a proprietary lossless image compression protocol and format for their hardware video codec accelerators, either video decoders or video input encoders. It considerably reduces memory bandwidth while writing and reading frames in memory. The underlying storage is considered to be 3 components, 8bit or 10-bit per component, YCbCr 420, single plane : - DRM_FORMAT_YUV420_8BIT - DRM_FORMAT_YUV420_10BIT This modifier will be notably added to DMA-BUF frames imported from the V4L2 Amlogic VDEC decoder. At least two layout are supported : - Basic: composed of a body and a header - Scatter: the buffer is filled with a IOMMU scatter table referring to the encoder current memory layout. This mode if more efficient in terms of memory allocation but frames are not dumpable and only valid during until the buffer is freed and back in control of the encoder At least two options are supported : - Memory saving: when the pixel bpp is 8b, the size of the superblock can be reduced, thus saving memory. This serie adds the missing register, updated the FBC decoder registers content to be committed by the crtc code. The Amlogic FBC has been tested with compressed content from the Amlogic HW VP9 decoder on S905X (GXL), S905D2 (G12A) and S905X3 (SM1) in 8bit (Scatter+Mem Saving on G12A/SM1, Mem Saving on GXL) and 10bit (Scatter on G12A/SM1, default on GXL). It's expected to work as-is on GXM and G12B SoCs. Changes since v3 at [3]: - added dropped fourcc patch for scatter - fixed build of last patch Changes since v2 at [2]: - Added "BASIC" layout and moved the SCATTER mode as layout, making BASIC and SCATTER layout exclusives - Moved the Memory Saving at bit 8 for options fields - Split fourcc and overlay patch to introduce basic, mem saving and then scatter in separate patches - Added comment about "transferability" of the buffers Changes since v1 at [1]: - s/VD1_AXI_SEL_AFB/VD1_AXI_SEL_AFBC/ into meson_registers.h [1] https://patchwork.freedesktop.org/series/73722/#rev1 [2] https://patchwork.freedesktop.org/series/73722/#rev2 Neil Armstrong (8): drm/fourcc: Add modifier definitions for describing Amlogic Video Framebuffer Compression drm/meson: add Amlogic Video FBC registers drm/meson: overlay: setup overlay for Amlogic FBC drm/meson: crtc: handle commit of Amlogic FBC frames drm/fourcc: amlogic: Add modifier definitions for Memory Saving option drm/meson: overlay: setup overlay for Amlogic FBC Memory Saving mode drm/fourcc: amlogic: Add modifier definitions for the Scatter layout drm/meson: overlay: setup overlay for Amlogic FBC Scatter Memory layout drivers/gpu/drm/meson/meson_crtc.c | 118 ++++++++--- drivers/gpu/drm/meson/meson_drv.h | 16 ++ drivers/gpu/drm/meson/meson_overlay.c | 257 +++++++++++++++++++++++- drivers/gpu/drm/meson/meson_registers.h | 22 ++ include/uapi/drm/drm_fourcc.h | 66 ++++++ 5 files changed, 441 insertions(+), 38 deletions(-) -- 2.22.0