- Merge trunk into ati-5-0-0 branch

This commit is contained in:
Kevin E Martin 2001-01-05 19:42:02 +00:00
parent 71897876f1
commit 0885a6be6d
18 changed files with 317 additions and 121 deletions

View file

@ -6,6 +6,7 @@
# drm.o is a fake target -- it is never built # drm.o is a fake target -- it is never built
# The real targets are in the module-list # The real targets are in the module-list
O_TARGET := drm.o O_TARGET := drm.o
module-list := gamma.o tdfx.o r128.o radeon.o ffb.o mga.o i810.o module-list := gamma.o tdfx.o r128.o radeon.o ffb.o mga.o i810.o
export-objs := $(patsubst %.o,%_drv.o,$(module-list)) export-objs := $(patsubst %.o,%_drv.o,$(module-list))
@ -25,6 +26,11 @@ export-objs := $(patsubst %.o,%_drv.o,$(module-list))
# memory waste (in the dual-head case) for greatly improved long-term # memory waste (in the dual-head case) for greatly improved long-term
# maintainability. # maintainability.
# #
# NOTE: lib-objs will be eliminated in future versions, thereby
# eliminating the need to compile the .o files into every module, but
# for now we still need them.
#
lib-objs := init.o memory.o proc.o auth.o context.o drawable.o bufs.o lib-objs := init.o memory.o proc.o auth.o context.o drawable.o bufs.o
lib-objs += lists.o lock.o ioctl.o fops.o vm.o dma.o ctxbitmap.o lib-objs += lists.o lock.o ioctl.o fops.o vm.o dma.o ctxbitmap.o
@ -36,61 +42,67 @@ else
endif endif
endif endif
gamma-objs := $(lib-objs) gamma_drv.o gamma_dma.o gamma-objs := gamma_drv.o gamma_dma.o
tdfx-objs := $(lib-objs) tdfx_drv.o tdfx_context.o tdfx-objs := tdfx_drv.o tdfx_context.o
r128-objs := $(lib-objs) r128_drv.o r128_cce.o r128_context.o \ r128-objs := r128_drv.o r128_cce.o r128_context.o r128_bufs.o \
r128_bufs.o r128_state.o r128_state.o
radeon-objs := $(lib-objs) radeon_drv.o radeon_cp.o radeon_context.o \ radeon-objs := radeon_drv.o radeon_cp.o radeon_context.o radeon_bufs.o \
radeon_bufs.o radeon_state.o radeon_state.o
ffb-objs := $(lib-objs) ffb_drv.o ffb_context.o ffb-objs := ffb_drv.o ffb_context.o
mga-objs := $(lib-objs) mga_drv.o mga_dma.o mga_context.o \ mga-objs := mga_drv.o mga_dma.o mga_context.o mga_bufs.o \
mga_bufs.o mga_state.o mga_state.o
i810-objs := $(lib-objs) i810_drv.o i810_dma.o i810_context.o \ i810-objs := i810_drv.o i810_dma.o i810_context.o i810_bufs.o
i810_bufs.o
obj-$(CONFIG_DRM_GAMMA) += gamma.o $(gamma-objs) obj-$(CONFIG_DRM_GAMMA) += gamma.o
obj-$(CONFIG_DRM_TDFX) += tdfx.o $(tdfx-objs) obj-$(CONFIG_DRM_TDFX) += tdfx.o
obj-$(CONFIG_DRM_R128) += r128.o $(r128-objs) obj-$(CONFIG_DRM_R128) += r128.o
obj-$(CONFIG_DRM_RADEON) += radeon.o $(radeon-objs) obj-$(CONFIG_DRM_RADEON) += radeon.o
obj-$(CONFIG_DRM_FFB) += ffb.o $(ffb-objs) obj-$(CONFIG_DRM_FFB) += ffb.o
obj-$(CONFIG_DRM_MGA) += mga.o
obj-$(CONFIG_DRM_I810) += i810.o
ifneq ($CONFIG_AGP),)
obj-$(CONFIG_DRM_MGA) += mga.o $(mga-objs) # When linking into the kernel, link the library just once.
obj-$(CONFIG_DRM_I810) += i810.o $(i810-objs) # If making modules, we include the library into each module
lib-objs-mod := $(patsubst %.o,%-mod.o,$(lib-objs))
ifdef MAKING_MODULES
lib = drmlib-mod.a
else
obj-y += drmlib.a
endif endif
# Take module names out of obj-y and int-m
obj-y := $(filter-out $(module-list), $(obj-y))
int-m := $(filter-out $(module-list), $(obj-m))
# Translate to Rules.make lists.
O_OBJS := $(filter-out $(export-objs), $(obj-y))
OX_OBJS := $(filter $(export-objs), $(obj-y))
M_OBJS := $(sort $(filter $(module-list), $(obj-m)))
MI_OBJS := $(sort $(filter-out $(export-objs), $(int-m)))
MIX_OBJS := $(sort $(filter $(export-objs), $(int-m)))
include $(TOPDIR)/Rules.make include $(TOPDIR)/Rules.make
gamma.o: $(gamma-objs) $(patsubst %.o,%.c,$(lib-objs-mod)):
$(LD) -r -o $@ $(gamma-objs) @ln -sf $(subst -mod,,$@) $@
tdfx.o: $(tdfx-objs) drmlib-mod.a: $(lib-objs-mod)
$(LD) -r -o $@ $(tdfx-objs) rm -f $@
$(AR) $(EXTRA_ARFLAGS) rcs $@ $(lib-objs-mod)
mga.o: $(mga-objs) drmlib.a: $(lib-objs)
$(LD) -r -o $@ $(mga-objs) rm -f $@
$(AR) $(EXTRA_ARFLAGS) rcs $@ $(lib-objs)
i810.o: $(i810-objs) gamma.o: $(gamma-objs) $(lib)
$(LD) -r -o $@ $(i810-objs) $(LD) -r -o $@ $(gamma-objs) $(lib)
r128.o: $(r128-objs) tdfx.o: $(tdfx-objs) $(lib)
$(LD) -r -o $@ $(r128-objs) $(LD) -r -o $@ $(tdfx-objs) $(lib)
radeon.o: $(radeon-objs) mga.o: $(mga-objs) $(lib)
$(LD) -r -o $@ $(radeon-objs) $(LD) -r -o $@ $(mga-objs) $(lib)
ffb.o: $(ffb-objs) i810.o: $(i810-objs) $(lib)
$(LD) -r -o $@ $(ffb-objs) $(LD) -r -o $@ $(i810-objs) $(lib)
r128.o: $(r128-objs) $(lib)
$(LD) -r -o $@ $(r128-objs) $(lib)
radeon.o: $(radeon-objs) $(lib)
$(LD) -r -o $@ $(radeon-objs) $(lib)
ffb.o: $(ffb-objs) $(lib)
$(LD) -r -o $@ $(ffb-objs) $(lib)

