1211 lines
48 KiB
Diff
1211 lines
48 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Ezequiel Garcia <ezequiel@collabora.com>
|
|
Date: Mon, 19 Jul 2021 22:52:34 +0200
|
|
Subject: [PATCH] media: hantro: Make struct hantro_variant.init() optional
|
|
|
|
The hantro_variant.init() function is there for platforms
|
|
to perform hardware-specific initialization, such as
|
|
clock rate bumping.
|
|
|
|
Not all platforms require it, so make it optional.
|
|
|
|
Signed-off-by: Ezequiel Garcia <ezequiel@collabora.com>
|
|
Tested-by: Alex Bee <knaerzche@gmail.com>
|
|
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
|
|
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
|
|
---
|
|
drivers/staging/media/hantro/hantro.h | 4 ++--
|
|
drivers/staging/media/hantro/hantro_drv.c | 10 ++++++----
|
|
drivers/staging/media/hantro/sama5d4_vdec_hw.c | 6 ------
|
|
3 files changed, 8 insertions(+), 12 deletions(-)
|
|
|
|
diff --git a/drivers/staging/media/hantro/hantro.h b/drivers/staging/media/hantro/hantro.h
|
|
index a70c386de6f1..c2e2dca38628 100644
|
|
--- a/drivers/staging/media/hantro/hantro.h
|
|
+++ b/drivers/staging/media/hantro/hantro.h
|
|
@@ -61,8 +61,8 @@ struct hantro_irq {
|
|
* @num_postproc_fmts: Number of post-processor formats.
|
|
* @codec: Supported codecs
|
|
* @codec_ops: Codec ops.
|
|
- * @init: Initialize hardware.
|
|
- * @runtime_resume: reenable hardware after power gating
|
|
+ * @init: Initialize hardware, optional.
|
|
+ * @runtime_resume: reenable hardware after power gating, optional.
|
|
* @irqs: array of irq names and interrupt handlers
|
|
* @num_irqs: number of irqs in the array
|
|
* @clk_names: array of clock names
|
|
diff --git a/drivers/staging/media/hantro/hantro_drv.c b/drivers/staging/media/hantro/hantro_drv.c
|
|
index 31d8449ca1d2..9b5415176bfe 100644
|
|
--- a/drivers/staging/media/hantro/hantro_drv.c
|
|
+++ b/drivers/staging/media/hantro/hantro_drv.c
|
|
@@ -942,10 +942,12 @@ static int hantro_probe(struct platform_device *pdev)
|
|
}
|
|
}
|
|
|
|
- ret = vpu->variant->init(vpu);
|
|
- if (ret) {
|
|
- dev_err(&pdev->dev, "Failed to init VPU hardware\n");
|
|
- return ret;
|
|
+ if (vpu->variant->init) {
|
|
+ ret = vpu->variant->init(vpu);
|
|
+ if (ret) {
|
|
+ dev_err(&pdev->dev, "Failed to init VPU hardware\n");
|
|
+ return ret;
|
|
+ }
|
|
}
|
|
|
|
pm_runtime_set_autosuspend_delay(vpu->dev, 100);
|
|
diff --git a/drivers/staging/media/hantro/sama5d4_vdec_hw.c b/drivers/staging/media/hantro/sama5d4_vdec_hw.c
|
|
index 58ae72c2b723..9c3b8cd0b239 100644
|
|
--- a/drivers/staging/media/hantro/sama5d4_vdec_hw.c
|
|
+++ b/drivers/staging/media/hantro/sama5d4_vdec_hw.c
|
|
@@ -64,11 +64,6 @@ static const struct hantro_fmt sama5d4_vdec_fmts[] = {
|
|
},
|
|
};
|
|
|
|
-static int sama5d4_hw_init(struct hantro_dev *vpu)
|
|
-{
|
|
- return 0;
|
|
-}
|
|
-
|
|
/*
|
|
* Supported codec ops.
|
|
*/
|
|
@@ -109,7 +104,6 @@ const struct hantro_variant sama5d4_vdec_variant = {
|
|
.codec = HANTRO_MPEG2_DECODER | HANTRO_VP8_DECODER |
|
|
HANTRO_H264_DECODER,
|
|
.codec_ops = sama5d4_vdec_codec_ops,
|
|
- .init = sama5d4_hw_init,
|
|
.irqs = sama5d4_irqs,
|
|
.num_irqs = ARRAY_SIZE(sama5d4_irqs),
|
|
.clk_names = sama5d4_clk_names,
|
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Ezequiel Garcia <ezequiel@collabora.com>
|
|
Date: Mon, 19 Jul 2021 22:52:35 +0200
|
|
Subject: [PATCH] media: hantro: Avoid redundant hantro_get_{dst,src}_buf()
|
|
calls
|
|
|
|
Getting the next src/dst buffer is relatively expensive
|
|
so avoid doing it multiple times.
|
|
|
|
Signed-off-by: Ezequiel Garcia <ezequiel@collabora.com>
|
|
Tested-by: Alex Bee <knaerzche@gmail.com>
|
|
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
|
|
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
|
|
---
|
|
.../staging/media/hantro/hantro_g1_h264_dec.c | 17 ++++++++---------
|
|
.../staging/media/hantro/hantro_g1_vp8_dec.c | 18 +++++++++---------
|
|
.../media/hantro/rockchip_vpu2_hw_vp8_dec.c | 19 +++++++++----------
|
|
3 files changed, 26 insertions(+), 28 deletions(-)
|
|
|
|
diff --git a/drivers/staging/media/hantro/hantro_g1_h264_dec.c b/drivers/staging/media/hantro/hantro_g1_h264_dec.c
|
|
index 5c792b7bcb79..2aa37baad0c3 100644
|
|
--- a/drivers/staging/media/hantro/hantro_g1_h264_dec.c
|
|
+++ b/drivers/staging/media/hantro/hantro_g1_h264_dec.c
|
|
@@ -19,13 +19,12 @@
|
|
#include "hantro_hw.h"
|
|
#include "hantro_v4l2.h"
|
|
|
|
-static void set_params(struct hantro_ctx *ctx)
|
|
+static void set_params(struct hantro_ctx *ctx, struct vb2_v4l2_buffer *src_buf)
|
|
{
|
|
const struct hantro_h264_dec_ctrls *ctrls = &ctx->h264_dec.ctrls;
|
|
const struct v4l2_ctrl_h264_decode_params *dec_param = ctrls->decode;
|
|
const struct v4l2_ctrl_h264_sps *sps = ctrls->sps;
|
|
const struct v4l2_ctrl_h264_pps *pps = ctrls->pps;
|
|
- struct vb2_v4l2_buffer *src_buf = hantro_get_src_buf(ctx);
|
|
struct hantro_dev *vpu = ctx->dev;
|
|
u32 reg;
|
|
|
|
@@ -226,22 +225,20 @@ static void set_ref(struct hantro_ctx *ctx)
|
|
}
|
|
}
|
|
|
|
-static void set_buffers(struct hantro_ctx *ctx)
|
|
+static void set_buffers(struct hantro_ctx *ctx, struct vb2_v4l2_buffer *src_buf)
|
|
{
|
|
const struct hantro_h264_dec_ctrls *ctrls = &ctx->h264_dec.ctrls;
|
|
- struct vb2_v4l2_buffer *src_buf, *dst_buf;
|
|
+ struct vb2_v4l2_buffer *dst_buf;
|
|
struct hantro_dev *vpu = ctx->dev;
|
|
dma_addr_t src_dma, dst_dma;
|
|
size_t offset = 0;
|
|
|
|
- src_buf = hantro_get_src_buf(ctx);
|
|
- dst_buf = hantro_get_dst_buf(ctx);
|
|
-
|
|
/* Source (stream) buffer. */
|
|
src_dma = vb2_dma_contig_plane_dma_addr(&src_buf->vb2_buf, 0);
|
|
vdpu_write_relaxed(vpu, src_dma, G1_REG_ADDR_STR);
|
|
|
|
/* Destination (decoded frame) buffer. */
|
|
+ dst_buf = hantro_get_dst_buf(ctx);
|
|
dst_dma = hantro_get_dec_buf_addr(ctx, &dst_buf->vb2_buf);
|
|
/* Adjust dma addr to start at second line for bottom field */
|
|
if (ctrls->decode->flags & V4L2_H264_DECODE_PARAM_FLAG_BOTTOM_FIELD)
|
|
@@ -276,6 +273,7 @@ static void set_buffers(struct hantro_ctx *ctx)
|
|
int hantro_g1_h264_dec_run(struct hantro_ctx *ctx)
|
|
{
|
|
struct hantro_dev *vpu = ctx->dev;
|
|
+ struct vb2_v4l2_buffer *src_buf;
|
|
int ret;
|
|
|
|
/* Prepare the H264 decoder context. */
|
|
@@ -284,9 +282,10 @@ int hantro_g1_h264_dec_run(struct hantro_ctx *ctx)
|
|
return ret;
|
|
|
|
/* Configure hardware registers. */
|
|
- set_params(ctx);
|
|
+ src_buf = hantro_get_src_buf(ctx);
|
|
+ set_params(ctx, src_buf);
|
|
set_ref(ctx);
|
|
- set_buffers(ctx);
|
|
+ set_buffers(ctx, src_buf);
|
|
|
|
hantro_end_prepare_run(ctx);
|
|
|
|
diff --git a/drivers/staging/media/hantro/hantro_g1_vp8_dec.c b/drivers/staging/media/hantro/hantro_g1_vp8_dec.c
|
|
index 2afd5996d75f..6180b23e7d94 100644
|
|
--- a/drivers/staging/media/hantro/hantro_g1_vp8_dec.c
|
|
+++ b/drivers/staging/media/hantro/hantro_g1_vp8_dec.c
|
|
@@ -367,13 +367,12 @@ static void cfg_tap(struct hantro_ctx *ctx,
|
|
}
|
|
|
|
static void cfg_ref(struct hantro_ctx *ctx,
|
|
- const struct v4l2_ctrl_vp8_frame *hdr)
|
|
+ const struct v4l2_ctrl_vp8_frame *hdr,
|
|
+ struct vb2_v4l2_buffer *vb2_dst)
|
|
{
|
|
struct hantro_dev *vpu = ctx->dev;
|
|
- struct vb2_v4l2_buffer *vb2_dst;
|
|
dma_addr_t ref;
|
|
|
|
- vb2_dst = hantro_get_dst_buf(ctx);
|
|
|
|
ref = hantro_get_ref(ctx, hdr->last_frame_ts);
|
|
if (!ref) {
|
|
@@ -405,16 +404,14 @@ static void cfg_ref(struct hantro_ctx *ctx,
|
|
}
|
|
|
|
static void cfg_buffers(struct hantro_ctx *ctx,
|
|
- const struct v4l2_ctrl_vp8_frame *hdr)
|
|
+ const struct v4l2_ctrl_vp8_frame *hdr,
|
|
+ struct vb2_v4l2_buffer *vb2_dst)
|
|
{
|
|
const struct v4l2_vp8_segment *seg = &hdr->segment;
|
|
struct hantro_dev *vpu = ctx->dev;
|
|
- struct vb2_v4l2_buffer *vb2_dst;
|
|
dma_addr_t dst_dma;
|
|
u32 reg;
|
|
|
|
- vb2_dst = hantro_get_dst_buf(ctx);
|
|
-
|
|
/* Set probability table buffer address */
|
|
vdpu_write_relaxed(vpu, ctx->vp8_dec.prob_tbl.dma,
|
|
G1_REG_ADDR_QTABLE);
|
|
@@ -436,6 +433,7 @@ int hantro_g1_vp8_dec_run(struct hantro_ctx *ctx)
|
|
{
|
|
const struct v4l2_ctrl_vp8_frame *hdr;
|
|
struct hantro_dev *vpu = ctx->dev;
|
|
+ struct vb2_v4l2_buffer *vb2_dst;
|
|
size_t height = ctx->dst_fmt.height;
|
|
size_t width = ctx->dst_fmt.width;
|
|
u32 mb_width, mb_height;
|
|
@@ -499,8 +497,10 @@ int hantro_g1_vp8_dec_run(struct hantro_ctx *ctx)
|
|
cfg_qp(ctx, hdr);
|
|
cfg_parts(ctx, hdr);
|
|
cfg_tap(ctx, hdr);
|
|
- cfg_ref(ctx, hdr);
|
|
- cfg_buffers(ctx, hdr);
|
|
+
|
|
+ vb2_dst = hantro_get_dst_buf(ctx);
|
|
+ cfg_ref(ctx, hdr, vb2_dst);
|
|
+ cfg_buffers(ctx, hdr, vb2_dst);
|
|
|
|
hantro_end_prepare_run(ctx);
|
|
|
|
diff --git a/drivers/staging/media/hantro/rockchip_vpu2_hw_vp8_dec.c b/drivers/staging/media/hantro/rockchip_vpu2_hw_vp8_dec.c
|
|
index 704607511b57..d079075448c9 100644
|
|
--- a/drivers/staging/media/hantro/rockchip_vpu2_hw_vp8_dec.c
|
|
+++ b/drivers/staging/media/hantro/rockchip_vpu2_hw_vp8_dec.c
|
|
@@ -444,14 +444,12 @@ static void cfg_tap(struct hantro_ctx *ctx,
|
|
}
|
|
|
|
static void cfg_ref(struct hantro_ctx *ctx,
|
|
- const struct v4l2_ctrl_vp8_frame *hdr)
|
|
+ const struct v4l2_ctrl_vp8_frame *hdr,
|
|
+ struct vb2_v4l2_buffer *vb2_dst)
|
|
{
|
|
struct hantro_dev *vpu = ctx->dev;
|
|
- struct vb2_v4l2_buffer *vb2_dst;
|
|
dma_addr_t ref;
|
|
|
|
- vb2_dst = hantro_get_dst_buf(ctx);
|
|
-
|
|
ref = hantro_get_ref(ctx, hdr->last_frame_ts);
|
|
if (!ref) {
|
|
vpu_debug(0, "failed to find last frame ts=%llu\n",
|
|
@@ -482,16 +480,14 @@ static void cfg_ref(struct hantro_ctx *ctx,
|
|
}
|
|
|
|
static void cfg_buffers(struct hantro_ctx *ctx,
|
|
- const struct v4l2_ctrl_vp8_frame *hdr)
|
|
+ const struct v4l2_ctrl_vp8_frame *hdr,
|
|
+ struct vb2_v4l2_buffer *vb2_dst)
|
|
{
|
|
const struct v4l2_vp8_segment *seg = &hdr->segment;
|
|
struct hantro_dev *vpu = ctx->dev;
|
|
- struct vb2_v4l2_buffer *vb2_dst;
|
|
dma_addr_t dst_dma;
|
|
u32 reg;
|
|
|
|
- vb2_dst = hantro_get_dst_buf(ctx);
|
|
-
|
|
/* Set probability table buffer address */
|
|
vdpu_write_relaxed(vpu, ctx->vp8_dec.prob_tbl.dma,
|
|
VDPU_REG_ADDR_QTABLE);
|
|
@@ -514,6 +510,7 @@ int rockchip_vpu2_vp8_dec_run(struct hantro_ctx *ctx)
|
|
{
|
|
const struct v4l2_ctrl_vp8_frame *hdr;
|
|
struct hantro_dev *vpu = ctx->dev;
|
|
+ struct vb2_v4l2_buffer *vb2_dst;
|
|
size_t height = ctx->dst_fmt.height;
|
|
size_t width = ctx->dst_fmt.width;
|
|
u32 mb_width, mb_height;
|
|
@@ -590,8 +587,10 @@ int rockchip_vpu2_vp8_dec_run(struct hantro_ctx *ctx)
|
|
cfg_qp(ctx, hdr);
|
|
cfg_parts(ctx, hdr);
|
|
cfg_tap(ctx, hdr);
|
|
- cfg_ref(ctx, hdr);
|
|
- cfg_buffers(ctx, hdr);
|
|
+
|
|
+ vb2_dst = hantro_get_dst_buf(ctx);
|
|
+ cfg_ref(ctx, hdr, vb2_dst);
|
|
+ cfg_buffers(ctx, hdr, vb2_dst);
|
|
|
|
hantro_end_prepare_run(ctx);
|
|
|
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Ezequiel Garcia <ezequiel@collabora.com>
|
|
Date: Mon, 19 Jul 2021 22:52:36 +0200
|
|
Subject: [PATCH] media: hantro: h264: Move DPB valid and long-term bitmaps
|
|
|
|
In order to reuse these bitmaps, move this process to
|
|
struct hantro_h264_dec_hw_ctx. This will be used by
|
|
the Rockchip VDPU2 H.264 driver.
|
|
|
|
This idea was originally proposed by Jonas Karlman
|
|
in "[RFC 08/12] media: hantro: Fix H264 decoding of field encoded content"
|
|
which was posted a while ago.
|
|
|
|
Link: https://lore.kernel.org/linux-media/HE1PR06MB4011EA39133818A85768B91FACBF0@HE1PR06MB4011.eurprd06.prod.outlook.com/
|
|
|
|
Signed-off-by: Ezequiel Garcia <ezequiel@collabora.com>
|
|
Tested-by: Alex Bee <knaerzche@gmail.com>
|
|
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
|
|
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
|
|
---
|
|
.../staging/media/hantro/hantro_g1_h264_dec.c | 17 ++---------------
|
|
drivers/staging/media/hantro/hantro_h264.c | 13 +++++++++++++
|
|
drivers/staging/media/hantro/hantro_hw.h | 4 ++++
|
|
3 files changed, 19 insertions(+), 15 deletions(-)
|
|
|
|
diff --git a/drivers/staging/media/hantro/hantro_g1_h264_dec.c b/drivers/staging/media/hantro/hantro_g1_h264_dec.c
|
|
index 2aa37baad0c3..6faacfc44c7c 100644
|
|
--- a/drivers/staging/media/hantro/hantro_g1_h264_dec.c
|
|
+++ b/drivers/staging/media/hantro/hantro_g1_h264_dec.c
|
|
@@ -129,25 +129,12 @@ static void set_ref(struct hantro_ctx *ctx)
|
|
struct v4l2_h264_dpb_entry *dpb = ctx->h264_dec.dpb;
|
|
const u8 *b0_reflist, *b1_reflist, *p_reflist;
|
|
struct hantro_dev *vpu = ctx->dev;
|
|
- u32 dpb_longterm = 0;
|
|
- u32 dpb_valid = 0;
|
|
int reg_num;
|
|
u32 reg;
|
|
int i;
|
|
|
|
- /*
|
|
- * Set up bit maps of valid and long term DPBs.
|
|
- * NOTE: The bits are reversed, i.e. MSb is DPB 0.
|
|
- */
|
|
- for (i = 0; i < HANTRO_H264_DPB_SIZE; ++i) {
|
|
- if (dpb[i].flags & V4L2_H264_DPB_ENTRY_FLAG_ACTIVE)
|
|
- dpb_valid |= BIT(HANTRO_H264_DPB_SIZE - 1 - i);
|
|
-
|
|
- if (dpb[i].flags & V4L2_H264_DPB_ENTRY_FLAG_LONG_TERM)
|
|
- dpb_longterm |= BIT(HANTRO_H264_DPB_SIZE - 1 - i);
|
|
- }
|
|
- vdpu_write_relaxed(vpu, dpb_valid << 16, G1_REG_VALID_REF);
|
|
- vdpu_write_relaxed(vpu, dpb_longterm << 16, G1_REG_LT_REF);
|
|
+ vdpu_write_relaxed(vpu, ctx->h264_dec.dpb_valid, G1_REG_VALID_REF);
|
|
+ vdpu_write_relaxed(vpu, ctx->h264_dec.dpb_longterm, G1_REG_LT_REF);
|
|
|
|
/*
|
|
* Set up reference frame picture numbers.
|
|
diff --git a/drivers/staging/media/hantro/hantro_h264.c b/drivers/staging/media/hantro/hantro_h264.c
|
|
index ed6eaf11d96f..6d72136760e7 100644
|
|
--- a/drivers/staging/media/hantro/hantro_h264.c
|
|
+++ b/drivers/staging/media/hantro/hantro_h264.c
|
|
@@ -229,12 +229,25 @@ static void prepare_table(struct hantro_ctx *ctx)
|
|
const struct v4l2_ctrl_h264_decode_params *dec_param = ctrls->decode;
|
|
struct hantro_h264_dec_priv_tbl *tbl = ctx->h264_dec.priv.cpu;
|
|
const struct v4l2_h264_dpb_entry *dpb = ctx->h264_dec.dpb;
|
|
+ u32 dpb_longterm = 0;
|
|
+ u32 dpb_valid = 0;
|
|
int i;
|
|
|
|
for (i = 0; i < HANTRO_H264_DPB_SIZE; ++i) {
|
|
tbl->poc[i * 2] = dpb[i].top_field_order_cnt;
|
|
tbl->poc[i * 2 + 1] = dpb[i].bottom_field_order_cnt;
|
|
+
|
|
+ /*
|
|
+ * Set up bit maps of valid and long term DPBs.
|
|
+ * NOTE: The bits are reversed, i.e. MSb is DPB 0.
|
|
+ */
|
|
+ if (dpb[i].flags & V4L2_H264_DPB_ENTRY_FLAG_ACTIVE)
|
|
+ dpb_valid |= BIT(HANTRO_H264_DPB_SIZE - 1 - i);
|
|
+ if (dpb[i].flags & V4L2_H264_DPB_ENTRY_FLAG_LONG_TERM)
|
|
+ dpb_longterm |= BIT(HANTRO_H264_DPB_SIZE - 1 - i);
|
|
}
|
|
+ ctx->h264_dec.dpb_valid = dpb_valid << 16;
|
|
+ ctx->h264_dec.dpb_longterm = dpb_longterm << 16;
|
|
|
|
tbl->poc[32] = dec_param->top_field_order_cnt;
|
|
tbl->poc[33] = dec_param->bottom_field_order_cnt;
|
|
diff --git a/drivers/staging/media/hantro/hantro_hw.h b/drivers/staging/media/hantro/hantro_hw.h
|
|
index 5dcf65805396..ce678fedaad6 100644
|
|
--- a/drivers/staging/media/hantro/hantro_hw.h
|
|
+++ b/drivers/staging/media/hantro/hantro_hw.h
|
|
@@ -89,12 +89,16 @@ struct hantro_h264_dec_reflists {
|
|
* @dpb: DPB
|
|
* @reflists: P/B0/B1 reflists
|
|
* @ctrls: V4L2 controls attached to a run
|
|
+ * @dpb_longterm: DPB long-term
|
|
+ * @dpb_valid: DPB valid
|
|
*/
|
|
struct hantro_h264_dec_hw_ctx {
|
|
struct hantro_aux_buf priv;
|
|
struct v4l2_h264_dpb_entry dpb[HANTRO_H264_DPB_SIZE];
|
|
struct hantro_h264_dec_reflists reflists;
|
|
struct hantro_h264_dec_ctrls ctrls;
|
|
+ u32 dpb_longterm;
|
|
+ u32 dpb_valid;
|
|
};
|
|
|
|
/**
|
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Ezequiel Garcia <ezequiel@collabora.com>
|
|
Date: Mon, 19 Jul 2021 22:52:37 +0200
|
|
Subject: [PATCH] media: hantro: h264: Move reference picture number to a
|
|
helper
|
|
|
|
Add a hantro_h264_get_ref_nbr() helper function to get the reference
|
|
picture numbers. This will be used by the Rockchip VDPU2 H.264 driver.
|
|
|
|
This idea was originally proposed by Jonas Karlman in
|
|
"[RFC 09/12] media: hantro: Refactor G1 H264 code"
|
|
posted a while ago.
|
|
|
|
Link: https://lore.kernel.org/linux-media/HE1PR06MB401165F2BA0AD8A634FDFAF2ACBF0@HE1PR06MB4011.eurprd06.prod.outlook.com/
|
|
|
|
Signed-off-by: Ezequiel Garcia <ezequiel@collabora.com>
|
|
Tested-by: Alex Bee <knaerzche@gmail.com>
|
|
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
|
|
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
|
|
---
|
|
drivers/staging/media/hantro/hantro_g1_h264_dec.c | 14 ++------------
|
|
drivers/staging/media/hantro/hantro_h264.c | 11 +++++++++++
|
|
drivers/staging/media/hantro/hantro_hw.h | 2 ++
|
|
3 files changed, 15 insertions(+), 12 deletions(-)
|
|
|
|
diff --git a/drivers/staging/media/hantro/hantro_g1_h264_dec.c b/drivers/staging/media/hantro/hantro_g1_h264_dec.c
|
|
index 6faacfc44c7c..236ce24ca00c 100644
|
|
--- a/drivers/staging/media/hantro/hantro_g1_h264_dec.c
|
|
+++ b/drivers/staging/media/hantro/hantro_g1_h264_dec.c
|
|
@@ -126,7 +126,6 @@ static void set_params(struct hantro_ctx *ctx, struct vb2_v4l2_buffer *src_buf)
|
|
|
|
static void set_ref(struct hantro_ctx *ctx)
|
|
{
|
|
- struct v4l2_h264_dpb_entry *dpb = ctx->h264_dec.dpb;
|
|
const u8 *b0_reflist, *b1_reflist, *p_reflist;
|
|
struct hantro_dev *vpu = ctx->dev;
|
|
int reg_num;
|
|
@@ -143,17 +142,8 @@ static void set_ref(struct hantro_ctx *ctx)
|
|
* subsequential reference pictures.
|
|
*/
|
|
for (i = 0; i < HANTRO_H264_DPB_SIZE; i += 2) {
|
|
- reg = 0;
|
|
- if (dpb[i].flags & V4L2_H264_DPB_ENTRY_FLAG_LONG_TERM)
|
|
- reg |= G1_REG_REF_PIC_REFER0_NBR(dpb[i].pic_num);
|
|
- else
|
|
- reg |= G1_REG_REF_PIC_REFER0_NBR(dpb[i].frame_num);
|
|
-
|
|
- if (dpb[i + 1].flags & V4L2_H264_DPB_ENTRY_FLAG_LONG_TERM)
|
|
- reg |= G1_REG_REF_PIC_REFER1_NBR(dpb[i + 1].pic_num);
|
|
- else
|
|
- reg |= G1_REG_REF_PIC_REFER1_NBR(dpb[i + 1].frame_num);
|
|
-
|
|
+ reg = G1_REG_REF_PIC_REFER0_NBR(hantro_h264_get_ref_nbr(ctx, i)) |
|
|
+ G1_REG_REF_PIC_REFER1_NBR(hantro_h264_get_ref_nbr(ctx, i + 1));
|
|
vdpu_write_relaxed(vpu, reg, G1_REG_REF_PIC(i / 2));
|
|
}
|
|
|
|
diff --git a/drivers/staging/media/hantro/hantro_h264.c b/drivers/staging/media/hantro/hantro_h264.c
|
|
index 6d72136760e7..0b4d2491be3b 100644
|
|
--- a/drivers/staging/media/hantro/hantro_h264.c
|
|
+++ b/drivers/staging/media/hantro/hantro_h264.c
|
|
@@ -348,6 +348,17 @@ dma_addr_t hantro_h264_get_ref_buf(struct hantro_ctx *ctx,
|
|
return dma_addr;
|
|
}
|
|
|
|
+u16 hantro_h264_get_ref_nbr(struct hantro_ctx *ctx, unsigned int dpb_idx)
|
|
+{
|
|
+ const struct v4l2_h264_dpb_entry *dpb = &ctx->h264_dec.dpb[dpb_idx];
|
|
+
|
|
+ if (!(dpb->flags & V4L2_H264_DPB_ENTRY_FLAG_ACTIVE))
|
|
+ return 0;
|
|
+ if (dpb->flags & V4L2_H264_DPB_ENTRY_FLAG_LONG_TERM)
|
|
+ return dpb->pic_num;
|
|
+ return dpb->frame_num;
|
|
+}
|
|
+
|
|
int hantro_h264_dec_prepare_run(struct hantro_ctx *ctx)
|
|
{
|
|
struct hantro_h264_dec_hw_ctx *h264_ctx = &ctx->h264_dec;
|
|
diff --git a/drivers/staging/media/hantro/hantro_hw.h b/drivers/staging/media/hantro/hantro_hw.h
|
|
index ce678fedaad6..7a8048afe357 100644
|
|
--- a/drivers/staging/media/hantro/hantro_hw.h
|
|
+++ b/drivers/staging/media/hantro/hantro_hw.h
|
|
@@ -238,6 +238,8 @@ void hantro_jpeg_enc_done(struct hantro_ctx *ctx);
|
|
|
|
dma_addr_t hantro_h264_get_ref_buf(struct hantro_ctx *ctx,
|
|
unsigned int dpb_idx);
|
|
+u16 hantro_h264_get_ref_nbr(struct hantro_ctx *ctx,
|
|
+ unsigned int dpb_idx);
|
|
int hantro_h264_dec_prepare_run(struct hantro_ctx *ctx);
|
|
int hantro_g1_h264_dec_run(struct hantro_ctx *ctx);
|
|
int hantro_h264_dec_init(struct hantro_ctx *ctx);
|
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Jonas Karlman <jonas@kwiboo.se>
|
|
Date: Mon, 19 Jul 2021 22:52:38 +0200
|
|
Subject: [PATCH] media: hantro: Add H.264 support for Rockchip VDPU2
|
|
|
|
Rockchip VDPU2 core is present on RK3328, RK3326/PX30, RK3399
|
|
and others. It's similar to Hantro G1, but it's not compatible with it.
|
|
|
|
Signed-off-by: Jonas Karlman <jonas@kwiboo.se>
|
|
Signed-off-by: Ezequiel Garcia <ezequiel@collabora.com>
|
|
Tested-by: Alex Bee <knaerzche@gmail.com>
|
|
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
|
|
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
|
|
---
|
|
drivers/staging/media/hantro/Makefile | 1 +
|
|
drivers/staging/media/hantro/hantro_hw.h | 1 +
|
|
.../media/hantro/rockchip_vpu2_hw_h264_dec.c | 491 ++++++++++++++++++
|
|
3 files changed, 493 insertions(+)
|
|
create mode 100644 drivers/staging/media/hantro/rockchip_vpu2_hw_h264_dec.c
|
|
|
|
diff --git a/drivers/staging/media/hantro/Makefile b/drivers/staging/media/hantro/Makefile
|
|
index 287370188d2a..90036831fec4 100644
|
|
--- a/drivers/staging/media/hantro/Makefile
|
|
+++ b/drivers/staging/media/hantro/Makefile
|
|
@@ -13,6 +13,7 @@ hantro-vpu-y += \
|
|
hantro_g2_hevc_dec.o \
|
|
hantro_g1_vp8_dec.o \
|
|
rockchip_vpu2_hw_jpeg_enc.o \
|
|
+ rockchip_vpu2_hw_h264_dec.o \
|
|
rockchip_vpu2_hw_mpeg2_dec.o \
|
|
rockchip_vpu2_hw_vp8_dec.o \
|
|
hantro_jpeg.o \
|
|
diff --git a/drivers/staging/media/hantro/hantro_hw.h b/drivers/staging/media/hantro/hantro_hw.h
|
|
index 7a8048afe357..9296624654a6 100644
|
|
--- a/drivers/staging/media/hantro/hantro_hw.h
|
|
+++ b/drivers/staging/media/hantro/hantro_hw.h
|
|
@@ -241,6 +241,7 @@ dma_addr_t hantro_h264_get_ref_buf(struct hantro_ctx *ctx,
|
|
u16 hantro_h264_get_ref_nbr(struct hantro_ctx *ctx,
|
|
unsigned int dpb_idx);
|
|
int hantro_h264_dec_prepare_run(struct hantro_ctx *ctx);
|
|
+int rockchip_vpu2_h264_dec_run(struct hantro_ctx *ctx);
|
|
int hantro_g1_h264_dec_run(struct hantro_ctx *ctx);
|
|
int hantro_h264_dec_init(struct hantro_ctx *ctx);
|
|
void hantro_h264_dec_exit(struct hantro_ctx *ctx);
|
|
diff --git a/drivers/staging/media/hantro/rockchip_vpu2_hw_h264_dec.c b/drivers/staging/media/hantro/rockchip_vpu2_hw_h264_dec.c
|
|
new file mode 100644
|
|
index 000000000000..64a6330475eb
|
|
--- /dev/null
|
|
+++ b/drivers/staging/media/hantro/rockchip_vpu2_hw_h264_dec.c
|
|
@@ -0,0 +1,491 @@
|
|
+// SPDX-License-Identifier: GPL-2.0
|
|
+/*
|
|
+ * Hantro VPU codec driver
|
|
+ *
|
|
+ * Copyright (c) 2014 Rockchip Electronics Co., Ltd.
|
|
+ * Hertz Wong <hertz.wong@rock-chips.com>
|
|
+ * Herman Chen <herman.chen@rock-chips.com>
|
|
+ *
|
|
+ * Copyright (C) 2014 Google, Inc.
|
|
+ * Tomasz Figa <tfiga@chromium.org>
|
|
+ */
|
|
+
|
|
+#include <linux/types.h>
|
|
+#include <linux/sort.h>
|
|
+
|
|
+#include <media/v4l2-mem2mem.h>
|
|
+
|
|
+#include "hantro_hw.h"
|
|
+#include "hantro_v4l2.h"
|
|
+
|
|
+#define VDPU_SWREG(nr) ((nr) * 4)
|
|
+
|
|
+#define VDPU_REG_DEC_OUT_BASE VDPU_SWREG(63)
|
|
+#define VDPU_REG_RLC_VLC_BASE VDPU_SWREG(64)
|
|
+#define VDPU_REG_QTABLE_BASE VDPU_SWREG(61)
|
|
+#define VDPU_REG_DIR_MV_BASE VDPU_SWREG(62)
|
|
+#define VDPU_REG_REFER_BASE(i) (VDPU_SWREG(84 + (i)))
|
|
+#define VDPU_REG_DEC_E(v) ((v) ? BIT(0) : 0)
|
|
+
|
|
+#define VDPU_REG_DEC_ADV_PRE_DIS(v) ((v) ? BIT(11) : 0)
|
|
+#define VDPU_REG_DEC_SCMD_DIS(v) ((v) ? BIT(10) : 0)
|
|
+#define VDPU_REG_FILTERING_DIS(v) ((v) ? BIT(8) : 0)
|
|
+#define VDPU_REG_PIC_FIXED_QUANT(v) ((v) ? BIT(7) : 0)
|
|
+#define VDPU_REG_DEC_LATENCY(v) (((v) << 1) & GENMASK(6, 1))
|
|
+
|
|
+#define VDPU_REG_INIT_QP(v) (((v) << 25) & GENMASK(30, 25))
|
|
+#define VDPU_REG_STREAM_LEN(v) (((v) << 0) & GENMASK(23, 0))
|
|
+
|
|
+#define VDPU_REG_APF_THRESHOLD(v) (((v) << 17) & GENMASK(30, 17))
|
|
+#define VDPU_REG_STARTMB_X(v) (((v) << 8) & GENMASK(16, 8))
|
|
+#define VDPU_REG_STARTMB_Y(v) (((v) << 0) & GENMASK(7, 0))
|
|
+
|
|
+#define VDPU_REG_DEC_MODE(v) (((v) << 0) & GENMASK(3, 0))
|
|
+
|
|
+#define VDPU_REG_DEC_STRENDIAN_E(v) ((v) ? BIT(5) : 0)
|
|
+#define VDPU_REG_DEC_STRSWAP32_E(v) ((v) ? BIT(4) : 0)
|
|
+#define VDPU_REG_DEC_OUTSWAP32_E(v) ((v) ? BIT(3) : 0)
|
|
+#define VDPU_REG_DEC_INSWAP32_E(v) ((v) ? BIT(2) : 0)
|
|
+#define VDPU_REG_DEC_OUT_ENDIAN(v) ((v) ? BIT(1) : 0)
|
|
+#define VDPU_REG_DEC_IN_ENDIAN(v) ((v) ? BIT(0) : 0)
|
|
+
|
|
+#define VDPU_REG_DEC_DATA_DISC_E(v) ((v) ? BIT(22) : 0)
|
|
+#define VDPU_REG_DEC_MAX_BURST(v) (((v) << 16) & GENMASK(20, 16))
|
|
+#define VDPU_REG_DEC_AXI_WR_ID(v) (((v) << 8) & GENMASK(15, 8))
|
|
+#define VDPU_REG_DEC_AXI_RD_ID(v) (((v) << 0) & GENMASK(7, 0))
|
|
+
|
|
+#define VDPU_REG_START_CODE_E(v) ((v) ? BIT(22) : 0)
|
|
+#define VDPU_REG_CH_8PIX_ILEAV_E(v) ((v) ? BIT(21) : 0)
|
|
+#define VDPU_REG_RLC_MODE_E(v) ((v) ? BIT(20) : 0)
|
|
+#define VDPU_REG_PIC_INTERLACE_E(v) ((v) ? BIT(17) : 0)
|
|
+#define VDPU_REG_PIC_FIELDMODE_E(v) ((v) ? BIT(16) : 0)
|
|
+#define VDPU_REG_PIC_TOPFIELD_E(v) ((v) ? BIT(13) : 0)
|
|
+#define VDPU_REG_WRITE_MVS_E(v) ((v) ? BIT(10) : 0)
|
|
+#define VDPU_REG_SEQ_MBAFF_E(v) ((v) ? BIT(7) : 0)
|
|
+#define VDPU_REG_PICORD_COUNT_E(v) ((v) ? BIT(6) : 0)
|
|
+#define VDPU_REG_DEC_TIMEOUT_E(v) ((v) ? BIT(5) : 0)
|
|
+#define VDPU_REG_DEC_CLK_GATE_E(v) ((v) ? BIT(4) : 0)
|
|
+
|
|
+#define VDPU_REG_PRED_BC_TAP_0_0(v) (((v) << 22) & GENMASK(31, 22))
|
|
+#define VDPU_REG_PRED_BC_TAP_0_1(v) (((v) << 12) & GENMASK(21, 12))
|
|
+#define VDPU_REG_PRED_BC_TAP_0_2(v) (((v) << 2) & GENMASK(11, 2))
|
|
+
|
|
+#define VDPU_REG_REFBU_E(v) ((v) ? BIT(31) : 0)
|
|
+
|
|
+#define VDPU_REG_PINIT_RLIST_F9(v) (((v) << 25) & GENMASK(29, 25))
|
|
+#define VDPU_REG_PINIT_RLIST_F8(v) (((v) << 20) & GENMASK(24, 20))
|
|
+#define VDPU_REG_PINIT_RLIST_F7(v) (((v) << 15) & GENMASK(19, 15))
|
|
+#define VDPU_REG_PINIT_RLIST_F6(v) (((v) << 10) & GENMASK(14, 10))
|
|
+#define VDPU_REG_PINIT_RLIST_F5(v) (((v) << 5) & GENMASK(9, 5))
|
|
+#define VDPU_REG_PINIT_RLIST_F4(v) (((v) << 0) & GENMASK(4, 0))
|
|
+
|
|
+#define VDPU_REG_PINIT_RLIST_F15(v) (((v) << 25) & GENMASK(29, 25))
|
|
+#define VDPU_REG_PINIT_RLIST_F14(v) (((v) << 20) & GENMASK(24, 20))
|
|
+#define VDPU_REG_PINIT_RLIST_F13(v) (((v) << 15) & GENMASK(19, 15))
|
|
+#define VDPU_REG_PINIT_RLIST_F12(v) (((v) << 10) & GENMASK(14, 10))
|
|
+#define VDPU_REG_PINIT_RLIST_F11(v) (((v) << 5) & GENMASK(9, 5))
|
|
+#define VDPU_REG_PINIT_RLIST_F10(v) (((v) << 0) & GENMASK(4, 0))
|
|
+
|
|
+#define VDPU_REG_REFER1_NBR(v) (((v) << 16) & GENMASK(31, 16))
|
|
+#define VDPU_REG_REFER0_NBR(v) (((v) << 0) & GENMASK(15, 0))
|
|
+
|
|
+#define VDPU_REG_REFER3_NBR(v) (((v) << 16) & GENMASK(31, 16))
|
|
+#define VDPU_REG_REFER2_NBR(v) (((v) << 0) & GENMASK(15, 0))
|
|
+
|
|
+#define VDPU_REG_REFER5_NBR(v) (((v) << 16) & GENMASK(31, 16))
|
|
+#define VDPU_REG_REFER4_NBR(v) (((v) << 0) & GENMASK(15, 0))
|
|
+
|
|
+#define VDPU_REG_REFER7_NBR(v) (((v) << 16) & GENMASK(31, 16))
|
|
+#define VDPU_REG_REFER6_NBR(v) (((v) << 0) & GENMASK(15, 0))
|
|
+
|
|
+#define VDPU_REG_REFER9_NBR(v) (((v) << 16) & GENMASK(31, 16))
|
|
+#define VDPU_REG_REFER8_NBR(v) (((v) << 0) & GENMASK(15, 0))
|
|
+
|
|
+#define VDPU_REG_REFER11_NBR(v) (((v) << 16) & GENMASK(31, 16))
|
|
+#define VDPU_REG_REFER10_NBR(v) (((v) << 0) & GENMASK(15, 0))
|
|
+
|
|
+#define VDPU_REG_REFER13_NBR(v) (((v) << 16) & GENMASK(31, 16))
|
|
+#define VDPU_REG_REFER12_NBR(v) (((v) << 0) & GENMASK(15, 0))
|
|
+
|
|
+#define VDPU_REG_REFER15_NBR(v) (((v) << 16) & GENMASK(31, 16))
|
|
+#define VDPU_REG_REFER14_NBR(v) (((v) << 0) & GENMASK(15, 0))
|
|
+
|
|
+#define VDPU_REG_BINIT_RLIST_F5(v) (((v) << 25) & GENMASK(29, 25))
|
|
+#define VDPU_REG_BINIT_RLIST_F4(v) (((v) << 20) & GENMASK(24, 20))
|
|
+#define VDPU_REG_BINIT_RLIST_F3(v) (((v) << 15) & GENMASK(19, 15))
|
|
+#define VDPU_REG_BINIT_RLIST_F2(v) (((v) << 10) & GENMASK(14, 10))
|
|
+#define VDPU_REG_BINIT_RLIST_F1(v) (((v) << 5) & GENMASK(9, 5))
|
|
+#define VDPU_REG_BINIT_RLIST_F0(v) (((v) << 0) & GENMASK(4, 0))
|
|
+
|
|
+#define VDPU_REG_BINIT_RLIST_F11(v) (((v) << 25) & GENMASK(29, 25))
|
|
+#define VDPU_REG_BINIT_RLIST_F10(v) (((v) << 20) & GENMASK(24, 20))
|
|
+#define VDPU_REG_BINIT_RLIST_F9(v) (((v) << 15) & GENMASK(19, 15))
|
|
+#define VDPU_REG_BINIT_RLIST_F8(v) (((v) << 10) & GENMASK(14, 10))
|
|
+#define VDPU_REG_BINIT_RLIST_F7(v) (((v) << 5) & GENMASK(9, 5))
|
|
+#define VDPU_REG_BINIT_RLIST_F6(v) (((v) << 0) & GENMASK(4, 0))
|
|
+
|
|
+#define VDPU_REG_BINIT_RLIST_F15(v) (((v) << 15) & GENMASK(19, 15))
|
|
+#define VDPU_REG_BINIT_RLIST_F14(v) (((v) << 10) & GENMASK(14, 10))
|
|
+#define VDPU_REG_BINIT_RLIST_F13(v) (((v) << 5) & GENMASK(9, 5))
|
|
+#define VDPU_REG_BINIT_RLIST_F12(v) (((v) << 0) & GENMASK(4, 0))
|
|
+
|
|
+#define VDPU_REG_BINIT_RLIST_B5(v) (((v) << 25) & GENMASK(29, 25))
|
|
+#define VDPU_REG_BINIT_RLIST_B4(v) (((v) << 20) & GENMASK(24, 20))
|
|
+#define VDPU_REG_BINIT_RLIST_B3(v) (((v) << 15) & GENMASK(19, 15))
|
|
+#define VDPU_REG_BINIT_RLIST_B2(v) (((v) << 10) & GENMASK(14, 10))
|
|
+#define VDPU_REG_BINIT_RLIST_B1(v) (((v) << 5) & GENMASK(9, 5))
|
|
+#define VDPU_REG_BINIT_RLIST_B0(v) (((v) << 0) & GENMASK(4, 0))
|
|
+
|
|
+#define VDPU_REG_BINIT_RLIST_B11(v) (((v) << 25) & GENMASK(29, 25))
|
|
+#define VDPU_REG_BINIT_RLIST_B10(v) (((v) << 20) & GENMASK(24, 20))
|
|
+#define VDPU_REG_BINIT_RLIST_B9(v) (((v) << 15) & GENMASK(19, 15))
|
|
+#define VDPU_REG_BINIT_RLIST_B8(v) (((v) << 10) & GENMASK(14, 10))
|
|
+#define VDPU_REG_BINIT_RLIST_B7(v) (((v) << 5) & GENMASK(9, 5))
|
|
+#define VDPU_REG_BINIT_RLIST_B6(v) (((v) << 0) & GENMASK(4, 0))
|
|
+
|
|
+#define VDPU_REG_BINIT_RLIST_B15(v) (((v) << 15) & GENMASK(19, 15))
|
|
+#define VDPU_REG_BINIT_RLIST_B14(v) (((v) << 10) & GENMASK(14, 10))
|
|
+#define VDPU_REG_BINIT_RLIST_B13(v) (((v) << 5) & GENMASK(9, 5))
|
|
+#define VDPU_REG_BINIT_RLIST_B12(v) (((v) << 0) & GENMASK(4, 0))
|
|
+
|
|
+#define VDPU_REG_PINIT_RLIST_F3(v) (((v) << 15) & GENMASK(19, 15))
|
|
+#define VDPU_REG_PINIT_RLIST_F2(v) (((v) << 10) & GENMASK(14, 10))
|
|
+#define VDPU_REG_PINIT_RLIST_F1(v) (((v) << 5) & GENMASK(9, 5))
|
|
+#define VDPU_REG_PINIT_RLIST_F0(v) (((v) << 0) & GENMASK(4, 0))
|
|
+
|
|
+#define VDPU_REG_REFER_LTERM_E(v) (((v) << 0) & GENMASK(31, 0))
|
|
+
|
|
+#define VDPU_REG_REFER_VALID_E(v) (((v) << 0) & GENMASK(31, 0))
|
|
+
|
|
+#define VDPU_REG_STRM_START_BIT(v) (((v) << 0) & GENMASK(5, 0))
|
|
+
|
|
+#define VDPU_REG_CH_QP_OFFSET2(v) (((v) << 22) & GENMASK(26, 22))
|
|
+#define VDPU_REG_CH_QP_OFFSET(v) (((v) << 17) & GENMASK(21, 17))
|
|
+#define VDPU_REG_PIC_MB_HEIGHT_P(v) (((v) << 9) & GENMASK(16, 9))
|
|
+#define VDPU_REG_PIC_MB_WIDTH(v) (((v) << 0) & GENMASK(8, 0))
|
|
+
|
|
+#define VDPU_REG_WEIGHT_BIPR_IDC(v) (((v) << 16) & GENMASK(17, 16))
|
|
+#define VDPU_REG_REF_FRAMES(v) (((v) << 0) & GENMASK(4, 0))
|
|
+
|
|
+#define VDPU_REG_FILT_CTRL_PRES(v) ((v) ? BIT(31) : 0)
|
|
+#define VDPU_REG_RDPIC_CNT_PRES(v) ((v) ? BIT(30) : 0)
|
|
+#define VDPU_REG_FRAMENUM_LEN(v) (((v) << 16) & GENMASK(20, 16))
|
|
+#define VDPU_REG_FRAMENUM(v) (((v) << 0) & GENMASK(15, 0))
|
|
+
|
|
+#define VDPU_REG_REFPIC_MK_LEN(v) (((v) << 16) & GENMASK(26, 16))
|
|
+#define VDPU_REG_IDR_PIC_ID(v) (((v) << 0) & GENMASK(15, 0))
|
|
+
|
|
+#define VDPU_REG_PPS_ID(v) (((v) << 24) & GENMASK(31, 24))
|
|
+#define VDPU_REG_REFIDX1_ACTIVE(v) (((v) << 19) & GENMASK(23, 19))
|
|
+#define VDPU_REG_REFIDX0_ACTIVE(v) (((v) << 14) & GENMASK(18, 14))
|
|
+#define VDPU_REG_POC_LENGTH(v) (((v) << 0) & GENMASK(7, 0))
|
|
+
|
|
+#define VDPU_REG_IDR_PIC_E(v) ((v) ? BIT(8) : 0)
|
|
+#define VDPU_REG_DIR_8X8_INFER_E(v) ((v) ? BIT(7) : 0)
|
|
+#define VDPU_REG_BLACKWHITE_E(v) ((v) ? BIT(6) : 0)
|
|
+#define VDPU_REG_CABAC_E(v) ((v) ? BIT(5) : 0)
|
|
+#define VDPU_REG_WEIGHT_PRED_E(v) ((v) ? BIT(4) : 0)
|
|
+#define VDPU_REG_CONST_INTRA_E(v) ((v) ? BIT(3) : 0)
|
|
+#define VDPU_REG_8X8TRANS_FLAG_E(v) ((v) ? BIT(2) : 0)
|
|
+#define VDPU_REG_TYPE1_QUANT_E(v) ((v) ? BIT(1) : 0)
|
|
+#define VDPU_REG_FIELDPIC_FLAG_E(v) ((v) ? BIT(0) : 0)
|
|
+
|
|
+static void set_params(struct hantro_ctx *ctx, struct vb2_v4l2_buffer *src_buf)
|
|
+{
|
|
+ const struct hantro_h264_dec_ctrls *ctrls = &ctx->h264_dec.ctrls;
|
|
+ const struct v4l2_ctrl_h264_decode_params *dec_param = ctrls->decode;
|
|
+ const struct v4l2_ctrl_h264_sps *sps = ctrls->sps;
|
|
+ const struct v4l2_ctrl_h264_pps *pps = ctrls->pps;
|
|
+ struct hantro_dev *vpu = ctx->dev;
|
|
+ u32 reg;
|
|
+
|
|
+ reg = VDPU_REG_DEC_ADV_PRE_DIS(0) |
|
|
+ VDPU_REG_DEC_SCMD_DIS(0) |
|
|
+ VDPU_REG_FILTERING_DIS(0) |
|
|
+ VDPU_REG_PIC_FIXED_QUANT(0) |
|
|
+ VDPU_REG_DEC_LATENCY(0);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(50));
|
|
+
|
|
+ reg = VDPU_REG_INIT_QP(pps->pic_init_qp_minus26 + 26) |
|
|
+ VDPU_REG_STREAM_LEN(vb2_get_plane_payload(&src_buf->vb2_buf, 0));
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(51));
|
|
+
|
|
+ reg = VDPU_REG_APF_THRESHOLD(8) |
|
|
+ VDPU_REG_STARTMB_X(0) |
|
|
+ VDPU_REG_STARTMB_Y(0);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(52));
|
|
+
|
|
+ reg = VDPU_REG_DEC_MODE(0);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(53));
|
|
+
|
|
+ reg = VDPU_REG_DEC_STRENDIAN_E(1) |
|
|
+ VDPU_REG_DEC_STRSWAP32_E(1) |
|
|
+ VDPU_REG_DEC_OUTSWAP32_E(1) |
|
|
+ VDPU_REG_DEC_INSWAP32_E(1) |
|
|
+ VDPU_REG_DEC_OUT_ENDIAN(1) |
|
|
+ VDPU_REG_DEC_IN_ENDIAN(0);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(54));
|
|
+
|
|
+ reg = VDPU_REG_DEC_DATA_DISC_E(0) |
|
|
+ VDPU_REG_DEC_MAX_BURST(16) |
|
|
+ VDPU_REG_DEC_AXI_WR_ID(0) |
|
|
+ VDPU_REG_DEC_AXI_RD_ID(0xff);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(56));
|
|
+
|
|
+ reg = VDPU_REG_START_CODE_E(1) |
|
|
+ VDPU_REG_CH_8PIX_ILEAV_E(0) |
|
|
+ VDPU_REG_RLC_MODE_E(0) |
|
|
+ VDPU_REG_PIC_INTERLACE_E(!(sps->flags & V4L2_H264_SPS_FLAG_FRAME_MBS_ONLY) &&
|
|
+ (sps->flags & V4L2_H264_SPS_FLAG_MB_ADAPTIVE_FRAME_FIELD ||
|
|
+ dec_param->flags & V4L2_H264_DECODE_PARAM_FLAG_FIELD_PIC)) |
|
|
+ VDPU_REG_PIC_FIELDMODE_E(dec_param->flags & V4L2_H264_DECODE_PARAM_FLAG_FIELD_PIC) |
|
|
+ VDPU_REG_PIC_TOPFIELD_E(!(dec_param->flags & V4L2_H264_DECODE_PARAM_FLAG_BOTTOM_FIELD)) |
|
|
+ VDPU_REG_WRITE_MVS_E((sps->profile_idc > 66) && dec_param->nal_ref_idc) |
|
|
+ VDPU_REG_SEQ_MBAFF_E(sps->flags & V4L2_H264_SPS_FLAG_MB_ADAPTIVE_FRAME_FIELD) |
|
|
+ VDPU_REG_PICORD_COUNT_E(sps->profile_idc > 66) |
|
|
+ VDPU_REG_DEC_TIMEOUT_E(1) |
|
|
+ VDPU_REG_DEC_CLK_GATE_E(1);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(57));
|
|
+
|
|
+ reg = VDPU_REG_PRED_BC_TAP_0_0(1) |
|
|
+ VDPU_REG_PRED_BC_TAP_0_1((u32)-5) |
|
|
+ VDPU_REG_PRED_BC_TAP_0_2(20);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(59));
|
|
+
|
|
+ reg = VDPU_REG_REFBU_E(0);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(65));
|
|
+
|
|
+ reg = VDPU_REG_STRM_START_BIT(0);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(109));
|
|
+
|
|
+ reg = VDPU_REG_CH_QP_OFFSET2(pps->second_chroma_qp_index_offset) |
|
|
+ VDPU_REG_CH_QP_OFFSET(pps->chroma_qp_index_offset) |
|
|
+ VDPU_REG_PIC_MB_HEIGHT_P(MB_HEIGHT(ctx->src_fmt.height)) |
|
|
+ VDPU_REG_PIC_MB_WIDTH(MB_WIDTH(ctx->src_fmt.width));
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(110));
|
|
+
|
|
+ reg = VDPU_REG_WEIGHT_BIPR_IDC(pps->weighted_bipred_idc) |
|
|
+ VDPU_REG_REF_FRAMES(sps->max_num_ref_frames);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(111));
|
|
+
|
|
+ reg = VDPU_REG_FILT_CTRL_PRES(pps->flags & V4L2_H264_PPS_FLAG_DEBLOCKING_FILTER_CONTROL_PRESENT) |
|
|
+ VDPU_REG_RDPIC_CNT_PRES(pps->flags & V4L2_H264_PPS_FLAG_REDUNDANT_PIC_CNT_PRESENT) |
|
|
+ VDPU_REG_FRAMENUM_LEN(sps->log2_max_frame_num_minus4 + 4) |
|
|
+ VDPU_REG_FRAMENUM(dec_param->frame_num);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(112));
|
|
+
|
|
+ reg = VDPU_REG_REFPIC_MK_LEN(dec_param->dec_ref_pic_marking_bit_size) |
|
|
+ VDPU_REG_IDR_PIC_ID(dec_param->idr_pic_id);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(113));
|
|
+
|
|
+ reg = VDPU_REG_PPS_ID(pps->pic_parameter_set_id) |
|
|
+ VDPU_REG_REFIDX1_ACTIVE(pps->num_ref_idx_l1_default_active_minus1 + 1) |
|
|
+ VDPU_REG_REFIDX0_ACTIVE(pps->num_ref_idx_l0_default_active_minus1 + 1) |
|
|
+ VDPU_REG_POC_LENGTH(dec_param->pic_order_cnt_bit_size);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(114));
|
|
+
|
|
+ reg = VDPU_REG_IDR_PIC_E(dec_param->flags & V4L2_H264_DECODE_PARAM_FLAG_IDR_PIC) |
|
|
+ VDPU_REG_DIR_8X8_INFER_E(sps->flags & V4L2_H264_SPS_FLAG_DIRECT_8X8_INFERENCE) |
|
|
+ VDPU_REG_BLACKWHITE_E(sps->profile_idc >= 100 && sps->chroma_format_idc == 0) |
|
|
+ VDPU_REG_CABAC_E(pps->flags & V4L2_H264_PPS_FLAG_ENTROPY_CODING_MODE) |
|
|
+ VDPU_REG_WEIGHT_PRED_E(pps->flags & V4L2_H264_PPS_FLAG_WEIGHTED_PRED) |
|
|
+ VDPU_REG_CONST_INTRA_E(pps->flags & V4L2_H264_PPS_FLAG_CONSTRAINED_INTRA_PRED) |
|
|
+ VDPU_REG_8X8TRANS_FLAG_E(pps->flags & V4L2_H264_PPS_FLAG_TRANSFORM_8X8_MODE) |
|
|
+ VDPU_REG_TYPE1_QUANT_E(pps->flags & V4L2_H264_PPS_FLAG_SCALING_MATRIX_PRESENT) |
|
|
+ VDPU_REG_FIELDPIC_FLAG_E(!(sps->flags & V4L2_H264_SPS_FLAG_FRAME_MBS_ONLY));
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(115));
|
|
+}
|
|
+
|
|
+static void set_ref(struct hantro_ctx *ctx)
|
|
+{
|
|
+ const u8 *b0_reflist, *b1_reflist, *p_reflist;
|
|
+ struct hantro_dev *vpu = ctx->dev;
|
|
+ u32 reg;
|
|
+ int i;
|
|
+
|
|
+ b0_reflist = ctx->h264_dec.reflists.b0;
|
|
+ b1_reflist = ctx->h264_dec.reflists.b1;
|
|
+ p_reflist = ctx->h264_dec.reflists.p;
|
|
+
|
|
+ reg = VDPU_REG_PINIT_RLIST_F9(p_reflist[9]) |
|
|
+ VDPU_REG_PINIT_RLIST_F8(p_reflist[8]) |
|
|
+ VDPU_REG_PINIT_RLIST_F7(p_reflist[7]) |
|
|
+ VDPU_REG_PINIT_RLIST_F6(p_reflist[6]) |
|
|
+ VDPU_REG_PINIT_RLIST_F5(p_reflist[5]) |
|
|
+ VDPU_REG_PINIT_RLIST_F4(p_reflist[4]);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(74));
|
|
+
|
|
+ reg = VDPU_REG_PINIT_RLIST_F15(p_reflist[15]) |
|
|
+ VDPU_REG_PINIT_RLIST_F14(p_reflist[14]) |
|
|
+ VDPU_REG_PINIT_RLIST_F13(p_reflist[13]) |
|
|
+ VDPU_REG_PINIT_RLIST_F12(p_reflist[12]) |
|
|
+ VDPU_REG_PINIT_RLIST_F11(p_reflist[11]) |
|
|
+ VDPU_REG_PINIT_RLIST_F10(p_reflist[10]);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(75));
|
|
+
|
|
+ reg = VDPU_REG_REFER1_NBR(hantro_h264_get_ref_nbr(ctx, 1)) |
|
|
+ VDPU_REG_REFER0_NBR(hantro_h264_get_ref_nbr(ctx, 0));
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(76));
|
|
+
|
|
+ reg = VDPU_REG_REFER3_NBR(hantro_h264_get_ref_nbr(ctx, 3)) |
|
|
+ VDPU_REG_REFER2_NBR(hantro_h264_get_ref_nbr(ctx, 2));
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(77));
|
|
+
|
|
+ reg = VDPU_REG_REFER5_NBR(hantro_h264_get_ref_nbr(ctx, 5)) |
|
|
+ VDPU_REG_REFER4_NBR(hantro_h264_get_ref_nbr(ctx, 4));
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(78));
|
|
+
|
|
+ reg = VDPU_REG_REFER7_NBR(hantro_h264_get_ref_nbr(ctx, 7)) |
|
|
+ VDPU_REG_REFER6_NBR(hantro_h264_get_ref_nbr(ctx, 6));
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(79));
|
|
+
|
|
+ reg = VDPU_REG_REFER9_NBR(hantro_h264_get_ref_nbr(ctx, 9)) |
|
|
+ VDPU_REG_REFER8_NBR(hantro_h264_get_ref_nbr(ctx, 8));
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(80));
|
|
+
|
|
+ reg = VDPU_REG_REFER11_NBR(hantro_h264_get_ref_nbr(ctx, 11)) |
|
|
+ VDPU_REG_REFER10_NBR(hantro_h264_get_ref_nbr(ctx, 10));
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(81));
|
|
+
|
|
+ reg = VDPU_REG_REFER13_NBR(hantro_h264_get_ref_nbr(ctx, 13)) |
|
|
+ VDPU_REG_REFER12_NBR(hantro_h264_get_ref_nbr(ctx, 12));
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(82));
|
|
+
|
|
+ reg = VDPU_REG_REFER15_NBR(hantro_h264_get_ref_nbr(ctx, 15)) |
|
|
+ VDPU_REG_REFER14_NBR(hantro_h264_get_ref_nbr(ctx, 14));
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(83));
|
|
+
|
|
+ reg = VDPU_REG_BINIT_RLIST_F5(b0_reflist[5]) |
|
|
+ VDPU_REG_BINIT_RLIST_F4(b0_reflist[4]) |
|
|
+ VDPU_REG_BINIT_RLIST_F3(b0_reflist[3]) |
|
|
+ VDPU_REG_BINIT_RLIST_F2(b0_reflist[2]) |
|
|
+ VDPU_REG_BINIT_RLIST_F1(b0_reflist[1]) |
|
|
+ VDPU_REG_BINIT_RLIST_F0(b0_reflist[0]);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(100));
|
|
+
|
|
+ reg = VDPU_REG_BINIT_RLIST_F11(b0_reflist[11]) |
|
|
+ VDPU_REG_BINIT_RLIST_F10(b0_reflist[10]) |
|
|
+ VDPU_REG_BINIT_RLIST_F9(b0_reflist[9]) |
|
|
+ VDPU_REG_BINIT_RLIST_F8(b0_reflist[8]) |
|
|
+ VDPU_REG_BINIT_RLIST_F7(b0_reflist[7]) |
|
|
+ VDPU_REG_BINIT_RLIST_F6(b0_reflist[6]);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(101));
|
|
+
|
|
+ reg = VDPU_REG_BINIT_RLIST_F15(b0_reflist[15]) |
|
|
+ VDPU_REG_BINIT_RLIST_F14(b0_reflist[14]) |
|
|
+ VDPU_REG_BINIT_RLIST_F13(b0_reflist[13]) |
|
|
+ VDPU_REG_BINIT_RLIST_F12(b0_reflist[12]);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(102));
|
|
+
|
|
+ reg = VDPU_REG_BINIT_RLIST_B5(b1_reflist[5]) |
|
|
+ VDPU_REG_BINIT_RLIST_B4(b1_reflist[4]) |
|
|
+ VDPU_REG_BINIT_RLIST_B3(b1_reflist[3]) |
|
|
+ VDPU_REG_BINIT_RLIST_B2(b1_reflist[2]) |
|
|
+ VDPU_REG_BINIT_RLIST_B1(b1_reflist[1]) |
|
|
+ VDPU_REG_BINIT_RLIST_B0(b1_reflist[0]);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(103));
|
|
+
|
|
+ reg = VDPU_REG_BINIT_RLIST_B11(b1_reflist[11]) |
|
|
+ VDPU_REG_BINIT_RLIST_B10(b1_reflist[10]) |
|
|
+ VDPU_REG_BINIT_RLIST_B9(b1_reflist[9]) |
|
|
+ VDPU_REG_BINIT_RLIST_B8(b1_reflist[8]) |
|
|
+ VDPU_REG_BINIT_RLIST_B7(b1_reflist[7]) |
|
|
+ VDPU_REG_BINIT_RLIST_B6(b1_reflist[6]);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(104));
|
|
+
|
|
+ reg = VDPU_REG_BINIT_RLIST_B15(b1_reflist[15]) |
|
|
+ VDPU_REG_BINIT_RLIST_B14(b1_reflist[14]) |
|
|
+ VDPU_REG_BINIT_RLIST_B13(b1_reflist[13]) |
|
|
+ VDPU_REG_BINIT_RLIST_B12(b1_reflist[12]);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(105));
|
|
+
|
|
+ reg = VDPU_REG_PINIT_RLIST_F3(p_reflist[3]) |
|
|
+ VDPU_REG_PINIT_RLIST_F2(p_reflist[2]) |
|
|
+ VDPU_REG_PINIT_RLIST_F1(p_reflist[1]) |
|
|
+ VDPU_REG_PINIT_RLIST_F0(p_reflist[0]);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(106));
|
|
+
|
|
+ reg = VDPU_REG_REFER_LTERM_E(ctx->h264_dec.dpb_longterm);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(107));
|
|
+
|
|
+ reg = VDPU_REG_REFER_VALID_E(ctx->h264_dec.dpb_valid);
|
|
+ vdpu_write_relaxed(vpu, reg, VDPU_SWREG(108));
|
|
+
|
|
+ /* Set up addresses of DPB buffers. */
|
|
+ for (i = 0; i < HANTRO_H264_DPB_SIZE; i++) {
|
|
+ dma_addr_t dma_addr = hantro_h264_get_ref_buf(ctx, i);
|
|
+
|
|
+ vdpu_write_relaxed(vpu, dma_addr, VDPU_REG_REFER_BASE(i));
|
|
+ }
|
|
+}
|
|
+
|
|
+static void set_buffers(struct hantro_ctx *ctx, struct vb2_v4l2_buffer *src_buf)
|
|
+{
|
|
+ const struct hantro_h264_dec_ctrls *ctrls = &ctx->h264_dec.ctrls;
|
|
+ struct vb2_v4l2_buffer *dst_buf;
|
|
+ struct hantro_dev *vpu = ctx->dev;
|
|
+ dma_addr_t src_dma, dst_dma;
|
|
+ size_t offset = 0;
|
|
+
|
|
+ /* Source (stream) buffer. */
|
|
+ src_dma = vb2_dma_contig_plane_dma_addr(&src_buf->vb2_buf, 0);
|
|
+ vdpu_write_relaxed(vpu, src_dma, VDPU_REG_RLC_VLC_BASE);
|
|
+
|
|
+ /* Destination (decoded frame) buffer. */
|
|
+ dst_buf = hantro_get_dst_buf(ctx);
|
|
+ dst_dma = hantro_get_dec_buf_addr(ctx, &dst_buf->vb2_buf);
|
|
+ /* Adjust dma addr to start at second line for bottom field */
|
|
+ if (ctrls->decode->flags & V4L2_H264_DECODE_PARAM_FLAG_BOTTOM_FIELD)
|
|
+ offset = ALIGN(ctx->src_fmt.width, MB_DIM);
|
|
+ vdpu_write_relaxed(vpu, dst_dma + offset, VDPU_REG_DEC_OUT_BASE);
|
|
+
|
|
+ /* Higher profiles require DMV buffer appended to reference frames. */
|
|
+ if (ctrls->sps->profile_idc > 66 && ctrls->decode->nal_ref_idc) {
|
|
+ unsigned int bytes_per_mb = 384;
|
|
+
|
|
+ /* DMV buffer for monochrome start directly after Y-plane */
|
|
+ if (ctrls->sps->profile_idc >= 100 &&
|
|
+ ctrls->sps->chroma_format_idc == 0)
|
|
+ bytes_per_mb = 256;
|
|
+ offset = bytes_per_mb * MB_WIDTH(ctx->src_fmt.width) *
|
|
+ MB_HEIGHT(ctx->src_fmt.height);
|
|
+
|
|
+ /*
|
|
+ * DMV buffer is split in two for field encoded frames,
|
|
+ * adjust offset for bottom field
|
|
+ */
|
|
+ if (ctrls->decode->flags & V4L2_H264_DECODE_PARAM_FLAG_BOTTOM_FIELD)
|
|
+ offset += 32 * MB_WIDTH(ctx->src_fmt.width) *
|
|
+ MB_HEIGHT(ctx->src_fmt.height);
|
|
+ vdpu_write_relaxed(vpu, dst_dma + offset, VDPU_REG_DIR_MV_BASE);
|
|
+ }
|
|
+
|
|
+ /* Auxiliary buffer prepared in hantro_g1_h264_dec_prepare_table(). */
|
|
+ vdpu_write_relaxed(vpu, ctx->h264_dec.priv.dma, VDPU_REG_QTABLE_BASE);
|
|
+}
|
|
+
|
|
+int rockchip_vpu2_h264_dec_run(struct hantro_ctx *ctx)
|
|
+{
|
|
+ struct hantro_dev *vpu = ctx->dev;
|
|
+ struct vb2_v4l2_buffer *src_buf;
|
|
+ u32 reg;
|
|
+ int ret;
|
|
+
|
|
+ /* Prepare the H264 decoder context. */
|
|
+ ret = hantro_h264_dec_prepare_run(ctx);
|
|
+ if (ret)
|
|
+ return ret;
|
|
+
|
|
+ src_buf = hantro_get_src_buf(ctx);
|
|
+ set_params(ctx, src_buf);
|
|
+ set_ref(ctx);
|
|
+ set_buffers(ctx, src_buf);
|
|
+
|
|
+ hantro_end_prepare_run(ctx);
|
|
+
|
|
+ /* Start decoding! */
|
|
+ reg = vdpu_read(vpu, VDPU_SWREG(57)) | VDPU_REG_DEC_E(1);
|
|
+ vdpu_write(vpu, reg, VDPU_SWREG(57));
|
|
+
|
|
+ return 0;
|
|
+}
|
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Ezequiel Garcia <ezequiel@collabora.com>
|
|
Date: Mon, 19 Jul 2021 22:52:39 +0200
|
|
Subject: [PATCH] media: hantro: Enable H.264 on Rockchip VDPU2
|
|
|
|
Given H.264 support for VDPU2 was just added, let's enable it.
|
|
For now, this is only enabled on platform that don't have
|
|
an RKVDEC core, such as RK3328.
|
|
|
|
Signed-off-by: Ezequiel Garcia <ezequiel@collabora.com>
|
|
Tested-by: Alex Bee <knaerzche@gmail.com>
|
|
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
|
|
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
|
|
---
|
|
.../staging/media/hantro/rockchip_vpu_hw.c | 26 ++++++++++++++++++-
|
|
1 file changed, 25 insertions(+), 1 deletion(-)
|
|
|
|
diff --git a/drivers/staging/media/hantro/rockchip_vpu_hw.c b/drivers/staging/media/hantro/rockchip_vpu_hw.c
|
|
index 3ccc16413f42..e4e3b5e7689b 100644
|
|
--- a/drivers/staging/media/hantro/rockchip_vpu_hw.c
|
|
+++ b/drivers/staging/media/hantro/rockchip_vpu_hw.c
|
|
@@ -162,6 +162,19 @@ static const struct hantro_fmt rk3399_vpu_dec_fmts[] = {
|
|
.fourcc = V4L2_PIX_FMT_NV12,
|
|
.codec_mode = HANTRO_MODE_NONE,
|
|
},
|
|
+ {
|
|
+ .fourcc = V4L2_PIX_FMT_H264_SLICE,
|
|
+ .codec_mode = HANTRO_MODE_H264_DEC,
|
|
+ .max_depth = 2,
|
|
+ .frmsize = {
|
|
+ .min_width = 48,
|
|
+ .max_width = 1920,
|
|
+ .step_width = MB_DIM,
|
|
+ .min_height = 48,
|
|
+ .max_height = 1088,
|
|
+ .step_height = MB_DIM,
|
|
+ },
|
|
+ },
|
|
{
|
|
.fourcc = V4L2_PIX_FMT_MPEG2_SLICE,
|
|
.codec_mode = HANTRO_MODE_MPEG2_DEC,
|
|
@@ -388,6 +401,12 @@ static const struct hantro_codec_ops rk3399_vpu_codec_ops[] = {
|
|
.init = hantro_jpeg_enc_init,
|
|
.exit = hantro_jpeg_enc_exit,
|
|
},
|
|
+ [HANTRO_MODE_H264_DEC] = {
|
|
+ .run = rockchip_vpu2_h264_dec_run,
|
|
+ .reset = rockchip_vpu2_dec_reset,
|
|
+ .init = hantro_h264_dec_init,
|
|
+ .exit = hantro_h264_dec_exit,
|
|
+ },
|
|
[HANTRO_MODE_MPEG2_DEC] = {
|
|
.run = rockchip_vpu2_mpeg2_dec_run,
|
|
.reset = rockchip_vpu2_dec_reset,
|
|
@@ -433,6 +452,8 @@ static const char * const rockchip_vpu_clk_names[] = {
|
|
"aclk", "hclk"
|
|
};
|
|
|
|
+/* VDPU1/VEPU1 */
|
|
+
|
|
const struct hantro_variant rk3036_vpu_variant = {
|
|
.dec_offset = 0x400,
|
|
.dec_fmts = rk3066_vpu_dec_fmts,
|
|
@@ -495,11 +516,14 @@ const struct hantro_variant rk3288_vpu_variant = {
|
|
.num_clocks = ARRAY_SIZE(rockchip_vpu_clk_names)
|
|
};
|
|
|
|
+/* VDPU2/VEPU2 */
|
|
+
|
|
const struct hantro_variant rk3328_vpu_variant = {
|
|
.dec_offset = 0x400,
|
|
.dec_fmts = rk3399_vpu_dec_fmts,
|
|
.num_dec_fmts = ARRAY_SIZE(rk3399_vpu_dec_fmts),
|
|
- .codec = HANTRO_MPEG2_DECODER | HANTRO_VP8_DECODER,
|
|
+ .codec = HANTRO_MPEG2_DECODER | HANTRO_VP8_DECODER |
|
|
+ HANTRO_H264_DECODER,
|
|
.codec_ops = rk3399_vpu_codec_ops,
|
|
.irqs = rockchip_vdpu2_irqs,
|
|
.num_irqs = ARRAY_SIZE(rockchip_vdpu2_irqs),
|
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Paul Kocialkowski <paul.kocialkowski@bootlin.com>
|
|
Date: Mon, 19 Jul 2021 22:52:41 +0200
|
|
Subject: [PATCH] media: dt-bindings: media: rockchip-vpu: Add PX30 compatible
|
|
|
|
The Rockchip PX30 SoC has a Hantro VPU that features a decoder (VDPU2)
|
|
and an encoder (VEPU2).
|
|
|
|
Suggested-by: Alex Bee <knaerzche@gmail.com>
|
|
Signed-off-by: Paul Kocialkowski <paul.kocialkowski@bootlin.com>
|
|
Signed-off-by: Ezequiel Garcia <ezequiel@collabora.com>
|
|
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
|
|
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
|
|
---
|
|
Documentation/devicetree/bindings/media/rockchip-vpu.yaml | 1 +
|
|
1 file changed, 1 insertion(+)
|
|
|
|
diff --git a/Documentation/devicetree/bindings/media/rockchip-vpu.yaml b/Documentation/devicetree/bindings/media/rockchip-vpu.yaml
|
|
index b88172a59de7..bacb60a34989 100644
|
|
--- a/Documentation/devicetree/bindings/media/rockchip-vpu.yaml
|
|
+++ b/Documentation/devicetree/bindings/media/rockchip-vpu.yaml
|
|
@@ -22,6 +22,7 @@ properties:
|
|
- rockchip,rk3288-vpu
|
|
- rockchip,rk3328-vpu
|
|
- rockchip,rk3399-vpu
|
|
+ - rockchip,px30-vpu
|
|
- items:
|
|
- const: rockchip,rk3188-vpu
|
|
- const: rockchip,rk3066-vpu
|
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Paul Kocialkowski <paul.kocialkowski@bootlin.com>
|
|
Date: Mon, 19 Jul 2021 22:52:40 +0200
|
|
Subject: [PATCH] media: hantro: Add support for the Rockchip PX30
|
|
|
|
The PX30 SoC includes both the VDPU2 and VEPU2 blocks which are similar
|
|
to the RK3399 (Hantro G1/H1 with shuffled registers).
|
|
|
|
Signed-off-by: Paul Kocialkowski <paul.kocialkowski@bootlin.com>
|
|
Signed-off-by: Ezequiel Garcia <ezequiel@collabora.com>
|
|
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
|
|
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
|
|
---
|
|
drivers/staging/media/hantro/hantro_drv.c | 1 +
|
|
drivers/staging/media/hantro/hantro_hw.h | 1 +
|
|
drivers/staging/media/hantro/rockchip_vpu_hw.c | 17 +++++++++++++++++
|
|
3 files changed, 19 insertions(+)
|
|
|
|
diff --git a/drivers/staging/media/hantro/hantro_drv.c b/drivers/staging/media/hantro/hantro_drv.c
|
|
index 9b5415176bfe..8a2edd67f2c6 100644
|
|
--- a/drivers/staging/media/hantro/hantro_drv.c
|
|
+++ b/drivers/staging/media/hantro/hantro_drv.c
|
|
@@ -582,6 +582,7 @@ static const struct v4l2_file_operations hantro_fops = {
|
|
|
|
static const struct of_device_id of_hantro_match[] = {
|
|
#ifdef CONFIG_VIDEO_HANTRO_ROCKCHIP
|
|
+ { .compatible = "rockchip,px30-vpu", .data = &px30_vpu_variant, },
|
|
{ .compatible = "rockchip,rk3036-vpu", .data = &rk3036_vpu_variant, },
|
|
{ .compatible = "rockchip,rk3066-vpu", .data = &rk3066_vpu_variant, },
|
|
{ .compatible = "rockchip,rk3288-vpu", .data = &rk3288_vpu_variant, },
|
|
diff --git a/drivers/staging/media/hantro/hantro_hw.h b/drivers/staging/media/hantro/hantro_hw.h
|
|
index 9296624654a6..df7b5e3a57b9 100644
|
|
--- a/drivers/staging/media/hantro/hantro_hw.h
|
|
+++ b/drivers/staging/media/hantro/hantro_hw.h
|
|
@@ -209,6 +209,7 @@ enum hantro_enc_fmt {
|
|
|
|
extern const struct hantro_variant imx8mq_vpu_g2_variant;
|
|
extern const struct hantro_variant imx8mq_vpu_variant;
|
|
+extern const struct hantro_variant px30_vpu_variant;
|
|
extern const struct hantro_variant rk3036_vpu_variant;
|
|
extern const struct hantro_variant rk3066_vpu_variant;
|
|
extern const struct hantro_variant rk3288_vpu_variant;
|
|
diff --git a/drivers/staging/media/hantro/rockchip_vpu_hw.c b/drivers/staging/media/hantro/rockchip_vpu_hw.c
|
|
index e4e3b5e7689b..d4f52957cc53 100644
|
|
--- a/drivers/staging/media/hantro/rockchip_vpu_hw.c
|
|
+++ b/drivers/staging/media/hantro/rockchip_vpu_hw.c
|
|
@@ -548,3 +548,20 @@ const struct hantro_variant rk3399_vpu_variant = {
|
|
.clk_names = rockchip_vpu_clk_names,
|
|
.num_clocks = ARRAY_SIZE(rockchip_vpu_clk_names)
|
|
};
|
|
+
|
|
+const struct hantro_variant px30_vpu_variant = {
|
|
+ .enc_offset = 0x0,
|
|
+ .enc_fmts = rockchip_vpu_enc_fmts,
|
|
+ .num_enc_fmts = ARRAY_SIZE(rockchip_vpu_enc_fmts),
|
|
+ .dec_offset = 0x400,
|
|
+ .dec_fmts = rk3399_vpu_dec_fmts,
|
|
+ .num_dec_fmts = ARRAY_SIZE(rk3399_vpu_dec_fmts),
|
|
+ .codec = HANTRO_JPEG_ENCODER | HANTRO_MPEG2_DECODER |
|
|
+ HANTRO_VP8_DECODER | HANTRO_H264_DECODER,
|
|
+ .codec_ops = rk3399_vpu_codec_ops,
|
|
+ .irqs = rockchip_vpu2_irqs,
|
|
+ .num_irqs = ARRAY_SIZE(rockchip_vpu2_irqs),
|
|
+ .init = rk3036_vpu_hw_init,
|
|
+ .clk_names = rockchip_vpu_clk_names,
|
|
+ .num_clocks = ARRAY_SIZE(rockchip_vpu_clk_names)
|
|
+};
|