lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <CAMeQTsZ+gud1+-sSzX4Fo4hngXGbiPois8V3zAuJR_-aw2mtNg@mail.gmail.com>
Date:	Tue, 18 Oct 2011 13:16:19 +0200
From:	Patrik Jakobsson <patrik.r.jakobsson@...il.com>
To:	Alan Cox <alan@...rguk.ukuu.org.uk>
Cc:	Hugh Dickins <hughd@...gle.com>, Rob Clark <rob.clark@...aro.org>,
	Andrew Morton <akpm@...ux-foundation.org>,
	Christoph Hellwig <hch@...radead.org>, greg@...ah.com,
	linux-kernel@...r.kernel.org
Subject: Re: [PATCH 34/49] gma500: the GEM and GTT code is device independant

On Mon, Oct 17, 2011 at 11:39 PM, Alan Cox wrote:
>> It feels to me like GEM is pulling shmem in an ever more alien direction:
>> these device constraints are so foreign to the nature of tmpfs; and
>> beyond my expertise, so that I'd be ever more likely to make the wrong
>> decisions (mixing swap and uncached pages? hmmm).
>
> For the most part we fixed that. You can now have a GEM object that is
> backed by a private memory object rather than having to be tmpfs.
> GMA500 uses it to attach 'stolen' memory to GEM handles, and at least
> one other pending submission uses it with a private CMA style allocator.
>
> The gma500 report seems an odd one - no GMA500 box has >4GB memory so how
> did the test code get a page that was unsuitable - is the test buggy ?

Hi Alan

I didn't hit any >4GB issues but when I got SDVO working I tried setting
1920x1080 which needs more then the ~8MB that BIOS sets aside
as stolen memory.

What happens is that a gem object outside stolen mem is created and
when we try to pin it we go down the path:

psb_gtt_pin -> psb_gtt_attach_pages -> read_cache_page_gfp

This triggers the following oops:

-----

[   43.604167] BUG: unable to handle kernel NULL pointer dereference at   (null)
[   43.604349] IP: [<  (null)>]   (null)
[   43.604477] *pde = 00000000
[   43.604603] Oops: 0000 [#1] SMP
[   43.604778] Modules linked in: psb_gfx(C+) drm_kms_helper drm
agpgart i2c_algo_bit psmouse i2c_isch gpio_sch video coretemp lpc_sch
serio_raw usbhid hid r8169 mii
[   43.605746]
[   43.605825] Pid: 1255, comm: modprobe Tainted: G         C
3.1.0-rc4+ #13 CompuLab SBC-FITPC2/SBC-FITPC2
[   43.606089] EIP: 0060:[<00000000>] EFLAGS: 00010246 CPU: 1
[   43.606180] EIP is at 0x0
[   43.606261] EAX: 00000000 EBX: f62ea340 ECX: f5e04020 EDX: f62ea340
[   43.606351] ESI: f683f288 EDI: 00000000 EBP: f698bbb8 ESP: f698bb9c
[   43.606441]  DS: 007b ES: 007b FS: 00d8 GS: 00e0 SS: 0068
[   43.606531] Process modprobe (pid: 1255, ti=f698a000 task=f4bb6500
task.ti=f698a000)
[   43.606641] Stack:
[   43.606718]  c10dbe31 000000d0 00000014 00000000 000001d0 00000000
f683f288 f698bbcc
[   43.607153]  c10dbf34 00000000 000001d0 f686f9c0 f698bbf4 f85afcee
f85aeb7a f6caf400
[   43.607582]  f683f288 f6f5205c 000007e9 fffffff4 f53cc600 f698bc7c
f698bc54 f85af0b2
[   43.608017] Call Trace:
[   43.608032]  [<c10dbe31>] ? do_read_cache_page+0x71/0x150
[   43.608032]  [<c10dbf34>] read_cache_page_gfp+0x24/0x30
[   43.608032]  [<f85afcee>] psb_gtt_pin+0xbe/0x220 [psb_gfx]
[   43.608032]  [<f85aeb7a>] ? psb_framebuffer_init+0x6a/0xa0 [psb_gfx]
[   43.608032]  [<f85af0b2>] psbfb_probe+0x3f2/0x460 [psb_gfx]
[   43.608032]  [<f80ccae7>] drm_fb_helper_single_fb_probe+0x127/0x2c0
[drm_kms_helper]
[   43.608032]  [<f80cce32>] drm_fb_helper_initial_config+0x1b2/0x210
[drm_kms_helper]
[   43.608032]  [<c1113ebe>] ? __kmalloc+0x13e/0x1d0
[   43.608032]  [<c1113c8d>] ? kmem_cache_alloc_trace+0xbd/0x120
[   43.608032]  [<f85af3e0>] psb_fbdev_init+0x70/0xb0 [psb_gfx]
[   43.608032]  [<f85b4c8e>] psb_driver_load+0x4ae/0x4c0 [psb_gfx]
[   43.608032]  [<f80a65a4>] drm_get_pci_dev+0x144/0x270 [drm]
[   43.608032]  [<c14a47cf>] ? _raw_spin_lock_irqsave+0x2f/0x50
[   43.608032]  [<f85b4642>] psb_probe+0x12/0x20 [psb_gfx]
[   43.608032]  [<c12609c7>] local_pci_probe+0x47/0xb0
[   43.608032]  [<c1261f08>] pci_device_probe+0x68/0x90
[   43.608032]  [<c12f0def>] driver_probe_device+0x7f/0x190
[   43.608032]  [<c1261e73>] ? pci_match_device+0xb3/0xc0
[   43.608032]  [<c12f0f81>] __driver_attach+0x81/0x90
[   43.608032]  [<c12f0f00>] ? driver_probe_device+0x190/0x190
[   43.608032]  [<c12f0048>] bus_for_each_dev+0x48/0x70
[   43.608032]  [<c1261920>] ? pci_pm_suspend+0x100/0x100
[   43.608032]  [<c12f0afe>] driver_attach+0x1e/0x20
[   43.608032]  [<c12f0f00>] ? driver_probe_device+0x190/0x190
[   43.608032]  [<c12f0718>] bus_add_driver+0xb8/0x250
[   43.608032]  [<c1261920>] ? pci_pm_suspend+0x100/0x100
[   43.608032]  [<c12f14d6>] driver_register+0x66/0x110
[   43.608032]  [<c1261035>] __pci_register_driver+0x45/0xb0
[   43.608032]  [<f80a67b1>] drm_pci_init+0xe1/0x110 [drm]
[   43.608032]  [<f8078012>] psb_init+0x12/0x1000 [psb_gfx]
[   43.608032]  [<c1001245>] do_one_initcall+0x35/0x170
[   43.608032]  [<f8078000>] ? 0xf8077fff
[   43.608032]  [<c107fcbb>] sys_init_module+0x13b/0x1aa0
[   43.608032]  [<c14ab21f>] sysenter_do_call+0x12/0x28
[   43.608032] Code:  Bad EIP value.
[   43.608032] EIP: [<00000000>] 0x0 SS:ESP 0068:f698bb9c
[   43.608032] CR2: 0000000000000000
[   43.612492] ---[ end trace 7c48b83f43438436 ]---
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