xref: /titanic_50/usr/src/uts/common/io/drm/drm.h (revision 0035d21c77a24d02faf34c10aabc120ca692efb5)
160405de4Skz151634 /* BEGIN CSTYLED */
260405de4Skz151634 
360405de4Skz151634 /**
460405de4Skz151634  * \file drm.h
560405de4Skz151634  * Header for the Direct Rendering Manager
660405de4Skz151634  *
760405de4Skz151634  * \author Rickard E. (Rik) Faith <faith@valinux.com>
860405de4Skz151634  *
960405de4Skz151634  * \par Acknowledgments:
1060405de4Skz151634  * Dec 1999, Richard Henderson <rth@twiddle.net>, move to generic \c cmpxchg.
1160405de4Skz151634  */
1260405de4Skz151634 
1360405de4Skz151634 /*
1460405de4Skz151634  * Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
1560405de4Skz151634  * Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
16*0035d21cSmiao chen - Sun Microsystems - Beijing China  * Copyright (c) 2009, Intel Corporation.
1760405de4Skz151634  * All rights reserved.
1860405de4Skz151634  *
1960405de4Skz151634  * Permission is hereby granted, free of charge, to any person obtaining a
2060405de4Skz151634  * copy of this software and associated documentation files (the "Software"),
2160405de4Skz151634  * to deal in the Software without restriction, including without limitation
2260405de4Skz151634  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
2360405de4Skz151634  * and/or sell copies of the Software, and to permit persons to whom the
2460405de4Skz151634  * Software is furnished to do so, subject to the following conditions:
2560405de4Skz151634  *
2660405de4Skz151634  * The above copyright notice and this permission notice (including the next
2760405de4Skz151634  * paragraph) shall be included in all copies or substantial portions of the
2860405de4Skz151634  * Software.
2960405de4Skz151634  *
3060405de4Skz151634  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
3160405de4Skz151634  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
3260405de4Skz151634  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
3360405de4Skz151634  * VA LINUX SYSTEMS AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
3460405de4Skz151634  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
3560405de4Skz151634  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
3660405de4Skz151634  * OTHER DEALINGS IN THE SOFTWARE.
3760405de4Skz151634  */
3860405de4Skz151634 
3960405de4Skz151634 /**
4060405de4Skz151634  * \mainpage
4160405de4Skz151634  *
4260405de4Skz151634  * The Direct Rendering Manager (DRM) is a device-independent kernel-level
4360405de4Skz151634  * device driver that provides support for the XFree86 Direct Rendering
4460405de4Skz151634  * Infrastructure (DRI).
4560405de4Skz151634  *
4660405de4Skz151634  * The DRM supports the Direct Rendering Infrastructure (DRI) in four major
4760405de4Skz151634  * ways:
4860405de4Skz151634  *     -# The DRM provides synchronized access to the graphics hardware via
4960405de4Skz151634  *        the use of an optimized two-tiered lock.
5060405de4Skz151634  *     -# The DRM enforces the DRI security policy for access to the graphics
5160405de4Skz151634  *        hardware by only allowing authenticated X11 clients access to
5260405de4Skz151634  *        restricted regions of memory.
5360405de4Skz151634  *     -# The DRM provides a generic DMA engine, complete with multiple
5460405de4Skz151634  *        queues and the ability to detect the need for an OpenGL context
5560405de4Skz151634  *        switch.
5660405de4Skz151634  *     -# The DRM is extensible via the use of small device-specific modules
5760405de4Skz151634  *        that rely extensively on the API exported by the DRM module.
5860405de4Skz151634  *
5960405de4Skz151634  */
6060405de4Skz151634 
61e92e3a86Szw161486 /*
62d0231070Smiao chen - Sun Microsystems - Beijing China  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
63e92e3a86Szw161486  * Use is subject to license terms.
64e92e3a86Szw161486  */
65e92e3a86Szw161486 
6660405de4Skz151634 #ifndef _DRM_H_
6760405de4Skz151634 #define _DRM_H_
6860405de4Skz151634 
6960405de4Skz151634 #include <sys/types32.h>
7060405de4Skz151634 
7160405de4Skz151634 #ifndef __user
7260405de4Skz151634 #define __user
7360405de4Skz151634 #endif
7460405de4Skz151634 
7560405de4Skz151634 #ifdef __GNUC__
7660405de4Skz151634 # define DEPRECATED  __attribute__ ((deprecated))
7760405de4Skz151634 #else
7860405de4Skz151634 # define DEPRECATED
7960405de4Skz151634 # define __volatile__ volatile
8060405de4Skz151634 #endif
8160405de4Skz151634 
8260405de4Skz151634 #if defined(__linux__)
8360405de4Skz151634 #include <asm/ioctl.h>		/* For _IO* macros */
8460405de4Skz151634 #define DRM_IOCTL_NR(n)		_IOC_NR(n)
8560405de4Skz151634 #define DRM_IOC_VOID		_IOC_NONE
8660405de4Skz151634 #define DRM_IOC_READ		_IOC_READ
8760405de4Skz151634 #define DRM_IOC_WRITE		_IOC_WRITE
8860405de4Skz151634 #define DRM_IOC_READWRITE	_IOC_READ|_IOC_WRITE
8960405de4Skz151634 #define DRM_IOC(dir, group, nr, size) _IOC(dir, group, nr, size)
90e92e3a86Szw161486 #elif defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__NetBSD__) || defined(__OpenBSD__) || defined(__DragonFly__)
91e92e3a86Szw161486 #if (defined(__FreeBSD__) || defined(__FreeBSD_kernel__)) && defined(IN_MODULE)
9260405de4Skz151634 /* Prevent name collision when including sys/ioccom.h */
9360405de4Skz151634 #undef ioctl
9460405de4Skz151634 #include <sys/ioccom.h>
9560405de4Skz151634 #define ioctl(a,b,c)		xf86ioctl(a,b,c)
9660405de4Skz151634 #else
9760405de4Skz151634 #include <sys/ioccom.h>
9860405de4Skz151634 #endif				/* __FreeBSD__ && xf86ioctl */
9960405de4Skz151634 #define DRM_IOCTL_NR(n)		((n) & 0xff)
10060405de4Skz151634 #define DRM_IOC_VOID		IOC_VOID
10160405de4Skz151634 #define DRM_IOC_READ		IOC_OUT
10260405de4Skz151634 #define DRM_IOC_WRITE		IOC_IN
10360405de4Skz151634 #define DRM_IOC_READWRITE	IOC_INOUT
10460405de4Skz151634 #define DRM_IOC(dir, group, nr, size) _IOC(dir, group, nr, size)
10560405de4Skz151634 #endif
10660405de4Skz151634 
10760405de4Skz151634 /* Solaris-specific. */
10860405de4Skz151634 #if defined(__SOLARIS__) || defined(sun)
10960405de4Skz151634 #define	_IOC_NR(nr)	(((nr) >> _IOC_NRSHIFT) & _IOC_NRMASK)
11060405de4Skz151634 
11160405de4Skz151634 #define	_IOC_NRBITS	8
11260405de4Skz151634 #define	_IOC_TYPEBITS   8
11360405de4Skz151634 #define	_IOC_SIZEBITS   14
11460405de4Skz151634 #define	_IOC_DIRBITS    2
11560405de4Skz151634 
11660405de4Skz151634 #define	_IOC_NRMASK	((1 << _IOC_NRBITS)-1)
11760405de4Skz151634 #define	_IOC_TYPEMASK   ((1 << _IOC_TYPEBITS)-1)
11860405de4Skz151634 #define	_IOC_SIZEMASK   ((1 << _IOC_SIZEBITS)-1)
11960405de4Skz151634 #define	_IOC_DIRMASK    ((1 << _IOC_DIRBITS)-1)
12060405de4Skz151634 
12160405de4Skz151634 #define	_IOC_NRSHIFT    0
12260405de4Skz151634 #define	_IOC_TYPESHIFT  (_IOC_NRSHIFT+_IOC_NRBITS)
12360405de4Skz151634 #define	_IOC_SIZESHIFT  (_IOC_TYPESHIFT+_IOC_TYPEBITS)
12460405de4Skz151634 #define	_IOC_DIRSHIFT   (_IOC_SIZESHIFT+_IOC_SIZEBITS)
12560405de4Skz151634 
12660405de4Skz151634 #define	_IOC_NONE	0U
12760405de4Skz151634 #define	_IOC_WRITE	1U
12860405de4Skz151634 #define	_IOC_READ	2U
12960405de4Skz151634 
13060405de4Skz151634 #define	_IOC(dir, type, nr, size) \
13160405de4Skz151634 	(((dir)  << _IOC_DIRSHIFT) | \
13260405de4Skz151634 	((type) << _IOC_TYPESHIFT) | \
13360405de4Skz151634 	((nr)   << _IOC_NRSHIFT) | \
13460405de4Skz151634 	((size) << _IOC_SIZESHIFT))
13560405de4Skz151634 
13660405de4Skz151634 /* used for X server compile */
13760405de4Skz151634 #if !defined(_KERNEL)
13860405de4Skz151634 #define	_IO(type, nr)		_IOC(_IOC_NONE, (type), (nr), 0)
13960405de4Skz151634 #define	_IOR(type, nr, size)	_IOC(_IOC_READ, (type), (nr), sizeof (size))
14060405de4Skz151634 #define	_IOW(type, nr, size)	_IOC(_IOC_WRITE, (type), (nr), sizeof (size))
14160405de4Skz151634 #define	_IOWR(type, nr, size)	_IOC(_IOC_READ|_IOC_WRITE, \
14260405de4Skz151634 				(type), (nr), sizeof (size))
14360405de4Skz151634 
14460405de4Skz151634 #define	_IOC_DIR(nr)		(((nr) >> _IOC_DIRSHIFT) & _IOC_DIRMASK)
14560405de4Skz151634 #define	_IOC_TYPE(nr)		(((nr) >> _IOC_TYPESHIFT) & _IOC_TYPEMASK)
14660405de4Skz151634 #define	_IOC_NR(nr)		(((nr) >> _IOC_NRSHIFT) & _IOC_NRMASK)
14760405de4Skz151634 #define	_IOC_SIZE(nr)		(((nr) >> _IOC_SIZESHIFT) & _IOC_SIZEMASK)
14860405de4Skz151634 
14960405de4Skz151634 #define	IOC_IN			(_IOC_WRITE << _IOC_DIRSHIFT)
15060405de4Skz151634 #define	IOC_OUT			(_IOC_READ << _IOC_DIRSHIFT)
15160405de4Skz151634 #define	IOC_INOUT		((_IOC_WRITE|_IOC_READ) << _IOC_DIRSHIFT)
15260405de4Skz151634 #define	IOCSIZE_MASK		(_IOC_SIZEMASK << _IOC_SIZESHIFT)
15360405de4Skz151634 #define	IOCSIZE_SHIFT		(_IOC_SIZESHIFT)
15460405de4Skz151634 #endif /* _KERNEL */
15560405de4Skz151634 
15660405de4Skz151634 #define	DRM_IOCTL_NR(n)		_IOC_NR(n)
15760405de4Skz151634 #define	DRM_IOC_VOID		IOC_VOID
15860405de4Skz151634 #define	DRM_IOC_READ		IOC_OUT
15960405de4Skz151634 #define	DRM_IOC_WRITE		IOC_IN
16060405de4Skz151634 #define	DRM_IOC_READWRITE	IOC_INOUT
16160405de4Skz151634 #define	DRM_IOC(dir, group, nr, size) _IOC(dir, group, nr, size)
16260405de4Skz151634 
16360405de4Skz151634 #endif /* __Solaris__ or sun */
16460405de4Skz151634 #define XFREE86_VERSION(major,minor,patch,snap) \
16560405de4Skz151634 		((major << 16) | (minor << 8) | patch)
16660405de4Skz151634 
16760405de4Skz151634 #ifndef CONFIG_XFREE86_VERSION
16860405de4Skz151634 #define CONFIG_XFREE86_VERSION XFREE86_VERSION(4,1,0,0)
16960405de4Skz151634 #endif
17060405de4Skz151634 
17160405de4Skz151634 #if CONFIG_XFREE86_VERSION < XFREE86_VERSION(4,1,0,0)
17260405de4Skz151634 #define DRM_PROC_DEVICES "/proc/devices"
17360405de4Skz151634 #define DRM_PROC_MISC	 "/proc/misc"
17460405de4Skz151634 #define DRM_PROC_DRM	 "/proc/drm"
17560405de4Skz151634 #define DRM_DEV_DRM	 "/dev/drm"
17660405de4Skz151634 #define DRM_DEV_MODE	 (S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP)
17760405de4Skz151634 #define DRM_DEV_UID	 0
17860405de4Skz151634 #define DRM_DEV_GID	 0
17960405de4Skz151634 #endif
18060405de4Skz151634 
18160405de4Skz151634 #if CONFIG_XFREE86_VERSION >= XFREE86_VERSION(4,1,0,0)
18260405de4Skz151634 #ifdef __OpenBSD__
18360405de4Skz151634 #define DRM_MAJOR       81
18460405de4Skz151634 #endif
18560405de4Skz151634 #if defined(__linux__) || defined(__NetBSD__)
18660405de4Skz151634 #define DRM_MAJOR       226
18760405de4Skz151634 #endif
188e92e3a86Szw161486 #define DRM_MAX_MINOR   15
18960405de4Skz151634 #endif
19060405de4Skz151634 #define DRM_NAME	"drm"	  /**< Name in kernel, /dev, and /proc */
19160405de4Skz151634 #define DRM_MIN_ORDER	5	  /**< At least 2^5 bytes = 32 bytes */
19260405de4Skz151634 #define DRM_MAX_ORDER	22	  /**< Up to 2^22 bytes = 4MB */
19360405de4Skz151634 #define DRM_RAM_PERCENT 10	  /**< How much system ram can we lock? */
19460405de4Skz151634 
19560405de4Skz151634 #define _DRM_LOCK_HELD	0x80000000U /**< Hardware lock is held */
19660405de4Skz151634 #define _DRM_LOCK_CONT	0x40000000U /**< Hardware lock is contended */
19760405de4Skz151634 #define _DRM_LOCK_IS_HELD(lock)	   ((lock) & _DRM_LOCK_HELD)
19860405de4Skz151634 #define _DRM_LOCK_IS_CONT(lock)	   ((lock) & _DRM_LOCK_CONT)
19960405de4Skz151634 #define _DRM_LOCKING_CONTEXT(lock) ((lock) & ~(_DRM_LOCK_HELD|_DRM_LOCK_CONT))
20060405de4Skz151634 
20160405de4Skz151634 #if defined(__linux__)
202e92e3a86Szw161486 #if defined(__KERNEL__)
203e92e3a86Szw161486 typedef __u64 drm_u64_t;
20460405de4Skz151634 #else
205e92e3a86Szw161486 typedef unsigned long long drm_u64_t;
206e92e3a86Szw161486 #endif
207e92e3a86Szw161486 
208e92e3a86Szw161486 typedef unsigned int drm_handle_t;
209d0538f66Scg149915 #else
210e92e3a86Szw161486 #include <sys/types.h>
211e92e3a86Szw161486 typedef uint64_t drm_u64_t;
21260405de4Skz151634 typedef unsigned long long drm_handle_t;	/**< To mapped regions */
21360405de4Skz151634 #endif
21460405de4Skz151634 typedef unsigned int drm_context_t;	/**< GLXContext handle */
21560405de4Skz151634 typedef unsigned int drm_drawable_t;
21660405de4Skz151634 typedef unsigned int drm_magic_t;	/**< Magic for authentication */
21760405de4Skz151634 
21860405de4Skz151634 /**
21960405de4Skz151634  * Cliprect.
22060405de4Skz151634  *
22160405de4Skz151634  * \warning If you change this structure, make sure you change
22260405de4Skz151634  * XF86DRIClipRectRec in the server as well
22360405de4Skz151634  *
22460405de4Skz151634  * \note KW: Actually it's illegal to change either for
22560405de4Skz151634  * backwards-compatibility reasons.
22660405de4Skz151634  */
22760405de4Skz151634 typedef struct drm_clip_rect {
22860405de4Skz151634 	unsigned short x1;
22960405de4Skz151634 	unsigned short y1;
23060405de4Skz151634 	unsigned short x2;
23160405de4Skz151634 	unsigned short y2;
23260405de4Skz151634 } drm_clip_rect_t;
23360405de4Skz151634 
23460405de4Skz151634 /**
235e92e3a86Szw161486  * Drawable information.
236e92e3a86Szw161486  */
237e92e3a86Szw161486 typedef struct drm_drawable_info {
238e92e3a86Szw161486 	unsigned int num_rects;
239e92e3a86Szw161486 	drm_clip_rect_t *rects;
240e92e3a86Szw161486 } drm_drawable_info_t;
241e92e3a86Szw161486 
242e92e3a86Szw161486 /**
24360405de4Skz151634  * Texture region,
24460405de4Skz151634  */
24560405de4Skz151634 typedef struct drm_tex_region {
24660405de4Skz151634 	unsigned char next;
24760405de4Skz151634 	unsigned char prev;
24860405de4Skz151634 	unsigned char in_use;
24960405de4Skz151634 	unsigned char padding;
25060405de4Skz151634 	unsigned int age;
25160405de4Skz151634 } drm_tex_region_t;
25260405de4Skz151634 
25360405de4Skz151634 /**
25460405de4Skz151634  * Hardware lock.
25560405de4Skz151634  *
25660405de4Skz151634  * The lock structure is a simple cache-line aligned integer.  To avoid
25760405de4Skz151634  * processor bus contention on a multiprocessor system, there should not be any
25860405de4Skz151634  * other data stored in the same cache line.
25960405de4Skz151634  */
26060405de4Skz151634 typedef struct drm_hw_lock {
26160405de4Skz151634 	__volatile__ unsigned int lock;		/**< lock variable */
26260405de4Skz151634 	char padding[60];			/**< Pad to cache line */
26360405de4Skz151634 } drm_hw_lock_t;
26460405de4Skz151634 
26560405de4Skz151634 /* This is beyond ugly, and only works on GCC.  However, it allows me to use
26660405de4Skz151634  * drm.h in places (i.e., in the X-server) where I can't use size_t.  The real
26760405de4Skz151634  * fix is to use uint32_t instead of size_t, but that fix will break existing
26860405de4Skz151634  * LP64 (i.e., PowerPC64, SPARC64, IA-64, Alpha, etc.) systems.  That *will*
26960405de4Skz151634  * eventually happen, though.  I chose 'unsigned long' to be the fallback type
27060405de4Skz151634  * because that works on all the platforms I know about.  Hopefully, the
27160405de4Skz151634  * real fix will happen before that bites us.
27260405de4Skz151634  */
27360405de4Skz151634 
27460405de4Skz151634 #ifdef __SIZE_TYPE__
27560405de4Skz151634 # define DRM_SIZE_T __SIZE_TYPE__
27660405de4Skz151634 #else
27760405de4Skz151634 #if !defined(__SOLARIS__) && !defined(sun)
27860405de4Skz151634 # warning "__SIZE_TYPE__ not defined.  Assuming sizeof(size_t) == sizeof(unsigned long)!"
27960405de4Skz151634 #endif
28060405de4Skz151634 # define DRM_SIZE_T unsigned long
28160405de4Skz151634 #endif
28260405de4Skz151634 
28360405de4Skz151634 /**
28460405de4Skz151634  * DRM_IOCTL_VERSION ioctl argument type.
28560405de4Skz151634  *
28660405de4Skz151634  * \sa drmGetVersion().
28760405de4Skz151634  */
28860405de4Skz151634 typedef struct drm_version {
28960405de4Skz151634 	int version_major;	  /**< Major version */
29060405de4Skz151634 	int version_minor;	  /**< Minor version */
29160405de4Skz151634 	int version_patchlevel;	  /**< Patch level */
29260405de4Skz151634 	DRM_SIZE_T name_len;	  /**< Length of name buffer */
29360405de4Skz151634 	char __user *name;		  /**< Name of driver */
29460405de4Skz151634 	DRM_SIZE_T date_len;	  /**< Length of date buffer */
29560405de4Skz151634 	char __user *date;		  /**< User-space buffer to hold date */
29660405de4Skz151634 	DRM_SIZE_T desc_len;	  /**< Length of desc buffer */
29760405de4Skz151634 	char __user *desc;		  /**< User-space buffer to hold desc */
29860405de4Skz151634 } drm_version_t;
29960405de4Skz151634 
30060405de4Skz151634 /**
30160405de4Skz151634  * DRM_IOCTL_GET_UNIQUE ioctl argument type.
30260405de4Skz151634  *
30360405de4Skz151634  * \sa drmGetBusid() and drmSetBusId().
30460405de4Skz151634  */
30560405de4Skz151634 typedef struct drm_unique {
30660405de4Skz151634 	DRM_SIZE_T unique_len;	  /**< Length of unique */
30760405de4Skz151634 	char __user *unique;	  /**< Unique name for driver instantiation */
30860405de4Skz151634 } drm_unique_t;
30960405de4Skz151634 
31060405de4Skz151634 #undef DRM_SIZE_T
31160405de4Skz151634 
31260405de4Skz151634 typedef struct drm_list {
31360405de4Skz151634 	int count;		  /**< Length of user-space structures */
31460405de4Skz151634 	drm_version_t __user *version;
31560405de4Skz151634 } drm_list_t;
31660405de4Skz151634 
31760405de4Skz151634 typedef struct drm_block {
31860405de4Skz151634 	int unused;
31960405de4Skz151634 } drm_block_t;
32060405de4Skz151634 
32160405de4Skz151634 /**
32260405de4Skz151634  * DRM_IOCTL_CONTROL ioctl argument type.
32360405de4Skz151634  *
32460405de4Skz151634  * \sa drmCtlInstHandler() and drmCtlUninstHandler().
32560405de4Skz151634  */
32660405de4Skz151634 typedef struct drm_control {
32760405de4Skz151634 	enum {
32860405de4Skz151634 		DRM_ADD_COMMAND,
32960405de4Skz151634 		DRM_RM_COMMAND,
33060405de4Skz151634 		DRM_INST_HANDLER,
33160405de4Skz151634 		DRM_UNINST_HANDLER
33260405de4Skz151634 	} func;
33360405de4Skz151634 	int irq;
33460405de4Skz151634 } drm_control_t;
33560405de4Skz151634 
33660405de4Skz151634 /**
33760405de4Skz151634  * Type of memory to map.
33860405de4Skz151634  */
33960405de4Skz151634 typedef enum drm_map_type {
34060405de4Skz151634 	_DRM_FRAME_BUFFER = 0,	  /**< WC (no caching), no core dump */
34160405de4Skz151634 	_DRM_REGISTERS = 1,	  /**< no caching, no core dump */
34260405de4Skz151634 	_DRM_SHM = 2,		  /**< shared, cached */
34360405de4Skz151634 	_DRM_AGP = 3,		  /**< AGP/GART */
34460405de4Skz151634 	_DRM_SCATTER_GATHER = 4,  /**< Scatter/gather memory for PCI DMA */
34560405de4Skz151634 	_DRM_CONSISTENT = 5,	  /**< Consistent memory for PCI DMA */
346d0538f66Scg149915 	_DRM_TTM	= 6
34760405de4Skz151634 } drm_map_type_t;
34860405de4Skz151634 
34960405de4Skz151634 /**
35060405de4Skz151634  * Memory mapping flags.
35160405de4Skz151634  */
35260405de4Skz151634 typedef enum drm_map_flags {
35360405de4Skz151634 	_DRM_RESTRICTED = 0x01,	     /**< Cannot be mapped to user-virtual */
35460405de4Skz151634 	_DRM_READ_ONLY = 0x02,
35560405de4Skz151634 	_DRM_LOCKED = 0x04,	     /**< shared, cached, locked */
35660405de4Skz151634 	_DRM_KERNEL = 0x08,	     /**< kernel requires access */
35760405de4Skz151634 	_DRM_WRITE_COMBINING = 0x10, /**< use write-combining if available */
35860405de4Skz151634 	_DRM_CONTAINS_LOCK = 0x20,   /**< SHM page that contains lock */
359d0231070Smiao chen - Sun Microsystems - Beijing China 	_DRM_REMOVABLE = 0x40,	     /**< Removable mapping */
360d0231070Smiao chen - Sun Microsystems - Beijing China 	_DRM_DRIVER = 0x80	     /**< Managed by driver */
36160405de4Skz151634 } drm_map_flags_t;
36260405de4Skz151634 
36360405de4Skz151634 typedef struct drm_ctx_priv_map {
36460405de4Skz151634 	unsigned int ctx_id;	 /**< Context requesting private mapping */
36560405de4Skz151634 	void *handle;		 /**< Handle of map */
36660405de4Skz151634 } drm_ctx_priv_map_t;
36760405de4Skz151634 
36860405de4Skz151634 /**
36960405de4Skz151634  * DRM_IOCTL_GET_MAP, DRM_IOCTL_ADD_MAP and DRM_IOCTL_RM_MAP ioctls
37060405de4Skz151634  * argument type.
37160405de4Skz151634  *
37260405de4Skz151634  * \sa drmAddMap().
37360405de4Skz151634  */
37460405de4Skz151634 typedef struct drm_map {
37560405de4Skz151634 	unsigned long long offset;	 /**< Requested physical address (0 for SAREA)*/
37660405de4Skz151634 	unsigned long long handle;
37760405de4Skz151634 				/**< User-space: "Handle" to pass to mmap() */
37860405de4Skz151634 				/**< Kernel-space: kernel-virtual address */
37960405de4Skz151634 	unsigned long size;	 /**< Requested physical size (bytes) */
38060405de4Skz151634 	drm_map_type_t type;	 /**< Type of memory to map */
38160405de4Skz151634 	drm_map_flags_t flags;	 /**< Flags */
38260405de4Skz151634 	int mtrr;		 /**< MTRR slot used */
38360405de4Skz151634 	/*   Private data */
38460405de4Skz151634 } drm_map_t;
38560405de4Skz151634 
38660405de4Skz151634 /**
38760405de4Skz151634  * DRM_IOCTL_GET_CLIENT ioctl argument type.
38860405de4Skz151634  */
38960405de4Skz151634 typedef struct drm_client {
39060405de4Skz151634 	int idx;		/**< Which client desired? */
39160405de4Skz151634 	int auth;		/**< Is client authenticated? */
39260405de4Skz151634 	unsigned long pid;	/**< Process ID */
39360405de4Skz151634 	unsigned long uid;	/**< User ID */
39460405de4Skz151634 	unsigned long magic;	/**< Magic */
39560405de4Skz151634 	unsigned long iocs;	/**< Ioctl count */
39660405de4Skz151634 } drm_client_t;
39760405de4Skz151634 
39860405de4Skz151634 typedef enum {
39960405de4Skz151634 	_DRM_STAT_LOCK,
40060405de4Skz151634 	_DRM_STAT_OPENS,
40160405de4Skz151634 	_DRM_STAT_CLOSES,
40260405de4Skz151634 	_DRM_STAT_IOCTLS,
40360405de4Skz151634 	_DRM_STAT_LOCKS,
40460405de4Skz151634 	_DRM_STAT_UNLOCKS,
40560405de4Skz151634 	_DRM_STAT_VALUE,	/**< Generic value */
40660405de4Skz151634 	_DRM_STAT_BYTE,		/**< Generic byte counter (1024bytes/K) */
40760405de4Skz151634 	_DRM_STAT_COUNT,	/**< Generic non-byte counter (1000/k) */
40860405de4Skz151634 
40960405de4Skz151634 	_DRM_STAT_IRQ,		/**< IRQ */
41060405de4Skz151634 	_DRM_STAT_PRIMARY,	/**< Primary DMA bytes */
41160405de4Skz151634 	_DRM_STAT_SECONDARY,	/**< Secondary DMA bytes */
41260405de4Skz151634 	_DRM_STAT_DMA,		/**< DMA */
41360405de4Skz151634 	_DRM_STAT_SPECIAL,	/**< Special DMA (e.g., priority or polled) */
41460405de4Skz151634 	_DRM_STAT_MISSED	/**< Missed DMA opportunity */
41560405de4Skz151634 	    /* Add to the *END* of the list */
41660405de4Skz151634 } drm_stat_type_t;
41760405de4Skz151634 
41860405de4Skz151634 /**
41960405de4Skz151634  * DRM_IOCTL_GET_STATS ioctl argument type.
42060405de4Skz151634  */
42160405de4Skz151634 typedef struct drm_stats {
42260405de4Skz151634 	unsigned long count;
42360405de4Skz151634 	struct {
42460405de4Skz151634 		unsigned long value;
42560405de4Skz151634 		drm_stat_type_t type;
42660405de4Skz151634 	} data[15];
42760405de4Skz151634 } drm_stats_t;
42860405de4Skz151634 
42960405de4Skz151634 /**
43060405de4Skz151634  * Hardware locking flags.
43160405de4Skz151634  */
43260405de4Skz151634 typedef enum drm_lock_flags {
43360405de4Skz151634 	_DRM_LOCK_READY = 0x01,	     /**< Wait until hardware is ready for DMA */
43460405de4Skz151634 	_DRM_LOCK_QUIESCENT = 0x02,  /**< Wait until hardware quiescent */
43560405de4Skz151634 	_DRM_LOCK_FLUSH = 0x04,	     /**< Flush this context's DMA queue first */
43660405de4Skz151634 	_DRM_LOCK_FLUSH_ALL = 0x08,  /**< Flush all DMA queues first */
43760405de4Skz151634 	/* These *HALT* flags aren't supported yet
43860405de4Skz151634 	   -- they will be used to support the
43960405de4Skz151634 	   full-screen DGA-like mode. */
44060405de4Skz151634 	_DRM_HALT_ALL_QUEUES = 0x10, /**< Halt all current and future queues */
44160405de4Skz151634 	_DRM_HALT_CUR_QUEUES = 0x20  /**< Halt all current queues */
44260405de4Skz151634 } drm_lock_flags_t;
44360405de4Skz151634 
44460405de4Skz151634 /**
44560405de4Skz151634  * DRM_IOCTL_LOCK, DRM_IOCTL_UNLOCK and DRM_IOCTL_FINISH ioctl argument type.
44660405de4Skz151634  *
44760405de4Skz151634  * \sa drmGetLock() and drmUnlock().
44860405de4Skz151634  */
44960405de4Skz151634 typedef struct drm_lock {
45060405de4Skz151634 	int context;
45160405de4Skz151634 	drm_lock_flags_t flags;
45260405de4Skz151634 } drm_lock_t;
45360405de4Skz151634 
45460405de4Skz151634 /**
45560405de4Skz151634  * DMA flags
45660405de4Skz151634  *
45760405de4Skz151634  * \warning
45860405de4Skz151634  * These values \e must match xf86drm.h.
45960405de4Skz151634  *
46060405de4Skz151634  * \sa drm_dma.
46160405de4Skz151634  */
46260405de4Skz151634 typedef enum drm_dma_flags {
46360405de4Skz151634 	/* Flags for DMA buffer dispatch */
46460405de4Skz151634 	_DRM_DMA_BLOCK = 0x01,	      /**<
46560405de4Skz151634 				       * Block until buffer dispatched.
46660405de4Skz151634 				       *
46760405de4Skz151634 				       * \note The buffer may not yet have
46860405de4Skz151634 				       * been processed by the hardware --
46960405de4Skz151634 				       * getting a hardware lock with the
47060405de4Skz151634 				       * hardware quiescent will ensure
47160405de4Skz151634 				       * that the buffer has been
47260405de4Skz151634 				       * processed.
47360405de4Skz151634 				       */
47460405de4Skz151634 	_DRM_DMA_WHILE_LOCKED = 0x02, /**< Dispatch while lock held */
47560405de4Skz151634 	_DRM_DMA_PRIORITY = 0x04,     /**< High priority dispatch */
47660405de4Skz151634 
47760405de4Skz151634 	/* Flags for DMA buffer request */
47860405de4Skz151634 	_DRM_DMA_WAIT = 0x10,	      /**< Wait for free buffers */
47960405de4Skz151634 	_DRM_DMA_SMALLER_OK = 0x20,   /**< Smaller-than-requested buffers OK */
48060405de4Skz151634 	_DRM_DMA_LARGER_OK = 0x40     /**< Larger-than-requested buffers OK */
48160405de4Skz151634 } drm_dma_flags_t;
48260405de4Skz151634 
48360405de4Skz151634 /**
48460405de4Skz151634  * DRM_IOCTL_ADD_BUFS and DRM_IOCTL_MARK_BUFS ioctl argument type.
48560405de4Skz151634  *
48660405de4Skz151634  * \sa drmAddBufs().
48760405de4Skz151634  */
48860405de4Skz151634 typedef enum {
48960405de4Skz151634 	_DRM_PAGE_ALIGN = 0x01,	/**< Align on page boundaries for DMA */
49060405de4Skz151634 	_DRM_AGP_BUFFER = 0x02,	/**< Buffer is in AGP space */
49160405de4Skz151634 	_DRM_SG_BUFFER  = 0x04,	/**< Scatter/gather memory buffer */
492d0538f66Scg149915 	_DRM_FB_BUFFER  = 0x08,  /**< Buffer is in frame buffer */
493d0538f66Scg149915 	_DRM_PCI_BUFFER_RO = 0x10 /**< Map PCI DMA buffer read-only */
49460405de4Skz151634 } drm_buf_flag;
49560405de4Skz151634 typedef struct drm_buf_desc {
49660405de4Skz151634 	int count;		 /**< Number of buffers of this size */
49760405de4Skz151634 	int size;		 /**< Size in bytes */
49860405de4Skz151634 	int low_mark;		 /**< Low water mark */
49960405de4Skz151634 	int high_mark;		 /**< High water mark */
50060405de4Skz151634 	drm_buf_flag flags;
50160405de4Skz151634 	unsigned long agp_start; /**<
50260405de4Skz151634 				  * Start address of where the AGP buffers are
50360405de4Skz151634 				  * in the AGP aperture
50460405de4Skz151634 				  */
50560405de4Skz151634 } drm_buf_desc_t;
50660405de4Skz151634 
50760405de4Skz151634 /**
50860405de4Skz151634  * DRM_IOCTL_INFO_BUFS ioctl argument type.
50960405de4Skz151634  */
51060405de4Skz151634 typedef struct drm_buf_info {
51160405de4Skz151634 	int count;		  /**< Number of buffers described in list */
51260405de4Skz151634 	drm_buf_desc_t __user *list;	  /**< List of buffer descriptions */
51360405de4Skz151634 } drm_buf_info_t;
51460405de4Skz151634 
51560405de4Skz151634 /**
51660405de4Skz151634  * DRM_IOCTL_FREE_BUFS ioctl argument type.
51760405de4Skz151634  */
51860405de4Skz151634 typedef struct drm_buf_free {
51960405de4Skz151634 	int count;
52060405de4Skz151634 	int __user *list;
52160405de4Skz151634 } drm_buf_free_t;
52260405de4Skz151634 
52360405de4Skz151634 /**
52460405de4Skz151634  * Buffer information
52560405de4Skz151634  *
52660405de4Skz151634  * \sa drm_buf_map.
52760405de4Skz151634  */
52860405de4Skz151634 typedef struct drm_buf_pub {
52960405de4Skz151634 	int idx;		       /**< Index into the master buffer list */
53060405de4Skz151634 	int total;		       /**< Buffer size */
53160405de4Skz151634 	int used;		       /**< Amount of buffer in use (for DMA) */
53260405de4Skz151634 	void __user *address;	       /**< Address of buffer */
53360405de4Skz151634 } drm_buf_pub_t;
53460405de4Skz151634 
53560405de4Skz151634 /**
53660405de4Skz151634  * DRM_IOCTL_MAP_BUFS ioctl argument type.
53760405de4Skz151634  */
53860405de4Skz151634 typedef struct drm_buf_map {
53960405de4Skz151634 	int count;		/**< Length of the buffer list */
54060405de4Skz151634 #if defined(__cplusplus)
54160405de4Skz151634 	void __user *c_virtual;
54260405de4Skz151634 #else
54360405de4Skz151634 	void __user *virtual;		/**< Mmap'd area in user-virtual */
54460405de4Skz151634 #endif
54560405de4Skz151634 	drm_buf_pub_t __user *list;	/**< Buffer information */
546d0538f66Scg149915 	int	fd;
54760405de4Skz151634 } drm_buf_map_t;
54860405de4Skz151634 
54960405de4Skz151634 /**
55060405de4Skz151634  * DRM_IOCTL_DMA ioctl argument type.
55160405de4Skz151634  *
55260405de4Skz151634  * Indices here refer to the offset into the buffer list in drm_buf_get.
55360405de4Skz151634  *
55460405de4Skz151634  * \sa drmDMA().
55560405de4Skz151634  */
55660405de4Skz151634 typedef struct drm_dma {
55760405de4Skz151634 	int context;			  /**< Context handle */
55860405de4Skz151634 	int send_count;			  /**< Number of buffers to send */
55960405de4Skz151634 	int __user *send_indices;	  /**< List of handles to buffers */
56060405de4Skz151634 	int __user *send_sizes;		  /**< Lengths of data to send */
56160405de4Skz151634 	drm_dma_flags_t flags;		  /**< Flags */
56260405de4Skz151634 	int request_count;		  /**< Number of buffers requested */
56360405de4Skz151634 	int request_size;		  /**< Desired size for buffers */
56460405de4Skz151634 	int __user *request_indices;	 /**< Buffer information */
56560405de4Skz151634 	int __user *request_sizes;
56660405de4Skz151634 	int granted_count;		  /**< Number of buffers granted */
56760405de4Skz151634 } drm_dma_t;
56860405de4Skz151634 
56960405de4Skz151634 typedef enum {
57060405de4Skz151634 	_DRM_CONTEXT_PRESERVED = 0x01,
57160405de4Skz151634 	_DRM_CONTEXT_2DONLY = 0x02
57260405de4Skz151634 } drm_ctx_flags_t;
57360405de4Skz151634 
57460405de4Skz151634 /**
57560405de4Skz151634  * DRM_IOCTL_ADD_CTX ioctl argument type.
57660405de4Skz151634  *
57760405de4Skz151634  * \sa drmCreateContext() and drmDestroyContext().
57860405de4Skz151634  */
57960405de4Skz151634 typedef struct drm_ctx {
58060405de4Skz151634 	drm_context_t handle;
58160405de4Skz151634 	drm_ctx_flags_t flags;
58260405de4Skz151634 } drm_ctx_t;
58360405de4Skz151634 
58460405de4Skz151634 /**
58560405de4Skz151634  * DRM_IOCTL_RES_CTX ioctl argument type.
58660405de4Skz151634  */
58760405de4Skz151634 typedef struct drm_ctx_res {
58860405de4Skz151634 	int count;
58960405de4Skz151634 	drm_ctx_t __user *contexts;
59060405de4Skz151634 } drm_ctx_res_t;
59160405de4Skz151634 
59260405de4Skz151634 
59360405de4Skz151634 /**
59460405de4Skz151634  * DRM_IOCTL_ADD_DRAW and DRM_IOCTL_RM_DRAW ioctl argument type.
59560405de4Skz151634  */
59660405de4Skz151634 typedef struct drm_draw {
59760405de4Skz151634 	drm_drawable_t handle;
59860405de4Skz151634 } drm_draw_t;
59960405de4Skz151634 
60060405de4Skz151634 /**
601d0538f66Scg149915  * DRM_IOCTL_UPDATE_DRAW ioctl argument type.
602d0538f66Scg149915  */
603d0538f66Scg149915 typedef enum {
604d0538f66Scg149915          DRM_DRAWABLE_CLIPRECTS,
605d0538f66Scg149915 } drm_drawable_info_type_t;
606d0538f66Scg149915 
607d0538f66Scg149915 typedef struct drm_update_draw {
608d0538f66Scg149915 	drm_drawable_t handle;
609d0538f66Scg149915 	unsigned int type;
610d0538f66Scg149915 	unsigned int num;
611d0538f66Scg149915 	unsigned long long data;
612d0538f66Scg149915 } drm_update_draw_t;
613d0538f66Scg149915 
614d0538f66Scg149915 /**
61560405de4Skz151634  * DRM_IOCTL_GET_MAGIC and DRM_IOCTL_AUTH_MAGIC ioctl argument type.
61660405de4Skz151634  */
61760405de4Skz151634 typedef struct drm_auth {
61860405de4Skz151634 	drm_magic_t magic;
61960405de4Skz151634 } drm_auth_t;
62060405de4Skz151634 
62160405de4Skz151634 /**
62260405de4Skz151634  * DRM_IOCTL_IRQ_BUSID ioctl argument type.
62360405de4Skz151634  *
62460405de4Skz151634  * \sa drmGetInterruptFromBusID().
62560405de4Skz151634  */
62660405de4Skz151634 typedef struct drm_irq_busid {
62760405de4Skz151634 	int irq;	/**< IRQ number */
62860405de4Skz151634 	int busnum;	/**< bus number */
62960405de4Skz151634 	int devnum;	/**< device number */
63060405de4Skz151634 	int funcnum;	/**< function number */
63160405de4Skz151634 } drm_irq_busid_t;
63260405de4Skz151634 
63360405de4Skz151634 typedef enum {
63460405de4Skz151634 	_DRM_VBLANK_ABSOLUTE = 0x0,	/**< Wait for specific vblank sequence number */
63560405de4Skz151634 	_DRM_VBLANK_RELATIVE = 0x1,	/**< Wait for given number of vblanks */
636d0231070Smiao chen - Sun Microsystems - Beijing China 	_DRM_VBLANK_FLIP = 0x8000000,	/**< Scheduled buffer swap should flip */
637d0538f66Scg149915 	_DRM_VBLANK_NEXTONMISS = 0x10000000,    /**< If missed, wait for next vblank */
638d0538f66Scg149915 	_DRM_VBLANK_SECONDARY = 0x20000000,     /**< Secondary display controller */
63960405de4Skz151634 	_DRM_VBLANK_SIGNAL = 0x40000000	/**< Send signal instead of blocking */
64060405de4Skz151634 } drm_vblank_seq_type_t;
64160405de4Skz151634 
642d0538f66Scg149915 #define _DRM_VBLANK_TYPES_MASK (_DRM_VBLANK_ABSOLUTE | _DRM_VBLANK_RELATIVE)
643d0538f66Scg149915 #define _DRM_VBLANK_FLAGS_MASK (_DRM_VBLANK_SIGNAL | _DRM_VBLANK_SECONDARY | \
644d0538f66Scg149915 	_DRM_VBLANK_NEXTONMISS)
64560405de4Skz151634 
64660405de4Skz151634 struct drm_wait_vblank_request {
64760405de4Skz151634 	drm_vblank_seq_type_t type;
64860405de4Skz151634 	unsigned int sequence;
64960405de4Skz151634 	unsigned long signal;
65060405de4Skz151634 };
65160405de4Skz151634 
65260405de4Skz151634 struct drm_wait_vblank_reply {
65360405de4Skz151634 	drm_vblank_seq_type_t type;
65460405de4Skz151634 	unsigned int sequence;
65560405de4Skz151634 	long tval_sec;
65660405de4Skz151634 	long tval_usec;
65760405de4Skz151634 };
65860405de4Skz151634 
65960405de4Skz151634 /**
66060405de4Skz151634  * DRM_IOCTL_WAIT_VBLANK ioctl argument type.
66160405de4Skz151634  *
66260405de4Skz151634  * \sa drmWaitVBlank().
66360405de4Skz151634  */
66460405de4Skz151634 typedef union drm_wait_vblank {
66560405de4Skz151634 	struct drm_wait_vblank_request request;
66660405de4Skz151634 	struct drm_wait_vblank_reply reply;
66760405de4Skz151634 } drm_wait_vblank_t;
66860405de4Skz151634 
669*0035d21cSmiao chen - Sun Microsystems - Beijing China #define _DRM_PRE_MODESET 1
670*0035d21cSmiao chen - Sun Microsystems - Beijing China #define _DRM_POST_MODESET 2
671*0035d21cSmiao chen - Sun Microsystems - Beijing China 
672*0035d21cSmiao chen - Sun Microsystems - Beijing China /**
673*0035d21cSmiao chen - Sun Microsystems - Beijing China  * DRM_IOCTL_MODESET_CTL ioctl argument type
674*0035d21cSmiao chen - Sun Microsystems - Beijing China  *
675*0035d21cSmiao chen - Sun Microsystems - Beijing China  * \sa drmModesetCtl().
676*0035d21cSmiao chen - Sun Microsystems - Beijing China  */
677*0035d21cSmiao chen - Sun Microsystems - Beijing China typedef struct drm_modeset_ctl {
678*0035d21cSmiao chen - Sun Microsystems - Beijing China 	uint32_t crtc;
679*0035d21cSmiao chen - Sun Microsystems - Beijing China 	uint32_t cmd;
680*0035d21cSmiao chen - Sun Microsystems - Beijing China } drm_modeset_ctl_t;
681*0035d21cSmiao chen - Sun Microsystems - Beijing China 
68260405de4Skz151634 /**
68360405de4Skz151634  * DRM_IOCTL_AGP_ENABLE ioctl argument type.
68460405de4Skz151634  *
68560405de4Skz151634  * \sa drmAgpEnable().
68660405de4Skz151634  */
68760405de4Skz151634 typedef struct drm_agp_mode {
68860405de4Skz151634 	unsigned long mode;	/**< AGP mode */
68960405de4Skz151634 } drm_agp_mode_t;
69060405de4Skz151634 
69160405de4Skz151634 /**
69260405de4Skz151634  * DRM_IOCTL_AGP_ALLOC and DRM_IOCTL_AGP_FREE ioctls argument type.
69360405de4Skz151634  *
69460405de4Skz151634  * \sa drmAgpAlloc() and drmAgpFree().
69560405de4Skz151634  */
69660405de4Skz151634 typedef struct drm_agp_buffer {
69760405de4Skz151634 	unsigned long size;	/**< In bytes -- will round to page boundary */
69860405de4Skz151634 	unsigned long handle;	/**< Used for binding / unbinding */
69960405de4Skz151634 	unsigned long type;	/**< Type of memory to allocate */
70060405de4Skz151634 	unsigned long physical;	/**< Physical used by i810 */
70160405de4Skz151634 } drm_agp_buffer_t;
70260405de4Skz151634 
70360405de4Skz151634 /**
70460405de4Skz151634  * DRM_IOCTL_AGP_BIND and DRM_IOCTL_AGP_UNBIND ioctls argument type.
70560405de4Skz151634  *
70660405de4Skz151634  * \sa drmAgpBind() and drmAgpUnbind().
70760405de4Skz151634  */
70860405de4Skz151634 typedef struct drm_agp_binding {
70960405de4Skz151634 	unsigned long handle;	/**< From drm_agp_buffer */
71060405de4Skz151634 	unsigned long offset;	/**< In bytes -- will round to page boundary */
71160405de4Skz151634 } drm_agp_binding_t;
71260405de4Skz151634 
71360405de4Skz151634 /**
71460405de4Skz151634  * DRM_IOCTL_AGP_INFO ioctl argument type.
71560405de4Skz151634  *
71660405de4Skz151634  * \sa drmAgpVersionMajor(), drmAgpVersionMinor(), drmAgpGetMode(),
71760405de4Skz151634  * drmAgpBase(), drmAgpSize(), drmAgpMemoryUsed(), drmAgpMemoryAvail(),
71860405de4Skz151634  * drmAgpVendorId() and drmAgpDeviceId().
71960405de4Skz151634  */
72060405de4Skz151634 typedef struct drm_agp_info {
72160405de4Skz151634 	int agp_version_major;
72260405de4Skz151634 	int agp_version_minor;
72360405de4Skz151634 	unsigned long mode;
72460405de4Skz151634 	unsigned long aperture_base;   /**< physical address */
72560405de4Skz151634 	unsigned long aperture_size;   /**< bytes */
72660405de4Skz151634 	unsigned long memory_allowed;  /**< bytes */
72760405de4Skz151634 	unsigned long memory_used;
72860405de4Skz151634 
72960405de4Skz151634 	/** \name PCI information */
73060405de4Skz151634 	/*@{ */
73160405de4Skz151634 	unsigned short id_vendor;
73260405de4Skz151634 	unsigned short id_device;
73360405de4Skz151634 	/*@} */
73460405de4Skz151634 } drm_agp_info_t;
73560405de4Skz151634 
73660405de4Skz151634 /**
73760405de4Skz151634  * DRM_IOCTL_SG_ALLOC ioctl argument type.
73860405de4Skz151634  */
73960405de4Skz151634 typedef struct drm_scatter_gather {
74060405de4Skz151634 	unsigned long size;	/**< In bytes -- will round to page boundary */
74160405de4Skz151634 	unsigned long handle;	/**< Used for mapping / unmapping */
74260405de4Skz151634 } drm_scatter_gather_t;
74360405de4Skz151634 
74460405de4Skz151634 /**
74560405de4Skz151634  * DRM_IOCTL_SET_VERSION ioctl argument type.
74660405de4Skz151634  */
74760405de4Skz151634 typedef struct drm_set_version {
74860405de4Skz151634 	int drm_di_major;
74960405de4Skz151634 	int drm_di_minor;
75060405de4Skz151634 	int drm_dd_major;
75160405de4Skz151634 	int drm_dd_minor;
75260405de4Skz151634 } drm_set_version_t;
75360405de4Skz151634 
754*0035d21cSmiao chen - Sun Microsystems - Beijing China /** DRM_IOCTL_GEM_CLOSE ioctl argument type */
755*0035d21cSmiao chen - Sun Microsystems - Beijing China typedef struct drm_gem_close {
756*0035d21cSmiao chen - Sun Microsystems - Beijing China 	/** Handle of the object to be closed. */
757*0035d21cSmiao chen - Sun Microsystems - Beijing China 	uint32_t handle;
758*0035d21cSmiao chen - Sun Microsystems - Beijing China 	uint32_t pad;
759*0035d21cSmiao chen - Sun Microsystems - Beijing China } drm_gem_close_t;
760*0035d21cSmiao chen - Sun Microsystems - Beijing China 
761*0035d21cSmiao chen - Sun Microsystems - Beijing China /** DRM_IOCTL_GEM_FLINK ioctl argument type */
762*0035d21cSmiao chen - Sun Microsystems - Beijing China typedef struct drm_gem_flink {
763*0035d21cSmiao chen - Sun Microsystems - Beijing China 	/** Handle for the object being named */
764*0035d21cSmiao chen - Sun Microsystems - Beijing China 	uint32_t handle;
765*0035d21cSmiao chen - Sun Microsystems - Beijing China 
766*0035d21cSmiao chen - Sun Microsystems - Beijing China 	/** Returned global name */
767*0035d21cSmiao chen - Sun Microsystems - Beijing China 	uint32_t name;
768*0035d21cSmiao chen - Sun Microsystems - Beijing China } drm_gem_flink_t;
769*0035d21cSmiao chen - Sun Microsystems - Beijing China 
770*0035d21cSmiao chen - Sun Microsystems - Beijing China /** DRM_IOCTL_GEM_OPEN ioctl argument type */
771*0035d21cSmiao chen - Sun Microsystems - Beijing China typedef struct drm_gem_open {
772*0035d21cSmiao chen - Sun Microsystems - Beijing China 	/** Name of object being opened */
773*0035d21cSmiao chen - Sun Microsystems - Beijing China 	uint32_t name;
774*0035d21cSmiao chen - Sun Microsystems - Beijing China 
775*0035d21cSmiao chen - Sun Microsystems - Beijing China 	/** Returned handle for the object */
776*0035d21cSmiao chen - Sun Microsystems - Beijing China 	uint32_t handle;
777*0035d21cSmiao chen - Sun Microsystems - Beijing China 
778*0035d21cSmiao chen - Sun Microsystems - Beijing China 	/** Returned size of the object */
779*0035d21cSmiao chen - Sun Microsystems - Beijing China 	uint64_t size;
780*0035d21cSmiao chen - Sun Microsystems - Beijing China } drm_gem_open_t;
781*0035d21cSmiao chen - Sun Microsystems - Beijing China 
78260405de4Skz151634 /**
78360405de4Skz151634  * \name Ioctls Definitions
78460405de4Skz151634  */
78560405de4Skz151634 /*@{*/
78660405de4Skz151634 
78760405de4Skz151634 #define DRM_IOCTL_BASE			'd'
78860405de4Skz151634 #define DRM_IO(nr)			_IO(DRM_IOCTL_BASE,nr)
78960405de4Skz151634 #define DRM_IOR(nr,type)		_IOR(DRM_IOCTL_BASE,nr,type)
79060405de4Skz151634 #define DRM_IOW(nr,type)		_IOW(DRM_IOCTL_BASE,nr,type)
79160405de4Skz151634 #define DRM_IOWR(nr,type)		_IOWR(DRM_IOCTL_BASE,nr,type)
79260405de4Skz151634 
79360405de4Skz151634 #define DRM_IOCTL_VERSION		DRM_IOWR(0x00, drm_version_t)
79460405de4Skz151634 #define DRM_IOCTL_GET_UNIQUE		DRM_IOWR(0x01, drm_unique_t)
79560405de4Skz151634 #define DRM_IOCTL_GET_MAGIC		DRM_IOR( 0x02, drm_auth_t)
79660405de4Skz151634 #define DRM_IOCTL_IRQ_BUSID		DRM_IOWR(0x03, drm_irq_busid_t)
79760405de4Skz151634 #define DRM_IOCTL_GET_MAP               DRM_IOWR(0x04, drm_map_t)
79860405de4Skz151634 #define DRM_IOCTL_GET_CLIENT            DRM_IOWR(0x05, drm_client_t)
79960405de4Skz151634 #define DRM_IOCTL_GET_STATS             DRM_IOR( 0x06, drm_stats_t)
80060405de4Skz151634 #define DRM_IOCTL_SET_VERSION		DRM_IOWR(0x07, drm_set_version_t)
801*0035d21cSmiao chen - Sun Microsystems - Beijing China #define DRM_IOCTL_MODESET_CTL           DRM_IOW(0x08,	drm_modeset_ctl_t)
802*0035d21cSmiao chen - Sun Microsystems - Beijing China #define DRM_IOCTL_GEM_CLOSE		DRM_IOW (0x09, drm_gem_close_t)
803*0035d21cSmiao chen - Sun Microsystems - Beijing China #define DRM_IOCTL_GEM_FLINK		DRM_IOWR(0x0a, drm_gem_flink_t)
804*0035d21cSmiao chen - Sun Microsystems - Beijing China #define DRM_IOCTL_GEM_OPEN		DRM_IOWR(0x0b, drm_gem_open_t)
80560405de4Skz151634 
80660405de4Skz151634 #define DRM_IOCTL_SET_UNIQUE		DRM_IOW( 0x10, drm_unique_t)
80760405de4Skz151634 #define DRM_IOCTL_AUTH_MAGIC		DRM_IOW( 0x11, drm_auth_t)
80860405de4Skz151634 #define DRM_IOCTL_BLOCK			DRM_IOWR(0x12, drm_block_t)
80960405de4Skz151634 #define DRM_IOCTL_UNBLOCK		DRM_IOWR(0x13, drm_block_t)
81060405de4Skz151634 #define DRM_IOCTL_CONTROL		DRM_IOW( 0x14, drm_control_t)
81160405de4Skz151634 #define DRM_IOCTL_ADD_MAP		DRM_IOWR(0x15, drm_map_t)
81260405de4Skz151634 #define DRM_IOCTL_ADD_BUFS		DRM_IOWR(0x16, drm_buf_desc_t)
81360405de4Skz151634 #define DRM_IOCTL_MARK_BUFS		DRM_IOW( 0x17, drm_buf_desc_t)
81460405de4Skz151634 #define DRM_IOCTL_INFO_BUFS		DRM_IOWR(0x18, drm_buf_info_t)
81560405de4Skz151634 #define DRM_IOCTL_MAP_BUFS		DRM_IOWR(0x19, drm_buf_map_t)
81660405de4Skz151634 #define DRM_IOCTL_FREE_BUFS		DRM_IOW( 0x1a, drm_buf_free_t)
81760405de4Skz151634 
81860405de4Skz151634 #define DRM_IOCTL_RM_MAP		DRM_IOW( 0x1b, drm_map_t)
81960405de4Skz151634 
82060405de4Skz151634 #define DRM_IOCTL_SET_SAREA_CTX		DRM_IOW( 0x1c, drm_ctx_priv_map_t)
82160405de4Skz151634 #define DRM_IOCTL_GET_SAREA_CTX 	DRM_IOWR(0x1d, drm_ctx_priv_map_t)
82260405de4Skz151634 
82360405de4Skz151634 #define DRM_IOCTL_ADD_CTX		DRM_IOWR(0x20, drm_ctx_t)
82460405de4Skz151634 #define DRM_IOCTL_RM_CTX		DRM_IOWR(0x21, drm_ctx_t)
82560405de4Skz151634 #define DRM_IOCTL_MOD_CTX		DRM_IOW( 0x22, drm_ctx_t)
82660405de4Skz151634 #define DRM_IOCTL_GET_CTX		DRM_IOWR(0x23, drm_ctx_t)
82760405de4Skz151634 #define DRM_IOCTL_SWITCH_CTX		DRM_IOW( 0x24, drm_ctx_t)
82860405de4Skz151634 #define DRM_IOCTL_NEW_CTX		DRM_IOW( 0x25, drm_ctx_t)
82960405de4Skz151634 #define DRM_IOCTL_RES_CTX		DRM_IOWR(0x26, drm_ctx_res_t)
83060405de4Skz151634 #define DRM_IOCTL_ADD_DRAW		DRM_IOWR(0x27, drm_draw_t)
83160405de4Skz151634 #define DRM_IOCTL_RM_DRAW		DRM_IOWR(0x28, drm_draw_t)
83260405de4Skz151634 #define DRM_IOCTL_DMA			DRM_IOWR(0x29, drm_dma_t)
83360405de4Skz151634 #define DRM_IOCTL_LOCK			DRM_IOW( 0x2a, drm_lock_t)
83460405de4Skz151634 #define DRM_IOCTL_UNLOCK		DRM_IOW( 0x2b, drm_lock_t)
83560405de4Skz151634 #define DRM_IOCTL_FINISH		DRM_IOW( 0x2c, drm_lock_t)
83660405de4Skz151634 
83760405de4Skz151634 #define DRM_IOCTL_AGP_ACQUIRE		DRM_IO(  0x30)
83860405de4Skz151634 #define DRM_IOCTL_AGP_RELEASE		DRM_IO(  0x31)
83960405de4Skz151634 #define DRM_IOCTL_AGP_ENABLE		DRM_IOW( 0x32, drm_agp_mode_t)
84060405de4Skz151634 #define DRM_IOCTL_AGP_INFO		DRM_IOR( 0x33, drm_agp_info_t)
84160405de4Skz151634 #define DRM_IOCTL_AGP_ALLOC		DRM_IOWR(0x34, drm_agp_buffer_t)
84260405de4Skz151634 #define DRM_IOCTL_AGP_FREE		DRM_IOW( 0x35, drm_agp_buffer_t)
84360405de4Skz151634 #define DRM_IOCTL_AGP_BIND		DRM_IOW( 0x36, drm_agp_binding_t)
84460405de4Skz151634 #define DRM_IOCTL_AGP_UNBIND		DRM_IOW( 0x37, drm_agp_binding_t)
84560405de4Skz151634 
84660405de4Skz151634 #define DRM_IOCTL_SG_ALLOC		DRM_IOW( 0x38, drm_scatter_gather_t)
84760405de4Skz151634 #define DRM_IOCTL_SG_FREE		DRM_IOW( 0x39, drm_scatter_gather_t)
84860405de4Skz151634 
84960405de4Skz151634 #define DRM_IOCTL_WAIT_VBLANK		DRM_IOWR(0x3a, drm_wait_vblank_t)
85060405de4Skz151634 
851d0231070Smiao chen - Sun Microsystems - Beijing China #define DRM_IOCTL_UPDATE_DRAW           DRM_IOW(0x3f, drm_update_draw_t)
85260405de4Skz151634 /*@}*/
85360405de4Skz151634 
85460405de4Skz151634 /**
85560405de4Skz151634  * Device specific ioctls should only be in their respective headers
856e92e3a86Szw161486  * The device specific ioctl range is from 0x40 to 0x99.
857e92e3a86Szw161486  * Generic IOCTLS restart at 0xA0.
85860405de4Skz151634  *
85960405de4Skz151634  * \sa drmCommandNone(), drmCommandRead(), drmCommandWrite(), and
86060405de4Skz151634  * drmCommandReadWrite().
86160405de4Skz151634  */
86260405de4Skz151634 #define DRM_COMMAND_BASE                0x40
863e92e3a86Szw161486 #define DRM_COMMAND_END                 0xA0
86460405de4Skz151634 
86560405de4Skz151634 #endif /* _DRM_H_ */
866