summaryrefslogtreecommitdiff
path: root/src/mesa/drivers/dri/s3v/s3v_lock.h
blob: f1bb2a9bf22e996b60f6543edafd7b26ead840e3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
/*
 * Author: Max Lingua <sunmax@libero.it>
 */

#ifndef __S3V_LOCK_H__
#define __S3V_LOCK_H__

#include <sys/ioctl.h>

#ifdef GLX_DIRECT_RENDERING

extern void s3vGetLock( s3vContextPtr vmesa, 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( vmesa ) \
   do {	\
      char __ret = 0; \
      DEBUG_CHECK_LOCK(); \
      DRM_CAS( vmesa->driHwLock, vmesa->hHWContext, \
	       (DRM_LOCK_HELD | vmesa->hHWContext), __ret ); \
      if ( __ret ) \
         s3vGetLock( vmesa, 0 ); \
      DEBUG_LOCK(); \
   } while (0)

/* Unlock the hardware.
 */
#define UNLOCK_HARDWARE( vmesa ) \
   do { \
      DRM_UNLOCK( vmesa->driFd, \
		  vmesa->driHwLock, \
		  vmesa->hHWContext ); \
      DEBUG_RESET(); \
   } while (0)

#endif

#define S3VHW_LOCK( vmesa )	\
   DRM_UNLOCK(vmesa->driFd, vmesa->driHwLock, vmesa->hHWContext); \
   DRM_SPINLOCK(&vmesa->driScreen->pSAREA->drawable_lock, \
		 vmesa->driScreen->drawLockID); \
   /* VALIDATE_DRAWABLE_INFO_NO_LOCK(vmesa); */

#define S3VHW_UNLOCK( vmesa ) \
    DRM_SPINUNLOCK(&vmesa->driScreen->pSAREA->drawable_lock, \
		   vmesa->driScreen->drawLockID); \
    /* VALIDATE_DRAWABLE_INFO_NO_LOCK_POST(vmesa); */

#define S3V_SIMPLE_LOCK( vmesa ) \
	ioctl(vmesa->driFd, 0x4a) 

#define S3V_SIMPLE_FLUSH_LOCK( vmesa ) \
	ioctl(vmesa->driFd, 0x4b) 

#define S3V_SIMPLE_UNLOCK( vmesa ) \
	ioctl(vmesa->driFd, 0x4c) 

#endif /* __S3V_LOCK_H__ */