Den 14.01.2019 16.00, skrev Noralf Trønnes: > > > Den 14.01.2019 03.15, skrev David Lechner: >> On 1/13/19 3:19 PM, David Lechner wrote: >>> On 1/11/19 2:12 PM, Noralf Trønnes wrote: >>>> This switches to drm_atomic_helper_dirtyfb() as the framebuffer dirty >>>> handler. All flushing will now happen in the pipe functions. >>>> >>>> Also enable the damage plane property for all except repaper which can >>>> only do full updates. >>>> >>>> ili9225: >>>> This change made ili9225_init() equal to mipi_dbi_init() so use it. >>>> >>>> v2: Remove fb check in mipi_dbi_enable_flush() it can't be NULL >>>> (kbuild test robot) >>>> >>>> Cc: David Lechner <david@xxxxxxxxxxxxxx> >>>> Cc: Eric Anholt <eric@xxxxxxxxxx> >>>> Signed-off-by: Noralf Trønnes <noralf@xxxxxxxxxxx> >>>> Acked-by: Sam Ravnborg <sam@xxxxxxxxxxxx> >>>> Acked-by: Daniel Vetter <daniel.vetter@xxxxxxxx> >>>> --- >>> >>> Tested-by: David Lechner <david@xxxxxxxxxxxxxx> >>> Reviewed-by: David Lechner <david@xxxxxxxxxxxxxx> >>> >>> Tested with ST7586 on LEGO MINDSTORMS EV3 and ILI9225 on >>> BeagleBone Green. (FWIW, I encounter other issues that had to >>> be fixed to make things work on both of these, but none were >>> actually related to this series.) >>> >> >> Actually, I have to take this back. It appears that the problems >> that I had on LEGO MINDSTORMS EV3 are actually caused by this >> series. I did a git bisect to be sure and ended up with this >> patch as the bad commit. I'm guessing that the damage helper >> must be causing some kind of memory corruption. Here is the >> crash I am getting: >> >> Unable to handle kernel NULL pointer dereference at virtual address >> 00000004 >> pgd = (ptrval) >> [00000004] *pgd=00000000 >> Internal error: Oops: 5 [#1] PREEMPT ARM >> Modules linked in: >> CPU: 0 PID: 1 Comm: swapper Not tainted 5.0.0-rc1-00125-ge9acadba5409 #1389 >> Hardware name: Generic DA850/OMAP-L138/AM18x >> PC is at rb_insert_color+0x1c/0x1a4 >> LR is at kernfs_link_sibling+0x94/0xcc >> pc : [<c04b95ec>] lr : [<c014bfdc>] psr: 60000013 >> sp : c2831b38 ip : 00000000 fp : c06b762c >> r10: 00000000 r9 : c06b835c r8 : 00000000 >> r7 : c2963f00 r6 : c066b028 r5 : c2016cc0 r4 : 00000000 >> r3 : 00000000 r2 : c2983010 r1 : c2963f2c r0 : c2016cd0 >> Flags: nZCv IRQs on FIQs on Mode SVC_32 ISA ARM Segment none >> Control: 0005317f Table: c0004000 DAC: 00000053 >> Process swapper (pid: 1, stack limit = 0x(ptrval)) >> Stack: (0xc2831b38 to 0xc2832000) >> 1b20: 00000000 >> c2016cc0 >> 1b40: c066b028 c014bfdc c2016cc0 c2963f00 c066b028 c014c768 c2963f00 >> c014c448 >> 1b60: 00000000 c2016cc0 c2963f00 c066b028 c2963f00 c014c860 00000000 >> 00000001 >> 1b80: c0589938 c2b4b408 00000000 c014ec70 00000000 c2b4b408 00000000 >> c04c4cb0 >> 1ba0: 0000070f 00000000 00000000 9fd04dd9 00000000 c2b4b408 c066b028 >> 00000000 >> 1bc0: c293ac98 c04b58f8 c059081c 00000000 c2b4b408 c066b028 00000000 >> 00000000 >> 1be0: 00000000 c04b5d64 c2831c08 9fd04dd9 c2b4b3c0 c293ac80 c2bd16c0 >> c2b4b408 >> 1c00: c00d650c c059081c c2bd16c0 c28e3a80 c2b4b3c0 00000000 c2b4b3c0 >> 00000000 >> 1c20: c06b7634 00020000 c06b835c c00d72f8 00000000 c00b0c24 00000000 >> 00000074 >> 1c40: c0590728 00000000 c0590728 c2b4b3c0 00000074 c0590728 00020000 >> 00000000 >> 1c60: c06b762c c00b0958 00000000 00380bc6 00000000 c06bbf1c c2bd9c00 >> c2bfe000 >> 1c80: c06bbf14 0000000c 00000000 00000000 c2831e0c c00b0a90 00000000 >> 00000000 >> 1ca0: 00000000 00000000 003b2580 c017d6e4 00000000 00000000 00000000 >> c2bfe000 >> 1cc0: c2bd9c00 00000000 003b2580 00000000 00000000 c01971a0 00001103 >> 00000000 >> 1ce0: c2bd8400 00000400 00000400 9fd04dd9 00000000 0000000a 00000002 >> 00000000 >> 1d00: ffffffff 00000000 ffffffff 00000000 00000000 00000001 00000a04 >> 00000032 >> 1d20: 00000000 0000000c 00000004 c00af550 c2bd9ecc 9fd04dd9 c2404480 >> c2bd9eb4 >> 1d40: c2bd8400 c2404480 00000002 00000001 00000000 00000000 00000001 >> 00000000 >> 1d60: 00000000 00000000 00000000 00000000 00000000 00000000 00000001 >> 00000000 >> 1d80: 00380bc6 00000000 003b257f 00000000 00000077 0000ffff 00000200 >> 00000002 >> 1da0: 00000001 0000ffff 00000000 00000401 c2bfe22c 00000000 00000000 >> 00000000 >> 1dc0: 00000000 00000000 c2012400 c24be100 00001000 00000000 c2404480 >> 00000000 >> 1de0: 00004003 9fd04dd9 00000000 c2bd9c00 c2404480 00000083 c24044fc >> 00008000 >> 1e00: 00000000 00000020 00008000 c00e4d88 c2404480 00000000 00000000 >> c0190afc >> 1e20: c2bd0be0 c0692898 c0692898 00000000 00000020 c0190b10 c0194f48 >> c2bd0be0 >> 1e40: c066b370 c00e568c c29f5380 c01002d4 c29f5380 c2bd0be0 00008000 >> c0100488 >> 1e60: c0692898 00000000 c066b028 c2bd0be0 c2bd0bc0 c01033ec 00000000 >> ffffff00 >> 1e80: ffff0a00 c0575ff4 c2bd0be0 c281a010 c2417098 c2bd0be0 0000000a >> 00000000 >> 1ea0: 0000000a 9fd04dd9 0000000a c2bd0be0 c2bd0bc0 00000000 c0575ff8 >> 00008000 >> 1ec0: c066b028 00008000 c0575ff4 c0104178 00000000 00000000 c2014000 >> c2014005 >> 1ee0: c0575ff8 c3fb1280 c0652868 c062b1ec 00000000 c01013d8 c24c3558 >> 00000000 >> 1f00: 00000000 00006180 c24c3558 c00f17c4 e10c76ac 0b300002 c2858015 >> c281a010 >> 1f20: c2415da8 9fd04dd9 00000000 00000002 c06ad310 c066b028 c066da68 >> 00000000 >> 1f40: 00000000 00000000 00000000 c062b478 00000000 c0037200 00306b6c >> 9fd00000 >> 1f60: c0576098 9fd04dd9 00000002 c06ad310 c0652878 00000000 00000000 >> 00000000 >> 1f80: 00000000 00000000 00000000 c062b5e4 00000000 00000000 00000000 >> 00000000 >> 1fa0: c04c7860 c04c7868 00000000 c00090e0 00000000 00000000 00000000 >> 00000000 >> 1fc0: 00000000 00000000 00000000 00000000 00000000 00000000 00000000 >> 00000000 >> 1fe0: 00000000 00000000 00000000 00000000 00000013 00000000 00000000 >> 00000000 >> [<c04b95ec>] (rb_insert_color) from [<c014bfdc>] >> (kernfs_link_sibling+0x94/0xcc) >> [<c014bfdc>] (kernfs_link_sibling) from [<c014c768>] >> (kernfs_add_one+0x90/0x140) >> [<c014c768>] (kernfs_add_one) from [<c014c860>] >> (kernfs_create_dir_ns+0x48/0x74) >> [<c014c860>] (kernfs_create_dir_ns) from [<c014ec70>] >> (sysfs_create_dir_ns+0x68/0xd0) >> [<c014ec70>] (sysfs_create_dir_ns) from [<c04b58f8>] >> (kobject_add_internal+0x9c/0x2c4) >> [<c04b58f8>] (kobject_add_internal) from [<c04b5d64>] >> (kobject_init_and_add+0x54/0x94) >> [<c04b5d64>] (kobject_init_and_add) from [<c00d650c>] >> (sysfs_slab_add+0x10c/0x220) >> [<c00d650c>] (sysfs_slab_add) from [<c00d72f8>] >> (__kmem_cache_create+0x1d8/0x338) >> [<c00d72f8>] (__kmem_cache_create) from [<c00b0958>] >> (kmem_cache_create_usercopy+0x180/0x298) >> [<c00b0958>] (kmem_cache_create_usercopy) from [<c00b0a90>] >> (kmem_cache_create+0x20/0x28) >> [<c00b0a90>] (kmem_cache_create) from [<c017d6e4>] >> (ext4_mb_init+0x374/0x44c) >> [<c017d6e4>] (ext4_mb_init) from [<c01971a0>] >> (ext4_fill_super+0x2258/0x2ef0) >> [<c01971a0>] (ext4_fill_super) from [<c00e4d88>] (mount_bdev+0x154/0x18c) >> [<c00e4d88>] (mount_bdev) from [<c0190b10>] (ext4_mount+0x14/0x20) >> [<c0190b10>] (ext4_mount) from [<c00e568c>] (mount_fs+0x14/0xa8) >> [<c00e568c>] (mount_fs) from [<c0100488>] (vfs_kern_mount+0x48/0xf0) >> [<c0100488>] (vfs_kern_mount) from [<c01033ec>] (do_mount+0x180/0xb9c) >> [<c01033ec>] (do_mount) from [<c0104178>] (ksys_mount+0x8c/0xb4) >> [<c0104178>] (ksys_mount) from [<c062b1ec>] (mount_block_root+0x128/0x2a4) >> [<c062b1ec>] (mount_block_root) from [<c062b478>] (mount_root+0x110/0x154) >> [<c062b478>] (mount_root) from [<c062b5e4>] (prepare_namespace+0x128/0x188) >> [<c062b5e4>] (prepare_namespace) from [<c04c7868>] (kernel_init+0x8/0xf4) >> [<c04c7868>] (kernel_init) from [<c00090e0>] (ret_from_fork+0x14/0x34) >> Exception stack(0xc2831fb0 to 0xc2831ff8) >> 1fa0: 00000000 00000000 00000000 >> 00000000 >> 1fc0: 00000000 00000000 00000000 00000000 00000000 00000000 00000000 >> 00000000 >> 1fe0: 00000000 00000000 00000000 00000000 00000013 00000000 >> Code: e5923000 e3130001 1a000054 e92d4070 (e593c004) >> ---[ end trace 2c8fc104914a532b ]--- >> Kernel panic - not syncing: Attempted to kill init! exitcode=0x0000000b >> ---[ end Kernel panic - not syncing: Attempted to kill init! >> exitcode=0x0000000b ]--- >> > > First step is to test if it's the damage clip allocation/freeing that's > causing problems. Setting clips to NULL avoids allocation and results in > a full update each time: > > diff --git a/drivers/gpu/drm/drm_damage_helper.c > b/drivers/gpu/drm/drm_damage_helper.c > index e16aa5ae00b4..943ae17b8b1c 100644 > --- a/drivers/gpu/drm/drm_damage_helper.c > +++ b/drivers/gpu/drm/drm_damage_helper.c > @@ -182,6 +182,7 @@ int drm_atomic_helper_dirtyfb(struct drm_framebuffer > *fb, > } > state->acquire_ctx = &ctx; > > + clips = NULL; > if (clips) { > uint32_t inc = 1; > > If that helps, try clearing/freeing the damage explicitly: > > diff --git a/drivers/gpu/drm/drm_damage_helper.c > b/drivers/gpu/drm/drm_damage_helper.c > index e16aa5ae00b4..0a59263e4733 100644 > --- a/drivers/gpu/drm/drm_damage_helper.c > +++ b/drivers/gpu/drm/drm_damage_helper.c > @@ -371,6 +371,8 @@ bool drm_atomic_helper_damage_merged(const struct > drm_plane_state *old_state, > valid = true; > } > > + drm_property_replace_blob(&state->fb_damage_clips, NULL); > + > return valid; > } > EXPORT_SYMBOL(drm_atomic_helper_damage_merged); > > If that doesn't help, try disabling the call to st7586_fb_dirty() so we > can rule out the driver. > If it helps, verify that the rectangle is within bounds. > I see that you have this call chain: st7586_pipe_enable() -> mipi_dbi_enable_flush() -> mipi_dbi_fb_dirty(). That doesn't look safe. The st7586 driver allocates a tx_buf with size: size_t bufsize = (mode->vdisplay + 2) / 3 * mode->hdisplay; whereas mipi_dbi_enable_flush() will trigger a copy to tx_buf with len: fb->width * fb->height * 2 It looks like you're writing zeroes way past the end of the buffer. Noralf. _______________________________________________ dri-devel mailing list dri-devel@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/dri-devel