summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/pci/drm/i915_dma.c30
-rw-r--r--sys/dev/pci/drm/i915_drv.h20
2 files changed, 25 insertions, 25 deletions
diff --git a/sys/dev/pci/drm/i915_dma.c b/sys/dev/pci/drm/i915_dma.c
index 74c436016c0..79959d9e264 100644
--- a/sys/dev/pci/drm/i915_dma.c
+++ b/sys/dev/pci/drm/i915_dma.c
@@ -73,24 +73,22 @@ int i915_wait_ring(struct drm_device * dev, int n, const char *caller)
* Sets up the hardware status page for devices that need a physical address
* in the register.
*/
-int i915_init_phys_hws(drm_i915_private_t *dev_priv, bus_dma_tag_t dmat)
+int
+i915_init_phys_hws(drm_i915_private_t *dev_priv, bus_dma_tag_t dmat)
{
/* Program Hardware Status Page */
- dev_priv->status_page_dmah =
- drm_pci_alloc(dmat, PAGE_SIZE, PAGE_SIZE, 0xffffffff);
-
- if (!dev_priv->status_page_dmah) {
- DRM_ERROR("Can not allocate hardware status page\n");
- return ENOMEM;
+ if ((dev_priv->hws_dmamem = drm_dmamem_alloc(dmat, PAGE_SIZE,
+ PAGE_SIZE, 1, PAGE_SIZE, 0, BUS_DMA_READ)) == NULL) {
+ return (ENOMEM);
}
- dev_priv->hw_status_page = dev_priv->status_page_dmah->vaddr;
- dev_priv->dma_status_page = dev_priv->status_page_dmah->busaddr;
+
+ dev_priv->hw_status_page = dev_priv->hws_dmamem->kva;
memset(dev_priv->hw_status_page, 0, PAGE_SIZE);
- I915_WRITE(HWS_PGA, dev_priv->dma_status_page);
+ I915_WRITE(HWS_PGA, dev_priv->hws_dmamem->map->dm_segs[0].ds_addr);
DRM_DEBUG("Enabled hardware status page\n");
- return 0;
+ return (0);
}
/**
@@ -99,9 +97,9 @@ int i915_init_phys_hws(drm_i915_private_t *dev_priv, bus_dma_tag_t dmat)
*/
void i915_free_hws(drm_i915_private_t *dev_priv, bus_dma_tag_t dmat)
{
- if (dev_priv->status_page_dmah) {
- drm_pci_free(dmat, dev_priv->status_page_dmah);
- dev_priv->status_page_dmah = NULL;
+ if (dev_priv->hws_dmamem) {
+ drm_dmamem_free(dmat, dev_priv->hws_dmamem);
+ dev_priv->hws_dmamem = NULL;
}
if (dev_priv->status_gfx_addr) {
@@ -111,6 +109,7 @@ void i915_free_hws(drm_i915_private_t *dev_priv, bus_dma_tag_t dmat)
/* Need to rewrite hardware status page */
I915_WRITE(HWS_PGA, 0x1ffff000);
+ dev_priv->hw_status_page = NULL;
}
void i915_kernel_lost_context(struct drm_device * dev)
@@ -223,7 +222,8 @@ static int i915_dma_resume(struct drm_device * dev)
if (dev_priv->status_gfx_addr != 0)
I915_WRITE(HWS_PGA, dev_priv->status_gfx_addr);
else
- I915_WRITE(HWS_PGA, dev_priv->dma_status_page);
+ I915_WRITE(HWS_PGA,
+ dev_priv->hws_dmamem->map->dm_segs[0].ds_addr);
DRM_DEBUG("Enabled hardware status page\n");
return 0;
diff --git a/sys/dev/pci/drm/i915_drv.h b/sys/dev/pci/drm/i915_drv.h
index 54154de5aa6..382521738a7 100644
--- a/sys/dev/pci/drm/i915_drv.h
+++ b/sys/dev/pci/drm/i915_drv.h
@@ -81,16 +81,16 @@ typedef struct drm_i915_private {
void *irqh;
struct vga_pci_bar *regs;
- drm_local_map_t *sarea;
-
- drm_i915_sarea_t *sarea_priv;
- drm_i915_ring_buffer_t ring;
- drm_dma_handle_t *status_page_dmah;
- void *hw_status_page;
- dma_addr_t dma_status_page;
- uint32_t counter;
- unsigned int status_gfx_addr;
- drm_local_map_t hws_map;
+
+ drm_local_map_t *sarea;
+ drm_i915_sarea_t *sarea_priv;
+
+ drm_i915_ring_buffer_t ring;
+ drm_local_map_t hws_map;
+ struct drm_dmamem *hws_dmamem;
+ void *hw_status_page;
+ unsigned int status_gfx_addr;
+ u_int32_t counter;
atomic_t irq_received;
/* Protects user_irq_refcount and irq_mask reg */