diff options
author | dawes <dawes> | 2002-02-14 01:59:27 +0000 |
---|---|---|
committer | dawes <dawes> | 2002-02-14 01:59:27 +0000 |
commit | 316e8f1af01604b1638a7613f2becd051cf3fcb5 (patch) | |
tree | 42de1a90195578a20c62fe804d9bc7db2c1613cf /xc/lib/GL/mesa/src/drv/gamma/gamma_lock.h | |
parent | d7079b0d92edbc78a16a913bfa9851332bfcc435 (diff) |
First pass of mesa-4-0 branch merge into trunk.
Diffstat (limited to 'xc/lib/GL/mesa/src/drv/gamma/gamma_lock.h')
-rw-r--r-- | xc/lib/GL/mesa/src/drv/gamma/gamma_lock.h | 88 |
1 files changed, 88 insertions, 0 deletions
diff --git a/xc/lib/GL/mesa/src/drv/gamma/gamma_lock.h b/xc/lib/GL/mesa/src/drv/gamma/gamma_lock.h new file mode 100644 index 000000000..8b66e19aa --- /dev/null +++ b/xc/lib/GL/mesa/src/drv/gamma/gamma_lock.h @@ -0,0 +1,88 @@ +#ifndef __GAMMA_LOCK_H__ +#define __GAMMA_LOCK_H__ + +#ifdef GLX_DIRECT_RENDERING + +extern void gammaGetLock( gammaContextPtr gmesa, GLuint flags ); + +/* Turn DEBUG_LOCKING on to find locking conflicts. + */ +#define DEBUG_LOCKING 0 + +#if DEBUG_LOCKING +extern char *prevLockFile; +extern int prevLockLine; + +#define DEBUG_LOCK() \ + do { \ + prevLockFile = (__FILE__); \ + prevLockLine = (__LINE__); \ + } while (0) + +#define DEBUG_RESET() \ + do { \ + prevLockFile = 0; \ + prevLockLine = 0; \ + } while (0) + +#define DEBUG_CHECK_LOCK() \ + do { \ + if ( prevLockFile ) { \ + fprintf( stderr, \ + "LOCK SET!\n\tPrevious %s:%d\n\tCurrent: %s:%d\n", \ + prevLockFile, prevLockLine, __FILE__, __LINE__ ); \ + exit( 1 ); \ + } \ + } while (0) + +#else + +#define DEBUG_LOCK() +#define DEBUG_RESET() +#define DEBUG_CHECK_LOCK() + +#endif + +/* + * !!! We may want to separate locks from locks with validation. This + * could be used to improve performance for those things commands that + * do not do any drawing !!! + */ + +/* Lock the hardware and validate our state. + */ +#define LOCK_HARDWARE( gmesa ) \ + do { \ + char __ret = 0; \ + DEBUG_CHECK_LOCK(); \ + DRM_CAS( gmesa->driHwLock, gmesa->hHWContext, \ + (DRM_LOCK_HELD | gmesa->hHWContext), __ret ); \ + if ( __ret ) \ + gammaGetLock( gmesa, 0 ); \ + DEBUG_LOCK(); \ + } while (0) + +/* Unlock the hardware. + */ +#define UNLOCK_HARDWARE( gmesa ) \ + do { \ + DRM_UNLOCK( gmesa->driFd, \ + gmesa->driHwLock, \ + gmesa->hHWContext ); \ + DEBUG_RESET(); \ + } while (0) + +#endif + +#define GAMMAHW_LOCK( gmesa ) \ + DRM_UNLOCK(gmesa->driFd, gmesa->driHwLock, gmesa->hHWContext); \ + DRM_SPINLOCK(&gmesa->driScreen->pSAREA->drawable_lock, \ + gmesa->driScreen->drawLockID); \ + VALIDATE_DRAWABLE_INFO_NO_LOCK(gmesa); + +#define GAMMAHW_UNLOCK( gmesa ) \ + DRM_SPINUNLOCK(&gmesa->driScreen->pSAREA->drawable_lock, \ + gmesa->driScreen->drawLockID); \ + VALIDATE_DRAWABLE_INFO_NO_LOCK_POST(gmesa); + +#endif /* __GAMMA_LOCK_H__ */ |