[FFmpeg-devel] [PATCH 2/2] libavformat/mpegts.c: is_pes_stream() use switch case

Marton Balint cus at passwd.hu
Wed Dec 4 00:04:23 EET 2024



On Sun, 1 Dec 2024, Scott Theisen wrote:

> also add STREAM_TYPE_PRIVATE_SECTION since a private_section() is not a
> PES_packet().
> ---
> libavformat/mpegts.c | 14 ++++++++++++--
> 1 file changed, 12 insertions(+), 2 deletions(-)

Will apply.

Thanks,
Marton

>
> diff --git a/libavformat/mpegts.c b/libavformat/mpegts.c
> index b4bf70bcbf..e470f12d22 100644
> --- a/libavformat/mpegts.c
> +++ b/libavformat/mpegts.c
> @@ -2316,8 +2316,18 @@ static int parse_stream_identifier_desc(const uint8_t *p, const uint8_t *p_end)
>
> static int is_pes_stream(int stream_type, uint32_t prog_reg_desc)
> {
> -    return !(stream_type == STREAM_TYPE_ISO_IEC_14496_SECTION ||
> -             (stream_type == STREAM_TYPE_SCTE_DATA_SCTE_35 && prog_reg_desc == AV_RL32("CUEI")) );
> +    switch (stream_type) {
> +    case STREAM_TYPE_PRIVATE_SECTION:
> +    case STREAM_TYPE_ISO_IEC_14496_SECTION:
> +        return 0;
> +    case STREAM_TYPE_SCTE_DATA_SCTE_35:
> +        /* This User Private stream_type value is used by multiple organizations
> +           for different things.  ANSI/SCTE 35 splice_info_section() is a
> +           private_section() not a PES_packet(). */
> +        return !(prog_reg_desc == AV_RL32("CUEI"));
> +    default:
> +        return 1;
> +    }
> }
>
> static void pmt_cb(MpegTSFilter *filter, const uint8_t *section, int section_len)
> -- 
> 2.43.0
>
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel at ffmpeg.org
> https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>
> To unsubscribe, visit link above, or email
> ffmpeg-devel-request at ffmpeg.org with subject "unsubscribe".
>


More information about the ffmpeg-devel mailing list