Mercurial > mplayer.hg
comparison libswscale/swscale.c @ 31930:99c8503d1be8
swscale: fix unaligned accesses in (RGB|BGR)32_1 to YUV conversion
author | mru |
---|---|
date | Mon, 23 Aug 2010 21:22:24 +0000 |
parents | 98cc2b73ba26 |
children | cc96ac540245 |
comparison
equal
deleted
inserted
replaced
31929:98cc2b73ba26 | 31930:99c8503d1be8 |
---|---|
1046 dst[i]= (((RY)*r + (GY)*g + (BY)*b + (33<<((S)-1)))>>(S));\ | 1046 dst[i]= (((RY)*r + (GY)*g + (BY)*b + (33<<((S)-1)))>>(S));\ |
1047 }\ | 1047 }\ |
1048 } | 1048 } |
1049 | 1049 |
1050 BGR2Y(uint32_t, bgr32ToY,16, 0, 0, 0x00FF, 0xFF00, 0x00FF, RY<< 8, GY , BY<< 8, RGB2YUV_SHIFT+8) | 1050 BGR2Y(uint32_t, bgr32ToY,16, 0, 0, 0x00FF, 0xFF00, 0x00FF, RY<< 8, GY , BY<< 8, RGB2YUV_SHIFT+8) |
1051 BGR2Y(uint32_t,bgr321ToY,16,16, 0, 0xFF00, 0x00FF, 0xFF00, RY , GY<<8, BY , RGB2YUV_SHIFT+8) | |
1051 BGR2Y(uint32_t, rgb32ToY, 0, 0,16, 0x00FF, 0xFF00, 0x00FF, RY<< 8, GY , BY<< 8, RGB2YUV_SHIFT+8) | 1052 BGR2Y(uint32_t, rgb32ToY, 0, 0,16, 0x00FF, 0xFF00, 0x00FF, RY<< 8, GY , BY<< 8, RGB2YUV_SHIFT+8) |
1053 BGR2Y(uint32_t,rgb321ToY, 0,16,16, 0xFF00, 0x00FF, 0xFF00, RY , GY<<8, BY , RGB2YUV_SHIFT+8) | |
1052 BGR2Y(uint16_t, bgr16ToY, 0, 0, 0, 0x001F, 0x07E0, 0xF800, RY<<11, GY<<5, BY , RGB2YUV_SHIFT+8) | 1054 BGR2Y(uint16_t, bgr16ToY, 0, 0, 0, 0x001F, 0x07E0, 0xF800, RY<<11, GY<<5, BY , RGB2YUV_SHIFT+8) |
1053 BGR2Y(uint16_t, bgr15ToY, 0, 0, 0, 0x001F, 0x03E0, 0x7C00, RY<<10, GY<<5, BY , RGB2YUV_SHIFT+7) | 1055 BGR2Y(uint16_t, bgr15ToY, 0, 0, 0, 0x001F, 0x03E0, 0x7C00, RY<<10, GY<<5, BY , RGB2YUV_SHIFT+7) |
1054 BGR2Y(uint16_t, rgb16ToY, 0, 0, 0, 0xF800, 0x07E0, 0x001F, RY , GY<<5, BY<<11, RGB2YUV_SHIFT+8) | 1056 BGR2Y(uint16_t, rgb16ToY, 0, 0, 0, 0xF800, 0x07E0, 0x001F, RY , GY<<5, BY<<11, RGB2YUV_SHIFT+8) |
1055 BGR2Y(uint16_t, rgb15ToY, 0, 0, 0, 0x7C00, 0x03E0, 0x001F, RY , GY<<5, BY<<10, RGB2YUV_SHIFT+7) | 1057 BGR2Y(uint16_t, rgb15ToY, 0, 0, 0, 0x7C00, 0x03E0, 0x001F, RY , GY<<5, BY<<10, RGB2YUV_SHIFT+7) |
1056 | 1058 |
1060 for (i=0; i<width; i++) { | 1062 for (i=0; i<width; i++) { |
1061 dst[i]= src[4*i]; | 1063 dst[i]= src[4*i]; |
1062 } | 1064 } |
1063 } | 1065 } |
1064 | 1066 |
1065 #define BGR2UV(type, name, shr, shg, shb, maskr, maskg, maskb, RU, GU, BU, RV, GV, BV, S)\ | 1067 #define BGR2UV(type, name, shr, shg, shb, shp, maskr, maskg, maskb, RU, GU, BU, RV, GV, BV, S) \ |
1066 static inline void name(uint8_t *dstU, uint8_t *dstV, const uint8_t *src, const uint8_t *dummy, long width, uint32_t *unused)\ | 1068 static inline void name(uint8_t *dstU, uint8_t *dstV, const uint8_t *src, const uint8_t *dummy, long width, uint32_t *unused)\ |
1067 {\ | 1069 {\ |
1068 int i;\ | 1070 int i;\ |
1069 for (i=0; i<width; i++) {\ | 1071 for (i=0; i<width; i++) {\ |
1070 int b= (((const type*)src)[i]&maskb)>>shb;\ | 1072 int b= (((const type*)src)[i]&maskb)>>(shb+shp);\ |
1071 int g= (((const type*)src)[i]&maskg)>>shg;\ | 1073 int g= (((const type*)src)[i]&maskg)>>(shg+shp);\ |
1072 int r= (((const type*)src)[i]&maskr)>>shr;\ | 1074 int r= (((const type*)src)[i]&maskr)>>(shr+shp);\ |
1073 \ | 1075 \ |
1074 dstU[i]= ((RU)*r + (GU)*g + (BU)*b + (257<<((S)-1)))>>(S);\ | 1076 dstU[i]= ((RU)*r + (GU)*g + (BU)*b + (257<<((S)-1)))>>(S);\ |
1075 dstV[i]= ((RV)*r + (GV)*g + (BV)*b + (257<<((S)-1)))>>(S);\ | 1077 dstV[i]= ((RV)*r + (GV)*g + (BV)*b + (257<<((S)-1)))>>(S);\ |
1076 }\ | 1078 }\ |
1077 }\ | 1079 }\ |
1078 static inline void name ## _half(uint8_t *dstU, uint8_t *dstV, const uint8_t *src, const uint8_t *dummy, long width, uint32_t *unused)\ | 1080 static inline void name ## _half(uint8_t *dstU, uint8_t *dstV, const uint8_t *src, const uint8_t *dummy, long width, uint32_t *unused)\ |
1079 {\ | 1081 {\ |
1080 int i;\ | 1082 int i;\ |
1081 for (i=0; i<width; i++) {\ | 1083 for (i=0; i<width; i++) {\ |
1082 int pix0= ((const type*)src)[2*i+0];\ | 1084 int pix0= ((const type*)src)[2*i+0]>>shp;\ |
1083 int pix1= ((const type*)src)[2*i+1];\ | 1085 int pix1= ((const type*)src)[2*i+1]>>shp;\ |
1084 int g= (pix0&~(maskr|maskb))+(pix1&~(maskr|maskb));\ | 1086 int g= (pix0&~(maskr|maskb))+(pix1&~(maskr|maskb));\ |
1085 int b= ((pix0+pix1-g)&(maskb|(2*maskb)))>>shb;\ | 1087 int b= ((pix0+pix1-g)&(maskb|(2*maskb)))>>shb;\ |
1086 int r= ((pix0+pix1-g)&(maskr|(2*maskr)))>>shr;\ | 1088 int r= ((pix0+pix1-g)&(maskr|(2*maskr)))>>shr;\ |
1087 g&= maskg|(2*maskg);\ | 1089 g&= maskg|(2*maskg);\ |
1088 \ | 1090 \ |
1091 dstU[i]= ((RU)*r + (GU)*g + (BU)*b + (257<<(S)))>>((S)+1);\ | 1093 dstU[i]= ((RU)*r + (GU)*g + (BU)*b + (257<<(S)))>>((S)+1);\ |
1092 dstV[i]= ((RV)*r + (GV)*g + (BV)*b + (257<<(S)))>>((S)+1);\ | 1094 dstV[i]= ((RV)*r + (GV)*g + (BV)*b + (257<<(S)))>>((S)+1);\ |
1093 }\ | 1095 }\ |
1094 } | 1096 } |
1095 | 1097 |
1096 BGR2UV(uint32_t, bgr32ToUV,16, 0, 0, 0xFF0000, 0xFF00, 0x00FF, RU<< 8, GU , BU<< 8, RV<< 8, GV , BV<< 8, RGB2YUV_SHIFT+8) | 1098 BGR2UV(uint32_t, bgr32ToUV,16, 0, 0, 0, 0xFF0000, 0xFF00, 0x00FF, RU<< 8, GU , BU<< 8, RV<< 8, GV , BV<< 8, RGB2YUV_SHIFT+8) |
1097 BGR2UV(uint32_t, rgb32ToUV, 0, 0,16, 0x00FF, 0xFF00, 0xFF0000, RU<< 8, GU , BU<< 8, RV<< 8, GV , BV<< 8, RGB2YUV_SHIFT+8) | 1099 BGR2UV(uint32_t,bgr321ToUV,16, 0, 0, 8, 0xFF0000, 0xFF00, 0x00FF, RU<< 8, GU , BU<< 8, RV<< 8, GV , BV<< 8, RGB2YUV_SHIFT+8) |
1098 BGR2UV(uint16_t, bgr16ToUV, 0, 0, 0, 0x001F, 0x07E0, 0xF800, RU<<11, GU<<5, BU , RV<<11, GV<<5, BV , RGB2YUV_SHIFT+8) | 1100 BGR2UV(uint32_t, rgb32ToUV, 0, 0,16, 0, 0x00FF, 0xFF00, 0xFF0000, RU<< 8, GU , BU<< 8, RV<< 8, GV , BV<< 8, RGB2YUV_SHIFT+8) |
1099 BGR2UV(uint16_t, bgr15ToUV, 0, 0, 0, 0x001F, 0x03E0, 0x7C00, RU<<10, GU<<5, BU , RV<<10, GV<<5, BV , RGB2YUV_SHIFT+7) | 1101 BGR2UV(uint32_t,rgb321ToUV, 0, 0,16, 8, 0x00FF, 0xFF00, 0xFF0000, RU<< 8, GU , BU<< 8, RV<< 8, GV , BV<< 8, RGB2YUV_SHIFT+8) |
1100 BGR2UV(uint16_t, rgb16ToUV, 0, 0, 0, 0xF800, 0x07E0, 0x001F, RU , GU<<5, BU<<11, RV , GV<<5, BV<<11, RGB2YUV_SHIFT+8) | 1102 BGR2UV(uint16_t, bgr16ToUV, 0, 0, 0, 0, 0x001F, 0x07E0, 0xF800, RU<<11, GU<<5, BU , RV<<11, GV<<5, BV , RGB2YUV_SHIFT+8) |
1101 BGR2UV(uint16_t, rgb15ToUV, 0, 0, 0, 0x7C00, 0x03E0, 0x001F, RU , GU<<5, BU<<10, RV , GV<<5, BV<<10, RGB2YUV_SHIFT+7) | 1103 BGR2UV(uint16_t, bgr15ToUV, 0, 0, 0, 0, 0x001F, 0x03E0, 0x7C00, RU<<10, GU<<5, BU , RV<<10, GV<<5, BV , RGB2YUV_SHIFT+7) |
1104 BGR2UV(uint16_t, rgb16ToUV, 0, 0, 0, 0, 0xF800, 0x07E0, 0x001F, RU , GU<<5, BU<<11, RV , GV<<5, BV<<11, RGB2YUV_SHIFT+8) | |
1105 BGR2UV(uint16_t, rgb15ToUV, 0, 0, 0, 0, 0x7C00, 0x03E0, 0x001F, RU , GU<<5, BU<<10, RV , GV<<5, BV<<10, RGB2YUV_SHIFT+7) | |
1102 | 1106 |
1103 static inline void palToY(uint8_t *dst, const uint8_t *src, long width, uint32_t *pal) | 1107 static inline void palToY(uint8_t *dst, const uint8_t *src, long width, uint32_t *pal) |
1104 { | 1108 { |
1105 int i; | 1109 int i; |
1106 for (i=0; i<width; i++) { | 1110 for (i=0; i<width; i++) { |