summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorXiang, Haihao <haihao.xiang@intel.com>2016-12-24 00:01:51 +0800
committerXiang, Haihao <haihao.xiang@intel.com>2016-12-28 16:23:31 +0800
commit23d0c8725e9f2ffd0665c5186049f149b996a488 (patch)
tree33a971d52e323c850981b85a14cd84f38a7df07a
parent4f8ca10e96ffeba8e7448d19f5028261c3b6b9a5 (diff)
VDEnc: update the MFX_AVC_IMG_STATE command
Don't enable brc domain rate control if HuC is not used. Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com> Reviewed-by: Kelley, Sean V <sean.v.kelley@intel.com>
-rw-r--r--src/gen9_vdenc.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/src/gen9_vdenc.c b/src/gen9_vdenc.c
index faad8fc..de6f510 100644
--- a/src/gen9_vdenc.c
+++ b/src/gen9_vdenc.c
@@ -1860,7 +1860,8 @@ static void
gen9_vdenc_init_mfx_avc_img_state(VADriverContextP ctx,
struct encode_state *encode_state,
struct intel_encoder_context *encoder_context,
- struct gen9_mfx_avc_img_state *pstate)
+ struct gen9_mfx_avc_img_state *pstate,
+ int use_huc)
{
struct gen9_vdenc_context *vdenc_context = encoder_context->mfc_context;
VAEncSequenceParameterBufferH264 *seq_param = (VAEncSequenceParameterBufferH264 *)encode_state->seq_param_ext->buffer;
@@ -1878,7 +1879,7 @@ gen9_vdenc_init_mfx_avc_img_state(VADriverContextP ctx,
pstate->dw3.image_structure = 0;
pstate->dw3.weighted_bipred_idc = pic_param->pic_fields.bits.weighted_bipred_idc;
pstate->dw3.weighted_pred_flag = pic_param->pic_fields.bits.weighted_pred_flag;
- pstate->dw3.brc_domain_rate_control_enable = 1;
+ pstate->dw3.brc_domain_rate_control_enable = !!use_huc;
pstate->dw3.chroma_qp_offset = pic_param->chroma_qp_index_offset;
pstate->dw3.second_chroma_qp_offset = pic_param->second_chroma_qp_index_offset;
@@ -2135,7 +2136,7 @@ gen9_vdenc_init_img_states(VADriverContextP ctx,
return;
mfx_img_cmd = (struct gen9_mfx_avc_img_state *)pbuffer;
- gen9_vdenc_init_mfx_avc_img_state(ctx, encode_state, encoder_context, mfx_img_cmd);
+ gen9_vdenc_init_mfx_avc_img_state(ctx, encode_state, encoder_context, mfx_img_cmd, 1);
pbuffer += sizeof(*mfx_img_cmd);
vdenc_img_cmd = (struct gen9_vdenc_img_state *)pbuffer;
@@ -2542,7 +2543,7 @@ gen9_vdenc_mfx_avc_img_state(VADriverContextP ctx,
struct intel_batchbuffer *batch = encoder_context->base.batch;
struct gen9_mfx_avc_img_state mfx_img_cmd;
- gen9_vdenc_init_mfx_avc_img_state(ctx, encode_state, encoder_context, &mfx_img_cmd);
+ gen9_vdenc_init_mfx_avc_img_state(ctx, encode_state, encoder_context, &mfx_img_cmd, 0);
BEGIN_BCS_BATCH(batch, (sizeof(mfx_img_cmd) >> 2));
intel_batchbuffer_data(batch, &mfx_img_cmd, sizeof(mfx_img_cmd));