diff options
| author | Luca Barbieri <luca@luca-barbieri.com> | 2010-01-06 04:02:45 +0100 | 
|---|---|---|
| committer | Ben Skeggs <bskeggs@redhat.com> | 2010-01-11 09:06:43 +1000 | 
| commit | 234896a7671c23233230622728f6942b3d1c098e (patch) | |
| tree | 38a9a140b0bd0a78aa92cad27b27691dbc71d719 /fs/proc/array.c | |
| parent | 7978b9cfa59133a34aaad420e447c2a29d5c6152 (diff) | |
drm/nouveau: Fix null deref in nouveau_fence_emit due to deleted fence
Currently Nouveau will unvalidate all buffers if it is forced to wait on
one, and then start revalidating from the beginning.  While doing so, it
destroys the operation fence, causing nouveau_fence_emit to crash.
This patch fixes this bug by taking the fence object out of validate_op
and creating it just before emit.  The fence pointer is initialized to 0
and unref'ed unconditionally.
In addition to fixing the bug, this prevents its reintroduction and
simplifies the code.
Signed-off-by: Luca Barbieri <luca@luca-barbieri.com>
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
Diffstat (limited to 'fs/proc/array.c')
0 files changed, 0 insertions, 0 deletions
