[V7,0/8] Support multi-hardware jpeg decoder for MT8195

kyrie.wu kyrie.wu at mediatek.com
Thu Sep 8 00:27:53 PDT 2022


On Tue, 2022-09-06 at 16:22 +0200, Hans Verkuil wrote:
> Hi Irui,
> 
> On 26/08/2022 11:28, Irui Wang wrote:
> > From: kyrie wu <kyrie.wu at mediatek.com>
> > 
> > This series adds support for multi hardware jpeg decoding,
> > by first adding use of_platform_populate to manage each hardware
> > information: interrupt, clock, register bases and power.
> > Secondly add decoding work queue to deal with the decoding requests
> > of multi-hardware at the same time. Lastly, add output picture
> > reorder function interface to eliminate the out of order images.
> > 
> > This series has been tested with both MT8195.
> > Decoding worked for this chip.
> 
> When building this I get the following sparse warning and several
> kerneldoc
> warnings:
> 
> SPARSE:drivers/media/platform/mediatek/jpeg/mtk_jpeg_dec_hw.c:661:24:
> warning: symbol 'mtk_jpegdec_hw_driver' was not declared. Should it
> be static?
> 
> kerneldoc: WARNINGS
> drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.h:127: warning:
> Function parameter or member 'clks' not described in
> 'mtk_jpegdec_clk'
> drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.h:127: warning:
> Function parameter or member 'clk_num' not described in
> 'mtk_jpegdec_clk'
> drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.h:178: warning:
> Function parameter or member 'job_timeout_work' not described in
> 'mtk_jpegdec_comp_dev'
> drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.h:178: warning:
> Function parameter or member 'hw_param' not described in
> 'mtk_jpegdec_comp_dev'
> drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.h:178: warning:
> Function parameter or member 'hw_state' not described in
> 'mtk_jpegdec_comp_dev'
> drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.h:178: warning:
> Function parameter or member 'hw_lock' not described in
> 'mtk_jpegdec_comp_dev'
> drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.h:219: warning:
> Function parameter or member 'reg_decbase' not described in
> 'mtk_jpeg_dev'
> drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.h:219: warning:
> Function parameter or member 'dec_hw_dev' not described in
> 'mtk_jpeg_dev'
> drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.h:219: warning:
> Function parameter or member 'is_jpgdec_multihw' not described in
> 'mtk_jpeg_dev'
> drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.h:219: warning:
> Function parameter or member 'dec_hw_wq' not described in
> 'mtk_jpeg_dev'
> drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.h:219: warning:
> Function parameter or member 'dec_workqueue' not described in
> 'mtk_jpeg_dev'
> drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.h:219: warning:
> Function parameter or member 'dechw_rdy' not described in
> 'mtk_jpeg_dev'
> 
> Can you fix this in a v8?
> 
> BTW, you can also choose to combine the jpeg encoder series with this
> series into one single series.
> I'll be merging them together anyway. That's up to you, though.
> 
> Regards,
> 
> 	Hans

Hi Hans,

I will fix those problems you mentioned above,
and decoder patches & encoder patches would be combined to only one
series in the next version.

Thanks.

Regards,

kyrie.
> 
> > 
> > Patch 1 Adds jpeg decoder dt-bindings for mt8195
> > 
> > Patches 2 jpeg decoder builds three module for using Multi-HW,
> > export some functions to make them visible by other modules.
> > 
> > Patch 3 use of_platform_populate to manage multi-hardware.
> > 
> > Patch 4 add jpeg decoding timeout function to judge hardware
> > timeout.
> > 
> > Patch 5 add decoding work queue to deal with multi-hardware
> > decoding
> > at the same time.
> > 
> > Patch 6 add output picture reorder function to order images.
> > 
> > Patch 7 refactor jpegdec func interface for HW working.
> > 
> > Patch 8 add stop cmd function to deal with EOS operation.
> > 
> > ---
> > This series patches dependent on:
> > media_stage tree:
> > [1]
> > 
https://urldefense.com/v3/__https://git.linuxtv.org/media_stage.git/commit/?id=b3627647f9ea7473d10fb08a95fd7c4133a17ca4__;!!CTRNKA9wMg0ARbw!yWsNB0KDQUXPazES9aQVbOQCfVz3QXxMu8-1qBsF7ln07u35A2YPzpAMfUd3dJQt$
> >  
> > 
> > patch1 new jpegdec dt-bindings included files
> > [2] MM IOMMU binding:
> > 
https://urldefense.com/v3/__https://patchwork.kernel.org/project/linux-mediatek/patch/20220217113453.13658-2-yong.wu@mediatek.com/__;!!CTRNKA9wMg0ARbw!yWsNB0KDQUXPazES9aQVbOQCfVz3QXxMu8-1qBsF7ln07u35A2YPzpAMfZHUWeCB$
> >  
> > 
> > [3] MT8195 power domain:
> > 
https://urldefense.com/v3/__https://patchwork.kernel.org/project/linux-mediatek/list/?series=580579__;!!CTRNKA9wMg0ARbw!yWsNB0KDQUXPazES9aQVbOQCfVz3QXxMu8-1qBsF7ln07u35A2YPzpAMfSYzdPjN$
> >  
> > 
> > Changes compared with v6:
> > - some modifications for patch v6's review comments.
> > 
> > Changes compared with v5:
> > - some modifications for patch v5's review comments.
> > - fix yaml file check errors.
> > 
> > Changes compared with v4:
> > - some modifications for patch v4's review comments.
> > - fix Gstreamer test errors.
> > 
> > Changes compared with v3:
> > - some modifications for patch v3's review comments.
> > 
> > Changes compared with v2:
> > - add stop cmd function.
> > - some modifications for patch v1's review comments.
> > 
> > Changes compared with v1:
> > - new yaml file for mt8195 jpeg decoder.
> > - some modifications for patch v1's review comments.
> > 
> > kyrie wu (8):
> >   dt-bindings: mediatek: Add mediatek,mt8195-jpgdec compatible
> >   media: mtk-jpegdec: export jpeg decoder functions
> >   media: mtk-jpegdec: support jpegdec multi-hardware
> >   media: mtk-jpegdec: add jpegdec timeout func interface
> >   media: mtk-jpegdec: add jpeg decode worker interface
> >   media: mtk-jpegdec: add output pic reorder interface
> >   media: mtk-jpegdec: refactor jpegdec func interface
> >   mtk-jpegdec: add stop cmd interface for jpgdec
> > 
> >  .../media/mediatek,mt8195-jpegdec.yaml        | 169 ++++++++++
> >  drivers/media/platform/mediatek/jpeg/Makefile |   5 +-
> >  .../platform/mediatek/jpeg/mtk_jpeg_core.c    | 233 ++++++++++++-
> >  .../platform/mediatek/jpeg/mtk_jpeg_core.h    |  46 +++
> >  .../platform/mediatek/jpeg/mtk_jpeg_dec_hw.c  | 314
> > ++++++++++++++++--
> >  .../platform/mediatek/jpeg/mtk_jpeg_dec_hw.h  |   3 +-
> >  .../platform/mediatek/jpeg/mtk_jpeg_dec_reg.h |   1 +
> >  7 files changed, 739 insertions(+), 32 deletions(-)
> >  create mode 100644
> > Documentation/devicetree/bindings/media/mediatek,mt8195-
> > jpegdec.yaml
> > 
> 
> 




More information about the linux-arm-kernel mailing list