Merged bsd-1-0-1
parent
2fbd4bf018
commit
d399dbcd56
|
@ -49,7 +49,13 @@
|
||||||
#include <sys/sysctl.h>
|
#include <sys/sysctl.h>
|
||||||
#include <sys/select.h>
|
#include <sys/select.h>
|
||||||
#include <sys/bus.h>
|
#include <sys/bus.h>
|
||||||
|
#if __FreeBSD_version >= 500005
|
||||||
#include <sys/taskqueue.h>
|
#include <sys/taskqueue.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if __FreeBSD_version >= 500006
|
||||||
|
#define DRM_AGP
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef DRM_AGP
|
#ifdef DRM_AGP
|
||||||
#include <pci/agpvar.h>
|
#include <pci/agpvar.h>
|
||||||
|
@ -71,9 +77,11 @@ typedef u_int32_t spinlock_t;
|
||||||
static __inline u_int32_t
|
static __inline u_int32_t
|
||||||
test_and_set_bit(int b, volatile u_int32_t *p)
|
test_and_set_bit(int b, volatile u_int32_t *p)
|
||||||
{
|
{
|
||||||
|
int s = splhigh();
|
||||||
u_int32_t m = 1<<b;
|
u_int32_t m = 1<<b;
|
||||||
u_int32_t r = *p & m;
|
u_int32_t r = *p & m;
|
||||||
*p |= m;
|
*p |= m;
|
||||||
|
splx(s);
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -101,9 +109,9 @@ find_first_zero_bit(volatile u_int32_t *p, int max)
|
||||||
int b;
|
int b;
|
||||||
|
|
||||||
for (b = 0; b < max; b += 32) {
|
for (b = 0; b < max; b += 32) {
|
||||||
if (p[b >> 5]) {
|
if (p[b >> 5] != ~0) {
|
||||||
for (;;) {
|
for (;;) {
|
||||||
if (p[b >> 5] & (1 << (b & 0x1f)))
|
if ((p[b >> 5] & (1 << (b & 0x1f))) == 0)
|
||||||
return b;
|
return b;
|
||||||
b++;
|
b++;
|
||||||
}
|
}
|
||||||
|
@ -117,10 +125,15 @@ find_first_zero_bit(volatile u_int32_t *p, int max)
|
||||||
#define memset(p, v, s) bzero(p, s)
|
#define memset(p, v, s) bzero(p, s)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Software interrupts for DMA pipe feeding. The FreeBSD kernel apis
|
* Fake out the module macros for versions of FreeBSD where they don't
|
||||||
* are severely lacking here.
|
* exist.
|
||||||
*/
|
*/
|
||||||
#define SWI_DRI (SWI_VM+2)
|
#if __FreeBSD_version < 500002
|
||||||
|
|
||||||
|
#define MODULE_VERSION(a,b) struct __hack
|
||||||
|
#define MODULE_DEPEND(a,b,c,d,e) struct __hack
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
#define DRM_DEBUG_CODE 2 /* Include debugging code (if > 1, then
|
#define DRM_DEBUG_CODE 2 /* Include debugging code (if > 1, then
|
||||||
also include looping detection. */
|
also include looping detection. */
|
||||||
|
@ -504,7 +517,9 @@ typedef struct drm_device {
|
||||||
int last_checked; /* Last context checked for DMA */
|
int last_checked; /* Last context checked for DMA */
|
||||||
int last_context; /* Last current context */
|
int last_context; /* Last current context */
|
||||||
int last_switch; /* Time at last context switch */
|
int last_switch; /* Time at last context switch */
|
||||||
|
#if __FreeBSD_version >= 500005
|
||||||
struct task task;
|
struct task task;
|
||||||
|
#endif
|
||||||
struct timespec ctx_start;
|
struct timespec ctx_start;
|
||||||
struct timespec lck_start;
|
struct timespec lck_start;
|
||||||
#if DRM_DMA_HISTOGRAM
|
#if DRM_DMA_HISTOGRAM
|
||||||
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
# $FreeBSD$
|
||||||
|
|
||||||
|
KMOD = mga
|
||||||
|
SRCS = mga_drv.c mga_context.c mga_state.c mga_bufs.c mga_dma.c
|
||||||
|
SRCS += device_if.h bus_if.h pci_if.h
|
||||||
|
CFLAGS += ${DEBUG_FLAGS} -I..
|
||||||
|
KERN = /usr/src/sys
|
||||||
|
KMODDEPS = drm
|
||||||
|
|
||||||
|
@:
|
||||||
|
ln -sf /sys @
|
||||||
|
|
||||||
|
machine:
|
||||||
|
ln -sf /sys/i386/include machine
|
||||||
|
|
||||||
|
.include <bsd.kmod.mk>
|
|
@ -4,7 +4,7 @@ KMOD = tdfx
|
||||||
SRCS = tdfx_drv.c tdfx_context.c
|
SRCS = tdfx_drv.c tdfx_context.c
|
||||||
SRCS += device_if.h bus_if.h pci_if.h
|
SRCS += device_if.h bus_if.h pci_if.h
|
||||||
CFLAGS += ${DEBUG_FLAGS} -I..
|
CFLAGS += ${DEBUG_FLAGS} -I..
|
||||||
KERN = /usr/src/sys
|
KMODDEPS = drm
|
||||||
|
|
||||||
@:
|
@:
|
||||||
ln -sf /sys @
|
ln -sf /sys @
|
||||||
|
@ -12,4 +12,4 @@ KERN = /usr/src/sys
|
||||||
machine:
|
machine:
|
||||||
ln -sf /sys/i386/include machine
|
ln -sf /sys/i386/include machine
|
||||||
|
|
||||||
.include "/usr/src/sys/conf/kmod.mk"
|
.include <bsd.kmod.mk>
|
||||||
|
|
11
bsd/drm.h
11
bsd/drm.h
|
@ -1,8 +1,8 @@
|
||||||
/* drm.h -- Header for Direct Rendering Manager -*- c -*-
|
/* drm.h -- Header for Direct Rendering Manager -*- c -*-
|
||||||
* Created: Mon Jan 4 10:05:05 1999 by faith@precisioninsight.com
|
* Created: Mon Jan 4 10:05:05 1999 by faith@precisioninsight.com
|
||||||
* Revised: Fri Aug 20 13:08:18 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,11 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/drm.h,v 1.46 1999/08/20 20:00:53 faith Exp $
|
* Authors:
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/drm.h,v 1.1 1999/09/25 14:37:58 dawes Exp $
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
|
*
|
||||||
|
* Acknowledgements:
|
||||||
|
* Dec 1999, Richard Henderson <rth@twiddle.net>, move to generic cmpxchg.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -66,7 +69,7 @@ typedef struct drm_clip_rect {
|
||||||
unsigned short y2;
|
unsigned short y2;
|
||||||
} drm_clip_rect_t;
|
} drm_clip_rect_t;
|
||||||
|
|
||||||
/* Seperate include files for the i810/mga specific structures */
|
/* Seperate include files for the i810/mga/r128 specific structures */
|
||||||
#include "mga_drm.h"
|
#include "mga_drm.h"
|
||||||
#include "i810_drm.h"
|
#include "i810_drm.h"
|
||||||
#include "r128_drm.h"
|
#include "r128_drm.h"
|
||||||
|
|
|
@ -3,10 +3,9 @@
|
||||||
KMOD = drm
|
KMOD = drm
|
||||||
SRCS = init.c memory.c auth.c context.c drawable.c bufs.c \
|
SRCS = init.c memory.c auth.c context.c drawable.c bufs.c \
|
||||||
lists.c lock.c ioctl.c fops.c vm.c dma.c sysctl.c \
|
lists.c lock.c ioctl.c fops.c vm.c dma.c sysctl.c \
|
||||||
agpsupport.c
|
agpsupport.c ctxbitmap.c
|
||||||
SRCS += device_if.h bus_if.h pci_if.h
|
SRCS += device_if.h bus_if.h pci_if.h
|
||||||
CFLAGS += ${DEBUG_FLAGS} -I.. # -DDRM_AGP
|
CFLAGS += ${DEBUG_FLAGS} -I..
|
||||||
KERN = /usr/src/sys
|
|
||||||
|
|
||||||
@:
|
@:
|
||||||
ln -sf /sys @
|
ln -sf /sys @
|
||||||
|
@ -14,4 +13,4 @@ KERN = /usr/src/sys
|
||||||
machine:
|
machine:
|
||||||
ln -sf /sys/i386/include machine
|
ln -sf /sys/i386/include machine
|
||||||
|
|
||||||
.include "/usr/src/sys/conf/kmod.mk"
|
.include <bsd.kmod.mk>
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
* Created: Mon Dec 13 09:56:45 1999 by faith@precisioninsight.com
|
* Created: Mon Dec 13 09:56:45 1999 by faith@precisioninsight.com
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -23,9 +24,7 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* Author: Rickard E. (Rik) Faith <faith@precisioninsight.com>
|
* Author: Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
*
|
|
||||||
* $XFree86$
|
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -238,8 +237,8 @@ drm_agp_head_t *drm_agp_init(void)
|
||||||
if (agp_available) {
|
if (agp_available) {
|
||||||
if (!(head = drm_alloc(sizeof(*head), DRM_MEM_AGPLISTS)))
|
if (!(head = drm_alloc(sizeof(*head), DRM_MEM_AGPLISTS)))
|
||||||
return NULL;
|
return NULL;
|
||||||
head->agpdev = agpdev;
|
|
||||||
memset((void *)head, 0, sizeof(*head));
|
memset((void *)head, 0, sizeof(*head));
|
||||||
|
head->agpdev = agpdev;
|
||||||
agp_get_info(agpdev, &head->info);
|
agp_get_info(agpdev, &head->info);
|
||||||
head->memory = NULL;
|
head->memory = NULL;
|
||||||
#if 0 /* bogus */
|
#if 0 /* bogus */
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* auth.c -- IOCTLs for authentication -*- c -*-
|
/* auth.c -- IOCTLs for authentication -*- c -*-
|
||||||
* Created: Tue Feb 2 08:37:54 1999 by faith@precisioninsight.com
|
* Created: Tue Feb 2 08:37:54 1999 by faith@precisioninsight.com
|
||||||
* Revised: Fri Aug 20 11:31:48 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,8 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/auth.c,v 1.4 1999/08/30 13:05:00 faith Exp $
|
* Authors:
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/auth.c,v 1.1 1999/09/25 14:37:57 dawes Exp $
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* bufs.c -- IOCTLs to manage buffers -*- c -*-
|
/* bufs.c -- IOCTLs to manage buffers -*- c -*-
|
||||||
* Created: Tue Feb 2 08:37:54 1999 by faith@precisioninsight.com
|
* Created: Tue Feb 2 08:37:54 1999 by faith@precisioninsight.com
|
||||||
* Revised: Fri Aug 20 22:48:10 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,8 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/bufs.c,v 1.8 1999/08/30 13:05:00 faith Exp $
|
* Authors:
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/bufs.c,v 1.1 1999/09/25 14:37:57 dawes Exp $
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* context.c -- IOCTLs for contexts and DMA queues -*- c -*-
|
/* context.c -- IOCTLs for contexts and DMA queues -*- c -*-
|
||||||
* Created: Tue Feb 2 08:37:54 1999 by faith@precisioninsight.com
|
* Created: Tue Feb 2 08:37:54 1999 by faith@precisioninsight.com
|
||||||
* Revised: Fri Aug 20 11:32:09 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,8 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/context.c,v 1.5 1999/08/30 13:05:00 faith Exp $
|
* Authors:
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/context.c,v 1.1 1999/09/25 14:37:58 dawes Exp $
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,85 @@
|
||||||
|
/* ctxbitmap.c -- Context bitmap management
|
||||||
|
* Created: Thu Jan 6 03:56:42 2000 by jhartmann@precisioninsight.com
|
||||||
|
*
|
||||||
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
|
* All Rights Reserved.
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
* copy of this software and associated documentation files (the "Software"),
|
||||||
|
* to deal in the Software without restriction, including without limitation
|
||||||
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
|
* and/or sell copies of the Software, and to permit persons to whom the
|
||||||
|
* Software is furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice (including the next
|
||||||
|
* paragraph) shall be included in all copies or substantial portions of the
|
||||||
|
* Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
|
* PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
|
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||||
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
|
* DEALINGS IN THE SOFTWARE.
|
||||||
|
*
|
||||||
|
* Author: Jeff Hartmann <jhartmann@valinux.com>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define __NO_VERSION__
|
||||||
|
#include "drmP.h"
|
||||||
|
|
||||||
|
void drm_ctxbitmap_free(drm_device_t *dev, int ctx_handle)
|
||||||
|
{
|
||||||
|
if (ctx_handle < 0) goto failed;
|
||||||
|
|
||||||
|
if (ctx_handle < DRM_MAX_CTXBITMAP) {
|
||||||
|
clear_bit(ctx_handle, dev->ctx_bitmap);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
failed:
|
||||||
|
DRM_ERROR("Attempt to free invalid context handle: %d\n",
|
||||||
|
ctx_handle);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
int drm_ctxbitmap_next(drm_device_t *dev)
|
||||||
|
{
|
||||||
|
int bit;
|
||||||
|
|
||||||
|
bit = find_first_zero_bit(dev->ctx_bitmap, DRM_MAX_CTXBITMAP);
|
||||||
|
if (bit < DRM_MAX_CTXBITMAP) {
|
||||||
|
set_bit(bit, dev->ctx_bitmap);
|
||||||
|
DRM_DEBUG("drm_ctxbitmap_next bit : %d\n", bit);
|
||||||
|
return bit;
|
||||||
|
}
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
int drm_ctxbitmap_init(drm_device_t *dev)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
int temp;
|
||||||
|
|
||||||
|
dev->ctx_bitmap = (u_int32_t *) drm_alloc(PAGE_SIZE,
|
||||||
|
DRM_MEM_CTXBITMAP);
|
||||||
|
if(dev->ctx_bitmap == NULL) {
|
||||||
|
return -ENOMEM;
|
||||||
|
}
|
||||||
|
memset((void *) dev->ctx_bitmap, 0, PAGE_SIZE);
|
||||||
|
for(i = 0; i < DRM_RESERVED_CONTEXTS; i++) {
|
||||||
|
temp = drm_ctxbitmap_next(dev);
|
||||||
|
DRM_DEBUG("drm_ctxbitmap_init : %d\n", temp);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void drm_ctxbitmap_cleanup(drm_device_t *dev)
|
||||||
|
{
|
||||||
|
drm_free((void *)dev->ctx_bitmap, PAGE_SIZE,
|
||||||
|
DRM_MEM_CTXBITMAP);
|
||||||
|
}
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* dma.c -- DMA IOCTL and function support -*- c -*-
|
/* dma.c -- DMA IOCTL and function support -*- c -*-
|
||||||
* Created: Fri Mar 19 14:30:16 1999 by faith@precisioninsight.com
|
* Created: Fri Mar 19 14:30:16 1999 by faith@precisioninsight.com
|
||||||
* Revised: Thu Sep 16 12:55:39 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,8 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/dma.c,v 1.7 1999/09/16 16:56:18 faith Exp $
|
* Authors:
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/dma.c,v 1.1 1999/09/25 14:37:58 dawes Exp $
|
* Rickard E. (Rik) Faith <faith@valinuxa.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -62,14 +62,23 @@ void drm_dma_takedown(drm_device_t *dev)
|
||||||
dma->bufs[i].page_order,
|
dma->bufs[i].page_order,
|
||||||
DRM_MEM_DMA);
|
DRM_MEM_DMA);
|
||||||
}
|
}
|
||||||
drm_free(dma->bufs[i].buflist,
|
|
||||||
dma->buf_count
|
|
||||||
* sizeof(*dma->bufs[0].buflist),
|
|
||||||
DRM_MEM_BUFS);
|
|
||||||
drm_free(dma->bufs[i].seglist,
|
drm_free(dma->bufs[i].seglist,
|
||||||
dma->buf_count
|
dma->bufs[i].seg_count
|
||||||
* sizeof(*dma->bufs[0].seglist),
|
* sizeof(*dma->bufs[0].seglist),
|
||||||
DRM_MEM_SEGS);
|
DRM_MEM_SEGS);
|
||||||
|
}
|
||||||
|
if(dma->bufs[i].buf_count) {
|
||||||
|
for(j = 0; j < dma->bufs[i].buf_count; j++) {
|
||||||
|
if(dma->bufs[i].buflist[j].dev_private) {
|
||||||
|
drm_free(dma->bufs[i].buflist[j].dev_private,
|
||||||
|
dma->bufs[i].buflist[j].dev_priv_size,
|
||||||
|
DRM_MEM_BUFS);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
drm_free(dma->bufs[i].buflist,
|
||||||
|
dma->bufs[i].buf_count *
|
||||||
|
sizeof(*dma->bufs[0].buflist),
|
||||||
|
DRM_MEM_BUFS);
|
||||||
drm_freelist_destroy(&dma->bufs[i].freelist);
|
drm_freelist_destroy(&dma->bufs[i].freelist);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* drawable.c -- IOCTLs for drawables -*- c -*-
|
/* drawable.c -- IOCTLs for drawables -*- c -*-
|
||||||
* Created: Tue Feb 2 08:37:54 1999 by faith@precisioninsight.com
|
* Created: Tue Feb 2 08:37:54 1999 by faith@precisioninsight.com
|
||||||
* Revised: Fri Aug 20 09:27:03 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,8 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/drawable.c,v 1.3 1999/08/30 13:05:00 faith Exp $
|
* Authors:
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/drawable.c,v 1.1 1999/09/25 14:37:58 dawes Exp $
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* fops.c -- File operations for DRM -*- c -*-
|
/* fops.c -- File operations for DRM -*- c -*-
|
||||||
* Created: Mon Jan 4 08:58:31 1999 by faith@precisioninsight.com
|
* Created: Mon Jan 4 08:58:31 1999 by faith@precisioninsight.com
|
||||||
* Revised: Tue Oct 12 08:48:59 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,9 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/fops.c,v 1.3 1999/08/20 15:36:45 faith Exp $
|
* Authors:
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/fops.c,v 1.1 1999/09/25 14:37:59 dawes Exp $
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
|
* Daryll Strauss <daryll@valinux.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* init.c -- Setup/Cleanup for DRM -*- c -*-
|
/* init.c -- Setup/Cleanup for DRM -*- c -*-
|
||||||
* Created: Mon Jan 4 08:58:31 1999 by faith@precisioninsight.com
|
* Created: Mon Jan 4 08:58:31 1999 by faith@precisioninsight.com
|
||||||
* Revised: Fri Aug 20 09:27:02 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,8 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/init.c,v 1.3 1999/08/20 15:07:01 faith Exp $
|
* Authors:
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/init.c,v 1.1 1999/09/25 14:38:01 dawes Exp $
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -98,4 +98,3 @@ void drm_parse_options(char *s)
|
||||||
drm_parse_option(h); /* parse */
|
drm_parse_option(h); /* parse */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* ioctl.c -- IOCTL processing for DRM -*- c -*-
|
/* ioctl.c -- IOCTL processing for DRM -*- c -*-
|
||||||
* Created: Fri Jan 8 09:01:26 1999 by faith@precisioninsight.com
|
* Created: Fri Jan 8 09:01:26 1999 by faith@precisioninsight.com
|
||||||
* Revised: Fri Aug 20 09:27:02 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,8 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/ioctl.c,v 1.3 1999/08/30 13:05:00 faith Exp $
|
* Authors:
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/ioctl.c,v 1.1 1999/09/25 14:38:01 dawes Exp $
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* lists.c -- Buffer list handling routines -*- c -*-
|
/* lists.c -- Buffer list handling routines -*- c -*-
|
||||||
* Created: Mon Apr 19 20:54:22 1999 by faith@precisioninsight.com
|
* Created: Mon Apr 19 20:54:22 1999 by faith@precisioninsight.com
|
||||||
* Revised: Fri Aug 20 09:27:01 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,8 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/lists.c,v 1.3 1999/08/20 15:07:02 faith Exp $
|
* Authors:
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/lists.c,v 1.1 1999/09/25 14:38:01 dawes Exp $
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* lock.c -- IOCTLs for locking -*- c -*-
|
/* lock.c -- IOCTLs for locking -*- c -*-
|
||||||
* Created: Tue Feb 2 08:37:54 1999 by faith@precisioninsight.com
|
* Created: Tue Feb 2 08:37:54 1999 by faith@precisioninsight.com
|
||||||
* Revised: Tue Oct 12 08:51:06 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,8 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/lock.c,v 1.5 1999/08/30 13:05:00 faith Exp $
|
* Authors:
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/lock.c,v 1.1 1999/09/25 14:38:01 dawes Exp $
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* memory.c -- Memory management wrappers for DRM -*- c -*-
|
/* memory.c -- Memory management wrappers for DRM -*- c -*-
|
||||||
* Created: Thu Feb 4 14:00:34 1999 by faith@precisioninsight.com
|
* Created: Thu Feb 4 14:00:34 1999 by faith@precisioninsight.com
|
||||||
* Revised: Fri Aug 20 13:04:33 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,8 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/memory.c,v 1.4 1999/08/20 20:00:53 faith Exp $
|
* Authors:
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/memory.c,v 1.1 1999/09/25 14:38:02 dawes Exp $
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* vm.c -- Memory mapping for DRM -*- c -*-
|
/* vm.c -- Memory mapping for DRM -*- c -*-
|
||||||
* Created: Mon Jan 4 08:58:31 1999 by faith@precisioninsight.com
|
* Created: Mon Jan 4 08:58:31 1999 by faith@precisioninsight.com
|
||||||
* Revised: Fri Aug 20 22:48:11 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,8 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/vm.c,v 1.7 1999/08/21 02:48:34 faith Exp $
|
* Authors:
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/vm.c,v 1.1 1999/09/25 14:38:02 dawes Exp $
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
25
bsd/drmP.h
25
bsd/drmP.h
|
@ -49,7 +49,13 @@
|
||||||
#include <sys/sysctl.h>
|
#include <sys/sysctl.h>
|
||||||
#include <sys/select.h>
|
#include <sys/select.h>
|
||||||
#include <sys/bus.h>
|
#include <sys/bus.h>
|
||||||
|
#if __FreeBSD_version >= 500005
|
||||||
#include <sys/taskqueue.h>
|
#include <sys/taskqueue.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if __FreeBSD_version >= 500006
|
||||||
|
#define DRM_AGP
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef DRM_AGP
|
#ifdef DRM_AGP
|
||||||
#include <pci/agpvar.h>
|
#include <pci/agpvar.h>
|
||||||
|
@ -71,9 +77,11 @@ typedef u_int32_t spinlock_t;
|
||||||
static __inline u_int32_t
|
static __inline u_int32_t
|
||||||
test_and_set_bit(int b, volatile u_int32_t *p)
|
test_and_set_bit(int b, volatile u_int32_t *p)
|
||||||
{
|
{
|
||||||
|
int s = splhigh();
|
||||||
u_int32_t m = 1<<b;
|
u_int32_t m = 1<<b;
|
||||||
u_int32_t r = *p & m;
|
u_int32_t r = *p & m;
|
||||||
*p |= m;
|
*p |= m;
|
||||||
|
splx(s);
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -101,9 +109,9 @@ find_first_zero_bit(volatile u_int32_t *p, int max)
|
||||||
int b;
|
int b;
|
||||||
|
|
||||||
for (b = 0; b < max; b += 32) {
|
for (b = 0; b < max; b += 32) {
|
||||||
if (p[b >> 5]) {
|
if (p[b >> 5] != ~0) {
|
||||||
for (;;) {
|
for (;;) {
|
||||||
if (p[b >> 5] & (1 << (b & 0x1f)))
|
if ((p[b >> 5] & (1 << (b & 0x1f))) == 0)
|
||||||
return b;
|
return b;
|
||||||
b++;
|
b++;
|
||||||
}
|
}
|
||||||
|
@ -117,10 +125,15 @@ find_first_zero_bit(volatile u_int32_t *p, int max)
|
||||||
#define memset(p, v, s) bzero(p, s)
|
#define memset(p, v, s) bzero(p, s)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Software interrupts for DMA pipe feeding. The FreeBSD kernel apis
|
* Fake out the module macros for versions of FreeBSD where they don't
|
||||||
* are severely lacking here.
|
* exist.
|
||||||
*/
|
*/
|
||||||
#define SWI_DRI (SWI_VM+2)
|
#if __FreeBSD_version < 500002
|
||||||
|
|
||||||
|
#define MODULE_VERSION(a,b) struct __hack
|
||||||
|
#define MODULE_DEPEND(a,b,c,d,e) struct __hack
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
#define DRM_DEBUG_CODE 2 /* Include debugging code (if > 1, then
|
#define DRM_DEBUG_CODE 2 /* Include debugging code (if > 1, then
|
||||||
also include looping detection. */
|
also include looping detection. */
|
||||||
|
@ -504,7 +517,9 @@ typedef struct drm_device {
|
||||||
int last_checked; /* Last context checked for DMA */
|
int last_checked; /* Last context checked for DMA */
|
||||||
int last_context; /* Last current context */
|
int last_context; /* Last current context */
|
||||||
int last_switch; /* Time at last context switch */
|
int last_switch; /* Time at last context switch */
|
||||||
|
#if __FreeBSD_version >= 500005
|
||||||
struct task task;
|
struct task task;
|
||||||
|
#endif
|
||||||
struct timespec ctx_start;
|
struct timespec ctx_start;
|
||||||
struct timespec lck_start;
|
struct timespec lck_start;
|
||||||
#if DRM_DMA_HISTOGRAM
|
#if DRM_DMA_HISTOGRAM
|
||||||
|
|
|
@ -4,7 +4,7 @@ KMOD = gamma
|
||||||
SRCS = gamma_drv.c gamma_dma.c
|
SRCS = gamma_drv.c gamma_dma.c
|
||||||
SRCS += device_if.h bus_if.h pci_if.h
|
SRCS += device_if.h bus_if.h pci_if.h
|
||||||
CFLAGS += ${DEBUG_FLAGS} -I..
|
CFLAGS += ${DEBUG_FLAGS} -I..
|
||||||
KERN = /usr/src/sys
|
KMODDEPS = drm
|
||||||
|
|
||||||
@:
|
@:
|
||||||
ln -sf /sys @
|
ln -sf /sys @
|
||||||
|
@ -12,4 +12,4 @@ KERN = /usr/src/sys
|
||||||
machine:
|
machine:
|
||||||
ln -sf /sys/i386/include machine
|
ln -sf /sys/i386/include machine
|
||||||
|
|
||||||
.include "/usr/src/sys/conf/kmod.mk"
|
.include <bsd.kmod.mk>
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* gamma_dma.c -- DMA support for GMX 2000 -*- c -*-
|
/* gamma_dma.c -- DMA support for GMX 2000 -*- c -*-
|
||||||
* Created: Fri Mar 19 14:30:16 1999 by faith@precisioninsight.com
|
* Created: Fri Mar 19 14:30:16 1999 by faith@precisioninsight.com
|
||||||
* Revised: Thu Sep 16 12:55:37 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,8 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/gamma_dma.c,v 1.9 1999/09/16 16:56:18 faith Exp $
|
* Authors:
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/gamma_dma.c,v 1.1 1999/09/25 14:38:00 dawes Exp $
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -92,13 +92,31 @@ static __inline void gamma_dma_dispatch(drm_device_t *dev,
|
||||||
GAMMA_WRITE(GAMMA_DMACOUNT, length / 4);
|
GAMMA_WRITE(GAMMA_DMACOUNT, length / 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
static __inline void gamma_dma_quiescent(drm_device_t *dev)
|
static __inline void gamma_dma_quiescent_single(drm_device_t *dev)
|
||||||
{
|
{
|
||||||
while (GAMMA_READ(GAMMA_DMACOUNT))
|
while (GAMMA_READ(GAMMA_DMACOUNT))
|
||||||
;
|
;
|
||||||
while (GAMMA_READ(GAMMA_INFIFOSPACE) < 3)
|
while (GAMMA_READ(GAMMA_INFIFOSPACE) < 3)
|
||||||
;
|
;
|
||||||
|
|
||||||
|
GAMMA_WRITE(GAMMA_FILTERMODE, 1 << 10);
|
||||||
|
GAMMA_WRITE(GAMMA_SYNC, 0);
|
||||||
|
|
||||||
|
do {
|
||||||
|
while (!GAMMA_READ(GAMMA_OUTFIFOWORDS))
|
||||||
|
;
|
||||||
|
} while (GAMMA_READ(GAMMA_OUTPUTFIFO) != GAMMA_SYNC_TAG);
|
||||||
|
}
|
||||||
|
|
||||||
|
static __inline void gamma_dma_quiescent_dual(drm_device_t *dev)
|
||||||
|
{
|
||||||
|
while (GAMMA_READ(GAMMA_DMACOUNT))
|
||||||
|
;
|
||||||
|
while (GAMMA_READ(GAMMA_INFIFOSPACE) < 3)
|
||||||
|
;
|
||||||
|
|
||||||
GAMMA_WRITE(GAMMA_BROADCASTMASK, 3);
|
GAMMA_WRITE(GAMMA_BROADCASTMASK, 3);
|
||||||
|
|
||||||
GAMMA_WRITE(GAMMA_FILTERMODE, 1 << 10);
|
GAMMA_WRITE(GAMMA_FILTERMODE, 1 << 10);
|
||||||
GAMMA_WRITE(GAMMA_SYNC, 0);
|
GAMMA_WRITE(GAMMA_SYNC, 0);
|
||||||
|
|
||||||
|
@ -108,7 +126,6 @@ static __inline void gamma_dma_quiescent(drm_device_t *dev)
|
||||||
;
|
;
|
||||||
} while (GAMMA_READ(GAMMA_OUTPUTFIFO) != GAMMA_SYNC_TAG);
|
} while (GAMMA_READ(GAMMA_OUTPUTFIFO) != GAMMA_SYNC_TAG);
|
||||||
|
|
||||||
|
|
||||||
/* Read from second MX */
|
/* Read from second MX */
|
||||||
do {
|
do {
|
||||||
while (!GAMMA_READ(GAMMA_OUTFIFOWORDS + 0x10000))
|
while (!GAMMA_READ(GAMMA_OUTFIFOWORDS + 0x10000))
|
||||||
|
@ -784,8 +801,13 @@ int gamma_lock(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
if (lock.flags & _DRM_LOCK_READY)
|
if (lock.flags & _DRM_LOCK_READY)
|
||||||
gamma_dma_ready(dev);
|
gamma_dma_ready(dev);
|
||||||
if (lock.flags & _DRM_LOCK_QUIESCENT)
|
if (lock.flags & _DRM_LOCK_QUIESCENT) {
|
||||||
gamma_dma_quiescent(dev);
|
if (gamma_found() == 1) {
|
||||||
|
gamma_dma_quiescent_single(dev);
|
||||||
|
} else {
|
||||||
|
gamma_dma_quiescent_dual(dev);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
DRM_DEBUG("%d %s\n", lock.context, ret ? "interrupted" : "has lock");
|
DRM_DEBUG("%d %s\n", lock.context, ret ? "interrupted" : "has lock");
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* gamma.c -- 3dlabs GMX 2000 driver -*- c -*-
|
/* gamma.c -- 3dlabs GMX 2000 driver -*- c -*-
|
||||||
* Created: Mon Jan 4 08:58:31 1999 by faith@precisioninsight.com
|
* Created: Mon Jan 4 08:58:31 1999 by faith@precisioninsight.com
|
||||||
* Revised: Tue Oct 12 08:51:36 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,8 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/gamma_drv.c,v 1.17 1999/08/30 13:05:00 faith Exp $
|
* Authors:
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/gamma_drv.c,v 1.1 1999/09/25 14:38:00 dawes Exp $
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -36,6 +36,16 @@
|
||||||
|
|
||||||
MODULE_DEPEND(gamma, drm, 1, 1, 1);
|
MODULE_DEPEND(gamma, drm, 1, 1, 1);
|
||||||
|
|
||||||
|
#ifndef PCI_DEVICE_ID_3DLABS_GAMMA
|
||||||
|
#define PCI_DEVICE_ID_3DLABS_GAMMA 0x0008
|
||||||
|
#endif
|
||||||
|
#ifndef PCI_DEVICE_ID_3DLABS_MX
|
||||||
|
#define PCI_DEVICE_ID_3DLABS_MX 0x0006
|
||||||
|
#endif
|
||||||
|
#ifndef PCI_VENDOR_ID_3DLABS
|
||||||
|
#define PCI_VENDOR_ID_3DLABS 0x3d3d
|
||||||
|
#endif
|
||||||
|
|
||||||
static int gamma_init(device_t nbdev);
|
static int gamma_init(device_t nbdev);
|
||||||
static void gamma_cleanup(device_t nbdev);
|
static void gamma_cleanup(device_t nbdev);
|
||||||
|
|
||||||
|
@ -47,6 +57,10 @@ static int gamma_probe(device_t dev)
|
||||||
case 0x00083d3d:
|
case 0x00083d3d:
|
||||||
s = "3D Labs Gamma graphics accelerator";
|
s = "3D Labs Gamma graphics accelerator";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 0x00063d3d:
|
||||||
|
s = "3D Labs MX graphics accelerator";
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (s) {
|
if (s) {
|
||||||
|
@ -92,10 +106,10 @@ DRIVER_MODULE(if_gamma, pci, gamma_driver, gamma_devclass, 0, 0);
|
||||||
|
|
||||||
#define GAMMA_NAME "gamma"
|
#define GAMMA_NAME "gamma"
|
||||||
#define GAMMA_DESC "3dlabs GMX 2000"
|
#define GAMMA_DESC "3dlabs GMX 2000"
|
||||||
#define GAMMA_DATE "19990830"
|
#define GAMMA_DATE "20000606"
|
||||||
#define GAMMA_MAJOR 0
|
#define GAMMA_MAJOR 1
|
||||||
#define GAMMA_MINOR 0
|
#define GAMMA_MINOR 0
|
||||||
#define GAMMA_PATCHLEVEL 5
|
#define GAMMA_PATCHLEVEL 0
|
||||||
|
|
||||||
#define CDEV_MAJOR 200
|
#define CDEV_MAJOR 200
|
||||||
|
|
||||||
|
@ -150,6 +164,8 @@ static drm_ioctl_desc_t gamma_ioctls[] = {
|
||||||
};
|
};
|
||||||
#define GAMMA_IOCTL_COUNT DRM_ARRAY_SIZE(gamma_ioctls)
|
#define GAMMA_IOCTL_COUNT DRM_ARRAY_SIZE(gamma_ioctls)
|
||||||
|
|
||||||
|
static int devices = 0;
|
||||||
|
|
||||||
static int gamma_setup(drm_device_t *dev)
|
static int gamma_setup(drm_device_t *dev)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
@ -285,6 +301,10 @@ gamma_takedown(drm_device_t *dev)
|
||||||
- PAGE_SHIFT,
|
- PAGE_SHIFT,
|
||||||
DRM_MEM_SAREA);
|
DRM_MEM_SAREA);
|
||||||
break;
|
break;
|
||||||
|
case _DRM_AGP:
|
||||||
|
/* Do nothing here, because this is all
|
||||||
|
handled in the AGP/GART driver. */
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
drm_free(map, sizeof(*map), DRM_MEM_MAPS);
|
drm_free(map, sizeof(*map), DRM_MEM_MAPS);
|
||||||
}
|
}
|
||||||
|
@ -326,6 +346,38 @@ gamma_takedown(drm_device_t *dev)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int gamma_found(void)
|
||||||
|
{
|
||||||
|
return devices;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
gamma_find_devices(device_t dev)
|
||||||
|
{
|
||||||
|
device_t *children, child;
|
||||||
|
int nchildren, i;
|
||||||
|
int count = 0;
|
||||||
|
|
||||||
|
if (device_get_children(device_get_parent(dev), &children, &nchildren))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
for (i = 0; i < nchildren; i++) {
|
||||||
|
child = children[i];
|
||||||
|
|
||||||
|
if (pci_get_slot(dev) == pci_get_slot(child) &&
|
||||||
|
pci_get_vendor(child) == PCI_VENDOR_ID_3DLABS &&
|
||||||
|
pci_get_device(child) == PCI_DEVICE_ID_3DLABS_MX) {
|
||||||
|
count++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
free(children, M_TEMP);
|
||||||
|
|
||||||
|
/* we don't currently support more than two */
|
||||||
|
if (count > 2) count = 2;
|
||||||
|
|
||||||
|
return count;
|
||||||
|
}
|
||||||
|
|
||||||
/* gamma_init is called via gamma_attach at module load time */
|
/* gamma_init is called via gamma_attach at module load time */
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
@ -342,6 +394,8 @@ gamma_init(device_t nbdev)
|
||||||
#if 0 /* XXX use getenv I guess */
|
#if 0 /* XXX use getenv I guess */
|
||||||
drm_parse_options(gamma);
|
drm_parse_options(gamma);
|
||||||
#endif
|
#endif
|
||||||
|
devices = gamma_find_devices(nbdev);
|
||||||
|
if (devices == 0) return -1;
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
if ((retcode = misc_register(&gamma_misc))) {
|
if ((retcode = misc_register(&gamma_misc))) {
|
||||||
|
@ -361,13 +415,14 @@ gamma_init(device_t nbdev)
|
||||||
drm_mem_init();
|
drm_mem_init();
|
||||||
drm_sysctl_init(dev);
|
drm_sysctl_init(dev);
|
||||||
|
|
||||||
DRM_INFO("Initialized %s %d.%d.%d %s on minor %d\n",
|
DRM_INFO("Initialized %s %d.%d.%d %s on minor %d with %d MX devices\n",
|
||||||
GAMMA_NAME,
|
GAMMA_NAME,
|
||||||
GAMMA_MAJOR,
|
GAMMA_MAJOR,
|
||||||
GAMMA_MINOR,
|
GAMMA_MINOR,
|
||||||
GAMMA_PATCHLEVEL,
|
GAMMA_PATCHLEVEL,
|
||||||
GAMMA_DATE,
|
GAMMA_DATE,
|
||||||
device_get_unit(nbdev));
|
device_get_unit(nbdev),
|
||||||
|
devices);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* gamma_drv.h -- Private header for 3dlabs GMX 2000 driver -*- c -*-
|
/* gamma_drv.h -- Private header for 3dlabs GMX 2000 driver -*- c -*-
|
||||||
* Created: Mon Jan 4 10:05:05 1999 by faith@precisioninsight.com
|
* Created: Mon Jan 4 10:05:05 1999 by faith@precisioninsight.com
|
||||||
* Revised: Fri Aug 20 09:24:27 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,9 +24,6 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/gamma_drv.h,v 1.4 1999/08/30 13:05:00 faith Exp $
|
|
||||||
* $XFree86: xc/programs/Xserver/hw/xfree86/os-support/linux/drm/kernel/gamma_drv.h,v 1.1 1999/09/25 14:38:00 dawes Exp $
|
|
||||||
*
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _GAMMA_DRV_H_
|
#ifndef _GAMMA_DRV_H_
|
||||||
|
@ -46,5 +43,6 @@ extern d_ioctl_t gamma_control;
|
||||||
extern int gamma_dma_schedule(drm_device_t *dev, int locked);
|
extern int gamma_dma_schedule(drm_device_t *dev, int locked);
|
||||||
extern int gamma_irq_install(drm_device_t *dev, int irq);
|
extern int gamma_irq_install(drm_device_t *dev, int irq);
|
||||||
extern int gamma_irq_uninstall(drm_device_t *dev);
|
extern int gamma_irq_uninstall(drm_device_t *dev);
|
||||||
|
extern int gamma_found(void);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
# $FreeBSD$
|
||||||
|
|
||||||
|
KMOD = mga
|
||||||
|
SRCS = mga_drv.c mga_context.c mga_state.c mga_bufs.c mga_dma.c
|
||||||
|
SRCS += device_if.h bus_if.h pci_if.h
|
||||||
|
CFLAGS += ${DEBUG_FLAGS} -I..
|
||||||
|
KERN = /usr/src/sys
|
||||||
|
KMODDEPS = drm
|
||||||
|
|
||||||
|
@:
|
||||||
|
ln -sf /sys @
|
||||||
|
|
||||||
|
machine:
|
||||||
|
ln -sf /sys/i386/include machine
|
||||||
|
|
||||||
|
.include <bsd.kmod.mk>
|
|
@ -0,0 +1,604 @@
|
||||||
|
/* mga_bufs.c -- IOCTLs to manage buffers
|
||||||
|
* Created: Thu Jan 6 01:47:26 2000 by jhartmann@precisioninsight.com
|
||||||
|
*
|
||||||
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
|
* All Rights Reserved.
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
* copy of this software and associated documentation files (the "Software"),
|
||||||
|
* to deal in the Software without restriction, including without limitation
|
||||||
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
|
* and/or sell copies of the Software, and to permit persons to whom the
|
||||||
|
* Software is furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice (including the next
|
||||||
|
* paragraph) shall be included in all copies or substantial portions of the
|
||||||
|
* Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
|
* PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
|
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||||
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
|
* DEALINGS IN THE SOFTWARE.
|
||||||
|
*
|
||||||
|
* Authors: Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
|
* Jeff Hartmann <jhartmann@valinux.com>
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define __NO_VERSION__
|
||||||
|
#include "drmP.h"
|
||||||
|
#include "mga_drv.h"
|
||||||
|
#include <sys/mman.h>
|
||||||
|
#include <vm/vm.h>
|
||||||
|
#include <vm/pmap.h>
|
||||||
|
#include <vm/vm_extern.h>
|
||||||
|
#include <vm/vm_map.h>
|
||||||
|
|
||||||
|
|
||||||
|
static int
|
||||||
|
mga_addbufs_agp(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_device_t *dev = kdev->si_drv1;
|
||||||
|
drm_device_dma_t *dma = dev->dma;
|
||||||
|
drm_buf_desc_t request;
|
||||||
|
drm_buf_entry_t *entry;
|
||||||
|
drm_buf_t *buf;
|
||||||
|
unsigned long offset;
|
||||||
|
unsigned long agp_offset;
|
||||||
|
int count;
|
||||||
|
int order;
|
||||||
|
int size;
|
||||||
|
int alignment;
|
||||||
|
int page_order;
|
||||||
|
int total;
|
||||||
|
int byte_count;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if (!dma) return EINVAL;
|
||||||
|
|
||||||
|
request = *(drm_buf_desc_t *) data;
|
||||||
|
|
||||||
|
count = request.count;
|
||||||
|
order = drm_order(request.size);
|
||||||
|
size = 1 << order;
|
||||||
|
agp_offset = request.agp_start;
|
||||||
|
alignment = (request.flags & _DRM_PAGE_ALIGN) ? round_page(size) :size;
|
||||||
|
page_order = order - PAGE_SHIFT > 0 ? order - PAGE_SHIFT : 0;
|
||||||
|
total = PAGE_SIZE << page_order;
|
||||||
|
byte_count = 0;
|
||||||
|
|
||||||
|
DRM_DEBUG("count: %d\n", count);
|
||||||
|
DRM_DEBUG("order: %d\n", order);
|
||||||
|
DRM_DEBUG("size: %d\n", size);
|
||||||
|
DRM_DEBUG("agp_offset: %ld\n", agp_offset);
|
||||||
|
DRM_DEBUG("alignment: %d\n", alignment);
|
||||||
|
DRM_DEBUG("page_order: %d\n", page_order);
|
||||||
|
DRM_DEBUG("total: %d\n", total);
|
||||||
|
DRM_DEBUG("byte_count: %d\n", byte_count);
|
||||||
|
|
||||||
|
if (order < DRM_MIN_ORDER || order > DRM_MAX_ORDER) return EINVAL;
|
||||||
|
if (dev->queue_count) return EBUSY; /* Not while in use */
|
||||||
|
simple_lock(&dev->count_lock);
|
||||||
|
if (dev->buf_use) {
|
||||||
|
simple_unlock(&dev->count_lock);
|
||||||
|
return EBUSY;
|
||||||
|
}
|
||||||
|
atomic_inc(&dev->buf_alloc);
|
||||||
|
simple_unlock(&dev->count_lock);
|
||||||
|
|
||||||
|
lockmgr(&dev->dev_lock, LK_EXCLUSIVE, 0, curproc);
|
||||||
|
entry = &dma->bufs[order];
|
||||||
|
if (entry->buf_count) {
|
||||||
|
lockmgr(&dev->dev_lock, LK_RELEASE, 0, curproc);
|
||||||
|
atomic_dec(&dev->buf_alloc);
|
||||||
|
return ENOMEM; /* May only call once for each order */
|
||||||
|
}
|
||||||
|
|
||||||
|
entry->buflist = drm_alloc(count * sizeof(*entry->buflist),
|
||||||
|
DRM_MEM_BUFS);
|
||||||
|
if (!entry->buflist) {
|
||||||
|
lockmgr(&dev->dev_lock, LK_RELEASE, 0, curproc);
|
||||||
|
atomic_dec(&dev->buf_alloc);
|
||||||
|
return ENOMEM;
|
||||||
|
}
|
||||||
|
memset(entry->buflist, 0, count * sizeof(*entry->buflist));
|
||||||
|
|
||||||
|
entry->buf_size = size;
|
||||||
|
entry->page_order = page_order;
|
||||||
|
offset = 0;
|
||||||
|
|
||||||
|
|
||||||
|
while(entry->buf_count < count) {
|
||||||
|
buf = &entry->buflist[entry->buf_count];
|
||||||
|
buf->idx = dma->buf_count + entry->buf_count;
|
||||||
|
buf->total = alignment;
|
||||||
|
buf->order = order;
|
||||||
|
buf->used = 0;
|
||||||
|
|
||||||
|
DRM_DEBUG("offset : %ld\n", offset);
|
||||||
|
|
||||||
|
buf->offset = offset; /* Hrm */
|
||||||
|
buf->bus_address = dev->agp->base + agp_offset + offset;
|
||||||
|
buf->address = (void *)(agp_offset + offset + dev->agp->base);
|
||||||
|
buf->next = NULL;
|
||||||
|
buf->waiting = 0;
|
||||||
|
buf->pending = 0;
|
||||||
|
buf->dma_wait = 0;
|
||||||
|
buf->pid = 0;
|
||||||
|
|
||||||
|
buf->dev_private = drm_alloc(sizeof(drm_mga_buf_priv_t), DRM_MEM_BUFS);
|
||||||
|
buf->dev_priv_size = sizeof(drm_mga_buf_priv_t);
|
||||||
|
|
||||||
|
#if DRM_DMA_HISTOGRAM
|
||||||
|
timespecclear(&buf->time_queued);
|
||||||
|
timespecclear(&buf->time_dispatched);
|
||||||
|
timespecclear(&buf->time_completed);
|
||||||
|
timespecclear(&buf->time_freed);
|
||||||
|
#endif
|
||||||
|
offset = offset + alignment;
|
||||||
|
entry->buf_count++;
|
||||||
|
byte_count += PAGE_SIZE << page_order;
|
||||||
|
|
||||||
|
DRM_DEBUG("buffer %d @ %p\n",
|
||||||
|
entry->buf_count, buf->address);
|
||||||
|
}
|
||||||
|
|
||||||
|
dma->buflist = drm_realloc(dma->buflist,
|
||||||
|
dma->buf_count * sizeof(*dma->buflist),
|
||||||
|
(dma->buf_count + entry->buf_count)
|
||||||
|
* sizeof(*dma->buflist),
|
||||||
|
DRM_MEM_BUFS);
|
||||||
|
for (i = dma->buf_count; i < dma->buf_count + entry->buf_count; i++)
|
||||||
|
dma->buflist[i] = &entry->buflist[i - dma->buf_count];
|
||||||
|
|
||||||
|
dma->buf_count += entry->buf_count;
|
||||||
|
|
||||||
|
DRM_DEBUG("dma->buf_count : %d\n", dma->buf_count);
|
||||||
|
|
||||||
|
dma->byte_count += byte_count;
|
||||||
|
|
||||||
|
DRM_DEBUG("entry->buf_count : %d\n", entry->buf_count);
|
||||||
|
|
||||||
|
drm_freelist_create(&entry->freelist, entry->buf_count);
|
||||||
|
for (i = 0; i < entry->buf_count; i++) {
|
||||||
|
drm_freelist_put(dev, &entry->freelist, &entry->buflist[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
lockmgr(&dev->dev_lock, LK_RELEASE, 0, curproc);
|
||||||
|
|
||||||
|
request.count = entry->buf_count;
|
||||||
|
request.size = size;
|
||||||
|
|
||||||
|
*(drm_buf_desc_t *) data = request;
|
||||||
|
|
||||||
|
atomic_dec(&dev->buf_alloc);
|
||||||
|
|
||||||
|
DRM_DEBUG("count: %d\n", count);
|
||||||
|
DRM_DEBUG("order: %d\n", order);
|
||||||
|
DRM_DEBUG("size: %d\n", size);
|
||||||
|
DRM_DEBUG("agp_offset: %ld\n", agp_offset);
|
||||||
|
DRM_DEBUG("alignment: %d\n", alignment);
|
||||||
|
DRM_DEBUG("page_order: %d\n", page_order);
|
||||||
|
DRM_DEBUG("total: %d\n", total);
|
||||||
|
DRM_DEBUG("byte_count: %d\n", byte_count);
|
||||||
|
|
||||||
|
dma->flags = _DRM_DMA_USE_AGP;
|
||||||
|
|
||||||
|
DRM_DEBUG("dma->flags : %x\n", dma->flags);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
mga_addbufs_pci(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_device_t *dev = kdev->si_drv1;
|
||||||
|
drm_device_dma_t *dma = dev->dma;
|
||||||
|
drm_buf_desc_t request;
|
||||||
|
int count;
|
||||||
|
int order;
|
||||||
|
int size;
|
||||||
|
int total;
|
||||||
|
int page_order;
|
||||||
|
drm_buf_entry_t *entry;
|
||||||
|
unsigned long page;
|
||||||
|
drm_buf_t *buf;
|
||||||
|
int alignment;
|
||||||
|
unsigned long offset;
|
||||||
|
int i;
|
||||||
|
int byte_count;
|
||||||
|
int page_count;
|
||||||
|
|
||||||
|
if (!dma) return EINVAL;
|
||||||
|
|
||||||
|
request = *(drm_buf_desc_t *) data;
|
||||||
|
|
||||||
|
count = request.count;
|
||||||
|
order = drm_order(request.size);
|
||||||
|
size = 1 << order;
|
||||||
|
|
||||||
|
DRM_DEBUG("count = %d, size = %d (%d), order = %d, queue_count = %d\n",
|
||||||
|
request.count, request.size, size, order, dev->queue_count);
|
||||||
|
|
||||||
|
if (order < DRM_MIN_ORDER || order > DRM_MAX_ORDER) return EINVAL;
|
||||||
|
if (dev->queue_count) return EBUSY; /* Not while in use */
|
||||||
|
|
||||||
|
alignment = (request.flags & _DRM_PAGE_ALIGN) ? round_page(size) :size;
|
||||||
|
page_order = order - PAGE_SHIFT > 0 ? order - PAGE_SHIFT : 0;
|
||||||
|
total = PAGE_SIZE << page_order;
|
||||||
|
|
||||||
|
simple_lock(&dev->count_lock);
|
||||||
|
if (dev->buf_use) {
|
||||||
|
simple_unlock(&dev->count_lock);
|
||||||
|
return EBUSY;
|
||||||
|
}
|
||||||
|
atomic_inc(&dev->buf_alloc);
|
||||||
|
simple_unlock(&dev->count_lock);
|
||||||
|
|
||||||
|
lockmgr(&dev->dev_lock, LK_EXCLUSIVE, 0, curproc);
|
||||||
|
entry = &dma->bufs[order];
|
||||||
|
if (entry->buf_count) {
|
||||||
|
lockmgr(&dev->dev_lock, LK_RELEASE, 0, curproc);
|
||||||
|
atomic_dec(&dev->buf_alloc);
|
||||||
|
return ENOMEM; /* May only call once for each order */
|
||||||
|
}
|
||||||
|
|
||||||
|
entry->buflist = drm_alloc(count * sizeof(*entry->buflist),
|
||||||
|
DRM_MEM_BUFS);
|
||||||
|
if (!entry->buflist) {
|
||||||
|
lockmgr(&dev->dev_lock, LK_RELEASE, 0, curproc);
|
||||||
|
atomic_dec(&dev->buf_alloc);
|
||||||
|
return ENOMEM;
|
||||||
|
}
|
||||||
|
memset(entry->buflist, 0, count * sizeof(*entry->buflist));
|
||||||
|
|
||||||
|
entry->seglist = drm_alloc(count * sizeof(*entry->seglist),
|
||||||
|
DRM_MEM_SEGS);
|
||||||
|
if (!entry->seglist) {
|
||||||
|
drm_free(entry->buflist,
|
||||||
|
count * sizeof(*entry->buflist),
|
||||||
|
DRM_MEM_BUFS);
|
||||||
|
lockmgr(&dev->dev_lock, LK_RELEASE, 0, curproc);
|
||||||
|
atomic_dec(&dev->buf_alloc);
|
||||||
|
return ENOMEM;
|
||||||
|
}
|
||||||
|
memset(entry->seglist, 0, count * sizeof(*entry->seglist));
|
||||||
|
|
||||||
|
dma->pagelist = drm_realloc(dma->pagelist,
|
||||||
|
dma->page_count * sizeof(*dma->pagelist),
|
||||||
|
(dma->page_count + (count << page_order))
|
||||||
|
* sizeof(*dma->pagelist),
|
||||||
|
DRM_MEM_PAGES);
|
||||||
|
DRM_DEBUG("pagelist: %d entries\n",
|
||||||
|
dma->page_count + (count << page_order));
|
||||||
|
|
||||||
|
|
||||||
|
entry->buf_size = size;
|
||||||
|
entry->page_order = page_order;
|
||||||
|
byte_count = 0;
|
||||||
|
page_count = 0;
|
||||||
|
while (entry->buf_count < count) {
|
||||||
|
if (!(page = drm_alloc_pages(page_order, DRM_MEM_DMA))) break;
|
||||||
|
entry->seglist[entry->seg_count++] = page;
|
||||||
|
for (i = 0; i < (1 << page_order); i++) {
|
||||||
|
DRM_DEBUG("page %d @ 0x%08lx\n",
|
||||||
|
dma->page_count + page_count,
|
||||||
|
page + PAGE_SIZE * i);
|
||||||
|
dma->pagelist[dma->page_count + page_count++]
|
||||||
|
= page + PAGE_SIZE * i;
|
||||||
|
}
|
||||||
|
for (offset = 0;
|
||||||
|
offset + size <= total && entry->buf_count < count;
|
||||||
|
offset += alignment, ++entry->buf_count) {
|
||||||
|
buf = &entry->buflist[entry->buf_count];
|
||||||
|
buf->idx = dma->buf_count + entry->buf_count;
|
||||||
|
buf->total = alignment;
|
||||||
|
buf->order = order;
|
||||||
|
buf->used = 0;
|
||||||
|
buf->offset = (dma->byte_count + byte_count + offset);
|
||||||
|
buf->address = (void *)(page + offset);
|
||||||
|
buf->next = NULL;
|
||||||
|
buf->waiting = 0;
|
||||||
|
buf->pending = 0;
|
||||||
|
buf->dma_wait = 0;
|
||||||
|
buf->pid = 0;
|
||||||
|
#if DRM_DMA_HISTOGRAM
|
||||||
|
timespecclear(&buf->time_queued);
|
||||||
|
timespecclear(&buf->time_dispatched);
|
||||||
|
timespecclear(&buf->time_completed);
|
||||||
|
timespecclear(&buf->time_freed);
|
||||||
|
#endif
|
||||||
|
DRM_DEBUG("buffer %d @ %p\n",
|
||||||
|
entry->buf_count, buf->address);
|
||||||
|
}
|
||||||
|
byte_count += PAGE_SIZE << page_order;
|
||||||
|
}
|
||||||
|
|
||||||
|
dma->buflist = drm_realloc(dma->buflist,
|
||||||
|
dma->buf_count * sizeof(*dma->buflist),
|
||||||
|
(dma->buf_count + entry->buf_count)
|
||||||
|
* sizeof(*dma->buflist),
|
||||||
|
DRM_MEM_BUFS);
|
||||||
|
for (i = dma->buf_count; i < dma->buf_count + entry->buf_count; i++)
|
||||||
|
dma->buflist[i] = &entry->buflist[i - dma->buf_count];
|
||||||
|
|
||||||
|
dma->buf_count += entry->buf_count;
|
||||||
|
dma->seg_count += entry->seg_count;
|
||||||
|
dma->page_count += entry->seg_count << page_order;
|
||||||
|
dma->byte_count += PAGE_SIZE * (entry->seg_count << page_order);
|
||||||
|
|
||||||
|
drm_freelist_create(&entry->freelist, entry->buf_count);
|
||||||
|
for (i = 0; i < entry->buf_count; i++) {
|
||||||
|
drm_freelist_put(dev, &entry->freelist, &entry->buflist[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
lockmgr(&dev->dev_lock, LK_RELEASE, 0, curproc);
|
||||||
|
|
||||||
|
request.count = entry->buf_count;
|
||||||
|
request.size = size;
|
||||||
|
|
||||||
|
*(drm_buf_desc_t *) data = request;
|
||||||
|
|
||||||
|
atomic_dec(&dev->buf_alloc);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
mga_addbufs(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_buf_desc_t request;
|
||||||
|
|
||||||
|
request = *(drm_buf_desc_t *) data;
|
||||||
|
|
||||||
|
if(request.flags & _DRM_AGP_BUFFER)
|
||||||
|
return mga_addbufs_agp(kdev, cmd, data, flags, p);
|
||||||
|
else
|
||||||
|
return mga_addbufs_pci(kdev, cmd, data, flags, p);
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
mga_infobufs(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_device_t *dev = kdev->si_drv1;
|
||||||
|
drm_device_dma_t *dma = dev->dma;
|
||||||
|
drm_buf_info_t request;
|
||||||
|
int i;
|
||||||
|
int count;
|
||||||
|
int error;
|
||||||
|
|
||||||
|
if (!dma) return EINVAL;
|
||||||
|
|
||||||
|
simple_lock(&dev->count_lock);
|
||||||
|
if (atomic_read(&dev->buf_alloc)) {
|
||||||
|
simple_unlock(&dev->count_lock);
|
||||||
|
return EBUSY;
|
||||||
|
}
|
||||||
|
++dev->buf_use; /* Can't allocate more after this call */
|
||||||
|
simple_unlock(&dev->count_lock);
|
||||||
|
|
||||||
|
request = *(drm_buf_info_t *) data;
|
||||||
|
|
||||||
|
for (i = 0, count = 0; i < DRM_MAX_ORDER+1; i++) {
|
||||||
|
if (dma->bufs[i].buf_count) ++count;
|
||||||
|
}
|
||||||
|
|
||||||
|
DRM_DEBUG("count = %d\n", count);
|
||||||
|
|
||||||
|
if (request.count >= count) {
|
||||||
|
for (i = 0, count = 0; i < DRM_MAX_ORDER+1; i++) {
|
||||||
|
if (dma->bufs[i].buf_count) {
|
||||||
|
error = copyout(&dma->bufs[i].buf_count,
|
||||||
|
&request.list[count].count,
|
||||||
|
sizeof(dma->bufs[0]
|
||||||
|
.buf_count));
|
||||||
|
if (error) return error;
|
||||||
|
error = copyout(&dma->bufs[i].buf_size,
|
||||||
|
&request.list[count].size,
|
||||||
|
sizeof(dma->bufs[0]
|
||||||
|
.buf_size));
|
||||||
|
if (error) return error;
|
||||||
|
error = copyout(&dma->bufs[i]
|
||||||
|
.freelist.low_mark,
|
||||||
|
&request.list[count].low_mark,
|
||||||
|
sizeof(dma->bufs[0]
|
||||||
|
.freelist.low_mark));
|
||||||
|
if (error) return error;
|
||||||
|
error = copyout(&dma->bufs[i]
|
||||||
|
.freelist.high_mark,
|
||||||
|
&request.list[count].high_mark,
|
||||||
|
sizeof(dma->bufs[0]
|
||||||
|
.freelist.high_mark));
|
||||||
|
if (error) return error;
|
||||||
|
DRM_DEBUG("%d %d %d %d %d\n",
|
||||||
|
i,
|
||||||
|
dma->bufs[i].buf_count,
|
||||||
|
dma->bufs[i].buf_size,
|
||||||
|
dma->bufs[i].freelist.low_mark,
|
||||||
|
dma->bufs[i].freelist.high_mark);
|
||||||
|
++count;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
request.count = count;
|
||||||
|
|
||||||
|
*(drm_buf_info_t *) data = request;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
mga_markbufs(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_device_t *dev = kdev->si_drv1;
|
||||||
|
drm_device_dma_t *dma = dev->dma;
|
||||||
|
drm_buf_desc_t request;
|
||||||
|
int order;
|
||||||
|
drm_buf_entry_t *entry;
|
||||||
|
|
||||||
|
if (!dma) return EINVAL;
|
||||||
|
|
||||||
|
request = *(drm_buf_desc_t *) data;
|
||||||
|
|
||||||
|
DRM_DEBUG("%d, %d, %d\n",
|
||||||
|
request.size, request.low_mark, request.high_mark);
|
||||||
|
order = drm_order(request.size);
|
||||||
|
if (order < DRM_MIN_ORDER || order > DRM_MAX_ORDER) return EINVAL;
|
||||||
|
entry = &dma->bufs[order];
|
||||||
|
|
||||||
|
if (request.low_mark < 0 || request.low_mark > entry->buf_count)
|
||||||
|
return EINVAL;
|
||||||
|
if (request.high_mark < 0 || request.high_mark > entry->buf_count)
|
||||||
|
return EINVAL;
|
||||||
|
|
||||||
|
entry->freelist.low_mark = request.low_mark;
|
||||||
|
entry->freelist.high_mark = request.high_mark;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
mga_freebufs(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_device_t *dev = kdev->si_drv1;
|
||||||
|
drm_device_dma_t *dma = dev->dma;
|
||||||
|
drm_buf_free_t request;
|
||||||
|
int i;
|
||||||
|
int error;
|
||||||
|
int idx;
|
||||||
|
drm_buf_t *buf;
|
||||||
|
|
||||||
|
if (!dma) return EINVAL;
|
||||||
|
|
||||||
|
request = *(drm_buf_free_t *) data;
|
||||||
|
|
||||||
|
DRM_DEBUG("%d\n", request.count);
|
||||||
|
for (i = 0; i < request.count; i++) {
|
||||||
|
error = copyin(&request.list[i],
|
||||||
|
&idx,
|
||||||
|
sizeof(idx));
|
||||||
|
if (error) return error;
|
||||||
|
if (idx < 0 || idx >= dma->buf_count) {
|
||||||
|
DRM_ERROR("Index %d (of %d max)\n",
|
||||||
|
idx, dma->buf_count - 1);
|
||||||
|
return EINVAL;
|
||||||
|
}
|
||||||
|
buf = dma->buflist[idx];
|
||||||
|
if (buf->pid != p->p_pid) {
|
||||||
|
DRM_ERROR("Process %d freeing buffer owned by %d\n",
|
||||||
|
p->p_pid, buf->pid);
|
||||||
|
return EINVAL;
|
||||||
|
}
|
||||||
|
drm_free_buffer(dev, buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
mga_mapbufs(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_device_t *dev = kdev->si_drv1;
|
||||||
|
drm_device_dma_t *dma = dev->dma;
|
||||||
|
int retcode = 0;
|
||||||
|
const int zero = 0;
|
||||||
|
vm_offset_t virtual;
|
||||||
|
vm_offset_t address;
|
||||||
|
drm_buf_map_t request;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if (!dma) return EINVAL;
|
||||||
|
|
||||||
|
DRM_DEBUG("\n");
|
||||||
|
|
||||||
|
simple_lock(&dev->count_lock);
|
||||||
|
if (atomic_read(&dev->buf_alloc)) {
|
||||||
|
simple_unlock(&dev->count_lock);
|
||||||
|
DRM_DEBUG("Busy\n");
|
||||||
|
return EBUSY;
|
||||||
|
}
|
||||||
|
++dev->buf_use; /* Can't allocate more after this call */
|
||||||
|
simple_unlock(&dev->count_lock);
|
||||||
|
|
||||||
|
request = *(drm_buf_map_t *) data;
|
||||||
|
|
||||||
|
DRM_DEBUG("mga_mapbufs\n");
|
||||||
|
DRM_DEBUG("dma->flags : %x\n", dma->flags);
|
||||||
|
|
||||||
|
if (request.count >= dma->buf_count) {
|
||||||
|
if(dma->flags & _DRM_DMA_USE_AGP) {
|
||||||
|
drm_mga_private_t *dev_priv = dev->dev_private;
|
||||||
|
drm_map_t *map = NULL;
|
||||||
|
|
||||||
|
map = dev->maplist[dev_priv->buffer_map_idx];
|
||||||
|
if (!map) {
|
||||||
|
DRM_DEBUG("map is null\n");
|
||||||
|
retcode = EINVAL;
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
|
DRM_DEBUG("map->offset : %lx\n", map->offset);
|
||||||
|
DRM_DEBUG("map->size : %lx\n", map->size);
|
||||||
|
DRM_DEBUG("map->type : %d\n", map->type);
|
||||||
|
DRM_DEBUG("map->flags : %x\n", map->flags);
|
||||||
|
DRM_DEBUG("map->handle : %p\n", map->handle);
|
||||||
|
DRM_DEBUG("map->mtrr : %d\n", map->mtrr);
|
||||||
|
virtual = 0;
|
||||||
|
retcode = vm_mmap(&p->p_vmspace->vm_map,
|
||||||
|
&virtual,
|
||||||
|
map->size,
|
||||||
|
PROT_READ|PROT_WRITE, VM_PROT_ALL,
|
||||||
|
MAP_SHARED,
|
||||||
|
SLIST_FIRST(&kdev->si_hlist),
|
||||||
|
map->offset);
|
||||||
|
} else {
|
||||||
|
virtual = 0;
|
||||||
|
retcode = vm_mmap(&p->p_vmspace->vm_map,
|
||||||
|
&virtual,
|
||||||
|
round_page(dma->byte_count),
|
||||||
|
PROT_READ|PROT_WRITE, VM_PROT_ALL,
|
||||||
|
MAP_SHARED,
|
||||||
|
SLIST_FIRST(&kdev->si_hlist),
|
||||||
|
0);
|
||||||
|
}
|
||||||
|
if (retcode) {
|
||||||
|
/* Real error */
|
||||||
|
DRM_DEBUG("mmap error\n");
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
request.virtual = (void *)virtual;
|
||||||
|
|
||||||
|
for (i = 0; i < dma->buf_count; i++) {
|
||||||
|
retcode = copyout(&dma->buflist[i]->idx,
|
||||||
|
&request.list[i].idx,
|
||||||
|
sizeof(request.list[0].idx));
|
||||||
|
if (retcode) goto done;
|
||||||
|
retcode = copyout(&dma->buflist[i]->total,
|
||||||
|
&request.list[i].total,
|
||||||
|
sizeof(request.list[0].total));
|
||||||
|
if (retcode) goto done;
|
||||||
|
retcode = copyout(&zero,
|
||||||
|
&request.list[i].used,
|
||||||
|
sizeof(request.list[0].used));
|
||||||
|
if (retcode) goto done;
|
||||||
|
address = virtual + dma->buflist[i]->offset;
|
||||||
|
retcode = copyout(&address,
|
||||||
|
&request.list[i].address,
|
||||||
|
sizeof(address));
|
||||||
|
if (retcode) goto done;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
done:
|
||||||
|
request.count = dma->buf_count;
|
||||||
|
DRM_DEBUG("%d buffers, retcode = %d\n", request.count, retcode);
|
||||||
|
|
||||||
|
*(drm_buf_map_t *) data = request;
|
||||||
|
|
||||||
|
DRM_DEBUG("retcode : %d\n", retcode);
|
||||||
|
|
||||||
|
return retcode;
|
||||||
|
}
|
|
@ -0,0 +1,196 @@
|
||||||
|
/* mga_context.c -- IOCTLs for mga contexts
|
||||||
|
* Created: Mon Dec 13 09:51:35 1999 by faith@precisioninsight.com
|
||||||
|
*
|
||||||
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
|
* All Rights Reserved.
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
* copy of this software and associated documentation files (the "Software"),
|
||||||
|
* to deal in the Software without restriction, including without limitation
|
||||||
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
|
* and/or sell copies of the Software, and to permit persons to whom the
|
||||||
|
* Software is furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice (including the next
|
||||||
|
* paragraph) shall be included in all copies or substantial portions of the
|
||||||
|
* Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
|
* PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
|
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||||
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
|
* DEALINGS IN THE SOFTWARE.
|
||||||
|
*
|
||||||
|
* Author: Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
|
* Jeff Hartmann <jhartmann@valinux.com>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define __NO_VERSION__
|
||||||
|
#include "drmP.h"
|
||||||
|
#include "mga_drv.h"
|
||||||
|
|
||||||
|
static int mga_alloc_queue(drm_device_t *dev)
|
||||||
|
{
|
||||||
|
int temp = drm_ctxbitmap_next(dev);
|
||||||
|
DRM_DEBUG("mga_alloc_queue: %d\n", temp);
|
||||||
|
return temp;
|
||||||
|
}
|
||||||
|
|
||||||
|
int mga_context_switch(drm_device_t *dev, int old, int new)
|
||||||
|
{
|
||||||
|
char buf[64];
|
||||||
|
|
||||||
|
atomic_inc(&dev->total_ctx);
|
||||||
|
|
||||||
|
if (test_and_set_bit(0, &dev->context_flag)) {
|
||||||
|
DRM_ERROR("Reentering -- FIXME\n");
|
||||||
|
return EBUSY;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if DRM_DMA_HISTOGRAM
|
||||||
|
getnanotime(&dev->ctx_start);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
DRM_DEBUG("Context switch from %d to %d\n", old, new);
|
||||||
|
|
||||||
|
if (new == dev->last_context) {
|
||||||
|
clear_bit(0, &dev->context_flag);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (drm_flags & DRM_FLAG_NOCTX) {
|
||||||
|
mga_context_switch_complete(dev, new);
|
||||||
|
} else {
|
||||||
|
sprintf(buf, "C %d %d\n", old, new);
|
||||||
|
drm_write_string(dev, buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int mga_context_switch_complete(drm_device_t *dev, int new)
|
||||||
|
{
|
||||||
|
dev->last_context = new; /* PRE/POST: This is the _only_ writer. */
|
||||||
|
dev->last_switch = ticks;
|
||||||
|
|
||||||
|
if (!_DRM_LOCK_IS_HELD(dev->lock.hw_lock->lock)) {
|
||||||
|
DRM_ERROR("Lock isn't held after context switch\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* If a context switch is ever initiated
|
||||||
|
when the kernel holds the lock, release
|
||||||
|
that lock here. */
|
||||||
|
#if DRM_DMA_HISTOGRAM
|
||||||
|
{
|
||||||
|
struct timespec ts;
|
||||||
|
getnanotime(&ts);
|
||||||
|
timespecsub(&ts, &dev->lck_start);
|
||||||
|
atomic_inc(&dev->histo.ctx[drm_histogram_slot(&ts)]);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
clear_bit(0, &dev->context_flag);
|
||||||
|
wakeup(&dev->context_wait);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
mga_resctx(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_ctx_res_t res;
|
||||||
|
drm_ctx_t ctx;
|
||||||
|
int i, error;
|
||||||
|
|
||||||
|
DRM_DEBUG("%d\n", DRM_RESERVED_CONTEXTS);
|
||||||
|
res = *(drm_ctx_res_t *) data;
|
||||||
|
if (res.count >= DRM_RESERVED_CONTEXTS) {
|
||||||
|
memset(&ctx, 0, sizeof(ctx));
|
||||||
|
for (i = 0; i < DRM_RESERVED_CONTEXTS; i++) {
|
||||||
|
ctx.handle = i;
|
||||||
|
error = copyout(&i, &res.contexts[i], sizeof(i));
|
||||||
|
if (error) return error;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
res.count = DRM_RESERVED_CONTEXTS;
|
||||||
|
*(drm_ctx_res_t *) data = res;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
mga_addctx(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_device_t *dev = kdev->si_drv1;
|
||||||
|
drm_ctx_t ctx;
|
||||||
|
|
||||||
|
ctx = *(drm_ctx_t *) data;
|
||||||
|
if ((ctx.handle = mga_alloc_queue(dev)) == DRM_KERNEL_CONTEXT) {
|
||||||
|
/* Skip kernel's context and get a new one. */
|
||||||
|
ctx.handle = mga_alloc_queue(dev);
|
||||||
|
}
|
||||||
|
if (ctx.handle == -1) {
|
||||||
|
DRM_DEBUG("Not enough free contexts.\n");
|
||||||
|
/* Should this return EBUSY instead? */
|
||||||
|
return ENOMEM;
|
||||||
|
}
|
||||||
|
DRM_DEBUG("%d\n", ctx.handle);
|
||||||
|
*(drm_ctx_t *) data = ctx;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
mga_modctx(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
/* This does nothing for the mga */
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int mga_getctx(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_ctx_t ctx;
|
||||||
|
|
||||||
|
ctx = *(drm_ctx_t *) data;
|
||||||
|
/* This is 0, because we don't hanlde any context flags */
|
||||||
|
ctx.flags = 0;
|
||||||
|
*(drm_ctx_t *) data = ctx;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int mga_switchctx(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_device_t *dev = kdev->si_drv1;
|
||||||
|
drm_ctx_t ctx;
|
||||||
|
|
||||||
|
ctx = *(drm_ctx_t *) data;
|
||||||
|
DRM_DEBUG("%d\n", ctx.handle);
|
||||||
|
return mga_context_switch(dev, dev->last_context, ctx.handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
int mga_newctx(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_device_t *dev = kdev->si_drv1;
|
||||||
|
drm_ctx_t ctx;
|
||||||
|
|
||||||
|
ctx = *(drm_ctx_t *) data;
|
||||||
|
DRM_DEBUG("%d\n", ctx.handle);
|
||||||
|
mga_context_switch_complete(dev, ctx.handle);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int mga_rmctx(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_device_t *dev = kdev->si_drv1;
|
||||||
|
drm_ctx_t ctx;
|
||||||
|
|
||||||
|
ctx = *(drm_ctx_t *) data;
|
||||||
|
DRM_DEBUG("%d\n", ctx.handle);
|
||||||
|
if(ctx.handle != DRM_KERNEL_CONTEXT) {
|
||||||
|
drm_ctxbitmap_free(dev, ctx.handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,714 @@
|
||||||
|
/* mga_drv.c -- Matrox g200/g400 driver
|
||||||
|
* Created: Mon Dec 13 01:56:22 1999 by jhartmann@precisioninsight.com
|
||||||
|
*
|
||||||
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
|
* All Rights Reserved.
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
* copy of this software and associated documentation files (the "Software"),
|
||||||
|
* to deal in the Software without restriction, including without limitation
|
||||||
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
|
* and/or sell copies of the Software, and to permit persons to whom the
|
||||||
|
* Software is furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice (including the next
|
||||||
|
* paragraph) shall be included in all copies or substantial portions of the
|
||||||
|
* Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
|
* PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
|
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||||
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
|
* DEALINGS IN THE SOFTWARE.
|
||||||
|
*
|
||||||
|
* Authors: Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
|
* Jeff Hartmann <jhartmann@valinux.com>
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "drmP.h"
|
||||||
|
#include "mga_drv.h"
|
||||||
|
|
||||||
|
#include <pci/pcivar.h>
|
||||||
|
|
||||||
|
MODULE_DEPEND(mga, drm, 1, 1, 1);
|
||||||
|
MODULE_DEPEND(mga, agp, 1, 1, 1);
|
||||||
|
|
||||||
|
#define MGA_NAME "mga"
|
||||||
|
#define MGA_DESC "Matrox g200/g400"
|
||||||
|
#define MGA_DATE "19991213"
|
||||||
|
#define MGA_MAJOR 1
|
||||||
|
#define MGA_MINOR 0
|
||||||
|
#define MGA_PATCHLEVEL 0
|
||||||
|
|
||||||
|
drm_ctx_t mga_res_ctx;
|
||||||
|
|
||||||
|
static int mga_probe(device_t dev)
|
||||||
|
{
|
||||||
|
const char *s = 0;
|
||||||
|
|
||||||
|
switch (pci_get_devid(dev)) {
|
||||||
|
case 0x0525102b:
|
||||||
|
s = "Matrox MGA G400 AGP graphics accelerator";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 0x0521102b:
|
||||||
|
s = "Matrox MGA G200 AGP graphics accelerator";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (s) {
|
||||||
|
device_set_desc(dev, s);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ENXIO;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int mga_attach(device_t dev)
|
||||||
|
{
|
||||||
|
return mga_init(dev);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int mga_detach(device_t dev)
|
||||||
|
{
|
||||||
|
mga_cleanup(dev);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static device_method_t mga_methods[] = {
|
||||||
|
/* Device interface */
|
||||||
|
DEVMETHOD(device_probe, mga_probe),
|
||||||
|
DEVMETHOD(device_attach, mga_attach),
|
||||||
|
DEVMETHOD(device_detach, mga_detach),
|
||||||
|
|
||||||
|
{ 0, 0 }
|
||||||
|
};
|
||||||
|
|
||||||
|
static driver_t mga_driver = {
|
||||||
|
"drm",
|
||||||
|
mga_methods,
|
||||||
|
sizeof(drm_device_t),
|
||||||
|
};
|
||||||
|
|
||||||
|
static devclass_t mga_devclass;
|
||||||
|
#define MGA_SOFTC(unit) \
|
||||||
|
((drm_device_t *) devclass_get_softc(mga_devclass, unit))
|
||||||
|
|
||||||
|
DRIVER_MODULE(if_mga, pci, mga_driver, mga_devclass, 0, 0);
|
||||||
|
|
||||||
|
#define CDEV_MAJOR 145
|
||||||
|
/* mga_drv.c */
|
||||||
|
static struct cdevsw mga_cdevsw = {
|
||||||
|
/* open */ mga_open,
|
||||||
|
/* close */ mga_close,
|
||||||
|
/* read */ drm_read,
|
||||||
|
/* write */ drm_write,
|
||||||
|
/* ioctl */ mga_ioctl,
|
||||||
|
/* poll */ drm_poll,
|
||||||
|
/* mmap */ drm_mmap,
|
||||||
|
/* strategy */ nostrategy,
|
||||||
|
/* name */ "mga",
|
||||||
|
/* maj */ CDEV_MAJOR,
|
||||||
|
/* dump */ nodump,
|
||||||
|
/* psize */ nopsize,
|
||||||
|
/* flags */ D_TTY | D_TRACKCLOSE,
|
||||||
|
/* bmaj */ -1
|
||||||
|
};
|
||||||
|
|
||||||
|
static drm_ioctl_desc_t mga_ioctls[] = {
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_VERSION)] = { mga_version, 0, 0 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_GET_UNIQUE)] = { drm_getunique, 0, 0 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_GET_MAGIC)] = { drm_getmagic, 0, 0 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_IRQ_BUSID)] = { drm_irq_busid, 0, 1 },
|
||||||
|
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_SET_UNIQUE)] = { drm_setunique, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_BLOCK)] = { drm_block, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_UNBLOCK)] = { drm_unblock, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_CONTROL)] = { mga_control, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AUTH_MAGIC)] = { drm_authmagic, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_ADD_MAP)] = { drm_addmap, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_ADD_BUFS)] = { mga_addbufs, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_MARK_BUFS)] = { mga_markbufs, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_INFO_BUFS)] = { mga_infobufs, 1, 0 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_MAP_BUFS)] = { mga_mapbufs, 1, 0 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_FREE_BUFS)] = { mga_freebufs, 1, 0 },
|
||||||
|
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_ADD_CTX)] = { mga_addctx, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_RM_CTX)] = { mga_rmctx, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_MOD_CTX)] = { mga_modctx, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_GET_CTX)] = { mga_getctx, 1, 0 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_SWITCH_CTX)] = { mga_switchctx, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_NEW_CTX)] = { mga_newctx, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_RES_CTX)] = { mga_resctx, 1, 0 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_ADD_DRAW)] = { drm_adddraw, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_RM_DRAW)] = { drm_rmdraw, 1, 1 },
|
||||||
|
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_DMA)] = { mga_dma, 1, 0 },
|
||||||
|
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_LOCK)] = { mga_lock, 1, 0 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_UNLOCK)] = { mga_unlock, 1, 0 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_FINISH)] = { drm_finish, 1, 0 },
|
||||||
|
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_ACQUIRE)] = { drm_agp_acquire, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_RELEASE)] = { drm_agp_release, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_ENABLE)] = { drm_agp_enable, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_INFO)] = { drm_agp_info, 1, 0 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_ALLOC)] = { drm_agp_alloc, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_FREE)] = { drm_agp_free, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_BIND)] = { drm_agp_bind, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_UNBIND)] = { drm_agp_unbind, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_MGA_INIT)] = { mga_dma_init, 1, 1 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_MGA_SWAP)] = { mga_swap_bufs, 1, 0 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_MGA_CLEAR)] = { mga_clear_bufs, 1, 0 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_MGA_ILOAD)] = { mga_iload, 1, 0 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_MGA_VERTEX)] = { mga_vertex, 1, 0 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_MGA_FLUSH)] = { mga_flush_ioctl, 1, 0 },
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_MGA_INDICES)] = { mga_indices, 1, 0 },
|
||||||
|
};
|
||||||
|
|
||||||
|
#define MGA_IOCTL_COUNT DRM_ARRAY_SIZE(mga_ioctls)
|
||||||
|
|
||||||
|
static int mga_setup(drm_device_t *dev)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
device_busy(dev->device);
|
||||||
|
|
||||||
|
atomic_set(&dev->ioctl_count, 0);
|
||||||
|
atomic_set(&dev->vma_count, 0);
|
||||||
|
dev->buf_use = 0;
|
||||||
|
atomic_set(&dev->buf_alloc, 0);
|
||||||
|
|
||||||
|
drm_dma_setup(dev);
|
||||||
|
|
||||||
|
atomic_set(&dev->total_open, 0);
|
||||||
|
atomic_set(&dev->total_close, 0);
|
||||||
|
atomic_set(&dev->total_ioctl, 0);
|
||||||
|
atomic_set(&dev->total_irq, 0);
|
||||||
|
atomic_set(&dev->total_ctx, 0);
|
||||||
|
atomic_set(&dev->total_locks, 0);
|
||||||
|
atomic_set(&dev->total_unlocks, 0);
|
||||||
|
atomic_set(&dev->total_contends, 0);
|
||||||
|
atomic_set(&dev->total_sleeps, 0);
|
||||||
|
|
||||||
|
for (i = 0; i < DRM_HASH_SIZE; i++) {
|
||||||
|
dev->magiclist[i].head = NULL;
|
||||||
|
dev->magiclist[i].tail = NULL;
|
||||||
|
}
|
||||||
|
dev->maplist = NULL;
|
||||||
|
dev->map_count = 0;
|
||||||
|
dev->vmalist = NULL;
|
||||||
|
dev->lock.hw_lock = NULL;
|
||||||
|
dev->lock.lock_queue = 0;
|
||||||
|
dev->queue_count = 0;
|
||||||
|
dev->queue_reserved = 0;
|
||||||
|
dev->queue_slots = 0;
|
||||||
|
dev->queuelist = NULL;
|
||||||
|
dev->irq = 0;
|
||||||
|
dev->context_flag = 0;
|
||||||
|
dev->interrupt_flag = 0;
|
||||||
|
dev->dma_flag = 0;
|
||||||
|
dev->last_context = 0;
|
||||||
|
dev->last_switch = 0;
|
||||||
|
dev->last_checked = 0;
|
||||||
|
callout_init(&dev->timer);
|
||||||
|
dev->context_wait = 0;
|
||||||
|
|
||||||
|
timespecclear(&dev->ctx_start);
|
||||||
|
timespecclear(&dev->lck_start);
|
||||||
|
|
||||||
|
dev->buf_rp = dev->buf;
|
||||||
|
dev->buf_wp = dev->buf;
|
||||||
|
dev->buf_end = dev->buf + DRM_BSZ;
|
||||||
|
bzero(&dev->buf_sel, sizeof dev->buf_sel);
|
||||||
|
dev->buf_sigio = NULL;
|
||||||
|
dev->buf_readers = 0;
|
||||||
|
dev->buf_writers = 0;
|
||||||
|
dev->buf_selecting = 0;
|
||||||
|
|
||||||
|
DRM_DEBUG("\n");
|
||||||
|
|
||||||
|
/* The kernel's context could be created here, but is now created
|
||||||
|
in drm_dma_enqueue. This is more resource-efficient for
|
||||||
|
hardware that does not do DMA, but may mean that
|
||||||
|
drm_select_queue fails between the time the interrupt is
|
||||||
|
initialized and the time the queues are initialized. */
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int mga_takedown(drm_device_t *dev)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
drm_magic_entry_t *pt, *next;
|
||||||
|
drm_map_t *map;
|
||||||
|
drm_vma_entry_t *vma, *vma_next;
|
||||||
|
|
||||||
|
DRM_DEBUG("\n");
|
||||||
|
|
||||||
|
if (dev->irq) mga_irq_uninstall(dev);
|
||||||
|
|
||||||
|
lockmgr(&dev->dev_lock, LK_EXCLUSIVE, 0, curproc);
|
||||||
|
callout_stop(&dev->timer);
|
||||||
|
|
||||||
|
if (dev->devname) {
|
||||||
|
drm_free(dev->devname, strlen(dev->devname)+1, DRM_MEM_DRIVER);
|
||||||
|
dev->devname = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dev->unique) {
|
||||||
|
drm_free(dev->unique, strlen(dev->unique)+1, DRM_MEM_DRIVER);
|
||||||
|
dev->unique = NULL;
|
||||||
|
dev->unique_len = 0;
|
||||||
|
}
|
||||||
|
/* Clear pid list */
|
||||||
|
for (i = 0; i < DRM_HASH_SIZE; i++) {
|
||||||
|
for (pt = dev->magiclist[i].head; pt; pt = next) {
|
||||||
|
next = pt->next;
|
||||||
|
drm_free(pt, sizeof(*pt), DRM_MEM_MAGIC);
|
||||||
|
}
|
||||||
|
dev->magiclist[i].head = dev->magiclist[i].tail = NULL;
|
||||||
|
}
|
||||||
|
/* Clear AGP information */
|
||||||
|
if (dev->agp) {
|
||||||
|
drm_agp_mem_t *entry;
|
||||||
|
drm_agp_mem_t *nexte;
|
||||||
|
|
||||||
|
/* Remove AGP resources, but leave dev->agp
|
||||||
|
intact until cleanup is called. */
|
||||||
|
for (entry = dev->agp->memory; entry; entry = nexte) {
|
||||||
|
nexte = entry->next;
|
||||||
|
if (entry->bound) drm_unbind_agp(entry->handle);
|
||||||
|
drm_free_agp(entry->handle, entry->pages);
|
||||||
|
drm_free(entry, sizeof(*entry), DRM_MEM_AGPLISTS);
|
||||||
|
}
|
||||||
|
dev->agp->memory = NULL;
|
||||||
|
|
||||||
|
if (dev->agp->acquired)
|
||||||
|
agp_release(dev->agp->agpdev);
|
||||||
|
|
||||||
|
dev->agp->acquired = 0;
|
||||||
|
dev->agp->enabled = 0;
|
||||||
|
}
|
||||||
|
/* Clear vma list (only built for debugging) */
|
||||||
|
if (dev->vmalist) {
|
||||||
|
for (vma = dev->vmalist; vma; vma = vma_next) {
|
||||||
|
vma_next = vma->next;
|
||||||
|
drm_free(vma, sizeof(*vma), DRM_MEM_VMAS);
|
||||||
|
}
|
||||||
|
dev->vmalist = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Clear map area and mtrr information */
|
||||||
|
if (dev->maplist) {
|
||||||
|
for (i = 0; i < dev->map_count; i++) {
|
||||||
|
map = dev->maplist[i];
|
||||||
|
switch (map->type) {
|
||||||
|
case _DRM_REGISTERS:
|
||||||
|
case _DRM_FRAME_BUFFER:
|
||||||
|
#ifdef CONFIG_MTRR
|
||||||
|
if (map->mtrr >= 0) {
|
||||||
|
int retcode;
|
||||||
|
retcode = mtrr_del(map->mtrr,
|
||||||
|
map->offset,
|
||||||
|
map->size);
|
||||||
|
DRM_DEBUG("mtrr_del = %d\n", retcode);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
drm_ioremapfree(map->handle, map->size);
|
||||||
|
break;
|
||||||
|
case _DRM_SHM:
|
||||||
|
drm_free_pages((unsigned long)map->handle,
|
||||||
|
drm_order(map->size)
|
||||||
|
- PAGE_SHIFT,
|
||||||
|
DRM_MEM_SAREA);
|
||||||
|
break;
|
||||||
|
case _DRM_AGP:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
drm_free(map, sizeof(*map), DRM_MEM_MAPS);
|
||||||
|
}
|
||||||
|
drm_free(dev->maplist,
|
||||||
|
dev->map_count * sizeof(*dev->maplist),
|
||||||
|
DRM_MEM_MAPS);
|
||||||
|
dev->maplist = NULL;
|
||||||
|
dev->map_count = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dev->queuelist) {
|
||||||
|
for (i = 0; i < dev->queue_count; i++) {
|
||||||
|
drm_waitlist_destroy(&dev->queuelist[i]->waitlist);
|
||||||
|
if (dev->queuelist[i]) {
|
||||||
|
drm_free(dev->queuelist[i],
|
||||||
|
sizeof(*dev->queuelist[0]),
|
||||||
|
DRM_MEM_QUEUES);
|
||||||
|
dev->queuelist[i] = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
drm_free(dev->queuelist,
|
||||||
|
dev->queue_slots * sizeof(*dev->queuelist),
|
||||||
|
DRM_MEM_QUEUES);
|
||||||
|
dev->queuelist = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
drm_dma_takedown(dev);
|
||||||
|
|
||||||
|
dev->queue_count = 0;
|
||||||
|
if (dev->lock.hw_lock) {
|
||||||
|
dev->lock.hw_lock = NULL; /* SHM removed */
|
||||||
|
dev->lock.pid = 0;
|
||||||
|
wakeup(&dev->lock.lock_queue);
|
||||||
|
}
|
||||||
|
lockmgr(&dev->dev_lock, LK_RELEASE, 0, curproc);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* mga_init is called via mga_attach at module load time, */
|
||||||
|
|
||||||
|
int
|
||||||
|
mga_init(device_t nbdev)
|
||||||
|
{
|
||||||
|
int retcode;
|
||||||
|
drm_device_t *dev = device_get_softc(nbdev);
|
||||||
|
|
||||||
|
DRM_DEBUG("\n");
|
||||||
|
|
||||||
|
memset((void *)dev, 0, sizeof(*dev));
|
||||||
|
simple_lock_init(&dev->count_lock);
|
||||||
|
lockinit(&dev->dev_lock, PZERO, "drmlk", 0, 0);
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
drm_parse_options(mga);
|
||||||
|
#endif
|
||||||
|
dev->device = nbdev;
|
||||||
|
dev->devnode = make_dev(&mga_cdevsw,
|
||||||
|
device_get_unit(nbdev),
|
||||||
|
DRM_DEV_UID,
|
||||||
|
DRM_DEV_GID,
|
||||||
|
DRM_DEV_MODE,
|
||||||
|
MGA_NAME);
|
||||||
|
dev->name = MGA_NAME;
|
||||||
|
|
||||||
|
DRM_DEBUG("doing mem init\n");
|
||||||
|
drm_mem_init();
|
||||||
|
DRM_DEBUG("doing proc init\n");
|
||||||
|
drm_sysctl_init(dev);
|
||||||
|
TAILQ_INIT(&dev->files);
|
||||||
|
DRM_DEBUG("doing agp init\n");
|
||||||
|
dev->agp = drm_agp_init();
|
||||||
|
if(dev->agp == NULL) {
|
||||||
|
DRM_INFO("The mga drm module requires the agp module"
|
||||||
|
" to function correctly\nPlease load the agp"
|
||||||
|
" module before you load the mga module\n");
|
||||||
|
drm_sysctl_cleanup(dev);
|
||||||
|
mga_takedown(dev);
|
||||||
|
return ENOMEM;
|
||||||
|
}
|
||||||
|
#if 0
|
||||||
|
dev->agp->agp_mtrr = mtrr_add(dev->agp->agp_info.aper_base,
|
||||||
|
dev->agp->agp_info.aper_size * 1024 * 1024,
|
||||||
|
MTRR_TYPE_WRCOMB,
|
||||||
|
1);
|
||||||
|
#endif
|
||||||
|
DRM_DEBUG("doing ctxbitmap init\n");
|
||||||
|
if((retcode = drm_ctxbitmap_init(dev))) {
|
||||||
|
DRM_ERROR("Cannot allocate memory for context bitmap.\n");
|
||||||
|
drm_sysctl_cleanup(dev);
|
||||||
|
mga_takedown(dev);
|
||||||
|
return retcode;
|
||||||
|
}
|
||||||
|
|
||||||
|
DRM_INFO("Initialized %s %d.%d.%d %s on minor %d\n",
|
||||||
|
MGA_NAME,
|
||||||
|
MGA_MAJOR,
|
||||||
|
MGA_MINOR,
|
||||||
|
MGA_PATCHLEVEL,
|
||||||
|
MGA_DATE,
|
||||||
|
device_get_unit(nbdev));
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* mga_cleanup is called via cleanup_module at module unload time. */
|
||||||
|
|
||||||
|
void mga_cleanup(device_t nbdev)
|
||||||
|
{
|
||||||
|
drm_device_t *dev = device_get_softc(nbdev);
|
||||||
|
|
||||||
|
DRM_DEBUG("\n");
|
||||||
|
|
||||||
|
drm_sysctl_cleanup(dev);
|
||||||
|
destroy_dev(dev->devnode);
|
||||||
|
|
||||||
|
DRM_INFO("Module unloaded\n");
|
||||||
|
drm_ctxbitmap_cleanup(dev);
|
||||||
|
mga_dma_cleanup(dev);
|
||||||
|
#if 0
|
||||||
|
if(dev->agp && dev->agp->agp_mtrr) {
|
||||||
|
int retval;
|
||||||
|
retval = mtrr_del(dev->agp->agp_mtrr,
|
||||||
|
dev->agp->agp_info.aper_base,
|
||||||
|
dev->agp->agp_info.aper_size * 1024*1024);
|
||||||
|
DRM_DEBUG("mtrr_del = %d\n", retval);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
mga_takedown(dev);
|
||||||
|
if (dev->agp) {
|
||||||
|
drm_free(dev->agp, sizeof(*dev->agp), DRM_MEM_AGPLISTS);
|
||||||
|
dev->agp = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
mga_version(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_version_t version;
|
||||||
|
int len;
|
||||||
|
|
||||||
|
version = *(drm_version_t *) data;
|
||||||
|
|
||||||
|
#define DRM_COPY(name,value) \
|
||||||
|
len = strlen(value); \
|
||||||
|
if (len > name##_len) len = name##_len; \
|
||||||
|
name##_len = strlen(value); \
|
||||||
|
if (len && name) { \
|
||||||
|
int error = copyout(value, name, len); \
|
||||||
|
if (error) return error; \
|
||||||
|
}
|
||||||
|
|
||||||
|
version.version_major = MGA_MAJOR;
|
||||||
|
version.version_minor = MGA_MINOR;
|
||||||
|
version.version_patchlevel = MGA_PATCHLEVEL;
|
||||||
|
|
||||||
|
DRM_COPY(version.name, MGA_NAME);
|
||||||
|
DRM_COPY(version.date, MGA_DATE);
|
||||||
|
DRM_COPY(version.desc, MGA_DESC);
|
||||||
|
|
||||||
|
*(drm_version_t *) data = version;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
mga_open(dev_t kdev, int flags, int fmt, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_device_t *dev = MGA_SOFTC(minor(kdev));
|
||||||
|
int retcode = 0;
|
||||||
|
|
||||||
|
DRM_DEBUG("open_count = %d\n", dev->open_count);
|
||||||
|
|
||||||
|
device_busy(dev->device);
|
||||||
|
if (!(retcode = drm_open_helper(kdev, flags, fmt, p, dev))) {
|
||||||
|
atomic_inc(&dev->total_open);
|
||||||
|
simple_lock(&dev->count_lock);
|
||||||
|
if (!dev->open_count++) {
|
||||||
|
simple_unlock(&dev->count_lock);
|
||||||
|
retcode = mga_setup(dev);
|
||||||
|
}
|
||||||
|
simple_unlock(&dev->count_lock);
|
||||||
|
}
|
||||||
|
device_unbusy(dev->device);
|
||||||
|
|
||||||
|
return retcode;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
mga_close(dev_t kdev, int flags, int fmt, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_device_t *dev = kdev->si_drv1;
|
||||||
|
drm_file_t *priv;
|
||||||
|
int retcode = 0;
|
||||||
|
|
||||||
|
DRM_DEBUG("pid = %d, open_count = %d\n",
|
||||||
|
p->p_pid, dev->open_count);
|
||||||
|
|
||||||
|
priv = drm_find_file_by_proc(dev, p);
|
||||||
|
if (!priv) {
|
||||||
|
DRM_DEBUG("can't find authenticator\n");
|
||||||
|
return EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dev->lock.hw_lock && _DRM_LOCK_IS_HELD(dev->lock.hw_lock->lock)
|
||||||
|
&& dev->lock.pid == p->p_pid) {
|
||||||
|
mga_reclaim_buffers(dev, priv->pid);
|
||||||
|
DRM_ERROR("Process %d dead, freeing lock for context %d\n",
|
||||||
|
p->p_pid,
|
||||||
|
_DRM_LOCKING_CONTEXT(dev->lock.hw_lock->lock));
|
||||||
|
drm_lock_free(dev,
|
||||||
|
&dev->lock.hw_lock->lock,
|
||||||
|
_DRM_LOCKING_CONTEXT(dev->lock.hw_lock->lock));
|
||||||
|
|
||||||
|
/* FIXME: may require heavy-handed reset of
|
||||||
|
hardware at this point, possibly
|
||||||
|
processed via a callback to the X
|
||||||
|
server. */
|
||||||
|
} else if (dev->lock.hw_lock) {
|
||||||
|
/* The lock is required to reclaim buffers */
|
||||||
|
for (;;) {
|
||||||
|
if (!dev->lock.hw_lock) {
|
||||||
|
/* Device has been unregistered */
|
||||||
|
retcode = EINTR;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (drm_lock_take(&dev->lock.hw_lock->lock,
|
||||||
|
DRM_KERNEL_CONTEXT)) {
|
||||||
|
dev->lock.pid = p->p_pid;
|
||||||
|
dev->lock.lock_time = ticks;
|
||||||
|
atomic_inc(&dev->total_locks);
|
||||||
|
break; /* Got lock */
|
||||||
|
}
|
||||||
|
/* Contention */
|
||||||
|
atomic_inc(&dev->total_sleeps);
|
||||||
|
retcode = tsleep(&dev->lock.lock_queue,
|
||||||
|
PZERO|PCATCH,
|
||||||
|
"drmlk2",
|
||||||
|
0);
|
||||||
|
if (retcode)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(!retcode) {
|
||||||
|
mga_reclaim_buffers(dev, priv->pid);
|
||||||
|
drm_lock_free(dev, &dev->lock.hw_lock->lock,
|
||||||
|
DRM_KERNEL_CONTEXT);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
funsetown(dev->buf_sigio);
|
||||||
|
|
||||||
|
lockmgr(&dev->dev_lock, LK_EXCLUSIVE, 0, p);
|
||||||
|
priv = drm_find_file_by_proc(dev, p);
|
||||||
|
if (priv) {
|
||||||
|
priv->refs--;
|
||||||
|
if (!priv->refs) {
|
||||||
|
TAILQ_REMOVE(&dev->files, priv, link);
|
||||||
|
drm_free(priv, sizeof(*priv), DRM_MEM_FILES);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
lockmgr(&dev->dev_lock, LK_RELEASE, 0, p);
|
||||||
|
|
||||||
|
atomic_inc(&dev->total_close);
|
||||||
|
simple_lock(&dev->count_lock);
|
||||||
|
if (!--dev->open_count) {
|
||||||
|
if (atomic_read(&dev->ioctl_count) || dev->blocked) {
|
||||||
|
DRM_ERROR("Device busy: %d %d\n",
|
||||||
|
atomic_read(&dev->ioctl_count),
|
||||||
|
dev->blocked);
|
||||||
|
simple_unlock(&dev->count_lock);
|
||||||
|
return EBUSY;
|
||||||
|
}
|
||||||
|
simple_unlock(&dev->count_lock);
|
||||||
|
device_unbusy(dev->device);
|
||||||
|
return mga_takedown(dev);
|
||||||
|
}
|
||||||
|
simple_unlock(&dev->count_lock);
|
||||||
|
return retcode;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* mga_ioctl is called whenever a process performs an ioctl on /dev/drm. */
|
||||||
|
|
||||||
|
int
|
||||||
|
mga_ioctl(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
int nr = DRM_IOCTL_NR(cmd);
|
||||||
|
drm_device_t *dev = kdev->si_drv1;
|
||||||
|
drm_file_t *priv;
|
||||||
|
int retcode = 0;
|
||||||
|
drm_ioctl_desc_t *ioctl;
|
||||||
|
d_ioctl_t *func;
|
||||||
|
|
||||||
|
DRM_DEBUG("dev=%p\n", dev);
|
||||||
|
priv = drm_find_file_by_proc(dev, p);
|
||||||
|
if (!priv) {
|
||||||
|
DRM_DEBUG("can't find authenticator\n");
|
||||||
|
return EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
atomic_inc(&dev->ioctl_count);
|
||||||
|
atomic_inc(&dev->total_ioctl);
|
||||||
|
++priv->ioctl_count;
|
||||||
|
|
||||||
|
DRM_DEBUG("pid = %d, cmd = 0x%02lx, nr = 0x%02x, auth = %d\n",
|
||||||
|
p->p_pid, cmd, nr, priv->authenticated);
|
||||||
|
|
||||||
|
switch (cmd) {
|
||||||
|
case FIONBIO:
|
||||||
|
atomic_dec(&dev->ioctl_count);
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
case FIOASYNC:
|
||||||
|
atomic_dec(&dev->ioctl_count);
|
||||||
|
dev->flags |= FASYNC;
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
case FIOSETOWN:
|
||||||
|
atomic_dec(&dev->ioctl_count);
|
||||||
|
return fsetown(*(int *)data, &dev->buf_sigio);
|
||||||
|
|
||||||
|
case FIOGETOWN:
|
||||||
|
atomic_dec(&dev->ioctl_count);
|
||||||
|
*(int *) data = fgetown(dev->buf_sigio);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (nr >= MGA_IOCTL_COUNT) {
|
||||||
|
retcode = EINVAL;
|
||||||
|
} else {
|
||||||
|
ioctl = &mga_ioctls[nr];
|
||||||
|
func = ioctl->func;
|
||||||
|
|
||||||
|
if (!func) {
|
||||||
|
DRM_DEBUG("no function\n");
|
||||||
|
retcode = EINVAL;
|
||||||
|
} else if ((ioctl->root_only && suser(p))
|
||||||
|
|| (ioctl->auth_needed && !priv->authenticated)) {
|
||||||
|
retcode = EACCES;
|
||||||
|
} else {
|
||||||
|
retcode = (func)(kdev, cmd, data, flags, p);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
atomic_dec(&dev->ioctl_count);
|
||||||
|
return retcode;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
mga_unlock(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
|
{
|
||||||
|
drm_device_t *dev = kdev->si_drv1;
|
||||||
|
drm_lock_t lock;
|
||||||
|
int s;
|
||||||
|
|
||||||
|
lock = *(drm_lock_t *) data;
|
||||||
|
|
||||||
|
if (lock.context == DRM_KERNEL_CONTEXT) {
|
||||||
|
DRM_ERROR("Process %d using kernel context %d\n",
|
||||||
|
p->p_pid, lock.context);
|
||||||
|
return EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
DRM_DEBUG("%d frees lock (%d holds)\n",
|
||||||
|
lock.context,
|
||||||
|
_DRM_LOCKING_CONTEXT(dev->lock.hw_lock->lock));
|
||||||
|
atomic_inc(&dev->total_unlocks);
|
||||||
|
if (_DRM_LOCK_IS_CONT(dev->lock.hw_lock->lock))
|
||||||
|
atomic_inc(&dev->total_contends);
|
||||||
|
drm_lock_transfer(dev, &dev->lock.hw_lock->lock, DRM_KERNEL_CONTEXT);
|
||||||
|
|
||||||
|
s = splsofttq();
|
||||||
|
mga_dma_schedule(dev, 1);
|
||||||
|
splx(s);
|
||||||
|
|
||||||
|
if (drm_lock_free(dev, &dev->lock.hw_lock->lock,
|
||||||
|
DRM_KERNEL_CONTEXT)) {
|
||||||
|
DRM_ERROR("\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
|
@ -0,0 +1,420 @@
|
||||||
|
/* mga_drv.h -- Private header for the Matrox g200/g400 driver
|
||||||
|
* Created: Mon Dec 13 01:50:01 1999 by jhartmann@precisioninsight.com
|
||||||
|
*
|
||||||
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
* copy of this software and associated documentation files (the "Software"),
|
||||||
|
* to deal in the Software without restriction, including without limitation
|
||||||
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
|
* and/or sell copies of the Software, and to permit persons to whom the
|
||||||
|
* Software is furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice (including the next
|
||||||
|
* paragraph) shall be included in all copies or substantial portions of the
|
||||||
|
* Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||||
|
* PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||||
|
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||||
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
|
* DEALINGS IN THE SOFTWARE.
|
||||||
|
*
|
||||||
|
* Authors: Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
|
* Jeff Hartmann <jhartmann@valinux.com>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _MGA_DRV_H_
|
||||||
|
#define _MGA_DRV_H_
|
||||||
|
|
||||||
|
#define MGA_BUF_IN_USE 0
|
||||||
|
#define MGA_BUF_SWAP_PENDING 1
|
||||||
|
#define MGA_BUF_FORCE_FIRE 2
|
||||||
|
#define MGA_BUF_NEEDS_OVERFLOW 3
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
u_int32_t buffer_status;
|
||||||
|
unsigned int num_dwords;
|
||||||
|
unsigned int max_dwords;
|
||||||
|
u_int32_t *current_dma_ptr;
|
||||||
|
u_int32_t *head;
|
||||||
|
u_int32_t phys_head;
|
||||||
|
unsigned int prim_age;
|
||||||
|
int sec_used;
|
||||||
|
int idx;
|
||||||
|
} drm_mga_prim_buf_t;
|
||||||
|
|
||||||
|
typedef struct _drm_mga_freelist {
|
||||||
|
unsigned int age;
|
||||||
|
drm_buf_t *buf;
|
||||||
|
struct _drm_mga_freelist *next;
|
||||||
|
struct _drm_mga_freelist *prev;
|
||||||
|
} drm_mga_freelist_t;
|
||||||
|
|
||||||
|
#define MGA_IN_DISPATCH 0
|
||||||
|
#define MGA_IN_FLUSH 1
|
||||||
|
#define MGA_IN_WAIT 2
|
||||||
|
#define MGA_IN_GETBUF 3
|
||||||
|
|
||||||
|
typedef struct _drm_mga_private {
|
||||||
|
u_int32_t dispatch_status;
|
||||||
|
unsigned int next_prim_age;
|
||||||
|
__volatile__ unsigned int last_prim_age;
|
||||||
|
int reserved_map_idx;
|
||||||
|
int buffer_map_idx;
|
||||||
|
drm_mga_sarea_t *sarea_priv;
|
||||||
|
int primary_size;
|
||||||
|
int warp_ucode_size;
|
||||||
|
int chipset;
|
||||||
|
unsigned int frontOffset;
|
||||||
|
unsigned int backOffset;
|
||||||
|
unsigned int depthOffset;
|
||||||
|
unsigned int textureOffset;
|
||||||
|
unsigned int textureSize;
|
||||||
|
int cpp;
|
||||||
|
unsigned int stride;
|
||||||
|
int sgram;
|
||||||
|
int use_agp;
|
||||||
|
drm_mga_warp_index_t WarpIndex[MGA_MAX_G400_PIPES];
|
||||||
|
unsigned int WarpPipe;
|
||||||
|
atomic_t pending_bufs;
|
||||||
|
void *status_page;
|
||||||
|
unsigned long real_status_page;
|
||||||
|
u_int8_t *ioremap;
|
||||||
|
drm_mga_prim_buf_t **prim_bufs;
|
||||||
|
drm_mga_prim_buf_t *next_prim;
|
||||||
|
drm_mga_prim_buf_t *last_prim;
|
||||||
|
drm_mga_prim_buf_t *current_prim;
|
||||||
|
int current_prim_idx;
|
||||||
|
drm_mga_freelist_t *head;
|
||||||
|
drm_mga_freelist_t *tail;
|
||||||
|
int flush_queue; /* Processes waiting until flush */
|
||||||
|
int wait_queue; /* Processes waiting until interrupt */
|
||||||
|
int buf_queue; /* Processes waiting for a free buf */
|
||||||
|
/* Some validated register values:
|
||||||
|
*/
|
||||||
|
u_int32_t mAccess;
|
||||||
|
} drm_mga_private_t;
|
||||||
|
|
||||||
|
/* mga_drv.c */
|
||||||
|
extern int mga_init(device_t);
|
||||||
|
extern void mga_cleanup(device_t);
|
||||||
|
extern d_ioctl_t mga_version;
|
||||||
|
extern d_open_t mga_open;
|
||||||
|
extern d_close_t mga_close;
|
||||||
|
extern d_ioctl_t mga_ioctl;
|
||||||
|
extern d_ioctl_t mga_unlock;
|
||||||
|
|
||||||
|
/* mga_dma.c */
|
||||||
|
extern int mga_dma_schedule(drm_device_t *dev, int locked);
|
||||||
|
extern int mga_irq_install(drm_device_t *dev, int irq);
|
||||||
|
extern int mga_irq_uninstall(drm_device_t *dev);
|
||||||
|
extern d_ioctl_t mga_dma;
|
||||||
|
extern d_ioctl_t mga_control;
|
||||||
|
extern d_ioctl_t mga_lock;
|
||||||
|
|
||||||
|
/* mga_dma_init does init and release */
|
||||||
|
extern int mga_dma_cleanup(drm_device_t *dev);
|
||||||
|
extern d_ioctl_t mga_dma_init;
|
||||||
|
extern d_ioctl_t mga_flush_ioctl;
|
||||||
|
extern void mga_flush_write_combine(void);
|
||||||
|
extern unsigned int mga_create_sync_tag(drm_device_t *dev);
|
||||||
|
extern drm_buf_t *mga_freelist_get(drm_device_t *dev);
|
||||||
|
extern int mga_freelist_put(drm_device_t *dev, drm_buf_t *buf);
|
||||||
|
extern int mga_advance_primary(drm_device_t *dev);
|
||||||
|
extern void mga_reclaim_buffers(drm_device_t *dev, pid_t pid);
|
||||||
|
|
||||||
|
/* mga_bufs.c */
|
||||||
|
extern d_ioctl_t mga_addbufs;
|
||||||
|
extern d_ioctl_t mga_infobufs;
|
||||||
|
extern d_ioctl_t mga_markbufs;
|
||||||
|
extern d_ioctl_t mga_freebufs;
|
||||||
|
extern d_ioctl_t mga_mapbufs;
|
||||||
|
extern d_ioctl_t mga_addmap;
|
||||||
|
/* mga_state.c */
|
||||||
|
extern d_ioctl_t mga_clear_bufs;
|
||||||
|
extern d_ioctl_t mga_swap_bufs;
|
||||||
|
extern d_ioctl_t mga_iload;
|
||||||
|
extern d_ioctl_t mga_vertex;
|
||||||
|
extern d_ioctl_t mga_indices;
|
||||||
|
/* mga_context.c */
|
||||||
|
extern d_ioctl_t mga_resctx;
|
||||||
|
extern d_ioctl_t mga_addctx;
|
||||||
|
extern d_ioctl_t mga_modctx;
|
||||||
|
extern d_ioctl_t mga_getctx;
|
||||||
|
extern d_ioctl_t mga_switchctx;
|
||||||
|
extern d_ioctl_t mga_newctx;
|
||||||
|
extern d_ioctl_t mga_rmctx;
|
||||||
|
|
||||||
|
extern int mga_context_switch(drm_device_t *dev, int old, int new);
|
||||||
|
extern int mga_context_switch_complete(drm_device_t *dev, int new);
|
||||||
|
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
TT_GENERAL,
|
||||||
|
TT_BLIT,
|
||||||
|
TT_VECTOR,
|
||||||
|
TT_VERTEX
|
||||||
|
} transferType_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
drm_mga_freelist_t *my_freelist;
|
||||||
|
int discard;
|
||||||
|
int dispatched;
|
||||||
|
} drm_mga_buf_priv_t;
|
||||||
|
|
||||||
|
#define DWGREG0 0x1c00
|
||||||
|
#define DWGREG0_END 0x1dff
|
||||||
|
#define DWGREG1 0x2c00
|
||||||
|
#define DWGREG1_END 0x2dff
|
||||||
|
|
||||||
|
#define ISREG0(r) (r >= DWGREG0 && r <= DWGREG0_END)
|
||||||
|
#define ADRINDEX0(r) (u_int8_t)((r - DWGREG0) >> 2)
|
||||||
|
#define ADRINDEX1(r) (u_int8_t)(((r - DWGREG1) >> 2) | 0x80)
|
||||||
|
#define ADRINDEX(r) (ISREG0(r) ? ADRINDEX0(r) : ADRINDEX1(r))
|
||||||
|
|
||||||
|
#define MGA_VERBOSE 0
|
||||||
|
#define MGA_NUM_PRIM_BUFS 8
|
||||||
|
|
||||||
|
#define PRIMLOCALS u_int8_t tempIndex[4]; u_int32_t *dma_ptr; u_int32_t phys_head; \
|
||||||
|
int outcount, num_dwords
|
||||||
|
|
||||||
|
#define PRIM_OVERFLOW(dev, dev_priv, length) do { \
|
||||||
|
drm_mga_prim_buf_t *tmp_buf = \
|
||||||
|
dev_priv->prim_bufs[dev_priv->current_prim_idx]; \
|
||||||
|
if( test_bit(MGA_BUF_NEEDS_OVERFLOW, \
|
||||||
|
&tmp_buf->buffer_status)) { \
|
||||||
|
mga_advance_primary(dev); \
|
||||||
|
mga_dma_schedule(dev, 1); \
|
||||||
|
} else if( tmp_buf->max_dwords - tmp_buf->num_dwords < length ||\
|
||||||
|
tmp_buf->sec_used > MGA_DMA_BUF_NR/2) { \
|
||||||
|
set_bit(MGA_BUF_FORCE_FIRE, &tmp_buf->buffer_status); \
|
||||||
|
mga_advance_primary(dev); \
|
||||||
|
mga_dma_schedule(dev, 1); \
|
||||||
|
} \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
|
#define PRIMGETPTR(dev_priv) do { \
|
||||||
|
drm_mga_prim_buf_t *tmp_buf = \
|
||||||
|
dev_priv->prim_bufs[dev_priv->current_prim_idx]; \
|
||||||
|
if(MGA_VERBOSE) \
|
||||||
|
DRM_DEBUG("PRIMGETPTR in %s\n", __FUNCTION__); \
|
||||||
|
dma_ptr = tmp_buf->current_dma_ptr; \
|
||||||
|
num_dwords = tmp_buf->num_dwords; \
|
||||||
|
phys_head = tmp_buf->phys_head; \
|
||||||
|
outcount = 0; \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
|
#define PRIMPTR(prim_buf) do { \
|
||||||
|
if(MGA_VERBOSE) \
|
||||||
|
DRM_DEBUG("PRIMPTR in %s\n", __FUNCTION__); \
|
||||||
|
dma_ptr = prim_buf->current_dma_ptr; \
|
||||||
|
num_dwords = prim_buf->num_dwords; \
|
||||||
|
phys_head = prim_buf->phys_head; \
|
||||||
|
outcount = 0; \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
|
#define PRIMFINISH(prim_buf) do { \
|
||||||
|
if (MGA_VERBOSE) { \
|
||||||
|
DRM_DEBUG( "PRIMFINISH in %s\n", __FUNCTION__); \
|
||||||
|
if (outcount & 3) \
|
||||||
|
DRM_DEBUG(" --- truncation\n"); \
|
||||||
|
} \
|
||||||
|
prim_buf->num_dwords = num_dwords; \
|
||||||
|
prim_buf->current_dma_ptr = dma_ptr; \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
|
#define PRIMADVANCE(dev_priv) do { \
|
||||||
|
drm_mga_prim_buf_t *tmp_buf = \
|
||||||
|
dev_priv->prim_bufs[dev_priv->current_prim_idx]; \
|
||||||
|
if (MGA_VERBOSE) { \
|
||||||
|
DRM_DEBUG("PRIMADVANCE in %s\n", __FUNCTION__); \
|
||||||
|
if (outcount & 3) \
|
||||||
|
DRM_DEBUG(" --- truncation\n"); \
|
||||||
|
} \
|
||||||
|
tmp_buf->num_dwords = num_dwords; \
|
||||||
|
tmp_buf->current_dma_ptr = dma_ptr; \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
#define PRIMUPDATE(dev_priv) do { \
|
||||||
|
drm_mga_prim_buf_t *tmp_buf = \
|
||||||
|
dev_priv->prim_bufs[dev_priv->current_prim_idx]; \
|
||||||
|
tmp_buf->sec_used++; \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
#define AGEBUF(dev_priv, buf_priv) do { \
|
||||||
|
drm_mga_prim_buf_t *tmp_buf = \
|
||||||
|
dev_priv->prim_bufs[dev_priv->current_prim_idx]; \
|
||||||
|
buf_priv->my_freelist->age = tmp_buf->prim_age; \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
|
||||||
|
#define PRIMOUTREG(reg, val) do { \
|
||||||
|
tempIndex[outcount]=ADRINDEX(reg); \
|
||||||
|
dma_ptr[1+outcount] = val; \
|
||||||
|
if (MGA_VERBOSE) \
|
||||||
|
DRM_DEBUG(" PRIMOUT %d: 0x%x -- 0x%x\n", \
|
||||||
|
num_dwords + 1 + outcount, ADRINDEX(reg), val); \
|
||||||
|
if( ++outcount == 4) { \
|
||||||
|
outcount = 0; \
|
||||||
|
dma_ptr[0] = *(u_int32_t *)tempIndex; \
|
||||||
|
dma_ptr+=5; \
|
||||||
|
num_dwords += 5; \
|
||||||
|
} \
|
||||||
|
}while (0)
|
||||||
|
|
||||||
|
/* A reduced set of the mga registers.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define MGAREG_MGA_EXEC 0x0100
|
||||||
|
#define MGAREG_ALPHACTRL 0x2c7c
|
||||||
|
#define MGAREG_AR0 0x1c60
|
||||||
|
#define MGAREG_AR1 0x1c64
|
||||||
|
#define MGAREG_AR2 0x1c68
|
||||||
|
#define MGAREG_AR3 0x1c6c
|
||||||
|
#define MGAREG_AR4 0x1c70
|
||||||
|
#define MGAREG_AR5 0x1c74
|
||||||
|
#define MGAREG_AR6 0x1c78
|
||||||
|
#define MGAREG_CXBNDRY 0x1c80
|
||||||
|
#define MGAREG_CXLEFT 0x1ca0
|
||||||
|
#define MGAREG_CXRIGHT 0x1ca4
|
||||||
|
#define MGAREG_DMAPAD 0x1c54
|
||||||
|
#define MGAREG_DSTORG 0x2cb8
|
||||||
|
#define MGAREG_DWGCTL 0x1c00
|
||||||
|
#define MGAREG_DWGSYNC 0x2c4c
|
||||||
|
#define MGAREG_FCOL 0x1c24
|
||||||
|
#define MGAREG_FIFOSTATUS 0x1e10
|
||||||
|
#define MGAREG_FOGCOL 0x1cf4
|
||||||
|
#define MGAREG_FXBNDRY 0x1c84
|
||||||
|
#define MGAREG_FXLEFT 0x1ca8
|
||||||
|
#define MGAREG_FXRIGHT 0x1cac
|
||||||
|
#define MGAREG_ICLEAR 0x1e18
|
||||||
|
#define MGAREG_IEN 0x1e1c
|
||||||
|
#define MGAREG_LEN 0x1c5c
|
||||||
|
#define MGAREG_MACCESS 0x1c04
|
||||||
|
#define MGAREG_PITCH 0x1c8c
|
||||||
|
#define MGAREG_PLNWT 0x1c1c
|
||||||
|
#define MGAREG_PRIMADDRESS 0x1e58
|
||||||
|
#define MGAREG_PRIMEND 0x1e5c
|
||||||
|
#define MGAREG_PRIMPTR 0x1e50
|
||||||
|
#define MGAREG_SECADDRESS 0x2c40
|
||||||
|
#define MGAREG_SECEND 0x2c44
|
||||||
|
#define MGAREG_SETUPADDRESS 0x2cd0
|
||||||
|
#define MGAREG_SETUPEND 0x2cd4
|
||||||
|
#define MGAREG_SOFTRAP 0x2c48
|
||||||
|
#define MGAREG_SRCORG 0x2cb4
|
||||||
|
#define MGAREG_STATUS 0x1e14
|
||||||
|
#define MGAREG_STENCIL 0x2cc8
|
||||||
|
#define MGAREG_STENCILCTL 0x2ccc
|
||||||
|
#define MGAREG_TDUALSTAGE0 0x2cf8
|
||||||
|
#define MGAREG_TDUALSTAGE1 0x2cfc
|
||||||
|
#define MGAREG_TEXBORDERCOL 0x2c5c
|
||||||
|
#define MGAREG_TEXCTL 0x2c30
|
||||||
|
#define MGAREG_TEXCTL2 0x2c3c
|
||||||
|
#define MGAREG_TEXFILTER 0x2c58
|
||||||
|
#define MGAREG_TEXHEIGHT 0x2c2c
|
||||||
|
#define MGAREG_TEXORG 0x2c24
|
||||||
|
#define MGAREG_TEXORG1 0x2ca4
|
||||||
|
#define MGAREG_TEXORG2 0x2ca8
|
||||||
|
#define MGAREG_TEXORG3 0x2cac
|
||||||
|
#define MGAREG_TEXORG4 0x2cb0
|
||||||
|
#define MGAREG_TEXTRANS 0x2c34
|
||||||
|
#define MGAREG_TEXTRANSHIGH 0x2c38
|
||||||
|
#define MGAREG_TEXWIDTH 0x2c28
|
||||||
|
#define MGAREG_WACCEPTSEQ 0x1dd4
|
||||||
|
#define MGAREG_WCODEADDR 0x1e6c
|
||||||
|
#define MGAREG_WFLAG 0x1dc4
|
||||||
|
#define MGAREG_WFLAG1 0x1de0
|
||||||
|
#define MGAREG_WFLAGNB 0x1e64
|
||||||
|
#define MGAREG_WFLAGNB1 0x1e08
|
||||||
|
#define MGAREG_WGETMSB 0x1dc8
|
||||||
|
#define MGAREG_WIADDR 0x1dc0
|
||||||
|
#define MGAREG_WIADDR2 0x1dd8
|
||||||
|
#define MGAREG_WMISC 0x1e70
|
||||||
|
#define MGAREG_WVRTXSZ 0x1dcc
|
||||||
|
#define MGAREG_YBOT 0x1c9c
|
||||||
|
#define MGAREG_YDST 0x1c90
|
||||||
|
#define MGAREG_YDSTLEN 0x1c88
|
||||||
|
#define MGAREG_YDSTORG 0x1c94
|
||||||
|
#define MGAREG_YTOP 0x1c98
|
||||||
|
#define MGAREG_ZORG 0x1c0c
|
||||||
|
|
||||||
|
#define PDEA_pagpxfer_enable 0x2
|
||||||
|
|
||||||
|
#define WIA_wmode_suspend 0x0
|
||||||
|
#define WIA_wmode_start 0x3
|
||||||
|
#define WIA_wagp_agp 0x4
|
||||||
|
|
||||||
|
#define DC_opcod_line_open 0x0
|
||||||
|
#define DC_opcod_autoline_open 0x1
|
||||||
|
#define DC_opcod_line_close 0x2
|
||||||
|
#define DC_opcod_autoline_close 0x3
|
||||||
|
#define DC_opcod_trap 0x4
|
||||||
|
#define DC_opcod_texture_trap 0x6
|
||||||
|
#define DC_opcod_bitblt 0x8
|
||||||
|
#define DC_opcod_iload 0x9
|
||||||
|
#define DC_atype_rpl 0x0
|
||||||
|
#define DC_atype_rstr 0x10
|
||||||
|
#define DC_atype_zi 0x30
|
||||||
|
#define DC_atype_blk 0x40
|
||||||
|
#define DC_atype_i 0x70
|
||||||
|
#define DC_linear_xy 0x0
|
||||||
|
#define DC_linear_linear 0x80
|
||||||
|
#define DC_zmode_nozcmp 0x0
|
||||||
|
#define DC_zmode_ze 0x200
|
||||||
|
#define DC_zmode_zne 0x300
|
||||||
|
#define DC_zmode_zlt 0x400
|
||||||
|
#define DC_zmode_zlte 0x500
|
||||||
|
#define DC_zmode_zgt 0x600
|
||||||
|
#define DC_zmode_zgte 0x700
|
||||||
|
#define DC_solid_disable 0x0
|
||||||
|
#define DC_solid_enable 0x800
|
||||||
|
#define DC_arzero_disable 0x0
|
||||||
|
#define DC_arzero_enable 0x1000
|
||||||
|
#define DC_sgnzero_disable 0x0
|
||||||
|
#define DC_sgnzero_enable 0x2000
|
||||||
|
#define DC_shftzero_disable 0x0
|
||||||
|
#define DC_shftzero_enable 0x4000
|
||||||
|
#define DC_bop_SHIFT 16
|
||||||
|
#define DC_trans_SHIFT 20
|
||||||
|
#define DC_bltmod_bmonolef 0x0
|
||||||
|
#define DC_bltmod_bmonowf 0x8000000
|
||||||
|
#define DC_bltmod_bplan 0x2000000
|
||||||
|
#define DC_bltmod_bfcol 0x4000000
|
||||||
|
#define DC_bltmod_bu32bgr 0x6000000
|
||||||
|
#define DC_bltmod_bu32rgb 0xe000000
|
||||||
|
#define DC_bltmod_bu24bgr 0x16000000
|
||||||
|
#define DC_bltmod_bu24rgb 0x1e000000
|
||||||
|
#define DC_pattern_disable 0x0
|
||||||
|
#define DC_pattern_enable 0x20000000
|
||||||
|
#define DC_transc_disable 0x0
|
||||||
|
#define DC_transc_enable 0x40000000
|
||||||
|
#define DC_clipdis_disable 0x0
|
||||||
|
#define DC_clipdis_enable 0x80000000
|
||||||
|
|
||||||
|
#define SETADD_mode_vertlist 0x0
|
||||||
|
|
||||||
|
|
||||||
|
#define MGA_CLEAR_CMD (DC_opcod_trap | DC_arzero_enable | \
|
||||||
|
DC_sgnzero_enable | DC_shftzero_enable | \
|
||||||
|
(0xC << DC_bop_SHIFT) | DC_clipdis_enable | \
|
||||||
|
DC_solid_enable | DC_transc_enable)
|
||||||
|
|
||||||
|
|
||||||
|
#define MGA_COPY_CMD (DC_opcod_bitblt | DC_atype_rpl | DC_linear_xy | \
|
||||||
|
DC_solid_disable | DC_arzero_disable | \
|
||||||
|
DC_sgnzero_enable | DC_shftzero_enable | \
|
||||||
|
(0xC << DC_bop_SHIFT) | DC_bltmod_bfcol | \
|
||||||
|
DC_pattern_disable | DC_transc_disable | \
|
||||||
|
DC_clipdis_enable) \
|
||||||
|
|
||||||
|
#define MGA_FLUSH_CMD (DC_opcod_texture_trap | (0xF << DC_trans_SHIFT) |\
|
||||||
|
DC_arzero_enable | DC_sgnzero_enable | \
|
||||||
|
DC_atype_i)
|
||||||
|
|
||||||
|
#endif
|
File diff suppressed because it is too large
Load Diff
|
@ -2,6 +2,7 @@
|
||||||
* Created: Tue Jan 25 01:50:01 1999 by jhartmann@precisioninsight.com
|
* Created: Tue Jan 25 01:50:01 1999 by jhartmann@precisioninsight.com
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -23,10 +24,9 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* Authors: Jeff Hartmann <jhartmann@precisioninsight.com>
|
* Authors: Jeff Hartmann <jhartmann@valinux.com>
|
||||||
* Keith Whitwell <keithw@precisioninsight.com>
|
* Keith Whitwell <keithw@valinux.com>
|
||||||
*
|
*
|
||||||
* $XFree86$
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _MGA_DRM_H_
|
#ifndef _MGA_DRM_H_
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* r128_drm.h -- Public header for the r128 driver
|
/* r128_drm.h -- Public header for the r128 driver -*- linux-c -*-
|
||||||
* Created: Wed Apr 5 19:24:19 2000 by kevin@precisioninsight.com
|
* Created: Wed Apr 5 19:24:19 2000 by kevin@precisioninsight.com
|
||||||
*
|
*
|
||||||
* Copyright 2000 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 2000 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
|
|
@ -4,7 +4,7 @@ KMOD = tdfx
|
||||||
SRCS = tdfx_drv.c tdfx_context.c
|
SRCS = tdfx_drv.c tdfx_context.c
|
||||||
SRCS += device_if.h bus_if.h pci_if.h
|
SRCS += device_if.h bus_if.h pci_if.h
|
||||||
CFLAGS += ${DEBUG_FLAGS} -I..
|
CFLAGS += ${DEBUG_FLAGS} -I..
|
||||||
KERN = /usr/src/sys
|
KMODDEPS = drm
|
||||||
|
|
||||||
@:
|
@:
|
||||||
ln -sf /sys @
|
ln -sf /sys @
|
||||||
|
@ -12,4 +12,4 @@ KERN = /usr/src/sys
|
||||||
machine:
|
machine:
|
||||||
ln -sf /sys/i386/include machine
|
ln -sf /sys/i386/include machine
|
||||||
|
|
||||||
.include "/usr/src/sys/conf/kmod.mk"
|
.include <bsd.kmod.mk>
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* tdfx_context.c -- IOCTLs for tdfx contexts -*- c -*-
|
/* tdfx_context.c -- IOCTLs for tdfx contexts -*- c -*-
|
||||||
* Created: Thu Oct 7 10:50:22 1999 by faith@precisioninsight.com
|
* Created: Thu Oct 7 10:50:22 1999 by faith@precisioninsight.com
|
||||||
* Revised: Sat Oct 9 23:39:56 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,9 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI$
|
* Authors:
|
||||||
* $XFree86$
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
|
* Daryll Strauss <daryll@valinux.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -36,9 +37,7 @@ extern drm_ctx_t tdfx_res_ctx;
|
||||||
|
|
||||||
static int tdfx_alloc_queue(drm_device_t *dev)
|
static int tdfx_alloc_queue(drm_device_t *dev)
|
||||||
{
|
{
|
||||||
static int context = 0;
|
return drm_ctxbitmap_next(dev);
|
||||||
|
|
||||||
return ++context; /* Should this reuse contexts in the future? */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int tdfx_context_switch(drm_device_t *dev, int old, int new)
|
int tdfx_context_switch(drm_device_t *dev, int old, int new)
|
||||||
|
@ -135,6 +134,12 @@ tdfx_addctx(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
ctx.handle = tdfx_alloc_queue(dev);
|
ctx.handle = tdfx_alloc_queue(dev);
|
||||||
}
|
}
|
||||||
DRM_DEBUG("%d\n", ctx.handle);
|
DRM_DEBUG("%d\n", ctx.handle);
|
||||||
|
if (ctx.handle == -1) {
|
||||||
|
DRM_DEBUG("Not enough free contexts.\n");
|
||||||
|
/* Should this return -EBUSY instead? */
|
||||||
|
return ENOMEM;
|
||||||
|
}
|
||||||
|
|
||||||
*(drm_ctx_t *) data = ctx;
|
*(drm_ctx_t *) data = ctx;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -189,13 +194,11 @@ tdfx_newctx(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
int
|
int
|
||||||
tdfx_rmctx(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
tdfx_rmctx(dev_t kdev, u_long cmd, caddr_t data, int flags, struct proc *p)
|
||||||
{
|
{
|
||||||
|
drm_device_t *dev = kdev->si_drv1;
|
||||||
drm_ctx_t ctx;
|
drm_ctx_t ctx;
|
||||||
|
|
||||||
ctx = *(drm_ctx_t *) data;
|
ctx = *(drm_ctx_t *) data;
|
||||||
DRM_DEBUG("%d\n", ctx.handle);
|
drm_ctxbitmap_free(dev, ctx.handle);
|
||||||
/* This is currently a noop because we
|
|
||||||
don't reuse context values. Perhaps we
|
|
||||||
should? */
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* tdfx.c -- tdfx driver -*- c -*-
|
/* tdfx.c -- tdfx driver -*- c -*-
|
||||||
* Created: Thu Oct 7 10:38:32 1999 by faith@precisioninsight.com
|
* Created: Thu Oct 7 10:38:32 1999 by faith@precisioninsight.com
|
||||||
* Revised: Tue Oct 12 08:51:35 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All Rights Reserved.
|
* All Rights Reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,9 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI$
|
* Authors:
|
||||||
* $XFree86$
|
* Rickard E. (Rik) Faith <faith@valinux.com>
|
||||||
|
* Daryll Strauss <daryll@valinux.com>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -35,13 +36,16 @@
|
||||||
#include <pci/pcivar.h>
|
#include <pci/pcivar.h>
|
||||||
|
|
||||||
MODULE_DEPEND(tdfx, drm, 1, 1, 1);
|
MODULE_DEPEND(tdfx, drm, 1, 1, 1);
|
||||||
|
#ifdef DRM_AGP
|
||||||
|
MODULE_DEPEND(tdfx, agp, 1, 1, 1);
|
||||||
|
#endif
|
||||||
|
|
||||||
#define TDFX_NAME "tdfx"
|
#define TDFX_NAME "tdfx"
|
||||||
#define TDFX_DESC "tdfx"
|
#define TDFX_DESC "tdfx"
|
||||||
#define TDFX_DATE "19991009"
|
#define TDFX_DATE "19991009"
|
||||||
#define TDFX_MAJOR 0
|
#define TDFX_MAJOR 1
|
||||||
#define TDFX_MINOR 0
|
#define TDFX_MINOR 0
|
||||||
#define TDFX_PATCHLEVEL 1
|
#define TDFX_PATCHLEVEL 0
|
||||||
|
|
||||||
static int tdfx_init(device_t nbdev);
|
static int tdfx_init(device_t nbdev);
|
||||||
static void tdfx_cleanup(device_t nbdev);
|
static void tdfx_cleanup(device_t nbdev);
|
||||||
|
@ -153,6 +157,16 @@ static drm_ioctl_desc_t tdfx_ioctls[] = {
|
||||||
[DRM_IOCTL_NR(DRM_IOCTL_LOCK)] = { tdfx_lock, 1, 0 },
|
[DRM_IOCTL_NR(DRM_IOCTL_LOCK)] = { tdfx_lock, 1, 0 },
|
||||||
[DRM_IOCTL_NR(DRM_IOCTL_UNLOCK)] = { tdfx_unlock, 1, 0 },
|
[DRM_IOCTL_NR(DRM_IOCTL_UNLOCK)] = { tdfx_unlock, 1, 0 },
|
||||||
[DRM_IOCTL_NR(DRM_IOCTL_FINISH)] = { drm_finish, 1, 0 },
|
[DRM_IOCTL_NR(DRM_IOCTL_FINISH)] = { drm_finish, 1, 0 },
|
||||||
|
#ifdef DRM_AGP
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_ACQUIRE)] = {drm_agp_acquire, 1, 1},
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_RELEASE)] = {drm_agp_release, 1, 1},
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_ENABLE)] = {drm_agp_enable, 1, 1},
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_INFO)] = {drm_agp_info, 1, 1},
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_ALLOC)] = {drm_agp_alloc, 1, 1},
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_FREE)] = {drm_agp_free, 1, 1},
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_BIND)] = {drm_agp_unbind, 1, 1},
|
||||||
|
[DRM_IOCTL_NR(DRM_IOCTL_AGP_UNBIND)] = {drm_agp_bind, 1, 1},
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
#define TDFX_IOCTL_COUNT DRM_ARRAY_SIZE(tdfx_ioctls)
|
#define TDFX_IOCTL_COUNT DRM_ARRAY_SIZE(tdfx_ioctls)
|
||||||
|
|
||||||
|
@ -259,6 +273,26 @@ tdfx_takedown(drm_device_t *dev)
|
||||||
}
|
}
|
||||||
dev->magiclist[i].head = dev->magiclist[i].tail = NULL;
|
dev->magiclist[i].head = dev->magiclist[i].tail = NULL;
|
||||||
}
|
}
|
||||||
|
#ifdef DRM_AGP
|
||||||
|
/* Clear AGP information */
|
||||||
|
if (dev->agp) {
|
||||||
|
drm_agp_mem_t *temp;
|
||||||
|
drm_agp_mem_t *temp_next;
|
||||||
|
|
||||||
|
temp = dev->agp->memory;
|
||||||
|
while(temp != NULL) {
|
||||||
|
temp_next = temp->next;
|
||||||
|
drm_free_agp(temp->handle, temp->pages);
|
||||||
|
drm_free(temp, sizeof(*temp), DRM_MEM_AGPLISTS);
|
||||||
|
temp = temp_next;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dev->agp->acquired)
|
||||||
|
agp_release(dev->agp->agpdev);
|
||||||
|
drm_free(dev->agp, sizeof(*dev->agp), DRM_MEM_AGPLISTS);
|
||||||
|
dev->agp = NULL;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Clear vma list (only built for debugging) */
|
/* Clear vma list (only built for debugging) */
|
||||||
if (dev->vmalist) {
|
if (dev->vmalist) {
|
||||||
|
@ -312,8 +346,6 @@ tdfx_takedown(drm_device_t *dev)
|
||||||
}
|
}
|
||||||
lockmgr(&dev->dev_lock, LK_RELEASE, 0, curproc);
|
lockmgr(&dev->dev_lock, LK_RELEASE, 0, curproc);
|
||||||
|
|
||||||
device_unbusy(dev->device);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -323,6 +355,7 @@ static int
|
||||||
tdfx_init(device_t nbdev)
|
tdfx_init(device_t nbdev)
|
||||||
{
|
{
|
||||||
drm_device_t *dev = device_get_softc(nbdev);
|
drm_device_t *dev = device_get_softc(nbdev);
|
||||||
|
int retcode;
|
||||||
|
|
||||||
DRM_DEBUG("\n");
|
DRM_DEBUG("\n");
|
||||||
|
|
||||||
|
@ -347,6 +380,16 @@ tdfx_init(device_t nbdev)
|
||||||
drm_sysctl_init(dev);
|
drm_sysctl_init(dev);
|
||||||
TAILQ_INIT(&dev->files);
|
TAILQ_INIT(&dev->files);
|
||||||
|
|
||||||
|
#ifdef DRM_AGP
|
||||||
|
dev->agp = drm_agp_init();
|
||||||
|
#endif
|
||||||
|
if((retcode = drm_ctxbitmap_init(dev))) {
|
||||||
|
DRM_ERROR("Cannot allocate memory for context bitmap.\n");
|
||||||
|
drm_sysctl_cleanup(dev);
|
||||||
|
tdfx_takedown(dev);
|
||||||
|
return retcode;
|
||||||
|
}
|
||||||
|
|
||||||
DRM_INFO("Initialized %s %d.%d.%d %s on minor %d\n",
|
DRM_INFO("Initialized %s %d.%d.%d %s on minor %d\n",
|
||||||
TDFX_NAME,
|
TDFX_NAME,
|
||||||
TDFX_MAJOR,
|
TDFX_MAJOR,
|
||||||
|
@ -372,7 +415,7 @@ tdfx_cleanup(device_t nbdev)
|
||||||
|
|
||||||
DRM_INFO("Module unloaded\n");
|
DRM_INFO("Module unloaded\n");
|
||||||
|
|
||||||
device_busy(dev->device);
|
drm_ctxbitmap_cleanup(dev);
|
||||||
tdfx_takedown(dev);
|
tdfx_takedown(dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -447,6 +490,7 @@ tdfx_close(dev_t kdev, int flags, int fmt, struct proc *p)
|
||||||
return EBUSY;
|
return EBUSY;
|
||||||
}
|
}
|
||||||
simple_unlock(&dev->count_lock);
|
simple_unlock(&dev->count_lock);
|
||||||
|
device_unbusy(dev->device);
|
||||||
return tdfx_takedown(dev);
|
return tdfx_takedown(dev);
|
||||||
}
|
}
|
||||||
simple_unlock(&dev->count_lock);
|
simple_unlock(&dev->count_lock);
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/* tdfx_drv.h -- Private header for tdfx driver -*- c -*-
|
/* tdfx_drv.h -- Private header for tdfx driver -*- c -*-
|
||||||
* Created: Thu Oct 7 10:40:04 1999 by faith@precisioninsight.com
|
* Created: Thu Oct 7 10:40:04 1999 by faith@precisioninsight.com
|
||||||
* Revised: Sat Oct 9 23:38:19 1999 by faith@precisioninsight.com
|
|
||||||
*
|
*
|
||||||
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
* Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
|
||||||
|
* Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
@ -24,8 +24,6 @@
|
||||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
* DEALINGS IN THE SOFTWARE.
|
* DEALINGS IN THE SOFTWARE.
|
||||||
*
|
*
|
||||||
* $PI$
|
|
||||||
* $XFree86$
|
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -351,7 +351,7 @@ typedef struct drm_agp_info {
|
||||||
#define DRM_IOCTL_I810_CLEAR DRM_IOW( 0x42, drm_i810_clear_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_FLUSH DRM_IO ( 0x43)
|
||||||
#define DRM_IOCTL_I810_GETAGE DRM_IO ( 0x44)
|
#define DRM_IOCTL_I810_GETAGE DRM_IO ( 0x44)
|
||||||
#define DRM_IOCTL_I810_GETBUF DRM_IOW( 0x45, drm_i810_dma_t)
|
#define DRM_IOCTL_I810_GETBUF DRM_IOWR(0x45, drm_i810_dma_t)
|
||||||
#define DRM_IOCTL_I810_SWAP DRM_IO ( 0x46)
|
#define DRM_IOCTL_I810_SWAP DRM_IO ( 0x46)
|
||||||
|
|
||||||
/* Rage 128 specific ioctls */
|
/* Rage 128 specific ioctls */
|
||||||
|
|
|
@ -351,7 +351,7 @@ typedef struct drm_agp_info {
|
||||||
#define DRM_IOCTL_I810_CLEAR DRM_IOW( 0x42, drm_i810_clear_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_FLUSH DRM_IO ( 0x43)
|
||||||
#define DRM_IOCTL_I810_GETAGE DRM_IO ( 0x44)
|
#define DRM_IOCTL_I810_GETAGE DRM_IO ( 0x44)
|
||||||
#define DRM_IOCTL_I810_GETBUF DRM_IOW( 0x45, drm_i810_dma_t)
|
#define DRM_IOCTL_I810_GETBUF DRM_IOWR(0x45, drm_i810_dma_t)
|
||||||
#define DRM_IOCTL_I810_SWAP DRM_IO ( 0x46)
|
#define DRM_IOCTL_I810_SWAP DRM_IO ( 0x46)
|
||||||
|
|
||||||
/* Rage 128 specific ioctls */
|
/* Rage 128 specific ioctls */
|
||||||
|
|
|
@ -351,7 +351,7 @@ typedef struct drm_agp_info {
|
||||||
#define DRM_IOCTL_I810_CLEAR DRM_IOW( 0x42, drm_i810_clear_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_FLUSH DRM_IO ( 0x43)
|
||||||
#define DRM_IOCTL_I810_GETAGE DRM_IO ( 0x44)
|
#define DRM_IOCTL_I810_GETAGE DRM_IO ( 0x44)
|
||||||
#define DRM_IOCTL_I810_GETBUF DRM_IOW( 0x45, drm_i810_dma_t)
|
#define DRM_IOCTL_I810_GETBUF DRM_IOWR(0x45, drm_i810_dma_t)
|
||||||
#define DRM_IOCTL_I810_SWAP DRM_IO ( 0x46)
|
#define DRM_IOCTL_I810_SWAP DRM_IO ( 0x46)
|
||||||
|
|
||||||
/* Rage 128 specific ioctls */
|
/* Rage 128 specific ioctls */
|
||||||
|
|
Loading…
Reference in New Issue