2005-04-16 15:20:36 -07:00
/**
2005-09-25 14:28:13 +10:00
* \ file drm . h
2005-04-16 15:20:36 -07:00
* Header for the Direct Rendering Manager
2005-09-25 14:28:13 +10:00
*
2005-04-16 15:20:36 -07:00
* \ author Rickard E . ( Rik ) Faith < faith @ valinux . com >
*
* \ par Acknowledgments :
* Dec 1999 , Richard Henderson < rth @ twiddle . net > , move to generic \ c cmpxchg .
*/
/*
* Copyright 1999 Precision Insight , Inc . , Cedar Park , Texas .
* Copyright 2000 VA Linux Systems , Inc . , Sunnyvale , California .
* All rights reserved .
*
* Permission is hereby granted , free of charge , to any person obtaining a
* copy of this software and associated documentation files ( the " Software " ) ,
* to deal in the Software without restriction , including without limitation
* the rights to use , copy , modify , merge , publish , distribute , sublicense ,
* and / or sell copies of the Software , and to permit persons to whom the
* Software is furnished to do so , subject to the following conditions :
*
* The above copyright notice and this permission notice ( including the next
* paragraph ) shall be included in all copies or substantial portions of the
* Software .
*
* THE SOFTWARE IS PROVIDED " AS IS " , WITHOUT WARRANTY OF ANY KIND , EXPRESS OR
* IMPLIED , INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY ,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT . IN NO EVENT SHALL
* VA LINUX SYSTEMS AND / OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM , DAMAGES OR
* OTHER LIABILITY , WHETHER IN AN ACTION OF CONTRACT , TORT OR OTHERWISE ,
* ARISING FROM , OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE .
*/
# ifndef _DRM_H_
# define _DRM_H_
2016-03-30 16:42:22 +02:00
# if defined(__KERNEL__)
# include <linux/types.h>
# include <asm/ioctl.h>
typedef unsigned int drm_handle_t ;
# elif defined(__linux__)
2009-12-02 12:13:48 -05:00
2009-02-26 00:51:42 +01:00
# include <linux/types.h>
2009-12-02 12:13:48 -05:00
# include <asm/ioctl.h>
typedef unsigned int drm_handle_t ;
# else /* One of the BSDs */
2005-04-16 15:20:36 -07:00
2019-01-15 15:04:18 +00:00
# include <stdint.h>
2009-12-02 12:13:48 -05:00
# include <sys/ioccom.h>
# include <sys/types.h>
typedef int8_t __s8 ;
typedef uint8_t __u8 ;
typedef int16_t __s16 ;
typedef uint16_t __u16 ;
typedef int32_t __s32 ;
typedef uint32_t __u32 ;
typedef int64_t __s64 ;
typedef uint64_t __u64 ;
2014-08-31 12:58:46 +02:00
typedef size_t __kernel_size_t ;
2009-12-02 12:13:48 -05:00
typedef unsigned long drm_handle_t ;
# endif
2007-08-28 15:16:47 +10:00
2016-04-07 18:49:00 +01:00
# if defined(__cplusplus)
extern " C " {
# endif
2005-04-16 15:20:36 -07:00
# define DRM_NAME "drm" /**< Name in kernel, /dev, and /proc */
# define DRM_MIN_ORDER 5 /**< At least 2^5 bytes = 32 bytes */
# define DRM_MAX_ORDER 22 /**< Up to 2^22 bytes = 4MB */
# define DRM_RAM_PERCENT 10 /**< How much system ram can we lock? */
2006-01-02 21:15:01 +11:00
# define _DRM_LOCK_HELD 0x80000000U /**< Hardware lock is held */
# define _DRM_LOCK_CONT 0x40000000U /**< Hardware lock is contended */
2005-04-16 15:20:36 -07:00
# define _DRM_LOCK_IS_HELD(lock) ((lock) & _DRM_LOCK_HELD)
# define _DRM_LOCK_IS_CONT(lock) ((lock) & _DRM_LOCK_CONT)
# define _DRM_LOCKING_CONTEXT(lock) ((lock) & ~(_DRM_LOCK_HELD|_DRM_LOCK_CONT))
2005-09-25 14:28:13 +10:00
typedef unsigned int drm_context_t ;
typedef unsigned int drm_drawable_t ;
typedef unsigned int drm_magic_t ;
2005-04-16 15:20:36 -07:00
/**
* Cliprect .
2005-09-25 14:28:13 +10:00
*
2005-04-16 15:20:36 -07:00
* \ warning : If you change this structure , make sure you change
* XF86DRIClipRectRec in the server as well
*
* \ note KW : Actually it ' s illegal to change either for
* backwards - compatibility reasons .
*/
2007-07-11 15:27:12 +10:00
struct drm_clip_rect {
2005-09-25 14:28:13 +10:00
unsigned short x1 ;
unsigned short y1 ;
unsigned short x2 ;
unsigned short y2 ;
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
2006-10-24 23:04:19 +10:00
/**
* Drawable information .
*/
2007-07-11 15:27:12 +10:00
struct drm_drawable_info {
2006-10-24 23:04:19 +10:00
unsigned int num_rects ;
2007-07-11 15:27:12 +10:00
struct drm_clip_rect * rects ;
} ;
2006-10-24 23:04:19 +10:00
2005-04-16 15:20:36 -07:00
/**
* Texture region ,
*/
2007-07-11 15:27:12 +10:00
struct drm_tex_region {
2005-09-25 14:28:13 +10:00
unsigned char next ;
unsigned char prev ;
unsigned char in_use ;
unsigned char padding ;
unsigned int age ;
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* Hardware lock .
*
* The lock structure is a simple cache - line aligned integer . To avoid
* processor bus contention on a multiprocessor system , there should not be any
* other data stored in the same cache line .
*/
2007-07-11 15:27:12 +10:00
struct drm_hw_lock {
2005-04-16 15:20:36 -07:00
__volatile__ unsigned int lock ; /**< lock variable */
2005-09-25 14:28:13 +10:00
char padding [ 60 ] ; /**< Pad to cache line */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_VERSION ioctl argument type .
2005-09-25 14:28:13 +10:00
*
2005-04-16 15:20:36 -07:00
* \ sa drmGetVersion ( ) .
*/
2007-07-11 15:27:12 +10:00
struct drm_version {
2005-09-25 14:28:13 +10:00
int version_major ; /**< Major version */
int version_minor ; /**< Minor version */
int version_patchlevel ; /**< Patch level */
2014-08-31 12:58:46 +02:00
__kernel_size_t name_len ; /**< Length of name buffer */
2005-09-25 14:28:13 +10:00
char __user * name ; /**< Name of driver */
2014-08-31 12:58:46 +02:00
__kernel_size_t date_len ; /**< Length of date buffer */
2005-09-25 14:28:13 +10:00
char __user * date ; /**< User-space buffer to hold date */
2014-08-31 12:58:46 +02:00
__kernel_size_t desc_len ; /**< Length of desc buffer */
2005-09-25 14:28:13 +10:00
char __user * desc ; /**< User-space buffer to hold desc */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_GET_UNIQUE ioctl argument type .
*
* \ sa drmGetBusid ( ) and drmSetBusId ( ) .
*/
2007-07-11 15:27:12 +10:00
struct drm_unique {
2014-08-31 12:58:46 +02:00
__kernel_size_t unique_len ; /**< Length of unique */
2005-09-25 14:28:13 +10:00
char __user * unique ; /**< Unique name for driver instantiation */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
2007-07-11 15:27:12 +10:00
struct drm_list {
2005-09-25 14:28:13 +10:00
int count ; /**< Length of user-space structures */
2007-07-11 15:27:12 +10:00
struct drm_version __user * version ;
} ;
2005-04-16 15:20:36 -07:00
2007-07-11 15:27:12 +10:00
struct drm_block {
2005-09-25 14:28:13 +10:00
int unused ;
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_CONTROL ioctl argument type .
*
* \ sa drmCtlInstHandler ( ) and drmCtlUninstHandler ( ) .
*/
2007-07-11 15:27:12 +10:00
struct drm_control {
2005-04-16 15:20:36 -07:00
enum {
DRM_ADD_COMMAND ,
DRM_RM_COMMAND ,
DRM_INST_HANDLER ,
DRM_UNINST_HANDLER
2005-09-25 14:28:13 +10:00
} func ;
int irq ;
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* Type of memory to map .
*/
2007-07-11 15:27:12 +10:00
enum drm_map_type {
2005-09-25 14:28:13 +10:00
_DRM_FRAME_BUFFER = 0 , /**< WC (no caching), no core dump */
_DRM_REGISTERS = 1 , /**< no caching, no core dump */
_DRM_SHM = 2 , /**< shared, cached */
_DRM_AGP = 3 , /**< AGP/GART */
2005-07-10 14:34:13 +10:00
_DRM_SCATTER_GATHER = 4 , /**< Scatter/gather memory for PCI DMA */
2016-03-30 16:42:23 +02:00
_DRM_CONSISTENT = 5 /**< Consistent memory for PCI DMA */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* Memory mapping flags .
*/
2007-07-11 15:27:12 +10:00
enum drm_map_flags {
2005-09-25 14:28:13 +10:00
_DRM_RESTRICTED = 0x01 , /**< Cannot be mapped to user-virtual */
_DRM_READ_ONLY = 0x02 ,
_DRM_LOCKED = 0x04 , /**< shared, cached, locked */
_DRM_KERNEL = 0x08 , /**< kernel requires access */
2005-04-16 15:20:36 -07:00
_DRM_WRITE_COMBINING = 0x10 , /**< use write-combining if available */
2005-09-25 14:28:13 +10:00
_DRM_CONTAINS_LOCK = 0x20 , /**< SHM page that contains lock */
2007-12-17 09:41:56 +10:00
_DRM_REMOVABLE = 0x40 , /**< Removable mapping */
_DRM_DRIVER = 0x80 /**< Managed by driver */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
2007-07-11 15:27:12 +10:00
struct drm_ctx_priv_map {
2005-09-25 14:28:13 +10:00
unsigned int ctx_id ; /**< Context requesting private mapping */
void * handle ; /**< Handle of map */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_GET_MAP , DRM_IOCTL_ADD_MAP and DRM_IOCTL_RM_MAP ioctls
* argument type .
*
* \ sa drmAddMap ( ) .
*/
2007-07-11 15:27:12 +10:00
struct drm_map {
2005-09-25 14:28:13 +10:00
unsigned long offset ; /**< Requested physical address (0 for SAREA)*/
unsigned long size ; /**< Requested physical size (bytes) */
2007-07-11 15:27:12 +10:00
enum drm_map_type type ; /**< Type of memory to map */
enum drm_map_flags flags ; /**< Flags */
2005-09-25 14:28:13 +10:00
void * handle ; /**< User-space: "Handle" to pass to mmap() */
2005-04-16 15:20:36 -07:00
/**< Kernel-space: kernel-virtual address */
2005-09-25 14:28:13 +10:00
int mtrr ; /**< MTRR slot used */
/* Private data */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_GET_CLIENT ioctl argument type .
*/
2007-07-11 15:27:12 +10:00
struct drm_client {
2005-09-25 14:28:13 +10:00
int idx ; /**< Which client desired? */
int auth ; /**< Is client authenticated? */
unsigned long pid ; /**< Process ID */
unsigned long uid ; /**< User ID */
unsigned long magic ; /**< Magic */
unsigned long iocs ; /**< Ioctl count */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
2007-07-11 15:27:12 +10:00
enum drm_stat_type {
2005-04-16 15:20:36 -07:00
_DRM_STAT_LOCK ,
_DRM_STAT_OPENS ,
_DRM_STAT_CLOSES ,
_DRM_STAT_IOCTLS ,
_DRM_STAT_LOCKS ,
_DRM_STAT_UNLOCKS ,
_DRM_STAT_VALUE , /**< Generic value */
_DRM_STAT_BYTE , /**< Generic byte counter (1024bytes/K) */
_DRM_STAT_COUNT , /**< Generic non-byte counter (1000/k) */
_DRM_STAT_IRQ , /**< IRQ */
_DRM_STAT_PRIMARY , /**< Primary DMA bytes */
_DRM_STAT_SECONDARY , /**< Secondary DMA bytes */
_DRM_STAT_DMA , /**< DMA */
_DRM_STAT_SPECIAL , /**< Special DMA (e.g., priority or polled) */
_DRM_STAT_MISSED /**< Missed DMA opportunity */
2005-09-25 14:28:13 +10:00
/* Add to the *END* of the list */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_GET_STATS ioctl argument type .
*/
2007-07-11 15:27:12 +10:00
struct drm_stats {
2005-04-16 15:20:36 -07:00
unsigned long count ;
struct {
2005-09-25 14:28:13 +10:00
unsigned long value ;
2007-07-11 15:27:12 +10:00
enum drm_stat_type type ;
2005-04-16 15:20:36 -07:00
} data [ 15 ] ;
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* Hardware locking flags .
*/
2007-07-11 15:27:12 +10:00
enum drm_lock_flags {
2005-09-25 14:28:13 +10:00
_DRM_LOCK_READY = 0x01 , /**< Wait until hardware is ready for DMA */
_DRM_LOCK_QUIESCENT = 0x02 , /**< Wait until hardware quiescent */
_DRM_LOCK_FLUSH = 0x04 , /**< Flush this context's DMA queue first */
_DRM_LOCK_FLUSH_ALL = 0x08 , /**< Flush all DMA queues first */
/* These *HALT* flags aren't supported yet
- - they will be used to support the
full - screen DGA - like mode . */
2005-04-16 15:20:36 -07:00
_DRM_HALT_ALL_QUEUES = 0x10 , /**< Halt all current and future queues */
_DRM_HALT_CUR_QUEUES = 0x20 /**< Halt all current queues */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_LOCK , DRM_IOCTL_UNLOCK and DRM_IOCTL_FINISH ioctl argument type .
2005-09-25 14:28:13 +10:00
*
2005-04-16 15:20:36 -07:00
* \ sa drmGetLock ( ) and drmUnlock ( ) .
*/
2007-07-11 15:27:12 +10:00
struct drm_lock {
2005-09-25 14:28:13 +10:00
int context ;
2007-07-11 15:27:12 +10:00
enum drm_lock_flags flags ;
} ;
2005-04-16 15:20:36 -07:00
/**
* DMA flags
*
2005-09-25 14:28:13 +10:00
* \ warning
2005-04-16 15:20:36 -07:00
* These values \ e must match xf86drm . h .
*
* \ sa drm_dma .
*/
2007-07-11 15:27:12 +10:00
enum drm_dma_flags {
2005-09-25 14:28:13 +10:00
/* Flags for DMA buffer dispatch */
_DRM_DMA_BLOCK = 0x01 , /**<
2005-04-16 15:20:36 -07:00
* Block until buffer dispatched .
2005-09-25 14:28:13 +10:00
*
2005-04-16 15:20:36 -07:00
* \ note The buffer may not yet have
* been processed by the hardware - -
* getting a hardware lock with the
* hardware quiescent will ensure
* that the buffer has been
* processed .
*/
_DRM_DMA_WHILE_LOCKED = 0x02 , /**< Dispatch while lock held */
2005-09-25 14:28:13 +10:00
_DRM_DMA_PRIORITY = 0x04 , /**< High priority dispatch */
2005-04-16 15:20:36 -07:00
2005-09-25 14:28:13 +10:00
/* Flags for DMA buffer request */
_DRM_DMA_WAIT = 0x10 , /**< Wait for free buffers */
_DRM_DMA_SMALLER_OK = 0x20 , /**< Smaller-than-requested buffers OK */
_DRM_DMA_LARGER_OK = 0x40 /**< Larger-than-requested buffers OK */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_ADD_BUFS and DRM_IOCTL_MARK_BUFS ioctl argument type .
*
* \ sa drmAddBufs ( ) .
*/
2007-07-11 15:27:12 +10:00
struct drm_buf_desc {
2005-09-25 14:28:13 +10:00
int count ; /**< Number of buffers of this size */
int size ; /**< Size in bytes */
int low_mark ; /**< Low water mark */
int high_mark ; /**< High water mark */
2005-04-16 15:20:36 -07:00
enum {
2005-09-25 14:28:13 +10:00
_DRM_PAGE_ALIGN = 0x01 , /**< Align on page boundaries for DMA */
_DRM_AGP_BUFFER = 0x02 , /**< Buffer is in AGP space */
_DRM_SG_BUFFER = 0x04 , /**< Scatter/gather memory buffer */
2006-10-24 12:03:04 -07:00
_DRM_FB_BUFFER = 0x08 , /**< Buffer is in frame buffer */
_DRM_PCI_BUFFER_RO = 0x10 /**< Map PCI DMA buffer read-only */
2005-09-25 14:28:13 +10:00
} flags ;
unsigned long agp_start ; /**<
2005-04-16 15:20:36 -07:00
* Start address of where the AGP buffers are
* in the AGP aperture
*/
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_INFO_BUFS ioctl argument type .
*/
2007-07-11 15:27:12 +10:00
struct drm_buf_info {
2005-09-25 14:28:13 +10:00
int count ; /**< Entries in list */
2007-07-11 15:27:12 +10:00
struct drm_buf_desc __user * list ;
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_FREE_BUFS ioctl argument type .
*/
2007-07-11 15:27:12 +10:00
struct drm_buf_free {
2005-09-25 14:28:13 +10:00
int count ;
int __user * list ;
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* Buffer information
*
* \ sa drm_buf_map .
*/
2007-07-11 15:27:12 +10:00
struct drm_buf_pub {
2005-09-25 14:28:13 +10:00
int idx ; /**< Index into the master buffer list */
int total ; /**< Buffer size */
int used ; /**< Amount of buffer in use (for DMA) */
void __user * address ; /**< Address of buffer */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_MAP_BUFS ioctl argument type .
*/
2007-07-11 15:27:12 +10:00
struct drm_buf_map {
2005-09-25 14:28:13 +10:00
int count ; /**< Length of the buffer list */
2016-03-30 17:12:33 +02:00
# ifdef __cplusplus
void __user * virt ;
# else
2005-09-25 14:28:13 +10:00
void __user * virtual ; /**< Mmap'd area in user-virtual */
2016-03-30 17:12:33 +02:00
# endif
2007-07-11 15:27:12 +10:00
struct drm_buf_pub __user * list ; /**< Buffer information */
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_DMA ioctl argument type .
*
* Indices here refer to the offset into the buffer list in drm_buf_get .
*
* \ sa drmDMA ( ) .
*/
2007-07-11 15:27:12 +10:00
struct drm_dma {
2005-09-25 14:28:13 +10:00
int context ; /**< Context handle */
int send_count ; /**< Number of buffers to send */
int __user * send_indices ; /**< List of handles to buffers */
int __user * send_sizes ; /**< Lengths of data to send */
2007-07-11 15:27:12 +10:00
enum drm_dma_flags flags ; /**< Flags */
2005-09-25 14:28:13 +10:00
int request_count ; /**< Number of buffers requested */
int request_size ; /**< Desired size for buffers */
int __user * request_indices ; /**< Buffer information */
int __user * request_sizes ;
int granted_count ; /**< Number of buffers granted */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
2007-07-11 15:27:12 +10:00
enum drm_ctx_flags {
2005-04-16 15:20:36 -07:00
_DRM_CONTEXT_PRESERVED = 0x01 ,
2005-09-25 14:28:13 +10:00
_DRM_CONTEXT_2DONLY = 0x02
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_ADD_CTX ioctl argument type .
*
* \ sa drmCreateContext ( ) and drmDestroyContext ( ) .
*/
2007-07-11 15:27:12 +10:00
struct drm_ctx {
2005-09-25 14:28:13 +10:00
drm_context_t handle ;
2007-07-11 15:27:12 +10:00
enum drm_ctx_flags flags ;
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_RES_CTX ioctl argument type .
*/
2007-07-11 15:27:12 +10:00
struct drm_ctx_res {
2005-09-25 14:28:13 +10:00
int count ;
2007-07-11 15:27:12 +10:00
struct drm_ctx __user * contexts ;
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_ADD_DRAW and DRM_IOCTL_RM_DRAW ioctl argument type .
*/
2007-07-11 15:27:12 +10:00
struct drm_draw {
2005-09-25 14:28:13 +10:00
drm_drawable_t handle ;
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
2006-10-24 23:04:19 +10:00
/**
* DRM_IOCTL_UPDATE_DRAW ioctl argument type .
*/
typedef enum {
2016-03-30 16:42:23 +02:00
DRM_DRAWABLE_CLIPRECTS
2006-10-24 23:04:19 +10:00
} drm_drawable_info_type_t ;
2007-07-11 15:27:12 +10:00
struct drm_update_draw {
2006-10-24 23:04:19 +10:00
drm_drawable_t handle ;
unsigned int type ;
unsigned int num ;
unsigned long long data ;
2007-07-11 15:27:12 +10:00
} ;
2006-10-24 23:04:19 +10:00
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_GET_MAGIC and DRM_IOCTL_AUTH_MAGIC ioctl argument type .
*/
2007-07-11 15:27:12 +10:00
struct drm_auth {
2005-09-25 14:28:13 +10:00
drm_magic_t magic ;
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_IRQ_BUSID ioctl argument type .
*
* \ sa drmGetInterruptFromBusID ( ) .
*/
2007-07-11 15:27:12 +10:00
struct drm_irq_busid {
2005-04-16 15:20:36 -07:00
int irq ; /**< IRQ number */
int busnum ; /**< bus number */
int devnum ; /**< device number */
int funcnum ; /**< function number */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
2007-07-11 15:27:12 +10:00
enum drm_vblank_seq_type {
2005-09-25 14:28:13 +10:00
_DRM_VBLANK_ABSOLUTE = 0x0 , /**< Wait for specific vblank sequence number */
_DRM_VBLANK_RELATIVE = 0x1 , /**< Wait for given number of vblanks */
2011-03-24 20:54:35 +10:00
/* bits 1-6 are reserved for high crtcs */
_DRM_VBLANK_HIGH_CRTC_MASK = 0x0000003e ,
2009-09-12 04:33:34 +10:00
_DRM_VBLANK_EVENT = 0x4000000 , /**< Send event instead of blocking */
2008-09-30 12:14:26 -07:00
_DRM_VBLANK_FLIP = 0x8000000 , /**< Scheduled buffer swap should flip */
2006-10-24 23:34:18 +10:00
_DRM_VBLANK_NEXTONMISS = 0x10000000 , /**< If missed, wait for next vblank */
2006-10-24 22:24:38 +10:00
_DRM_VBLANK_SECONDARY = 0x20000000 , /**< Secondary display controller */
2009-01-27 21:19:41 -08:00
_DRM_VBLANK_SIGNAL = 0x40000000 /**< Send signal instead of blocking, unsupported */
2007-07-11 15:27:12 +10:00
} ;
2011-03-24 20:54:35 +10:00
# define _DRM_VBLANK_HIGH_CRTC_SHIFT 1
2005-04-16 15:20:36 -07:00
2006-10-24 22:24:38 +10:00
# define _DRM_VBLANK_TYPES_MASK (_DRM_VBLANK_ABSOLUTE | _DRM_VBLANK_RELATIVE)
2009-09-12 04:33:34 +10:00
# define _DRM_VBLANK_FLAGS_MASK (_DRM_VBLANK_EVENT | _DRM_VBLANK_SIGNAL | \
_DRM_VBLANK_SECONDARY | _DRM_VBLANK_NEXTONMISS )
2005-04-16 15:20:36 -07:00
struct drm_wait_vblank_request {
2007-07-11 15:27:12 +10:00
enum drm_vblank_seq_type type ;
2005-04-16 15:20:36 -07:00
unsigned int sequence ;
unsigned long signal ;
} ;
struct drm_wait_vblank_reply {
2007-07-11 15:27:12 +10:00
enum drm_vblank_seq_type type ;
2005-04-16 15:20:36 -07:00
unsigned int sequence ;
long tval_sec ;
long tval_usec ;
} ;
/**
* DRM_IOCTL_WAIT_VBLANK ioctl argument type .
*
* \ sa drmWaitVBlank ( ) .
*/
2007-07-11 15:27:12 +10:00
union drm_wait_vblank {
2005-04-16 15:20:36 -07:00
struct drm_wait_vblank_request request ;
struct drm_wait_vblank_reply reply ;
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
2008-09-30 12:14:26 -07:00
# define _DRM_PRE_MODESET 1
# define _DRM_POST_MODESET 2
/**
* DRM_IOCTL_MODESET_CTL ioctl argument type
*
* \ sa drmModesetCtl ( ) .
*/
struct drm_modeset_ctl {
2009-02-26 00:51:42 +01:00
__u32 crtc ;
__u32 cmd ;
2008-09-30 12:14:26 -07:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_AGP_ENABLE ioctl argument type .
*
* \ sa drmAgpEnable ( ) .
*/
2007-07-11 15:27:12 +10:00
struct drm_agp_mode {
2005-04-16 15:20:36 -07:00
unsigned long mode ; /**< AGP mode */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_AGP_ALLOC and DRM_IOCTL_AGP_FREE ioctls argument type .
*
* \ sa drmAgpAlloc ( ) and drmAgpFree ( ) .
*/
2007-07-11 15:27:12 +10:00
struct drm_agp_buffer {
2005-04-16 15:20:36 -07:00
unsigned long size ; /**< In bytes -- will round to page boundary */
unsigned long handle ; /**< Used for binding / unbinding */
2005-09-25 14:28:13 +10:00
unsigned long type ; /**< Type of memory to allocate */
unsigned long physical ; /**< Physical used by i810 */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_AGP_BIND and DRM_IOCTL_AGP_UNBIND ioctls argument type .
*
* \ sa drmAgpBind ( ) and drmAgpUnbind ( ) .
*/
2007-07-11 15:27:12 +10:00
struct drm_agp_binding {
2005-09-25 14:28:13 +10:00
unsigned long handle ; /**< From drm_agp_buffer */
2005-04-16 15:20:36 -07:00
unsigned long offset ; /**< In bytes -- will round to page boundary */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_AGP_INFO ioctl argument type .
*
* \ sa drmAgpVersionMajor ( ) , drmAgpVersionMinor ( ) , drmAgpGetMode ( ) ,
* drmAgpBase ( ) , drmAgpSize ( ) , drmAgpMemoryUsed ( ) , drmAgpMemoryAvail ( ) ,
* drmAgpVendorId ( ) and drmAgpDeviceId ( ) .
*/
2007-07-11 15:27:12 +10:00
struct drm_agp_info {
2005-09-25 14:28:13 +10:00
int agp_version_major ;
int agp_version_minor ;
unsigned long mode ;
unsigned long aperture_base ; /* physical address */
unsigned long aperture_size ; /* bytes */
unsigned long memory_allowed ; /* bytes */
unsigned long memory_used ;
/* PCI information */
2005-04-16 15:20:36 -07:00
unsigned short id_vendor ;
unsigned short id_device ;
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_SG_ALLOC ioctl argument type .
*/
2007-07-11 15:27:12 +10:00
struct drm_scatter_gather {
2005-04-16 15:20:36 -07:00
unsigned long size ; /**< In bytes -- will round to page boundary */
unsigned long handle ; /**< Used for mapping / unmapping */
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
/**
* DRM_IOCTL_SET_VERSION ioctl argument type .
*/
2007-07-11 15:27:12 +10:00
struct drm_set_version {
2005-04-16 15:20:36 -07:00
int drm_di_major ;
int drm_di_minor ;
int drm_dd_major ;
int drm_dd_minor ;
2007-07-11 15:27:12 +10:00
} ;
2005-04-16 15:20:36 -07:00
2008-07-30 12:06:12 -07:00
/** DRM_IOCTL_GEM_CLOSE ioctl argument type */
struct drm_gem_close {
/** Handle of the object to be closed. */
2009-02-26 00:51:42 +01:00
__u32 handle ;
__u32 pad ;
2008-07-30 12:06:12 -07:00
} ;
/** DRM_IOCTL_GEM_FLINK ioctl argument type */
struct drm_gem_flink {
/** Handle for the object being named */
2009-02-26 00:51:42 +01:00
__u32 handle ;
2008-07-30 12:06:12 -07:00
/** Returned global name */
2009-02-26 00:51:42 +01:00
__u32 name ;
2008-07-30 12:06:12 -07:00
} ;
/** DRM_IOCTL_GEM_OPEN ioctl argument type */
struct drm_gem_open {
/** Name of object being opened */
2009-02-26 00:51:42 +01:00
__u32 name ;
2008-07-30 12:06:12 -07:00
/** Returned handle for the object */
2009-02-26 00:51:42 +01:00
__u32 handle ;
2008-07-30 12:06:12 -07:00
/** Returned size of the object */
2009-02-26 00:51:42 +01:00
__u64 size ;
2008-07-30 12:06:12 -07:00
} ;
2013-09-25 16:45:19 +01:00
# define DRM_CAP_DUMB_BUFFER 0x1
# define DRM_CAP_VBLANK_HIGH_CRTC 0x2
# define DRM_CAP_DUMB_PREFERRED_DEPTH 0x3
# define DRM_CAP_DUMB_PREFER_SHADOW 0x4
# define DRM_CAP_PRIME 0x5
# define DRM_PRIME_CAP_IMPORT 0x1
# define DRM_PRIME_CAP_EXPORT 0x2
# define DRM_CAP_TIMESTAMP_MONOTONIC 0x6
# define DRM_CAP_ASYNC_PAGE_FLIP 0x7
2014-03-28 12:31:05 +00:00
/*
* The CURSOR_WIDTH and CURSOR_HEIGHT capabilities return a valid widthxheight
* combination for the hardware cursor . The intention is that a hardware
* agnostic userspace can query a cursor plane size to use .
*
* Note that the cross - driver contract is to merely return a valid size ;
* drivers are free to attach another meaning on top , eg . i915 returns the
* maximum plane size .
*/
2014-02-12 12:48:23 -05:00
# define DRM_CAP_CURSOR_WIDTH 0x8
# define DRM_CAP_CURSOR_HEIGHT 0x9
2015-02-05 14:41:52 +00:00
# define DRM_CAP_ADDFB2_MODIFIERS 0x10
2016-08-08 16:23:39 +09:00
# define DRM_CAP_PAGE_FLIP_TARGET 0x11
2017-04-04 17:52:21 +01:00
# define DRM_CAP_CRTC_IN_VBLANK_EVENT 0x12
2017-04-04 13:26:24 +10:00
# define DRM_CAP_SYNCOBJ 0x13
2019-04-16 13:57:50 +01:00
# define DRM_CAP_SYNCOBJ_TIMELINE 0x14
2013-09-25 16:45:19 +01:00
2011-02-21 11:17:35 +10:00
/** DRM_IOCTL_GET_CAP ioctl argument type */
struct drm_get_cap {
__u64 capability ;
__u64 value ;
} ;
2013-09-25 16:45:22 +01:00
/**
* DRM_CLIENT_CAP_STEREO_3D
*
* if set to 1 , the DRM core will expose the stereo 3 D capabilities of the
* monitor by advertising the supported 3 D layouts in the flags of struct
* drm_mode_modeinfo .
*/
# define DRM_CLIENT_CAP_STEREO_3D 1
2014-04-01 15:22:42 -07:00
/**
* DRM_CLIENT_CAP_UNIVERSAL_PLANES
*
* If set to 1 , the DRM core will expose all planes ( overlay , primary , and
* cursor ) to userspace .
*/
# define DRM_CLIENT_CAP_UNIVERSAL_PLANES 2
2014-12-18 16:01:50 -05:00
/**
* DRM_CLIENT_CAP_ATOMIC
*
* If set to 1 , the DRM core will expose atomic properties to userspace
*/
# define DRM_CLIENT_CAP_ATOMIC 3
2018-05-08 16:39:41 +05:30
/**
* DRM_CLIENT_CAP_ASPECT_RATIO
*
* If set to 1 , the DRM core will provide aspect ratio information in modes .
*/
# define DRM_CLIENT_CAP_ASPECT_RATIO 4
2018-02-28 14:11:23 +00:00
/**
* DRM_CLIENT_CAP_WRITEBACK_CONNECTORS
*
* If set to 1 , the DRM core will expose special connectors to be used for
* writing back to memory the scene setup in the commit . Depends on client
* also supporting DRM_CLIENT_CAP_ATOMIC
*/
# define DRM_CLIENT_CAP_WRITEBACK_CONNECTORS 5
2013-09-25 16:45:20 +01:00
/** DRM_IOCTL_SET_CLIENT_CAP ioctl argument type */
struct drm_set_client_cap {
__u64 capability ;
__u64 value ;
} ;
2015-12-22 19:36:44 -02:00
# define DRM_RDWR O_RDWR
2011-11-25 15:21:02 +00:00
# define DRM_CLOEXEC O_CLOEXEC
struct drm_prime_handle {
__u32 handle ;
/** Flags.. only applicable for handle->fd */
__u32 flags ;
/** Returned dmabuf file descriptor */
__s32 fd ;
} ;
2017-04-04 13:26:24 +10:00
struct drm_syncobj_create {
__u32 handle ;
2017-08-25 10:52:25 -07:00
# define DRM_SYNCOBJ_CREATE_SIGNALED (1 << 0)
2017-04-04 13:26:24 +10:00
__u32 flags ;
} ;
struct drm_syncobj_destroy {
__u32 handle ;
__u32 pad ;
} ;
2017-04-26 04:09:02 +01:00
# define DRM_SYNCOBJ_FD_TO_HANDLE_FLAGS_IMPORT_SYNC_FILE (1 << 0)
# define DRM_SYNCOBJ_HANDLE_TO_FD_FLAGS_EXPORT_SYNC_FILE (1 << 0)
2017-04-04 13:26:24 +10:00
struct drm_syncobj_handle {
__u32 handle ;
__u32 flags ;
__s32 fd ;
__u32 pad ;
} ;
2019-04-01 17:51:01 +08:00
struct drm_syncobj_transfer {
__u32 src_handle ;
__u32 dst_handle ;
__u64 src_point ;
__u64 dst_point ;
__u32 flags ;
__u32 pad ;
} ;
2017-08-25 10:52:22 -07:00
# define DRM_SYNCOBJ_WAIT_FLAGS_WAIT_ALL (1 << 0)
2017-08-25 10:52:24 -07:00
# define DRM_SYNCOBJ_WAIT_FLAGS_WAIT_FOR_SUBMIT (1 << 1)
2019-04-01 17:50:57 +08:00
# define DRM_SYNCOBJ_WAIT_FLAGS_WAIT_AVAILABLE (1 << 2) /* wait for time point to become available */
2017-08-25 10:52:22 -07:00
struct drm_syncobj_wait {
__u64 handles ;
/* absolute timeout */
__s64 timeout_nsec ;
__u32 count_handles ;
__u32 flags ;
__u32 first_signaled ; /* only valid when not waiting all */
__u32 pad ;
} ;
2019-04-01 17:50:57 +08:00
struct drm_syncobj_timeline_wait {
__u64 handles ;
/* wait on specific timeline point for every handles*/
__u64 points ;
/* absolute timeout */
__s64 timeout_nsec ;
__u32 count_handles ;
__u32 flags ;
__u32 first_signaled ; /* only valid when not waiting all */
__u32 pad ;
} ;
2017-08-28 14:10:27 -07:00
struct drm_syncobj_array {
__u64 handles ;
__u32 count_handles ;
__u32 pad ;
} ;
2019-07-30 21:02:08 +08:00
# define DRM_SYNCOBJ_QUERY_FLAGS_LAST_SUBMITTED (1 << 0) /* last available point on timeline syncobj */
2019-04-01 17:50:58 +08:00
struct drm_syncobj_timeline_array {
__u64 handles ;
__u64 points ;
__u32 count_handles ;
2019-07-30 21:02:08 +08:00
__u32 flags ;
2019-04-01 17:50:58 +08:00
} ;
2017-06-29 22:49:31 -07:00
/* Query current scanout sequence number */
struct drm_crtc_get_sequence {
__u32 crtc_id ; /* requested crtc_id */
__u32 active ; /* return: crtc output is active */
__u64 sequence ; /* return: most recent vblank sequence */
__s64 sequence_ns ; /* return: most recent time of first pixel out */
} ;
/* Queue event to be delivered at specified sequence. Time stamp marks
* when the first pixel of the refresh cycle leaves the display engine
* for the display
*/
# define DRM_CRTC_SEQUENCE_RELATIVE 0x00000001 /* sequence is relative to current */
# define DRM_CRTC_SEQUENCE_NEXT_ON_MISS 0x00000002 /* Use next sequence if we've missed */
struct drm_crtc_queue_sequence {
__u32 crtc_id ;
__u32 flags ;
__u64 sequence ; /* on input, target sequence. on output, actual sequence */
__u64 user_data ; /* user data passed to event */
} ;
2016-04-07 18:49:00 +01:00
# if defined(__cplusplus)
}
# endif
2016-03-30 17:54:52 +02:00
# include "drm_mode.h"
2008-11-07 14:05:41 -08:00
2016-04-07 18:49:00 +01:00
# if defined(__cplusplus)
extern " C " {
# endif
2005-04-16 15:20:36 -07:00
# define DRM_IOCTL_BASE 'd'
# define DRM_IO(nr) _IO(DRM_IOCTL_BASE,nr)
# define DRM_IOR(nr,type) _IOR(DRM_IOCTL_BASE,nr,type)
# define DRM_IOW(nr,type) _IOW(DRM_IOCTL_BASE,nr,type)
# define DRM_IOWR(nr,type) _IOWR(DRM_IOCTL_BASE,nr,type)
2007-07-11 15:27:12 +10:00
# define DRM_IOCTL_VERSION DRM_IOWR(0x00, struct drm_version)
# define DRM_IOCTL_GET_UNIQUE DRM_IOWR(0x01, struct drm_unique)
# define DRM_IOCTL_GET_MAGIC DRM_IOR( 0x02, struct drm_auth)
# define DRM_IOCTL_IRQ_BUSID DRM_IOWR(0x03, struct drm_irq_busid)
# define DRM_IOCTL_GET_MAP DRM_IOWR(0x04, struct drm_map)
# define DRM_IOCTL_GET_CLIENT DRM_IOWR(0x05, struct drm_client)
# define DRM_IOCTL_GET_STATS DRM_IOR( 0x06, struct drm_stats)
# define DRM_IOCTL_SET_VERSION DRM_IOWR(0x07, struct drm_set_version)
2008-09-30 12:14:26 -07:00
# define DRM_IOCTL_MODESET_CTL DRM_IOW(0x08, struct drm_modeset_ctl)
2008-07-30 12:06:12 -07:00
# define DRM_IOCTL_GEM_CLOSE DRM_IOW (0x09, struct drm_gem_close)
# define DRM_IOCTL_GEM_FLINK DRM_IOWR(0x0a, struct drm_gem_flink)
# define DRM_IOCTL_GEM_OPEN DRM_IOWR(0x0b, struct drm_gem_open)
2011-02-21 11:17:35 +10:00
# define DRM_IOCTL_GET_CAP DRM_IOWR(0x0c, struct drm_get_cap)
2013-09-25 16:45:20 +01:00
# define DRM_IOCTL_SET_CLIENT_CAP DRM_IOW( 0x0d, struct drm_set_client_cap)
2007-07-11 15:27:12 +10:00
# define DRM_IOCTL_SET_UNIQUE DRM_IOW( 0x10, struct drm_unique)
# define DRM_IOCTL_AUTH_MAGIC DRM_IOW( 0x11, struct drm_auth)
# define DRM_IOCTL_BLOCK DRM_IOWR(0x12, struct drm_block)
# define DRM_IOCTL_UNBLOCK DRM_IOWR(0x13, struct drm_block)
# define DRM_IOCTL_CONTROL DRM_IOW( 0x14, struct drm_control)
# define DRM_IOCTL_ADD_MAP DRM_IOWR(0x15, struct drm_map)
# define DRM_IOCTL_ADD_BUFS DRM_IOWR(0x16, struct drm_buf_desc)
# define DRM_IOCTL_MARK_BUFS DRM_IOW( 0x17, struct drm_buf_desc)
# define DRM_IOCTL_INFO_BUFS DRM_IOWR(0x18, struct drm_buf_info)
# define DRM_IOCTL_MAP_BUFS DRM_IOWR(0x19, struct drm_buf_map)
# define DRM_IOCTL_FREE_BUFS DRM_IOW( 0x1a, struct drm_buf_free)
# define DRM_IOCTL_RM_MAP DRM_IOW( 0x1b, struct drm_map)
# define DRM_IOCTL_SET_SAREA_CTX DRM_IOW( 0x1c, struct drm_ctx_priv_map)
# define DRM_IOCTL_GET_SAREA_CTX DRM_IOWR(0x1d, struct drm_ctx_priv_map)
2008-11-28 14:22:24 +10:00
# define DRM_IOCTL_SET_MASTER DRM_IO(0x1e)
# define DRM_IOCTL_DROP_MASTER DRM_IO(0x1f)
2007-07-11 15:27:12 +10:00
# define DRM_IOCTL_ADD_CTX DRM_IOWR(0x20, struct drm_ctx)
# define DRM_IOCTL_RM_CTX DRM_IOWR(0x21, struct drm_ctx)
# define DRM_IOCTL_MOD_CTX DRM_IOW( 0x22, struct drm_ctx)
# define DRM_IOCTL_GET_CTX DRM_IOWR(0x23, struct drm_ctx)
# define DRM_IOCTL_SWITCH_CTX DRM_IOW( 0x24, struct drm_ctx)
# define DRM_IOCTL_NEW_CTX DRM_IOW( 0x25, struct drm_ctx)
# define DRM_IOCTL_RES_CTX DRM_IOWR(0x26, struct drm_ctx_res)
# define DRM_IOCTL_ADD_DRAW DRM_IOWR(0x27, struct drm_draw)
# define DRM_IOCTL_RM_DRAW DRM_IOWR(0x28, struct drm_draw)
# define DRM_IOCTL_DMA DRM_IOWR(0x29, struct drm_dma)
# define DRM_IOCTL_LOCK DRM_IOW( 0x2a, struct drm_lock)
# define DRM_IOCTL_UNLOCK DRM_IOW( 0x2b, struct drm_lock)
# define DRM_IOCTL_FINISH DRM_IOW( 0x2c, struct drm_lock)
2005-04-16 15:20:36 -07:00
2011-11-25 15:21:02 +00:00
# define DRM_IOCTL_PRIME_HANDLE_TO_FD DRM_IOWR(0x2d, struct drm_prime_handle)
# define DRM_IOCTL_PRIME_FD_TO_HANDLE DRM_IOWR(0x2e, struct drm_prime_handle)
2010-03-09 10:56:52 +10:00
2005-04-16 15:20:36 -07:00
# define DRM_IOCTL_AGP_ACQUIRE DRM_IO( 0x30)
# define DRM_IOCTL_AGP_RELEASE DRM_IO( 0x31)
2007-07-11 15:27:12 +10:00
# define DRM_IOCTL_AGP_ENABLE DRM_IOW( 0x32, struct drm_agp_mode)
# define DRM_IOCTL_AGP_INFO DRM_IOR( 0x33, struct drm_agp_info)
# define DRM_IOCTL_AGP_ALLOC DRM_IOWR(0x34, struct drm_agp_buffer)
# define DRM_IOCTL_AGP_FREE DRM_IOW( 0x35, struct drm_agp_buffer)
# define DRM_IOCTL_AGP_BIND DRM_IOW( 0x36, struct drm_agp_binding)
# define DRM_IOCTL_AGP_UNBIND DRM_IOW( 0x37, struct drm_agp_binding)
2005-04-16 15:20:36 -07:00
2008-06-13 15:06:31 +10:00
# define DRM_IOCTL_SG_ALLOC DRM_IOWR(0x38, struct drm_scatter_gather)
2007-07-11 15:27:12 +10:00
# define DRM_IOCTL_SG_FREE DRM_IOW( 0x39, struct drm_scatter_gather)
2005-04-16 15:20:36 -07:00
2007-07-11 15:27:12 +10:00
# define DRM_IOCTL_WAIT_VBLANK DRM_IOWR(0x3a, union drm_wait_vblank)
2005-04-16 15:20:36 -07:00
2017-06-29 22:49:31 -07:00
# define DRM_IOCTL_CRTC_GET_SEQUENCE DRM_IOWR(0x3b, struct drm_crtc_get_sequence)
# define DRM_IOCTL_CRTC_QUEUE_SEQUENCE DRM_IOWR(0x3c, struct drm_crtc_queue_sequence)
2007-07-11 15:27:12 +10:00
# define DRM_IOCTL_UPDATE_DRAW DRM_IOW(0x3f, struct drm_update_draw)
2006-10-24 23:04:19 +10:00
2008-11-07 14:05:41 -08:00
# define DRM_IOCTL_MODE_GETRESOURCES DRM_IOWR(0xA0, struct drm_mode_card_res)
# define DRM_IOCTL_MODE_GETCRTC DRM_IOWR(0xA1, struct drm_mode_crtc)
# define DRM_IOCTL_MODE_SETCRTC DRM_IOWR(0xA2, struct drm_mode_crtc)
# define DRM_IOCTL_MODE_CURSOR DRM_IOWR(0xA3, struct drm_mode_cursor)
# define DRM_IOCTL_MODE_GETGAMMA DRM_IOWR(0xA4, struct drm_mode_crtc_lut)
# define DRM_IOCTL_MODE_SETGAMMA DRM_IOWR(0xA5, struct drm_mode_crtc_lut)
# define DRM_IOCTL_MODE_GETENCODER DRM_IOWR(0xA6, struct drm_mode_get_encoder)
# define DRM_IOCTL_MODE_GETCONNECTOR DRM_IOWR(0xA7, struct drm_mode_get_connector)
2013-04-26 17:40:28 +03:00
# define DRM_IOCTL_MODE_ATTACHMODE DRM_IOWR(0xA8, struct drm_mode_mode_cmd) /* deprecated (never worked) */
# define DRM_IOCTL_MODE_DETACHMODE DRM_IOWR(0xA9, struct drm_mode_mode_cmd) /* deprecated (never worked) */
2008-11-07 14:05:41 -08:00
# define DRM_IOCTL_MODE_GETPROPERTY DRM_IOWR(0xAA, struct drm_mode_get_property)
# define DRM_IOCTL_MODE_SETPROPERTY DRM_IOWR(0xAB, struct drm_mode_connector_set_property)
# define DRM_IOCTL_MODE_GETPROPBLOB DRM_IOWR(0xAC, struct drm_mode_get_blob)
# define DRM_IOCTL_MODE_GETFB DRM_IOWR(0xAD, struct drm_mode_fb_cmd)
# define DRM_IOCTL_MODE_ADDFB DRM_IOWR(0xAE, struct drm_mode_fb_cmd)
# define DRM_IOCTL_MODE_RMFB DRM_IOWR(0xAF, unsigned int)
2009-11-17 12:43:55 -05:00
# define DRM_IOCTL_MODE_PAGE_FLIP DRM_IOWR(0xB0, struct drm_mode_crtc_page_flip)
2009-12-03 23:25:47 +00:00
# define DRM_IOCTL_MODE_DIRTYFB DRM_IOWR(0xB1, struct drm_mode_fb_dirty_cmd)
2008-11-07 14:05:41 -08:00
2011-02-07 12:16:14 +10:00
# define DRM_IOCTL_MODE_CREATE_DUMB DRM_IOWR(0xB2, struct drm_mode_create_dumb)
# define DRM_IOCTL_MODE_MAP_DUMB DRM_IOWR(0xB3, struct drm_mode_map_dumb)
# define DRM_IOCTL_MODE_DESTROY_DUMB DRM_IOWR(0xB4, struct drm_mode_destroy_dumb)
2011-11-14 14:51:27 -08:00
# define DRM_IOCTL_MODE_GETPLANERESOURCES DRM_IOWR(0xB5, struct drm_mode_get_plane_res)
# define DRM_IOCTL_MODE_GETPLANE DRM_IOWR(0xB6, struct drm_mode_get_plane)
# define DRM_IOCTL_MODE_SETPLANE DRM_IOWR(0xB7, struct drm_mode_set_plane)
2011-11-14 14:51:28 -08:00
# define DRM_IOCTL_MODE_ADDFB2 DRM_IOWR(0xB8, struct drm_mode_fb_cmd2)
2012-05-15 18:09:02 -03:00
# define DRM_IOCTL_MODE_OBJ_GETPROPERTIES DRM_IOWR(0xB9, struct drm_mode_obj_get_properties)
# define DRM_IOCTL_MODE_OBJ_SETPROPERTY DRM_IOWR(0xBA, struct drm_mode_obj_set_property)
2013-06-20 11:48:52 +10:00
# define DRM_IOCTL_MODE_CURSOR2 DRM_IOWR(0xBB, struct drm_mode_cursor2)
2014-12-18 16:01:56 -05:00
# define DRM_IOCTL_MODE_ATOMIC DRM_IOWR(0xBC, struct drm_mode_atomic)
2015-05-22 13:34:51 +01:00
# define DRM_IOCTL_MODE_CREATEPROPBLOB DRM_IOWR(0xBD, struct drm_mode_create_blob)
# define DRM_IOCTL_MODE_DESTROYPROPBLOB DRM_IOWR(0xBE, struct drm_mode_destroy_blob)
2011-02-07 12:16:14 +10:00
2017-04-04 13:26:24 +10:00
# define DRM_IOCTL_SYNCOBJ_CREATE DRM_IOWR(0xBF, struct drm_syncobj_create)
# define DRM_IOCTL_SYNCOBJ_DESTROY DRM_IOWR(0xC0, struct drm_syncobj_destroy)
# define DRM_IOCTL_SYNCOBJ_HANDLE_TO_FD DRM_IOWR(0xC1, struct drm_syncobj_handle)
# define DRM_IOCTL_SYNCOBJ_FD_TO_HANDLE DRM_IOWR(0xC2, struct drm_syncobj_handle)
2017-08-25 10:52:22 -07:00
# define DRM_IOCTL_SYNCOBJ_WAIT DRM_IOWR(0xC3, struct drm_syncobj_wait)
2017-08-28 14:10:27 -07:00
# define DRM_IOCTL_SYNCOBJ_RESET DRM_IOWR(0xC4, struct drm_syncobj_array)
2017-08-28 14:10:28 -07:00
# define DRM_IOCTL_SYNCOBJ_SIGNAL DRM_IOWR(0xC5, struct drm_syncobj_array)
2017-04-04 13:26:24 +10:00
2017-03-16 17:56:28 -07:00
# define DRM_IOCTL_MODE_CREATE_LEASE DRM_IOWR(0xC6, struct drm_mode_create_lease)
# define DRM_IOCTL_MODE_LIST_LESSEES DRM_IOWR(0xC7, struct drm_mode_list_lessees)
# define DRM_IOCTL_MODE_GET_LEASE DRM_IOWR(0xC8, struct drm_mode_get_lease)
# define DRM_IOCTL_MODE_REVOKE_LEASE DRM_IOWR(0xC9, struct drm_mode_revoke_lease)
2019-04-01 17:50:57 +08:00
# define DRM_IOCTL_SYNCOBJ_TIMELINE_WAIT DRM_IOWR(0xCA, struct drm_syncobj_timeline_wait)
2019-04-01 17:50:58 +08:00
# define DRM_IOCTL_SYNCOBJ_QUERY DRM_IOWR(0xCB, struct drm_syncobj_timeline_array)
2019-04-01 17:51:01 +08:00
# define DRM_IOCTL_SYNCOBJ_TRANSFER DRM_IOWR(0xCC, struct drm_syncobj_transfer)
2019-04-01 17:51:02 +08:00
# define DRM_IOCTL_SYNCOBJ_TIMELINE_SIGNAL DRM_IOWR(0xCD, struct drm_syncobj_timeline_array)
2019-04-01 17:50:58 +08:00
2019-12-16 19:46:43 -08:00
# define DRM_IOCTL_MODE_GETFB2 DRM_IOWR(0xCE, struct drm_mode_fb_cmd2)
2005-04-16 15:20:36 -07:00
/**
* Device specific ioctls should only be in their respective headers
2014-06-09 14:39:50 +01:00
* The device specific ioctl range is from 0x40 to 0x9f .
2007-03-19 08:52:17 +11:00
* Generic IOCTLS restart at 0xA0 .
2005-04-16 15:20:36 -07:00
*
* \ sa drmCommandNone ( ) , drmCommandRead ( ) , drmCommandWrite ( ) , and
* drmCommandReadWrite ( ) .
*/
# define DRM_COMMAND_BASE 0x40
2007-03-19 08:52:17 +11:00
# define DRM_COMMAND_END 0xA0
2005-04-16 15:20:36 -07:00
2009-09-12 04:33:34 +10:00
/**
* Header for events written back to userspace on the drm fd . The
* type defines the type of event , the length specifies the total
* length of the event ( including the header ) , and user_data is
* typically a 64 bit value passed with the ioctl that triggered the
* event . A read on the drm fd will always only return complete
* events , that is , if for example the read buffer is 100 bytes , and
* there are two 64 byte events pending , only one will be returned .
*
* Event types 0 - 0x7fffffff are generic drm events , 0x80000000 and
* up are chipset specific .
*/
struct drm_event {
__u32 type ;
__u32 length ;
} ;
# define DRM_EVENT_VBLANK 0x01
2009-11-19 10:50:22 -08:00
# define DRM_EVENT_FLIP_COMPLETE 0x02
2017-06-29 22:49:31 -07:00
# define DRM_EVENT_CRTC_SEQUENCE 0x03
2009-09-12 04:33:34 +10:00
struct drm_event_vblank {
struct drm_event base ;
__u64 user_data ;
__u32 tv_sec ;
__u32 tv_usec ;
__u32 sequence ;
2017-04-04 17:52:21 +01:00
__u32 crtc_id ; /* 0 on older kernels that do not support this */
2009-09-12 04:33:34 +10:00
} ;
2017-06-29 22:49:31 -07:00
/* Event delivered at sequence. Time stamp marks when the first pixel
* of the refresh cycle leaves the display engine for the display
*/
struct drm_event_crtc_sequence {
struct drm_event base ;
__u64 user_data ;
__s64 time_ns ;
__u64 sequence ;
} ;
2007-07-11 15:27:12 +10:00
/* typedef area */
# ifndef __KERNEL__
typedef struct drm_clip_rect drm_clip_rect_t ;
typedef struct drm_drawable_info drm_drawable_info_t ;
typedef struct drm_tex_region drm_tex_region_t ;
typedef struct drm_hw_lock drm_hw_lock_t ;
typedef struct drm_version drm_version_t ;
typedef struct drm_unique drm_unique_t ;
typedef struct drm_list drm_list_t ;
typedef struct drm_block drm_block_t ;
typedef struct drm_control drm_control_t ;
typedef enum drm_map_type drm_map_type_t ;
typedef enum drm_map_flags drm_map_flags_t ;
typedef struct drm_ctx_priv_map drm_ctx_priv_map_t ;
typedef struct drm_map drm_map_t ;
typedef struct drm_client drm_client_t ;
typedef enum drm_stat_type drm_stat_type_t ;
typedef struct drm_stats drm_stats_t ;
typedef enum drm_lock_flags drm_lock_flags_t ;
typedef struct drm_lock drm_lock_t ;
typedef enum drm_dma_flags drm_dma_flags_t ;
typedef struct drm_buf_desc drm_buf_desc_t ;
typedef struct drm_buf_info drm_buf_info_t ;
typedef struct drm_buf_free drm_buf_free_t ;
typedef struct drm_buf_pub drm_buf_pub_t ;
typedef struct drm_buf_map drm_buf_map_t ;
typedef struct drm_dma drm_dma_t ;
typedef union drm_wait_vblank drm_wait_vblank_t ;
typedef struct drm_agp_mode drm_agp_mode_t ;
typedef enum drm_ctx_flags drm_ctx_flags_t ;
typedef struct drm_ctx drm_ctx_t ;
typedef struct drm_ctx_res drm_ctx_res_t ;
typedef struct drm_draw drm_draw_t ;
typedef struct drm_update_draw drm_update_draw_t ;
typedef struct drm_auth drm_auth_t ;
typedef struct drm_irq_busid drm_irq_busid_t ;
typedef enum drm_vblank_seq_type drm_vblank_seq_type_t ;
typedef struct drm_agp_buffer drm_agp_buffer_t ;
typedef struct drm_agp_binding drm_agp_binding_t ;
typedef struct drm_agp_info drm_agp_info_t ;
typedef struct drm_scatter_gather drm_scatter_gather_t ;
typedef struct drm_set_version drm_set_version_t ;
# endif
2016-04-07 18:49:00 +01:00
# if defined(__cplusplus)
}
# endif
2005-04-16 15:20:36 -07:00
# endif