Mercurial > mplayer.hg
changeset 17586:65b39a32a7c4
Fix big-endian color permutation problems.
patch by Alan Curry, pacman_at_TheWorld_dot_com
author | diego |
---|---|
date | Sat, 11 Feb 2006 13:35:46 +0000 |
parents | 03829916a1c3 |
children | e1108996497c |
files | postproc/rgb2rgb.c postproc/rgb2rgb_template.c |
diffstat | 2 files changed, 46 insertions(+), 11 deletions(-) [+] |
line wrap: on
line diff
--- a/postproc/rgb2rgb.c Sat Feb 11 09:56:49 2006 +0000 +++ b/postproc/rgb2rgb.c Sat Feb 11 13:35:46 2006 +0000 @@ -446,9 +446,16 @@ long num_pixels = src_size >> 2; for(i=0; i<num_pixels; i++) { + #ifdef WORDS_BIGENDIAN + /* RGB32 (= A,B,G,R) -> BGR24 (= B,G,R) */ + dst[3*i + 0] = src[4*i + 1]; + dst[3*i + 1] = src[4*i + 2]; + dst[3*i + 2] = src[4*i + 3]; + #else dst[3*i + 0] = src[4*i + 2]; dst[3*i + 1] = src[4*i + 1]; dst[3*i + 2] = src[4*i + 0]; + #endif } } @@ -457,10 +464,18 @@ long i; for(i=0; 3*i<src_size; i++) { + #ifdef WORDS_BIGENDIAN + /* RGB24 (= R,G,B) -> BGR32 (= A,R,G,B) */ + dst[4*i + 0] = 0; + dst[4*i + 1] = src[3*i + 0]; + dst[4*i + 2] = src[3*i + 1]; + dst[4*i + 3] = src[3*i + 2]; + #else dst[4*i + 0] = src[3*i + 2]; dst[4*i + 1] = src[3*i + 1]; dst[4*i + 2] = src[3*i + 0]; dst[4*i + 3] = 0; + #endif } } @@ -474,10 +489,17 @@ { register uint16_t bgr; bgr = *s++; + #ifdef WORDS_BIGENDIAN + *d++ = 0; + *d++ = (bgr&0x1F)<<3; + *d++ = (bgr&0x7E0)>>3; + *d++ = (bgr&0xF800)>>8; + #else *d++ = (bgr&0xF800)>>8; *d++ = (bgr&0x7E0)>>3; *d++ = (bgr&0x1F)<<3; *d++ = 0; + #endif } } @@ -541,10 +563,17 @@ { register uint16_t bgr; bgr = *s++; + #ifdef WORDS_BIGENDIAN + *d++ = 0; + *d++ = (bgr&0x1F)<<3; + *d++ = (bgr&0x3E0)>>2; + *d++ = (bgr&0x7C00)>>7; + #else *d++ = (bgr&0x7C00)>>7; *d++ = (bgr&0x3E0)>>2; *d++ = (bgr&0x1F)<<3; *d++ = 0; + #endif } }
--- a/postproc/rgb2rgb_template.c Sat Feb 11 09:56:49 2006 +0000 +++ b/postproc/rgb2rgb_template.c Sat Feb 11 13:35:46 2006 +0000 @@ -104,10 +104,12 @@ while(s < end) { #ifdef WORDS_BIGENDIAN + /* RGB24 (= R,G,B) -> RGB32 (= A,B,G,R) */ *dest++ = 0; - *dest++ = *s++; - *dest++ = *s++; - *dest++ = *s++; + *dest++ = s[2]; + *dest++ = s[1]; + *dest++ = s[0]; + s+=3; #else *dest++ = *s++; *dest++ = *s++; @@ -188,10 +190,12 @@ while(s < end) { #ifdef WORDS_BIGENDIAN + /* RGB32 (= A,B,G,R) -> RGB24 (= R,G,B) */ s++; - *dest++ = *s++; - *dest++ = *s++; - *dest++ = *s++; + dest[2] = *s++; + dest[1] = *s++; + dest[0] = *s++; + dest += 3; #else *dest++ = *s++; *dest++ = *s++; @@ -465,6 +469,7 @@ while(s < end) { // FIXME on bigendian + /* Looks bigendian-OK to me. --Pac. */ const int src= *s; s += 4; *d++ = ((src&0xF8)<<8) + ((src&0xFC00)>>5) + ((src&0xF80000)>>19); } @@ -562,6 +567,7 @@ while(s < end) { // FIXME on bigendian + /* Looks bigendian-OK to me. --Pac. */ const int src= *s; s += 4; *d++ = ((src&0xFF)>>3) + ((src&0xF800)>>6) + ((src&0xF80000)>>9); } @@ -624,6 +630,7 @@ while(s < end) { // FIXME on bigendian + /* Looks bigendian-OK to me. --Pac. */ const int src= *s; s += 4; *d++ = ((src&0xF8)<<7) + ((src&0xF800)>>6) + ((src&0xF80000)>>19); } @@ -1247,14 +1254,13 @@ int bgr= *s++; *((uint32_t*)d)++ = ((bgr&0x1F)<<3) + ((bgr&0x3E0)<<6) + ((bgr&0x7C00)<<9); #else -//FIXME this is very likely wrong for bigendian (and the following converters too) register uint16_t bgr; bgr = *s++; #ifdef WORDS_BIGENDIAN *d++ = 0; - *d++ = (bgr&0x1F)<<3; + *d++ = (bgr&0x7C00)>>7; *d++ = (bgr&0x3E0)>>2; - *d++ = (bgr&0x7C00)>>7; + *d++ = (bgr&0x1F)<<3; #else *d++ = (bgr&0x1F)<<3; *d++ = (bgr&0x3E0)>>2; @@ -1326,9 +1332,9 @@ bgr = *s++; #ifdef WORDS_BIGENDIAN *d++ = 0; - *d++ = (bgr&0x1F)<<3; + *d++ = (bgr&0xF800)>>8; *d++ = (bgr&0x7E0)>>3; - *d++ = (bgr&0xF800)>>8; + *d++ = (bgr&0x1F)<<3; #else *d++ = (bgr&0x1F)<<3; *d++ = (bgr&0x7E0)>>3;