[FFmpeg-devel] [PATCH v3 2/6] avformat/mpegtsenc: refact mpegts_check_bitstream to loop up table
Nuo Mi
nuomi2021 at gmail.com
Sat Jan 27 06:15:08 EET 2024
---
libavformat/mpegtsenc.c | 33 ++++++++++++++++++---------------
1 file changed, 18 insertions(+), 15 deletions(-)
diff --git a/libavformat/mpegtsenc.c b/libavformat/mpegtsenc.c
index 84edd418f0..418fa08ad5 100644
--- a/libavformat/mpegtsenc.c
+++ b/libavformat/mpegtsenc.c
@@ -2257,23 +2257,26 @@ static void mpegts_deinit(AVFormatContext *s)
static int mpegts_check_bitstream(AVFormatContext *s, AVStream *st,
const AVPacket *pkt)
{
- int ret = 1;
+ struct Entry {
+ enum AVCodecID id;
+ const char *bsf_name;
+ uint8_t m;
+ uint8_t v;
+ } list[] = {
+ { AV_CODEC_ID_H264, "h264_mp4toannexb", 0xff, 0x01 },
+ { AV_CODEC_ID_HEVC, "hevc_mp4toannexb", 0xff, 0x01 },
+ };
- if (st->codecpar->codec_id == AV_CODEC_ID_H264) {
- if (pkt->size >= 5 && AV_RB32(pkt->data) != 0x0000001 &&
- (AV_RB24(pkt->data) != 0x000001 ||
- (st->codecpar->extradata_size > 0 &&
- st->codecpar->extradata[0] == 1)))
- ret = ff_stream_add_bitstream_filter(st, "h264_mp4toannexb", NULL);
- } else if (st->codecpar->codec_id == AV_CODEC_ID_HEVC) {
- if (pkt->size >= 5 && AV_RB32(pkt->data) != 0x0000001 &&
- (AV_RB24(pkt->data) != 0x000001 ||
- (st->codecpar->extradata_size > 0 &&
- st->codecpar->extradata[0] == 1)))
- ret = ff_stream_add_bitstream_filter(st, "hevc_mp4toannexb", NULL);
+ for (int i = 0; i < FF_ARRAY_ELEMS(list); i++) {
+ struct Entry *e = list + i;
+ if (e->id == st->codecpar->codec_id &&
+ pkt->size >= 5 && AV_RB32(pkt->data) != 0x0000001 &&
+ (AV_RB24(pkt->data) != 0x000001 ||
+ (st->codecpar->extradata_size > 0 &&
+ (st->codecpar->extradata[0] & e->m == e->v))))
+ return ff_stream_add_bitstream_filter(st, e->bsf_name, NULL);
}
-
- return ret;
+ return 1;
}
#define OFFSET(x) offsetof(MpegTSWrite, x)
--
2.25.1
More information about the ffmpeg-devel
mailing list