vmwgfx: minor dmabuf utilities cleanup
authorThomas Hellstrom <thellstrom@vmware.com>
Tue, 4 Oct 2011 18:13:28 +0000 (20:13 +0200)
committerDave Airlie <airlied@redhat.com>
Wed, 5 Oct 2011 09:17:20 +0000 (10:17 +0100)
Add / fix some function comments.
Don't move out an fbdev framebuffer when unused. Just unpin.
Only have a single function that computes a SVGAGuestPtr from the buffer's
current placement, and make it more versatile by accepting a
struct ttm_buffer_object

Signed-off-by: Thomas Hellstrom <thellstrom@vmware.com>
Reviewed-by: Jakob Bornecrantz <jakob@vmware.com>
Signed-off-by: Dave Airlie <airlied@redhat.com>
drivers/gpu/drm/vmwgfx/vmwgfx_dmabuf.c
drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
drivers/gpu/drm/vmwgfx/vmwgfx_fb.c
drivers/gpu/drm/vmwgfx/vmwgfx_overlay.c
drivers/gpu/drm/vmwgfx/vmwgfx_scrn.c

index 5668ad980cb5a058e0d41c7b8ed936d4be2459c6..7f744a82892a7ee4e13a2f06ee6868be33a4fa35 100644 (file)
 
 
 /**
- * Validate a buffer to placement.
+ * vmw_dmabuf_to_placement - Validate a buffer to placement.
  *
- * May only be called by the current master as this function takes the
- * its lock in write mode.
+ * @dev_priv:  Driver private.
+ * @buf:  DMA buffer to move.
+ * @pin:  Pin buffer if true.
+ * @interruptible:  Use interruptible wait.
+ *
+ * May only be called by the current master since it assumes that the
+ * master lock is the current master's lock.
+ * This function takes the master's lock in write mode.
  *
  * Returns
  *  -ERESTARTSYS if interrupted by a signal.
@@ -67,10 +73,11 @@ err:
 }
 
 /**
- * Move a buffer to vram or gmr.
+ * vmw_dmabuf_to_vram_or_gmr - Move a buffer to vram or gmr.
  *
- * May only be called by the current master as this function takes the
- * its lock in write mode.
+ * May only be called by the current master since it assumes that the
+ * master lock is the current master's lock.
+ * This function takes the master's lock in write mode.
  *
  * @dev_priv:  Driver private.
  * @buf:  DMA buffer to move.
@@ -134,10 +141,11 @@ err:
 }
 
 /**
- * Move a buffer to vram.
+ * vmw_dmabuf_to_vram - Move a buffer to vram.
  *
- * May only be called by the current master as this function takes the
- * its lock in write mode.
+ * May only be called by the current master since it assumes that the
+ * master lock is the current master's lock.
+ * This function takes the master's lock in write mode.
  *
  * @dev_priv:  Driver private.
  * @buf:  DMA buffer to move.
@@ -164,10 +172,11 @@ int vmw_dmabuf_to_vram(struct vmw_private *dev_priv,
 }
 
 /**
- * Move a buffer to start of vram.
+ * vmw_dmabuf_to_start_of_vram - Move a buffer to start of vram.
  *
- * May only be called by the current master as this function takes the
- * its lock in write mode.
+ * May only be called by the current master since it assumes that the
+ * master lock is the current master's lock.
+ * This function takes the master's lock in write mode.
  *
  * @dev_priv:  Driver private.
  * @buf:  DMA buffer to move.
@@ -219,11 +228,13 @@ err_unlock:
        return ret;
 }
 
+
 /**
- * Unpin the buffer given buffer, does not move the buffer.
+ * vmw_dmabuf_upin - Unpin the buffer given buffer, does not move the buffer.
  *
- * May only be called by the current master as this function takes the
- * its lock in write mode.
+ * May only be called by the current master since it assumes that the
+ * master lock is the current master's lock.
+ * This function takes the master's lock in write mode.
  *
  * @dev_priv:  Driver private.
  * @buf:  DMA buffer to unpin.
@@ -246,47 +257,22 @@ int vmw_dmabuf_unpin(struct vmw_private *dev_priv,
                                       interruptible);
 }
 
+
 /**
- * Move a buffer to system memory, does not pin the buffer.
- *
- * May only be called by the current master as this function takes the
- * its lock in write mode.
- *
- * @dev_priv:  Driver private.
- * @buf:  DMA buffer to move.
- * @interruptible:  Use interruptible wait.
+ * vmw_bo_get_guest_ptr - Get the guest ptr representing the current placement
+ * of a buffer.
  *
- * Returns
- * -ERESTARTSYS if interrupted by a signal.
+ * @bo: Pointer to a struct ttm_buffer_object. Must be pinned or reserved.
+ * @ptr: SVGAGuestPtr returning the result.
  */
-int vmw_dmabuf_to_system(struct vmw_private *dev_priv,
-                        struct vmw_dma_buffer *buf,
-                        bool interruptible)
-{
-       return vmw_dmabuf_to_placement(dev_priv, buf,
-                                      &vmw_sys_placement,
-                                      interruptible);
-}
-
-void vmw_dmabuf_get_id_offset(struct vmw_dma_buffer *buf,
-                             uint32_t *gmrId, uint32_t *offset)
-{
-       if (buf->base.mem.mem_type == TTM_PL_VRAM) {
-               *gmrId = SVGA_GMR_FRAMEBUFFER;
-               *offset = buf->base.offset;
-       } else {
-               *gmrId = buf->base.mem.start;
-               *offset = 0;
-       }
-}
-
-void vmw_dmabuf_get_guest_ptr(struct vmw_dma_buffer *buf, SVGAGuestPtr *ptr)
+void vmw_bo_get_guest_ptr(const struct ttm_buffer_object *bo,
+                         SVGAGuestPtr *ptr)
 {
-       if (buf->base.mem.mem_type == TTM_PL_VRAM) {
+       if (bo->mem.mem_type == TTM_PL_VRAM) {
                ptr->gmrId = SVGA_GMR_FRAMEBUFFER;
-               ptr->offset = buf->base.offset;
+               ptr->offset = bo->offset;
        } else {
-               ptr->gmrId = buf->base.mem.start;
+               ptr->gmrId = bo->mem.start;
                ptr->offset = 0;
        }
 }
index fc0e3bc63ec0df577bb08236123e19c928016696..b22b96a491a4378ed8ecfadb55aba8788bf26955 100644 (file)
@@ -416,13 +416,8 @@ extern int vmw_dmabuf_to_start_of_vram(struct vmw_private *vmw_priv,
 extern int vmw_dmabuf_unpin(struct vmw_private *vmw_priv,
                            struct vmw_dma_buffer *bo,
                            bool interruptible);
-extern int vmw_dmabuf_to_system(struct vmw_private *vmw_priv,
-                               struct vmw_dma_buffer *bo,
-                               bool interruptible);
-extern void vmw_dmabuf_get_id_offset(struct vmw_dma_buffer *buf,
-                                    uint32_t *gmrId, uint32_t *offset);
-extern void vmw_dmabuf_get_guest_ptr(struct vmw_dma_buffer *buf,
-                                    SVGAGuestPtr *ptr);
+extern void vmw_bo_get_guest_ptr(const struct ttm_buffer_object *buf,
+                                SVGAGuestPtr *ptr);
 
 /**
  * Misc Ioctl functionality - vmwgfx_ioctl.c
index 191f1b2a2a2695d51e94351298d9421aa6b49e52..070797b7b03ae6f22f0b8670094c4690b70f40ea 100644 (file)
@@ -613,8 +613,7 @@ int vmw_fb_off(struct vmw_private *vmw_priv)
        par->bo_ptr = NULL;
        ttm_bo_kunmap(&par->map);
 
-       /* move this to system instead of just unpinning it */
-       vmw_dmabuf_to_system(vmw_priv, par->vmw_bo, false);
+       vmw_dmabuf_unpin(vmw_priv, par->vmw_bo, false);
 
        return 0;
 }
index 29481e1cace7addb3c25f989c5fa55d25996ee78..14399eec9c3cf2985f3dce4531c748873d33af3e 100644 (file)
@@ -99,9 +99,9 @@ static int vmw_overlay_send_put(struct vmw_private *dev_priv,
 {
        struct vmw_escape_video_flush *flush;
        size_t fifo_size;
-       uint32_t gmrId, offset;
        bool have_so = dev_priv->sou_priv ? true : false;
        int i, num_items;
+       SVGAGuestPtr ptr;
 
        struct {
                struct vmw_escape_header escape;
@@ -141,12 +141,12 @@ static int vmw_overlay_send_put(struct vmw_private *dev_priv,
        for (i = 0; i < num_items; i++)
                items[i].registerId = i;
 
-       vmw_dmabuf_get_id_offset(buf, &gmrId, &offset);
-       offset += arg->offset;
+       vmw_bo_get_guest_ptr(&buf->base, &ptr);
+       ptr.offset += arg->offset;
 
        items[SVGA_VIDEO_ENABLED].value     = true;
        items[SVGA_VIDEO_FLAGS].value       = arg->flags;
-       items[SVGA_VIDEO_DATA_OFFSET].value = offset;
+       items[SVGA_VIDEO_DATA_OFFSET].value = ptr.offset;
        items[SVGA_VIDEO_FORMAT].value      = arg->format;
        items[SVGA_VIDEO_COLORKEY].value    = arg->color_key;
        items[SVGA_VIDEO_SIZE].value        = arg->size;
@@ -164,7 +164,7 @@ static int vmw_overlay_send_put(struct vmw_private *dev_priv,
        items[SVGA_VIDEO_PITCH_2].value     = arg->pitch[1];
        items[SVGA_VIDEO_PITCH_3].value     = arg->pitch[2];
        if (have_so) {
-               items[SVGA_VIDEO_DATA_GMRID].value    = gmrId;
+               items[SVGA_VIDEO_DATA_GMRID].value    = ptr.gmrId;
                items[SVGA_VIDEO_DST_SCREEN_ID].value = SVGA_ID_INVALID;
        }
 
index e74b8e31d042c0cd499d3dad5c44191e7a466e74..347e406994435aaf8b36f2139a9e33e85348def7 100644 (file)
@@ -168,7 +168,7 @@ static int vmw_sou_fifo_create(struct vmw_private *dev_priv,
        cmd->obj.root.y = y;
 
        /* Ok to assume that buffer is pinned in vram */
-       vmw_dmabuf_get_guest_ptr(sou->buffer, &cmd->obj.backingStore.ptr);
+       vmw_bo_get_guest_ptr(&sou->buffer->base, &cmd->obj.backingStore.ptr);
        cmd->obj.backingStore.pitch = mode->hdisplay * 4;
 
        vmw_fifo_commit(dev_priv, fifo_size);