devicetree.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: "Yunfei Dong (董云飞)" <Yunfei.Dong@mediatek.com>
To: "nhebert@chromium.org" <nhebert@chromium.org>,
	"benjamin.gaignard@collabora.com"
	<benjamin.gaignard@collabora.com>,
	"nfraprado@collabora.com" <nfraprado@collabora.com>,
	"angelogioacchino.delregno@collabora.com" 
	<angelogioacchino.delregno@collabora.com>,
	"nicolas.dufresne@collabora.com" <nicolas.dufresne@collabora.com>,
	"hverkuil-cisco@xs4all.nl" <hverkuil-cisco@xs4all.nl>
Cc: "linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
	"linux-mediatek@lists.infradead.org" 
	<linux-mediatek@lists.infradead.org>,
	"frkoenig@chromium.org" <frkoenig@chromium.org>,
	"stevecho@chromium.org" <stevecho@chromium.org>,
	"wenst@chromium.org" <wenst@chromium.org>,
	"linux-media@vger.kernel.org" <linux-media@vger.kernel.org>,
	"devicetree@vger.kernel.org" <devicetree@vger.kernel.org>,
	"daniel@ffwll.ch" <daniel@ffwll.ch>,
	Project_Global_Chrome_Upstream_Group 
	<Project_Global_Chrome_Upstream_Group@mediatek.com>,
	"hsinyi@chromium.org" <hsinyi@chromium.org>,
	"linux-arm-kernel@lists.infradead.org" 
	<linux-arm-kernel@lists.infradead.org>
Subject: Re: [PATCH v6,0/11] media: mediatek: vcodec: separate encoder and decoder
Date: Sat, 22 Jul 2023 07:54:23 +0000	[thread overview]
Message-ID: <1d1f85566566a00a6a9a33b54d8634a2b3f988d9.camel@mediatek.com> (raw)
In-Reply-To: <7917efd2-7b37-66c6-5213-3bfab192a76b@xs4all.nl>

Hi Hans,

Thanks for your help.
On Fri, 2023-07-21 at 17:09 +0200, Hans Verkuil wrote:
>  	 
> External email : Please do not click links or open attachments until
> you have verified the sender or the content.
>  Hi Yunfei Dong,
> 
> On 04/07/2023 15:13, Yunfei Dong wrote:
> > With the driver more and more complex, encoder and decoder need to
> add more parameter
> > in shared struct 'mtk_vcodec_ctx' and 'mtk_vcodec_dev'. Encoder use
> about 40% and
> > decoder use 60% parameter. Need to allocate extra unused memory
> when encoder and decoder
> > working.
> > 
> > Separate encoder and decoder in different folder and use
> independent data struct.
> > 
> > patch 1 remove unused parameter.
> > patch 2~3 align fw and interrupt related interface.
> > patch 4~6 remove the dependency of debug log
> > patch 7~8 separate mtk_vcodec_ctx and mtk_vcodec_dev
> > patch 9 fix unreasonable parameter
> > patch 10 removed unused header files
> > patch 11 separate encoder and decoder in different folder
> 
> There were quite a few vcodec patches that still used the old
> location of
> these sources, so I decided to make PRs for those first.
> 
> That means that you need to rebase all your current patch series on
> top
> of that.
> 
> My tree with the pending patches is here:
> 
> https://git.linuxtv.org/hverkuil/media_tree.git/log/?h=for-v6.6g
> 
> Your set of patches that need to be rebased are here in patchwork:
> 
> 
https://patchwork.linuxtv.org/project/linux-media/list/?submitter=7655
> 
> I basically had a choice of either taking your patches, and then
> having
> to ask a lot of people to rebase their work, or take theirs first,
> and
> only asking one person, you, to rebase. So I went with the latter
> choice.
> 
> You can choose whether to post a single patchseries for all 16
> patches,
> or just post a v7 for the first and v2 for the other two patchseries.
> Up to you.
> 
> I do promise to process your the rebased series as soon as possible
> to avoid more conflicts.
> 
> Regards,
> 
> Hans
> 
I resend these patches based on your v6.6g branch.

