summaryrefslogtreecommitdiffstats
path: root/libswscale
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2012-01-10 23:12:21 +0100
committerMichael Niedermayer <michaelni@gmx.at>2012-01-10 23:12:24 +0100
commita9bd29e15e8d4ab4afaba7c31ebc0063c1df2db9 (patch)
tree6d7838b72e6ae2b4e390e278988b9a20d8aa2247 /libswscale
parentf4a01d7788449b08a3bd0569951860602bcd9eb5 (diff)
parent296a338261ebcfaf7b961a6d1e6a3adb4da69a61 (diff)
downloadffmpeg-streaming-a9bd29e15e8d4ab4afaba7c31ebc0063c1df2db9.zip
ffmpeg-streaming-a9bd29e15e8d4ab4afaba7c31ebc0063c1df2db9.tar.gz
Merge remote-tracking branch 'richardpl/sws'
* richardpl/sws: rgb2rgb: remove unused bgr8torgb8() rgb2rgb: rgb12tobgr12() rgb2rgb: allow conversion for <15 bpp bmpenc: support for PIX_FMT_RGB444 bmpdec: support for rgb444 with bitfields compression Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libswscale')
-rw-r--r--libswscale/rgb2rgb.c18
-rw-r--r--libswscale/rgb2rgb.h2
-rw-r--r--libswscale/swscale_unscaled.c63
3 files changed, 41 insertions, 42 deletions
diff --git a/libswscale/rgb2rgb.c b/libswscale/rgb2rgb.c
index 5b84f89..eb7ca7b 100644
--- a/libswscale/rgb2rgb.c
+++ b/libswscale/rgb2rgb.c
@@ -282,18 +282,16 @@ void rgb15tobgr15(const uint8_t *src, uint8_t *dst, int src_size)
}
}
-void bgr8torgb8(const uint8_t *src, uint8_t *dst, int src_size)
+void rgb12tobgr12(const uint8_t *src, uint8_t *dst, int src_size)
{
int i;
- int num_pixels = src_size;
- for (i=0; i<num_pixels; i++) {
- unsigned b,g,r;
- register uint8_t rgb;
- rgb = src[i];
- r = (rgb&0x07);
- g = (rgb&0x38)>>3;
- b = (rgb&0xC0)>>6;
- dst[i] = ((b<<1)&0x07) | ((g&0x07)<<3) | ((r&0x03)<<6);
+ int num_pixels = src_size >> 1;
+
+ for (i = 0; i < num_pixels; i++) {
+ unsigned br;
+ unsigned rgb = ((const uint16_t *)src)[i];
+ br = rgb & 0x0F0F;
+ ((uint16_t *)dst)[i] = (br >> 8) | (rgb & 0x00F0) | (br << 8);
}
}
diff --git a/libswscale/rgb2rgb.h b/libswscale/rgb2rgb.h
index a7542cb..4e63124 100644
--- a/libswscale/rgb2rgb.h
+++ b/libswscale/rgb2rgb.h
@@ -62,7 +62,7 @@ void rgb15tobgr32(const uint8_t *src, uint8_t *dst, int src_size);
void rgb15to24(const uint8_t *src, uint8_t *dst, int src_size);
void rgb15tobgr16(const uint8_t *src, uint8_t *dst, int src_size);
void rgb15tobgr15(const uint8_t *src, uint8_t *dst, int src_size);
-void bgr8torgb8(const uint8_t *src, uint8_t *dst, int src_size);
+void rgb12tobgr12(const uint8_t *src, uint8_t *dst, int src_size);
void shuffle_bytes_0321(const uint8_t *src, uint8_t *dst, int src_size);
void shuffle_bytes_1230(const uint8_t *src, uint8_t *dst, int src_size);
diff --git a/libswscale/swscale_unscaled.c b/libswscale/swscale_unscaled.c
index 401666b..bf79caab 100644
--- a/libswscale/swscale_unscaled.c
+++ b/libswscale/swscale_unscaled.c
@@ -404,8 +404,8 @@ static int rgbToRgbWrapper(SwsContext *c, const uint8_t *src[], int srcStride[],
const enum PixelFormat dstFormat = c->dstFormat;
const int srcBpp = (c->srcFormatBpp + 7) >> 3;
const int dstBpp = (c->dstFormatBpp + 7) >> 3;
- const int srcId = c->srcFormatBpp >> 2; /* 1:0, 4:1, 8:2, 15:3, 16:4, 24:6, 32:8 */
- const int dstId = c->dstFormatBpp >> 2;
+ const int srcId = c->srcFormatBpp;
+ const int dstId = c->dstFormatBpp;
void (*conv)(const uint8_t *src, uint8_t *dst, int src_size) = NULL;
#define CONV_IS(src, dst) (srcFormat == PIX_FMT_##src && dstFormat == PIX_FMT_##dst)
@@ -427,38 +427,39 @@ static int rgbToRgbWrapper(SwsContext *c, const uint8_t *src[], int srcStride[],
/* BGR -> BGR */
if ((isBGRinInt(srcFormat) && isBGRinInt(dstFormat)) ||
(isRGBinInt(srcFormat) && isRGBinInt(dstFormat))) {
- switch (srcId | (dstId << 4)) {
- case 0x34: conv = rgb16to15; break;
- case 0x36: conv = rgb24to15; break;
- case 0x38: conv = rgb32to15; break;
- case 0x43: conv = rgb15to16; break;
- case 0x46: conv = rgb24to16; break;
- case 0x48: conv = rgb32to16; break;
- case 0x63: conv = rgb15to24; break;
- case 0x64: conv = rgb16to24; break;
- case 0x68: conv = rgb32to24; break;
- case 0x83: conv = rgb15to32; break;
- case 0x84: conv = rgb16to32; break;
- case 0x86: conv = rgb24to32; break;
+ switch (srcId | (dstId << 16)) {
+ case 0x000F0010: conv = rgb16to15; break;
+ case 0x000F0018: conv = rgb24to15; break;
+ case 0x000F0020: conv = rgb32to15; break;
+ case 0x0010000F: conv = rgb15to16; break;
+ case 0x00100018: conv = rgb24to16; break;
+ case 0x00100020: conv = rgb32to16; break;
+ case 0x0018000F: conv = rgb15to24; break;
+ case 0x00180010: conv = rgb16to24; break;
+ case 0x00180020: conv = rgb32to24; break;
+ case 0x0020000F: conv = rgb15to32; break;
+ case 0x00200010: conv = rgb16to32; break;
+ case 0x00200018: conv = rgb24to32; break;
}
} else if ((isBGRinInt(srcFormat) && isRGBinInt(dstFormat)) ||
(isRGBinInt(srcFormat) && isBGRinInt(dstFormat))) {
- switch (srcId | (dstId << 4)) {
- case 0x33: conv = rgb15tobgr15; break;
- case 0x34: conv = rgb16tobgr15; break;
- case 0x36: conv = rgb24tobgr15; break;
- case 0x38: conv = rgb32tobgr15; break;
- case 0x43: conv = rgb15tobgr16; break;
- case 0x44: conv = rgb16tobgr16; break;
- case 0x46: conv = rgb24tobgr16; break;
- case 0x48: conv = rgb32tobgr16; break;
- case 0x63: conv = rgb15tobgr24; break;
- case 0x64: conv = rgb16tobgr24; break;
- case 0x66: conv = rgb24tobgr24; break;
- case 0x68: conv = rgb32tobgr24; break;
- case 0x83: conv = rgb15tobgr32; break;
- case 0x84: conv = rgb16tobgr32; break;
- case 0x86: conv = rgb24tobgr32; break;
+ switch (srcId | (dstId << 16)) {
+ case 0x000C000C: conv = rgb12tobgr12; break;
+ case 0x000F000F: conv = rgb15tobgr15; break;
+ case 0x000F0010: conv = rgb16tobgr15; break;
+ case 0x000F0018: conv = rgb24tobgr15; break;
+ case 0x000F0020: conv = rgb32tobgr15; break;
+ case 0x0010000F: conv = rgb15tobgr16; break;
+ case 0x00100010: conv = rgb16tobgr16; break;
+ case 0x00100018: conv = rgb24tobgr16; break;
+ case 0x00100020: conv = rgb32tobgr16; break;
+ case 0x0018000F: conv = rgb15tobgr24; break;
+ case 0x00180010: conv = rgb16tobgr24; break;
+ case 0x00180018: conv = rgb24tobgr24; break;
+ case 0x00180020: conv = rgb32tobgr24; break;
+ case 0x0020000F: conv = rgb15tobgr32; break;
+ case 0x00200010: conv = rgb16tobgr32; break;
+ case 0x00200018: conv = rgb24tobgr32; break;
}
}
OpenPOWER on IntegriCloud