diff options
author | Axel Davy <[email protected]> | 2016-12-04 00:29:16 +0100 |
---|---|---|
committer | Axel Davy <[email protected]> | 2016-12-20 23:47:08 +0100 |
commit | d4a9b21feb890c149f0aa44b0bb6ea63a9932925 (patch) | |
tree | c1a0a091c8d3cf4ff34c60ad4b945af297042c3d | |
parent | f04263923132bcf0425e1297da460543e93a95fe (diff) |
st/nine: Use nine_context_box_upload for volumes
Use nine_context_box_upload for uploads:
. systemmem volume to default volume
. managed volume internal content to its resource.
Check the uploads are executed before any action
that can alter the data, that is LockBox and
volume destruction.
Signed-off-by: Axel Davy <[email protected]>
-rw-r--r-- | src/gallium/state_trackers/nine/volume9.c | 60 | ||||
-rw-r--r-- | src/gallium/state_trackers/nine/volume9.h | 2 |
2 files changed, 26 insertions, 36 deletions
diff --git a/src/gallium/state_trackers/nine/volume9.c b/src/gallium/state_trackers/nine/volume9.c index b579f9205f5..e8abfe7f3bc 100644 --- a/src/gallium/state_trackers/nine/volume9.c +++ b/src/gallium/state_trackers/nine/volume9.c @@ -145,6 +145,9 @@ NineVolume9_dtor( struct NineVolume9 *This ) if (This->transfer) NineVolume9_UnlockBox(This); + if (p_atomic_read(&This->pending_uploads_counter)) + nine_csmt_process(This->base.device); + if (This->data) align_free(This->data); if (This->data_conversion) @@ -301,6 +304,9 @@ NineVolume9_LockBox( struct NineVolume9 *This, &box); } + if (p_atomic_read(&This->pending_uploads_counter)) + nine_csmt_process(This->base.device); + if (This->data_conversion) { /* For now we only have uncompressed formats here */ pLockedVolume->RowPitch = This->stride_conversion; @@ -398,12 +404,9 @@ NineVolume9_CopyMemToDefault( struct NineVolume9 *This, unsigned dstx, unsigned dsty, unsigned dstz, struct pipe_box *pSrcBox ) { - struct pipe_context *pipe; - struct pipe_transfer *transfer = NULL; struct pipe_resource *r_dst = This->resource; struct pipe_box src_box; struct pipe_box dst_box; - uint8_t *map = NULL; DBG("This=%p From=%p dstx=%u dsty=%u dstz=%u pSrcBox=%p\n", This, From, dstx, dsty, dstz, pSrcBox); @@ -430,32 +433,15 @@ NineVolume9_CopyMemToDefault( struct NineVolume9 *This, dst_box.height = src_box.height; dst_box.depth = src_box.depth; - pipe = NineDevice9_GetPipe(This->base.device); - - map = pipe->transfer_map(pipe, - r_dst, - This->level, - PIPE_TRANSFER_WRITE | PIPE_TRANSFER_DISCARD_RANGE, - &dst_box, &transfer); - if (!map) - return; - - /* Note: if formats are the sames, it will revert - * to normal memcpy */ - (void) util_format_translate_3d(r_dst->format, - map, transfer->stride, - transfer->layer_stride, - 0, 0, 0, - From->info.format, - From->data, From->stride, - From->layer_stride, - src_box.x, src_box.y, - src_box.z, - src_box.width, - src_box.height, - src_box.depth); - - pipe_transfer_unmap(pipe, transfer); + nine_context_box_upload(This->base.device, + &From->pending_uploads_counter, + r_dst, + This->level, + &dst_box, + From->info.format, + From->data, From->stride, + From->layer_stride, + &src_box); if (This->data_conversion) (void) util_format_translate_3d(This->format_conversion, @@ -481,10 +467,8 @@ HRESULT NineVolume9_UploadSelf( struct NineVolume9 *This, const struct pipe_box *damaged ) { - struct pipe_context *pipe; struct pipe_resource *res = This->resource; struct pipe_box box; - uint8_t *ptr; DBG("This=%p damaged=%p data=%p res=%p\n", This, damaged, This->data, res); @@ -503,11 +487,15 @@ NineVolume9_UploadSelf( struct NineVolume9 *This, box.depth = This->desc.Depth; } - ptr = NineVolume9_GetSystemMemPointer(This, box.x, box.y, box.z); - - pipe = NineDevice9_GetPipe(This->base.device); - pipe->texture_subdata(pipe, res, This->level, 0, &box, - ptr, This->stride, This->layer_stride); + nine_context_box_upload(This->base.device, + &This->pending_uploads_counter, + res, + This->level, + &box, + res->format, + This->data, This->stride, + This->layer_stride, + &box); return D3D_OK; } diff --git a/src/gallium/state_trackers/nine/volume9.h b/src/gallium/state_trackers/nine/volume9.h index 5bddf8f4c19..e84119f62cf 100644 --- a/src/gallium/state_trackers/nine/volume9.h +++ b/src/gallium/state_trackers/nine/volume9.h @@ -53,6 +53,8 @@ struct NineVolume9 struct pipe_transfer *transfer; unsigned lock_count; + + unsigned pending_uploads_counter; /* pending uploads */ }; static inline struct NineVolume9 * NineVolume9( void *data ) |