diff options
author | Eric Anholt <anholt@freebsd.org> | 2003-11-06 04:48:06 +0000 |
---|---|---|
committer | Eric Anholt <anholt@freebsd.org> | 2003-11-06 04:48:06 +0000 |
commit | 1f7598245af7e73b34130a44fbaac230e29d7aad (patch) | |
tree | 050abd77d041309e17a37649ed41e2e3cc2d03ae /linux | |
parent | 2c1172a31794e20f7ba1a2ab234d4dab2f84005b (diff) |
Return EBUSY when attempting to addmap a DRM_SHM area with a lock in it if
dev->lock.hw_lock is already set. This fixes the case of two X Servers
running on the same head on different VTs with interface 1.1, by making
the 2nd head fail to inizialize like before.
Diffstat (limited to 'linux')
-rw-r--r-- | linux/drm_bufs.h | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/linux/drm_bufs.h b/linux/drm_bufs.h index 77573709..e30e6de8 100644 --- a/linux/drm_bufs.h +++ b/linux/drm_bufs.h @@ -161,6 +161,12 @@ int DRM(addmap)( struct inode *inode, struct file *filp, } map->offset = (unsigned long)map->handle; if ( map->flags & _DRM_CONTAINS_LOCK ) { + /* Prevent a 2nd X Server from creating a 2nd lock */ + if (dev->lock.hw_lock != NULL) { + vfree( map->handle ); + DRM(free)( map, sizeof(*map), DRM_MEM_MAPS ); + return -EBUSY; + } dev->sigdata.lock = dev->lock.hw_lock = map->handle; /* Pointer to lock */ } |