drm: rockchip: CONFIG_DRM_FBDEV_EMULATION will crash the HDMI down sometimes

Mark yao mark.yao at rock-chips.com
Tue Jan 17 00:25:07 PST 2017


static void vop_plane_atomic_update(struct drm_plane *plane,
         struct drm_plane_state *old_state)
{
     if (WARN_ON(!vop->is_enabled))
         return;

The issues seems vop is not enable. but commit planes is using 
DRM_PLANE_COMMIT_ACTIVE_ONLY...

Hi Randy

Can you add some print for this bug:
     1, I think vop_crtc_enable function should be call before 
vop_plane_atomic_update, you can add some print to verified it.
     2, also add a trace on vop_crtc_disable.
     3, print the status of  crtc->state->active and 
plane_crtc_active(plane->state) when bug happen.

Thanks.
On 2017年01月17日 15:58, Randy Li wrote:
> Hello:
>   I want to enable the video output at RK3288 Firefly board, but I 
> found if I enable CONFIG_DRM_FBDEV_EMULATION, the HDMI would crash 
> down sometimes but sometimes it works. After disable that opinion, I 
> never meet a problem. I have not verified it with eDP as I meet a big 
> problem in there.
>
> [  OK  ] Stopped LSB: Load kernel modules needed to enable cpufreq 
> scaling.
> [   33.282843] [drm:drm_atomic_helper_commit_cleanup_done 
> [drm_kms_helper]] *ERROR* [CRTC:27:crtc-0] flip_done timed out
> [   33.361489] ------------[ cut here ]------------
> [   33.366251] WARNING: CPU: 2 PID: 476 at 
> /home/ayaka/workspace/rk3288/kernel/linux-kernel/drivers/gpu/drm/rockchip/rockchip_drm$
> vop.c:730 vop_plane_atomic_update+0x1218/0x177c [rockchipdrm]
> [   33.383071] Modules linked in: rockchip_vop_reg rockchipdrm 
> dw_hdmi_rockchip dw_hdmi drm_kms_helper cfbfillrect mali_kbase sys$
> opyarea gpio_ir_recv cfbimgblt sysfillrect rc_core dwc2 sysimgblt 
> fb_sys_fops panel_simple cfbcopyarea rk_crypto drm nvmem_rockch$
> p_efuse udc_core des_generic phy_rockchip_usb pwm_rockchip pwm_bl 
> backlight fb
> [   33.412751] CPU: 2 PID: 476 Comm: X Tainted: G        W 
> 4.10.0-rc3-next-20170111+ #148
> [   33.421182] Hardware name: Rockchip (Device Tree)
> [   33.425905] [<c0112b98>] (unwind_backtrace) from [<c010dab8>] 
> (show_stack+0x20/0x24)
> [   33.433652] [<c010dab8>] (show_stack) from [<c044973c>] 
> (dump_stack+0x8c/0xa0)
> [   33.440881] [<c044973c>] (dump_stack) from [<c0125f88>] 
> (__warn+0xf8/0x110)
> [   33.447839] [<c0125f88>] (__warn) from [<c01260b8>] 
> (warn_slowpath_null+0x30/0x38)
> [   33.455431] [<c01260b8>] (warn_slowpath_null) from [<bf5cb4dc>] 
> (vop_plane_atomic_update+0x1218/0x177c [rockchipdrm])
> [   33.466126] [<bf5cb4dc>] (vop_plane_atomic_update [rockchipdrm]) 
> from [<bf4d8590>] (drm_atomic_helper_commit_planes+0xd4/0x2b8
> [drm_kms_helper])
> [   33.479160] [<bf4d8590>] (drm_atomic_helper_commit_planes 
> [drm_kms_helper]) from [<bf5c6a88>] (rockchip_atomic_commit_tail+0x4$
> /0x68 [rockchipdrm])
> [   33.492451] [<bf5c6a88>] (rockchip_atomic_commit_tail 
> [rockchipdrm]) from [<bf4dc714>] (commit_tail+0x50/0xb8 [drm_kms_helper]$
> [   33.504061] [<bf4dc714>] (commit_tail [drm_kms_helper]) from 
> [<bf4dc870>] (drm_atomic_helper_commit+0xd4/0x13c [drm_kms_helper$
> )
> [   33.515850] [<bf4dc870>] (drm_atomic_helper_commit 
> [drm_kms_helper]) from [<bf09318c>] (drm_atomic_commit+0x5c/0x68 [drm])
> [   33.527126] [<bf09318c>] (drm_atomic_commit [drm]) from 
> [<bf4e00f8>] (restore_fbdev_mode+0x160/0x300 [drm_kms_helper])
> [   33.537952] [<bf4e00f8>] (restore_fbdev_mode [drm_kms_helper]) from 
> [<bf4e171c>] (drm_fb_helper_restore_fbdev_mode_unlocked+0x$
> 0/0x84 [drm_kms_helper])
> [   33.551590] [<bf4e171c>] (drm_fb_helper_restore_fbdev_mode_unlocked 
> [drm_kms_helper]) from [<bf5c6218>] (rockchip_drm_lastclos$
> +0x1c/0x20 [rockchipdrm])
> [   33.565404] [<bf5c6218>] (rockchip_drm_lastclose [rockchipdrm]) 
> from [<bf07d20c>] (drm_lastclose+0x48/0xd8 [drm])
> [   33.575977] [<bf07d20c>] (drm_lastclose [drm]) from [<bf07d560>] 
> (drm_release+0x2c4/0x36c [drm])
> [   33.584927] [<bf07d560>] (drm_release [drm]) from [<c02d7b34>] 
> (__fput+0x9c/0x1e8)
> [   33.592501] [<c02d7b34>] (__fput) from [<c02d7cf0>] 
> (____fput+0x18/0x1c)
> [   33.599206] [<c02d7cf0>] (____fput) from [<c0146ed4>] 
> (task_work_run+0xcc/0xf0)
> [   33.606519] [<c0146ed4>] (task_work_run) from [<c010d1b0>] 
> (do_work_pending+0xd0/0xd4)
> [   33.614439] [<c010d1b0>] (do_work_pending) from [<c0108e28>] 
> (slow_work_pending+0xc/0x20)
> [   33.622674] ---[ end trace 95ed2c3f167607d2 ]---
> [   33.627327] ------------[ cut here ]------------
> [   33.632013] WARNING: CPU: 2 PID: 476 at 
> /home/ayaka/workspace/rk3288/kernel/linux-kernel/drivers/gpu/drm/rockchip/rockchip_drm_
> vop.c:1017 vop_crtc_atomic_flush+0x27c/0x2b8 [rockchipdrm]
> [   33.648542] Modules linked in: rockchip_vop_reg rockchipdrm 
> dw_hdmi_rockchip dw_hdmi drm_kms_helper cfbfillrect mali_kbase sysc
> opyarea gpio_ir_recv cfbimgblt sysfillrect rc_core dwc2 sysimgblt 
> fb_sys_fops panel_simple cfbcopyarea rk_crypto drm nvmem_rockchi
> p_efuse udc_core des_generic phy_rockchip_usb pwm_rockchip pwm_bl 
> backlight fb
> [   33.678191] CPU: 2 PID: 476 Comm: X Tainted: G        W 
> 4.10.0-rc3-next-20170111+ #148
> [   33.686621] Hardware name: Rockchip (Device Tree)
> [   33.691339] [<c0112b98>] (unwind_backtrace) from [<c010dab8>] 
> (show_stack+0x20/0x24)
> [   33.699084] [<c010dab8>] (show_stack) from [<c044973c>] 
> (dump_stack+0x8c/0xa0)
> [   33.706309] [<c044973c>] (dump_stack) from [<c0125f88>] 
> (__warn+0xf8/0x110)
> [   33.713275] [<c0125f88>] (__warn) from [<c01260b8>] 
> (warn_slowpath_null+0x30/0x38)
> [   33.720864] [<c01260b8>] (warn_slowpath_null) from [<bf5c83e0>] 
> (vop_crtc_atomic_flush+0x27c/0x2b8 [rockchipdrm])
> [   33.731208] [<bf5c83e0>] (vop_crtc_atomic_flush [rockchipdrm]) from 
> [<bf4d868c>] (drm_atomic_helper_commit_planes+0x1d0/0x2b8 [
> drm_kms_helper])
> [   33.744159] [<bf4d868c>] (drm_atomic_helper_commit_planes 
> [drm_kms_helper]) from [<bf5c6a88>] (rockchip_atomic_commit_tail+0x44
> /0x68 [rockchipdrm])
> [   33.757451] [<bf5c6a88>] (rockchip_atomic_commit_tail 
> [rockchipdrm]) from [<bf4dc714>] (commit_tail+0x50/0xb8 [drm_kms_helper])
> [   33.769064] [<bf4dc714>] (commit_tail [drm_kms_helper]) from 
> [<bf4dc870>] (drm_atomic_helper_commit+0xd4/0x13c [drm_kms_helper]
> )
> [   33.780861] [<bf4dc870>] (drm_atomic_helper_commit 
> [drm_kms_helper]) from [<bf09318c>] (drm_atomic_commit+0x5c/0x68 [drm])
> [   33.792131] [<bf09318c>] (drm_atomic_commit [drm]) from 
> [<bf4e00f8>] (restore_fbdev_mode+0x160/0x300 [drm_kms_helper])
> [   33.802956] [<bf4e00f8>] (restore_fbdev_mode [drm_kms_helper]) from 
> [<bf4e171c>] (drm_fb_helper_restore_fbdev_mode_unlocked+0x4
> 0/0x84 [drm_kms_helper])
> [   33.816590] [<bf4e171c>] (drm_fb_helper_restore_fbdev_mode_unlocked 
> [drm_kms_helper]) from [<bf5c6218>] (rockchip_drm_lastclose
> +0x1c/0x20 [rockchipdrm])
> [   33.830406] [<bf5c6218>] (rockchip_drm_lastclose [rockchipdrm]) 
> from [<bf07d20c>] (drm_lastclose+0x48/0xd8 [drm])
> [   33.840975] [<bf07d20c>] (drm_lastclose [drm]) from [<bf07d560>] 
> (drm_release+0x2c4/0x36c [drm])
> [   33.849923] [<bf07d560>] (drm_release [drm]) from [<c02d7b34>] 
> (__fput+0x9c/0x1e8)
> [   33.857497] [<c02d7b34>] (__fput) from [<c02d7cf0>] 
> (____fput+0x18/0x1c)
> [   33.864201] [<c02d7cf0>] (____fput) from [<c0146ed4>] 
> (task_work_run+0xcc/0xf0)
> [   33.871514] [<c0146ed4>] (task_work_run) from [<c010d1b0>] 
> (do_work_pending+0xd0/0xd4)
> [   33.879434] [<c010d1b0>] (do_work_pending) from [<c0108e28>] 
> (slow_work_pending+0xc/0x20)
> [   33.887671] ---[ end trace 95ed2c3f167607d3 ]---
> [   33.892322] ------------[ cut here ]------------
> [   33.897058] WARNING: CPU: 2 PID: 476 at 
> /home/ayaka/workspace/rk3288/kernel/linux-kernel/drivers/gpu/drm/drm_atomic_helper.c:15
> 63 drm_atomic_helper_commit_hw_done+0xc0/0xc8 [drm_kms_helper]
> [   33.913937] Modules linked in: rockchip_vop_reg rockchipdrm 
> dw_hdmi_rockchip dw_hdmi drm_kms_helper cfbfillrect mali_kbase sysc
> opyarea gpio_ir_recv cfbimgblt sysfillrect rc_core dwc2 sysimgblt 
> fb_sys_fops panel_simple cfbcopyarea rk_crypto drm nvmem_rockchi
> p_efuse udc_core des_generic phy_rockchip_usb pwm_rockchip pwm_bl 
> backlight fb
> [   33.943581] CPU: 2 PID: 476 Comm: X Tainted: G        W 
> 4.10.0-rc3-next-20170111+ #148
> [   33.952010] Hardware name: Rockchip (Device Tree)
> [   33.956726] [<c0112b98>] (unwind_backtrace) from [<c010dab8>] 
> (show_stack+0x20/0x24)
> [   33.964470] [<c010dab8>] (show_stack) from [<c044973c>] 
> (dump_stack+0x8c/0xa0)
> [   33.971695] [<c044973c>] (dump_stack) from [<c0125f88>] 
> (__warn+0xf8/0x110)
> [   33.978661] [<c0125f88>] (__warn) from [<c01260b8>] 
> (warn_slowpath_null+0x30/0x38)
> [   33.986301] [<c01260b8>] (warn_slowpath_null) from [<bf4d9410>] 
> (drm_atomic_helper_commit_hw_done+0xc0/0xc8 [drm_kms_helper])
> [   33.997686] [<bf4d9410>] (drm_atomic_helper_commit_hw_done 
> [drm_kms_helper]) from [<bf5c6a90>] (rockchip_atomic_commit_tail+0x4
> c/0x68 [rockchipdrm])
> [   34.011062] [<bf5c6a90>] (rockchip_atomic_commit_tail 
> [rockchipdrm]) from [<bf4dc714>] (commit_tail+0x50/0xb8 [drm_kms_helper])
> [   34.022670] [<bf4dc714>] (commit_tail [drm_kms_helper]) from 
> [<bf4dc870>] (drm_atomic_helper_commit+0xd4/0x13c [drm_kms_helper]
> )
> [   34.034458] [<bf4dc870>] (drm_atomic_helper_commit 
> [drm_kms_helper]) from [<bf09318c>] (drm_atomic_commit+0x5c/0x68 [drm])
> [   34.045728] [<bf09318c>] (drm_atomic_commit [drm]) from 
> [<bf4e00f8>] (restore_fbdev_mode+0x160/0x300 [drm_kms_helper])
> [   34.056555] [<bf4e00f8>] (restore_fbdev_mode [drm_kms_helper]) from 
> [<bf4e171c>] (drm_fb_helper_restore_fbdev_mode_unlocked+0x4
> 0/0x84 [drm_kms_helper])
> [   34.070190] [<bf4e171c>] (drm_fb_helper_restore_fbdev_mode_unlocked 
> [drm_kms_helper]) from [<bf5c6218>] (rockchip_drm_lastclose
> +0x1c/0x20 [rockchipdrm])
> [   34.084005] [<bf5c6218>] (rockchip_drm_lastclose [rockchipdrm]) 
> from [<bf07d20c>] (drm_lastclose+0x48/0xd8 [drm])
> [   34.094581] [<bf07d20c>] (drm_lastclose [drm]) from [<bf07d560>] 
> (drm_release+0x2c4/0x36c [drm])
> [   34.103526] [<bf07d560>] (drm_release [drm]) from [<c02d7b34>] 
> (__fput+0x9c/0x1e8)
> [   34.111099] [<c02d7b34>] (__fput) from [<c02d7cf0>] 
> (____fput+0x18/0x1c)
> [   34.117802] [<c02d7cf0>] (____fput) from [<c0146ed4>] 
> (task_work_run+0xcc/0xf0)
> [   34.125115] [<c0146ed4>] (task_work_run) from [<c010d1b0>] 
> (do_work_pending+0xd0/0xd4)
> [   34.133034] [<c010d1b0>] (do_work_pending) from [<c0108e28>] 
> (slow_work_pending+0xc/0x20)
> [   34.141250] ---[ end trace 95ed2c3f167607d4 ]---
> [   34.145921] ------------[ cut here ]------------
> [   34.150566] WARNING: CPU: 2 PID: 476 at 
> /home/ayaka/workspace/rk3288/kernel/linux-kernel/drivers/gpu/drm/rockchip/rockchip_drm_
> vop.c:828 vop_crtc_enable_vblank+0x1ac/0x1b4 [rockchipdrm]
> [   34.167054] Modules linked in: rockchip_vop_reg rockchipdrm 
> dw_hdmi_rockchip dw_hdmi drm_kms_helper cfbfillrect mali_kbase sysc
> opyarea gpio_ir_recv cfbimgblt sysfillrect rc_core dwc2 sysimgblt 
> fb_sys_fops panel_simple cfbcopyarea rk_crypto drm nvmem_rockchi
> p_efuse udc_core des_generic phy_rockchip_usb pwm_rockchip pwm_bl 
> backlight fb
> [   34.196651] CPU: 2 PID: 476 Comm: X Tainted: G        W 
> 4.10.0-rc3-next-20170111+ #148
> [   34.205078] Hardware name: Rockchip (Device Tree)
> [   34.209794] [<c0112b98>] (unwind_backtrace) from [<c010dab8>] 
> (show_stack+0x20/0x24)
> [   34.217538] [<c010dab8>] (show_stack) from [<c044973c>] 
> (dump_stack+0x8c/0xa0)
> [   34.224763] [<c044973c>] (dump_stack) from [<c0125f88>] 
> (__warn+0xf8/0x110)
> [   34.231729] [<c0125f88>] (__warn) from [<c01260b8>] 
> (warn_slowpath_null+0x30/0x38)
> [   34.239318] [<c01260b8>] (warn_slowpath_null) from [<bf5c7b7c>] 
> (vop_crtc_enable_vblank+0x1ac/0x1b4 [rockchipdrm])
> [   34.249693] [<bf5c7b7c>] (vop_crtc_enable_vblank [rockchipdrm]) 
> from [<bf5c61f0>] (rockchip_drm_crtc_enable_vblank+0x48/0x54 [r
> ockchipdrm])
> [   34.262378] [<bf5c61f0>] (rockchip_drm_crtc_enable_vblank 
> [rockchipdrm]) from [<bf07ff80>] (drm_vblank_enable+0x8c/0xf8 [drm])
> [   34.274077] [<bf07ff80>] (drm_vblank_enable [drm]) from 
> [<bf0800b4>] (drm_vblank_get+0xc8/0xf0 [drm])
> [   34.283616] [<bf0800b4>] (drm_vblank_get [drm]) from [<bf0800fc>] 
> (drm_crtc_vblank_get+0x20/0x24 [drm])
> [   34.293239] [<bf0800fc>] (drm_crtc_vblank_get [drm]) from 
> [<bf4dc00c>] (drm_atomic_helper_wait_for_vblanks.part.0+0xa8/0x2a8 [d
> rm_kms_helper])
> [   34.306146] [<bf4dc00c>] (drm_atomic_helper_wait_for_vblanks.part.0 
> [drm_kms_helper]) from [<bf4dc230>] (drm_atomic_helper_wait
> _for_vblanks+0x24/0x28 [drm_kms_helper])
> [   34.321176] [<bf4dc230>] (drm_atomic_helper_wait_for_vblanks 
> [drm_kms_helper]) from [<bf5c6a9c>] (rockchip_atomic_commit_tail+0
> x58/0x68 [rockchipdrm])
> [   34.334725] [<bf5c6a9c>] (rockchip_atomic_commit_tail 
> [rockchipdrm]) from [<bf4dc714>] (commit_tail+0x50/0xb8 [drm_kms_helper])
> [   34.346330] [<bf4dc714>] (commit_tail [drm_kms_helper]) from 
> [<bf4dc870>] (drm_atomic_helper_commit+0xd4/0x13c [drm_kms_helper]
> )
> [   34.358117] [<bf4dc870>] (drm_atomic_helper_commit 
> [drm_kms_helper]) from [<bf09318c>] (drm_atomic_commit+0x5c/0x68 [drm])
> [   34.369386] [<bf09318c>] (drm_atomic_commit [drm]) from 
> [<bf4e00f8>] (restore_fbdev_mode+0x160/0x300 [drm_kms_helper])
> [   34.380209] [<bf4e00f8>] (restore_fbdev_mode [drm_kms_helper]) from 
> [<bf4e171c>] (drm_fb_helper_restore_fbdev_mode_unlocked+0x4
> 0/0x84 [drm_kms_helper])
> [   34.393845] [<bf4e171c>] (drm_fb_helper_restore_fbdev_mode_unlocked 
> [drm_kms_helper]) from [<bf5c6218>] (rockchip_drm_lastclose
> +0x1c/0x20 [rockchipdrm])
> [   34.407664] [<bf5c6218>] (rockchip_drm_lastclose [rockchipdrm]) 
> from [<bf07d20c>] (drm_lastclose+0x48/0xd8 [drm])
> [   34.418237] [<bf07d20c>] (drm_lastclose [drm]) from [<bf07d560>] 
> (drm_release+0x2c4/0x36c [drm])
> [   34.427179] [<bf07d560>] (drm_release [drm]) from [<c02d7b34>] 
> (__fput+0x9c/0x1e8)
> [   34.434754] [<c02d7b34>] (__fput) from [<c02d7cf0>] 
> (____fput+0x18/0x1c)
> [   34.441458] [<c02d7cf0>] (____fput) from [<c0146ed4>] 
> (task_work_run+0xcc/0xf0)
> [   34.448769] [<c0146ed4>] (task_work_run) from [<c010d1b0>] 
> (do_work_pending+0xd0/0xd4)
> [   34.456688] [<c010d1b0>] (do_work_pending) from [<c0108e28>] 
> (slow_work_pending+0xc/0x20)
> [   34.464856] ---[ end trace 95ed2c3f167607d5 ]---


-- 
Mark Yao





More information about the linux-arm-kernel mailing list