For the first two patches need to be changed again, I send the patch
based on commit (e5408c1053e3: media: mediatek: vcodec: Return NULL if
no vdec_fd is found).

Please help to check it again.

Best Regards,
Yunfei Dong

> > ---
> > Changed from v5:
> > - fix some words error for patch 3/6/11.
> > - rename mtk_vcodec_comm_drv.h to mtk_vcodec_cmn_drv.h for patch 7.
> > Changed from v4:
> > - add one parameter to record register base for reg_base for patch
> 3.
> > - add debug string for non ctx log for patch 6.
> > - change the comment of struct mtk_vcodec_dec_ctx and struct
> mtk_vcodec_enc_ctx for patch 7.
> > - prefer to use struct mtk_vcodec_dec_dev an current period, will
> re-construct in the future for patch 8.
> > Changed from v3:
> > - re-write commit message for patch 3.
> > Changed from v2:
> > - This patch main changed:
> >   1: add different macro mtk_dec_debug and mtk_enc_debug calling
> common
> >      macro mtk_vcodec_debug in order to use dev_dbg instead of
> pr_debug.
> >   2: add different macro mtk_v4l2_venc_dbg and mtk_v4l2_vdec_dbg
> calling common
> >      macro  in order to use dev_dbg instead of pr_debug.
> > Changed from v1:
> > - Change pr_dbg to dev_dbg for mtk_v4l2_level and mtk_vcodec_dbg
> for patch 4.
> > - Change pr_err to dev_err for mtk_v4l2_err and mtk_vcodec_err for
> patch 5.
> > - Fix unreasonable parameter for patch 8.
> > ---
> > Yunfei Dong (11):
> >   media: mediatek: vcodec: remove unused parameter
> >   media: mediatek: vcodec: align fw interface
> >   media: mediatek: vcodec: Removing struct 'mtk_vcodec_ctx/dev' for
> >     shared interface
> >   media: mediatek: vcodec: Removing useless debug log
> >   media: mediatek: vcodec: remove the dependency of vcodec debug
> log
> >   media: mediatek: vcodec: replace pr_* with dev_* for v4l2 debug
> >     message
> >   media: mediatek: vcodec: separate struct 'mtk_vcodec_ctx'
> >   media: mediatek: vcodec: separate struct mtk_vcodec_dev
> >   media: mediatek: vcodec: fix unreasonable parameter definition
> and
> >     style
> >   media: mediatek: vcodec: remove unused include header
> >   media: mediatek: vcodec: separate decoder and encoder
> > 
> >  .../media/platform/mediatek/vcodec/Makefile   |  55 +-
> >  .../platform/mediatek/vcodec/common/Makefile  |  21 +
> >  .../vcodec/common/mtk_vcodec_cmn_drv.h        | 147 +++++
> >  .../vcodec/{ => common}/mtk_vcodec_dbgfs.c    |  57 +-
> >  .../vcodec/{ => common}/mtk_vcodec_dbgfs.h    |  24 +-
> >  .../vcodec/{ => common}/mtk_vcodec_fw.c       |  21 +-
> >  .../vcodec/{ => common}/mtk_vcodec_fw.h       |   8 +-
> >  .../vcodec/{ => common}/mtk_vcodec_fw_priv.h  |  14 +-
> >  .../vcodec/{ => common}/mtk_vcodec_fw_scp.c   |  26 +-
> >  .../vcodec/{ => common}/mtk_vcodec_fw_vpu.c   |  64 +-
> >  .../mediatek/vcodec/common/mtk_vcodec_intr.c  |  68 +++
> >  .../vcodec/{ => common}/mtk_vcodec_intr.h     |   6 +-
> >  .../vcodec/{ => common}/mtk_vcodec_util.c     |  67 +--
> >  .../mediatek/vcodec/common/mtk_vcodec_util.h  |  73 +++
> >  .../platform/mediatek/vcodec/decoder/Makefile |  25 +
> >  .../vcodec/{ => decoder}/mtk_vcodec_dec.c     | 182 +++---
> >  .../vcodec/{ => decoder}/mtk_vcodec_dec.h     |  10 +-
> >  .../vcodec/{ => decoder}/mtk_vcodec_dec_drv.c |  84 ++-
> >  .../vcodec/decoder/mtk_vcodec_dec_drv.h       | 315 ++++++++++
> >  .../vcodec/{ => decoder}/mtk_vcodec_dec_hw.c  |  19 +-
> >  .../vcodec/{ => decoder}/mtk_vcodec_dec_hw.h  |   6 +-
> >  .../vcodec/{ => decoder}/mtk_vcodec_dec_pm.c  |  38 +-
> >  .../vcodec/{ => decoder}/mtk_vcodec_dec_pm.h  |   6 +-
> >  .../{ => decoder}/mtk_vcodec_dec_stateful.c   | 176 +++---
> >  .../{ => decoder}/mtk_vcodec_dec_stateless.c  |  91 +--
> >  .../{ => decoder}/vdec/vdec_av1_req_lat_if.c  | 158 +++--
> >  .../vcodec/{ => decoder}/vdec/vdec_h264_if.c  |  79 ++-
> >  .../{ => decoder}/vdec/vdec_h264_req_common.c |   4 +-
> >  .../{ => decoder}/vdec/vdec_h264_req_common.h |   6 +-
> >  .../{ => decoder}/vdec/vdec_h264_req_if.c     |  75 ++-
> >  .../vdec/vdec_h264_req_multi_if.c             | 157 +++--
> >  .../vdec/vdec_hevc_req_multi_if.c             | 129 ++---
> >  .../vcodec/{ => decoder}/vdec/vdec_vp8_if.c   |  72 ++-
> >  .../{ => decoder}/vdec/vdec_vp8_req_if.c      |  81 ++-
> >  .../vcodec/{ => decoder}/vdec/vdec_vp9_if.c   | 132 ++---
> >  .../{ => decoder}/vdec/vdec_vp9_req_lat_if.c  | 129 ++---
> >  .../vcodec/{ => decoder}/vdec_drv_base.h      |   2 +-
> >  .../vcodec/{ => decoder}/vdec_drv_if.c        |  12 +-
> >  .../vcodec/{ => decoder}/vdec_drv_if.h        |  10 +-
> >  .../vcodec/{ => decoder}/vdec_ipi_msg.h       |   0
> >  .../vcodec/{ => decoder}/vdec_msg_queue.c     |  64 +-
> >  .../vcodec/{ => decoder}/vdec_msg_queue.h     |  14 +-
> >  .../vcodec/{ => decoder}/vdec_vpu_if.c        |  57 +-
> >  .../vcodec/{ => decoder}/vdec_vpu_if.h        |   6 +-
> >  .../platform/mediatek/vcodec/encoder/Makefile |  11 +
> >  .../vcodec/{ => encoder}/mtk_vcodec_enc.c     | 296 +++++-----
> >  .../vcodec/{ => encoder}/mtk_vcodec_enc.h     |  12 +-
> >  .../vcodec/{ => encoder}/mtk_vcodec_enc_drv.c |  73 +--
> >  .../vcodec/encoder/mtk_vcodec_enc_drv.h       | 246 ++++++++
> >  .../vcodec/{ => encoder}/mtk_vcodec_enc_pm.c  |  12 +-
> >  .../vcodec/{ => encoder}/mtk_vcodec_enc_pm.h  |   4 +-
> >  .../vcodec/{ => encoder}/venc/venc_h264_if.c  | 110 ++--
> >  .../vcodec/{ => encoder}/venc/venc_vp8_if.c   |  69 +--
> >  .../vcodec/{ => encoder}/venc_drv_base.h      |   4 +-
> >  .../vcodec/{ => encoder}/venc_drv_if.c        |  10 +-
> >  .../vcodec/{ => encoder}/venc_drv_if.h        |  11 +-
> >  .../vcodec/{ => encoder}/venc_ipi_msg.h       |   0
> >  .../vcodec/{ => encoder}/venc_vpu_if.c        |  75 +--
> >  .../vcodec/{ => encoder}/venc_vpu_if.h        |   3 +-
> >  .../platform/mediatek/vcodec/mtk_vcodec_drv.h | 548 --------------
> ----
> >  .../mediatek/vcodec/mtk_vcodec_intr.c         |  43 --
> >  .../mediatek/vcodec/mtk_vcodec_util.h         |  83 ---
> >  62 files changed, 2217 insertions(+), 2183 deletions(-)
> >  create mode 100644
> drivers/media/platform/mediatek/vcodec/common/Makefile
> >  create mode 100644
> drivers/media/platform/mediatek/vcodec/common/mtk_vcodec_cmn_drv.h
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> common}/mtk_vcodec_dbgfs.c (76%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> common}/mtk_vcodec_dbgfs.h (62%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> common}/mtk_vcodec_fw.c (75%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> common}/mtk_vcodec_fw.h (86%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> common}/mtk_vcodec_fw_priv.h (75%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> common}/mtk_vcodec_fw_scp.c (70%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> common}/mtk_vcodec_fw_vpu.c (58%)
> >  create mode 100644
> drivers/media/platform/mediatek/vcodec/common/mtk_vcodec_intr.c
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> common}/mtk_vcodec_intr.h (68%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> common}/mtk_vcodec_util.c (55%)
> >  create mode 100644
> drivers/media/platform/mediatek/vcodec/common/mtk_vcodec_util.h
> >  create mode 100644
> drivers/media/platform/mediatek/vcodec/decoder/Makefile
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/mtk_vcodec_dec.c (83%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/mtk_vcodec_dec.h (91%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/mtk_vcodec_dec_drv.c (83%)
> >  create mode 100644
> drivers/media/platform/mediatek/vcodec/decoder/mtk_vcodec_dec_drv.h
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/mtk_vcodec_dec_hw.c (91%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/mtk_vcodec_dec_hw.h (92%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/mtk_vcodec_dec_pm.c (81%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/mtk_vcodec_dec_pm.h (61%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/mtk_vcodec_dec_stateful.c (73%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/mtk_vcodec_dec_stateless.c (84%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec/vdec_av1_req_lat_if.c (93%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec/vdec_h264_if.c (84%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec/vdec_h264_req_common.c (98%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec/vdec_h264_req_common.h (97%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec/vdec_h264_req_if.c (86%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec/vdec_h264_req_multi_if.c (85%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec/vdec_hevc_req_multi_if.c (90%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec/vdec_vp8_if.c (87%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec/vdec_vp8_req_if.c (81%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec/vdec_vp9_if.c (87%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec/vdec_vp9_req_lat_if.c (94%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec_drv_base.h (95%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec_drv_if.c (86%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec_drv_if.h (89%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec_ipi_msg.h (100%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec_msg_queue.c (82%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec_msg_queue.h (95%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec_vpu_if.c (79%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> decoder}/vdec_vpu_if.h (97%)
> >  create mode 100644
> drivers/media/platform/mediatek/vcodec/encoder/Makefile
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> encoder}/mtk_vcodec_enc.c (82%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> encoder}/mtk_vcodec_enc.h (78%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> encoder}/mtk_vcodec_enc_drv.c (86%)
> >  create mode 100644
> drivers/media/platform/mediatek/vcodec/encoder/mtk_vcodec_enc_drv.h
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> encoder}/mtk_vcodec_enc_pm.c (83%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> encoder}/mtk_vcodec_enc_pm.h (78%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> encoder}/venc/venc_h264_if.c (88%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> encoder}/venc/venc_vp8_if.c (88%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> encoder}/venc_drv_base.h (94%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> encoder}/venc_drv_if.c (86%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> encoder}/venc_drv_if.h (94%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> encoder}/venc_ipi_msg.h (100%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> encoder}/venc_vpu_if.c (82%)
> >  rename drivers/media/platform/mediatek/vcodec/{ =>
> encoder}/venc_vpu_if.h (96%)
> >  delete mode 100644
> drivers/media/platform/mediatek/vcodec/mtk_vcodec_drv.h
> >  delete mode 100644
> drivers/media/platform/mediatek/vcodec/mtk_vcodec_intr.c
> >  delete mode 100644
> drivers/media/platform/mediatek/vcodec/mtk_vcodec_util.h
> > 
> 
> 

      reply	other threads:[~2023-07-22  7:54 UTC|newest]

Thread overview: 15+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-07-04 13:13 [PATCH v6,0/11] media: mediatek: vcodec: separate encoder and decoder Yunfei Dong
2023-07-04 13:13 ` [PATCH v6,01/11] media: mediatek: vcodec: remove unused parameter Yunfei Dong
2023-07-04 13:13 ` [PATCH v6,02/11] media: mediatek: vcodec: align fw interface Yunfei Dong
2023-07-04 13:13 ` [PATCH v6,03/11] media: mediatek: vcodec: Removing struct 'mtk_vcodec_ctx/dev' for shared interface Yunfei Dong
2023-07-04 13:13 ` [PATCH v6,04/11] media: mediatek: vcodec: Removing useless debug log Yunfei Dong
2023-07-04 13:13 ` [PATCH v6,05/11] media: mediatek: vcodec: remove the dependency of vcodec " Yunfei Dong
2023-07-04 13:13 ` [PATCH v6,06/11] media: mediatek: vcodec: replace pr_* with dev_* for v4l2 debug message Yunfei Dong
2023-07-07 19:37   ` Nicolas Dufresne
2023-07-04 13:13 ` [PATCH v6,07/11] media: mediatek: vcodec: separate struct 'mtk_vcodec_ctx' Yunfei Dong
2023-07-04 13:13 ` [PATCH v6,08/11] media: mediatek: vcodec: separate struct mtk_vcodec_dev Yunfei Dong
2023-07-04 13:13 ` [PATCH v6,09/11] media: mediatek: vcodec: fix unreasonable parameter definition and style Yunfei Dong
2023-07-04 13:13 ` [PATCH v6,10/11] media: mediatek: vcodec: remove unused include header Yunfei Dong
2023-07-04 13:13 ` [PATCH v6,11/11] media: mediatek: vcodec: separate decoder and encoder Yunfei Dong
2023-07-21 15:09 ` [PATCH v6,0/11] media: mediatek: vcodec: separate encoder and decoder Hans Verkuil
2023-07-22  7:54   ` Yunfei Dong (董云飞) [this message]

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=1d1f85566566a00a6a9a33b54d8634a2b3f988d9.camel@mediatek.com \
    --to=yunfei.dong@mediatek.com \
    --cc=Project_Global_Chrome_Upstream_Group@mediatek.com \
    --cc=angelogioacchino.delregno@collabora.com \
    --cc=benjamin.gaignard@collabora.com \
    --cc=daniel@ffwll.ch \
    --cc=devicetree@vger.kernel.org \
    --cc=frkoenig@chromium.org \
    --cc=hsinyi@chromium.org \
    --cc=hverkuil-cisco@xs4all.nl \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-media@vger.kernel.org \
    --cc=linux-mediatek@lists.infradead.org \
    --cc=nfraprado@collabora.com \
    --cc=nhebert@chromium.org \
    --cc=nicolas.dufresne@collabora.com \
    --cc=stevecho@chromium.org \
    --cc=wenst@chromium.org \
    /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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).