diff --git a/libswscale/swscale.c b/libswscale/swscale.c index 1b21a2f463dcf8ecc170b0d5d4c458ceceb6dcbe..0dec5e5e8e64be62130b9f7994d6ce3e033af779 100644 --- a/libswscale/swscale.c +++ b/libswscale/swscale.c @@ -2036,7 +2036,10 @@ SwsContext *sws_getContext(int srcW, int srcH, int srcFormat, int dstW, int dstH c->chrSrcVSubSample+= c->vChrDrop; // drop every 2. pixel for chroma calculation unless user wants full chroma - if((isBGR(srcFormat) || isRGB(srcFormat)) && !(flags&SWS_FULL_CHR_H_INP)) + if((isBGR(srcFormat) || isRGB(srcFormat)) && !(flags&SWS_FULL_CHR_H_INP) + && srcFormat!=PIX_FMT_RGB8 && srcFormat!=PIX_FMT_BGR8 + && srcFormat!=PIX_FMT_RGB4 && srcFormat!=PIX_FMT_BGR4 + && srcFormat!=PIX_FMT_RGB4_BYTE && srcFormat!=PIX_FMT_BGR4_BYTE) c->chrSrcHSubSample=1; if(param){ diff --git a/libswscale/swscale_template.c b/libswscale/swscale_template.c index a8616efcb0c64c63fe28f7b5a56c9a1ca4cd8b22..61f8705a4cd5395b09546226f8ebd5272127d8a9 100644 --- a/libswscale/swscale_template.c +++ b/libswscale/swscale_template.c @@ -2296,12 +2296,10 @@ static inline void RENAME(palToUV)(uint8_t *dstU, uint8_t *dstV, uint8_t *src1, assert(src1 == src2); for(i=0; i>9; - dstV[i]= p>>17; + dstU[i]= p>>8; + dstV[i]= p>>16; } }