Commit 92910d98 authored by Dave Airlie's avatar Dave Airlie

Remove DRIVER_CTX_[CD]TOR, HAVE_KERNEL_CTX_SWITCH, DRIVER_BUF_PRIV_T, DRIVER_AGP_BUFFERS_MAP

Signed-off-by: default avatarDave Airlie <airlied@linux.ie>
parent 3e6242b5
...@@ -627,6 +627,10 @@ struct drm_driver_fn { ...@@ -627,6 +627,10 @@ struct drm_driver_fn {
void (*release)(struct drm_device *, struct file *filp); void (*release)(struct drm_device *, struct file *filp);
void (*dma_ready)(struct drm_device *); void (*dma_ready)(struct drm_device *);
int (*dma_quiescent)(struct drm_device *); int (*dma_quiescent)(struct drm_device *);
int (*context_ctor)(struct drm_device *dev, int context);
int (*context_dtor)(struct drm_device *dev, int context);
int (*kernel_context_switch)(struct drm_device *dev, int old, int new);
int (*kernel_context_switch_unlock)(struct drm_device *dev);
}; };
/** /**
* DRM device structure. * DRM device structure.
...@@ -758,7 +762,8 @@ typedef struct drm_device { ...@@ -758,7 +762,8 @@ typedef struct drm_device {
sigset_t sigmask; sigset_t sigmask;
struct drm_driver_fn fn_tbl; struct drm_driver_fn fn_tbl;
drm_local_map_t *agp_buffer_map;
int dev_priv_size;
} drm_device_t; } drm_device_t;
extern void DRM(driver_register_fns)(struct drm_device *dev); extern void DRM(driver_register_fns)(struct drm_device *dev);
......
...@@ -44,18 +44,6 @@ ...@@ -44,18 +44,6 @@
#define __HAVE_SG 0 #define __HAVE_SG 0
#endif #endif
#ifndef DRIVER_BUF_PRIV_T
#define DRIVER_BUF_PRIV_T u32
#endif
#ifndef DRIVER_AGP_BUFFERS_MAP
#if __HAVE_AGP && __HAVE_DMA
#error "You must define DRIVER_AGP_BUFFERS_MAP()"
#else
#define DRIVER_AGP_BUFFERS_MAP( dev ) NULL
#endif
#endif
/** /**
* Compute size order. Returns the exponent of the smaller power of two which * Compute size order. Returns the exponent of the smaller power of two which
* is greater or equal to given number. * is greater or equal to given number.
...@@ -473,8 +461,8 @@ int DRM(addbufs_agp)( struct inode *inode, struct file *filp, ...@@ -473,8 +461,8 @@ int DRM(addbufs_agp)( struct inode *inode, struct file *filp,
init_waitqueue_head( &buf->dma_wait ); init_waitqueue_head( &buf->dma_wait );
buf->filp = NULL; buf->filp = NULL;
buf->dev_priv_size = sizeof(DRIVER_BUF_PRIV_T); buf->dev_priv_size = dev->dev_priv_size;
buf->dev_private = DRM(alloc)( sizeof(DRIVER_BUF_PRIV_T), buf->dev_private = DRM(alloc)( buf->dev_priv_size,
DRM_MEM_BUFS ); DRM_MEM_BUFS );
if(!buf->dev_private) { if(!buf->dev_private) {
/* Set count correctly so we free the proper amount. */ /* Set count correctly so we free the proper amount. */
...@@ -698,8 +686,8 @@ int DRM(addbufs_pci)( struct inode *inode, struct file *filp, ...@@ -698,8 +686,8 @@ int DRM(addbufs_pci)( struct inode *inode, struct file *filp,
init_waitqueue_head( &buf->dma_wait ); init_waitqueue_head( &buf->dma_wait );
buf->filp = NULL; buf->filp = NULL;
buf->dev_priv_size = sizeof(DRIVER_BUF_PRIV_T); buf->dev_priv_size = dev->dev_priv_size;
buf->dev_private = DRM(alloc)( sizeof(DRIVER_BUF_PRIV_T), buf->dev_private = DRM(alloc)( dev->dev_priv_size,
DRM_MEM_BUFS ); DRM_MEM_BUFS );
if(!buf->dev_private) { if(!buf->dev_private) {
/* Set count correctly so we free the proper amount. */ /* Set count correctly so we free the proper amount. */
...@@ -882,8 +870,8 @@ int DRM(addbufs_sg)( struct inode *inode, struct file *filp, ...@@ -882,8 +870,8 @@ int DRM(addbufs_sg)( struct inode *inode, struct file *filp,
init_waitqueue_head( &buf->dma_wait ); init_waitqueue_head( &buf->dma_wait );
buf->filp = NULL; buf->filp = NULL;
buf->dev_priv_size = sizeof(DRIVER_BUF_PRIV_T); buf->dev_priv_size = dev->dev_priv_size;
buf->dev_private = DRM(alloc)( sizeof(DRIVER_BUF_PRIV_T), buf->dev_private = DRM(alloc)( dev->dev_priv_size,
DRM_MEM_BUFS ); DRM_MEM_BUFS );
if(!buf->dev_private) { if(!buf->dev_private) {
/* Set count correctly so we free the proper amount. */ /* Set count correctly so we free the proper amount. */
...@@ -1221,7 +1209,7 @@ int DRM(mapbufs)( struct inode *inode, struct file *filp, ...@@ -1221,7 +1209,7 @@ int DRM(mapbufs)( struct inode *inode, struct file *filp,
if ( request.count >= dma->buf_count ) { if ( request.count >= dma->buf_count ) {
if ( (__HAVE_AGP && (dma->flags & _DRM_DMA_USE_AGP)) || if ( (__HAVE_AGP && (dma->flags & _DRM_DMA_USE_AGP)) ||
(__HAVE_SG && (dma->flags & _DRM_DMA_USE_SG)) ) { (__HAVE_SG && (dma->flags & _DRM_DMA_USE_SG)) ) {
drm_map_t *map = DRIVER_AGP_BUFFERS_MAP( dev ); drm_map_t *map = dev->agp_buffer_map;
if ( !map ) { if ( !map ) {
retcode = -EINVAL; retcode = -EINVAL;
......
...@@ -419,10 +419,13 @@ int DRM(addctx)( struct inode *inode, struct file *filp, ...@@ -419,10 +419,13 @@ int DRM(addctx)( struct inode *inode, struct file *filp,
/* Should this return -EBUSY instead? */ /* Should this return -EBUSY instead? */
return -ENOMEM; return -ENOMEM;
} }
#ifdef DRIVER_CTX_CTOR
if ( ctx.handle != DRM_KERNEL_CONTEXT ) if ( ctx.handle != DRM_KERNEL_CONTEXT )
DRIVER_CTX_CTOR(ctx.handle); /* XXX: also pass dev ? */ {
#endif if (dev->fn_tbl.context_ctor)
dev->fn_tbl.context_ctor(dev, ctx.handle);
}
ctx_entry = DRM(alloc)( sizeof(*ctx_entry), DRM_MEM_CTXLIST ); ctx_entry = DRM(alloc)( sizeof(*ctx_entry), DRM_MEM_CTXLIST );
if ( !ctx_entry ) { if ( !ctx_entry ) {
DRM_DEBUG("out of memory\n"); DRM_DEBUG("out of memory\n");
...@@ -554,9 +557,8 @@ int DRM(rmctx)( struct inode *inode, struct file *filp, ...@@ -554,9 +557,8 @@ int DRM(rmctx)( struct inode *inode, struct file *filp,
priv->remove_auth_on_close = 1; priv->remove_auth_on_close = 1;
} }
if ( ctx.handle != DRM_KERNEL_CONTEXT ) { if ( ctx.handle != DRM_KERNEL_CONTEXT ) {
#ifdef DRIVER_CTX_DTOR if (dev->fn_tbl.context_dtor)
DRIVER_CTX_DTOR(ctx.handle); /* XXX: also pass dev ? */ dev->fn_tbl.context_dtor(dev, ctx.handle);
#endif
DRM(ctxbitmap_free)( dev, ctx.handle ); DRM(ctxbitmap_free)( dev, ctx.handle );
} }
......
...@@ -76,13 +76,6 @@ ...@@ -76,13 +76,6 @@
#ifndef __HAVE_SG #ifndef __HAVE_SG
#define __HAVE_SG 0 #define __HAVE_SG 0
#endif #endif
/* __HAVE_KERNEL_CTX_SWITCH isn't used by any of the drm modules in
* the DRI cvs tree, but it is required by the kernel tree's sparc
* driver.
*/
#ifndef __HAVE_KERNEL_CTX_SWITCH
#define __HAVE_KERNEL_CTX_SWITCH 0
#endif
#ifndef __HAVE_DRIVER_FOPS_READ #ifndef __HAVE_DRIVER_FOPS_READ
#define __HAVE_DRIVER_FOPS_READ 0 #define __HAVE_DRIVER_FOPS_READ 0
#endif #endif
...@@ -272,9 +265,6 @@ static int DRM(setup)( drm_device_t *dev ) ...@@ -272,9 +265,6 @@ static int DRM(setup)( drm_device_t *dev )
#ifdef __HAVE_COUNTER14 #ifdef __HAVE_COUNTER14
dev->types[14] = __HAVE_COUNTER14; dev->types[14] = __HAVE_COUNTER14;
#endif #endif
#ifdef __HAVE_COUNTER15
dev->types[14] = __HAVE_COUNTER14;
#endif
for ( i = 0 ; i < DRM_ARRAY_SIZE(dev->counts) ; i++ ) for ( i = 0 ; i < DRM_ARRAY_SIZE(dev->counts) ; i++ )
atomic_set( &dev->counts[i], 0 ); atomic_set( &dev->counts[i], 0 );
...@@ -559,6 +549,8 @@ static int DRM(probe)(struct pci_dev *pdev) ...@@ -559,6 +549,8 @@ static int DRM(probe)(struct pci_dev *pdev)
dev->pci_func = PCI_FUNC(pdev->devfn); dev->pci_func = PCI_FUNC(pdev->devfn);
dev->irq = pdev->irq; dev->irq = pdev->irq;
/* dev_priv_size can be changed by a driver in driver_register_fns */
dev->dev_priv_size = sizeof(u32);
DRM(driver_register_fns)(dev); DRM(driver_register_fns)(dev);
if (dev->fn_tbl.preinit) if (dev->fn_tbl.preinit)
...@@ -882,9 +874,8 @@ int DRM(release)( struct inode *inode, struct file *filp ) ...@@ -882,9 +874,8 @@ int DRM(release)( struct inode *inode, struct file *filp )
list_for_each_entry_safe( pos, n, &dev->ctxlist->head, head ) { list_for_each_entry_safe( pos, n, &dev->ctxlist->head, head ) {
if ( pos->tag == priv && if ( pos->tag == priv &&
pos->handle != DRM_KERNEL_CONTEXT ) { pos->handle != DRM_KERNEL_CONTEXT ) {
#ifdef DRIVER_CTX_DTOR if (dev->fn_tbl.context_dtor)
DRIVER_CTX_DTOR(pos->handle); dev->fn_tbl.context_dtor(dev, pos->handle);
#endif
#if __HAVE_CTX_BITMAP #if __HAVE_CTX_BITMAP
DRM(ctxbitmap_free)( dev, pos->handle ); DRM(ctxbitmap_free)( dev, pos->handle );
#endif #endif
...@@ -1083,17 +1074,15 @@ int DRM(lock)( struct inode *inode, struct file *filp, ...@@ -1083,17 +1074,15 @@ int DRM(lock)( struct inode *inode, struct file *filp,
if ( dev->fn_tbl.dma_quiescent && (lock.flags & _DRM_LOCK_QUIESCENT )) if ( dev->fn_tbl.dma_quiescent && (lock.flags & _DRM_LOCK_QUIESCENT ))
return dev->fn_tbl.dma_quiescent(dev); return dev->fn_tbl.dma_quiescent(dev);
/* __HAVE_KERNEL_CTX_SWITCH isn't used by any of the /* dev->fn_tbl.kernel_context_switch isn't used by any of the x86
* drm modules in the DRI cvs tree, but it is required * drivers but is used by the Sparc driver.
* by the Sparc driver.
*/ */
#if __HAVE_KERNEL_CTX_SWITCH
if ( dev->last_context != lock.context ) {
DRM(context_switch)(dev, dev->last_context,
lock.context);
}
#endif
if (dev->fn_tbl.kernel_context_switch &&
dev->last_context != lock.context) {
dev->fn_tbl.kernel_context_switch(dev, dev->last_context,
lock.context);
}
DRM_DEBUG( "%d %s\n", lock.context, ret ? "interrupted" : "has lock" ); DRM_DEBUG( "%d %s\n", lock.context, ret ? "interrupted" : "has lock" );
return ret; return ret;
...@@ -1128,40 +1117,24 @@ int DRM(unlock)( struct inode *inode, struct file *filp, ...@@ -1128,40 +1117,24 @@ int DRM(unlock)( struct inode *inode, struct file *filp,
atomic_inc( &dev->counts[_DRM_STAT_UNLOCKS] ); atomic_inc( &dev->counts[_DRM_STAT_UNLOCKS] );
/* __HAVE_KERNEL_CTX_SWITCH isn't used by any of the drm /* kernel_context_switch isn't used by any of the x86 drm
* modules in the DRI cvs tree, but it is required by the * modules but is required by the Sparc driver.
* Sparc driver.
*/
#if __HAVE_KERNEL_CTX_SWITCH
/* We no longer really hold it, but if we are the next
* agent to request it then we should just be able to
* take it immediately and not eat the ioctl.
*/ */
dev->lock.filp = NULL; if (dev->fn_tbl.kernel_context_switch_unlock)
{ dev->fn_tbl.kernel_context_switch_unlock(dev);
__volatile__ unsigned int *plock = &dev->lock.hw_lock->lock; else {
unsigned int old, new, prev, ctx; DRM(lock_transfer)( dev, &dev->lock.hw_lock->lock,
DRM_KERNEL_CONTEXT );
ctx = lock.context;
do {
old = *plock;
new = ctx;
prev = cmpxchg(plock, old, new);
} while (prev != old);
}
wake_up_interruptible(&dev->lock.lock_queue);
#else
DRM(lock_transfer)( dev, &dev->lock.hw_lock->lock,
DRM_KERNEL_CONTEXT );
#if __HAVE_DMA_SCHEDULE #if __HAVE_DMA_SCHEDULE
DRM(dma_schedule)( dev, 1 ); DRM(dma_schedule)( dev, 1 );
#endif #endif
if ( DRM(lock_free)( dev, &dev->lock.hw_lock->lock, if ( DRM(lock_free)( dev, &dev->lock.hw_lock->lock,
DRM_KERNEL_CONTEXT ) ) { DRM_KERNEL_CONTEXT ) ) {
DRM_ERROR( "\n" ); DRM_ERROR( "\n" );
}
} }
#endif /* !__HAVE_KERNEL_CTX_SWITCH */
unblock_all_signals(); unblock_all_signals();
return 0; return 0;
......
...@@ -8,9 +8,5 @@ ...@@ -8,9 +8,5 @@
*/ */
#define DRM(x) ffb_##x #define DRM(x) ffb_##x
/* General customization:
*/
#define __HAVE_KERNEL_CTX_SWITCH 1
#endif #endif
...@@ -570,10 +570,29 @@ static void ffb_driver_postcleanup(drm_device_t *dev) ...@@ -570,10 +570,29 @@ static void ffb_driver_postcleanup(drm_device_t *dev)
if (ffb_position != NULL) kfree(ffb_position); if (ffb_position != NULL) kfree(ffb_position);
} }
static int ffb_driver_kernel_context_switch_unlock(struct drm_device *dev)
{
dev->lock.filp = 0;
{
__volatile__ unsigned int *plock = &dev->lock.hw_lock->lock;
unsigned int old, new, prev, ctx;
ctx = lock.context;
do {
old = *plock;
new = ctx;
prev = cmpxchg(plock, old, new);
} while (prev != old);
}
wake_up_interruptible(&dev->lock.lock_queue);
}
static void ffb_driver_register_fns(drm_device_t *dev) static void ffb_driver_register_fns(drm_device_t *dev)
{ {
dev->fn_tbl.release = ffb_driver_release; dev->fn_tbl.release = ffb_driver_release;
dev->fn_tbl.presetup = ffb_driver_presetup; dev->fn_tbl.presetup = ffb_driver_presetup;
dev->fn_tbl.pretakedown = ffb_driver_pretakedown; dev->fn_tbl.pretakedown = ffb_driver_pretakedown;
dev->fn_tbl.postcleanup = ffb_driver_postcleanup; dev->fn_tbl.postcleanup = ffb_driver_postcleanup;
dev->fn_tbl.kernel_context_switch = ffb_context_switch;
dev->fn_tbl.kernel_context_switch_unlock = ffb_driver_kernel_context_switch_unlock;
} }
...@@ -91,8 +91,4 @@ ...@@ -91,8 +91,4 @@
#define __HAVE_IRQ 1 #define __HAVE_IRQ 1
#define __HAVE_IRQ_BH 1 #define __HAVE_IRQ_BH 1
#define DRIVER_AGP_BUFFERS_MAP( dev ) \
((drm_gamma_private_t *)((dev)->dev_private))->buffers
#endif /* __GAMMA_H__ */ #endif /* __GAMMA_H__ */
...@@ -661,9 +661,9 @@ static int gamma_do_init_dma( drm_device_t *dev, drm_gamma_init_t *init ) ...@@ -661,9 +661,9 @@ static int gamma_do_init_dma( drm_device_t *dev, drm_gamma_init_t *init )
buf = dma->buflist[GLINT_DRI_BUF_COUNT]; buf = dma->buflist[GLINT_DRI_BUF_COUNT];
} else { } else {
DRM_FIND_MAP( dev_priv->buffers, init->buffers_offset ); DRM_FIND_MAP( dev->agp_buffer_map, init->buffers_offset );
DRM_IOREMAP( dev_priv->buffers, dev ); DRM_IOREMAP( dev->agp_buffer_map, dev );
buf = dma->buflist[GLINT_DRI_BUF_COUNT]; buf = dma->buflist[GLINT_DRI_BUF_COUNT];
pgt = buf->address; pgt = buf->address;
...@@ -699,10 +699,9 @@ int gamma_do_cleanup_dma( drm_device_t *dev ) ...@@ -699,10 +699,9 @@ int gamma_do_cleanup_dma( drm_device_t *dev )
#endif #endif
if ( dev->dev_private ) { if ( dev->dev_private ) {
drm_gamma_private_t *dev_priv = dev->dev_private;
if ( dev_priv->buffers != NULL ) if ( dev->agp_buffer_map != NULL )
DRM_IOREMAPFREE( dev_priv->buffers, dev ); DRM_IOREMAPFREE( dev->agp_buffer_map, dev );
DRM(free)( dev->dev_private, sizeof(drm_gamma_private_t), DRM(free)( dev->dev_private, sizeof(drm_gamma_private_t),
DRM_MEM_DRIVER ); DRM_MEM_DRIVER );
......
...@@ -35,7 +35,6 @@ ...@@ -35,7 +35,6 @@
typedef struct drm_gamma_private { typedef struct drm_gamma_private {
drm_gamma_sarea_t *sarea_priv; drm_gamma_sarea_t *sarea_priv;
drm_map_t *sarea; drm_map_t *sarea;
drm_map_t *buffers;
drm_map_t *mmio0; drm_map_t *mmio0;
drm_map_t *mmio1; drm_map_t *mmio1;
drm_map_t *mmio2; drm_map_t *mmio2;
......
...@@ -97,12 +97,4 @@ ...@@ -97,12 +97,4 @@
/* XXX: Add vblank support? */ /* XXX: Add vblank support? */
#define __HAVE_IRQ 0 #define __HAVE_IRQ 0
/* Buffer customization:
*/
#define DRIVER_BUF_PRIV_T drm_i810_buf_priv_t
#define DRIVER_AGP_BUFFERS_MAP( dev ) \
((drm_i810_private_t *)((dev)->dev_private))->buffer_map
#endif #endif
...@@ -371,8 +371,8 @@ static int i810_dma_initialize(drm_device_t *dev, ...@@ -371,8 +371,8 @@ static int i810_dma_initialize(drm_device_t *dev,
DRM_ERROR("can not find mmio map!\n"); DRM_ERROR("can not find mmio map!\n");
return -EINVAL; return -EINVAL;
} }
DRM_FIND_MAP( dev_priv->buffer_map, init->buffers_offset ); DRM_FIND_MAP( dev->agp_buffer_map, init->buffers_offset );
if (!dev_priv->buffer_map) { if (!dev->agp_buffer_map) {
dev->dev_private = (void *)dev_priv; dev->dev_private = (void *)dev_priv;
i810_dma_cleanup(dev); i810_dma_cleanup(dev);
DRM_ERROR("can not find dma buffer map!\n"); DRM_ERROR("can not find dma buffer map!\n");
...@@ -1407,6 +1407,7 @@ static int i810_driver_dma_quiescent(drm_device_t *dev) ...@@ -1407,6 +1407,7 @@ static int i810_driver_dma_quiescent(drm_device_t *dev)
void i810_driver_register_fns(drm_device_t *dev) void i810_driver_register_fns(drm_device_t *dev)
{ {
dev->dev_priv_size = sizeof(drm_i810_buf_priv_t);
dev->fn_tbl.pretakedown = i810_driver_pretakedown; dev->fn_tbl.pretakedown = i810_driver_pretakedown;
dev->fn_tbl.release = i810_driver_release; dev->fn_tbl.release = i810_driver_release;
dev->fn_tbl.dma_quiescent = i810_driver_dma_quiescent; dev->fn_tbl.dma_quiescent = i810_driver_dma_quiescent;
......
...@@ -53,7 +53,6 @@ typedef struct _drm_i810_ring_buffer{ ...@@ -53,7 +53,6 @@ typedef struct _drm_i810_ring_buffer{
typedef struct drm_i810_private { typedef struct drm_i810_private {
drm_map_t *sarea_map; drm_map_t *sarea_map;
drm_map_t *buffer_map;
drm_map_t *mmio_map; drm_map_t *mmio_map;
drm_i810_sarea_t *sarea_priv; drm_i810_sarea_t *sarea_priv;
......
...@@ -104,13 +104,4 @@ ...@@ -104,13 +104,4 @@
#define __HAVE_IRQ 0 #define __HAVE_IRQ 0
#endif #endif
/* Buffer customization:
*/
#define DRIVER_BUF_PRIV_T drm_i830_buf_priv_t
#define DRIVER_AGP_BUFFERS_MAP( dev ) \
((drm_i830_private_t *)((dev)->dev_private))->buffer_map
#endif #endif
...@@ -378,8 +378,8 @@ static int i830_dma_initialize(drm_device_t *dev, ...@@ -378,8 +378,8 @@ static int i830_dma_initialize(drm_device_t *dev,
DRM_ERROR("can not find mmio map!\n"); DRM_ERROR("can not find mmio map!\n");
return -EINVAL; return -EINVAL;
} }
DRM_FIND_MAP( dev_priv->buffer_map, init->buffers_offset ); DRM_FIND_MAP( dev->agp_buffer_map, init->buffers_offset );
if(!dev_priv->buffer_map) { if(!dev->agp_buffer_map) {
dev->dev_private = (void *)dev_priv; dev->dev_private = (void *)dev_priv;
i830_dma_cleanup(dev); i830_dma_cleanup(dev);
DRM_ERROR("can not find dma buffer map!\n"); DRM_ERROR("can not find dma buffer map!\n");
...@@ -1602,6 +1602,7 @@ static int i830_driver_dma_quiescent(drm_device_t *dev) ...@@ -1602,6 +1602,7 @@ static int i830_driver_dma_quiescent(drm_device_t *dev)
void i830_driver_register_fns(drm_device_t *dev) void i830_driver_register_fns(drm_device_t *dev)
{ {
dev->dev_priv_size = sizeof(drm_i830_buf_priv_t);
dev->fn_tbl.pretakedown = i830_driver_pretakedown; dev->fn_tbl.pretakedown = i830_driver_pretakedown;
dev->fn_tbl.release = i830_driver_release; dev->fn_tbl.release = i830_driver_release;
dev->fn_tbl.dma_quiescent = i830_driver_dma_quiescent; dev->fn_tbl.dma_quiescent = i830_driver_dma_quiescent;
......
...@@ -53,7 +53,6 @@ typedef struct _drm_i830_ring_buffer{ ...@@ -53,7 +53,6 @@ typedef struct _drm_i830_ring_buffer{
typedef struct drm_i830_private { typedef struct drm_i830_private {
drm_map_t *sarea_map; drm_map_t *sarea_map;
drm_map_t *buffer_map;
drm_map_t *mmio_map; drm_map_t *mmio_map;
drm_i830_sarea_t *sarea_priv; drm_i830_sarea_t *sarea_priv;
......
...@@ -76,11 +76,4 @@ ...@@ -76,11 +76,4 @@
#define __HAVE_VBL_IRQ 1 #define __HAVE_VBL_IRQ 1
#define __HAVE_SHARED_IRQ 1 #define __HAVE_SHARED_IRQ 1
/* Buffer customization:
*/
#define DRIVER_BUF_PRIV_T drm_mga_buf_priv_t
#define DRIVER_AGP_BUFFERS_MAP( dev ) \
((drm_mga_private_t *)((dev)->dev_private))->buffers
#endif #endif
...@@ -533,8 +533,8 @@ static int mga_do_init_dma( drm_device_t *dev, drm_mga_init_t *init ) ...@@ -533,8 +533,8 @@ static int mga_do_init_dma( drm_device_t *dev, drm_mga_init_t *init )
mga_do_cleanup_dma( dev ); mga_do_cleanup_dma( dev );
return DRM_ERR(EINVAL); return DRM_ERR(EINVAL);
} }
DRM_FIND_MAP( dev_priv->buffers, init->buffers_offset ); DRM_FIND_MAP( dev->agp_buffer_map, init->buffers_offset );
if(!dev_priv->buffers) { if(!dev->agp_buffer_map) {
DRM_ERROR( "failed to find dma buffer region!\n" ); DRM_ERROR( "failed to find dma buffer region!\n" );
/* Assign dev_private so we can do cleanup. */ /* Assign dev_private so we can do cleanup. */
dev->dev_private = (void *)dev_priv; dev->dev_private = (void *)dev_priv;
...@@ -548,11 +548,11 @@ static int mga_do_init_dma( drm_device_t *dev, drm_mga_init_t *init ) ...@@ -548,11 +548,11 @@ static int mga_do_init_dma( drm_device_t *dev, drm_mga_init_t *init )
DRM_IOREMAP( dev_priv->warp, dev ); DRM_IOREMAP( dev_priv->warp, dev );
DRM_IOREMAP( dev_priv->primary, dev ); DRM_IOREMAP( dev_priv->primary, dev );
DRM_IOREMAP( dev_priv->buffers, dev ); DRM_IOREMAP( dev->agp_buffer_map, dev );
if(!dev_priv->warp->handle || if(!dev_priv->warp->handle ||
!dev_priv->primary->handle || !dev_priv->primary->handle ||
!dev_priv->buffers->handle ) { !dev->agp_buffer_map->handle ) {
DRM_ERROR( "failed to ioremap agp regions!\n" ); DRM_ERROR( "failed to ioremap agp regions!\n" );
/* Assign dev_private so we can do cleanup. */ /* Assign dev_private so we can do cleanup. */
dev->dev_private = (void *)dev_priv; dev->dev_private = (void *)dev_priv;
...@@ -646,8 +646,8 @@ int mga_do_cleanup_dma( drm_device_t *dev ) ...@@ -646,8 +646,8 @@ int mga_do_cleanup_dma( drm_device_t *dev )
DRM_IOREMAPFREE( dev_priv->warp, dev ); DRM_IOREMAPFREE( dev_priv->warp, dev );
if ( dev_priv->primary != NULL ) if ( dev_priv->primary != NULL )
DRM_IOREMAPFREE( dev_priv->primary, dev ); DRM_IOREMAPFREE( dev_priv->primary, dev );
if ( dev_priv->buffers != NULL ) if ( dev->agp_buffer_map != NULL )
DRM_IOREMAPFREE( dev_priv->buffers, dev ); DRM_IOREMAPFREE( dev->agp_buffer_map, dev );
if ( dev_priv->head != NULL ) { if ( dev_priv->head != NULL ) {
mga_freelist_cleanup( dev ); mga_freelist_cleanup( dev );
......
...@@ -86,11 +86,4 @@ ...@@ -86,11 +86,4 @@
#define __HAVE_VBL_IRQ 1 #define __HAVE_VBL_IRQ 1
#define __HAVE_SHARED_IRQ 1 #define __HAVE_SHARED_IRQ 1
/* Buffer customization:
*/
#define DRIVER_BUF_PRIV_T drm_r128_buf_priv_t
#define DRIVER_AGP_BUFFERS_MAP( dev ) \
((drm_r128_private_t *)((dev)->dev_private))->buffers
#endif #endif
...@@ -488,8 +488,8 @@ static int r128_do_init_cce( drm_device_t *dev, drm_r128_init_t *init ) ...@@ -488,8 +488,8 @@ static int r128_do_init_cce( drm_device_t *dev, drm_r128_init_t *init )
r128_do_cleanup_cce( dev ); r128_do_cleanup_cce( dev );
return DRM_ERR(EINVAL); return DRM_ERR(EINVAL);
} }
DRM_FIND_MAP( dev_priv->buffers, init->buffers_offset ); DRM_FIND_MAP( dev->agp_buffer_map, init->buffers_offset );
if(!dev_priv->buffers) { if(!dev->agp_buffer_map) {
DRM_ERROR("could not find dma buffer region!\n"); DRM_ERROR("could not find dma buffer region!\n");
dev->dev_private = (void *)dev_priv; dev->dev_private = (void *)dev_priv;
r128_do_cleanup_cce( dev ); r128_do_cleanup_cce( dev );
...@@ -515,10 +515,10 @@ static int r128_do_init_cce( drm_device_t *dev, drm_r128_init_t *init ) ...@@ -515,10 +515,10 @@ static int r128_do_init_cce( drm_device_t *dev, drm_r128_init_t *init )
if ( !dev_priv->is_pci ) { if ( !dev_priv->is_pci ) {
DRM_IOREMAP( dev_priv->cce_ring, dev ); DRM_IOREMAP( dev_priv->cce_ring, dev );
DRM_IOREMAP( dev_priv->ring_rptr, dev ); DRM_IOREMAP( dev_priv->ring_rptr, dev );
DRM_IOREMAP( dev_priv->buffers, dev ); DRM_IOREMAP( dev->agp_buffer_map, dev );
if(!dev_priv->cce_ring->handle || if(!dev_priv->cce_ring->handle ||
!dev_priv->ring_rptr->handle || !dev_priv->ring_rptr->handle ||
!dev_priv->buffers->handle) { !dev->agp_buffer_map->handle) {
DRM_ERROR("Could not ioremap agp regions!\n"); DRM_ERROR("Could not ioremap agp regions!\n");
dev->dev_private = (void *)dev_priv; dev->dev_private = (void *)dev_priv;
r128_do_cleanup_cce( dev ); r128_do_cleanup_cce( dev );
...@@ -531,7 +531,7 @@ static int r128_do_init_cce( drm_device_t *dev, drm_r128_init_t *init ) ...@@ -531,7 +531,7 @@ static int r128_do_init_cce( drm_device_t *dev, drm_r128_init_t *init )
(void *)dev_priv->cce_ring->offset; (void *)dev_priv->cce_ring->offset;
dev_priv->ring_rptr->handle = dev_priv->ring_rptr->handle =
(void *)dev_priv->ring_rptr->offset; (void *)dev_priv->ring_rptr->offset;
dev_priv->buffers->handle = (void *)dev_priv->buffers->offset; dev->agp_buffer_map->handle = (void *)dev->agp_buffer_map->offset;
} }
#if __REALLY_HAVE_AGP #if __REALLY_HAVE_AGP
...@@ -604,8 +604,8 @@ int r128_do_cleanup_cce( drm_device_t *dev ) ...@@ -604,8 +604,8 @@ int r128_do_cleanup_cce( drm_device_t *dev )
DRM_IOREMAPFREE( dev_priv->cce_ring, dev ); DRM_IOREMAPFREE( dev_priv->cce_ring, dev );
if ( dev_priv->ring_rptr != NULL ) if ( dev_priv->ring_rptr != NULL )
DRM_IOREMAPFREE( dev_priv->ring_rptr, dev ); DRM_IOREMAPFREE( dev_priv->ring_rptr, dev );
if ( dev_priv->buffers != NULL ) if ( dev->agp_buffer_map != NULL )
DRM_IOREMAPFREE( dev_priv->buffers, dev ); DRM_IOREMAPFREE( dev->agp_buffer_map, dev );
} else } else
#endif #endif
{ {
......
...@@ -100,7 +100,6 @@ typedef struct drm_r128_private { ...@@ -100,7 +100,6 @@ typedef struct drm_r128_private {
drm_local_map_t *mmio; drm_local_map_t *mmio;
drm_local_map_t *cce_ring; drm_local_map_t *cce_ring;
drm_local_map_t *ring_rptr; drm_local_map_t *ring_rptr;
drm_local_map_t *buffers;
drm_local_map_t *agp_textures; drm_local_map_t *agp_textures;
} drm_r128_private_t; } drm_r128_private_t;
......
...@@ -667,7 +667,7 @@ static void r128_cce_dispatch_indirect( drm_device_t *dev, ...@@ -667,7 +667,7 @@ static void r128_cce_dispatch_indirect( drm_device_t *dev,
*/ */
if ( dwords & 1 ) { if ( dwords & 1 ) {
u32 *data = (u32 *) u32 *data = (u32 *)
((char *)dev_priv->buffers->handle ((char *)dev->agp_buffer_map->handle
+ buf->offset + start); + buf->offset + start);
data[dwords++] = cpu_to_le32( R128_CCE_PACKET2 ); data[dwords++] = cpu_to_le32( R128_CCE_PACKET2 );
} }
...@@ -713,7 +713,7 @@ static void r128_cce_dispatch_indices( drm_device_t *dev, ...@@ -713,7 +713,7 @@ static void r128_cce_dispatch_indices( drm_device_t *dev,
drm_r128_buf_priv_t *buf_priv = buf->dev_private; drm_r128_buf_priv_t *buf_priv = buf->dev_private;
drm_r128_sarea_t *sarea_priv = dev_priv->sarea_priv; drm_r128_sarea_t *sarea_priv = dev_priv->sarea_priv;
int format = sarea_priv->vc_format; int format = sarea_priv->vc_format;
int offset = dev_priv->buffers->offset - dev_priv->cce_buffers_offset; int offset = dev->agp_buffer_map->offset - dev_priv->cce_buffers_offset;
int prim = buf_priv->prim; int prim = buf_priv->prim;
u32 *data; u32 *data;
int dwords; int dwords;
...@@ -733,7 +733,7 @@ static void r128_cce_dispatch_indices( drm_device_t *dev, ...@@ -733,7 +733,7 @@ static void r128_cce_dispatch_indices( drm_device_t *dev,
dwords = (end - start + 3) / sizeof(u32); dwords = (end - start + 3) / sizeof(u32);
data = (u32 *)((char *)dev_priv->buffers->handle data = (u32 *)((char *)dev->agp_buffer_map->handle
+ buf->offset + start); + buf->offset + start);
data[0] = cpu_to_le32( CCE_PACKET3( R128_3D_RNDR_GEN_INDX_PRIM, data[0] = cpu_to_le32( CCE_PACKET3( R128_3D_RNDR_GEN_INDX_PRIM,
...@@ -857,7 +857,7 @@ static int r128_cce_dispatch_blit( DRMFILE filp, ...@@ -857,7 +857,7 @@ static int r128_cce_dispatch_blit( DRMFILE filp,
dwords = (blit->width * blit->height) >> dword_shift; dwords = (blit->width * blit->height) >> dword_shift;
data = (u32 *)((char *)dev_priv->buffers->handle + buf->offset); data = (u32 *)((char *)dev->agp_buffer_map->handle + buf->offset);
data[0] = cpu_to_le32( CCE_PACKET3( R128_CNTL_HOSTDATA_BLT, dwords + 6 ) ); data[0] = cpu_to_le32( CCE_PACKET3( R128_CNTL_HOSTDATA_BLT, dwords + 6 ) );
data[1] = cpu_to_le32( (R128_GMC_DST_PITCH_OFFSET_CNTL | data[1] = cpu_to_le32( (R128_GMC_DST_PITCH_OFFSET_CNTL |
...@@ -1712,6 +1712,7 @@ static void r128_driver_pretakedown(drm_device_t *dev) ...@@ -1712,6 +1712,7 @@ static void r128_driver_pretakedown(drm_device_t *dev)
void r128_driver_register_fns(drm_device_t *dev) void r128_driver_register_fns(drm_device_t *dev)
{ {
dev->dev_priv_size = sizeof(drm_r128_buf_priv_t);
dev->fn_tbl.prerelease = r128_driver_prerelease; dev->fn_tbl.prerelease = r128_driver_prerelease;
dev->fn_tbl.pretakedown = r128_driver_pretakedown; dev->fn_tbl.pretakedown = r128_driver_pretakedown;
} }
...@@ -125,12 +125,4 @@ ...@@ -125,12 +125,4 @@
#define __HAVE_VBL_IRQ 1 #define __HAVE_VBL_IRQ 1
#define __HAVE_SHARED_IRQ 1 #define __HAVE_SHARED_IRQ 1
/* Buffer customization:
*/
#define DRIVER_BUF_PRIV_T drm_radeon_buf_priv_t
#define DRIVER_AGP_BUFFERS_MAP( dev ) \
((drm_radeon_private_t *)((dev)->dev_private))->buffers
#endif #endif
...@@ -1139,8 +1139,8 @@ static int radeon_do_init_cp( drm_device_t *dev, drm_radeon_init_t *init ) ...@@ -1139,8 +1139,8 @@ static int radeon_do_init_cp( drm_device_t *dev, drm_radeon_init_t *init )
radeon_do_cleanup_cp(dev); radeon_do_cleanup_cp(dev);
return DRM_ERR(EINVAL); return DRM_ERR(EINVAL);
} }
DRM_FIND_MAP( dev_priv->buffers, init->buffers_offset ); DRM_FIND_MAP( dev->agp_buffer_map, init->buffers_offset );
if(!dev_priv->buffers) { if(!dev->agp_buffer_map) {
DRM_ERROR("could not find dma buffer region!\n"); DRM_ERROR("could not find dma buffer region!\n");
dev->dev_private = (void *)dev_priv; dev->dev_private = (void *)dev_priv;
radeon_do_cleanup_cp(dev); radeon_do_cleanup_cp(dev);
...@@ -1165,10 +1165,10 @@ static int radeon_do_init_cp( drm_device_t *dev, drm_radeon_init_t *init ) ...@@ -1165,10 +1165,10 @@ static int radeon_do_init_cp( drm_device_t *dev, drm_radeon_init_t *init )
if ( !dev_priv->is_pci ) { if ( !dev_priv->is_pci ) {
DRM_IOREMAP( dev_priv->cp_ring, dev ); DRM_IOREMAP( dev_priv->cp_ring, dev );
DRM_IOREMAP( dev_priv->ring_rptr, dev ); DRM_IOREMAP( dev_priv->ring_rptr, dev );
DRM_IOREMAP( dev_priv->buffers, dev ); DRM_IOREMAP( dev->agp_buffer_map, dev );
if(!dev_priv->cp_ring->handle || if(!dev_priv->cp_ring->handle ||
!dev_priv->ring_rptr->handle || !dev_priv->ring_rptr->handle ||
!dev_priv->buffers->handle) { !dev->agp_buffer_map->handle) {
DRM_ERROR("could not find ioremap agp regions!\n"); DRM_ERROR("could not find ioremap agp regions!\n");
dev->dev_private = (void *)dev_priv; dev->dev_private = (void *)dev_priv;
radeon_do_cleanup_cp(dev); radeon_do_cleanup_cp(dev);
...@@ -1181,14 +1181,14 @@ static int radeon_do_init_cp( drm_device_t *dev, drm_radeon_init_t *init ) ...@@ -1181,14 +1181,14 @@ static int radeon_do_init_cp( drm_device_t *dev, drm_radeon_init_t *init )
(void *)dev_priv->cp_ring->offset; (void *)dev_priv->cp_ring->offset;
dev_priv->ring_rptr->handle = dev_priv->ring_rptr->handle =
(void *)dev_priv->ring_rptr->offset; (void *)dev_priv->ring_rptr->offset;
dev_priv->buffers->handle = (void *)dev_priv->buffers->offset; dev->agp_buffer_map->handle = (void *)dev->agp_buffer_map->offset;
DRM_DEBUG( "dev_priv->cp_ring->handle %p\n", DRM_DEBUG( "dev_priv->cp_ring->handle %p\n",
dev_priv->cp_ring->handle ); dev_priv->cp_ring->handle );
DRM_DEBUG( "dev_priv->ring_rptr->handle %p\n", DRM_DEBUG( "dev_priv->ring_rptr->handle %p\n",
dev_priv->ring_rptr->handle ); dev_priv->ring_rptr->handle );
DRM_DEBUG( "dev_priv->buffers->handle %p\n", DRM_DEBUG( "dev->agp_buffer_map->handle %p\n",
dev_priv->buffers->handle ); dev->agp_buffer_map->handle );
} }
dev_priv->fb_location = ( RADEON_READ( RADEON_MC_FB_LOCATION ) dev_priv->fb_location = ( RADEON_READ( RADEON_MC_FB_LOCATION )
...@@ -1213,12 +1213,12 @@ static int radeon_do_init_cp( drm_device_t *dev, drm_radeon_init_t *init ) ...@@ -1213,12 +1213,12 @@ static int radeon_do_init_cp( drm_device_t *dev, drm_radeon_init_t *init )
#if __REALLY_HAVE_AGP #if __REALLY_HAVE_AGP
if ( !dev_priv->is_pci ) if ( !dev_priv->is_pci )
dev_priv->gart_buffers_offset = (dev_priv->buffers->offset dev_priv->gart_buffers_offset = (dev->agp_buffer_map->offset
- dev->agp->base - dev->agp->base
+ dev_priv->gart_vm_start); + dev_priv->gart_vm_start);
else else
#endif #endif
dev_priv->gart_buffers_offset = (dev_priv->buffers->offset dev_priv->gart_buffers_offset = (dev->agp_buffer_map->offset
- dev->sg->handle - dev->sg->handle
+ dev_priv->gart_vm_start); + dev_priv->gart_vm_start);
...@@ -1292,8 +1292,8 @@ int radeon_do_cleanup_cp( drm_device_t *dev ) ...@@ -1292,8 +1292,8 @@ int radeon_do_cleanup_cp( drm_device_t *dev )
DRM_IOREMAPFREE( dev_priv->cp_ring, dev ); DRM_IOREMAPFREE( dev_priv->cp_ring, dev );
if ( dev_priv->ring_rptr != NULL ) if ( dev_priv->ring_rptr != NULL )
DRM_IOREMAPFREE( dev_priv->ring_rptr, dev ); DRM_IOREMAPFREE( dev_priv->ring_rptr, dev );
if ( dev_priv->buffers != NULL ) if ( dev->agp_buffer_map != NULL )
DRM_IOREMAPFREE( dev_priv->buffers, dev ); DRM_IOREMAPFREE( dev->agp_buffer_map, dev );
} else } else
#endif #endif
{ {
......
...@@ -138,7 +138,6 @@ typedef struct drm_radeon_private { ...@@ -138,7 +138,6 @@ typedef struct drm_radeon_private {
drm_local_map_t *mmio; drm_local_map_t *mmio;
drm_local_map_t *cp_ring; drm_local_map_t *cp_ring;
drm_local_map_t *ring_rptr; drm_local_map_t *ring_rptr;
drm_local_map_t *buffers;
drm_local_map_t *gart_textures; drm_local_map_t *gart_textures;
struct mem_block *gart_heap; struct mem_block *gart_heap;
......
...@@ -1247,7 +1247,7 @@ static void radeon_cp_dispatch_indirect( drm_device_t *dev, ...@@ -1247,7 +1247,7 @@ static void radeon_cp_dispatch_indirect( drm_device_t *dev,
*/ */
if ( dwords & 1 ) { if ( dwords & 1 ) {
u32 *data = (u32 *) u32 *data = (u32 *)
((char *)dev_priv->buffers->handle ((char *)dev->agp_buffer_map->handle
+ buf->offset + start); + buf->offset + start);
data[dwords++] = RADEON_CP_PACKET2; data[dwords++] = RADEON_CP_PACKET2;
} }
...@@ -1301,7 +1301,7 @@ static void radeon_cp_dispatch_indices( drm_device_t *dev, ...@@ -1301,7 +1301,7 @@ static void radeon_cp_dispatch_indices( drm_device_t *dev,
dwords = (prim->finish - prim->start + 3) / sizeof(u32); dwords = (prim->finish - prim->start + 3) / sizeof(u32);
data = (u32 *)((char *)dev_priv->buffers->handle + data = (u32 *)((char *)dev->agp_buffer_map->handle +
elt_buf->offset + prim->start); elt_buf->offset + prim->start);
data[0] = CP_PACKET3( RADEON_3D_RNDR_GEN_INDX_PRIM, dwords-2 ); data[0] = CP_PACKET3( RADEON_3D_RNDR_GEN_INDX_PRIM, dwords-2 );
...@@ -1445,7 +1445,7 @@ static int radeon_cp_dispatch_texture( DRMFILE filp, ...@@ -1445,7 +1445,7 @@ static int radeon_cp_dispatch_texture( DRMFILE filp,
/* Dispatch the indirect buffer. /* Dispatch the indirect buffer.
*/ */
buffer = (u32*)((char*)dev_priv->buffers->handle + buf->offset); buffer = (u32*)((char*)dev->agp_buffer_map->handle + buf->offset);
dwords = size / 4; dwords = size / 4;
buffer[0] = CP_PACKET3( RADEON_CNTL_HOSTDATA_BLT, dwords + 6 ); buffer[0] = CP_PACKET3( RADEON_CNTL_HOSTDATA_BLT, dwords + 6 );
buffer[1] = (RADEON_GMC_DST_PITCH_OFFSET_CNTL | buffer[1] = (RADEON_GMC_DST_PITCH_OFFSET_CNTL |
...@@ -2548,6 +2548,12 @@ int radeon_cp_setparam( DRM_IOCTL_ARGS ) { ...@@ -2548,6 +2548,12 @@ int radeon_cp_setparam( DRM_IOCTL_ARGS ) {
return 0; return 0;
} }
/* When a client dies:
* - Check for and clean up flipped page state
* - Free any alloced GART memory.
*
* DRM infrastructure takes care of reclaiming dma buffers.
*/
static void radeon_driver_prerelease(drm_device_t *dev, DRMFILE filp) static void radeon_driver_prerelease(drm_device_t *dev, DRMFILE filp)
{ {
if ( dev->dev_private ) { if ( dev->dev_private ) {
...@@ -2576,6 +2582,7 @@ static void radeon_driver_open_helper(drm_device_t *dev, drm_file_t *filp_priv) ...@@ -2576,6 +2582,7 @@ static void radeon_driver_open_helper(drm_device_t *dev, drm_file_t *filp_priv)
void radeon_driver_register_fns(struct drm_device *dev) void radeon_driver_register_fns(struct drm_device *dev)
{ {
dev->dev_priv_size = sizeof(drm_radeon_buf_priv_t);
dev->fn_tbl.prerelease = radeon_driver_prerelease; dev->fn_tbl.prerelease = radeon_driver_prerelease;
dev->fn_tbl.pretakedown = radeon_driver_pretakedown; dev->fn_tbl.pretakedown = radeon_driver_pretakedown;
dev->fn_tbl.open_helper = radeon_driver_open_helper; dev->fn_tbl.open_helper = radeon_driver_open_helper;
......
...@@ -64,15 +64,4 @@ ...@@ -64,15 +64,4 @@
#define __HAVE_COUNTERS 5 #define __HAVE_COUNTERS 5
/* Buffer customization:
*/
#define DRIVER_AGP_BUFFERS_MAP( dev ) \
((drm_sis_private_t *)((dev)->dev_private))->buffers
extern int sis_init_context(int context);
extern int sis_final_context(int context);
#define DRIVER_CTX_CTOR sis_init_context
#define DRIVER_CTX_DTOR sis_final_context
#endif #endif
...@@ -31,8 +31,6 @@ ...@@ -31,8 +31,6 @@
#include "sis_ds.h" #include "sis_ds.h"
typedef struct drm_sis_private { typedef struct drm_sis_private {
drm_map_t *buffers;
memHeap_t *AGPHeap; memHeap_t *AGPHeap;
memHeap_t *FBHeap; memHeap_t *FBHeap;
} drm_sis_private_t; } drm_sis_private_t;
......
...@@ -326,7 +326,7 @@ int sis_ioctl_agp_free( DRM_IOCTL_ARGS ) ...@@ -326,7 +326,7 @@ int sis_ioctl_agp_free( DRM_IOCTL_ARGS )
return 0; return 0;
} }
int sis_init_context(int context) int sis_init_context(struct drm_device *dev, int context)
{ {
int i; int i;
...@@ -358,7 +358,7 @@ int sis_init_context(int context) ...@@ -358,7 +358,7 @@ int sis_init_context(int context)
return 1; return 1;
} }
int sis_final_context(int context) int sis_final_context(struct drm_device *dev, int context)
{ {
int i; int i;
...@@ -407,4 +407,6 @@ int sis_final_context(int context) ...@@ -407,4 +407,6 @@ int sis_final_context(int context)
void DRM(driver_register_fns)(drm_device_t *dev) void DRM(driver_register_fns)(drm_device_t *dev)
{ {
dev->fn_tbl.context_ctor = sis_init_context;
dev->fn_tbl.context_dtor = sis_final_context;
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment