[FFmpeg-cvslog] lavc/rawdec: Retrieve nut palette from packets

Mats Peterson git at videolan.org
Tue Feb 16 15:03:15 CET 2016


ffmpeg | branch: master | Mats Peterson <matsp888 at yahoo.com> | Tue Feb 16 11:44:50 2016 +0100| [b86ba37096dd5c3c45d10fcd994128f973bfee7f] | committer: Michael Niedermayer

lavc/rawdec: Retrieve nut palette from packets

Signed-off-by: Michael Niedermayer <michael at niedermayer.cc>

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=b86ba37096dd5c3c45d10fcd994128f973bfee7f
---

 libavcodec/rawdec.c |    8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)

diff --git a/libavcodec/rawdec.c b/libavcodec/rawdec.c
index 287be96..3a2fac3 100644
--- a/libavcodec/rawdec.c
+++ b/libavcodec/rawdec.c
@@ -384,7 +384,6 @@ static int raw_decode(AVCodecContext *avctx, void *data, int *got_frame,
     if (avctx->pix_fmt == AV_PIX_FMT_PAL8) {
         const uint8_t *pal = av_packet_get_side_data(avpkt, AV_PKT_DATA_PALETTE,
                                                      NULL);
-
         if (pal) {
             av_buffer_unref(&context->palette);
             context->palette = av_buffer_alloc(AVPALETTE_SIZE);
@@ -394,6 +393,13 @@ static int raw_decode(AVCodecContext *avctx, void *data, int *got_frame,
             }
             memcpy(context->palette->data, pal, AVPALETTE_SIZE);
             frame->palette_has_changed = 1;
+        } else if (context->is_nut_pal8) {
+            int vid_size = avctx->width * avctx->height;
+            if (avpkt->size - vid_size) {
+                pal = avpkt->data + vid_size;
+                memcpy(context->palette->data, pal, avpkt->size - vid_size);
+                frame->palette_has_changed = 1;
+            }
         }
     }
 



More information about the ffmpeg-cvslog mailing list