[Mesa-dev] [PATCH 2/3] st/vdpau: Use transfer_inline_write to upload ycbcr data

Christian König deathsimple at vodafone.de
Mon Feb 13 05:36:46 PST 2012


Uses less code and looks at least a bit cleaner than mapping manually.

Signed-off-by: Christian König <deathsimple at vodafone.de>
---
 src/gallium/state_trackers/vdpau/surface.c |   23 +++++------------------
 1 files changed, 5 insertions(+), 18 deletions(-)

diff --git a/src/gallium/state_trackers/vdpau/surface.c b/src/gallium/state_trackers/vdpau/surface.c
index 84467fd..a0ebe00 100644
--- a/src/gallium/state_trackers/vdpau/surface.c
+++ b/src/gallium/state_trackers/vdpau/surface.c
@@ -239,24 +239,11 @@ vlVdpVideoSurfacePutBitsYCbCr(VdpVideoSurface surface,
             sv->texture->width0, sv->texture->height0, 1
          };
 
-         struct pipe_transfer *transfer;
-         void *map;
-
-         transfer = pipe->get_transfer(pipe, sv->texture, 0, PIPE_TRANSFER_WRITE, &dst_box);
-         if (!transfer)
-            return VDP_STATUS_RESOURCES;
-
-         map = pipe->transfer_map(pipe, transfer);
-         if (map) {
-            util_copy_rect(map, sv->texture->format, transfer->stride, 0, 0,
-                           dst_box.width, dst_box.height,
-                           source_data[i] + source_pitches[i] * j,
-                           source_pitches[i] * sv->texture->depth0,
-                           0, 0);
-         }
-
-         pipe->transfer_unmap(pipe, transfer);
-         pipe->transfer_destroy(pipe, transfer);
+         pipe->transfer_inline_write(pipe, sv->texture, 0,
+                                     PIPE_TRANSFER_WRITE, &dst_box,
+                                     source_data[i] + source_pitches[i] * j,
+                                     source_pitches[i] * sv->texture->depth0,
+                                     0);
       }
    }
 
-- 
1.7.5.4



More information about the mesa-dev mailing list