[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