From: Neil Armstrong <narmstrong@baylibre.com>
To: daniel@ffwll.ch, dri-devel@lists.freedesktop.org
Cc: ppaalanen@gmail.com, mjourdan@baylibre.com,
brian.starkey@arm.com, Neil Armstrong <narmstrong@baylibre.com>,
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 [thread overview]
Message-ID: <20200325085025.30631-1-narmstrong@baylibre.com> (raw)
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
WARNING: multiple messages have this Message-ID (diff)
From: Neil Armstrong <narmstrong@baylibre.com>
To: daniel@ffwll.ch, dri-devel@lists.freedesktop.org
Cc: mjourdan@baylibre.com, Neil Armstrong <narmstrong@baylibre.com>,
linux-kernel@vger.kernel.org, ppaalanen@gmail.com,
linux-amlogic@lists.infradead.org, brian.starkey@arm.com,
linux-arm-kernel@lists.infradead.org
Subject: [PATCH v4 0/8] drm/meson: add support for Amlogic Video FBC
Date: Wed, 25 Mar 2020 09:50:17 +0100 [thread overview]
Message-ID: <20200325085025.30631-1-narmstrong@baylibre.com> (raw)
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
_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
WARNING: multiple messages have this Message-ID (diff)
From: Neil Armstrong <narmstrong@baylibre.com>
To: daniel@ffwll.ch, dri-devel@lists.freedesktop.org
Cc: mjourdan@baylibre.com, Neil Armstrong <narmstrong@baylibre.com>,
linux-kernel@vger.kernel.org, linux-amlogic@lists.infradead.org,
linux-arm-kernel@lists.infradead.org
Subject: [PATCH v4 0/8] drm/meson: add support for Amlogic Video FBC
Date: Wed, 25 Mar 2020 09:50:17 +0100 [thread overview]
Message-ID: <20200325085025.30631-1-narmstrong@baylibre.com> (raw)
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
_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel
WARNING: multiple messages have this Message-ID (diff)
From: Neil Armstrong <narmstrong@baylibre.com>
To: daniel@ffwll.ch, dri-devel@lists.freedesktop.org
Cc: mjourdan@baylibre.com, Neil Armstrong <narmstrong@baylibre.com>,
linux-kernel@vger.kernel.org, ppaalanen@gmail.com,
linux-amlogic@lists.infradead.org, brian.starkey@arm.com,
linux-arm-kernel@lists.infradead.org
Subject: [PATCH v4 0/8] drm/meson: add support for Amlogic Video FBC
Date: Wed, 25 Mar 2020 09:50:17 +0100 [thread overview]
Message-ID: <20200325085025.30631-1-narmstrong@baylibre.com> (raw)
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
_______________________________________________
linux-amlogic mailing list
linux-amlogic@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-amlogic
next reply other threads:[~2020-03-25 8:50 UTC|newest]
Thread overview: 64+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-03-25 8:50 Neil Armstrong [this message]
2020-03-25 8:50 ` [PATCH v4 0/8] drm/meson: add support for Amlogic Video FBC Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` [PATCH v4 1/8] drm/fourcc: Add modifier definitions for describing Amlogic Video Framebuffer Compression Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` [PATCH v4 2/8] drm/meson: add Amlogic Video FBC registers Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` [PATCH v4 3/8] drm/meson: overlay: setup overlay for Amlogic FBC Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` [PATCH v4 4/8] drm/meson: crtc: handle commit of Amlogic FBC frames Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` [PATCH v4 5/8] drm/fourcc: amlogic: Add modifier definitions for Memory Saving option Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` [PATCH v4 6/8] drm/meson: overlay: setup overlay for Amlogic FBC Memory Saving mode Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` [PATCH v4 7/8] drm/fourcc: amlogic: Add modifier definitions for the Scatter layout Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 9:04 ` Simon Ser
2020-03-25 9:04 ` Simon Ser
2020-03-25 9:04 ` Simon Ser
2020-03-25 9:04 ` Simon Ser
2020-03-25 10:24 ` Neil Armstrong
2020-03-25 10:24 ` Neil Armstrong
2020-03-25 10:24 ` Neil Armstrong
2020-03-25 10:24 ` Neil Armstrong
2020-03-25 13:49 ` Pekka Paalanen
2020-03-25 13:49 ` Pekka Paalanen
2020-03-25 13:49 ` Pekka Paalanen
2020-03-25 13:49 ` Pekka Paalanen
2020-03-25 16:18 ` Neil Armstrong
2020-03-25 16:18 ` Neil Armstrong
2020-03-25 16:18 ` Neil Armstrong
2020-03-25 16:18 ` Neil Armstrong
2020-03-26 9:36 ` Pekka Paalanen
2020-03-26 9:36 ` Pekka Paalanen
2020-03-26 9:36 ` Pekka Paalanen
2020-03-26 9:36 ` Pekka Paalanen
2020-03-27 14:14 ` Neil Armstrong
2020-03-27 14:14 ` Neil Armstrong
2020-03-27 14:14 ` Neil Armstrong
2020-03-27 14:14 ` Neil Armstrong
2020-03-30 14:41 ` Pekka Paalanen
2020-03-30 14:41 ` Pekka Paalanen
2020-03-30 14:41 ` Pekka Paalanen
2020-03-30 14:41 ` Pekka Paalanen
2020-03-25 8:50 ` [PATCH v4 8/8] drm/meson: overlay: setup overlay for Amlogic FBC Scatter Memory layout Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
2020-03-25 8:50 ` Neil Armstrong
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20200325085025.30631-1-narmstrong@baylibre.com \
--to=narmstrong@baylibre.com \
--cc=brian.starkey@arm.com \
--cc=daniel@ffwll.ch \
--cc=dri-devel@lists.freedesktop.org \
--cc=linux-amlogic@lists.infradead.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mjourdan@baylibre.com \
--cc=ppaalanen@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.