fedora core 6 1.2949 + vserver 2.2.0
[linux-2.6.git] / drivers / char / drm / r128_drv.h
index 26f7cf8..f1efb49 100644 (file)
@@ -1,6 +1,7 @@
 /* r128_drv.h -- Private header for r128 driver -*- linux-c -*-
  * Created: Mon Dec 13 09:51:11 1999 by faith@precisioninsight.com
- *
+ */
+/*
  * Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
  * Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
  * All rights reserved.
  *    Rickard E. (Rik) Faith <faith@valinux.com>
  *    Kevin E. Martin <martin@valinux.com>
  *    Gareth Hughes <gareth@valinux.com>
- *    Michel Dänzer <daenzerm@student.ethz.ch>
+ *    Michel Dzer <daenzerm@student.ethz.ch>
  */
 
 #ifndef __R128_DRV_H__
 #define __R128_DRV_H__
 
-#define GET_RING_HEAD(ring)            DRM_READ32(  (ring)->ring_rptr, 0 ) /* (ring)->head */
-#define SET_RING_HEAD(ring,val)                DRM_WRITE32( (ring)->ring_rptr, 0, (val) ) /* (ring)->head */
+/* General customization:
+ */
+#define DRIVER_AUTHOR          "Gareth Hughes, VA Linux Systems Inc."
+
+#define DRIVER_NAME            "r128"
+#define DRIVER_DESC            "ATI Rage 128"
+#define DRIVER_DATE            "20030725"
+
+/* Interface history:
+ *
+ * ??  - ??
+ * 2.4 - Add support for ycbcr textures (no new ioctls)
+ * 2.5 - Add FLIP ioctl, disable FULLSCREEN.
+ */
+#define DRIVER_MAJOR           2
+#define DRIVER_MINOR           5
+#define DRIVER_PATCHLEVEL      0
+
+#define GET_RING_HEAD(dev_priv)                R128_READ( R128_PM4_BUFFER_DL_RPTR )
 
 typedef struct drm_r128_freelist {
-       unsigned int age;
-       drm_buf_t *buf;
-       struct drm_r128_freelist *next;
-       struct drm_r128_freelist *prev;
+       unsigned int age;
+       drm_buf_t *buf;
+       struct drm_r128_freelist *next;
+       struct drm_r128_freelist *prev;
 } drm_r128_freelist_t;
 
 typedef struct drm_r128_ring_buffer {
@@ -50,13 +68,11 @@ typedef struct drm_r128_ring_buffer {
        int size;
        int size_l2qw;
 
-       volatile u32 *head;
        u32 tail;
        u32 tail_mask;
        int space;
 
        int high_mark;
-       drm_local_map_t *ring_rptr;
 } drm_r128_ring_buffer_t;
 
 typedef struct drm_r128_private {
@@ -67,13 +83,11 @@ typedef struct drm_r128_private {
        int cce_fifo_size;
        int cce_running;
 
-       drm_r128_freelist_t *head;
-       drm_r128_freelist_t *tail;
+       drm_r128_freelist_t *head;
+       drm_r128_freelist_t *tail;
 
        int usec_timeout;
        int is_pci;
-       unsigned long phys_pci_gart;
-       dma_addr_t bus_pci_gart;
        unsigned long cce_buffers_offset;
 
        atomic_t idle_count;
@@ -100,12 +114,11 @@ typedef struct drm_r128_private {
        u32 span_pitch_offset_c;
 
        drm_local_map_t *sarea;
-       drm_local_map_t *fb;
        drm_local_map_t *mmio;
        drm_local_map_t *cce_ring;
        drm_local_map_t *ring_rptr;
-       drm_local_map_t *buffers;
        drm_local_map_t *agp_textures;
+       drm_ati_pcigart_info gart_info;
 } drm_r128_private_t;
 
 typedef struct drm_r128_buf_priv {
@@ -113,48 +126,40 @@ typedef struct drm_r128_buf_priv {
        int prim;
        int discard;
        int dispatched;
-       drm_r128_freelist_t *list_entry;
+       drm_r128_freelist_t *list_entry;
 } drm_r128_buf_priv_t;
 
+extern drm_ioctl_desc_t r128_ioctls[];
+extern int r128_max_ioctl;
+
                                /* r128_cce.c */
-extern int r128_cce_init( DRM_IOCTL_ARGS );
-extern int r128_cce_start( DRM_IOCTL_ARGS );
-extern int r128_cce_stop( DRM_IOCTL_ARGS );
-extern int r128_cce_reset( DRM_IOCTL_ARGS );
-extern int r128_cce_idle( DRM_IOCTL_ARGS );
-extern int r128_engine_reset( DRM_IOCTL_ARGS );
-extern int r128_fullscreen( DRM_IOCTL_ARGS );
-extern int r128_cce_buffers( DRM_IOCTL_ARGS );
-extern int r128_getparam( DRM_IOCTL_ARGS );
-
-extern void r128_freelist_reset( drm_device_t *dev );
-extern drm_buf_t *r128_freelist_get( drm_device_t *dev );
-
-extern int r128_wait_ring( drm_r128_private_t *dev_priv, int n );
-
-static __inline__ void
-r128_update_ring_snapshot( drm_r128_ring_buffer_t *ring )
-{
-       ring->space = (GET_RING_HEAD( ring ) - ring->tail) * sizeof(u32);
-       if ( ring->space <= 0 )
-               ring->space += ring->size;
-}
+extern int r128_cce_init(DRM_IOCTL_ARGS);
+extern int r128_cce_start(DRM_IOCTL_ARGS);
+extern int r128_cce_stop(DRM_IOCTL_ARGS);
+extern int r128_cce_reset(DRM_IOCTL_ARGS);
+extern int r128_cce_idle(DRM_IOCTL_ARGS);
+extern int r128_engine_reset(DRM_IOCTL_ARGS);
+extern int r128_fullscreen(DRM_IOCTL_ARGS);
+extern int r128_cce_buffers(DRM_IOCTL_ARGS);
+
+extern void r128_freelist_reset(drm_device_t * dev);
+
+extern int r128_wait_ring(drm_r128_private_t * dev_priv, int n);
 
-extern int r128_do_cce_idle( drm_r128_private_t *dev_priv );
-extern int r128_do_cleanup_cce( drm_device_t *dev );
-extern int r128_do_cleanup_pageflip( drm_device_t *dev );
+extern int r128_do_cce_idle(drm_r128_private_t * dev_priv);
+extern int r128_do_cleanup_cce(drm_device_t * dev);
 
-                               /* r128_state.c */
-extern int r128_cce_clear( DRM_IOCTL_ARGS );
-extern int r128_cce_swap( DRM_IOCTL_ARGS );
-extern int r128_cce_flip( DRM_IOCTL_ARGS );
-extern int r128_cce_vertex( DRM_IOCTL_ARGS );
-extern int r128_cce_indices( DRM_IOCTL_ARGS );
-extern int r128_cce_blit( DRM_IOCTL_ARGS );
-extern int r128_cce_depth( DRM_IOCTL_ARGS );
-extern int r128_cce_stipple( DRM_IOCTL_ARGS );
-extern int r128_cce_indirect( DRM_IOCTL_ARGS );
+extern int r128_driver_vblank_wait(drm_device_t * dev, unsigned int *sequence);
 
+extern irqreturn_t r128_driver_irq_handler(DRM_IRQ_ARGS);
+extern void r128_driver_irq_preinstall(drm_device_t * dev);
+extern void r128_driver_irq_postinstall(drm_device_t * dev);
+extern void r128_driver_irq_uninstall(drm_device_t * dev);
+extern void r128_driver_lastclose(drm_device_t * dev);
+extern void r128_driver_preclose(drm_device_t * dev, DRMFILE filp);
+
+extern long r128_compat_ioctl(struct file *filp, unsigned int cmd,
+                             unsigned long arg);
 
 /* Register definitions, register access macros and drmAddMap constants
  * for Rage 128 kernel driver.
@@ -263,7 +268,6 @@ extern int r128_cce_indirect( DRM_IOCTL_ARGS );
 #      define R128_EVENT_CRTC_OFFSET           (1 << 0)
 #define R128_WINDOW_XY_OFFSET          0x1bcc
 
-
 /* CCE registers
  */
 #define R128_PM4_BUFFER_OFFSET         0x0700
@@ -279,6 +283,7 @@ extern int r128_cce_indirect( DRM_IOCTL_ARGS );
 #      define R128_PM4_64PIO_64VCBM_64INDBM    (7  << 28)
 #      define R128_PM4_64BM_64VCBM_64INDBM     (8  << 28)
 #      define R128_PM4_64PIO_64VCPIO_64INDPIO  (15 << 28)
+#      define R128_PM4_BUFFER_CNTL_NOUPDATE    (1  << 27)
 
 #define R128_PM4_BUFFER_WM_CNTL                0x0708
 #      define R128_WMA_SHIFT                   0
@@ -313,7 +318,6 @@ extern int r128_cce_indirect( DRM_IOCTL_ARGS );
 #define R128_PM4_FIFO_DATA_EVEN                0x1000
 #define R128_PM4_FIFO_DATA_ODD         0x1004
 
-
 /* CCE command packets
  */
 #define R128_CCE_PACKET0               0x00000000
@@ -391,9 +395,6 @@ do {                                                                        \
        R128_WRITE(R128_CLOCK_CNTL_DATA, (val));                        \
 } while (0)
 
-extern int R128_READ_PLL(drm_device_t *dev, int addr);
-
-
 #define CCE_PACKET0( reg, n )          (R128_CCE_PACKET0 |             \
                                         ((n) << 16) | ((reg) >> 2))
 #define CCE_PACKET1( reg0, reg1 )      (R128_CCE_PACKET1 |             \
@@ -402,6 +403,13 @@ extern int R128_READ_PLL(drm_device_t *dev, int addr);
 #define CCE_PACKET3( pkt, n )          (R128_CCE_PACKET3 |             \
                                         (pkt) | ((n) << 16))
 
+static __inline__ void r128_update_ring_snapshot(drm_r128_private_t * dev_priv)
+{
+       drm_r128_ring_buffer_t *ring = &dev_priv->ring;
+       ring->space = (GET_RING_HEAD(dev_priv) - ring->tail) * sizeof(u32);
+       if (ring->space <= 0)
+               ring->space += ring->size;
+}
 
 /* ================================================================
  * Misc helper macros
@@ -412,7 +420,7 @@ do {                                                                        \
        drm_r128_ring_buffer_t *ring = &dev_priv->ring; int i;          \
        if ( ring->space < ring->high_mark ) {                          \
                for ( i = 0 ; i < dev_priv->usec_timeout ; i++ ) {      \
-                       r128_update_ring_snapshot( ring );              \
+                       r128_update_ring_snapshot( dev_priv );          \
                        if ( ring->space >= ring->high_mark )           \
                                goto __ring_space_done;                 \
                        DRM_UDELAY(1);                          \
@@ -440,22 +448,14 @@ do {                                                                      \
        OUT_RING( R128_EVENT_CRTC_OFFSET );                             \
 } while (0)
 
-
 /* ================================================================
  * Ring control
  */
 
-#if defined(__powerpc__)
-#define r128_flush_write_combine()     (void) GET_RING_HEAD( &dev_priv->ring )
-#else
-#define r128_flush_write_combine()     DRM_WRITEMEMORYBARRIER()
-#endif
-
-
 #define R128_VERBOSE   0
 
 #define RING_LOCALS                                                    \
-       int write; unsigned int tail_mask; volatile u32 *ring;
+       int write, _nr; unsigned int tail_mask; volatile u32 *ring;
 
 #define BEGIN_RING( n ) do {                                           \
        if ( R128_VERBOSE ) {                                           \
@@ -463,9 +463,10 @@ do {                                                                       \
                           (n), __FUNCTION__ );                         \
        }                                                               \
        if ( dev_priv->ring.space <= (n) * sizeof(u32) ) {              \
+               COMMIT_RING();                                          \
                r128_wait_ring( dev_priv, (n) * sizeof(u32) );          \
        }                                                               \
-       dev_priv->ring.space -= (n) * sizeof(u32);                      \
+       _nr = n; dev_priv->ring.space -= (n) * sizeof(u32);             \
        ring = dev_priv->ring.start;                                    \
        write = dev_priv->ring.tail;                                    \
        tail_mask = dev_priv->ring.tail_mask;                           \
@@ -488,9 +489,23 @@ do {                                                                       \
                        dev_priv->ring.start,                           \
                        write * sizeof(u32) );                          \
        }                                                               \
-       r128_flush_write_combine();                                     \
-       dev_priv->ring.tail = write;                                    \
-       R128_WRITE( R128_PM4_BUFFER_DL_WPTR, write );                   \
+       if (((dev_priv->ring.tail + _nr) & tail_mask) != write) {       \
+               DRM_ERROR(                                              \
+                       "ADVANCE_RING(): mismatch: nr: %x write: %x line: %d\n",        \
+                       ((dev_priv->ring.tail + _nr) & tail_mask),      \
+                       write, __LINE__);                               \
+       } else                                                          \
+               dev_priv->ring.tail = write;                            \
+} while (0)
+
+#define COMMIT_RING() do {                                             \
+       if ( R128_VERBOSE ) {                                           \
+               DRM_INFO( "COMMIT_RING() tail=0x%06x\n",                \
+                       dev_priv->ring.tail );                          \
+       }                                                               \
+       DRM_MEMORYBARRIER();                                            \
+       R128_WRITE( R128_PM4_BUFFER_DL_WPTR, dev_priv->ring.tail );     \
+       R128_READ( R128_PM4_BUFFER_DL_WPTR );                           \
 } while (0)
 
 #define OUT_RING( x ) do {                                             \
@@ -502,4 +517,4 @@ do {                                                                        \
        write &= tail_mask;                                             \
 } while (0)
 
-#endif /* __R128_DRV_H__ */
+#endif                         /* __R128_DRV_H__ */