diff options
author | Mats Peterson <matsp888@yahoo.com> | 2016-03-03 08:25:58 +0100 |
---|---|---|
committer | Michael Niedermayer <michael@niedermayer.cc> | 2016-03-04 04:02:19 +0100 |
commit | ba40b3520d91a3bff1637cbff54562e03b79bc2d (patch) | |
tree | 0d18031b8bbb1dae15dee2242a9326ed0444a3f8 | |
parent | 21234c835d2d003d390d462b6e1b2622e7b02c39 (diff) | |
download | ffmpeg-ba40b3520d91a3bff1637cbff54562e03b79bc2d.tar.gz |
lavf/utils: Normalize AVPacket.data to native endian in ff_get_packet_palette()
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
-rw-r--r-- | libavformat/internal.h | 7 | ||||
-rw-r--r-- | libavformat/utils.c | 23 |
2 files changed, 21 insertions, 9 deletions
diff --git a/libavformat/internal.h b/libavformat/internal.h index 63e0632a5d..37a8591ea2 100644 --- a/libavformat/internal.h +++ b/libavformat/internal.h @@ -588,9 +588,12 @@ int ff_reshuffle_raw_rgb(AVFormatContext *s, AVPacket **ppkt, AVCodecContext *en * * Use 0 for the ret parameter to check for side data only. * - * @param pkt pointer to the packet before calling ff_reshuffle_raw_rgb() + * @param pkt pointer to packet before calling ff_reshuffle_raw_rgb() * @param ret return value from ff_reshuffle_raw_rgb(), or 0 + * @param palette pointer to palette buffer + * @return negative error code or + * 1 if the packet has a palette, else 0 */ -int ff_get_packet_palette(AVFormatContext *s, AVPacket *pkt, int ret, const uint8_t **palette); +int ff_get_packet_palette(AVFormatContext *s, AVPacket *pkt, int ret, uint32_t *palette); #endif /* AVFORMAT_INTERNAL_H */ diff --git a/libavformat/utils.c b/libavformat/utils.c index 85702dd92a..7c14725d8b 100644 --- a/libavformat/utils.c +++ b/libavformat/utils.c @@ -4782,18 +4782,27 @@ int ff_standardize_creation_time(AVFormatContext *s) return ret; } -int ff_get_packet_palette(AVFormatContext *s, AVPacket *pkt, int ret, const uint8_t **palette) +int ff_get_packet_palette(AVFormatContext *s, AVPacket *pkt, int ret, uint32_t *palette) { + uint8_t *side_data; int size; - *palette = av_packet_get_side_data(pkt, AV_PKT_DATA_PALETTE, &size); - if (*palette && size != AVPALETTE_SIZE) { - av_log(s, AV_LOG_ERROR, "Invalid palette side data\n"); - return AVERROR_INVALIDDATA; + side_data = av_packet_get_side_data(pkt, AV_PKT_DATA_PALETTE, &size); + if (side_data) { + if (size != AVPALETTE_SIZE) { + av_log(s, AV_LOG_ERROR, "Invalid palette side data\n"); + return AVERROR_INVALIDDATA; + } + memcpy(palette, side_data, AVPALETTE_SIZE); + return 1; } - if (!*palette && ret == CONTAINS_PAL) - *palette = pkt->data + pkt->size - AVPALETTE_SIZE; + if (ret == CONTAINS_PAL) { + int i; + for (i = 0; i < AVPALETTE_COUNT; i++) + palette[i] = AV_RL32(pkt->data + pkt->size - AVPALETTE_SIZE + i*4); + return 1; + } return 0; } |