Commit d9418aba authored by Andreas Rheinhardt's avatar Andreas Rheinhardt Committed by Mark Thompson

cbs_h264, h264_metadata: Deleting SEI messages never fails

Given the recent changes to ff_cbs_delete_unit, it is no longer sensible
to use a return value for ff_cbs_h264_delete_sei_message; instead, use
asserts to ensure that the required conditions are met and remove the
callers' checks for the return value. Also, document said conditions.

An assert that is essentially equivalent to the one used in
ff_cbs_delete_unit has been removed, too.
Signed-off-by: 's avatarAndreas Rheinhardt <andreas.rheinhardt@gmail.com>
parent 730e5be3
...@@ -478,10 +478,13 @@ int ff_cbs_h264_add_sei_message(CodedBitstreamContext *ctx, ...@@ -478,10 +478,13 @@ int ff_cbs_h264_add_sei_message(CodedBitstreamContext *ctx,
* *
* Deletes from nal_unit, which must be an SEI NAL unit. If this is the * Deletes from nal_unit, which must be an SEI NAL unit. If this is the
* last message in nal_unit, also deletes it from access_unit. * last message in nal_unit, also deletes it from access_unit.
*
* Requires nal_unit to be a unit in access_unit and position to be >= 0
* and < the payload count of the SEI nal_unit.
*/ */
int ff_cbs_h264_delete_sei_message(CodedBitstreamContext *ctx, void ff_cbs_h264_delete_sei_message(CodedBitstreamContext *ctx,
CodedBitstreamFragment *access_unit, CodedBitstreamFragment *access_unit,
CodedBitstreamUnit *nal_unit, CodedBitstreamUnit *nal_unit,
int position); int position);
#endif /* AVCODEC_CBS_H264_H */ #endif /* AVCODEC_CBS_H264_H */
...@@ -1644,10 +1644,10 @@ int ff_cbs_h264_add_sei_message(CodedBitstreamContext *ctx, ...@@ -1644,10 +1644,10 @@ int ff_cbs_h264_add_sei_message(CodedBitstreamContext *ctx,
return 0; return 0;
} }
int ff_cbs_h264_delete_sei_message(CodedBitstreamContext *ctx, void ff_cbs_h264_delete_sei_message(CodedBitstreamContext *ctx,
CodedBitstreamFragment *au, CodedBitstreamFragment *au,
CodedBitstreamUnit *nal, CodedBitstreamUnit *nal,
int position) int position)
{ {
H264RawSEI *sei = nal->content; H264RawSEI *sei = nal->content;
...@@ -1662,7 +1662,6 @@ int ff_cbs_h264_delete_sei_message(CodedBitstreamContext *ctx, ...@@ -1662,7 +1662,6 @@ int ff_cbs_h264_delete_sei_message(CodedBitstreamContext *ctx,
if (&au->units[i] == nal) if (&au->units[i] == nal)
break; break;
} }
av_assert0(i < au->nb_units && "NAL unit not in access unit.");
ff_cbs_delete_unit(ctx, au, i); ff_cbs_delete_unit(ctx, au, i);
} else { } else {
...@@ -1673,6 +1672,4 @@ int ff_cbs_h264_delete_sei_message(CodedBitstreamContext *ctx, ...@@ -1673,6 +1672,4 @@ int ff_cbs_h264_delete_sei_message(CodedBitstreamContext *ctx,
sei->payload + position + 1, sei->payload + position + 1,
(sei->payload_count - position) * sizeof(*sei->payload)); (sei->payload_count - position) * sizeof(*sei->payload));
} }
return 0;
} }
...@@ -437,15 +437,9 @@ static int h264_metadata_filter(AVBSFContext *bsf, AVPacket *pkt) ...@@ -437,15 +437,9 @@ static int h264_metadata_filter(AVBSFContext *bsf, AVPacket *pkt)
for (j = sei->payload_count - 1; j >= 0; j--) { for (j = sei->payload_count - 1; j >= 0; j--) {
if (sei->payload[j].payload_type == if (sei->payload[j].payload_type ==
H264_SEI_TYPE_FILLER_PAYLOAD) { H264_SEI_TYPE_FILLER_PAYLOAD)
err = ff_cbs_h264_delete_sei_message(ctx->cbc, au, ff_cbs_h264_delete_sei_message(ctx->cbc, au,
&au->units[i], j); &au->units[i], j);
if (err < 0) {
av_log(bsf, AV_LOG_ERROR, "Failed to delete "
"filler SEI message.\n");
goto fail;
}
}
} }
} }
} }
...@@ -469,13 +463,8 @@ static int h264_metadata_filter(AVBSFContext *bsf, AVPacket *pkt) ...@@ -469,13 +463,8 @@ static int h264_metadata_filter(AVBSFContext *bsf, AVPacket *pkt)
if (ctx->display_orientation == REMOVE || if (ctx->display_orientation == REMOVE ||
ctx->display_orientation == INSERT) { ctx->display_orientation == INSERT) {
err = ff_cbs_h264_delete_sei_message(ctx->cbc, au, ff_cbs_h264_delete_sei_message(ctx->cbc, au,
&au->units[i], j); &au->units[i], j);
if (err < 0) {
av_log(bsf, AV_LOG_ERROR, "Failed to delete "
"display orientation SEI message.\n");
goto fail;
}
continue; continue;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment