[FFmpeg-cvslog] dds: Write the palette in the native endian form

Martin Storsjö git at videolan.org
Thu Jul 23 21:46:39 CEST 2015


ffmpeg | branch: master | Martin Storsjö <martin at martin.st> | Thu Jul 23 17:59:44 2015 +0300| [44f7df0c987965763c609f6dc36974b04182e58d] | committer: Martin Storsjö

dds: Write the palette in the native endian form

This fixes the palette on big endian, broken (or, differing from
little endian) since 57214b2f7.

Signed-off-by: Martin Storsjö <martin at martin.st>

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

 libavcodec/dds.c |   12 +++++++-----
 1 file changed, 7 insertions(+), 5 deletions(-)

diff --git a/libavcodec/dds.c b/libavcodec/dds.c
index 2c3a2f2..f124d4a 100644
--- a/libavcodec/dds.c
+++ b/libavcodec/dds.c
@@ -653,14 +653,16 @@ static int dds_decode(AVCodecContext *avctx, void *data,
 
         if (ctx->paletted) {
             int i;
-            uint8_t *p = frame->data[1];
+            uint32_t *p = (uint32_t*) frame->data[1];
 
             /* Use the first 1024 bytes as palette, then copy the rest. */
             for (i = 0; i < 256; i++) {
-                p[i * 4 + 2] = bytestream2_get_byte(gbc);
-                p[i * 4 + 1] = bytestream2_get_byte(gbc);
-                p[i * 4 + 0] = bytestream2_get_byte(gbc);
-                p[i * 4 + 3] = bytestream2_get_byte(gbc);
+                uint32_t rgba = 0;
+                rgba |= bytestream2_get_byte(gbc) << 16;
+                rgba |= bytestream2_get_byte(gbc) << 8;
+                rgba |= bytestream2_get_byte(gbc) << 0;
+                rgba |= bytestream2_get_byte(gbc) << 24;
+                p[i] = rgba;
             }
 
             frame->palette_has_changed = 1;



More information about the ffmpeg-cvslog mailing list