diff mbox series

[FFmpeg-devel,3/5] avcodec/ylc: Avoid code duplication when creating and freeing VLCs

Message ID 20210308152957.601419-3-andreas.rheinhardt@gmail.com
State Accepted
Commit d7d33c0376057817d25cca63d4136350ca76a1aa
Headers show
Series [FFmpeg-devel,1/5] avcodec/ylc: Remove write-only variable | expand

Checks

Context Check Description
andriy/x86_make success Make finished
andriy/x86_make_fate success Make fate finished
andriy/configure warning Failed to apply patch

Commit Message

Andreas Rheinhardt March 8, 2021, 3:29 p.m. UTC
Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@gmail.com>
---
 libavcodec/ylc.c | 23 +++++++----------------
 1 file changed, 7 insertions(+), 16 deletions(-)

Comments

Paul B Mahol March 8, 2021, 3:58 p.m. UTC | #1
all ylc patches lgtm.

On Mon, Mar 8, 2021 at 4:30 PM Andreas Rheinhardt <
andreas.rheinhardt@gmail.com> wrote:

> Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@gmail.com>
> ---
>  libavcodec/ylc.c | 23 +++++++----------------
>  1 file changed, 7 insertions(+), 16 deletions(-)
>
> diff --git a/libavcodec/ylc.c b/libavcodec/ylc.c
> index 6dc3e60fec..793d8846b5 100644
> --- a/libavcodec/ylc.c
> +++ b/libavcodec/ylc.c
> @@ -38,7 +38,7 @@
>
>  typedef struct YLCContext {
>      VLC vlc[4];
> -    uint32_t table[1024];
> +    uint32_t table[256];
>      uint8_t *buffer;
>      int buffer_size;
>      BswapDSPContext bdsp;
> @@ -324,25 +324,18 @@ static int decode_frame(AVCodecContext *avctx,
>      if ((ret = init_get_bits8(&gb, s->buffer, boffset - toffset)) < 0)
>          return ret;
>
> -    for (x = 0; x < 1024; x++) {
> +    for (int i = 0; i < 4; i++) {
> +        for (x = 0; x < 256; x++) {
>          unsigned len = get_unary(&gb, 1, 31);
>          uint32_t val = ((1U << len) - 1) + get_bits_long(&gb, len);
>
>          s->table[x] = val;
>      }
>
> -    ret = build_vlc(avctx, &s->vlc[0], &s->table[0  ]);
> -    if (ret < 0)
> -        return ret;
> -    ret = build_vlc(avctx, &s->vlc[1], &s->table[256]);
> -    if (ret < 0)
> -        return ret;
> -    ret = build_vlc(avctx, &s->vlc[2], &s->table[512]);
> -    if (ret < 0)
> -        return ret;
> -    ret = build_vlc(avctx, &s->vlc[3], &s->table[768]);
> +        ret = build_vlc(avctx, &s->vlc[i], s->table);
>      if (ret < 0)
>          return ret;
> +    }
>
>      memcpy(s->buffer, avpkt->data + boffset, avpkt->size - boffset);
>      memset(s->buffer + avpkt->size - boffset, 0,
> AV_INPUT_BUFFER_PADDING_SIZE);
> @@ -451,10 +444,8 @@ static av_cold int decode_end(AVCodecContext *avctx)
>  {
>      YLCContext *s = avctx->priv_data;
>
> -    ff_free_vlc(&s->vlc[0]);
> -    ff_free_vlc(&s->vlc[1]);
> -    ff_free_vlc(&s->vlc[2]);
> -    ff_free_vlc(&s->vlc[3]);
> +    for (int i = 0; i < FF_ARRAY_ELEMS(s->vlc); i++)
> +        ff_free_vlc(&s->vlc[i]);
>      av_freep(&s->buffer);
>      s->buffer_size = 0;
>
> --
> 2.27.0
>
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel@ffmpeg.org
> https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>
> To unsubscribe, visit link above, or email
> ffmpeg-devel-request@ffmpeg.org with subject "unsubscribe".
diff mbox series

Patch

diff --git a/libavcodec/ylc.c b/libavcodec/ylc.c
index 6dc3e60fec..793d8846b5 100644
--- a/libavcodec/ylc.c
+++ b/libavcodec/ylc.c
@@ -38,7 +38,7 @@ 
 
 typedef struct YLCContext {
     VLC vlc[4];
-    uint32_t table[1024];
+    uint32_t table[256];
     uint8_t *buffer;
     int buffer_size;
     BswapDSPContext bdsp;
@@ -324,25 +324,18 @@  static int decode_frame(AVCodecContext *avctx,
     if ((ret = init_get_bits8(&gb, s->buffer, boffset - toffset)) < 0)
         return ret;
 
-    for (x = 0; x < 1024; x++) {
+    for (int i = 0; i < 4; i++) {
+        for (x = 0; x < 256; x++) {
         unsigned len = get_unary(&gb, 1, 31);
         uint32_t val = ((1U << len) - 1) + get_bits_long(&gb, len);
 
         s->table[x] = val;
     }
 
-    ret = build_vlc(avctx, &s->vlc[0], &s->table[0  ]);
-    if (ret < 0)
-        return ret;
-    ret = build_vlc(avctx, &s->vlc[1], &s->table[256]);
-    if (ret < 0)
-        return ret;
-    ret = build_vlc(avctx, &s->vlc[2], &s->table[512]);
-    if (ret < 0)
-        return ret;
-    ret = build_vlc(avctx, &s->vlc[3], &s->table[768]);
+        ret = build_vlc(avctx, &s->vlc[i], s->table);
     if (ret < 0)
         return ret;
+    }
 
     memcpy(s->buffer, avpkt->data + boffset, avpkt->size - boffset);
     memset(s->buffer + avpkt->size - boffset, 0, AV_INPUT_BUFFER_PADDING_SIZE);
@@ -451,10 +444,8 @@  static av_cold int decode_end(AVCodecContext *avctx)
 {
     YLCContext *s = avctx->priv_data;
 
-    ff_free_vlc(&s->vlc[0]);
-    ff_free_vlc(&s->vlc[1]);
-    ff_free_vlc(&s->vlc[2]);
-    ff_free_vlc(&s->vlc[3]);
+    for (int i = 0; i < FF_ARRAY_ELEMS(s->vlc); i++)
+        ff_free_vlc(&s->vlc[i]);
     av_freep(&s->buffer);
     s->buffer_size = 0;