Commit 2d420087 authored by Paul B Mahol's avatar Paul B Mahol

sanm: make use of dsputil

About 27% faster decoding.
Signed-off-by: 's avatarPaul B Mahol <onemda@gmail.com>
parent acdf9a6c
...@@ -25,6 +25,7 @@ ...@@ -25,6 +25,7 @@
#include "avcodec.h" #include "avcodec.h"
#include "bytestream.h" #include "bytestream.h"
#include "libavutil/bswap.h" #include "libavutil/bswap.h"
#include "libavcodec/dsputil.h"
#include "sanm_data.h" #include "sanm_data.h"
#define NGLYPHS 256 #define NGLYPHS 256
...@@ -449,8 +450,7 @@ static int old_codec37(SANMVideoContext *ctx, int top, ...@@ -449,8 +450,7 @@ static int old_codec37(SANMVideoContext *ctx, int top,
int code; int code;
if (skip_run) { if (skip_run) {
skip_run--; skip_run--;
for (k = 0; k < 4; k++) copy_block4(dst + i, prev + i, stride, stride, 4);
memcpy(dst + i + k * stride, prev + i + k * stride, 4);
continue; continue;
} }
if (bytestream2_get_bytes_left(&ctx->gb) < 1) if (bytestream2_get_bytes_left(&ctx->gb) < 1)
...@@ -501,8 +501,7 @@ static int old_codec37(SANMVideoContext *ctx, int top, ...@@ -501,8 +501,7 @@ static int old_codec37(SANMVideoContext *ctx, int top,
int code; int code;
if (skip_run) { if (skip_run) {
skip_run--; skip_run--;
for (k = 0; k < 4; k++) copy_block4(dst + i, prev + i, stride, stride, 4);
memcpy(dst + i + k * stride, prev + i + k * stride, 4);
continue; continue;
} }
code = bytestream2_get_byte(&ctx->gb); code = bytestream2_get_byte(&ctx->gb);
...@@ -769,10 +768,21 @@ static int decode_nop(SANMVideoContext *ctx) ...@@ -769,10 +768,21 @@ static int decode_nop(SANMVideoContext *ctx)
static void copy_block(uint16_t *pdest, uint16_t *psrc, int block_size, int pitch) static void copy_block(uint16_t *pdest, uint16_t *psrc, int block_size, int pitch)
{ {
int y; uint8_t *dst = (uint8_t *)pdest;
uint8_t *src = (uint8_t *)psrc;
int stride = pitch * 2;
for (y = 0; y < block_size; y++, pdest += pitch, psrc += pitch) switch (block_size) {
memcpy(pdest, psrc, block_size * sizeof(pdest[0])); case 2:
copy_block4(dst, src, stride, stride, 2);
break;
case 4:
copy_block8(dst, src, stride, stride, 4);
break;
case 8:
copy_block16(dst, src, stride, stride, 8);
break;
}
} }
static void fill_block(uint16_t *pdest, uint16_t color, int block_size, int pitch) static void fill_block(uint16_t *pdest, uint16_t color, int block_size, int pitch)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment