[Mesa-dev] [PATCH v2] vl/rbsp: add a check for emulation prevention three byte

Christian König christian.koenig at amd.com
Tue Aug 9 15:41:55 UTC 2016


Am 09.08.2016 um 17:18 schrieb Leo Liu:
> This is the case when the "00 00 03" is very close to the beginning of
> nal unit header
>
> v2: move the check to rbsp init
>
> Signed-off-by: Leo Liu <leo.liu at amd.com>

Reviewed-by: Christian König <christian.koenig at amd.com>

> ---
>   src/gallium/auxiliary/vl/vl_rbsp.h | 14 ++++++++++++--
>   1 file changed, 12 insertions(+), 2 deletions(-)
>
> diff --git a/src/gallium/auxiliary/vl/vl_rbsp.h b/src/gallium/auxiliary/vl/vl_rbsp.h
> index 7867238..c8bebff 100644
> --- a/src/gallium/auxiliary/vl/vl_rbsp.h
> +++ b/src/gallium/auxiliary/vl/vl_rbsp.h
> @@ -50,7 +50,8 @@ struct vl_rbsp {
>    */
>   static inline void vl_rbsp_init(struct vl_rbsp *rbsp, struct vl_vlc *nal, unsigned num_bits)
>   {
> -   unsigned bits_left = vl_vlc_bits_left(nal);
> +   unsigned valid, bits_left = vl_vlc_bits_left(nal);
> +   int i;
>   
>      /* copy the position */
>      rbsp->nal = *nal;
> @@ -62,10 +63,19 @@ static inline void vl_rbsp_init(struct vl_rbsp *rbsp, struct vl_vlc *nal, unsign
>         if (vl_vlc_peekbits(nal, 24) == 0x000001 ||
>             vl_vlc_peekbits(nal, 32) == 0x00000001) {
>            vl_vlc_limit(&rbsp->nal, bits_left - vl_vlc_bits_left(nal));
> -         return;
> +         break;
>         }
>         vl_vlc_eatbits(nal, 8);
>      }
> +
> +   valid = vl_vlc_valid_bits(&rbsp->nal);
> +   /* search for the emulation prevention three byte */
> +   for (i = 24; i <= valid; i += 8) {
> +      if ((vl_vlc_peekbits(&rbsp->nal, i) & 0xffffff) == 0x3) {
> +         vl_vlc_removebits(&rbsp->nal, i - 8, 8);
> +         i += 8;
> +      }
> +   }
>   }
>   
>   /**




More information about the mesa-dev mailing list