00bbc813c2
[ Upstream commit e20ae5ae9f0c843aded4f06f3d1cab7384789e92 ] Right now, msm8998 video decoder (venus) is non-functional: $ time mpv --hwdec=v4l2m2m-copy --vd-lavc-software-fallback=no --vo=null --no-audio --untimed --length=30 --quiet demo-480.webm (+) Video --vid=1 (*) (vp9 854x480 29.970fps) Audio --aid=1 --alang=eng (*) (opus 2ch 48000Hz) [ffmpeg/video] vp9_v4l2m2m: output VIDIOC_REQBUFS failed: Connection timed out [ffmpeg/video] vp9_v4l2m2m: no v4l2 output context's buffers [ffmpeg/video] vp9_v4l2m2m: can't configure decoder Could not open codec. Software decoding fallback is disabled. Exiting... (Quit) Bryan O'Donoghue suggested the proper fix: - Set required register offsets in venus GDSC structs. - Set HW_CTRL flag. $ time mpv --hwdec=v4l2m2m-copy --vd-lavc-software-fallback=no --vo=null --no-audio --untimed --length=30 --quiet demo-480.webm (+) Video --vid=1 (*) (vp9 854x480 29.970fps) Audio --aid=1 --alang=eng (*) (opus 2ch 48000Hz) [ffmpeg/video] vp9_v4l2m2m: VIDIOC_G_FMT ioctl [ffmpeg/video] vp9_v4l2m2m: VIDIOC_G_FMT ioctl ... Using hardware decoding (v4l2m2m-copy). VO: [null] 854x480 nv12 Exiting... (End of file) real 0m3.315s user 0m1.277s sys 0m0.453s NOTES: GDSC = Globally Distributed Switch Controller Use same code as mmcc-msm8996 with: s/venus_gdsc/video_top_gdsc/ s/venus_core0_gdsc/video_subcore0_gdsc/ s/venus_core1_gdsc/video_subcore1_gdsc/ https://git.codelinaro.org/clo/la/kernel/msm-4.4/-/blob/caf_migration/kernel.lnx.4.4.r38-rel/include/dt-bindings/clock/msm-clocks-hwio-8996.h https://git.codelinaro.org/clo/la/kernel/msm-4.4/-/blob/caf_migration/kernel.lnx.4.4.r38-rel/include/dt-bindings/clock/msm-clocks-hwio-8998.h 0x1024 = MMSS_VIDEO GDSCR (undocumented) 0x1028 = MMSS_VIDEO_CORE_CBCR 0x1030 = MMSS_VIDEO_AHB_CBCR 0x1034 = MMSS_VIDEO_AXI_CBCR 0x1038 = MMSS_VIDEO_MAXI_CBCR 0x1040 = MMSS_VIDEO_SUBCORE0 GDSCR (undocumented) 0x1044 = MMSS_VIDEO_SUBCORE1 GDSCR (undocumented) 0x1048 = MMSS_VIDEO_SUBCORE0_CBCR 0x104c = MMSS_VIDEO_SUBCORE1_CBCR Fixes: d14b15b5931c2b ("clk: qcom: Add MSM8998 Multimedia Clock Controller (MMCC) driver") Reviewed-by: Bryan O'Donoghue <bryan.odonoghue@linaro.org> Signed-off-by: Marc Gonzalez <mgonzalez@freebox.fr> Reviewed-by: Jeffrey Hugo <quic_jhugo@quicinc.com> Link: https://lore.kernel.org/r/ff4e2e34-a677-4c39-8c29-83655c5512ae@freebox.fr Signed-off-by: Bjorn Andersson <andersson@kernel.org> Signed-off-by: Sasha Levin <sashal@kernel.org> |
||
---|---|---|
.. | ||
a53-pll.c | ||
apcs-msm8916.c | ||
apss-ipq-pll.c | ||
apss-ipq6018.c | ||
camcc-sdm845.c | ||
clk-alpha-pll.c | ||
clk-alpha-pll.h | ||
clk-branch.c | ||
clk-branch.h | ||
clk-cpu-8996.c | ||
clk-hfpll.c | ||
clk-hfpll.h | ||
clk-krait.c | ||
clk-krait.h | ||
clk-pll.c | ||
clk-pll.h | ||
clk-rcg.c | ||
clk-rcg.h | ||
clk-rcg2.c | ||
clk-regmap-divider.c | ||
clk-regmap-divider.h | ||
clk-regmap-mux-div.c | ||
clk-regmap-mux-div.h | ||
clk-regmap-mux.c | ||
clk-regmap-mux.h | ||
clk-regmap.c | ||
clk-regmap.h | ||
clk-rpm.c | ||
clk-rpmh.c | ||
clk-smd-rpm.c | ||
clk-spmi-pmic-div.c | ||
common.c | ||
common.h | ||
dispcc-sc7180.c | ||
dispcc-sdm845.c | ||
dispcc-sm8250.c | ||
gcc-apq8084.c | ||
gcc-ipq806x.c | ||
gcc-ipq4019.c | ||
gcc-ipq6018.c | ||
gcc-ipq8074.c | ||
gcc-mdm9615.c | ||
gcc-msm8660.c | ||
gcc-msm8916.c | ||
gcc-msm8939.c | ||
gcc-msm8960.c | ||
gcc-msm8974.c | ||
gcc-msm8994.c | ||
gcc-msm8996.c | ||
gcc-msm8998.c | ||
gcc-qcs404.c | ||
gcc-sc7180.c | ||
gcc-sdm660.c | ||
gcc-sdm845.c | ||
gcc-sm8150.c | ||
gcc-sm8250.c | ||
gdsc.c | ||
gdsc.h | ||
gpucc-msm8998.c | ||
gpucc-sc7180.c | ||
gpucc-sdm845.c | ||
gpucc-sm8150.c | ||
gpucc-sm8250.c | ||
hfpll.c | ||
Kconfig | ||
kpss-xcc.c | ||
krait-cc.c | ||
lcc-ipq806x.c | ||
lcc-mdm9615.c | ||
lcc-msm8960.c | ||
lpasscc-sdm845.c | ||
lpasscorecc-sc7180.c | ||
Makefile | ||
mmcc-apq8084.c | ||
mmcc-msm8960.c | ||
mmcc-msm8974.c | ||
mmcc-msm8996.c | ||
mmcc-msm8998.c | ||
mss-sc7180.c | ||
q6sstop-qcs404.c | ||
reset.c | ||
reset.h | ||
turingcc-qcs404.c | ||
videocc-sc7180.c | ||
videocc-sdm845.c | ||
videocc-sm8150.c | ||
videocc-sm8250.c |