Mercurial > libavcodec.hg
changeset 11691:24827da9c8dc libavcodec
Optimize decodeplane8(), patch by Sebastian Vater <cdgs basty googlemail com>.
author | rbultje |
---|---|
date | Sat, 08 May 2010 21:48:44 +0000 |
parents | 56a2ead12502 |
children | 5eb6d3cbf257 |
files | iff.c |
diffstat | 1 files changed, 48 insertions(+), 7 deletions(-) [+] |
line wrap: on
line diff
--- a/iff.c Sat May 08 16:24:33 2010 +0000 +++ b/iff.c Sat May 08 21:48:44 2010 +0000 @@ -36,6 +36,49 @@ uint8_t * planebuf; } IffContext; +#define LUT8_PART(plane, v) \ + AV_LE2ME64C(UINT64_C(0x0000000)<<32 | v) << plane, \ + AV_LE2ME64C(UINT64_C(0x1000000)<<32 | v) << plane, \ + AV_LE2ME64C(UINT64_C(0x0010000)<<32 | v) << plane, \ + AV_LE2ME64C(UINT64_C(0x1010000)<<32 | v) << plane, \ + AV_LE2ME64C(UINT64_C(0x0000100)<<32 | v) << plane, \ + AV_LE2ME64C(UINT64_C(0x1000100)<<32 | v) << plane, \ + AV_LE2ME64C(UINT64_C(0x0010100)<<32 | v) << plane, \ + AV_LE2ME64C(UINT64_C(0x1010100)<<32 | v) << plane, \ + AV_LE2ME64C(UINT64_C(0x0000001)<<32 | v) << plane, \ + AV_LE2ME64C(UINT64_C(0x1000001)<<32 | v) << plane, \ + AV_LE2ME64C(UINT64_C(0x0010001)<<32 | v) << plane, \ + AV_LE2ME64C(UINT64_C(0x1010001)<<32 | v) << plane, \ + AV_LE2ME64C(UINT64_C(0x0000101)<<32 | v) << plane, \ + AV_LE2ME64C(UINT64_C(0x1000101)<<32 | v) << plane, \ + AV_LE2ME64C(UINT64_C(0x0010101)<<32 | v) << plane, \ + AV_LE2ME64C(UINT64_C(0x1010101)<<32 | v) << plane + +#define LUT8(plane) { \ + LUT8_PART(plane, 0x0000000), \ + LUT8_PART(plane, 0x1000000), \ + LUT8_PART(plane, 0x0010000), \ + LUT8_PART(plane, 0x1010000), \ + LUT8_PART(plane, 0x0000100), \ + LUT8_PART(plane, 0x1000100), \ + LUT8_PART(plane, 0x0010100), \ + LUT8_PART(plane, 0x1010100), \ + LUT8_PART(plane, 0x0000001), \ + LUT8_PART(plane, 0x1000001), \ + LUT8_PART(plane, 0x0010001), \ + LUT8_PART(plane, 0x1010001), \ + LUT8_PART(plane, 0x0000101), \ + LUT8_PART(plane, 0x1000101), \ + LUT8_PART(plane, 0x0010101), \ + LUT8_PART(plane, 0x1010101), \ +} + +// 8 planes * 8-bit mask +static const uint64_t plane8_lut[8][256] = { + LUT8(0), LUT8(1), LUT8(2), LUT8(3), + LUT8(4), LUT8(5), LUT8(6), LUT8(7), +}; + /** * Convert CMAP buffer (stored in extradata) to lavc palette format */ @@ -95,14 +138,12 @@ * @param bps bits_per_coded_sample (must be <= 8) * @param plane plane number to decode as */ -static void decodeplane8(uint8_t *dst, const uint8_t *const buf, int buf_size, int bps, int plane) +static void decodeplane8(uint8_t *dst, const uint8_t *buf, int buf_size, int bps, int plane) { - GetBitContext gb; - int i; - const int b = buf_size * 8; - init_get_bits(&gb, buf, buf_size * 8); - for(i = 0; i < b; i++) { - dst[i] |= get_bits1(&gb) << plane; + const uint64_t *lut = plane8_lut[plane]; + for(; --buf_size != 0; dst += 8) { + uint64_t v = AV_RN64A(dst) | lut[*buf++]; + AV_WN64A(dst, v); } }