r128_drv.c
上传用户:lgb322
上传日期:2013-02-24
资源大小:30529k
文件大小:4k
源码类别:

嵌入式Linux

开发平台:

Unix_Linux

  1. /* r128_drv.c -- ATI Rage 128 driver -*- linux-c -*-
  2.  * Created: Mon Dec 13 09:47:27 1999 by faith@precisioninsight.com
  3.  *
  4.  * Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
  5.  * Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
  6.  * All Rights Reserved.
  7.  *
  8.  * Permission is hereby granted, free of charge, to any person obtaining a
  9.  * copy of this software and associated documentation files (the "Software"),
  10.  * to deal in the Software without restriction, including without limitation
  11.  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
  12.  * and/or sell copies of the Software, and to permit persons to whom the
  13.  * Software is furnished to do so, subject to the following conditions:
  14.  *
  15.  * The above copyright notice and this permission notice (including the next
  16.  * paragraph) shall be included in all copies or substantial portions of the
  17.  * Software.
  18.  *
  19.  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  20.  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  21.  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
  22.  * VA LINUX SYSTEMS AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
  23.  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
  24.  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
  25.  * OTHER DEALINGS IN THE SOFTWARE.
  26.  *
  27.  * Authors:
  28.  *    Rickard E. (Rik) Faith <faith@valinux.com>
  29.  *    Gareth Hughes <gareth@valinux.com>
  30.  */
  31. #include <linux/config.h>
  32. #include "r128.h"
  33. #include "drmP.h"
  34. #include "r128_drv.h"
  35. #include "ati_pcigart.h"
  36. #define DRIVER_AUTHOR "Gareth Hughes, VA Linux Systems Inc."
  37. #define DRIVER_NAME "r128"
  38. #define DRIVER_DESC "ATI Rage 128"
  39. #define DRIVER_DATE "20010405"
  40. #define DRIVER_MAJOR 2
  41. #define DRIVER_MINOR 1
  42. #define DRIVER_PATCHLEVEL 6
  43. #define DRIVER_IOCTLS     
  44.    [DRM_IOCTL_NR(DRM_IOCTL_DMA)]             = { r128_cce_buffers,  1, 0 }, 
  45.    [DRM_IOCTL_NR(DRM_IOCTL_R128_INIT)]       = { r128_cce_init,     1, 1 }, 
  46.    [DRM_IOCTL_NR(DRM_IOCTL_R128_CCE_START)]  = { r128_cce_start,    1, 1 }, 
  47.    [DRM_IOCTL_NR(DRM_IOCTL_R128_CCE_STOP)]   = { r128_cce_stop,     1, 1 }, 
  48.    [DRM_IOCTL_NR(DRM_IOCTL_R128_CCE_RESET)]  = { r128_cce_reset,    1, 1 }, 
  49.    [DRM_IOCTL_NR(DRM_IOCTL_R128_CCE_IDLE)]   = { r128_cce_idle,     1, 0 }, 
  50.    [DRM_IOCTL_NR(DRM_IOCTL_R128_RESET)]      = { r128_engine_reset, 1, 0 }, 
  51.    [DRM_IOCTL_NR(DRM_IOCTL_R128_FULLSCREEN)] = { r128_fullscreen,   1, 0 }, 
  52.    [DRM_IOCTL_NR(DRM_IOCTL_R128_SWAP)]       = { r128_cce_swap,     1, 0 }, 
  53.    [DRM_IOCTL_NR(DRM_IOCTL_R128_CLEAR)]      = { r128_cce_clear,    1, 0 }, 
  54.    [DRM_IOCTL_NR(DRM_IOCTL_R128_VERTEX)]     = { r128_cce_vertex,   1, 0 }, 
  55.    [DRM_IOCTL_NR(DRM_IOCTL_R128_INDICES)]    = { r128_cce_indices,  1, 0 }, 
  56.    [DRM_IOCTL_NR(DRM_IOCTL_R128_BLIT)]       = { r128_cce_blit,     1, 0 }, 
  57.    [DRM_IOCTL_NR(DRM_IOCTL_R128_DEPTH)]      = { r128_cce_depth,    1, 0 }, 
  58.    [DRM_IOCTL_NR(DRM_IOCTL_R128_STIPPLE)]    = { r128_cce_stipple,  1, 0 }, 
  59.    [DRM_IOCTL_NR(DRM_IOCTL_R128_INDIRECT)]   = { r128_cce_indirect, 1, 1 },
  60. #if 0
  61. /* GH: Count data sent to card via ring or vertex/indirect buffers.
  62.  */
  63. #define __HAVE_COUNTERS         3
  64. #define __HAVE_COUNTER6         _DRM_STAT_IRQ
  65. #define __HAVE_COUNTER7         _DRM_STAT_PRIMARY
  66. #define __HAVE_COUNTER8         _DRM_STAT_SECONDARY
  67. #endif
  68. #include "drm_agpsupport.h"
  69. #include "drm_auth.h"
  70. #include "drm_bufs.h"
  71. #include "drm_context.h"
  72. #include "drm_dma.h"
  73. #include "drm_drawable.h"
  74. #include "drm_drv.h"
  75. #ifndef MODULE
  76. /* DRM(options) is called by the kernel to parse command-line options
  77.  * passed via the boot-loader (e.g., LILO).  It calls the insmod option
  78.  * routine, drm_parse_drm.
  79.  */
  80. /* JH- We have to hand expand the string ourselves because of the cpp.  If
  81.  * anyone can think of a way that we can fit into the __setup macro without
  82.  * changing it, then please send the solution my way.
  83.  */
  84. static int __init r128_options( char *str )
  85. {
  86. DRM(parse_options)( str );
  87. return 1;
  88. }
  89. __setup( DRIVER_NAME "=", r128_options );
  90. #endif
  91. #include "drm_fops.h"
  92. #include "drm_init.h"
  93. #include "drm_ioctl.h"
  94. #include "drm_lock.h"
  95. #include "drm_memory.h"
  96. #include "drm_proc.h"
  97. #include "drm_vm.h"
  98. #include "drm_stub.h"
  99. #include "drm_scatter.h"