diff options
-rw-r--r-- | sys/dev/pci/drm/drmP.h | 248 |
1 files changed, 11 insertions, 237 deletions
diff --git a/sys/dev/pci/drm/drmP.h b/sys/dev/pci/drm/drmP.h index 5d88c44af37..237fe2ed70b 100644 --- a/sys/dev/pci/drm/drmP.h +++ b/sys/dev/pci/drm/drmP.h @@ -49,36 +49,25 @@ typedef struct drm_file drm_file_t; #include <sys/proc.h> #include <sys/resource.h> #include <sys/resourcevar.h> -#include <sys/lock.h> +#include <sys/mutex.h> #include <sys/fcntl.h> -#include <sys/uio.h> #include <sys/filio.h> #include <sys/signalvar.h> #include <sys/poll.h> #include <sys/tree.h> -#include <machine/param.h> -#include <machine/bus.h> -#include <machine/param.h> -#include <machine/bus.h> -#if !defined(DRM_NO_MTRR) -#include <machine/sysarch.h> -#endif #include <sys/endian.h> #include <sys/mman.h> -#include <sys/types.h> -#include <sys/conf.h> #include <sys/stdint.h> -#include <sys/malloc.h> -#include <machine/bus.h> #include <sys/agpio.h> #include <sys/memrange.h> #include <sys/vnode.h> -#include <dev/pci/pcidevs.h> #include <uvm/uvm.h> +#include <dev/pci/pcidevs.h> #include <dev/pci/pcivar.h> #include <dev/pci/agpvar.h> #include <dev/pci/vga_pcivar.h> -#include <dev/pci/pcivar.h> +#include <machine/param.h> +#include <machine/bus.h> #include "drm.h" #include "drm_linux_list.h" @@ -89,33 +78,6 @@ typedef struct drm_file drm_file_t; #define DRM_NO_MTRR #endif /* Until the mtrr apis are merged. */ -#if defined(__FreeBSD__) || defined(__NetBSD__) -#include <opt_drm.h> -#endif -#ifdef DRM_DEBUG -#undef DRM_DEBUG -#define DRM_DEBUG_DEFAULT_ON 1 -#endif /* DRM_DEBUG */ - -#ifndef __Linux__ -/* stop the linux version tests breaking the compile */ -#define LINUX_VERSION_CODE 500 -#define KERNEL_VERSION(a,b,c)0 -#endif - -#if defined(DRM_LINUX) && DRM_LINUX && !defined(__amd64__) -#include <sys/file.h> -#include <sys/proc.h> -#include <machine/../linux/linux.h> -#include <machine/../linux/linux_proto.h> -#else -/* Either it was defined when it shouldn't be (FreeBSD amd64) or it isn't - * supported on this OS yet. - */ -#undef DRM_LINUX -#define DRM_LINUX 0 -#endif - #define DRM_KERNEL_CONTEXT 0 /* Change drm_resctx if changed */ #define DRM_RESERVED_CONTEXTS 1 /* Change drm_resctx if changed */ @@ -151,10 +113,6 @@ typedef struct drm_file drm_file_t; #define DRM_IF_VERSION(maj, min) (maj << 16 | min) -#ifndef __OpenBSD__ -MALLOC_DECLARE(M_DRM); -#endif - #define __OS_HAS_AGP 1 #define DRM_DEV_MODE (S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP) @@ -166,49 +124,6 @@ MALLOC_DECLARE(M_DRM); #define DRM_WAKEUP_INT(w) wakeup(w) #define DRM_INIT_WAITQUEUE(queue) do {(void)(queue);} while (0) -#if defined(__FreeBSD__) && __FreeBSD_version < 502109 -#define bus_alloc_resource_any(dev, type, rid, flags) \ - bus_alloc_resource(dev, type, rid, 0ul, ~0ul, 1, flags) -#endif - -#if defined(__FreeBSD__) && __FreeBSD_version >= 500000 -#define DRM_CDEV struct cdev * -#define DRM_CURPROC curthread -#define DRM_STRUCTPROC struct thread -#define DRM_PROC(p) (p) -#define DRM_SPINTYPE struct mtx -#define DRM_SPININIT(l,name) mtx_init(l, name, NULL, MTX_DEF) -#define DRM_SPINUNINIT(l) mtx_destroy(l) -#define DRM_SPINLOCK(l) mtx_lock(l) -#define DRM_SPINUNLOCK(u) mtx_unlock(u) -#define DRM_SPINLOCK_ASSERT(l) mtx_assert(l, MA_OWNED) -#define DRM_PID(p) (p)->td_proc->p_pid -#define DRM_CURRENTPID DRM_PID(curthread) -#define DRM_UID(p) (p)->td_ucred->cr_svuid -#define DRM_LOCK() mtx_lock(&dev->dev_lock) -#define DRM_UNLOCK() mtx_unlock(&dev->dev_lock) -#define DRM_SYSCTL_HANDLER_ARGS (SYSCTL_HANDLER_ARGS) -#else /* __FreeBSD__ && __FreeBSD_version >= 500000 */ -#ifdef __NetBSD__ -#define DRM_CDEV dev_t -#define DRM_CURPROC curproc -#define DRM_STRUCTPROC struct proc -#define DRM_SPINTYPE struct simplelock -#define DRM_SPININIT(l,name) simple_lock_init(&l) -#define DRM_SPINUNINIT(l) DRM_NOOP -#define DRM_SPINLOCK(l) if(!simple_lock_try(l)) simple_lock(l) -#define DRM_SPINUNLOCK(u) simple_unlock(u) -#define DRM_SPINLOCK_ASSERT(l) DRM_NOOP -#define DRM_LOCK() DRM_SPINLOCK(&dev->dev_lock) -#define DRM_UNLOCK() DRM_SPINUNLOCK(&dev->dev_lock) -#define DRM_SLEEPLOCK(v,l,f,s,i) ltsleep(v,f,s,i,l); -#define spldrm() spltty() -#define DRM_PID(p) (p)->p_pid -#define DRM_CURRENTPID DRM_PID(curproc) -#define DRM_UID(p) kauth_cred_getsvuid((p)->p_cred) -#define DRM_SYSCTL_HANDLER_ARGS (SYSCTLFN_ARGS) -#else -#ifdef __OpenBSD__ #define DRM_CDEV dev_t #define DRM_CURPROC curproc #define DRM_STRUCTPROC struct proc @@ -220,6 +135,11 @@ MALLOC_DECLARE(M_DRM); #define DRM_SPINUNINIT(l) DRM_NOOP #define DRM_SPINLOCK(l) mtx_enter(l) #define DRM_SPINUNLOCK(l) mtx_leave(l) +#define DRM_SPINLOCK_IRQSAVE(l, irqflags) do { \ + DRM_SPINLOCK(l); \ + (void)irqflags; \ +} while (0) +#define DRM_SPINUNLOCK_IRQRESTORE(u, irqflags) DRM_SPINUNLOCK(u) #define DRM_SPINLOCK_ASSERT(l) DRM_NOOP #define DRM_LOCK() DRM_SPINLOCK(&dev->dev_lock) #define DRM_UNLOCK() DRM_SPINUNLOCK(&dev->dev_lock) @@ -227,12 +147,9 @@ MALLOC_DECLARE(M_DRM); #define DRM_PID(p) (p)->p_pid #define DRM_CURRENTPID DRM_PID(curproc) #define DRM_UID(p) (p)->p_pid -/* Number of DRM devices at any one time. If you have more than this, i want to see your setup */ #define DRM_MAXUNITS 8 extern drm_device_t *drm_units[]; -/* XXX fixme */ -#define DRM_SYSCTL_HANDLER_ARGS (int *name, u_int namelen, void *oldp, size_t *oldlenp, void *newp, \ - size_t newlen, struct proc *p) + /* Deal with netbsd code where only the print statements differ */ #define printk printf #define __unused /* nothing */ @@ -246,25 +163,12 @@ extern drm_device_t *drm_units[]; #define drm_read drmread #define drm_poll drmpoll #define drm_mmap drmmmap -#endif /* __OpenBSD__ */ -#endif /* __NetBSD__ */ -#endif /* __NetBSD__ || __OpenBSD__ */ -#define DRM_SPINLOCK_IRQSAVE(l, irqflags) do { \ - DRM_SPINLOCK(l); \ - (void)irqflags; \ -} while (0) -#define DRM_SPINUNLOCK_IRQRESTORE(u, irqflags) DRM_SPINUNLOCK(u) + #define DRM_IRQ_ARGS void *arg -#ifdef __FreeBSD__ -typedef void irqreturn_t; -#define IRQ_HANDLED /* nothing */ -#define IRQ_NONE /* nothing */ -#elif defined(__NetBSD__) || defined(__OpenBSD__) typedef int irqreturn_t; #define IRQ_HANDLED 1 #define IRQ_NONE 0 -#endif enum { DRM_IS_NOT_AGP, @@ -273,11 +177,6 @@ enum { }; #define DRM_AGP_MEM struct agp_memory_info -#if defined(__FreeBSD__) -#define drm_get_device_from_kdev(_kdev) (_kdev->si_drv1) -#elif defined(__NetBSD__) -#define drm_get_device_from_kdev(_kdev) device_lookup(&drm_cd, minor(_kdev)) -#elif defined(__OpenBSD__) /* D_CLONE only supports one device, this will be fixed eventually */ #define drm_get_device_from_kdev(_kdev) \ drm_units[0] @@ -288,36 +187,13 @@ enum { drm_units[minor(kdev)] : NULL #endif -#endif /* __FreeBSD__ / __NetBSD__ / __OpenBSD__ */ - -#ifdef __FreeBSD__ -#define PAGE_ALIGN(addr) round_page(addr) -#if __FreeBSD_version >= 700000 -/* DRM_SUSER returns true if the user is superuser */ -#define DRM_SUSER(p) (priv_check(p, PRIV_DRIVER) == 0) -#else -#define DRM_SUSER(p) (suser(p) == 0) -#endif -#define DRM_AGP_FIND_DEVICE() agp_find_device() -#define DRM_MTRR_WC MDF_WRITECOMBINE -#define jiffies ticks -#else /* __FreeBSD__ */ -#if defined(__NetBSD__) -#define DRM_SUSER(p) (kauth_cred_getsvuid((p)->p_cred) == 0) -#define DRM_MAXUNITS 128 -extern drm_device_t *drm_units[]; -#define jiffies hardclock_ticks -#define CDEV_MAJOR 34 -#define DRM_MTRR_WC MTRR_TYPE_WC -#elif defined(__OpenBSD__) /* DRM_SUSER returns true if the user is superuser */ #define DRM_SUSER(p) (suser(p, p->p_acflag) == 0) extern int ticks; /* really should be in a header */ #define jiffies ticks #define DRM_MTRR_WC MDF_WRITECOMBINE -#endif /* __OpenBSD__ */ #define PAGE_ALIGN(addr) (((addr) + PAGE_SIZE - 1) & PAGE_MASK) @@ -329,7 +205,6 @@ extern int ticks; /* really should be in a header */ typedef drm_device_t *device_t; extern struct cfdriver drm_cd; -#endif /* !__FreeBSD__ */ /* Capabilities taken from src/sys/dev/pci/pcireg.h. */ #ifndef PCIY_AGP @@ -368,25 +243,6 @@ typedef u_int8_t u8; "lock; addl $0,0(%%rsp)" : : : "memory"); #endif -#ifdef __FreeBSD__ -#define DRM_READ8(map, offset) \ - *(volatile u_int8_t *) (((unsigned long)(map)->handle) + (offset)) -#define DRM_READ16(map, offset) \ - *(volatile u_int16_t *) (((unsigned long)(map)->handle) + (offset)) -#define DRM_READ32(map, offset) \ - *(volatile u_int32_t *)(((unsigned long)(map)->handle) + (offset)) -#define DRM_WRITE8(map, offset, val) \ - *(volatile u_int8_t *) (((unsigned long)(map)->handle) + (offset)) = val -#define DRM_WRITE16(map, offset, val) \ - *(volatile u_int16_t *) (((unsigned long)(map)->handle) + (offset)) = val -#define DRM_WRITE32(map, offset, val) \ - *(volatile u_int32_t *)(((unsigned long)(map)->handle) + (offset)) = val - -#define DRM_VERIFYAREA_READ( uaddr, size ) \ - (!useracc(__DECONST(caddr_t, uaddr), size, VM_PROT_READ)) - -#else /* __FreeBSD__ */ - typedef vaddr_t vm_offset_t; #define DRM_READ8(map, offset) \ @@ -405,7 +261,6 @@ typedef vaddr_t vm_offset_t; #define DRM_VERIFYAREA_READ( uaddr, size ) \ (!uvm_map_checkprot(&(curproc->p_vmspace->vm_map), \ (vaddr_t)uaddr, (vaddr_t)uaddr+size, UVM_PROT_READ)) -#endif /* !__FreeBSD__ */ #define DRM_COPY_TO_USER(user, kern, size) \ copyout(kern, user, size) @@ -415,18 +270,9 @@ typedef vaddr_t vm_offset_t; copyin(arg2, arg1, arg3) #define DRM_COPY_TO_USER_UNCHECKED(arg1, arg2, arg3) \ copyout(arg2, arg1, arg3) -#if __FreeBSD_version > 500000 -#define DRM_GET_USER_UNCHECKED(val, uaddr) \ - ((val) = fuword32(uaddr), 0) -#else #define DRM_GET_USER_UNCHECKED(val, uaddr) \ ((val) = fuword(uaddr), 0) -#endif -#ifdef __OpenBSD__ #define le32_to_cpu(x) letoh32(x) -#else -#define le32_to_cpu(x) le32toh(x) -#endif #define cpu_to_le32(x) htole32(x) #define DRM_HZ hz @@ -447,7 +293,6 @@ do { \ } \ } while (0) -#if defined(__OpenBSD__) || (defined(__FreeBSD__) && __FreeBSD_version > 500000) /* Returns -errno to shared code */ #define DRM_WAIT_ON( ret, queue, timeout, condition ) \ ret = 0; \ @@ -463,17 +308,6 @@ while ( ret == 0 ) { \ DRM_SPINUNLOCK(&dev->irq_lock); \ DRM_LOCK(); \ } -#else -/* Returns -errno to shared code */ -#define DRM_WAIT_ON( ret, queue, timeout, condition ) \ -for ( ret = 0 ; !ret && !(condition) ; ) { \ - int s = spldrm(); \ - if (!(condition)) \ - ret = -tsleep( &(queue), PZERO | PCATCH, \ - "drmwtq", (timeout) ); \ - splx(s); \ -} -#endif #define DRM_ERROR(fmt, arg...) \ printf("error: [" DRM_NAME ":pid%d:%s] *ERROR* " fmt, \ @@ -554,16 +388,11 @@ typedef struct drm_freelist { typedef struct drm_dma_handle { void *vaddr; bus_addr_t busaddr; -#if defined(__FreeBSD__) - bus_dma_tag_t tag; - bus_dmamap_t map; -#elif defined(__NetBSD__) || defined(__OpenBSD__) bus_dmamap_t dmamap; bus_dma_segment_t seg; void *addr; bus_addr_t dmaaddr; size_t size; -#endif } drm_dma_handle_t; typedef struct drm_buf_entry { @@ -640,7 +469,6 @@ typedef struct drm_agp_head { unsigned long page_mask; } drm_agp_head_t; -#ifdef __OpenBSD__ struct drm_sg_dmamem { bus_dma_tag_t sg_tag; bus_dmamap_t sg_map; @@ -649,7 +477,6 @@ struct drm_sg_dmamem { size_t sg_size; caddr_t sg_kva; }; -#endif typedef struct drm_sg_mem { unsigned long handle; @@ -657,9 +484,7 @@ typedef struct drm_sg_mem { int pages; dma_addr_t *busaddr; drm_dma_handle_t *dmah; /* Handle to PCI memory for ATI PCIGART table */ -#ifdef __OpenBSD__ struct drm_sg_dmamem *mem; -#endif } drm_sg_mem_t; /* @@ -694,11 +519,7 @@ typedef struct drm_local_map { int mtrr; /* Boolean: MTRR used */ /* Private data */ int rid; /* PCI resource ID for bus_space */ -#ifdef __FreeBSD__ - struct resource *bsr; -#else struct vga_pci_bar *bsr; -#endif bus_space_tag_t bst; bus_space_handle_t bsh; drm_dma_handle_t *dmah; @@ -810,9 +631,7 @@ struct drm_driver_info { * DRM device functions structure */ struct drm_device { -#if defined(__NetBSD__) || defined(__OpenBSD__) struct device device; /* softc is an extension of struct device */ -#endif struct drm_driver_info driver; drm_pci_id_list_t *id_entry; /* PCI ID, name, and chipset private */ @@ -822,26 +641,18 @@ struct drm_device { char *unique; /* Unique identifier: e.g., busid */ int unique_len; /* Length of unique field */ -#ifdef __FreeBSD__ - device_t device; /* Device instance from newbus */ - struct cdev *devnode; /* Device number for mknod */ -#endif -#ifdef __OpenBSD__ dev_t kdev; /* used by uvm_mmap, this is just a placeholder */ struct vga_pci_softc *vga_softc; -#endif int if_version; /* Highest interface version set */ int flags; /* Flags to open(2) */ /* Locks */ -#if (defined(__FreeBSD__) && __FreeBSD_version > 500000) || defined __NetBSD__ || defined __OpenBSD__ DRM_SPINTYPE dma_lock; /* protects dev->dma */ DRM_SPINTYPE irq_lock; /* protects irq condition checks */ DRM_SPINTYPE dev_lock; /* protects everything else */ DRM_SPINTYPE drw_lock; -#endif /* Usage Counters */ int open_count; /* Outstanding files open */ @@ -871,22 +682,12 @@ struct drm_device { /* Context support */ int irq; /* Interrupt used by board */ int irq_enabled; /* True if the irq handler is enabled */ -#ifdef __FreeBSD__ - int irqrid; /* Interrupt used by board */ - struct resource *irqr; /* Resource for interrupt used by board */ -#elif defined(__NetBSD__) || defined(__OpenBSD__) struct pci_attach_args pa; int unit; /* drm unit number */ -#endif void *irqh; /* Handle from bus_setup_intr */ /* Storage of resource pointers for drm_get_resource_* */ -#ifdef __FreeBSD__ - struct resource *pcir[DRM_MAX_PCI_RESOURCE]; - int pcirid[DRM_MAX_PCI_RESOURCE]; -#else struct vga_pci_bar *pcir[DRM_MAX_PCI_RESOURCE]; -#endif int pci_domain; int pci_bus; @@ -914,11 +715,7 @@ struct drm_device { u_int32_t max_vblank_count; /* size of counter reg */ -#ifdef __FreeBSD__ - struct sigio *buf_sigio; /* Processes waiting for SIGIO */ -#elif defined(__NetBSD__) || defined(__OpenBSD__) pid_t buf_pgid; -#endif drm_agp_head_t *agp; drm_sg_mem_t *sg; /* Scatter gather memory */ @@ -927,34 +724,16 @@ struct drm_device { unsigned int agp_buffer_token; drm_local_map_t *agp_buffer_map; -#ifdef __FreeBSD__ - struct unrhdr *drw_unrhdr; -#else u_int drw_no; -#endif /* RB tree of drawable infos */ RB_HEAD(drawable_tree, bsd_drm_drawable_info) drw_head; -#if defined(__FreeBSD__) - struct task locked_task; -#endif void (*locked_task_call)(drm_device_t *dev); }; extern int drm_debug_flag; /* Device setup support (drm_drv.c) */ -#ifdef __FreeBSD__ -int drm_probe(device_t nbdev, drm_pci_id_list_t *idlist); -int drm_attach(device_t nbdev, drm_pci_id_list_t *idlist); -int drm_detach(device_t nbdev); -d_ioctl_t drm_ioctl; -d_open_t drm_open; -d_close_t drm_close; -d_read_t drm_read; -d_poll_t drm_poll; -d_mmap_t drm_mmap; -#elif defined(__NetBSD__) || defined(__OpenBSD__) int drm_probe(struct pci_attach_args *, drm_pci_id_list_t * ); void drm_attach(struct device *kdev, struct device *parent, struct pci_attach_args *pa, drm_pci_id_list_t *idlist); @@ -966,17 +745,12 @@ dev_type_close(drm_close); dev_type_read(drm_read); dev_type_poll(drm_poll); dev_type_mmap(drm_mmap); -#endif extern drm_local_map_t *drm_getsarea(drm_device_t *dev); /* File operations helpers (drm_fops.c) */ int drm_open_helper(DRM_CDEV, int, int, DRM_STRUCTPROC *, drm_device_t *); -#ifdef __OpenBSD__ drm_file_t *drm_find_file_by_minor(drm_device_t *, int); -#else -drm_file_t *drm_find_file_by_proc(drm_device_t *, DRM_STRUCTPROC *); -#endif /* Memory management support (drm_memory.c) */ void drm_mem_init(void); |