summaryrefslogtreecommitdiff
path: root/sys/dev/pci/drm
diff options
context:
space:
mode:
authorOwain Ainsworth <oga@cvs.openbsd.org>2008-09-09 21:02:07 +0000
committerOwain Ainsworth <oga@cvs.openbsd.org>2008-09-09 21:02:07 +0000
commit46934e53f9b57425f055db09b473257cbe091a84 (patch)
treee61fc6fb25295c3bd98b7152d158a22c1f619ac6 /sys/dev/pci/drm
parent944a7a5ee1793b3167671ed5bf7acc319f00e2e4 (diff)
Kill some stupid agp api wrapper functions, just use the agp api
directly. While i'm here, factor out some common functionality into a separate function, and kill some typedefs (man this code is full of them...). Shaves another 450 bytes off the kernel. Tested by ckuethe and Paul de Weerd, thanks.
Diffstat (limited to 'sys/dev/pci/drm')
-rw-r--r--sys/dev/pci/drm/drmP.h25
-rw-r--r--sys/dev/pci/drm/drm_agpsupport.c127
-rw-r--r--sys/dev/pci/drm/drm_drv.c34
3 files changed, 71 insertions, 115 deletions
diff --git a/sys/dev/pci/drm/drmP.h b/sys/dev/pci/drm/drmP.h
index 7ab0d21ce41..413d491ace1 100644
--- a/sys/dev/pci/drm/drmP.h
+++ b/sys/dev/pci/drm/drmP.h
@@ -171,12 +171,6 @@ extern int ticks; /* really should be in a header */
#define PAGE_ALIGN(addr) (((addr) + PAGE_SIZE - 1) & PAGE_MASK)
-#ifdef DRM_NO_AGP
-#define DRM_AGP_FIND_DEVICE() 0
-#else
-#define DRM_AGP_FIND_DEVICE() agp_find_device(0)
-#endif
-
extern struct cfdriver drm_cd;
typedef unsigned long dma_addr_t;
@@ -382,7 +376,7 @@ struct drm_agp_mem {
TAILQ_ENTRY(drm_agp_mem) link;
};
-typedef struct drm_agp_head {
+struct drm_agp_head {
struct device *agpdev;
const char *chipset;
TAILQ_HEAD(agp_memlist, drm_agp_mem) memory;
@@ -394,7 +388,7 @@ typedef struct drm_agp_head {
int cant_use_aperture;
int enabled;
int mtrr;
-} drm_agp_head_t;
+};
struct drm_sg_dmamem {
bus_dma_tag_t sg_tag;
@@ -593,12 +587,12 @@ struct drm_device {
pid_t buf_pgid;
- drm_agp_head_t *agp;
- drm_sg_mem_t *sg; /* Scatter gather memory */
- atomic_t *ctx_bitmap;
- void *dev_private;
- unsigned int agp_buffer_token;
- drm_local_map_t *agp_buffer_map;
+ struct drm_agp_head *agp;
+ drm_sg_mem_t *sg; /* Scatter gather memory */
+ atomic_t *ctx_bitmap;
+ void *dev_private;
+ unsigned int agp_buffer_token;
+ drm_local_map_t *agp_buffer_map;
u_int drw_no;
/* RB tree of drawable infos */
@@ -695,7 +689,8 @@ void drm_handle_vblank(struct drm_device *, int);
/* AGP/PCI Express/GART support (drm_agpsupport.c) */
int drm_device_is_agp(struct drm_device *);
int drm_device_is_pcie(struct drm_device *);
-drm_agp_head_t *drm_agp_init(void);
+struct drm_agp_head *drm_agp_init(void);
+void drm_agp_takedown(struct drm_device *);
int drm_agp_acquire(struct drm_device *);
int drm_agp_release(struct drm_device *);
int drm_agp_info(struct drm_device *, struct drm_agp_info *);
diff --git a/sys/dev/pci/drm/drm_agpsupport.c b/sys/dev/pci/drm/drm_agpsupport.c
index 03784c0b35b..be3f368c4c8 100644
--- a/sys/dev/pci/drm/drm_agpsupport.c
+++ b/sys/dev/pci/drm/drm_agpsupport.c
@@ -36,6 +36,8 @@
#include "drmP.h"
struct drm_agp_mem *drm_agp_lookup_entry(struct drm_device *, void *);
+void drm_agp_remove_entry(struct drm_device *,
+ struct drm_agp_mem *);
int
drm_device_is_agp(struct drm_device *dev)
@@ -185,7 +187,8 @@ drm_agp_alloc(struct drm_device *dev, struct drm_agp_buffer *request)
type = (u_int32_t)request->type;
DRM_UNLOCK();
- handle = drm_agp_allocate_memory(pages, type);
+ handle = agp_alloc_memory(dev->agp->agpdev, type,
+ pages << AGP_PAGE_SHIFT);
DRM_LOCK();
if (handle == NULL) {
drm_free(entry, sizeof(*entry), DRM_MEM_AGPLISTS);
@@ -245,7 +248,7 @@ drm_agp_unbind(struct drm_device *dev, struct drm_agp_binding *request)
return (EINVAL);
DRM_UNLOCK();
- retcode = drm_agp_unbind_memory(entry->handle);
+ retcode = agp_unbind_memory(dev->agp->agpdev, entry->handle);
DRM_LOCK();
if (retcode == 0)
@@ -286,7 +289,8 @@ drm_agp_bind(struct drm_device *dev, struct drm_agp_binding *request)
page = (request->offset + PAGE_SIZE - 1) / PAGE_SIZE;
DRM_UNLOCK();
- retcode = drm_agp_bind_memory(entry->handle, page);
+ retcode = agp_bind_memory(dev->agp->agpdev, entry->handle,
+ page * PAGE_SIZE);
DRM_LOCK();
if (retcode == 0)
entry->bound = dev->agp->base + (page << PAGE_SHIFT);
@@ -308,6 +312,43 @@ drm_agp_bind_ioctl(struct drm_device *dev, void *data,
return (retcode);
}
+/*
+ * Remove entry from list and free. Call locked.
+ */
+void
+drm_agp_remove_entry(struct drm_device *dev, struct drm_agp_mem *entry)
+{
+ TAILQ_REMOVE(&dev->agp->memory, entry, link);
+
+ DRM_UNLOCK();
+ if (entry->bound)
+ agp_unbind_memory(dev->agp->agpdev, entry->handle);
+ agp_free_memory(dev->agp->agpdev, entry->handle);
+ drm_free(entry, sizeof(*entry), DRM_MEM_AGPLISTS);
+ DRM_LOCK();
+}
+
+void
+drm_agp_takedown(struct drm_device *dev)
+{
+ struct drm_agp_mem *entry;
+
+ if (dev->agp == NULL)
+ return;
+
+ /*
+ * Remove AGP resources, but leave dev->agp intact until
+ * we detach the device
+ */
+ DRM_LOCK();
+ while ((entry = TAILQ_FIRST(&dev->agp->memory)) != NULL)
+ drm_agp_remove_entry(dev, entry);
+ DRM_UNLOCK();
+
+ drm_agp_release(dev);
+ dev->agp->enabled = 0;
+}
+
int
drm_agp_free(struct drm_device *dev, struct drm_agp_buffer *request)
{
@@ -319,19 +360,10 @@ drm_agp_free(struct drm_device *dev, struct drm_agp_buffer *request)
entry = drm_agp_lookup_entry(dev, (void*)request->handle);
if (entry == NULL)
return (EINVAL);
-
- TAILQ_REMOVE(&dev->agp->memory, entry, link);
-
- DRM_UNLOCK();
- if (entry->bound)
- drm_agp_unbind_memory(entry->handle);
- drm_agp_free_memory(entry->handle);
- DRM_LOCK();
-
- drm_free(entry, sizeof(*entry), DRM_MEM_AGPLISTS);
+ drm_agp_remove_entry(dev, entry);
+
return (0);
-
}
int
@@ -348,15 +380,15 @@ drm_agp_free_ioctl(struct drm_device *dev, void *data,
return (retcode);
}
-drm_agp_head_t *
+struct drm_agp_head *
drm_agp_init(void)
{
#ifndef DRM_NO_AGP
- struct device *agpdev;
- drm_agp_head_t *head = NULL;
- int agp_available = 1;
+ struct device *agpdev;
+ struct drm_agp_head *head = NULL;
+ int agp_available = 1;
- agpdev = DRM_AGP_FIND_DEVICE();
+ agpdev = agp_find_device(0);
if (agpdev == NULL)
agp_available = 0;
@@ -376,60 +408,3 @@ drm_agp_init(void)
return (NULL);
#endif
}
-
-void *
-drm_agp_allocate_memory(size_t pages, u32 type)
-{
- struct device *agpdev;
-
- agpdev = DRM_AGP_FIND_DEVICE();
- if (agpdev == NULL)
- return (NULL);
-
- return (agp_alloc_memory(agpdev, type, pages << AGP_PAGE_SHIFT));
-}
-
-int
-drm_agp_free_memory(void *handle)
-{
- struct device *agpdev;
-
- agpdev = DRM_AGP_FIND_DEVICE();
- if (agpdev == NULL || handle == NULL)
- return (0);
-
- agp_free_memory(agpdev, handle);
- return (1);
-}
-
-int
-drm_agp_bind_memory(void *handle, off_t start)
-{
-#ifndef DRM_NO_AGP
- struct device *agpdev;
-
- agpdev = DRM_AGP_FIND_DEVICE();
- if (agpdev == NULL || handle == NULL)
- return (EINVAL);
-
- return (agp_bind_memory(agpdev, handle, start * PAGE_SIZE));
-#else
- return (0);
-#endif
-}
-
-int
-drm_agp_unbind_memory(void *handle)
-{
-#ifndef DRM_NO_AGP
- struct device *agpdev;
-
- agpdev = DRM_AGP_FIND_DEVICE();
- if (agpdev == NULL || handle == NULL)
- return (EINVAL);
-
- return (agp_unbind_memory(agpdev, handle));
-#else
- return (0);
-#endif
-}
diff --git a/sys/dev/pci/drm/drm_drv.c b/sys/dev/pci/drm/drm_drv.c
index fd8ad5519cc..7a39ee79b51 100644
--- a/sys/dev/pci/drm/drm_drv.c
+++ b/sys/dev/pci/drm/drm_drv.c
@@ -392,38 +392,25 @@ drm_lastclose(struct drm_device *dev)
dev->unique_len = 0;
}
- drm_drawable_free_all(dev);
/* Clear pid list */
while ((pt = SPLAY_ROOT(&dev->magiclist)) != NULL) {
SPLAY_REMOVE(drm_magic_tree, &dev->magiclist, pt);
drm_free(pt, sizeof(*pt), DRM_MEM_MAGIC);
}
- /* Clear AGP information */
- if (dev->agp != NULL) {
- struct drm_agp_mem *entry;
-
- /*
- * Remove AGP resources, but leave dev->agp intact until
- * we detach the device
- */
- while ((entry = TAILQ_FIRST(&dev->agp->memory)) != NULL) {
- if (entry->bound)
- drm_agp_unbind_memory(entry->handle);
- drm_agp_free_memory(entry->handle);
- TAILQ_REMOVE(&dev->agp->memory, entry, link);
- drm_free(entry, sizeof(*entry), DRM_MEM_AGPLISTS);
- }
-
- if (dev->agp->acquired)
- drm_agp_release(dev);
+ DRM_UNLOCK();
+ drm_agp_takedown(dev);
+ drm_drawable_free_all(dev);
+ drm_dma_takedown(dev);
+ DRM_LOCK();
- dev->agp->acquired = 0;
- dev->agp->enabled = 0;
- }
if (dev->sg != NULL) {
- drm_sg_cleanup(dev->sg);
+ drm_sg_mem_t *sg = dev->sg;
dev->sg = NULL;
+
+ DRM_UNLOCK();
+ drm_sg_cleanup(sg);
+ DRM_LOCK();
}
for (map = TAILQ_FIRST(&dev->maplist); map != TAILQ_END(&dev->maplist);
@@ -433,7 +420,6 @@ drm_lastclose(struct drm_device *dev)
drm_rmmap(dev, map);
}
- drm_dma_takedown(dev);
if (dev->lock.hw_lock != NULL) {
dev->lock.hw_lock = NULL; /* SHM removed */
dev->lock.file_priv = NULL;