[FFmpeg-devel] [PATCH] rtpenc_vp8: Use 15-bit PictureIDs

Martin Storsjö martin at martin.st
Sat Mar 26 00:43:59 EET 2022


On Tue, 22 Mar 2022, kevin at muxable.com wrote:

> From: Kevin Wang <kevmo314 at gmail.com>
>
> 7-bit PictureIDs are not supported by WebRTC:
> https://groups.google.com/g/discuss-webrtc/c/333-L02vuWA
>
> In practice, 15-bit PictureIDs offer better compatibility.
>
> Signed-off-by: Kevin Wang <kevin at muxable.com>
> ---
> libavformat/rtpenc_vp8.c | 3 ++-
> 1 file changed, 2 insertions(+), 1 deletion(-)
>
> diff --git a/libavformat/rtpenc_vp8.c b/libavformat/rtpenc_vp8.c
> index 671d245758..655d44517e 100644
> --- a/libavformat/rtpenc_vp8.c
> +++ b/libavformat/rtpenc_vp8.c
> @@ -35,7 +35,8 @@ void ff_rtp_send_vp8(AVFormatContext *s1, const uint8_t *buf, int size)
>     // partition id 0
>     *s->buf_ptr++ = 0x90;
>     *s->buf_ptr++ = 0x80; // Picture id present
> -    *s->buf_ptr++ = s->frame_count++ & 0x7f;
> +    *s->buf_ptr++ = ((s->frame_count & 0x7f00) >> 8) | 0x80;
> +    *s->buf_ptr++ = s->frame_count++ & 0xff;
>     // Calculate the number of remaining bytes
>     header_size     = s->buf_ptr - s->buf;
>     max_packet_size = s->max_payload_size - header_size;
> -- 
> 2.34.1

LGTM, thanks!

// Martin



More information about the ffmpeg-devel mailing list