View file

@ -924,7 +924,7 @@ int i810_irq_install(drm_device_t *dev, int irq)
dev->dma->next_queue = NULL; dev->dma->next_queue = NULL;
dev->dma->this_buffer = NULL; dev->dma->this_buffer = NULL;
dev->tq.next = NULL; INIT_LIST_HEAD(&dev->tq.list);
dev->tq.sync = 0; dev->tq.sync = 0;
dev->tq.routine = i810_dma_task_queue; dev->tq.routine = i810_dma_task_queue;
dev->tq.data = dev; dev->tq.data = dev;

View file

@ -38,7 +38,7 @@
#define MGA_DESC "Matrox G200/G400" #define MGA_DESC "Matrox G200/G400"
#define MGA_DATE "20000928" #define MGA_DATE "20000928"
#define MGA_MAJOR 2 #define MGA_MAJOR 2
#define MGA_MINOR 0 #define MGA_MINOR 1
#define MGA_PATCHLEVEL 1 #define MGA_PATCHLEVEL 1
static drm_device_t mga_device; static drm_device_t mga_device;
@ -114,6 +114,7 @@ static drm_ioctl_desc_t mga_ioctls[] = {
[DRM_IOCTL_NR(DRM_IOCTL_MGA_VERTEX)] = { mga_vertex, 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_FLUSH)] = { mga_flush_ioctl, 1, 0 },
[DRM_IOCTL_NR(DRM_IOCTL_MGA_INDICES)] = { mga_indices, 1, 0 }, [DRM_IOCTL_NR(DRM_IOCTL_MGA_INDICES)] = { mga_indices, 1, 0 },
[DRM_IOCTL_NR(DRM_IOCTL_MGA_BLIT)] = { mga_blit, 1, 0 },
}; };
#define MGA_IOCTL_COUNT DRM_ARRAY_SIZE(mga_ioctls) #define MGA_IOCTL_COUNT DRM_ARRAY_SIZE(mga_ioctls)
@ -502,7 +503,7 @@ int mga_release(struct inode *inode, struct file *filp)
if (dev->lock.hw_lock && _DRM_LOCK_IS_HELD(dev->lock.hw_lock->lock) if (dev->lock.hw_lock && _DRM_LOCK_IS_HELD(dev->lock.hw_lock->lock)
&& dev->lock.pid == current->pid) { && dev->lock.pid == current->pid) {
mga_reclaim_buffers(dev, priv->pid); mga_reclaim_buffers(dev, priv->pid);
DRM_INFO("Process %d dead (ctx %d, d_s = 0x%02x)\n", DRM_INFO("Process %d dead (ctx %d, d_s = 0x%02lx)\n",
current->pid, current->pid,
_DRM_LOCKING_CONTEXT(dev->lock.hw_lock->lock), _DRM_LOCKING_CONTEXT(dev->lock.hw_lock->lock),
dev->dev_private ? dev->dev_private ?

View file

@ -6,6 +6,7 @@
# drm.o is a fake target -- it is never built # drm.o is a fake target -- it is never built
# The real targets are in the module-list # The real targets are in the module-list
O_TARGET := drm.o O_TARGET := drm.o
module-list := gamma.o tdfx.o r128.o radeon.o ffb.o mga.o i810.o module-list := gamma.o tdfx.o r128.o radeon.o ffb.o mga.o i810.o
export-objs := $(patsubst %.o,%_drv.o,$(module-list)) export-objs := $(patsubst %.o,%_drv.o,$(module-list))
@ -25,6 +26,11 @@ export-objs := $(patsubst %.o,%_drv.o,$(module-list))
# memory waste (in the dual-head case) for greatly improved long-term # memory waste (in the dual-head case) for greatly improved long-term
# maintainability. # maintainability.
# #
# NOTE: lib-objs will be eliminated in future versions, thereby
# eliminating the need to compile the .o files into every module, but
# for now we still need them.
#
lib-objs := init.o memory.o proc.o auth.o context.o drawable.o bufs.o lib-objs := init.o memory.o proc.o auth.o context.o drawable.o bufs.o
lib-objs += lists.o lock.o ioctl.o fops.o vm.o dma.o ctxbitmap.o lib-objs += lists.o lock.o ioctl.o fops.o vm.o dma.o ctxbitmap.o
@ -36,61 +42,67 @@ else
endif endif
endif endif
gamma-objs := $(lib-objs) gamma_drv.o gamma_dma.o gamma-objs := gamma_drv.o gamma_dma.o
tdfx-objs := $(lib-objs) tdfx_drv.o tdfx_context.o tdfx-objs := tdfx_drv.o tdfx_context.o
r128-objs := $(lib-objs) r128_drv.o r128_cce.o r128_context.o \ r128-objs := r128_drv.o r128_cce.o r128_context.o r128_bufs.o \
r128_bufs.o r128_state.o r128_state.o
radeon-objs := $(lib-objs) radeon_drv.o radeon_cp.o radeon_context.o \ radeon-objs := radeon_drv.o radeon_cp.o radeon_context.o radeon_bufs.o \
radeon_bufs.o radeon_state.o radeon_state.o
ffb-objs := $(lib-objs) ffb_drv.o ffb_context.o ffb-objs := ffb_drv.o ffb_context.o
mga-objs := $(lib-objs) mga_drv.o mga_dma.o mga_context.o \ mga-objs := mga_drv.o mga_dma.o mga_context.o mga_bufs.o \
mga_bufs.o mga_state.o mga_state.o
i810-objs := $(lib-objs) i810_drv.o i810_dma.o i810_context.o \ i810-objs := i810_drv.o i810_dma.o i810_context.o i810_bufs.o
i810_bufs.o
obj-$(CONFIG_DRM_GAMMA) += gamma.o $(gamma-objs) obj-$(CONFIG_DRM_GAMMA) += gamma.o
obj-$(CONFIG_DRM_TDFX) += tdfx.o $(tdfx-objs) obj-$(CONFIG_DRM_TDFX) += tdfx.o
obj-$(CONFIG_DRM_R128) += r128.o $(r128-objs) obj-$(CONFIG_DRM_R128) += r128.o
obj-$(CONFIG_DRM_RADEON) += radeon.o $(radeon-objs) obj-$(CONFIG_DRM_RADEON) += radeon.o
obj-$(CONFIG_DRM_FFB) += ffb.o $(ffb-objs) obj-$(CONFIG_DRM_FFB) += ffb.o
obj-$(CONFIG_DRM_MGA) += mga.o
obj-$(CONFIG_DRM_I810) += i810.o
ifneq ($CONFIG_AGP),)
obj-$(CONFIG_DRM_MGA) += mga.o $(mga-objs) # When linking into the kernel, link the library just once.
obj-$(CONFIG_DRM_I810) += i810.o $(i810-objs) # If making modules, we include the library into each module
lib-objs-mod := $(patsubst %.o,%-mod.o,$(lib-objs))
ifdef MAKING_MODULES
lib = drmlib-mod.a
else
obj-y += drmlib.a
endif endif
# Take module names out of obj-y and int-m
obj-y := $(filter-out $(module-list), $(obj-y))
int-m := $(filter-out $(module-list), $(obj-m))
# Translate to Rules.make lists.
O_OBJS := $(filter-out $(export-objs), $(obj-y))
OX_OBJS := $(filter $(export-objs), $(obj-y))
M_OBJS := $(sort $(filter $(module-list), $(obj-m)))
MI_OBJS := $(sort $(filter-out $(export-objs), $(int-m)))
MIX_OBJS := $(sort $(filter $(export-objs), $(int-m)))
include $(TOPDIR)/Rules.make include $(TOPDIR)/Rules.make
gamma.o: $(gamma-objs) $(patsubst %.o,%.c,$(lib-objs-mod)):
$(LD) -r -o $@ $(gamma-objs) @ln -sf $(subst -mod,,$@) $@
tdfx.o: $(tdfx-objs) drmlib-mod.a: $(lib-objs-mod)
$(LD) -r -o $@ $(tdfx-objs) rm -f $@
$(AR) $(EXTRA_ARFLAGS) rcs $@ $(lib-objs-mod)
mga.o: $(mga-objs) drmlib.a: $(lib-objs)
$(LD) -r -o $@ $(mga-objs) rm -f $@
$(AR) $(EXTRA_ARFLAGS) rcs $@ $(lib-objs)
i810.o: $(i810-objs) gamma.o: $(gamma-objs) $(lib)
$(LD) -r -o $@ $(i810-objs) $(LD) -r -o $@ $(gamma-objs) $(lib)
r128.o: $(r128-objs) tdfx.o: $(tdfx-objs) $(lib)
$(LD) -r -o $@ $(r128-objs) $(LD) -r -o $@ $(tdfx-objs) $(lib)
radeon.o: $(radeon-objs) mga.o: $(mga-objs) $(lib)
$(LD) -r -o $@ $(radeon-objs) $(LD) -r -o $@ $(mga-objs) $(lib)
ffb.o: $(ffb-objs) i810.o: $(i810-objs) $(lib)
$(LD) -r -o $@ $(ffb-objs) $(LD) -r -o $@ $(i810-objs) $(lib)
r128.o: $(r128-objs) $(lib)
$(LD) -r -o $@ $(r128-objs) $(lib)
radeon.o: $(radeon-objs) $(lib)
$(LD) -r -o $@ $(radeon-objs) $(lib)
ffb.o: $(ffb-objs) $(lib)
$(LD) -r -o $@ $(ffb-objs) $(lib)

View file

@ -60,13 +60,6 @@ GAMMAHEADERS= gamma_drv.h $(DRMHEADERS)
TDFXOBJS= tdfx_drv.o tdfx_context.o TDFXOBJS= tdfx_drv.o tdfx_context.o
TDFXHEADERS= tdfx_drv.h $(DRMHEADERS) TDFXHEADERS= tdfx_drv.h $(DRMHEADERS)
R128OBJS= r128_drv.o r128_cce.o r128_bufs.o r128_context.o r128_state.o
R128HEADERS= r128_drv.h r128_drm.h $(DRMHEADERS)
RADEONOBJS= radeon_drv.o radeon_cp.o radeon_bufs.o radeon_context.o \
radeon_state.o
RADEONHEADERS= radeon_drv.h radeon_drm.h $(DRMHEADERS)
INC= /usr/include INC= /usr/include
CFLAGS= -O2 $(WARNINGS) CFLAGS= -O2 $(WARNINGS)
@ -147,6 +140,13 @@ MGAHEADERS= mga_drv.h $(DRMHEADERS)
I810OBJS= i810_drv.o i810_dma.o i810_bufs.o i810_context.o I810OBJS= i810_drv.o i810_dma.o i810_bufs.o i810_context.o
I810HEADERS= i810_drv.h $(DRMHEADERS) I810HEADERS= i810_drv.h $(DRMHEADERS)
R128OBJS= r128_drv.o r128_cce.o r128_bufs.o r128_context.o r128_state.o
R128HEADERS= r128_drv.h r128_drm.h $(DRMHEADERS)
RADEONOBJS= radeon_drv.o radeon_cp.o radeon_bufs.o radeon_context.o \
radeon_state.o
RADEONHEADERS= radeon_drv.h radeon_drm.h $(DRMHEADERS)
endif endif
ifeq ($(SIS),1) ifeq ($(SIS),1)
@ -160,6 +160,7 @@ MODS += sis.o
SISOBJS= sis_drv.o sis_context.o sis_ds.o sis_mm.o SISOBJS= sis_drv.o sis_context.o sis_ds.o sis_mm.o
SISHEADERS= sis_drv.h sis_ds.h sis_drm.h $(DRMHEADERS) SISHEADERS= sis_drv.h sis_ds.h sis_drm.h $(DRMHEADERS)
MODCFLAGS += -DCONFIG_DRM_SIS
endif endif
all::;@echo === KERNEL HEADERS IN $(TREE) all::;@echo === KERNEL HEADERS IN $(TREE)

View file

@ -42,4 +42,9 @@
#define __exit #define __exit
#endif #endif
/* This is a hack that only works for
this code base -- because we always
call this with dev->tq.* */
#define INIT_LIST_HEAD(pointer) dev->tq.next = NULL
#endif #endif

View file

@ -83,7 +83,9 @@ typedef struct drm_clip_rect {
#include "i810_drm.h" #include "i810_drm.h"
#include "r128_drm.h" #include "r128_drm.h"
#include "radeon_drm.h" #include "radeon_drm.h"
#ifdef CONFIG_DRM_SIS
#include "sis_drm.h" #include "sis_drm.h"
#endif
typedef struct drm_version { typedef struct drm_version {
int version_major; /* Major version */ int version_major; /* Major version */
@ -351,6 +353,7 @@ typedef struct drm_agp_info {
#define DRM_IOCTL_MGA_VERTEX DRM_IOW( 0x44, drm_mga_vertex_t) #define DRM_IOCTL_MGA_VERTEX DRM_IOW( 0x44, drm_mga_vertex_t)
#define DRM_IOCTL_MGA_FLUSH DRM_IOW( 0x45, drm_lock_t ) #define DRM_IOCTL_MGA_FLUSH DRM_IOW( 0x45, drm_lock_t )
#define DRM_IOCTL_MGA_INDICES DRM_IOW( 0x46, drm_mga_indices_t) #define DRM_IOCTL_MGA_INDICES DRM_IOW( 0x46, drm_mga_indices_t)
#define DRM_IOCTL_MGA_BLIT DRM_IOW( 0x47, drm_mga_blit_t)
/* I810 specific ioctls */ /* I810 specific ioctls */
#define DRM_IOCTL_I810_INIT DRM_IOW( 0x40, drm_i810_init_t) #define DRM_IOCTL_I810_INIT DRM_IOW( 0x40, drm_i810_init_t)
@ -396,6 +399,7 @@ typedef struct drm_agp_info {
#define DRM_IOCTL_RADEON_STIPPLE DRM_IOW( 0x4c, drm_radeon_stipple_t) #define DRM_IOCTL_RADEON_STIPPLE DRM_IOW( 0x4c, drm_radeon_stipple_t)
#define DRM_IOCTL_RADEON_INDIRECT DRM_IOWR(0x4d, drm_radeon_indirect_t) #define DRM_IOCTL_RADEON_INDIRECT DRM_IOWR(0x4d, drm_radeon_indirect_t)
#ifdef CONFIG_DRM_SIS
/* SiS specific ioctls */ /* SiS specific ioctls */
#define SIS_IOCTL_FB_ALLOC DRM_IOWR(0x44, drm_sis_mem_t) #define SIS_IOCTL_FB_ALLOC DRM_IOWR(0x44, drm_sis_mem_t)
#define SIS_IOCTL_FB_FREE DRM_IOW( 0x45, drm_sis_mem_t) #define SIS_IOCTL_FB_FREE DRM_IOW( 0x45, drm_sis_mem_t)
@ -405,5 +409,6 @@ typedef struct drm_agp_info {
#define SIS_IOCTL_FLIP DRM_IOW( 0x48, drm_sis_flip_t) #define SIS_IOCTL_FLIP DRM_IOW( 0x48, drm_sis_flip_t)
#define SIS_IOCTL_FLIP_INIT DRM_IO( 0x49) #define SIS_IOCTL_FLIP_INIT DRM_IO( 0x49)
#define SIS_IOCTL_FLIP_FINAL DRM_IO( 0x50) #define SIS_IOCTL_FLIP_FINAL DRM_IO( 0x50)
#endif
#endif #endif

View file

@ -651,7 +651,7 @@ int gamma_irq_install(drm_device_t *dev, int irq)
dev->dma->next_queue = NULL; dev->dma->next_queue = NULL;
dev->dma->this_buffer = NULL; dev->dma->this_buffer = NULL;
dev->tq.next = NULL; INIT_LIST_HEAD(&dev->tq.list);
dev->tq.sync = 0; dev->tq.sync = 0;
dev->tq.routine = gamma_dma_schedule_tq_wrapper; dev->tq.routine = gamma_dma_schedule_tq_wrapper;
dev->tq.data = dev; dev->tq.data = dev;

View file

@ -924,7 +924,7 @@ int i810_irq_install(drm_device_t *dev, int irq)
dev->dma->next_queue = NULL; dev->dma->next_queue = NULL;
dev->dma->this_buffer = NULL; dev->dma->this_buffer = NULL;
dev->tq.next = NULL; INIT_LIST_HEAD(&dev->tq.list);
dev->tq.sync = 0; dev->tq.sync = 0;
dev->tq.routine = i810_dma_task_queue; dev->tq.routine = i810_dma_task_queue;
dev->tq.data = dev; dev->tq.data = dev;

View file

@ -143,7 +143,7 @@ static inline void mga_dma_quiescent(drm_device_t *dev)
unsigned long end; unsigned long end;
int i; int i;
DRM_DEBUG("dispatch_status = 0x%02x\n", dev_priv->dispatch_status); DRM_DEBUG("dispatch_status = 0x%02lx\n", dev_priv->dispatch_status);
end = jiffies + (HZ*3); end = jiffies + (HZ*3);
while(1) { while(1) {
if(!test_and_set_bit(MGA_IN_DISPATCH, if(!test_and_set_bit(MGA_IN_DISPATCH,
@ -154,7 +154,7 @@ static inline void mga_dma_quiescent(drm_device_t *dev)
DRM_ERROR("irqs: %d wanted %d\n", DRM_ERROR("irqs: %d wanted %d\n",
atomic_read(&dev->total_irq), atomic_read(&dev->total_irq),
atomic_read(&dma->total_lost)); atomic_read(&dma->total_lost));
DRM_ERROR("lockup: dispatch_status = 0x%02x," DRM_ERROR("lockup: dispatch_status = 0x%02lx,"
" jiffies = %lu, end = %lu\n", " jiffies = %lu, end = %lu\n",
dev_priv->dispatch_status, jiffies, end); dev_priv->dispatch_status, jiffies, end);
return; return;
@ -177,7 +177,7 @@ static inline void mga_dma_quiescent(drm_device_t *dev)
sarea_priv->dirty |= MGA_DMA_FLUSH; sarea_priv->dirty |= MGA_DMA_FLUSH;
clear_bit(MGA_IN_DISPATCH, &dev_priv->dispatch_status); clear_bit(MGA_IN_DISPATCH, &dev_priv->dispatch_status);
DRM_DEBUG("exit, dispatch_status = 0x%02x\n", DRM_DEBUG("exit, dispatch_status = 0x%02lx\n",
dev_priv->dispatch_status); dev_priv->dispatch_status);
} }
@ -818,7 +818,7 @@ int mga_irq_install(drm_device_t *dev, int irq)
dev->dma->next_buffer = NULL; dev->dma->next_buffer = NULL;
dev->dma->next_queue = NULL; dev->dma->next_queue = NULL;
dev->dma->this_buffer = NULL; dev->dma->this_buffer = NULL;
dev->tq.next = NULL; INIT_LIST_HEAD(&dev->tq.list);
dev->tq.sync = 0; dev->tq.sync = 0;
dev->tq.routine = mga_dma_task_queue; dev->tq.routine = mga_dma_task_queue;
dev->tq.data = dev; dev->tq.data = dev;

View file

@ -271,4 +271,14 @@ typedef struct _drm_mga_indices {
int discard; /* client finished with buffer? */ int discard; /* client finished with buffer? */
} drm_mga_indices_t; } drm_mga_indices_t;
typedef struct _drm_mga_blit {
unsigned int planemask;
unsigned int source;
unsigned int dest;
int delta_sx, delta_sy;
int delta_dx, delta_dy;
int height, ydir; /* flip image vertically */
int source_pitch, dest_pitch;
} drm_mga_blit_t;
#endif #endif

View file

@ -38,7 +38,7 @@
#define MGA_DESC "Matrox G200/G400" #define MGA_DESC "Matrox G200/G400"
#define MGA_DATE "20000928" #define MGA_DATE "20000928"
#define MGA_MAJOR 2 #define MGA_MAJOR 2
#define MGA_MINOR 0 #define MGA_MINOR 1
#define MGA_PATCHLEVEL 1 #define MGA_PATCHLEVEL 1
static drm_device_t mga_device; static drm_device_t mga_device;
@ -114,6 +114,7 @@ static drm_ioctl_desc_t mga_ioctls[] = {
[DRM_IOCTL_NR(DRM_IOCTL_MGA_VERTEX)] = { mga_vertex, 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_FLUSH)] = { mga_flush_ioctl, 1, 0 },
[DRM_IOCTL_NR(DRM_IOCTL_MGA_INDICES)] = { mga_indices, 1, 0 }, [DRM_IOCTL_NR(DRM_IOCTL_MGA_INDICES)] = { mga_indices, 1, 0 },
[DRM_IOCTL_NR(DRM_IOCTL_MGA_BLIT)] = { mga_blit, 1, 0 },
}; };
#define MGA_IOCTL_COUNT DRM_ARRAY_SIZE(mga_ioctls) #define MGA_IOCTL_COUNT DRM_ARRAY_SIZE(mga_ioctls)
@ -502,7 +503,7 @@ int mga_release(struct inode *inode, struct file *filp)
if (dev->lock.hw_lock && _DRM_LOCK_IS_HELD(dev->lock.hw_lock->lock) if (dev->lock.hw_lock && _DRM_LOCK_IS_HELD(dev->lock.hw_lock->lock)
&& dev->lock.pid == current->pid) { && dev->lock.pid == current->pid) {
mga_reclaim_buffers(dev, priv->pid); mga_reclaim_buffers(dev, priv->pid);
DRM_INFO("Process %d dead (ctx %d, d_s = 0x%02x)\n", DRM_INFO("Process %d dead (ctx %d, d_s = 0x%02lx)\n",
current->pid, current->pid,
_DRM_LOCKING_CONTEXT(dev->lock.hw_lock->lock), _DRM_LOCKING_CONTEXT(dev->lock.hw_lock->lock),
dev->dev_private ? dev->dev_private ?

View file

@ -38,7 +38,7 @@
#define MGA_BUF_NEEDS_OVERFLOW 3 #define MGA_BUF_NEEDS_OVERFLOW 3
typedef struct { typedef struct {
u32 buffer_status; long buffer_status; /* long req'd for set_bit() --RR */
int num_dwords; int num_dwords;
int max_dwords; int max_dwords;
u32 *current_dma_ptr; u32 *current_dma_ptr;
@ -62,7 +62,7 @@ typedef struct _drm_mga_freelist {
#define MGA_IN_GETBUF 3 #define MGA_IN_GETBUF 3
typedef struct _drm_mga_private { typedef struct _drm_mga_private {
u32 dispatch_status; long dispatch_status; /* long req'd for set_bit() --RR */
unsigned int next_prim_age; unsigned int next_prim_age;
__volatile__ unsigned int last_prim_age; __volatile__ unsigned int last_prim_age;
int reserved_map_idx; int reserved_map_idx;
@ -160,6 +160,8 @@ extern int mga_vertex(struct inode *inode, struct file *filp,
unsigned int cmd, unsigned long arg); unsigned int cmd, unsigned long arg);
extern int mga_indices(struct inode *inode, struct file *filp, extern int mga_indices(struct inode *inode, struct file *filp,
unsigned int cmd, unsigned long arg); unsigned int cmd, unsigned long arg);
extern int mga_blit(struct inode *inode, struct file *filp,
unsigned int cmd, unsigned long arg);
/* mga_context.c */ /* mga_context.c */
extern int mga_resctx(struct inode *inode, struct file *filp, extern int mga_resctx(struct inode *inode, struct file *filp,
unsigned int cmd, unsigned long arg); unsigned int cmd, unsigned long arg);
@ -339,6 +341,7 @@ drm_mga_prim_buf_t *tmp_buf = \
#define MGAREG_SECEND 0x2c44 #define MGAREG_SECEND 0x2c44
#define MGAREG_SETUPADDRESS 0x2cd0 #define MGAREG_SETUPADDRESS 0x2cd0
#define MGAREG_SETUPEND 0x2cd4 #define MGAREG_SETUPEND 0x2cd4
#define MGAREG_SGN 0x1c58
#define MGAREG_SOFTRAP 0x2c48 #define MGAREG_SOFTRAP 0x2c48
#define MGAREG_SRCORG 0x2cb4 #define MGAREG_SRCORG 0x2cb4
#define MGAREG_STATUS 0x1e14 #define MGAREG_STATUS 0x1e14
@ -497,6 +500,12 @@ drm_mga_prim_buf_t *tmp_buf = \
#define DC_clipdis_enable 0x80000000 #define DC_clipdis_enable 0x80000000
#define SO_srcacc_pci 0x0
#define SO_srcacc_agp 0x2
#define SO_srcmap_fb 0x0
#define SO_srcmap_sys 0x1
#define SETADD_mode_vertlist 0x0 #define SETADD_mode_vertlist 0x0

View file

@ -491,6 +491,8 @@ static void mga_dma_dispatch_tex_blit(drm_device_t * dev,
int length, unsigned int destOrg) int length, unsigned int destOrg)
{ {
drm_mga_private_t *dev_priv = dev->dev_private; drm_mga_private_t *dev_priv = dev->dev_private;
drm_mga_sarea_t *sarea_priv = dev_priv->sarea_priv;
unsigned int *regs = sarea_priv->ContextState;
int use_agp = PDEA_pagpxfer_enable | 0x00000001; int use_agp = PDEA_pagpxfer_enable | 0x00000001;
u16 y2; u16 y2;
PRIMLOCALS; PRIMLOCALS;
@ -505,7 +507,7 @@ static void mga_dma_dispatch_tex_blit(drm_device_t * dev,
PRIMOUTREG(MGAREG_AR5, 64); PRIMOUTREG(MGAREG_AR5, 64);
PRIMOUTREG(MGAREG_PITCH, 64); PRIMOUTREG(MGAREG_PITCH, 64);
PRIMOUTREG(MGAREG_DMAPAD, 0); PRIMOUTREG(MGAREG_PLNWT, ~0);
PRIMOUTREG(MGAREG_DMAPAD, 0); PRIMOUTREG(MGAREG_DMAPAD, 0);
PRIMOUTREG(MGAREG_DWGCTL, MGA_COPY_CMD); PRIMOUTREG(MGAREG_DWGCTL, MGA_COPY_CMD);
@ -514,7 +516,7 @@ static void mga_dma_dispatch_tex_blit(drm_device_t * dev,
PRIMOUTREG(MGAREG_FXBNDRY, (63 << 16)); PRIMOUTREG(MGAREG_FXBNDRY, (63 << 16));
PRIMOUTREG(MGAREG_YDSTLEN + MGAREG_MGA_EXEC, y2); PRIMOUTREG(MGAREG_YDSTLEN + MGAREG_MGA_EXEC, y2);
PRIMOUTREG(MGAREG_DMAPAD, 0); PRIMOUTREG(MGAREG_PLNWT, regs[MGA_CTXREG_PLNWT]);
PRIMOUTREG(MGAREG_SRCORG, 0); PRIMOUTREG(MGAREG_SRCORG, 0);
PRIMOUTREG(MGAREG_PITCH, dev_priv->stride / dev_priv->cpp); PRIMOUTREG(MGAREG_PITCH, dev_priv->stride / dev_priv->cpp);
PRIMOUTREG(MGAREG_DWGSYNC, 0x7000); PRIMOUTREG(MGAREG_DWGSYNC, 0x7000);
@ -691,7 +693,7 @@ static void mga_dma_dispatch_clear(drm_device_t * dev, int flags,
/* Force reset of DWGCTL */ /* Force reset of DWGCTL */
PRIMOUTREG(MGAREG_DMAPAD, 0); PRIMOUTREG(MGAREG_DMAPAD, 0);
PRIMOUTREG(MGAREG_DMAPAD, 0); PRIMOUTREG(MGAREG_DMAPAD, 0);
PRIMOUTREG(MGAREG_DMAPAD, 0); PRIMOUTREG(MGAREG_PLNWT, regs[MGA_CTXREG_PLNWT]);
PRIMOUTREG(MGAREG_DWGCTL, regs[MGA_CTXREG_DWGCTL]); PRIMOUTREG(MGAREG_DWGCTL, regs[MGA_CTXREG_DWGCTL]);
PRIMADVANCE(dev_priv); PRIMADVANCE(dev_priv);
} }
@ -722,7 +724,7 @@ static void mga_dma_dispatch_swap(drm_device_t * dev)
PRIMOUTREG(MGAREG_DMAPAD, 0); PRIMOUTREG(MGAREG_DMAPAD, 0);
PRIMOUTREG(MGAREG_DMAPAD, 0); PRIMOUTREG(MGAREG_DMAPAD, 0);
PRIMOUTREG(MGAREG_DMAPAD, 0); PRIMOUTREG(MGAREG_PLNWT, ~0);
PRIMOUTREG(MGAREG_DWGCTL, MGA_COPY_CMD); PRIMOUTREG(MGAREG_DWGCTL, MGA_COPY_CMD);
for (i = 0; i < nbox; i++) { for (i = 0; i < nbox; i++) {
@ -739,13 +741,141 @@ static void mga_dma_dispatch_swap(drm_device_t * dev)
/* Force reset of DWGCTL */ /* Force reset of DWGCTL */
PRIMOUTREG(MGAREG_DMAPAD, 0); PRIMOUTREG(MGAREG_DMAPAD, 0);
PRIMOUTREG(MGAREG_DMAPAD, 0); PRIMOUTREG(MGAREG_PLNWT, regs[MGA_CTXREG_PLNWT]);
PRIMOUTREG(MGAREG_SRCORG, 0); PRIMOUTREG(MGAREG_SRCORG, 0);
PRIMOUTREG(MGAREG_DWGCTL, regs[MGA_CTXREG_DWGCTL]); PRIMOUTREG(MGAREG_DWGCTL, regs[MGA_CTXREG_DWGCTL]);
PRIMADVANCE(dev_priv); PRIMADVANCE(dev_priv);
} }
/* #define BLIT_LEFT 1 */
/* #define BLIT_UP 4 */
static void mga_dma_dispatch_blit(drm_device_t * dev,
unsigned int planemask,
unsigned int source,
unsigned int dest,
int delta_sx, int delta_sy,
int delta_dx, int delta_dy,
int source_pitch,
int dest_pitch,
int height,
int ydir)
{
drm_mga_private_t *dev_priv = dev->dev_private;
drm_mga_sarea_t *sarea_priv = dev_priv->sarea_priv;
unsigned int *regs = sarea_priv->ContextState;
int nbox = sarea_priv->nbox;
drm_clip_rect_t *pbox = sarea_priv->boxes;
int pixel_stride = dev_priv->stride / dev_priv->cpp;
u32 scandir = 0, i;
PRIMLOCALS;
PRIM_OVERFLOW(dev, dev_priv, (MGA_NR_SAREA_CLIPRECTS * 5) + 20);
PRIMOUTREG(MGAREG_DMAPAD, 0);
PRIMOUTREG(MGAREG_DMAPAD, 0);
PRIMOUTREG(MGAREG_DWGSYNC, 0x7100);
PRIMOUTREG(MGAREG_DWGSYNC, 0x7000);
PRIMOUTREG(MGAREG_DWGCTL, MGA_COPY_CMD);
PRIMOUTREG(MGAREG_PLNWT, planemask);
PRIMOUTREG(MGAREG_SRCORG, source);
PRIMOUTREG(MGAREG_DSTORG, dest);
PRIMOUTREG(MGAREG_SGN, scandir);
PRIMOUTREG(MGAREG_MACCESS, dev_priv->mAccess);
PRIMOUTREG(MGAREG_AR5, ydir * source_pitch);
PRIMOUTREG(MGAREG_PITCH, dest_pitch);
for (i = 0; i < nbox; i++) {
int srcx = pbox[i].x1 + delta_sx;
int srcy = pbox[i].y1 + delta_sy;
int dstx = pbox[i].x1 + delta_dx;
int dsty = pbox[i].y1 + delta_dy;
int h = pbox[i].y2 - pbox[i].y1;
int w = pbox[i].x2 - pbox[i].x1 - 1;
int start;
if (ydir == -1) {
srcy = height - srcy - 1;
}
start = srcy * source_pitch + srcx;
PRIMOUTREG(MGAREG_AR0, start + w);
PRIMOUTREG(MGAREG_AR3, start);
PRIMOUTREG(MGAREG_FXBNDRY, ((dstx+w) << 16) | (dstx & 0xffff));
PRIMOUTREG(MGAREG_YDSTLEN + MGAREG_MGA_EXEC, (dsty << 16) | h);
}
/* Do something to flush AGP?
*/
/* Force reset of DWGCTL */
PRIMOUTREG(MGAREG_DMAPAD, 0);
PRIMOUTREG(MGAREG_PLNWT, regs[MGA_CTXREG_PLNWT]);
PRIMOUTREG(MGAREG_PITCH, pixel_stride);
PRIMOUTREG(MGAREG_DWGCTL, regs[MGA_CTXREG_DWGCTL]);
PRIMADVANCE(dev_priv);
}
int mga_blit(struct inode *inode, struct file *filp,
unsigned int cmd, unsigned long arg)
{
drm_file_t *priv = filp->private_data;
drm_device_t *dev = priv->dev;
drm_mga_private_t *dev_priv =
(drm_mga_private_t *) dev->dev_private;
drm_mga_sarea_t *sarea_priv = dev_priv->sarea_priv;
drm_mga_blit_t blit;
if (copy_from_user(&blit, (drm_mga_blit_t *) arg, sizeof(blit)))
return -EFAULT;
DRM_DEBUG("%s\n", __FUNCTION__);
if (!_DRM_LOCK_IS_HELD(dev->lock.hw_lock->lock)) {
DRM_ERROR("mga_blit_bufs called without lock held\n");
return -EINVAL;
}
if (sarea_priv->nbox > MGA_NR_SAREA_CLIPRECTS)
sarea_priv->nbox = MGA_NR_SAREA_CLIPRECTS;
/* Make sure we restore the 3D state next time.
*/
dev_priv->sarea_priv->dirty |= MGA_UPLOAD_CTX;
if ((blit.source & 0x3) != (SO_srcmap_sys|SO_srcacc_pci) &&
(blit.dest & 0x3) != (SO_srcmap_sys|SO_srcacc_pci))
{
mga_dma_dispatch_blit(dev,
blit.planemask,
blit.source,
blit.dest,
blit.delta_sx, blit.delta_sy,
blit.delta_dx, blit.delta_dy,
blit.source_pitch,
blit.dest_pitch,
blit.height,
blit.ydir);
}
PRIMUPDATE(dev_priv);
#ifdef __i386__
mga_flush_write_combine();
#endif
mga_dma_schedule(dev, 1);
return 0;
}
int mga_clear_bufs(struct inode *inode, struct file *filp, int mga_clear_bufs(struct inode *inode, struct file *filp,
unsigned int cmd, unsigned long arg) unsigned int cmd, unsigned long arg)
{ {

View file

@ -24,8 +24,8 @@
* DEALINGS IN THE SOFTWARE. * DEALINGS IN THE SOFTWARE.
* *
* Authors: * Authors:
* Gareth Hughes <gareth@valinux.com>
* Kevin E. Martin <martin@valinux.com> * Kevin E. Martin <martin@valinux.com>
* Gareth Hughes <gareth@valinux.com>
* *
*/ */

View file

@ -23,8 +23,8 @@
* DEALINGS IN THE SOFTWARE. * DEALINGS IN THE SOFTWARE.
* *
* Authors: * Authors:
* Gareth Hughes <gareth@valinux.com>
* Kevin E. Martin <martin@valinux.com> * Kevin E. Martin <martin@valinux.com>
* Gareth Hughes <gareth@valinux.com>
* *
*/ */

View file

@ -83,7 +83,9 @@ typedef struct drm_clip_rect {
#include "i810_drm.h" #include "i810_drm.h"
#include "r128_drm.h" #include "r128_drm.h"
#include "radeon_drm.h" #include "radeon_drm.h"
#ifdef CONFIG_DRM_SIS
#include "sis_drm.h" #include "sis_drm.h"
#endif
typedef struct drm_version { typedef struct drm_version {
int version_major; /* Major version */ int version_major; /* Major version */
@ -351,6 +353,7 @@ typedef struct drm_agp_info {
#define DRM_IOCTL_MGA_VERTEX DRM_IOW( 0x44, drm_mga_vertex_t) #define DRM_IOCTL_MGA_VERTEX DRM_IOW( 0x44, drm_mga_vertex_t)
#define DRM_IOCTL_MGA_FLUSH DRM_IOW( 0x45, drm_lock_t ) #define DRM_IOCTL_MGA_FLUSH DRM_IOW( 0x45, drm_lock_t )
#define DRM_IOCTL_MGA_INDICES DRM_IOW( 0x46, drm_mga_indices_t) #define DRM_IOCTL_MGA_INDICES DRM_IOW( 0x46, drm_mga_indices_t)
#define DRM_IOCTL_MGA_BLIT DRM_IOW( 0x47, drm_mga_blit_t)
/* I810 specific ioctls */ /* I810 specific ioctls */
#define DRM_IOCTL_I810_INIT DRM_IOW( 0x40, drm_i810_init_t) #define DRM_IOCTL_I810_INIT DRM_IOW( 0x40, drm_i810_init_t)
@ -396,6 +399,7 @@ typedef struct drm_agp_info {
#define DRM_IOCTL_RADEON_STIPPLE DRM_IOW( 0x4c, drm_radeon_stipple_t) #define DRM_IOCTL_RADEON_STIPPLE DRM_IOW( 0x4c, drm_radeon_stipple_t)
#define DRM_IOCTL_RADEON_INDIRECT DRM_IOWR(0x4d, drm_radeon_indirect_t) #define DRM_IOCTL_RADEON_INDIRECT DRM_IOWR(0x4d, drm_radeon_indirect_t)
#ifdef CONFIG_DRM_SIS
/* SiS specific ioctls */ /* SiS specific ioctls */
#define SIS_IOCTL_FB_ALLOC DRM_IOWR(0x44, drm_sis_mem_t) #define SIS_IOCTL_FB_ALLOC DRM_IOWR(0x44, drm_sis_mem_t)
#define SIS_IOCTL_FB_FREE DRM_IOW( 0x45, drm_sis_mem_t) #define SIS_IOCTL_FB_FREE DRM_IOW( 0x45, drm_sis_mem_t)
@ -405,5 +409,6 @@ typedef struct drm_agp_info {
#define SIS_IOCTL_FLIP DRM_IOW( 0x48, drm_sis_flip_t) #define SIS_IOCTL_FLIP DRM_IOW( 0x48, drm_sis_flip_t)
#define SIS_IOCTL_FLIP_INIT DRM_IO( 0x49) #define SIS_IOCTL_FLIP_INIT DRM_IO( 0x49)
#define SIS_IOCTL_FLIP_FINAL DRM_IO( 0x50) #define SIS_IOCTL_FLIP_FINAL DRM_IO( 0x50)
#endif
#endif #endif

View file

@ -83,7 +83,9 @@ typedef struct drm_clip_rect {
#include "i810_drm.h" #include "i810_drm.h"
#include "r128_drm.h" #include "r128_drm.h"
#include "radeon_drm.h" #include "radeon_drm.h"
#ifdef CONFIG_DRM_SIS
#include "sis_drm.h" #include "sis_drm.h"
#endif
typedef struct drm_version { typedef struct drm_version {
int version_major; /* Major version */ int version_major; /* Major version */
@ -351,6 +353,7 @@ typedef struct drm_agp_info {
#define DRM_IOCTL_MGA_VERTEX DRM_IOW( 0x44, drm_mga_vertex_t) #define DRM_IOCTL_MGA_VERTEX DRM_IOW( 0x44, drm_mga_vertex_t)
#define DRM_IOCTL_MGA_FLUSH DRM_IOW( 0x45, drm_lock_t ) #define DRM_IOCTL_MGA_FLUSH DRM_IOW( 0x45, drm_lock_t )
#define DRM_IOCTL_MGA_INDICES DRM_IOW( 0x46, drm_mga_indices_t) #define DRM_IOCTL_MGA_INDICES DRM_IOW( 0x46, drm_mga_indices_t)
#define DRM_IOCTL_MGA_BLIT DRM_IOW( 0x47, drm_mga_blit_t)
/* I810 specific ioctls */ /* I810 specific ioctls */
#define DRM_IOCTL_I810_INIT DRM_IOW( 0x40, drm_i810_init_t) #define DRM_IOCTL_I810_INIT DRM_IOW( 0x40, drm_i810_init_t)
@ -396,6 +399,7 @@ typedef struct drm_agp_info {
#define DRM_IOCTL_RADEON_STIPPLE DRM_IOW( 0x4c, drm_radeon_stipple_t) #define DRM_IOCTL_RADEON_STIPPLE DRM_IOW( 0x4c, drm_radeon_stipple_t)
#define DRM_IOCTL_RADEON_INDIRECT DRM_IOWR(0x4d, drm_radeon_indirect_t) #define DRM_IOCTL_RADEON_INDIRECT DRM_IOWR(0x4d, drm_radeon_indirect_t)
#ifdef CONFIG_DRM_SIS
/* SiS specific ioctls */ /* SiS specific ioctls */
#define SIS_IOCTL_FB_ALLOC DRM_IOWR(0x44, drm_sis_mem_t) #define SIS_IOCTL_FB_ALLOC DRM_IOWR(0x44, drm_sis_mem_t)
#define SIS_IOCTL_FB_FREE DRM_IOW( 0x45, drm_sis_mem_t) #define SIS_IOCTL_FB_FREE DRM_IOW( 0x45, drm_sis_mem_t)
@ -405,5 +409,6 @@ typedef struct drm_agp_info {
#define SIS_IOCTL_FLIP DRM_IOW( 0x48, drm_sis_flip_t) #define SIS_IOCTL_FLIP DRM_IOW( 0x48, drm_sis_flip_t)
#define SIS_IOCTL_FLIP_INIT DRM_IO( 0x49) #define SIS_IOCTL_FLIP_INIT DRM_IO( 0x49)
#define SIS_IOCTL_FLIP_FINAL DRM_IO( 0x50) #define SIS_IOCTL_FLIP_FINAL DRM_IO( 0x50)
#endif
#endif #endif