xf86drm.h 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803
  1. /**
  2. * \file xf86drm.h
  3. * OS-independent header for DRM user-level library interface.
  4. *
  5. * \author Rickard E. (Rik) Faith <faith@valinux.com>
  6. */
  7. /*
  8. * Copyright 1999, 2000 Precision Insight, Inc., Cedar Park, Texas.
  9. * Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
  10. * All Rights Reserved.
  11. *
  12. * Permission is hereby granted, free of charge, to any person obtaining a
  13. * copy of this software and associated documentation files (the "Software"),
  14. * to deal in the Software without restriction, including without limitation
  15. * the rights to use, copy, modify, merge, publish, distribute, sublicense,
  16. * and/or sell copies of the Software, and to permit persons to whom the
  17. * Software is furnished to do so, subject to the following conditions:
  18. *
  19. * The above copyright notice and this permission notice (including the next
  20. * paragraph) shall be included in all copies or substantial portions of the
  21. * Software.
  22. *
  23. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  24. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  25. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
  26. * PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
  27. * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
  28. * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  29. * DEALINGS IN THE SOFTWARE.
  30. *
  31. */
  32. #ifndef _XF86DRM_H_
  33. #define _XF86DRM_H_
  34. #include <stdarg.h>
  35. #include <sys/types.h>
  36. #include <stdint.h>
  37. #include <drm.h>
  38. #if defined(__cplusplus)
  39. extern "C" {
  40. #endif
  41. #ifndef DRM_MAX_MINOR
  42. #define DRM_MAX_MINOR 16
  43. #endif
  44. #if defined(__linux__)
  45. #define DRM_IOCTL_NR(n) _IOC_NR(n)
  46. #define DRM_IOC_VOID _IOC_NONE
  47. #define DRM_IOC_READ _IOC_READ
  48. #define DRM_IOC_WRITE _IOC_WRITE
  49. #define DRM_IOC_READWRITE _IOC_READ|_IOC_WRITE
  50. #define DRM_IOC(dir, group, nr, size) _IOC(dir, group, nr, size)
  51. #else /* One of the *BSDs */
  52. #include <sys/ioccom.h>
  53. #define DRM_IOCTL_NR(n) ((n) & 0xff)
  54. #define DRM_IOC_VOID IOC_VOID
  55. #define DRM_IOC_READ IOC_OUT
  56. #define DRM_IOC_WRITE IOC_IN
  57. #define DRM_IOC_READWRITE IOC_INOUT
  58. #define DRM_IOC(dir, group, nr, size) _IOC(dir, group, nr, size)
  59. #endif
  60. /* Defaults, if nothing set in xf86config */
  61. #define DRM_DEV_UID 0
  62. #define DRM_DEV_GID 0
  63. /* Default /dev/dri directory permissions 0755 */
  64. #define DRM_DEV_DIRMODE \
  65. (S_IRUSR|S_IWUSR|S_IXUSR|S_IRGRP|S_IXGRP|S_IROTH|S_IXOTH)
  66. #define DRM_DEV_MODE (S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP)
  67. #ifdef __OpenBSD__
  68. #define DRM_DIR_NAME "/dev"
  69. #define DRM_DEV_NAME "%s/drm%d"
  70. #define DRM_CONTROL_DEV_NAME "%s/drmC%d"
  71. #define DRM_RENDER_DEV_NAME "%s/drmR%d"
  72. #else
  73. #define DRM_DIR_NAME "/dev/dri"
  74. #define DRM_DEV_NAME "%s/card%d"
  75. #define DRM_CONTROL_DEV_NAME "%s/controlD%d"
  76. #define DRM_RENDER_DEV_NAME "%s/renderD%d"
  77. #define DRM_PROC_NAME "/proc/dri/" /* For backward Linux compatibility */
  78. #endif
  79. #define DRM_ERR_NO_DEVICE (-1001)
  80. #define DRM_ERR_NO_ACCESS (-1002)
  81. #define DRM_ERR_NOT_ROOT (-1003)
  82. #define DRM_ERR_INVALID (-1004)
  83. #define DRM_ERR_NO_FD (-1005)
  84. #define DRM_AGP_NO_HANDLE 0
  85. typedef unsigned int drmSize, *drmSizePtr; /**< For mapped regions */
  86. typedef void *drmAddress, **drmAddressPtr; /**< For mapped regions */
  87. #if (__GNUC__ >= 3)
  88. #define DRM_PRINTFLIKE(f, a) __attribute__ ((format(__printf__, f, a)))
  89. #else
  90. #define DRM_PRINTFLIKE(f, a)
  91. #endif
  92. typedef struct _drmServerInfo {
  93. int (*debug_print)(const char *format, va_list ap) DRM_PRINTFLIKE(1,0);
  94. int (*load_module)(const char *name);
  95. void (*get_perms)(gid_t *, mode_t *);
  96. } drmServerInfo, *drmServerInfoPtr;
  97. typedef struct drmHashEntry {
  98. int fd;
  99. void (*f)(int, void *, void *);
  100. void *tagTable;
  101. } drmHashEntry;
  102. extern int drmIoctl(int fd, unsigned long request, void *arg);
  103. extern void *drmGetHashTable(void);
  104. extern drmHashEntry *drmGetEntry(int fd);
  105. /**
  106. * Driver version information.
  107. *
  108. * \sa drmGetVersion() and drmSetVersion().
  109. */
  110. typedef struct _drmVersion {
  111. int version_major; /**< Major version */
  112. int version_minor; /**< Minor version */
  113. int version_patchlevel; /**< Patch level */
  114. int name_len; /**< Length of name buffer */
  115. char *name; /**< Name of driver */
  116. int date_len; /**< Length of date buffer */
  117. char *date; /**< User-space buffer to hold date */
  118. int desc_len; /**< Length of desc buffer */
  119. char *desc; /**< User-space buffer to hold desc */
  120. } drmVersion, *drmVersionPtr;
  121. typedef struct _drmStats {
  122. unsigned long count; /**< Number of data */
  123. struct {
  124. unsigned long value; /**< Value from kernel */
  125. const char *long_format; /**< Suggested format for long_name */
  126. const char *long_name; /**< Long name for value */
  127. const char *rate_format; /**< Suggested format for rate_name */
  128. const char *rate_name; /**< Short name for value per second */
  129. int isvalue; /**< True if value (vs. counter) */
  130. const char *mult_names; /**< Multiplier names (e.g., "KGM") */
  131. int mult; /**< Multiplier value (e.g., 1024) */
  132. int verbose; /**< Suggest only in verbose output */
  133. } data[15];
  134. } drmStatsT;
  135. /* All of these enums *MUST* match with the
  136. kernel implementation -- so do *NOT*
  137. change them! (The drmlib implementation
  138. will just copy the flags instead of
  139. translating them.) */
  140. typedef enum {
  141. DRM_FRAME_BUFFER = 0, /**< WC, no caching, no core dump */
  142. DRM_REGISTERS = 1, /**< no caching, no core dump */
  143. DRM_SHM = 2, /**< shared, cached */
  144. DRM_AGP = 3, /**< AGP/GART */
  145. DRM_SCATTER_GATHER = 4, /**< PCI scatter/gather */
  146. DRM_CONSISTENT = 5 /**< PCI consistent */
  147. } drmMapType;
  148. typedef enum {
  149. DRM_RESTRICTED = 0x0001, /**< Cannot be mapped to client-virtual */
  150. DRM_READ_ONLY = 0x0002, /**< Read-only in client-virtual */
  151. DRM_LOCKED = 0x0004, /**< Physical pages locked */
  152. DRM_KERNEL = 0x0008, /**< Kernel requires access */
  153. DRM_WRITE_COMBINING = 0x0010, /**< Use write-combining, if available */
  154. DRM_CONTAINS_LOCK = 0x0020, /**< SHM page that contains lock */
  155. DRM_REMOVABLE = 0x0040 /**< Removable mapping */
  156. } drmMapFlags;
  157. /**
  158. * \warning These values *MUST* match drm.h
  159. */
  160. typedef enum {
  161. /** \name Flags for DMA buffer dispatch */
  162. /*@{*/
  163. DRM_DMA_BLOCK = 0x01, /**<
  164. * Block until buffer dispatched.
  165. *
  166. * \note the buffer may not yet have been
  167. * processed by the hardware -- getting a
  168. * hardware lock with the hardware quiescent
  169. * will ensure that the buffer has been
  170. * processed.
  171. */
  172. DRM_DMA_WHILE_LOCKED = 0x02, /**< Dispatch while lock held */
  173. DRM_DMA_PRIORITY = 0x04, /**< High priority dispatch */
  174. /*@}*/
  175. /** \name Flags for DMA buffer request */
  176. /*@{*/
  177. DRM_DMA_WAIT = 0x10, /**< Wait for free buffers */
  178. DRM_DMA_SMALLER_OK = 0x20, /**< Smaller-than-requested buffers OK */
  179. DRM_DMA_LARGER_OK = 0x40 /**< Larger-than-requested buffers OK */
  180. /*@}*/
  181. } drmDMAFlags;
  182. typedef enum {
  183. DRM_PAGE_ALIGN = 0x01,
  184. DRM_AGP_BUFFER = 0x02,
  185. DRM_SG_BUFFER = 0x04,
  186. DRM_FB_BUFFER = 0x08,
  187. DRM_PCI_BUFFER_RO = 0x10
  188. } drmBufDescFlags;
  189. typedef enum {
  190. DRM_LOCK_READY = 0x01, /**< Wait until hardware is ready for DMA */
  191. DRM_LOCK_QUIESCENT = 0x02, /**< Wait until hardware quiescent */
  192. DRM_LOCK_FLUSH = 0x04, /**< Flush this context's DMA queue first */
  193. DRM_LOCK_FLUSH_ALL = 0x08, /**< Flush all DMA queues first */
  194. /* These *HALT* flags aren't supported yet
  195. -- they will be used to support the
  196. full-screen DGA-like mode. */
  197. DRM_HALT_ALL_QUEUES = 0x10, /**< Halt all current and future queues */
  198. DRM_HALT_CUR_QUEUES = 0x20 /**< Halt all current queues */
  199. } drmLockFlags;
  200. typedef enum {
  201. DRM_CONTEXT_PRESERVED = 0x01, /**< This context is preserved and
  202. never swapped. */
  203. DRM_CONTEXT_2DONLY = 0x02 /**< This context is for 2D rendering only. */
  204. } drm_context_tFlags, *drm_context_tFlagsPtr;
  205. typedef struct _drmBufDesc {
  206. int count; /**< Number of buffers of this size */
  207. int size; /**< Size in bytes */
  208. int low_mark; /**< Low water mark */
  209. int high_mark; /**< High water mark */
  210. } drmBufDesc, *drmBufDescPtr;
  211. typedef struct _drmBufInfo {
  212. int count; /**< Number of buffers described in list */
  213. drmBufDescPtr list; /**< List of buffer descriptions */
  214. } drmBufInfo, *drmBufInfoPtr;
  215. typedef struct _drmBuf {
  216. int idx; /**< Index into the master buffer list */
  217. int total; /**< Buffer size */
  218. int used; /**< Amount of buffer in use (for DMA) */
  219. drmAddress address; /**< Address */
  220. } drmBuf, *drmBufPtr;
  221. /**
  222. * Buffer mapping information.
  223. *
  224. * Used by drmMapBufs() and drmUnmapBufs() to store information about the
  225. * mapped buffers.
  226. */
  227. typedef struct _drmBufMap {
  228. int count; /**< Number of buffers mapped */
  229. drmBufPtr list; /**< Buffers */
  230. } drmBufMap, *drmBufMapPtr;
  231. typedef struct _drmLock {
  232. volatile unsigned int lock;
  233. char padding[60];
  234. /* This is big enough for most current (and future?) architectures:
  235. DEC Alpha: 32 bytes
  236. Intel Merced: ?
  237. Intel P5/PPro/PII/PIII: 32 bytes
  238. Intel StrongARM: 32 bytes
  239. Intel i386/i486: 16 bytes
  240. MIPS: 32 bytes (?)
  241. Motorola 68k: 16 bytes
  242. Motorola PowerPC: 32 bytes
  243. Sun SPARC: 32 bytes
  244. */
  245. } drmLock, *drmLockPtr;
  246. /**
  247. * Indices here refer to the offset into
  248. * list in drmBufInfo
  249. */
  250. typedef struct _drmDMAReq {
  251. drm_context_t context; /**< Context handle */
  252. int send_count; /**< Number of buffers to send */
  253. int *send_list; /**< List of handles to buffers */
  254. int *send_sizes; /**< Lengths of data to send, in bytes */
  255. drmDMAFlags flags; /**< Flags */
  256. int request_count; /**< Number of buffers requested */
  257. int request_size; /**< Desired size of buffers requested */
  258. int *request_list; /**< Buffer information */
  259. int *request_sizes; /**< Minimum acceptable sizes */
  260. int granted_count; /**< Number of buffers granted at this size */
  261. } drmDMAReq, *drmDMAReqPtr;
  262. typedef struct _drmRegion {
  263. drm_handle_t handle;
  264. unsigned int offset;
  265. drmSize size;
  266. drmAddress map;
  267. } drmRegion, *drmRegionPtr;
  268. typedef struct _drmTextureRegion {
  269. unsigned char next;
  270. unsigned char prev;
  271. unsigned char in_use;
  272. unsigned char padding; /**< Explicitly pad this out */
  273. unsigned int age;
  274. } drmTextureRegion, *drmTextureRegionPtr;
  275. typedef enum {
  276. DRM_VBLANK_ABSOLUTE = 0x0, /**< Wait for specific vblank sequence number */
  277. DRM_VBLANK_RELATIVE = 0x1, /**< Wait for given number of vblanks */
  278. /* bits 1-6 are reserved for high crtcs */
  279. DRM_VBLANK_HIGH_CRTC_MASK = 0x0000003e,
  280. DRM_VBLANK_EVENT = 0x4000000, /**< Send event instead of blocking */
  281. DRM_VBLANK_FLIP = 0x8000000, /**< Scheduled buffer swap should flip */
  282. DRM_VBLANK_NEXTONMISS = 0x10000000, /**< If missed, wait for next vblank */
  283. DRM_VBLANK_SECONDARY = 0x20000000, /**< Secondary display controller */
  284. DRM_VBLANK_SIGNAL = 0x40000000 /* Send signal instead of blocking */
  285. } drmVBlankSeqType;
  286. #define DRM_VBLANK_HIGH_CRTC_SHIFT 1
  287. typedef struct _drmVBlankReq {
  288. drmVBlankSeqType type;
  289. unsigned int sequence;
  290. unsigned long signal;
  291. } drmVBlankReq, *drmVBlankReqPtr;
  292. typedef struct _drmVBlankReply {
  293. drmVBlankSeqType type;
  294. unsigned int sequence;
  295. long tval_sec;
  296. long tval_usec;
  297. } drmVBlankReply, *drmVBlankReplyPtr;
  298. typedef union _drmVBlank {
  299. drmVBlankReq request;
  300. drmVBlankReply reply;
  301. } drmVBlank, *drmVBlankPtr;
  302. typedef struct _drmSetVersion {
  303. int drm_di_major;
  304. int drm_di_minor;
  305. int drm_dd_major;
  306. int drm_dd_minor;
  307. } drmSetVersion, *drmSetVersionPtr;
  308. #define __drm_dummy_lock(lock) (*(__volatile__ unsigned int *)lock)
  309. #define DRM_LOCK_HELD 0x80000000U /**< Hardware lock is held */
  310. #define DRM_LOCK_CONT 0x40000000U /**< Hardware lock is contended */
  311. #if defined(__GNUC__) && (__GNUC__ >= 2)
  312. # if defined(__i386) || defined(__AMD64__) || defined(__x86_64__) || defined(__amd64__)
  313. /* Reflect changes here to drmP.h */
  314. #define DRM_CAS(lock,old,new,__ret) \
  315. do { \
  316. int __dummy; /* Can't mark eax as clobbered */ \
  317. __asm__ __volatile__( \
  318. "lock ; cmpxchg %4,%1\n\t" \
  319. "setnz %0" \
  320. : "=d" (__ret), \
  321. "=m" (__drm_dummy_lock(lock)), \
  322. "=a" (__dummy) \
  323. : "2" (old), \
  324. "r" (new)); \
  325. } while (0)
  326. #elif defined(__alpha__)
  327. #define DRM_CAS(lock, old, new, ret) \
  328. do { \
  329. int tmp, old32; \
  330. __asm__ __volatile__( \
  331. " addl $31, %5, %3\n" \
  332. "1: ldl_l %0, %2\n" \
  333. " cmpeq %0, %3, %1\n" \
  334. " beq %1, 2f\n" \
  335. " mov %4, %0\n" \
  336. " stl_c %0, %2\n" \
  337. " beq %0, 3f\n" \
  338. " mb\n" \
  339. "2: cmpeq %1, 0, %1\n" \
  340. ".subsection 2\n" \
  341. "3: br 1b\n" \
  342. ".previous" \
  343. : "=&r"(tmp), "=&r"(ret), \
  344. "=m"(__drm_dummy_lock(lock)), \
  345. "=&r"(old32) \
  346. : "r"(new), "r"(old) \
  347. : "memory"); \
  348. } while (0)
  349. #elif defined(__sparc__)
  350. #define DRM_CAS(lock,old,new,__ret) \
  351. do { register unsigned int __old __asm("o0"); \
  352. register unsigned int __new __asm("o1"); \
  353. register volatile unsigned int *__lock __asm("o2"); \
  354. __old = old; \
  355. __new = new; \
  356. __lock = (volatile unsigned int *)lock; \
  357. __asm__ __volatile__( \
  358. /*"cas [%2], %3, %0"*/ \
  359. ".word 0xd3e29008\n\t" \
  360. /*"membar #StoreStore | #StoreLoad"*/ \
  361. ".word 0x8143e00a" \
  362. : "=&r" (__new) \
  363. : "0" (__new), \
  364. "r" (__lock), \
  365. "r" (__old) \
  366. : "memory"); \
  367. __ret = (__new != __old); \
  368. } while(0)
  369. #elif defined(__ia64__)
  370. #ifdef __INTEL_COMPILER
  371. /* this currently generates bad code (missing stop bits)... */
  372. #include <ia64intrin.h>
  373. #define DRM_CAS(lock,old,new,__ret) \
  374. do { \
  375. unsigned long __result, __old = (old) & 0xffffffff; \
  376. __mf(); \
  377. __result = _InterlockedCompareExchange_acq(&__drm_dummy_lock(lock), (new), __old);\
  378. __ret = (__result) != (__old); \
  379. /* __ret = (__sync_val_compare_and_swap(&__drm_dummy_lock(lock), \
  380. (old), (new)) \
  381. != (old)); */\
  382. } while (0)
  383. #else
  384. #define DRM_CAS(lock,old,new,__ret) \
  385. do { \
  386. unsigned int __result, __old = (old); \
  387. __asm__ __volatile__( \
  388. "mf\n" \
  389. "mov ar.ccv=%2\n" \
  390. ";;\n" \
  391. "cmpxchg4.acq %0=%1,%3,ar.ccv" \
  392. : "=r" (__result), "=m" (__drm_dummy_lock(lock)) \
  393. : "r" ((unsigned long)__old), "r" (new) \
  394. : "memory"); \
  395. __ret = (__result) != (__old); \
  396. } while (0)
  397. #endif
  398. #elif defined(__powerpc__)
  399. #define DRM_CAS(lock,old,new,__ret) \
  400. do { \
  401. __asm__ __volatile__( \
  402. "sync;" \
  403. "0: lwarx %0,0,%1;" \
  404. " xor. %0,%3,%0;" \
  405. " bne 1f;" \
  406. " stwcx. %2,0,%1;" \
  407. " bne- 0b;" \
  408. "1: " \
  409. "sync;" \
  410. : "=&r"(__ret) \
  411. : "r"(lock), "r"(new), "r"(old) \
  412. : "cr0", "memory"); \
  413. } while (0)
  414. #endif /* architecture */
  415. #endif /* __GNUC__ >= 2 */
  416. #ifndef DRM_CAS
  417. #define DRM_CAS(lock,old,new,ret) do { ret=1; } while (0) /* FAST LOCK FAILS */
  418. #endif
  419. #if defined(__alpha__)
  420. #define DRM_CAS_RESULT(_result) long _result
  421. #elif defined(__powerpc__)
  422. #define DRM_CAS_RESULT(_result) int _result
  423. #else
  424. #define DRM_CAS_RESULT(_result) char _result
  425. #endif
  426. #define DRM_LIGHT_LOCK(fd,lock,context) \
  427. do { \
  428. DRM_CAS_RESULT(__ret); \
  429. DRM_CAS(lock,context,DRM_LOCK_HELD|context,__ret); \
  430. if (__ret) drmGetLock(fd,context,0); \
  431. } while(0)
  432. /* This one counts fast locks -- for
  433. benchmarking only. */
  434. #define DRM_LIGHT_LOCK_COUNT(fd,lock,context,count) \
  435. do { \
  436. DRM_CAS_RESULT(__ret); \
  437. DRM_CAS(lock,context,DRM_LOCK_HELD|context,__ret); \
  438. if (__ret) drmGetLock(fd,context,0); \
  439. else ++count; \
  440. } while(0)
  441. #define DRM_LOCK(fd,lock,context,flags) \
  442. do { \
  443. if (flags) drmGetLock(fd,context,flags); \
  444. else DRM_LIGHT_LOCK(fd,lock,context); \
  445. } while(0)
  446. #define DRM_UNLOCK(fd,lock,context) \
  447. do { \
  448. DRM_CAS_RESULT(__ret); \
  449. DRM_CAS(lock,DRM_LOCK_HELD|context,context,__ret); \
  450. if (__ret) drmUnlock(fd,context); \
  451. } while(0)
  452. /* Simple spin locks */
  453. #define DRM_SPINLOCK(spin,val) \
  454. do { \
  455. DRM_CAS_RESULT(__ret); \
  456. do { \
  457. DRM_CAS(spin,0,val,__ret); \
  458. if (__ret) while ((spin)->lock); \
  459. } while (__ret); \
  460. } while(0)
  461. #define DRM_SPINLOCK_TAKE(spin,val) \
  462. do { \
  463. DRM_CAS_RESULT(__ret); \
  464. int cur; \
  465. do { \
  466. cur = (*spin).lock; \
  467. DRM_CAS(spin,cur,val,__ret); \
  468. } while (__ret); \
  469. } while(0)
  470. #define DRM_SPINLOCK_COUNT(spin,val,count,__ret) \
  471. do { \
  472. int __i; \
  473. __ret = 1; \
  474. for (__i = 0; __ret && __i < count; __i++) { \
  475. DRM_CAS(spin,0,val,__ret); \
  476. if (__ret) for (;__i < count && (spin)->lock; __i++); \
  477. } \
  478. } while(0)
  479. #define DRM_SPINUNLOCK(spin,val) \
  480. do { \
  481. DRM_CAS_RESULT(__ret); \
  482. if ((*spin).lock == val) { /* else server stole lock */ \
  483. do { \
  484. DRM_CAS(spin,val,0,__ret); \
  485. } while (__ret); \
  486. } \
  487. } while(0)
  488. /* General user-level programmer's API: unprivileged */
  489. extern int drmAvailable(void);
  490. extern int drmOpen(const char *name, const char *busid);
  491. #define DRM_NODE_PRIMARY 0
  492. #define DRM_NODE_CONTROL 1
  493. #define DRM_NODE_RENDER 2
  494. #define DRM_NODE_MAX 3
  495. extern int drmOpenWithType(const char *name, const char *busid,
  496. int type);
  497. extern int drmOpenControl(int minor);
  498. extern int drmOpenRender(int minor);
  499. extern int drmClose(int fd);
  500. extern drmVersionPtr drmGetVersion(int fd);
  501. extern drmVersionPtr drmGetLibVersion(int fd);
  502. extern int drmGetCap(int fd, uint64_t capability, uint64_t *value);
  503. extern void drmFreeVersion(drmVersionPtr);
  504. extern int drmGetMagic(int fd, drm_magic_t * magic);
  505. extern char *drmGetBusid(int fd);
  506. extern int drmGetInterruptFromBusID(int fd, int busnum, int devnum,
  507. int funcnum);
  508. extern int drmGetMap(int fd, int idx, drm_handle_t *offset,
  509. drmSize *size, drmMapType *type,
  510. drmMapFlags *flags, drm_handle_t *handle,
  511. int *mtrr);
  512. extern int drmGetClient(int fd, int idx, int *auth, int *pid,
  513. int *uid, unsigned long *magic,
  514. unsigned long *iocs);
  515. extern int drmGetStats(int fd, drmStatsT *stats);
  516. extern int drmSetInterfaceVersion(int fd, drmSetVersion *version);
  517. extern int drmCommandNone(int fd, unsigned long drmCommandIndex);
  518. extern int drmCommandRead(int fd, unsigned long drmCommandIndex,
  519. void *data, unsigned long size);
  520. extern int drmCommandWrite(int fd, unsigned long drmCommandIndex,
  521. void *data, unsigned long size);
  522. extern int drmCommandWriteRead(int fd, unsigned long drmCommandIndex,
  523. void *data, unsigned long size);
  524. /* General user-level programmer's API: X server (root) only */
  525. extern void drmFreeBusid(const char *busid);
  526. extern int drmSetBusid(int fd, const char *busid);
  527. extern int drmAuthMagic(int fd, drm_magic_t magic);
  528. extern int drmAddMap(int fd,
  529. drm_handle_t offset,
  530. drmSize size,
  531. drmMapType type,
  532. drmMapFlags flags,
  533. drm_handle_t * handle);
  534. extern int drmRmMap(int fd, drm_handle_t handle);
  535. extern int drmAddContextPrivateMapping(int fd, drm_context_t ctx_id,
  536. drm_handle_t handle);
  537. extern int drmAddBufs(int fd, int count, int size,
  538. drmBufDescFlags flags,
  539. int agp_offset);
  540. extern int drmMarkBufs(int fd, double low, double high);
  541. extern int drmCreateContext(int fd, drm_context_t * handle);
  542. extern int drmSetContextFlags(int fd, drm_context_t context,
  543. drm_context_tFlags flags);
  544. extern int drmGetContextFlags(int fd, drm_context_t context,
  545. drm_context_tFlagsPtr flags);
  546. extern int drmAddContextTag(int fd, drm_context_t context, void *tag);
  547. extern int drmDelContextTag(int fd, drm_context_t context);
  548. extern void *drmGetContextTag(int fd, drm_context_t context);
  549. extern drm_context_t * drmGetReservedContextList(int fd, int *count);
  550. extern void drmFreeReservedContextList(drm_context_t *);
  551. extern int drmSwitchToContext(int fd, drm_context_t context);
  552. extern int drmDestroyContext(int fd, drm_context_t handle);
  553. extern int drmCreateDrawable(int fd, drm_drawable_t * handle);
  554. extern int drmDestroyDrawable(int fd, drm_drawable_t handle);
  555. extern int drmUpdateDrawableInfo(int fd, drm_drawable_t handle,
  556. drm_drawable_info_type_t type,
  557. unsigned int num, void *data);
  558. extern int drmCtlInstHandler(int fd, int irq);
  559. extern int drmCtlUninstHandler(int fd);
  560. extern int drmSetClientCap(int fd, uint64_t capability,
  561. uint64_t value);
  562. /* General user-level programmer's API: authenticated client and/or X */
  563. extern int drmMap(int fd,
  564. drm_handle_t handle,
  565. drmSize size,
  566. drmAddressPtr address);
  567. extern int drmUnmap(drmAddress address, drmSize size);
  568. extern drmBufInfoPtr drmGetBufInfo(int fd);
  569. extern drmBufMapPtr drmMapBufs(int fd);
  570. extern int drmUnmapBufs(drmBufMapPtr bufs);
  571. extern int drmDMA(int fd, drmDMAReqPtr request);
  572. extern int drmFreeBufs(int fd, int count, int *list);
  573. extern int drmGetLock(int fd,
  574. drm_context_t context,
  575. drmLockFlags flags);
  576. extern int drmUnlock(int fd, drm_context_t context);
  577. extern int drmFinish(int fd, int context, drmLockFlags flags);
  578. extern int drmGetContextPrivateMapping(int fd, drm_context_t ctx_id,
  579. drm_handle_t * handle);
  580. /* AGP/GART support: X server (root) only */
  581. extern int drmAgpAcquire(int fd);
  582. extern int drmAgpRelease(int fd);
  583. extern int drmAgpEnable(int fd, unsigned long mode);
  584. extern int drmAgpAlloc(int fd, unsigned long size,
  585. unsigned long type, unsigned long *address,
  586. drm_handle_t *handle);
  587. extern int drmAgpFree(int fd, drm_handle_t handle);
  588. extern int drmAgpBind(int fd, drm_handle_t handle,
  589. unsigned long offset);
  590. extern int drmAgpUnbind(int fd, drm_handle_t handle);
  591. /* AGP/GART info: authenticated client and/or X */
  592. extern int drmAgpVersionMajor(int fd);
  593. extern int drmAgpVersionMinor(int fd);
  594. extern unsigned long drmAgpGetMode(int fd);
  595. extern unsigned long drmAgpBase(int fd); /* Physical location */
  596. extern unsigned long drmAgpSize(int fd); /* Bytes */
  597. extern unsigned long drmAgpMemoryUsed(int fd);
  598. extern unsigned long drmAgpMemoryAvail(int fd);
  599. extern unsigned int drmAgpVendorId(int fd);
  600. extern unsigned int drmAgpDeviceId(int fd);
  601. /* PCI scatter/gather support: X server (root) only */
  602. extern int drmScatterGatherAlloc(int fd, unsigned long size,
  603. drm_handle_t *handle);
  604. extern int drmScatterGatherFree(int fd, drm_handle_t handle);
  605. extern int drmWaitVBlank(int fd, drmVBlankPtr vbl);
  606. /* Support routines */
  607. extern void drmSetServerInfo(drmServerInfoPtr info);
  608. extern int drmError(int err, const char *label);
  609. extern void *drmMalloc(int size);
  610. extern void drmFree(void *pt);
  611. /* Hash table routines */
  612. extern void *drmHashCreate(void);
  613. extern int drmHashDestroy(void *t);
  614. extern int drmHashLookup(void *t, unsigned long key, void **value);
  615. extern int drmHashInsert(void *t, unsigned long key, void *value);
  616. extern int drmHashDelete(void *t, unsigned long key);
  617. extern int drmHashFirst(void *t, unsigned long *key, void **value);
  618. extern int drmHashNext(void *t, unsigned long *key, void **value);
  619. /* PRNG routines */
  620. extern void *drmRandomCreate(unsigned long seed);
  621. extern int drmRandomDestroy(void *state);
  622. extern unsigned long drmRandom(void *state);
  623. extern double drmRandomDouble(void *state);
  624. /* Skip list routines */
  625. extern void *drmSLCreate(void);
  626. extern int drmSLDestroy(void *l);
  627. extern int drmSLLookup(void *l, unsigned long key, void **value);
  628. extern int drmSLInsert(void *l, unsigned long key, void *value);
  629. extern int drmSLDelete(void *l, unsigned long key);
  630. extern int drmSLNext(void *l, unsigned long *key, void **value);
  631. extern int drmSLFirst(void *l, unsigned long *key, void **value);
  632. extern void drmSLDump(void *l);
  633. extern int drmSLLookupNeighbors(void *l, unsigned long key,
  634. unsigned long *prev_key, void **prev_value,
  635. unsigned long *next_key, void **next_value);
  636. extern int drmOpenOnce(void *unused, const char *BusID, int *newlyopened);
  637. extern int drmOpenOnceWithType(const char *BusID, int *newlyopened, int type);
  638. extern void drmCloseOnce(int fd);
  639. extern void drmMsg(const char *format, ...) DRM_PRINTFLIKE(1, 2);
  640. extern int drmSetMaster(int fd);
  641. extern int drmDropMaster(int fd);
  642. #define DRM_EVENT_CONTEXT_VERSION 2
  643. typedef struct _drmEventContext {
  644. /* This struct is versioned so we can add more pointers if we
  645. * add more events. */
  646. int version;
  647. void (*vblank_handler)(int fd,
  648. unsigned int sequence,
  649. unsigned int tv_sec,
  650. unsigned int tv_usec,
  651. void *user_data);
  652. void (*page_flip_handler)(int fd,
  653. unsigned int sequence,
  654. unsigned int tv_sec,
  655. unsigned int tv_usec,
  656. void *user_data);
  657. } drmEventContext, *drmEventContextPtr;
  658. extern int drmHandleEvent(int fd, drmEventContextPtr evctx);
  659. extern char *drmGetDeviceNameFromFd(int fd);
  660. extern int drmGetNodeTypeFromFd(int fd);
  661. extern int drmPrimeHandleToFD(int fd, uint32_t handle, uint32_t flags, int *prime_fd);
  662. extern int drmPrimeFDToHandle(int fd, int prime_fd, uint32_t *handle);
  663. extern char *drmGetPrimaryDeviceNameFromFd(int fd);
  664. extern char *drmGetRenderDeviceNameFromFd(int fd);
  665. #define DRM_BUS_PCI 0
  666. typedef struct _drmPciBusInfo {
  667. uint16_t domain;
  668. uint8_t bus;
  669. uint8_t dev;
  670. uint8_t func;
  671. } drmPciBusInfo, *drmPciBusInfoPtr;
  672. typedef struct _drmPciDeviceInfo {
  673. uint16_t vendor_id;
  674. uint16_t device_id;
  675. uint16_t subvendor_id;
  676. uint16_t subdevice_id;
  677. uint8_t revision_id;
  678. } drmPciDeviceInfo, *drmPciDeviceInfoPtr;
  679. typedef struct _drmDevice {
  680. char **nodes; /* DRM_NODE_MAX sized array */
  681. int available_nodes; /* DRM_NODE_* bitmask */
  682. int bustype;
  683. union {
  684. drmPciBusInfoPtr pci;
  685. } businfo;
  686. union {
  687. drmPciDeviceInfoPtr pci;
  688. } deviceinfo;
  689. } drmDevice, *drmDevicePtr;
  690. extern int drmGetDevice(int fd, drmDevicePtr *device);
  691. extern void drmFreeDevice(drmDevicePtr *device);
  692. extern int drmGetDevices(drmDevicePtr devices[], int max_devices);
  693. extern void drmFreeDevices(drmDevicePtr devices[], int count);
  694. #if defined(__cplusplus)
  695. }
  696. #endif
  697. #endif