Signed-off-by: Leo Liu <leo....@amd.com>
---
 src/gallium/state_trackers/va/picture_vp9.c | 25 ++++++++++++++++++++++++-
 1 file changed, 24 insertions(+), 1 deletion(-)

diff --git a/src/gallium/state_trackers/va/picture_vp9.c 
b/src/gallium/state_trackers/va/picture_vp9.c
index d333a0cbcd..38684ca21e 100644
--- a/src/gallium/state_trackers/va/picture_vp9.c
+++ b/src/gallium/state_trackers/va/picture_vp9.c
@@ -84,5 +84,28 @@ void vlVaHandlePictureParameterBufferVP9(vlVaDriver *drv, 
vlVaContext *context,
 
 void vlVaHandleSliceParameterBufferVP9(vlVaContext *context, vlVaBuffer *buf)
 {
-   /* TODO */
+   VASliceParameterBufferVP9 *vp9 = buf->data;
+   int i;
+
+   assert(buf->size >= sizeof(VASliceParameterBufferVP9) && buf->num_elements 
== 1);
+
+   context->desc.vp9.slice_parameter.slice_data_size = vp9->slice_data_size;
+   context->desc.vp9.slice_parameter.slice_data_offset = 
vp9->slice_data_offset;
+   context->desc.vp9.slice_parameter.slice_data_flag = vp9->slice_data_flag;
+
+   for (i = 0; i < 8; ++i) {
+      
context->desc.vp9.slice_parameter.seg_param[i].segment_flags.segment_reference_enabled
 =
+         vp9->seg_param[i].segment_flags.fields.segment_reference_enabled;
+      
context->desc.vp9.slice_parameter.seg_param[i].segment_flags.segment_reference =
+         vp9->seg_param[i].segment_flags.fields.segment_reference;
+      
context->desc.vp9.slice_parameter.seg_param[i].segment_flags.segment_reference_skipped
 =
+         vp9->seg_param[i].segment_flags.fields.segment_reference_skipped;
+
+      memcpy(context->desc.vp9.slice_parameter.seg_param[i].filter_level, 
vp9->seg_param[i].filter_level, 4 * 2);
+
+      context->desc.vp9.slice_parameter.seg_param[i].luma_ac_quant_scale = 
vp9->seg_param[i].luma_ac_quant_scale;
+      context->desc.vp9.slice_parameter.seg_param[i].luma_dc_quant_scale = 
vp9->seg_param[i].luma_dc_quant_scale;
+      context->desc.vp9.slice_parameter.seg_param[i].chroma_ac_quant_scale = 
vp9->seg_param[i].chroma_ac_quant_scale;
+      context->desc.vp9.slice_parameter.seg_param[i].chroma_dc_quant_scale = 
vp9->seg_param[i].chroma_dc_quant_scale;
+   }
 }
-- 
2.14.1

_______________________________________________
mesa-dev mailing list
mesa-dev@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/mesa-dev

Reply via email to