[Intel-gfx] i915: NULL pointer dereference in i915_update_dri1_breadcrumb() during shutdown

Eugene Shatokhin eugene.shatokhin at rosalab.ru
Tue Dec 10 15:25:42 CET 2013


On 12/10/2013 04:23 PM, Daniel Vetter wrote:
> On Tue, Dec 10, 2013 at 12:27:55PM +0400, Eugene Shatokhin wrote:
>> Hi,
>>
>> I have recently observed a NULL pointer dereference in i915 driver
>> on my Eee PC running ROSA Linux with kernel 3.10.21.
>>
>> The crash occurs during shutdown but quite rarely, not each time.
>>
>> The system log is lost but here is what I extracted from the info
>> displayed on the screen.
>>
>> NULL pointer dereference at 0x4
>> EIP is at i915_update_dri1_breadcrumb+0x25/0x70
>> comm: systemd-journal
>>
>> i915_update_dri1_breadcrumb+0x25:
>> 	mov    0x4(%eax),%ebx // %eax contains 0, the list of register
>> values confirms that.
>>
>> That is the reading of 'master_priv->sarea_priv':
>>
>> void i915_update_dri1_breadcrumb(struct drm_device *dev)
>> {
>> 	drm_i915_private_t *dev_priv = dev->dev_private;
>> 	struct drm_i915_master_private *master_priv;
>>
>> 	if (dev->primary->master) {
>> 		master_priv = dev->primary->master->driver_priv;
>> 		if (master_priv->sarea_priv) // <<< crashes here
>> 			master_priv->sarea_priv->last_dispatch =
>> 				READ_BREADCRUMB(dev_priv);
>> 	}
>> }
>
> Indeed, that's fairly hapzardous. But also only needed for legacy ums
> support. I'll send out a patch to block this in kms mode quickly. Please
> test it.
>
> Thanks, Daniel

Thanks a lot!

I am building kernel 3.10.23 now with this patch applied and will let 
you know if something goes wrong.

Regards,
Eugene

-- 
Eugene Shatokhin, ROSA Laboratory.
www.rosalab.com



More information about the Intel-gfx mailing list