Merged drmcommand-0-0-1
parent
a820c74137
commit
3903e5ac94
94
bsd/drm.h
94
bsd/drm.h
|
@ -93,15 +93,6 @@ typedef struct drm_tex_region {
|
||||||
unsigned int age;
|
unsigned int age;
|
||||||
} drm_tex_region_t;
|
} drm_tex_region_t;
|
||||||
|
|
||||||
/* Seperate include files for the driver specific structures */
|
|
||||||
#include "mga_drm.h"
|
|
||||||
#include "i810_drm.h"
|
|
||||||
#include "i830_drm.h"
|
|
||||||
#include "r128_drm.h"
|
|
||||||
#include "radeon_drm.h"
|
|
||||||
#include "sis_drm.h"
|
|
||||||
#include "gamma_drm.h"
|
|
||||||
|
|
||||||
typedef struct drm_version {
|
typedef struct drm_version {
|
||||||
int version_major; /* Major version */
|
int version_major; /* Major version */
|
||||||
int version_minor; /* Minor version */
|
int version_minor; /* Minor version */
|
||||||
|
@ -422,87 +413,8 @@ typedef struct drm_scatter_gather {
|
||||||
#define DRM_IOCTL_SG_ALLOC DRM_IOW( 0x38, drm_scatter_gather_t)
|
#define DRM_IOCTL_SG_ALLOC DRM_IOW( 0x38, drm_scatter_gather_t)
|
||||||
#define DRM_IOCTL_SG_FREE DRM_IOW( 0x39, drm_scatter_gather_t)
|
#define DRM_IOCTL_SG_FREE DRM_IOW( 0x39, drm_scatter_gather_t)
|
||||||
|
|
||||||
/* MGA specific ioctls */
|
/* Device specfic ioctls should only be in their respective headers
|
||||||
#define DRM_IOCTL_MGA_INIT DRM_IOW( 0x40, drm_mga_init_t)
|
* The device specific ioctl range is 0x40 to 0x79. */
|
||||||
#define DRM_IOCTL_MGA_FLUSH DRM_IOW( 0x41, drm_lock_t)
|
#define DRM_COMMAND_BASE 0x40
|
||||||
#define DRM_IOCTL_MGA_RESET DRM_IO( 0x42)
|
|
||||||
#define DRM_IOCTL_MGA_SWAP DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_MGA_CLEAR DRM_IOW( 0x44, drm_mga_clear_t)
|
|
||||||
#define DRM_IOCTL_MGA_VERTEX DRM_IOW( 0x45, drm_mga_vertex_t)
|
|
||||||
#define DRM_IOCTL_MGA_INDICES DRM_IOW( 0x46, drm_mga_indices_t)
|
|
||||||
#define DRM_IOCTL_MGA_ILOAD DRM_IOW( 0x47, drm_mga_iload_t)
|
|
||||||
#define DRM_IOCTL_MGA_BLIT DRM_IOW( 0x48, drm_mga_blit_t)
|
|
||||||
|
|
||||||
/* i810 specific ioctls */
|
|
||||||
#define DRM_IOCTL_I810_INIT DRM_IOW( 0x40, drm_i810_init_t)
|
|
||||||
#define DRM_IOCTL_I810_VERTEX DRM_IOW( 0x41, drm_i810_vertex_t)
|
|
||||||
#define DRM_IOCTL_I810_CLEAR DRM_IOW( 0x42, drm_i810_clear_t)
|
|
||||||
#define DRM_IOCTL_I810_FLUSH DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_I810_GETAGE DRM_IO( 0x44)
|
|
||||||
#define DRM_IOCTL_I810_GETBUF DRM_IOWR(0x45, drm_i810_dma_t)
|
|
||||||
#define DRM_IOCTL_I810_SWAP DRM_IO( 0x46)
|
|
||||||
#define DRM_IOCTL_I810_COPY DRM_IOW( 0x47, drm_i810_copy_t)
|
|
||||||
#define DRM_IOCTL_I810_DOCOPY DRM_IO( 0x48)
|
|
||||||
|
|
||||||
/* Rage 128 specific ioctls */
|
|
||||||
#define DRM_IOCTL_R128_INIT DRM_IOW( 0x40, drm_r128_init_t)
|
|
||||||
#define DRM_IOCTL_R128_CCE_START DRM_IO( 0x41)
|
|
||||||
#define DRM_IOCTL_R128_CCE_STOP DRM_IOW( 0x42, drm_r128_cce_stop_t)
|
|
||||||
#define DRM_IOCTL_R128_CCE_RESET DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_R128_CCE_IDLE DRM_IO( 0x44)
|
|
||||||
#define DRM_IOCTL_R128_RESET DRM_IO( 0x46)
|
|
||||||
#define DRM_IOCTL_R128_SWAP DRM_IO( 0x47)
|
|
||||||
#define DRM_IOCTL_R128_CLEAR DRM_IOW( 0x48, drm_r128_clear_t)
|
|
||||||
#define DRM_IOCTL_R128_VERTEX DRM_IOW( 0x49, drm_r128_vertex_t)
|
|
||||||
#define DRM_IOCTL_R128_INDICES DRM_IOW( 0x4a, drm_r128_indices_t)
|
|
||||||
#define DRM_IOCTL_R128_BLIT DRM_IOW( 0x4b, drm_r128_blit_t)
|
|
||||||
#define DRM_IOCTL_R128_DEPTH DRM_IOW( 0x4c, drm_r128_depth_t)
|
|
||||||
#define DRM_IOCTL_R128_STIPPLE DRM_IOW( 0x4d, drm_r128_stipple_t)
|
|
||||||
#define DRM_IOCTL_R128_INDIRECT DRM_IOWR(0x4f, drm_r128_indirect_t)
|
|
||||||
#define DRM_IOCTL_R128_FULLSCREEN DRM_IOW( 0x50, drm_r128_fullscreen_t)
|
|
||||||
#define DRM_IOCTL_R128_CLEAR2 DRM_IOW( 0x51, drm_r128_clear2_t)
|
|
||||||
|
|
||||||
/* Radeon specific ioctls */
|
|
||||||
#define DRM_IOCTL_RADEON_CP_INIT DRM_IOW( 0x40, drm_radeon_init_t)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_START DRM_IO( 0x41)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_STOP DRM_IOW( 0x42, drm_radeon_cp_stop_t)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_RESET DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_IDLE DRM_IO( 0x44)
|
|
||||||
#define DRM_IOCTL_RADEON_RESET DRM_IO( 0x45)
|
|
||||||
#define DRM_IOCTL_RADEON_FULLSCREEN DRM_IOW( 0x46, drm_radeon_fullscreen_t)
|
|
||||||
#define DRM_IOCTL_RADEON_SWAP DRM_IO( 0x47)
|
|
||||||
#define DRM_IOCTL_RADEON_CLEAR DRM_IOW( 0x48, drm_radeon_clear_t)
|
|
||||||
#define DRM_IOCTL_RADEON_VERTEX DRM_IOW( 0x49, drm_radeon_vertex_t)
|
|
||||||
#define DRM_IOCTL_RADEON_INDICES DRM_IOW( 0x4a, drm_radeon_indices_t)
|
|
||||||
#define DRM_IOCTL_RADEON_STIPPLE DRM_IOW( 0x4c, drm_radeon_stipple_t)
|
|
||||||
#define DRM_IOCTL_RADEON_INDIRECT DRM_IOWR(0x4d, drm_radeon_indirect_t)
|
|
||||||
#define DRM_IOCTL_RADEON_TEXTURE DRM_IOWR(0x4e, drm_radeon_texture_t)
|
|
||||||
#define DRM_IOCTL_RADEON_VERTEX2 DRM_IOW( 0x4f, drm_radeon_vertex_t)
|
|
||||||
|
|
||||||
/* Gamma specific ioctls */
|
|
||||||
#define DRM_IOCTL_GAMMA_INIT DRM_IOW( 0x40, drm_gamma_init_t)
|
|
||||||
#define DRM_IOCTL_GAMMA_COPY DRM_IOW( 0x41, drm_gamma_copy_t)
|
|
||||||
|
|
||||||
/* SiS specific ioctls */
|
|
||||||
|
|
||||||
#define SIS_IOCTL_FB_ALLOC DRM_IOWR(0x44, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_FB_FREE DRM_IOW( 0x45, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_AGP_INIT DRM_IOWR(0x53, drm_sis_agp_t)
|
|
||||||
#define SIS_IOCTL_AGP_ALLOC DRM_IOWR(0x54, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_AGP_FREE DRM_IOW( 0x55, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_FLIP DRM_IOW( 0x48, drm_sis_flip_t)
|
|
||||||
#define SIS_IOCTL_FLIP_INIT DRM_IO( 0x49)
|
|
||||||
#define SIS_IOCTL_FLIP_FINAL DRM_IO( 0x50)
|
|
||||||
|
|
||||||
/* I830 specific ioctls */
|
|
||||||
#define DRM_IOCTL_I830_INIT DRM_IOW( 0x40, drm_i830_init_t)
|
|
||||||
#define DRM_IOCTL_I830_VERTEX DRM_IOW( 0x41, drm_i830_vertex_t)
|
|
||||||
#define DRM_IOCTL_I830_CLEAR DRM_IOW( 0x42, drm_i830_clear_t)
|
|
||||||
#define DRM_IOCTL_I830_FLUSH DRM_IO ( 0x43)
|
|
||||||
#define DRM_IOCTL_I830_GETAGE DRM_IO ( 0x44)
|
|
||||||
#define DRM_IOCTL_I830_GETBUF DRM_IOWR(0x45, drm_i830_dma_t)
|
|
||||||
#define DRM_IOCTL_I830_SWAP DRM_IO ( 0x46)
|
|
||||||
#define DRM_IOCTL_I830_COPY DRM_IOW( 0x47, drm_i830_copy_t)
|
|
||||||
#define DRM_IOCTL_I830_DOCOPY DRM_IO ( 0x48)
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -33,6 +33,8 @@
|
||||||
|
|
||||||
#include "gamma.h"
|
#include "gamma.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "gamma_drm.h"
|
||||||
#include "gamma_drv.h"
|
#include "gamma_drv.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -35,6 +35,8 @@
|
||||||
#include <opt_drm_linux.h>
|
#include <opt_drm_linux.h>
|
||||||
#include "gamma.h"
|
#include "gamma.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "gamma_drm.h"
|
||||||
#include "gamma_drv.h"
|
#include "gamma_drv.h"
|
||||||
|
|
||||||
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
||||||
|
|
|
@ -48,6 +48,16 @@ typedef struct _drm_gamma_sarea {
|
||||||
int vertex_prim;
|
int vertex_prim;
|
||||||
} drm_gamma_sarea_t;
|
} drm_gamma_sarea_t;
|
||||||
|
|
||||||
|
/* WARNING: If you change any of these defines, make sure to change the
|
||||||
|
* defines in the Xserver file (xf86drmGamma.h)
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Gamma specific ioctls
|
||||||
|
* The device specific ioctl range is 0x40 to 0x79.
|
||||||
|
*/
|
||||||
|
#define DRM_IOCTL_GAMMA_INIT DRM_IOW( 0x40, drm_gamma_init_t)
|
||||||
|
#define DRM_IOCTL_GAMMA_COPY DRM_IOW( 0x41, drm_gamma_copy_t)
|
||||||
|
|
||||||
typedef struct drm_gamma_copy {
|
typedef struct drm_gamma_copy {
|
||||||
unsigned int DMAOutputAddress;
|
unsigned int DMAOutputAddress;
|
||||||
unsigned int DMAOutputCount;
|
unsigned int DMAOutputCount;
|
||||||
|
|
|
@ -33,6 +33,8 @@
|
||||||
|
|
||||||
#include "i810.h"
|
#include "i810.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "i810_drm.h"
|
||||||
#include "i810_drv.h"
|
#include "i810_drv.h"
|
||||||
|
|
||||||
#define I810_BUF_FREE 2
|
#define I810_BUF_FREE 2
|
||||||
|
@ -125,7 +127,7 @@ static int i810_freelist_put(drm_device_t *dev, drm_buf_t *buf)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
int i810_mmap_buffers(struct file *filp, struct vm_area_struct *vma)
|
int i810_mmap_buffers(struct file *filp, struct vm_area_struct *vma)
|
||||||
{
|
{
|
||||||
DRM_OS_DEVICE;
|
DRM_OS_DEVICE;
|
||||||
|
@ -150,6 +152,7 @@ int i810_mmap_buffers(struct file *filp, struct vm_area_struct *vma)
|
||||||
vma->vm_page_prot)) DRM_OS_RETURN(EAGAIN);
|
vma->vm_page_prot)) DRM_OS_RETURN(EAGAIN);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
static int i810_map_buffer(drm_buf_t *buf, struct file *filp)
|
static int i810_map_buffer(drm_buf_t *buf, struct file *filp)
|
||||||
{
|
{
|
||||||
|
|
|
@ -38,6 +38,8 @@
|
||||||
|
|
||||||
#include "i810.h"
|
#include "i810.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "i810_drm.h"
|
||||||
#include "i810_drv.h"
|
#include "i810_drv.h"
|
||||||
|
|
||||||
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
||||||
|
|
|
@ -166,14 +166,34 @@ typedef struct _drm_i810_sarea {
|
||||||
|
|
||||||
} drm_i810_sarea_t;
|
} drm_i810_sarea_t;
|
||||||
|
|
||||||
|
/* WARNING: If you change any of these defines, make sure to change the
|
||||||
|
* defines in the Xserver file (xf86drmMga.h)
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* i810 specific ioctls
|
||||||
|
* The device specific ioctl range is 0x40 to 0x79.
|
||||||
|
*/
|
||||||
|
#define DRM_IOCTL_I810_INIT DRM_IOW( 0x40, drm_i810_init_t)
|
||||||
|
#define DRM_IOCTL_I810_VERTEX DRM_IOW( 0x41, drm_i810_vertex_t)
|
||||||
|
#define DRM_IOCTL_I810_CLEAR DRM_IOW( 0x42, drm_i810_clear_t)
|
||||||
|
#define DRM_IOCTL_I810_FLUSH DRM_IO( 0x43)
|
||||||
|
#define DRM_IOCTL_I810_GETAGE DRM_IO( 0x44)
|
||||||
|
#define DRM_IOCTL_I810_GETBUF DRM_IOWR(0x45, drm_i810_dma_t)
|
||||||
|
#define DRM_IOCTL_I810_SWAP DRM_IO( 0x46)
|
||||||
|
#define DRM_IOCTL_I810_COPY DRM_IOW( 0x47, drm_i810_copy_t)
|
||||||
|
#define DRM_IOCTL_I810_DOCOPY DRM_IO( 0x48)
|
||||||
|
#define DRM_IOCTL_I810_OV0INFO DRM_IOR( 0x49, drm_i810_overlay_t)
|
||||||
|
#define DRM_IOCTL_I810_FSTATUS DRM_IO ( 0x4a)
|
||||||
|
#define DRM_IOCTL_I810_OV0FLIP DRM_IO ( 0x4b)
|
||||||
|
#define DRM_IOCTL_I810_MC DRM_IOW( 0x4c, drm_i810_mc_t)
|
||||||
|
#define DRM_IOCTL_I810_RSTATUS DRM_IO ( 0x4d )
|
||||||
|
|
||||||
typedef struct _drm_i810_clear {
|
typedef struct _drm_i810_clear {
|
||||||
int clear_color;
|
int clear_color;
|
||||||
int clear_depth;
|
int clear_depth;
|
||||||
int flags;
|
int flags;
|
||||||
} drm_i810_clear_t;
|
} drm_i810_clear_t;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* These may be placeholders if we have more cliprects than
|
/* These may be placeholders if we have more cliprects than
|
||||||
* I810_NR_SAREA_CLIPRECTS. In that case, the client sets discard to
|
* I810_NR_SAREA_CLIPRECTS. In that case, the client sets discard to
|
||||||
* false, indicating that the buffer will be dispatched again with a
|
* false, indicating that the buffer will be dispatched again with a
|
||||||
|
|
|
@ -34,6 +34,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "i830.h"
|
#include "i830.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "i830_drm.h"
|
||||||
#include "i830_drv.h"
|
#include "i830_drv.h"
|
||||||
#include <linux/interrupt.h> /* For task queue support */
|
#include <linux/interrupt.h> /* For task queue support */
|
||||||
|
|
||||||
|
|
|
@ -34,6 +34,8 @@
|
||||||
#include <linux/config.h>
|
#include <linux/config.h>
|
||||||
#include "i830.h"
|
#include "i830.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "i830_drm.h"
|
||||||
#include "i830_drv.h"
|
#include "i830_drv.h"
|
||||||
|
|
||||||
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
||||||
|
|
|
@ -201,6 +201,19 @@ typedef struct _drm_i830_sarea {
|
||||||
int vertex_prim;
|
int vertex_prim;
|
||||||
} drm_i830_sarea_t;
|
} drm_i830_sarea_t;
|
||||||
|
|
||||||
|
/* I830 specific ioctls
|
||||||
|
* The device specific ioctl range is 0x40 to 0x79.
|
||||||
|
*/
|
||||||
|
#define DRM_IOCTL_I830_INIT DRM_IOW( 0x40, drm_i830_init_t)
|
||||||
|
#define DRM_IOCTL_I830_VERTEX DRM_IOW( 0x41, drm_i830_vertex_t)
|
||||||
|
#define DRM_IOCTL_I830_CLEAR DRM_IOW( 0x42, drm_i830_clear_t)
|
||||||
|
#define DRM_IOCTL_I830_FLUSH DRM_IO ( 0x43)
|
||||||
|
#define DRM_IOCTL_I830_GETAGE DRM_IO ( 0x44)
|
||||||
|
#define DRM_IOCTL_I830_GETBUF DRM_IOWR(0x45, drm_i830_dma_t)
|
||||||
|
#define DRM_IOCTL_I830_SWAP DRM_IO ( 0x46)
|
||||||
|
#define DRM_IOCTL_I830_COPY DRM_IOW( 0x47, drm_i830_copy_t)
|
||||||
|
#define DRM_IOCTL_I830_DOCOPY DRM_IO ( 0x48)
|
||||||
|
|
||||||
typedef struct _drm_i830_clear {
|
typedef struct _drm_i830_clear {
|
||||||
int clear_color;
|
int clear_color;
|
||||||
int clear_depth;
|
int clear_depth;
|
||||||
|
|
|
@ -36,6 +36,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "mga.h"
|
#include "mga.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "mga_drm.h"
|
||||||
#include "mga_drv.h"
|
#include "mga_drv.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -37,6 +37,8 @@
|
||||||
|
|
||||||
#include "mga.h"
|
#include "mga.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "mga_drm.h"
|
||||||
#include "mga_drv.h"
|
#include "mga_drv.h"
|
||||||
|
|
||||||
#define DRIVER_AUTHOR "Gareth Hughes, VA Linux Systems Inc."
|
#define DRIVER_AUTHOR "Gareth Hughes, VA Linux Systems Inc."
|
||||||
|
|
|
@ -35,6 +35,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "mga.h"
|
#include "mga.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "mga_drm.h"
|
||||||
#include "mga_drv.h"
|
#include "mga_drv.h"
|
||||||
#include "drm.h"
|
#include "drm.h"
|
||||||
|
|
||||||
|
|
|
@ -30,6 +30,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "mga.h"
|
#include "mga.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "mga_drm.h"
|
||||||
#include "mga_drv.h"
|
#include "mga_drv.h"
|
||||||
#include "mga_ucode.h"
|
#include "mga_ucode.h"
|
||||||
|
|
||||||
|
|
|
@ -38,6 +38,7 @@
|
||||||
/* WARNING: If you change any of these defines, make sure to change the
|
/* WARNING: If you change any of these defines, make sure to change the
|
||||||
* defines in the Xserver file (mga_sarea.h)
|
* defines in the Xserver file (mga_sarea.h)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __MGA_SAREA_DEFINES__
|
#ifndef __MGA_SAREA_DEFINES__
|
||||||
#define __MGA_SAREA_DEFINES__
|
#define __MGA_SAREA_DEFINES__
|
||||||
|
|
||||||
|
@ -225,6 +226,20 @@ typedef struct _drm_mga_sarea {
|
||||||
/* WARNING: If you change any of these defines, make sure to change the
|
/* WARNING: If you change any of these defines, make sure to change the
|
||||||
* defines in the Xserver file (xf86drmMga.h)
|
* defines in the Xserver file (xf86drmMga.h)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* MGA specific ioctls
|
||||||
|
* The device specific ioctl range is 0x40 to 0x79.
|
||||||
|
*/
|
||||||
|
#define DRM_IOCTL_MGA_INIT DRM_IOW( 0x40, drm_mga_init_t)
|
||||||
|
#define DRM_IOCTL_MGA_FLUSH DRM_IOW( 0x41, drm_lock_t)
|
||||||
|
#define DRM_IOCTL_MGA_RESET DRM_IO( 0x42)
|
||||||
|
#define DRM_IOCTL_MGA_SWAP DRM_IO( 0x43)
|
||||||
|
#define DRM_IOCTL_MGA_CLEAR DRM_IOW( 0x44, drm_mga_clear_t)
|
||||||
|
#define DRM_IOCTL_MGA_VERTEX DRM_IOW( 0x45, drm_mga_vertex_t)
|
||||||
|
#define DRM_IOCTL_MGA_INDICES DRM_IOW( 0x46, drm_mga_indices_t)
|
||||||
|
#define DRM_IOCTL_MGA_ILOAD DRM_IOW( 0x47, drm_mga_iload_t)
|
||||||
|
#define DRM_IOCTL_MGA_BLIT DRM_IOW( 0x48, drm_mga_blit_t)
|
||||||
|
|
||||||
typedef struct _drm_mga_warp_index {
|
typedef struct _drm_mga_warp_index {
|
||||||
int installed;
|
int installed;
|
||||||
unsigned long phys_addr;
|
unsigned long phys_addr;
|
||||||
|
|
|
@ -31,6 +31,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "r128.h"
|
#include "r128.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "r128_drm.h"
|
||||||
#include "r128_drv.h"
|
#include "r128_drv.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -37,6 +37,8 @@
|
||||||
|
|
||||||
#include "r128.h"
|
#include "r128.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "r128_drm.h"
|
||||||
#include "r128_drv.h"
|
#include "r128_drv.h"
|
||||||
#if __REALLY_HAVE_SG
|
#if __REALLY_HAVE_SG
|
||||||
#include "ati_pcigart.h"
|
#include "ati_pcigart.h"
|
||||||
|
|
|
@ -30,6 +30,8 @@
|
||||||
|
|
||||||
#include "r128.h"
|
#include "r128.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "r128_drm.h"
|
||||||
#include "r128_drv.h"
|
#include "r128_drv.h"
|
||||||
#include "drm.h"
|
#include "drm.h"
|
||||||
|
|
||||||
|
|
|
@ -170,6 +170,27 @@ typedef struct drm_r128_sarea {
|
||||||
/* WARNING: If you change any of these defines, make sure to change the
|
/* WARNING: If you change any of these defines, make sure to change the
|
||||||
* defines in the Xserver file (xf86drmR128.h)
|
* defines in the Xserver file (xf86drmR128.h)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* Rage 128 specific ioctls
|
||||||
|
* The device specific ioctl range is 0x40 to 0x79.
|
||||||
|
*/
|
||||||
|
#define DRM_IOCTL_R128_INIT DRM_IOW( 0x40, drm_r128_init_t)
|
||||||
|
#define DRM_IOCTL_R128_CCE_START DRM_IO( 0x41)
|
||||||
|
#define DRM_IOCTL_R128_CCE_STOP DRM_IOW( 0x42, drm_r128_cce_stop_t)
|
||||||
|
#define DRM_IOCTL_R128_CCE_RESET DRM_IO( 0x43)
|
||||||
|
#define DRM_IOCTL_R128_CCE_IDLE DRM_IO( 0x44)
|
||||||
|
#define DRM_IOCTL_R128_RESET DRM_IO( 0x46)
|
||||||
|
#define DRM_IOCTL_R128_SWAP DRM_IO( 0x47)
|
||||||
|
#define DRM_IOCTL_R128_CLEAR DRM_IOW( 0x48, drm_r128_clear_t)
|
||||||
|
#define DRM_IOCTL_R128_VERTEX DRM_IOW( 0x49, drm_r128_vertex_t)
|
||||||
|
#define DRM_IOCTL_R128_INDICES DRM_IOW( 0x4a, drm_r128_indices_t)
|
||||||
|
#define DRM_IOCTL_R128_BLIT DRM_IOW( 0x4b, drm_r128_blit_t)
|
||||||
|
#define DRM_IOCTL_R128_DEPTH DRM_IOW( 0x4c, drm_r128_depth_t)
|
||||||
|
#define DRM_IOCTL_R128_STIPPLE DRM_IOW( 0x4d, drm_r128_stipple_t)
|
||||||
|
#define DRM_IOCTL_R128_INDIRECT DRM_IOWR(0x4f, drm_r128_indirect_t)
|
||||||
|
#define DRM_IOCTL_R128_FULLSCREEN DRM_IOW( 0x50, drm_r128_fullscreen_t)
|
||||||
|
#define DRM_IOCTL_R128_CLEAR2 DRM_IOW( 0x51, drm_r128_clear2_t)
|
||||||
|
|
||||||
typedef struct drm_r128_init {
|
typedef struct drm_r128_init {
|
||||||
enum {
|
enum {
|
||||||
R128_INIT_CCE = 0x01,
|
R128_INIT_CCE = 0x01,
|
||||||
|
|
|
@ -30,6 +30,8 @@
|
||||||
|
|
||||||
#include "radeon.h"
|
#include "radeon.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "radeon_drm.h"
|
||||||
#include "radeon_drv.h"
|
#include "radeon_drv.h"
|
||||||
|
|
||||||
#include <vm/vm.h>
|
#include <vm/vm.h>
|
||||||
|
@ -624,7 +626,7 @@ static void radeon_cp_init_ring_buffer( drm_device_t *dev,
|
||||||
|
|
||||||
RADEON_WRITE( RADEON_CP_RB_RPTR_ADDR,
|
RADEON_WRITE( RADEON_CP_RB_RPTR_ADDR,
|
||||||
entry->busaddr[page_ofs]);
|
entry->busaddr[page_ofs]);
|
||||||
DRM_DEBUG( "ring rptr: offset=0x%08x handle=0x%08lx\n",
|
DRM_DEBUG( "ring rptr: offset=0x%08x handle=0x%08x\n",
|
||||||
entry->busaddr[page_ofs],
|
entry->busaddr[page_ofs],
|
||||||
entry->handle + tmp_ofs );
|
entry->handle + tmp_ofs );
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,6 +36,8 @@
|
||||||
|
|
||||||
#include "radeon.h"
|
#include "radeon.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "radeon_drm.h"
|
||||||
#include "radeon_drv.h"
|
#include "radeon_drv.h"
|
||||||
#if __REALLY_HAVE_SG
|
#if __REALLY_HAVE_SG
|
||||||
#include "ati_pcigart.h"
|
#include "ati_pcigart.h"
|
||||||
|
|
|
@ -29,8 +29,9 @@
|
||||||
|
|
||||||
#include "radeon.h"
|
#include "radeon.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
#include "radeon_drv.h"
|
|
||||||
#include "drm.h"
|
#include "drm.h"
|
||||||
|
#include "radeon_drm.h"
|
||||||
|
#include "radeon_drv.h"
|
||||||
|
|
||||||
|
|
||||||
/* ================================================================
|
/* ================================================================
|
||||||
|
|
|
@ -236,7 +236,29 @@ typedef struct {
|
||||||
|
|
||||||
/* WARNING: If you change any of these defines, make sure to change the
|
/* WARNING: If you change any of these defines, make sure to change the
|
||||||
* defines in the Xserver file (xf86drmRadeon.h)
|
* defines in the Xserver file (xf86drmRadeon.h)
|
||||||
|
*
|
||||||
|
* KW: actually it's illegal to change any of this (backwards compatibility).
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* Radeon specific ioctls
|
||||||
|
* The device specific ioctl range is 0x40 to 0x79.
|
||||||
|
*/
|
||||||
|
#define DRM_IOCTL_RADEON_CP_INIT DRM_IOW( 0x40, drm_radeon_init_t)
|
||||||
|
#define DRM_IOCTL_RADEON_CP_START DRM_IO( 0x41)
|
||||||
|
#define DRM_IOCTL_RADEON_CP_STOP DRM_IOW( 0x42, drm_radeon_cp_stop_t)
|
||||||
|
#define DRM_IOCTL_RADEON_CP_RESET DRM_IO( 0x43)
|
||||||
|
#define DRM_IOCTL_RADEON_CP_IDLE DRM_IO( 0x44)
|
||||||
|
#define DRM_IOCTL_RADEON_RESET DRM_IO( 0x45)
|
||||||
|
#define DRM_IOCTL_RADEON_FULLSCREEN DRM_IOW( 0x46, drm_radeon_fullscreen_t)
|
||||||
|
#define DRM_IOCTL_RADEON_SWAP DRM_IO( 0x47)
|
||||||
|
#define DRM_IOCTL_RADEON_CLEAR DRM_IOW( 0x48, drm_radeon_clear_t)
|
||||||
|
#define DRM_IOCTL_RADEON_VERTEX DRM_IOW( 0x49, drm_radeon_vertex_t)
|
||||||
|
#define DRM_IOCTL_RADEON_INDICES DRM_IOW( 0x4a, drm_radeon_indices_t)
|
||||||
|
#define DRM_IOCTL_RADEON_STIPPLE DRM_IOW( 0x4c, drm_radeon_stipple_t)
|
||||||
|
#define DRM_IOCTL_RADEON_INDIRECT DRM_IOWR(0x4d, drm_radeon_indirect_t)
|
||||||
|
#define DRM_IOCTL_RADEON_TEXTURE DRM_IOWR(0x4e, drm_radeon_texture_t)
|
||||||
|
#define DRM_IOCTL_RADEON_VERTEX2 DRM_IOW( 0x4f, drm_radeon_vertex_t)
|
||||||
|
|
||||||
typedef struct drm_radeon_init {
|
typedef struct drm_radeon_init {
|
||||||
enum {
|
enum {
|
||||||
RADEON_INIT_CP = 0x01,
|
RADEON_INIT_CP = 0x01,
|
||||||
|
|
|
@ -2,6 +2,16 @@
|
||||||
#ifndef _sis_drm_public_h_
|
#ifndef _sis_drm_public_h_
|
||||||
#define _sis_drm_public_h_
|
#define _sis_drm_public_h_
|
||||||
|
|
||||||
|
/* SiS specific ioctls */
|
||||||
|
#define SIS_IOCTL_FB_ALLOC DRM_IOWR(0x44, drm_sis_mem_t)
|
||||||
|
#define SIS_IOCTL_FB_FREE DRM_IOW( 0x45, drm_sis_mem_t)
|
||||||
|
#define SIS_IOCTL_AGP_INIT DRM_IOWR(0x53, drm_sis_agp_t)
|
||||||
|
#define SIS_IOCTL_AGP_ALLOC DRM_IOWR(0x54, drm_sis_mem_t)
|
||||||
|
#define SIS_IOCTL_AGP_FREE DRM_IOW( 0x55, drm_sis_mem_t)
|
||||||
|
#define SIS_IOCTL_FLIP DRM_IOW( 0x48, drm_sis_flip_t)
|
||||||
|
#define SIS_IOCTL_FLIP_INIT DRM_IO( 0x49)
|
||||||
|
#define SIS_IOCTL_FLIP_FINAL DRM_IO( 0x50)
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int context;
|
int context;
|
||||||
unsigned int offset;
|
unsigned int offset;
|
||||||
|
|
|
@ -434,7 +434,7 @@ static void drmCopyVersion(drmVersionPtr d, const drm_version_t *s)
|
||||||
d->desc = drmStrdup(s->desc);
|
d->desc = drmStrdup(s->desc);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* drmVersion obtains the version information via an ioctl. Similar
|
/* drmGet Version obtains the driver version information via an ioctl. Similar
|
||||||
* information is available via /proc/dri. */
|
* information is available via /proc/dri. */
|
||||||
|
|
||||||
drmVersionPtr drmGetVersion(int fd)
|
drmVersionPtr drmGetVersion(int fd)
|
||||||
|
@ -483,6 +483,26 @@ drmVersionPtr drmGetVersion(int fd)
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* drmGetLibVersion set version information for the drm user space library.
|
||||||
|
* this version number is driver indepedent */
|
||||||
|
|
||||||
|
drmVersionPtr drmGetLibVersion(int fd)
|
||||||
|
{
|
||||||
|
drm_version_t *version = drmMalloc(sizeof(*version));
|
||||||
|
|
||||||
|
/* Version history:
|
||||||
|
* revision 1.0.x = original DRM interface with no drmGetLibVersion
|
||||||
|
* entry point and many drm<Device> extensions
|
||||||
|
* revision 1.1.x = added drmCommand entry points for device extensions
|
||||||
|
* added drmGetLibVersion to identify libdrm.a version
|
||||||
|
*/
|
||||||
|
version->version_major = 1;
|
||||||
|
version->version_minor = 1;
|
||||||
|
version->version_patchlevel = 0;
|
||||||
|
|
||||||
|
return (drmVersionPtr)version;
|
||||||
|
}
|
||||||
|
|
||||||
void drmFreeBusid(const char *busid)
|
void drmFreeBusid(const char *busid)
|
||||||
{
|
{
|
||||||
drmFree((void *)busid);
|
drmFree((void *)busid);
|
||||||
|
@ -1343,6 +1363,58 @@ int drmGetStats(int fd, drmStatsT *stats)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int drmCommandNone(int fd, unsigned long drmCommandIndex)
|
||||||
|
{
|
||||||
|
void *data = NULL; /* dummy */
|
||||||
|
unsigned long request;
|
||||||
|
|
||||||
|
request = DRM_IO( DRM_COMMAND_BASE + drmCommandIndex);
|
||||||
|
|
||||||
|
if (ioctl(fd, request, data)) {
|
||||||
|
return -errno;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int drmCommandRead(int fd, unsigned long drmCommandIndex,
|
||||||
|
void *data, unsigned long size )
|
||||||
|
{
|
||||||
|
unsigned long request;
|
||||||
|
|
||||||
|
request = DRM_IOR( DRM_COMMAND_BASE + drmCommandIndex, size);
|
||||||
|
|
||||||
|
if (ioctl(fd, request, data)) {
|
||||||
|
return -errno;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int drmCommandWrite(int fd, unsigned long drmCommandIndex,
|
||||||
|
void *data, unsigned long size )
|
||||||
|
{
|
||||||
|
unsigned long request;
|
||||||
|
|
||||||
|
request = DRM_IOW( DRM_COMMAND_BASE + drmCommandIndex, size);
|
||||||
|
|
||||||
|
if (ioctl(fd, request, data)) {
|
||||||
|
return -errno;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int drmCommandWriteRead(int fd, unsigned long drmCommandIndex,
|
||||||
|
void *data, unsigned long size )
|
||||||
|
{
|
||||||
|
unsigned long request;
|
||||||
|
|
||||||
|
request = DRM_IOWR( DRM_COMMAND_BASE + drmCommandIndex, size);
|
||||||
|
|
||||||
|
if (ioctl(fd, request, data)) {
|
||||||
|
return -errno;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
#if defined(XFree86Server) || defined(DRM_USE_MALLOC)
|
#if defined(XFree86Server) || defined(DRM_USE_MALLOC)
|
||||||
static void drmSIGIOHandler(int interrupt, void *closure)
|
static void drmSIGIOHandler(int interrupt, void *closure)
|
||||||
{
|
{
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -33,6 +33,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "i810.h"
|
#include "i810.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "i810_drm.h"
|
||||||
#include "i810_drv.h"
|
#include "i810_drv.h"
|
||||||
#include <linux/interrupt.h> /* For task queue support */
|
#include <linux/interrupt.h> /* For task queue support */
|
||||||
|
|
||||||
|
|
|
@ -168,14 +168,34 @@ typedef struct _drm_i810_sarea {
|
||||||
|
|
||||||
} drm_i810_sarea_t;
|
} drm_i810_sarea_t;
|
||||||
|
|
||||||
|
/* WARNING: If you change any of these defines, make sure to change the
|
||||||
|
* defines in the Xserver file (xf86drmMga.h)
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* i810 specific ioctls
|
||||||
|
* The device specific ioctl range is 0x40 to 0x79.
|
||||||
|
*/
|
||||||
|
#define DRM_IOCTL_I810_INIT DRM_IOW( 0x40, drm_i810_init_t)
|
||||||
|
#define DRM_IOCTL_I810_VERTEX DRM_IOW( 0x41, drm_i810_vertex_t)
|
||||||
|
#define DRM_IOCTL_I810_CLEAR DRM_IOW( 0x42, drm_i810_clear_t)
|
||||||
|
#define DRM_IOCTL_I810_FLUSH DRM_IO( 0x43)
|
||||||
|
#define DRM_IOCTL_I810_GETAGE DRM_IO( 0x44)
|
||||||
|
#define DRM_IOCTL_I810_GETBUF DRM_IOWR(0x45, drm_i810_dma_t)
|
||||||
|
#define DRM_IOCTL_I810_SWAP DRM_IO( 0x46)
|
||||||
|
#define DRM_IOCTL_I810_COPY DRM_IOW( 0x47, drm_i810_copy_t)
|
||||||
|
#define DRM_IOCTL_I810_DOCOPY DRM_IO( 0x48)
|
||||||
|
#define DRM_IOCTL_I810_OV0INFO DRM_IOR( 0x49, drm_i810_overlay_t)
|
||||||
|
#define DRM_IOCTL_I810_FSTATUS DRM_IO ( 0x4a)
|
||||||
|
#define DRM_IOCTL_I810_OV0FLIP DRM_IO ( 0x4b)
|
||||||
|
#define DRM_IOCTL_I810_MC DRM_IOW( 0x4c, drm_i810_mc_t)
|
||||||
|
#define DRM_IOCTL_I810_RSTATUS DRM_IO ( 0x4d )
|
||||||
|
|
||||||
typedef struct _drm_i810_clear {
|
typedef struct _drm_i810_clear {
|
||||||
int clear_color;
|
int clear_color;
|
||||||
int clear_depth;
|
int clear_depth;
|
||||||
int flags;
|
int flags;
|
||||||
} drm_i810_clear_t;
|
} drm_i810_clear_t;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* These may be placeholders if we have more cliprects than
|
/* These may be placeholders if we have more cliprects than
|
||||||
* I810_NR_SAREA_CLIPRECTS. In that case, the client sets discard to
|
* I810_NR_SAREA_CLIPRECTS. In that case, the client sets discard to
|
||||||
* false, indicating that the buffer will be dispatched again with a
|
* false, indicating that the buffer will be dispatched again with a
|
||||||
|
|
|
@ -33,6 +33,8 @@
|
||||||
#include <linux/config.h>
|
#include <linux/config.h>
|
||||||
#include "i810.h"
|
#include "i810.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "i810_drm.h"
|
||||||
#include "i810_drv.h"
|
#include "i810_drv.h"
|
||||||
|
|
||||||
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
||||||
|
|
|
@ -34,6 +34,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "i830.h"
|
#include "i830.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "i830_drm.h"
|
||||||
#include "i830_drv.h"
|
#include "i830_drv.h"
|
||||||
#include <linux/interrupt.h> /* For task queue support */
|
#include <linux/interrupt.h> /* For task queue support */
|
||||||
|
|
||||||
|
|
|
@ -201,6 +201,19 @@ typedef struct _drm_i830_sarea {
|
||||||
int vertex_prim;
|
int vertex_prim;
|
||||||
} drm_i830_sarea_t;
|
} drm_i830_sarea_t;
|
||||||
|
|
||||||
|
/* I830 specific ioctls
|
||||||
|
* The device specific ioctl range is 0x40 to 0x79.
|
||||||
|
*/
|
||||||
|
#define DRM_IOCTL_I830_INIT DRM_IOW( 0x40, drm_i830_init_t)
|
||||||
|
#define DRM_IOCTL_I830_VERTEX DRM_IOW( 0x41, drm_i830_vertex_t)
|
||||||
|
#define DRM_IOCTL_I830_CLEAR DRM_IOW( 0x42, drm_i830_clear_t)
|
||||||
|
#define DRM_IOCTL_I830_FLUSH DRM_IO ( 0x43)
|
||||||
|
#define DRM_IOCTL_I830_GETAGE DRM_IO ( 0x44)
|
||||||
|
#define DRM_IOCTL_I830_GETBUF DRM_IOWR(0x45, drm_i830_dma_t)
|
||||||
|
#define DRM_IOCTL_I830_SWAP DRM_IO ( 0x46)
|
||||||
|
#define DRM_IOCTL_I830_COPY DRM_IOW( 0x47, drm_i830_copy_t)
|
||||||
|
#define DRM_IOCTL_I830_DOCOPY DRM_IO ( 0x48)
|
||||||
|
|
||||||
typedef struct _drm_i830_clear {
|
typedef struct _drm_i830_clear {
|
||||||
int clear_color;
|
int clear_color;
|
||||||
int clear_depth;
|
int clear_depth;
|
||||||
|
|
|
@ -34,6 +34,8 @@
|
||||||
#include <linux/config.h>
|
#include <linux/config.h>
|
||||||
#include "i830.h"
|
#include "i830.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "i830_drm.h"
|
||||||
#include "i830_drv.h"
|
#include "i830_drv.h"
|
||||||
|
|
||||||
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
||||||
|
|
|
@ -32,6 +32,8 @@
|
||||||
#include <linux/config.h>
|
#include <linux/config.h>
|
||||||
#include "mga.h"
|
#include "mga.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "mga_drm.h"
|
||||||
#include "mga_drv.h"
|
#include "mga_drv.h"
|
||||||
|
|
||||||
#define DRIVER_AUTHOR "Gareth Hughes, VA Linux Systems Inc."
|
#define DRIVER_AUTHOR "Gareth Hughes, VA Linux Systems Inc."
|
||||||
|
|
|
@ -32,6 +32,8 @@
|
||||||
#include <linux/config.h>
|
#include <linux/config.h>
|
||||||
#include "r128.h"
|
#include "r128.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "r128_drm.h"
|
||||||
#include "r128_drv.h"
|
#include "r128_drv.h"
|
||||||
#include "ati_pcigart.h"
|
#include "ati_pcigart.h"
|
||||||
|
|
||||||
|
|
|
@ -30,6 +30,8 @@
|
||||||
#include <linux/config.h>
|
#include <linux/config.h>
|
||||||
#include "radeon.h"
|
#include "radeon.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "radeon_drm.h"
|
||||||
#include "radeon_drv.h"
|
#include "radeon_drv.h"
|
||||||
#include "ati_pcigart.h"
|
#include "ati_pcigart.h"
|
||||||
|
|
||||||
|
|
99
linux/drm.h
99
linux/drm.h
|
@ -99,15 +99,6 @@ typedef struct drm_tex_region {
|
||||||
unsigned int age;
|
unsigned int age;
|
||||||
} drm_tex_region_t;
|
} drm_tex_region_t;
|
||||||
|
|
||||||
/* Seperate include files for the i810/mga/r128 specific structures */
|
|
||||||
#include "mga_drm.h"
|
|
||||||
#include "i810_drm.h"
|
|
||||||
#include "r128_drm.h"
|
|
||||||
#include "radeon_drm.h"
|
|
||||||
#include "sis_drm.h"
|
|
||||||
#include "i830_drm.h"
|
|
||||||
#include "gamma_drm.h"
|
|
||||||
|
|
||||||
typedef struct drm_version {
|
typedef struct drm_version {
|
||||||
int version_major; /* Major version */
|
int version_major; /* Major version */
|
||||||
int version_minor; /* Minor version */
|
int version_minor; /* Minor version */
|
||||||
|
@ -428,92 +419,8 @@ typedef struct drm_scatter_gather {
|
||||||
#define DRM_IOCTL_SG_ALLOC DRM_IOW( 0x38, drm_scatter_gather_t)
|
#define DRM_IOCTL_SG_ALLOC DRM_IOW( 0x38, drm_scatter_gather_t)
|
||||||
#define DRM_IOCTL_SG_FREE DRM_IOW( 0x39, drm_scatter_gather_t)
|
#define DRM_IOCTL_SG_FREE DRM_IOW( 0x39, drm_scatter_gather_t)
|
||||||
|
|
||||||
/* MGA specific ioctls */
|
/* Device specfic ioctls should only be in their respective headers
|
||||||
#define DRM_IOCTL_MGA_INIT DRM_IOW( 0x40, drm_mga_init_t)
|
* The device specific ioctl range is 0x40 to 0x79. */
|
||||||
#define DRM_IOCTL_MGA_FLUSH DRM_IOW( 0x41, drm_lock_t)
|
#define DRM_COMMAND_BASE 0x40
|
||||||
#define DRM_IOCTL_MGA_RESET DRM_IO( 0x42)
|
|
||||||
#define DRM_IOCTL_MGA_SWAP DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_MGA_CLEAR DRM_IOW( 0x44, drm_mga_clear_t)
|
|
||||||
#define DRM_IOCTL_MGA_VERTEX DRM_IOW( 0x45, drm_mga_vertex_t)
|
|
||||||
#define DRM_IOCTL_MGA_INDICES DRM_IOW( 0x46, drm_mga_indices_t)
|
|
||||||
#define DRM_IOCTL_MGA_ILOAD DRM_IOW( 0x47, drm_mga_iload_t)
|
|
||||||
#define DRM_IOCTL_MGA_BLIT DRM_IOW( 0x48, drm_mga_blit_t)
|
|
||||||
|
|
||||||
/* i810 specific ioctls */
|
|
||||||
#define DRM_IOCTL_I810_INIT DRM_IOW( 0x40, drm_i810_init_t)
|
|
||||||
#define DRM_IOCTL_I810_VERTEX DRM_IOW( 0x41, drm_i810_vertex_t)
|
|
||||||
#define DRM_IOCTL_I810_CLEAR DRM_IOW( 0x42, drm_i810_clear_t)
|
|
||||||
#define DRM_IOCTL_I810_FLUSH DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_I810_GETAGE DRM_IO( 0x44)
|
|
||||||
#define DRM_IOCTL_I810_GETBUF DRM_IOWR(0x45, drm_i810_dma_t)
|
|
||||||
#define DRM_IOCTL_I810_SWAP DRM_IO( 0x46)
|
|
||||||
#define DRM_IOCTL_I810_COPY DRM_IOW( 0x47, drm_i810_copy_t)
|
|
||||||
#define DRM_IOCTL_I810_DOCOPY DRM_IO( 0x48)
|
|
||||||
#define DRM_IOCTL_I810_OV0INFO DRM_IOR( 0x49, drm_i810_overlay_t)
|
|
||||||
#define DRM_IOCTL_I810_FSTATUS DRM_IO ( 0x4a)
|
|
||||||
#define DRM_IOCTL_I810_OV0FLIP DRM_IO ( 0x4b)
|
|
||||||
#define DRM_IOCTL_I810_MC DRM_IOW( 0x4c, drm_i810_mc_t)
|
|
||||||
#define DRM_IOCTL_I810_RSTATUS DRM_IO ( 0x4d )
|
|
||||||
|
|
||||||
|
|
||||||
/* Rage 128 specific ioctls */
|
|
||||||
#define DRM_IOCTL_R128_INIT DRM_IOW( 0x40, drm_r128_init_t)
|
|
||||||
#define DRM_IOCTL_R128_CCE_START DRM_IO( 0x41)
|
|
||||||
#define DRM_IOCTL_R128_CCE_STOP DRM_IOW( 0x42, drm_r128_cce_stop_t)
|
|
||||||
#define DRM_IOCTL_R128_CCE_RESET DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_R128_CCE_IDLE DRM_IO( 0x44)
|
|
||||||
#define DRM_IOCTL_R128_RESET DRM_IO( 0x46)
|
|
||||||
#define DRM_IOCTL_R128_SWAP DRM_IO( 0x47)
|
|
||||||
#define DRM_IOCTL_R128_CLEAR DRM_IOW( 0x48, drm_r128_clear_t)
|
|
||||||
#define DRM_IOCTL_R128_VERTEX DRM_IOW( 0x49, drm_r128_vertex_t)
|
|
||||||
#define DRM_IOCTL_R128_INDICES DRM_IOW( 0x4a, drm_r128_indices_t)
|
|
||||||
#define DRM_IOCTL_R128_BLIT DRM_IOW( 0x4b, drm_r128_blit_t)
|
|
||||||
#define DRM_IOCTL_R128_DEPTH DRM_IOW( 0x4c, drm_r128_depth_t)
|
|
||||||
#define DRM_IOCTL_R128_STIPPLE DRM_IOW( 0x4d, drm_r128_stipple_t)
|
|
||||||
#define DRM_IOCTL_R128_INDIRECT DRM_IOWR(0x4f, drm_r128_indirect_t)
|
|
||||||
#define DRM_IOCTL_R128_FULLSCREEN DRM_IOW( 0x50, drm_r128_fullscreen_t)
|
|
||||||
#define DRM_IOCTL_R128_CLEAR2 DRM_IOW( 0x51, drm_r128_clear2_t)
|
|
||||||
|
|
||||||
/* Radeon specific ioctls */
|
|
||||||
#define DRM_IOCTL_RADEON_CP_INIT DRM_IOW( 0x40, drm_radeon_init_t)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_START DRM_IO( 0x41)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_STOP DRM_IOW( 0x42, drm_radeon_cp_stop_t)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_RESET DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_IDLE DRM_IO( 0x44)
|
|
||||||
#define DRM_IOCTL_RADEON_RESET DRM_IO( 0x45)
|
|
||||||
#define DRM_IOCTL_RADEON_FULLSCREEN DRM_IOW( 0x46, drm_radeon_fullscreen_t)
|
|
||||||
#define DRM_IOCTL_RADEON_SWAP DRM_IO( 0x47)
|
|
||||||
#define DRM_IOCTL_RADEON_CLEAR DRM_IOW( 0x48, drm_radeon_clear_t)
|
|
||||||
#define DRM_IOCTL_RADEON_VERTEX DRM_IOW( 0x49, drm_radeon_vertex_t)
|
|
||||||
#define DRM_IOCTL_RADEON_INDICES DRM_IOW( 0x4a, drm_radeon_indices_t)
|
|
||||||
#define DRM_IOCTL_RADEON_STIPPLE DRM_IOW( 0x4c, drm_radeon_stipple_t)
|
|
||||||
#define DRM_IOCTL_RADEON_INDIRECT DRM_IOWR(0x4d, drm_radeon_indirect_t)
|
|
||||||
#define DRM_IOCTL_RADEON_TEXTURE DRM_IOWR(0x4e, drm_radeon_texture_t)
|
|
||||||
#define DRM_IOCTL_RADEON_VERTEX2 DRM_IOW( 0x4f, drm_radeon_vertex_t)
|
|
||||||
|
|
||||||
/* Gamma specific ioctls */
|
|
||||||
#define DRM_IOCTL_GAMMA_INIT DRM_IOW( 0x40, drm_gamma_init_t)
|
|
||||||
#define DRM_IOCTL_GAMMA_COPY DRM_IOW( 0x41, drm_gamma_copy_t)
|
|
||||||
|
|
||||||
/* SiS specific ioctls */
|
|
||||||
#define SIS_IOCTL_FB_ALLOC DRM_IOWR(0x44, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_FB_FREE DRM_IOW( 0x45, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_AGP_INIT DRM_IOWR(0x53, drm_sis_agp_t)
|
|
||||||
#define SIS_IOCTL_AGP_ALLOC DRM_IOWR(0x54, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_AGP_FREE DRM_IOW( 0x55, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_FLIP DRM_IOW( 0x48, drm_sis_flip_t)
|
|
||||||
#define SIS_IOCTL_FLIP_INIT DRM_IO( 0x49)
|
|
||||||
#define SIS_IOCTL_FLIP_FINAL DRM_IO( 0x50)
|
|
||||||
|
|
||||||
/* I830 specific ioctls */
|
|
||||||
#define DRM_IOCTL_I830_INIT DRM_IOW( 0x40, drm_i830_init_t)
|
|
||||||
#define DRM_IOCTL_I830_VERTEX DRM_IOW( 0x41, drm_i830_vertex_t)
|
|
||||||
#define DRM_IOCTL_I830_CLEAR DRM_IOW( 0x42, drm_i830_clear_t)
|
|
||||||
#define DRM_IOCTL_I830_FLUSH DRM_IO ( 0x43)
|
|
||||||
#define DRM_IOCTL_I830_GETAGE DRM_IO ( 0x44)
|
|
||||||
#define DRM_IOCTL_I830_GETBUF DRM_IOWR(0x45, drm_i830_dma_t)
|
|
||||||
#define DRM_IOCTL_I830_SWAP DRM_IO ( 0x46)
|
|
||||||
#define DRM_IOCTL_I830_COPY DRM_IOW( 0x47, drm_i830_copy_t)
|
|
||||||
#define DRM_IOCTL_I830_DOCOPY DRM_IO ( 0x48)
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -32,6 +32,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "gamma.h"
|
#include "gamma.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "gamma_drm.h"
|
||||||
#include "gamma_drv.h"
|
#include "gamma_drv.h"
|
||||||
|
|
||||||
#include <linux/interrupt.h> /* For task queue support */
|
#include <linux/interrupt.h> /* For task queue support */
|
||||||
|
|
|
@ -48,6 +48,16 @@ typedef struct _drm_gamma_sarea {
|
||||||
int vertex_prim;
|
int vertex_prim;
|
||||||
} drm_gamma_sarea_t;
|
} drm_gamma_sarea_t;
|
||||||
|
|
||||||
|
/* WARNING: If you change any of these defines, make sure to change the
|
||||||
|
* defines in the Xserver file (xf86drmGamma.h)
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Gamma specific ioctls
|
||||||
|
* The device specific ioctl range is 0x40 to 0x79.
|
||||||
|
*/
|
||||||
|
#define DRM_IOCTL_GAMMA_INIT DRM_IOW( 0x40, drm_gamma_init_t)
|
||||||
|
#define DRM_IOCTL_GAMMA_COPY DRM_IOW( 0x41, drm_gamma_copy_t)
|
||||||
|
|
||||||
typedef struct drm_gamma_copy {
|
typedef struct drm_gamma_copy {
|
||||||
unsigned int DMAOutputAddress;
|
unsigned int DMAOutputAddress;
|
||||||
unsigned int DMAOutputCount;
|
unsigned int DMAOutputCount;
|
||||||
|
|
|
@ -32,6 +32,8 @@
|
||||||
#include <linux/config.h>
|
#include <linux/config.h>
|
||||||
#include "gamma.h"
|
#include "gamma.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "gamma_drm.h"
|
||||||
#include "gamma_drv.h"
|
#include "gamma_drv.h"
|
||||||
|
|
||||||
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
||||||
|
|
|
@ -33,6 +33,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "i810.h"
|
#include "i810.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "i810_drm.h"
|
||||||
#include "i810_drv.h"
|
#include "i810_drv.h"
|
||||||
#include <linux/interrupt.h> /* For task queue support */
|
#include <linux/interrupt.h> /* For task queue support */
|
||||||
|
|
||||||
|
|
|
@ -168,14 +168,34 @@ typedef struct _drm_i810_sarea {
|
||||||
|
|
||||||
} drm_i810_sarea_t;
|
} drm_i810_sarea_t;
|
||||||
|
|
||||||
|
/* WARNING: If you change any of these defines, make sure to change the
|
||||||
|
* defines in the Xserver file (xf86drmMga.h)
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* i810 specific ioctls
|
||||||
|
* The device specific ioctl range is 0x40 to 0x79.
|
||||||
|
*/
|
||||||
|
#define DRM_IOCTL_I810_INIT DRM_IOW( 0x40, drm_i810_init_t)
|
||||||
|
#define DRM_IOCTL_I810_VERTEX DRM_IOW( 0x41, drm_i810_vertex_t)
|
||||||
|
#define DRM_IOCTL_I810_CLEAR DRM_IOW( 0x42, drm_i810_clear_t)
|
||||||
|
#define DRM_IOCTL_I810_FLUSH DRM_IO( 0x43)
|
||||||
|
#define DRM_IOCTL_I810_GETAGE DRM_IO( 0x44)
|
||||||
|
#define DRM_IOCTL_I810_GETBUF DRM_IOWR(0x45, drm_i810_dma_t)
|
||||||
|
#define DRM_IOCTL_I810_SWAP DRM_IO( 0x46)
|
||||||
|
#define DRM_IOCTL_I810_COPY DRM_IOW( 0x47, drm_i810_copy_t)
|
||||||
|
#define DRM_IOCTL_I810_DOCOPY DRM_IO( 0x48)
|
||||||
|
#define DRM_IOCTL_I810_OV0INFO DRM_IOR( 0x49, drm_i810_overlay_t)
|
||||||
|
#define DRM_IOCTL_I810_FSTATUS DRM_IO ( 0x4a)
|
||||||
|
#define DRM_IOCTL_I810_OV0FLIP DRM_IO ( 0x4b)
|
||||||
|
#define DRM_IOCTL_I810_MC DRM_IOW( 0x4c, drm_i810_mc_t)
|
||||||
|
#define DRM_IOCTL_I810_RSTATUS DRM_IO ( 0x4d )
|
||||||
|
|
||||||
typedef struct _drm_i810_clear {
|
typedef struct _drm_i810_clear {
|
||||||
int clear_color;
|
int clear_color;
|
||||||
int clear_depth;
|
int clear_depth;
|
||||||
int flags;
|
int flags;
|
||||||
} drm_i810_clear_t;
|
} drm_i810_clear_t;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* These may be placeholders if we have more cliprects than
|
/* These may be placeholders if we have more cliprects than
|
||||||
* I810_NR_SAREA_CLIPRECTS. In that case, the client sets discard to
|
* I810_NR_SAREA_CLIPRECTS. In that case, the client sets discard to
|
||||||
* false, indicating that the buffer will be dispatched again with a
|
* false, indicating that the buffer will be dispatched again with a
|
||||||
|
|
|
@ -33,6 +33,8 @@
|
||||||
#include <linux/config.h>
|
#include <linux/config.h>
|
||||||
#include "i810.h"
|
#include "i810.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "i810_drm.h"
|
||||||
#include "i810_drv.h"
|
#include "i810_drv.h"
|
||||||
|
|
||||||
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
||||||
|
|
|
@ -34,6 +34,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "i830.h"
|
#include "i830.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "i830_drm.h"
|
||||||
#include "i830_drv.h"
|
#include "i830_drv.h"
|
||||||
#include <linux/interrupt.h> /* For task queue support */
|
#include <linux/interrupt.h> /* For task queue support */
|
||||||
|
|
||||||
|
|
|
@ -201,6 +201,19 @@ typedef struct _drm_i830_sarea {
|
||||||
int vertex_prim;
|
int vertex_prim;
|
||||||
} drm_i830_sarea_t;
|
} drm_i830_sarea_t;
|
||||||
|
|
||||||
|
/* I830 specific ioctls
|
||||||
|
* The device specific ioctl range is 0x40 to 0x79.
|
||||||
|
*/
|
||||||
|
#define DRM_IOCTL_I830_INIT DRM_IOW( 0x40, drm_i830_init_t)
|
||||||
|
#define DRM_IOCTL_I830_VERTEX DRM_IOW( 0x41, drm_i830_vertex_t)
|
||||||
|
#define DRM_IOCTL_I830_CLEAR DRM_IOW( 0x42, drm_i830_clear_t)
|
||||||
|
#define DRM_IOCTL_I830_FLUSH DRM_IO ( 0x43)
|
||||||
|
#define DRM_IOCTL_I830_GETAGE DRM_IO ( 0x44)
|
||||||
|
#define DRM_IOCTL_I830_GETBUF DRM_IOWR(0x45, drm_i830_dma_t)
|
||||||
|
#define DRM_IOCTL_I830_SWAP DRM_IO ( 0x46)
|
||||||
|
#define DRM_IOCTL_I830_COPY DRM_IOW( 0x47, drm_i830_copy_t)
|
||||||
|
#define DRM_IOCTL_I830_DOCOPY DRM_IO ( 0x48)
|
||||||
|
|
||||||
typedef struct _drm_i830_clear {
|
typedef struct _drm_i830_clear {
|
||||||
int clear_color;
|
int clear_color;
|
||||||
int clear_depth;
|
int clear_depth;
|
||||||
|
|
|
@ -34,6 +34,8 @@
|
||||||
#include <linux/config.h>
|
#include <linux/config.h>
|
||||||
#include "i830.h"
|
#include "i830.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "i830_drm.h"
|
||||||
#include "i830_drv.h"
|
#include "i830_drv.h"
|
||||||
|
|
||||||
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
#define DRIVER_AUTHOR "VA Linux Systems Inc."
|
||||||
|
|
|
@ -36,6 +36,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "mga.h"
|
#include "mga.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "mga_drm.h"
|
||||||
#include "mga_drv.h"
|
#include "mga_drv.h"
|
||||||
|
|
||||||
#include <linux/interrupt.h> /* For task queue support */
|
#include <linux/interrupt.h> /* For task queue support */
|
||||||
|
|
|
@ -38,6 +38,7 @@
|
||||||
/* WARNING: If you change any of these defines, make sure to change the
|
/* WARNING: If you change any of these defines, make sure to change the
|
||||||
* defines in the Xserver file (mga_sarea.h)
|
* defines in the Xserver file (mga_sarea.h)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __MGA_SAREA_DEFINES__
|
#ifndef __MGA_SAREA_DEFINES__
|
||||||
#define __MGA_SAREA_DEFINES__
|
#define __MGA_SAREA_DEFINES__
|
||||||
|
|
||||||
|
@ -225,6 +226,20 @@ typedef struct _drm_mga_sarea {
|
||||||
/* WARNING: If you change any of these defines, make sure to change the
|
/* WARNING: If you change any of these defines, make sure to change the
|
||||||
* defines in the Xserver file (xf86drmMga.h)
|
* defines in the Xserver file (xf86drmMga.h)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* MGA specific ioctls
|
||||||
|
* The device specific ioctl range is 0x40 to 0x79.
|
||||||
|
*/
|
||||||
|
#define DRM_IOCTL_MGA_INIT DRM_IOW( 0x40, drm_mga_init_t)
|
||||||
|
#define DRM_IOCTL_MGA_FLUSH DRM_IOW( 0x41, drm_lock_t)
|
||||||
|
#define DRM_IOCTL_MGA_RESET DRM_IO( 0x42)
|
||||||
|
#define DRM_IOCTL_MGA_SWAP DRM_IO( 0x43)
|
||||||
|
#define DRM_IOCTL_MGA_CLEAR DRM_IOW( 0x44, drm_mga_clear_t)
|
||||||
|
#define DRM_IOCTL_MGA_VERTEX DRM_IOW( 0x45, drm_mga_vertex_t)
|
||||||
|
#define DRM_IOCTL_MGA_INDICES DRM_IOW( 0x46, drm_mga_indices_t)
|
||||||
|
#define DRM_IOCTL_MGA_ILOAD DRM_IOW( 0x47, drm_mga_iload_t)
|
||||||
|
#define DRM_IOCTL_MGA_BLIT DRM_IOW( 0x48, drm_mga_blit_t)
|
||||||
|
|
||||||
typedef struct _drm_mga_warp_index {
|
typedef struct _drm_mga_warp_index {
|
||||||
int installed;
|
int installed;
|
||||||
unsigned long phys_addr;
|
unsigned long phys_addr;
|
||||||
|
|
|
@ -32,6 +32,8 @@
|
||||||
#include <linux/config.h>
|
#include <linux/config.h>
|
||||||
#include "mga.h"
|
#include "mga.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "mga_drm.h"
|
||||||
#include "mga_drv.h"
|
#include "mga_drv.h"
|
||||||
|
|
||||||
#define DRIVER_AUTHOR "Gareth Hughes, VA Linux Systems Inc."
|
#define DRIVER_AUTHOR "Gareth Hughes, VA Linux Systems Inc."
|
||||||
|
|
|
@ -35,6 +35,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "mga.h"
|
#include "mga.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "mga_drm.h"
|
||||||
#include "mga_drv.h"
|
#include "mga_drv.h"
|
||||||
#include "drm.h"
|
#include "drm.h"
|
||||||
|
|
||||||
|
|
|
@ -30,6 +30,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "mga.h"
|
#include "mga.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "mga_drm.h"
|
||||||
#include "mga_drv.h"
|
#include "mga_drv.h"
|
||||||
#include "mga_ucode.h"
|
#include "mga_ucode.h"
|
||||||
|
|
||||||
|
|
|
@ -31,6 +31,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "r128.h"
|
#include "r128.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "r128_drm.h"
|
||||||
#include "r128_drv.h"
|
#include "r128_drv.h"
|
||||||
|
|
||||||
#include <linux/interrupt.h> /* For task queue support */
|
#include <linux/interrupt.h> /* For task queue support */
|
||||||
|
|
|
@ -170,6 +170,27 @@ typedef struct drm_r128_sarea {
|
||||||
/* WARNING: If you change any of these defines, make sure to change the
|
/* WARNING: If you change any of these defines, make sure to change the
|
||||||
* defines in the Xserver file (xf86drmR128.h)
|
* defines in the Xserver file (xf86drmR128.h)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* Rage 128 specific ioctls
|
||||||
|
* The device specific ioctl range is 0x40 to 0x79.
|
||||||
|
*/
|
||||||
|
#define DRM_IOCTL_R128_INIT DRM_IOW( 0x40, drm_r128_init_t)
|
||||||
|
#define DRM_IOCTL_R128_CCE_START DRM_IO( 0x41)
|
||||||
|
#define DRM_IOCTL_R128_CCE_STOP DRM_IOW( 0x42, drm_r128_cce_stop_t)
|
||||||
|
#define DRM_IOCTL_R128_CCE_RESET DRM_IO( 0x43)
|
||||||
|
#define DRM_IOCTL_R128_CCE_IDLE DRM_IO( 0x44)
|
||||||
|
#define DRM_IOCTL_R128_RESET DRM_IO( 0x46)
|
||||||
|
#define DRM_IOCTL_R128_SWAP DRM_IO( 0x47)
|
||||||
|
#define DRM_IOCTL_R128_CLEAR DRM_IOW( 0x48, drm_r128_clear_t)
|
||||||
|
#define DRM_IOCTL_R128_VERTEX DRM_IOW( 0x49, drm_r128_vertex_t)
|
||||||
|
#define DRM_IOCTL_R128_INDICES DRM_IOW( 0x4a, drm_r128_indices_t)
|
||||||
|
#define DRM_IOCTL_R128_BLIT DRM_IOW( 0x4b, drm_r128_blit_t)
|
||||||
|
#define DRM_IOCTL_R128_DEPTH DRM_IOW( 0x4c, drm_r128_depth_t)
|
||||||
|
#define DRM_IOCTL_R128_STIPPLE DRM_IOW( 0x4d, drm_r128_stipple_t)
|
||||||
|
#define DRM_IOCTL_R128_INDIRECT DRM_IOWR(0x4f, drm_r128_indirect_t)
|
||||||
|
#define DRM_IOCTL_R128_FULLSCREEN DRM_IOW( 0x50, drm_r128_fullscreen_t)
|
||||||
|
#define DRM_IOCTL_R128_CLEAR2 DRM_IOW( 0x51, drm_r128_clear2_t)
|
||||||
|
|
||||||
typedef struct drm_r128_init {
|
typedef struct drm_r128_init {
|
||||||
enum {
|
enum {
|
||||||
R128_INIT_CCE = 0x01,
|
R128_INIT_CCE = 0x01,
|
||||||
|
|
|
@ -32,6 +32,8 @@
|
||||||
#include <linux/config.h>
|
#include <linux/config.h>
|
||||||
#include "r128.h"
|
#include "r128.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "r128_drm.h"
|
||||||
#include "r128_drv.h"
|
#include "r128_drv.h"
|
||||||
#include "ati_pcigart.h"
|
#include "ati_pcigart.h"
|
||||||
|
|
||||||
|
|
|
@ -30,6 +30,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "r128.h"
|
#include "r128.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "r128_drm.h"
|
||||||
#include "r128_drv.h"
|
#include "r128_drv.h"
|
||||||
#include "drm.h"
|
#include "drm.h"
|
||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
|
|
|
@ -31,6 +31,8 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "radeon.h"
|
#include "radeon.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "radeon_drm.h"
|
||||||
#include "radeon_drv.h"
|
#include "radeon_drv.h"
|
||||||
|
|
||||||
#include <linux/interrupt.h> /* For task queue support */
|
#include <linux/interrupt.h> /* For task queue support */
|
||||||
|
|
|
@ -236,7 +236,29 @@ typedef struct {
|
||||||
|
|
||||||
/* WARNING: If you change any of these defines, make sure to change the
|
/* WARNING: If you change any of these defines, make sure to change the
|
||||||
* defines in the Xserver file (xf86drmRadeon.h)
|
* defines in the Xserver file (xf86drmRadeon.h)
|
||||||
|
*
|
||||||
|
* KW: actually it's illegal to change any of this (backwards compatibility).
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* Radeon specific ioctls
|
||||||
|
* The device specific ioctl range is 0x40 to 0x79.
|
||||||
|
*/
|
||||||
|
#define DRM_IOCTL_RADEON_CP_INIT DRM_IOW( 0x40, drm_radeon_init_t)
|
||||||
|
#define DRM_IOCTL_RADEON_CP_START DRM_IO( 0x41)
|
||||||
|
#define DRM_IOCTL_RADEON_CP_STOP DRM_IOW( 0x42, drm_radeon_cp_stop_t)
|
||||||
|
#define DRM_IOCTL_RADEON_CP_RESET DRM_IO( 0x43)
|
||||||
|
#define DRM_IOCTL_RADEON_CP_IDLE DRM_IO( 0x44)
|
||||||
|
#define DRM_IOCTL_RADEON_RESET DRM_IO( 0x45)
|
||||||
|
#define DRM_IOCTL_RADEON_FULLSCREEN DRM_IOW( 0x46, drm_radeon_fullscreen_t)
|
||||||
|
#define DRM_IOCTL_RADEON_SWAP DRM_IO( 0x47)
|
||||||
|
#define DRM_IOCTL_RADEON_CLEAR DRM_IOW( 0x48, drm_radeon_clear_t)
|
||||||
|
#define DRM_IOCTL_RADEON_VERTEX DRM_IOW( 0x49, drm_radeon_vertex_t)
|
||||||
|
#define DRM_IOCTL_RADEON_INDICES DRM_IOW( 0x4a, drm_radeon_indices_t)
|
||||||
|
#define DRM_IOCTL_RADEON_STIPPLE DRM_IOW( 0x4c, drm_radeon_stipple_t)
|
||||||
|
#define DRM_IOCTL_RADEON_INDIRECT DRM_IOWR(0x4d, drm_radeon_indirect_t)
|
||||||
|
#define DRM_IOCTL_RADEON_TEXTURE DRM_IOWR(0x4e, drm_radeon_texture_t)
|
||||||
|
#define DRM_IOCTL_RADEON_VERTEX2 DRM_IOW( 0x4f, drm_radeon_vertex_t)
|
||||||
|
|
||||||
typedef struct drm_radeon_init {
|
typedef struct drm_radeon_init {
|
||||||
enum {
|
enum {
|
||||||
RADEON_INIT_CP = 0x01,
|
RADEON_INIT_CP = 0x01,
|
||||||
|
|
|
@ -30,6 +30,8 @@
|
||||||
#include <linux/config.h>
|
#include <linux/config.h>
|
||||||
#include "radeon.h"
|
#include "radeon.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
|
#include "drm.h"
|
||||||
|
#include "radeon_drm.h"
|
||||||
#include "radeon_drv.h"
|
#include "radeon_drv.h"
|
||||||
#include "ati_pcigart.h"
|
#include "ati_pcigart.h"
|
||||||
|
|
||||||
|
|
|
@ -30,8 +30,9 @@
|
||||||
#define __NO_VERSION__
|
#define __NO_VERSION__
|
||||||
#include "radeon.h"
|
#include "radeon.h"
|
||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
#include "radeon_drv.h"
|
|
||||||
#include "drm.h"
|
#include "drm.h"
|
||||||
|
#include "radeon_drm.h"
|
||||||
|
#include "radeon_drv.h"
|
||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2,6 +2,16 @@
|
||||||
#ifndef _sis_drm_public_h_
|
#ifndef _sis_drm_public_h_
|
||||||
#define _sis_drm_public_h_
|
#define _sis_drm_public_h_
|
||||||
|
|
||||||
|
/* SiS specific ioctls */
|
||||||
|
#define SIS_IOCTL_FB_ALLOC DRM_IOWR(0x44, drm_sis_mem_t)
|
||||||
|
#define SIS_IOCTL_FB_FREE DRM_IOW( 0x45, drm_sis_mem_t)
|
||||||
|
#define SIS_IOCTL_AGP_INIT DRM_IOWR(0x53, drm_sis_agp_t)
|
||||||
|
#define SIS_IOCTL_AGP_ALLOC DRM_IOWR(0x54, drm_sis_mem_t)
|
||||||
|
#define SIS_IOCTL_AGP_FREE DRM_IOW( 0x55, drm_sis_mem_t)
|
||||||
|
#define SIS_IOCTL_FLIP DRM_IOW( 0x48, drm_sis_flip_t)
|
||||||
|
#define SIS_IOCTL_FLIP_INIT DRM_IO( 0x49)
|
||||||
|
#define SIS_IOCTL_FLIP_FINAL DRM_IO( 0x50)
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int context;
|
int context;
|
||||||
unsigned int offset;
|
unsigned int offset;
|
||||||
|
|
|
@ -99,15 +99,6 @@ typedef struct drm_tex_region {
|
||||||
unsigned int age;
|
unsigned int age;
|
||||||
} drm_tex_region_t;
|
} drm_tex_region_t;
|
||||||
|
|
||||||
/* Seperate include files for the i810/mga/r128 specific structures */
|
|
||||||
#include "mga_drm.h"
|
|
||||||
#include "i810_drm.h"
|
|
||||||
#include "r128_drm.h"
|
|
||||||
#include "radeon_drm.h"
|
|
||||||
#include "sis_drm.h"
|
|
||||||
#include "i830_drm.h"
|
|
||||||
#include "gamma_drm.h"
|
|
||||||
|
|
||||||
typedef struct drm_version {
|
typedef struct drm_version {
|
||||||
int version_major; /* Major version */
|
int version_major; /* Major version */
|
||||||
int version_minor; /* Minor version */
|
int version_minor; /* Minor version */
|
||||||
|
@ -428,92 +419,8 @@ typedef struct drm_scatter_gather {
|
||||||
#define DRM_IOCTL_SG_ALLOC DRM_IOW( 0x38, drm_scatter_gather_t)
|
#define DRM_IOCTL_SG_ALLOC DRM_IOW( 0x38, drm_scatter_gather_t)
|
||||||
#define DRM_IOCTL_SG_FREE DRM_IOW( 0x39, drm_scatter_gather_t)
|
#define DRM_IOCTL_SG_FREE DRM_IOW( 0x39, drm_scatter_gather_t)
|
||||||
|
|
||||||
/* MGA specific ioctls */
|
/* Device specfic ioctls should only be in their respective headers
|
||||||
#define DRM_IOCTL_MGA_INIT DRM_IOW( 0x40, drm_mga_init_t)
|
* The device specific ioctl range is 0x40 to 0x79. */
|
||||||
#define DRM_IOCTL_MGA_FLUSH DRM_IOW( 0x41, drm_lock_t)
|
#define DRM_COMMAND_BASE 0x40
|
||||||
#define DRM_IOCTL_MGA_RESET DRM_IO( 0x42)
|
|
||||||
#define DRM_IOCTL_MGA_SWAP DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_MGA_CLEAR DRM_IOW( 0x44, drm_mga_clear_t)
|
|
||||||
#define DRM_IOCTL_MGA_VERTEX DRM_IOW( 0x45, drm_mga_vertex_t)
|
|
||||||
#define DRM_IOCTL_MGA_INDICES DRM_IOW( 0x46, drm_mga_indices_t)
|
|
||||||
#define DRM_IOCTL_MGA_ILOAD DRM_IOW( 0x47, drm_mga_iload_t)
|
|
||||||
#define DRM_IOCTL_MGA_BLIT DRM_IOW( 0x48, drm_mga_blit_t)
|
|
||||||
|
|
||||||
/* i810 specific ioctls */
|
|
||||||
#define DRM_IOCTL_I810_INIT DRM_IOW( 0x40, drm_i810_init_t)
|
|
||||||
#define DRM_IOCTL_I810_VERTEX DRM_IOW( 0x41, drm_i810_vertex_t)
|
|
||||||
#define DRM_IOCTL_I810_CLEAR DRM_IOW( 0x42, drm_i810_clear_t)
|
|
||||||
#define DRM_IOCTL_I810_FLUSH DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_I810_GETAGE DRM_IO( 0x44)
|
|
||||||
#define DRM_IOCTL_I810_GETBUF DRM_IOWR(0x45, drm_i810_dma_t)
|
|
||||||
#define DRM_IOCTL_I810_SWAP DRM_IO( 0x46)
|
|
||||||
#define DRM_IOCTL_I810_COPY DRM_IOW( 0x47, drm_i810_copy_t)
|
|
||||||
#define DRM_IOCTL_I810_DOCOPY DRM_IO( 0x48)
|
|
||||||
#define DRM_IOCTL_I810_OV0INFO DRM_IOR( 0x49, drm_i810_overlay_t)
|
|
||||||
#define DRM_IOCTL_I810_FSTATUS DRM_IO ( 0x4a)
|
|
||||||
#define DRM_IOCTL_I810_OV0FLIP DRM_IO ( 0x4b)
|
|
||||||
#define DRM_IOCTL_I810_MC DRM_IOW( 0x4c, drm_i810_mc_t)
|
|
||||||
#define DRM_IOCTL_I810_RSTATUS DRM_IO ( 0x4d )
|
|
||||||
|
|
||||||
|
|
||||||
/* Rage 128 specific ioctls */
|
|
||||||
#define DRM_IOCTL_R128_INIT DRM_IOW( 0x40, drm_r128_init_t)
|
|
||||||
#define DRM_IOCTL_R128_CCE_START DRM_IO( 0x41)
|
|
||||||
#define DRM_IOCTL_R128_CCE_STOP DRM_IOW( 0x42, drm_r128_cce_stop_t)
|
|
||||||
#define DRM_IOCTL_R128_CCE_RESET DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_R128_CCE_IDLE DRM_IO( 0x44)
|
|
||||||
#define DRM_IOCTL_R128_RESET DRM_IO( 0x46)
|
|
||||||
#define DRM_IOCTL_R128_SWAP DRM_IO( 0x47)
|
|
||||||
#define DRM_IOCTL_R128_CLEAR DRM_IOW( 0x48, drm_r128_clear_t)
|
|
||||||
#define DRM_IOCTL_R128_VERTEX DRM_IOW( 0x49, drm_r128_vertex_t)
|
|
||||||
#define DRM_IOCTL_R128_INDICES DRM_IOW( 0x4a, drm_r128_indices_t)
|
|
||||||
#define DRM_IOCTL_R128_BLIT DRM_IOW( 0x4b, drm_r128_blit_t)
|
|
||||||
#define DRM_IOCTL_R128_DEPTH DRM_IOW( 0x4c, drm_r128_depth_t)
|
|
||||||
#define DRM_IOCTL_R128_STIPPLE DRM_IOW( 0x4d, drm_r128_stipple_t)
|
|
||||||
#define DRM_IOCTL_R128_INDIRECT DRM_IOWR(0x4f, drm_r128_indirect_t)
|
|
||||||
#define DRM_IOCTL_R128_FULLSCREEN DRM_IOW( 0x50, drm_r128_fullscreen_t)
|
|
||||||
#define DRM_IOCTL_R128_CLEAR2 DRM_IOW( 0x51, drm_r128_clear2_t)
|
|
||||||
|
|
||||||
/* Radeon specific ioctls */
|
|
||||||
#define DRM_IOCTL_RADEON_CP_INIT DRM_IOW( 0x40, drm_radeon_init_t)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_START DRM_IO( 0x41)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_STOP DRM_IOW( 0x42, drm_radeon_cp_stop_t)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_RESET DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_IDLE DRM_IO( 0x44)
|
|
||||||
#define DRM_IOCTL_RADEON_RESET DRM_IO( 0x45)
|
|
||||||
#define DRM_IOCTL_RADEON_FULLSCREEN DRM_IOW( 0x46, drm_radeon_fullscreen_t)
|
|
||||||
#define DRM_IOCTL_RADEON_SWAP DRM_IO( 0x47)
|
|
||||||
#define DRM_IOCTL_RADEON_CLEAR DRM_IOW( 0x48, drm_radeon_clear_t)
|
|
||||||
#define DRM_IOCTL_RADEON_VERTEX DRM_IOW( 0x49, drm_radeon_vertex_t)
|
|
||||||
#define DRM_IOCTL_RADEON_INDICES DRM_IOW( 0x4a, drm_radeon_indices_t)
|
|
||||||
#define DRM_IOCTL_RADEON_STIPPLE DRM_IOW( 0x4c, drm_radeon_stipple_t)
|
|
||||||
#define DRM_IOCTL_RADEON_INDIRECT DRM_IOWR(0x4d, drm_radeon_indirect_t)
|
|
||||||
#define DRM_IOCTL_RADEON_TEXTURE DRM_IOWR(0x4e, drm_radeon_texture_t)
|
|
||||||
#define DRM_IOCTL_RADEON_VERTEX2 DRM_IOW( 0x4f, drm_radeon_vertex_t)
|
|
||||||
|
|
||||||
/* Gamma specific ioctls */
|
|
||||||
#define DRM_IOCTL_GAMMA_INIT DRM_IOW( 0x40, drm_gamma_init_t)
|
|
||||||
#define DRM_IOCTL_GAMMA_COPY DRM_IOW( 0x41, drm_gamma_copy_t)
|
|
||||||
|
|
||||||
/* SiS specific ioctls */
|
|
||||||
#define SIS_IOCTL_FB_ALLOC DRM_IOWR(0x44, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_FB_FREE DRM_IOW( 0x45, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_AGP_INIT DRM_IOWR(0x53, drm_sis_agp_t)
|
|
||||||
#define SIS_IOCTL_AGP_ALLOC DRM_IOWR(0x54, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_AGP_FREE DRM_IOW( 0x55, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_FLIP DRM_IOW( 0x48, drm_sis_flip_t)
|
|
||||||
#define SIS_IOCTL_FLIP_INIT DRM_IO( 0x49)
|
|
||||||
#define SIS_IOCTL_FLIP_FINAL DRM_IO( 0x50)
|
|
||||||
|
|
||||||
/* I830 specific ioctls */
|
|
||||||
#define DRM_IOCTL_I830_INIT DRM_IOW( 0x40, drm_i830_init_t)
|
|
||||||
#define DRM_IOCTL_I830_VERTEX DRM_IOW( 0x41, drm_i830_vertex_t)
|
|
||||||
#define DRM_IOCTL_I830_CLEAR DRM_IOW( 0x42, drm_i830_clear_t)
|
|
||||||
#define DRM_IOCTL_I830_FLUSH DRM_IO ( 0x43)
|
|
||||||
#define DRM_IOCTL_I830_GETAGE DRM_IO ( 0x44)
|
|
||||||
#define DRM_IOCTL_I830_GETBUF DRM_IOWR(0x45, drm_i830_dma_t)
|
|
||||||
#define DRM_IOCTL_I830_SWAP DRM_IO ( 0x46)
|
|
||||||
#define DRM_IOCTL_I830_COPY DRM_IOW( 0x47, drm_i830_copy_t)
|
|
||||||
#define DRM_IOCTL_I830_DOCOPY DRM_IO ( 0x48)
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
99
shared/drm.h
99
shared/drm.h
|
@ -99,15 +99,6 @@ typedef struct drm_tex_region {
|
||||||
unsigned int age;
|
unsigned int age;
|
||||||
} drm_tex_region_t;
|
} drm_tex_region_t;
|
||||||
|
|
||||||
/* Seperate include files for the i810/mga/r128 specific structures */
|
|
||||||
#include "mga_drm.h"
|
|
||||||
#include "i810_drm.h"
|
|
||||||
#include "r128_drm.h"
|
|
||||||
#include "radeon_drm.h"
|
|
||||||
#include "sis_drm.h"
|
|
||||||
#include "i830_drm.h"
|
|
||||||
#include "gamma_drm.h"
|
|
||||||
|
|
||||||
typedef struct drm_version {
|
typedef struct drm_version {
|
||||||
int version_major; /* Major version */
|
int version_major; /* Major version */
|
||||||
int version_minor; /* Minor version */
|
int version_minor; /* Minor version */
|
||||||
|
@ -428,92 +419,8 @@ typedef struct drm_scatter_gather {
|
||||||
#define DRM_IOCTL_SG_ALLOC DRM_IOW( 0x38, drm_scatter_gather_t)
|
#define DRM_IOCTL_SG_ALLOC DRM_IOW( 0x38, drm_scatter_gather_t)
|
||||||
#define DRM_IOCTL_SG_FREE DRM_IOW( 0x39, drm_scatter_gather_t)
|
#define DRM_IOCTL_SG_FREE DRM_IOW( 0x39, drm_scatter_gather_t)
|
||||||
|
|
||||||
/* MGA specific ioctls */
|
/* Device specfic ioctls should only be in their respective headers
|
||||||
#define DRM_IOCTL_MGA_INIT DRM_IOW( 0x40, drm_mga_init_t)
|
* The device specific ioctl range is 0x40 to 0x79. */
|
||||||
#define DRM_IOCTL_MGA_FLUSH DRM_IOW( 0x41, drm_lock_t)
|
#define DRM_COMMAND_BASE 0x40
|
||||||
#define DRM_IOCTL_MGA_RESET DRM_IO( 0x42)
|
|
||||||
#define DRM_IOCTL_MGA_SWAP DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_MGA_CLEAR DRM_IOW( 0x44, drm_mga_clear_t)
|
|
||||||
#define DRM_IOCTL_MGA_VERTEX DRM_IOW( 0x45, drm_mga_vertex_t)
|
|
||||||
#define DRM_IOCTL_MGA_INDICES DRM_IOW( 0x46, drm_mga_indices_t)
|
|
||||||
#define DRM_IOCTL_MGA_ILOAD DRM_IOW( 0x47, drm_mga_iload_t)
|
|
||||||
#define DRM_IOCTL_MGA_BLIT DRM_IOW( 0x48, drm_mga_blit_t)
|
|
||||||
|
|
||||||
/* i810 specific ioctls */
|
|
||||||
#define DRM_IOCTL_I810_INIT DRM_IOW( 0x40, drm_i810_init_t)
|
|
||||||
#define DRM_IOCTL_I810_VERTEX DRM_IOW( 0x41, drm_i810_vertex_t)
|
|
||||||
#define DRM_IOCTL_I810_CLEAR DRM_IOW( 0x42, drm_i810_clear_t)
|
|
||||||
#define DRM_IOCTL_I810_FLUSH DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_I810_GETAGE DRM_IO( 0x44)
|
|
||||||
#define DRM_IOCTL_I810_GETBUF DRM_IOWR(0x45, drm_i810_dma_t)
|
|
||||||
#define DRM_IOCTL_I810_SWAP DRM_IO( 0x46)
|
|
||||||
#define DRM_IOCTL_I810_COPY DRM_IOW( 0x47, drm_i810_copy_t)
|
|
||||||
#define DRM_IOCTL_I810_DOCOPY DRM_IO( 0x48)
|
|
||||||
#define DRM_IOCTL_I810_OV0INFO DRM_IOR( 0x49, drm_i810_overlay_t)
|
|
||||||
#define DRM_IOCTL_I810_FSTATUS DRM_IO ( 0x4a)
|
|
||||||
#define DRM_IOCTL_I810_OV0FLIP DRM_IO ( 0x4b)
|
|
||||||
#define DRM_IOCTL_I810_MC DRM_IOW( 0x4c, drm_i810_mc_t)
|
|
||||||
#define DRM_IOCTL_I810_RSTATUS DRM_IO ( 0x4d )
|
|
||||||
|
|
||||||
|
|
||||||
/* Rage 128 specific ioctls */
|
|
||||||
#define DRM_IOCTL_R128_INIT DRM_IOW( 0x40, drm_r128_init_t)
|
|
||||||
#define DRM_IOCTL_R128_CCE_START DRM_IO( 0x41)
|
|
||||||
#define DRM_IOCTL_R128_CCE_STOP DRM_IOW( 0x42, drm_r128_cce_stop_t)
|
|
||||||
#define DRM_IOCTL_R128_CCE_RESET DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_R128_CCE_IDLE DRM_IO( 0x44)
|
|
||||||
#define DRM_IOCTL_R128_RESET DRM_IO( 0x46)
|
|
||||||
#define DRM_IOCTL_R128_SWAP DRM_IO( 0x47)
|
|
||||||
#define DRM_IOCTL_R128_CLEAR DRM_IOW( 0x48, drm_r128_clear_t)
|
|
||||||
#define DRM_IOCTL_R128_VERTEX DRM_IOW( 0x49, drm_r128_vertex_t)
|
|
||||||
#define DRM_IOCTL_R128_INDICES DRM_IOW( 0x4a, drm_r128_indices_t)
|
|
||||||
#define DRM_IOCTL_R128_BLIT DRM_IOW( 0x4b, drm_r128_blit_t)
|
|
||||||
#define DRM_IOCTL_R128_DEPTH DRM_IOW( 0x4c, drm_r128_depth_t)
|
|
||||||
#define DRM_IOCTL_R128_STIPPLE DRM_IOW( 0x4d, drm_r128_stipple_t)
|
|
||||||
#define DRM_IOCTL_R128_INDIRECT DRM_IOWR(0x4f, drm_r128_indirect_t)
|
|
||||||
#define DRM_IOCTL_R128_FULLSCREEN DRM_IOW( 0x50, drm_r128_fullscreen_t)
|
|
||||||
#define DRM_IOCTL_R128_CLEAR2 DRM_IOW( 0x51, drm_r128_clear2_t)
|
|
||||||
|
|
||||||
/* Radeon specific ioctls */
|
|
||||||
#define DRM_IOCTL_RADEON_CP_INIT DRM_IOW( 0x40, drm_radeon_init_t)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_START DRM_IO( 0x41)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_STOP DRM_IOW( 0x42, drm_radeon_cp_stop_t)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_RESET DRM_IO( 0x43)
|
|
||||||
#define DRM_IOCTL_RADEON_CP_IDLE DRM_IO( 0x44)
|
|
||||||
#define DRM_IOCTL_RADEON_RESET DRM_IO( 0x45)
|
|
||||||
#define DRM_IOCTL_RADEON_FULLSCREEN DRM_IOW( 0x46, drm_radeon_fullscreen_t)
|
|
||||||
#define DRM_IOCTL_RADEON_SWAP DRM_IO( 0x47)
|
|
||||||
#define DRM_IOCTL_RADEON_CLEAR DRM_IOW( 0x48, drm_radeon_clear_t)
|
|
||||||
#define DRM_IOCTL_RADEON_VERTEX DRM_IOW( 0x49, drm_radeon_vertex_t)
|
|
||||||
#define DRM_IOCTL_RADEON_INDICES DRM_IOW( 0x4a, drm_radeon_indices_t)
|
|
||||||
#define DRM_IOCTL_RADEON_STIPPLE DRM_IOW( 0x4c, drm_radeon_stipple_t)
|
|
||||||
#define DRM_IOCTL_RADEON_INDIRECT DRM_IOWR(0x4d, drm_radeon_indirect_t)
|
|
||||||
#define DRM_IOCTL_RADEON_TEXTURE DRM_IOWR(0x4e, drm_radeon_texture_t)
|
|
||||||
#define DRM_IOCTL_RADEON_VERTEX2 DRM_IOW( 0x4f, drm_radeon_vertex_t)
|
|
||||||
|
|
||||||
/* Gamma specific ioctls */
|
|
||||||
#define DRM_IOCTL_GAMMA_INIT DRM_IOW( 0x40, drm_gamma_init_t)
|
|
||||||
#define DRM_IOCTL_GAMMA_COPY DRM_IOW( 0x41, drm_gamma_copy_t)
|
|
||||||
|
|
||||||
/* SiS specific ioctls */
|
|
||||||
#define SIS_IOCTL_FB_ALLOC DRM_IOWR(0x44, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_FB_FREE DRM_IOW( 0x45, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_AGP_INIT DRM_IOWR(0x53, drm_sis_agp_t)
|
|
||||||
#define SIS_IOCTL_AGP_ALLOC DRM_IOWR(0x54, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_AGP_FREE DRM_IOW( 0x55, drm_sis_mem_t)
|
|
||||||
#define SIS_IOCTL_FLIP DRM_IOW( 0x48, drm_sis_flip_t)
|
|
||||||
#define SIS_IOCTL_FLIP_INIT DRM_IO( 0x49)
|
|
||||||
#define SIS_IOCTL_FLIP_FINAL DRM_IO( 0x50)
|
|
||||||
|
|
||||||
/* I830 specific ioctls */
|
|
||||||
#define DRM_IOCTL_I830_INIT DRM_IOW( 0x40, drm_i830_init_t)
|
|
||||||
#define DRM_IOCTL_I830_VERTEX DRM_IOW( 0x41, drm_i830_vertex_t)
|
|
||||||
#define DRM_IOCTL_I830_CLEAR DRM_IOW( 0x42, drm_i830_clear_t)
|
|
||||||
#define DRM_IOCTL_I830_FLUSH DRM_IO ( 0x43)
|
|
||||||
#define DRM_IOCTL_I830_GETAGE DRM_IO ( 0x44)
|
|
||||||
#define DRM_IOCTL_I830_GETBUF DRM_IOWR(0x45, drm_i830_dma_t)
|
|
||||||
#define DRM_IOCTL_I830_SWAP DRM_IO ( 0x46)
|
|
||||||
#define DRM_IOCTL_I830_COPY DRM_IOW( 0x47, drm_i830_copy_t)
|
|
||||||
#define DRM_IOCTL_I830_DOCOPY DRM_IO ( 0x48)
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue