[PATCH] drm/radeon: kernel panic in drm_calc_vbltimestamp_from_scanoutpos with 3.18.0-rc6

Alex Deucher alexdeucher at gmail.com
Sun Nov 30 20:02:45 PST 2014


On Thu, Nov 27, 2014 at 10:57 AM, Petr Mladek <pmladek at suse.cz> wrote:
> I was unable too boot 3.18.0-rc6 because of the following kernel
> panic in drm_calc_vbltimestamp_from_scanoutpos():
>
>     [drm] Initialized drm 1.1.0 20060810
>     [drm] radeon kernel modesetting enabled.
>     [drm] initializing kernel modesetting (RV100 0x1002:0x515E 0x15D9:0x8080).
>     [drm] register mmio base: 0xC8400000
>     [drm] register mmio size: 65536
>     radeon 0000:0b:01.0: VRAM: 128M 0x00000000D0000000 - 0x00000000D7FFFFFF (16M used)
>     radeon 0000:0b:01.0: GTT: 512M 0x00000000B0000000 - 0x00000000CFFFFFFF
>     [drm] Detected VRAM RAM=128M, BAR=128M
>     [drm] RAM width 16bits DDR
>     [TTM] Zone  kernel: Available graphics memory: 3829346 kiB
>     [TTM] Zone   dma32: Available graphics memory: 2097152 kiB
>     [TTM] Initializing pool allocator
>     [TTM] Initializing DMA pool allocator
>     [drm] radeon: 16M of VRAM memory ready
>     [drm] radeon: 512M of GTT memory ready.
>     [drm] GART: num cpu pages 131072, num gpu pages 131072
>     [drm] PCI GART of 512M enabled (table at 0x0000000037880000).
>     radeon 0000:0b:01.0: WB disabled
>     radeon 0000:0b:01.0: fence driver on ring 0 use gpu addr 0x00000000b0000000 and cpu addr 0xffff8800bbbfa000
>     [drm] Supports vblank timestamp caching Rev 2 (21.10.2013).
>     [drm] Driver supports precise vblank timestamp query.
>     [drm] radeon: irq initialized.
>     [drm] Loading R100 Microcode
>     radeon 0000:0b:01.0: Direct firmware load for radeon/R100_cp.bin failed with error -2
>     radeon_cp: Failed to load firmware "radeon/R100_cp.bin"
>     [drm:r100_cp_init] *ERROR* Failed to load firmware!
>     radeon 0000:0b:01.0: failed initializing CP (-2).
>     radeon 0000:0b:01.0: Disabling GPU acceleration
>     [drm] radeon: cp finalized
>     BUG: unable to handle kernel NULL pointer dereference at 000000000000025c
>     IP: [<ffffffff8150423b>] drm_calc_vbltimestamp_from_scanoutpos+0x4b/0x320
>     PGD 0
>     Oops: 0000 [#1] SMP
>     Modules linked in:
>     CPU: 1 PID: 1 Comm: swapper/0 Not tainted 3.18.0-rc6-4-default #2649
>     Hardware name: Supermicro X7DB8/X7DB8, BIOS 6.00 07/26/2006
>     task: ffff880234da2010 ti: ffff880234da4000 task.ti: ffff880234da4000
>     RIP: 0010:[<ffffffff8150423b>]  [<ffffffff8150423b>] drm_calc_vbltimestamp_from_scanoutpos+0x4b/0x320
>     RSP: 0000:ffff880234da7918  EFLAGS: 00010086
>     RAX: ffffffff81557890 RBX: 0000000000000000 RCX: ffff880234da7a48
>     RDX: ffff880234da79f4 RSI: 0000000000000000 RDI: ffff880232e15000
>     RBP: ffff880234da79b8 R08: 0000000000000000 R09: 0000000000000000
>     R10: 000000000000000a R11: 0000000000000001 R12: ffff880232dda1c0
>     R13: ffff880232e1518c R14: 0000000000000292 R15: ffff880232e15000
>     FS:  0000000000000000(0000) GS:ffff88023fc40000(0000) knlGS:0000000000000000
>     CS:  0010 DS: 0000 ES: 0000 CR0: 000000008005003b
>     CR2: 000000000000025c CR3: 0000000002014000 CR4: 00000000000007e0
>     Stack:
>      ffff880234da79d8 0000000000000286 ffff880232dcbc00 0000000000002480
>      ffff880234da7958 0000000000000296 ffff880234da7998 ffffffff8151b51d
>      ffff880234da7a48 0000000032dcbeb0 ffff880232dcbc00 ffff880232dcbc58
>     Call Trace:
>      [<ffffffff8151b51d>] ? drm_vma_offset_remove+0x1d/0x110
>      [<ffffffff8152dc98>] radeon_get_vblank_timestamp_kms+0x38/0x60
>      [<ffffffff8152076a>] ? ttm_bo_release_list+0xba/0x180
>      [<ffffffff81503751>] drm_get_last_vbltimestamp+0x41/0x70
>      [<ffffffff81503933>] vblank_disable_and_save+0x73/0x1d0
>      [<ffffffff81106b2f>] ? try_to_del_timer_sync+0x4f/0x70
>      [<ffffffff81505245>] drm_vblank_cleanup+0x65/0xa0
>      [<ffffffff815604fa>] radeon_irq_kms_fini+0x1a/0x70
>      [<ffffffff8156c07e>] r100_init+0x26e/0x410
>      [<ffffffff8152ae3e>] radeon_device_init+0x7ae/0xb50
>      [<ffffffff8152d57f>] radeon_driver_load_kms+0x8f/0x210
>      [<ffffffff81506965>] drm_dev_register+0xb5/0x110
>      [<ffffffff8150998f>] drm_get_pci_dev+0x8f/0x200
>      [<ffffffff815291cd>] radeon_pci_probe+0xad/0xe0
>      [<ffffffff8141a365>] local_pci_probe+0x45/0xa0
>      [<ffffffff8141b741>] pci_device_probe+0xd1/0x130
>      [<ffffffff81633dad>] driver_probe_device+0x12d/0x3e0
>      [<ffffffff8163413b>] __driver_attach+0x9b/0xa0
>      [<ffffffff816340a0>] ? __device_attach+0x40/0x40
>      [<ffffffff81631cd3>] bus_for_each_dev+0x63/0xa0
>      [<ffffffff8163378e>] driver_attach+0x1e/0x20
>      [<ffffffff81633390>] bus_add_driver+0x180/0x240
>      [<ffffffff81634914>] driver_register+0x64/0xf0
>      [<ffffffff81419cac>] __pci_register_driver+0x4c/0x50
>      [<ffffffff81509bf5>] drm_pci_init+0xf5/0x120
>      [<ffffffff821dc871>] ? ttm_init+0x6a/0x6a
>      [<ffffffff821dc908>] radeon_init+0x97/0xb5
>      [<ffffffff810002fc>] do_one_initcall+0xbc/0x1f0
>      [<ffffffff810e3278>] ? __wake_up+0x48/0x60
>      [<ffffffff8218e256>] kernel_init_freeable+0x18a/0x215
>      [<ffffffff8218d983>] ? initcall_blacklist+0xc0/0xc0
>      [<ffffffff818a78f0>] ? rest_init+0x80/0x80
>      [<ffffffff818a78fe>] kernel_init+0xe/0xf0
>      [<ffffffff818c0c3c>] ret_from_fork+0x7c/0xb0
>      [<ffffffff818a78f0>] ? rest_init+0x80/0x80
>     Code: 45 ac 0f 88 a8 01 00 00 3b b7 d0 01 00 00 49 89 ff 0f 83 99 01 00 00 48 8b 47 20 48 8b 80 88 00 00 00 48 85 c0 0f 84 cd 01 00 00 <41> 8b b1 5c 02 00 00 41 8b 89 58 02 00 00 89 75 98 41 8b b1 60
>     RIP  [<ffffffff8150423b>] drm_calc_vbltimestamp_from_scanoutpos+0x4b/0x320
>      RSP <ffff880234da7918>
>     CR2: 000000000000025c
>     ---[ end trace ad2c0aadf48e2032 ]---
>     Kernel panic - not syncing: Attempted to kill init! exitcode=0x00000009
>
> It has helped me to add a NULL pointer check that was suggested at
> http://lists.freedesktop.org/archives/dri-devel/2014-October/070663.html
>
> I am not familiar with the code. But the change looks sane
> and we need something fast at this stage of 3.18 development.
>
> Suggested-by: Helge Deller <deller at gmx.de>
> Signed-off-by: Petr Mladek <pmladek at suse.cz>
> Tested-by: Petr Mladek <pmladek at suse.cz>

Applied to my -fixes tree.

Thanks,

Alex

> ---
>  drivers/gpu/drm/radeon/radeon_kms.c | 2 ++
>  1 file changed, 2 insertions(+)
>
> diff --git a/drivers/gpu/drm/radeon/radeon_kms.c b/drivers/gpu/drm/radeon/radeon_kms.c
> index 8309b11e674d..03586763ee86 100644
> --- a/drivers/gpu/drm/radeon/radeon_kms.c
> +++ b/drivers/gpu/drm/radeon/radeon_kms.c
> @@ -795,6 +795,8 @@ int radeon_get_vblank_timestamp_kms(struct drm_device *dev, int crtc,
>
>         /* Get associated drm_crtc: */
>         drmcrtc = &rdev->mode_info.crtcs[crtc]->base;
> +       if (!drmcrtc)
> +               return -EINVAL;
>
>         /* Helper routine in DRM core does all the work: */
>         return drm_calc_vbltimestamp_from_scanoutpos(dev, crtc, max_error,
> --
> 1.8.5.2
>
> _______________________________________________
> dri-devel mailing list
> dri-devel at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/dri-devel


More information about the dri-devel mailing list