Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752625AbaLAECs (ORCPT ); Sun, 30 Nov 2014 23:02:48 -0500 Received: from mail-qa0-f54.google.com ([209.85.216.54]:51542 "EHLO mail-qa0-f54.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752294AbaLAECq (ORCPT ); Sun, 30 Nov 2014 23:02:46 -0500 MIME-Version: 1.0 In-Reply-To: <1417103841-22739-1-git-send-email-pmladek@suse.cz> References: <1417103841-22739-1-git-send-email-pmladek@suse.cz> Date: Sun, 30 Nov 2014 23:02:45 -0500 Message-ID: Subject: Re: [PATCH] drm/radeon: kernel panic in drm_calc_vbltimestamp_from_scanoutpos with 3.18.0-rc6 From: Alex Deucher To: Petr Mladek Cc: Alex Deucher , Christian Konig , David Airlie , Linus Torvalds , Helge Deller , LKML , Maling list - DRI developers Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Nov 27, 2014 at 10:57 AM, Petr Mladek 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: [] 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:[] [] 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: > [] ? drm_vma_offset_remove+0x1d/0x110 > [] radeon_get_vblank_timestamp_kms+0x38/0x60 > [] ? ttm_bo_release_list+0xba/0x180 > [] drm_get_last_vbltimestamp+0x41/0x70 > [] vblank_disable_and_save+0x73/0x1d0 > [] ? try_to_del_timer_sync+0x4f/0x70 > [] drm_vblank_cleanup+0x65/0xa0 > [] radeon_irq_kms_fini+0x1a/0x70 > [] r100_init+0x26e/0x410 > [] radeon_device_init+0x7ae/0xb50 > [] radeon_driver_load_kms+0x8f/0x210 > [] drm_dev_register+0xb5/0x110 > [] drm_get_pci_dev+0x8f/0x200 > [] radeon_pci_probe+0xad/0xe0 > [] local_pci_probe+0x45/0xa0 > [] pci_device_probe+0xd1/0x130 > [] driver_probe_device+0x12d/0x3e0 > [] __driver_attach+0x9b/0xa0 > [] ? __device_attach+0x40/0x40 > [] bus_for_each_dev+0x63/0xa0 > [] driver_attach+0x1e/0x20 > [] bus_add_driver+0x180/0x240 > [] driver_register+0x64/0xf0 > [] __pci_register_driver+0x4c/0x50 > [] drm_pci_init+0xf5/0x120 > [] ? ttm_init+0x6a/0x6a > [] radeon_init+0x97/0xb5 > [] do_one_initcall+0xbc/0x1f0 > [] ? __wake_up+0x48/0x60 > [] kernel_init_freeable+0x18a/0x215 > [] ? initcall_blacklist+0xc0/0xc0 > [] ? rest_init+0x80/0x80 > [] kernel_init+0xe/0xf0 > [] ret_from_fork+0x7c/0xb0 > [] ? 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 [] drm_calc_vbltimestamp_from_scanoutpos+0x4b/0x320 > RSP > 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 > Signed-off-by: Petr Mladek > Tested-by: Petr Mladek 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@lists.freedesktop.org > http://lists.freedesktop.org/mailman/listinfo/dri-devel -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/