Commit 95e62b02 authored by reimar's avatar reimar

Simplify nuv: factor out LZO decompression


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@10440 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 0ae2f6e9
...@@ -114,11 +114,19 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, ...@@ -114,11 +114,19 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size,
// skip rest of the frameheader. // skip rest of the frameheader.
buf = &buf[12]; buf = &buf[12];
buf_size -= 12; buf_size -= 12;
if (comptype == NUV_RTJPEG_IN_LZO || comptype == NUV_LZO) {
int outlen = c->decomp_size, inlen = buf_size;
if (lzo1x_decode(c->decomp_buf, &outlen, buf, &inlen))
av_log(avctx, AV_LOG_ERROR, "error during lzo decompression\n");
buf = c->decomp_buf;
buf_size = c->decomp_size;
}
c->pic.pict_type = FF_I_TYPE; c->pic.pict_type = FF_I_TYPE;
c->pic.key_frame = 1; c->pic.key_frame = 1;
// decompress/copy/whatever data // decompress/copy/whatever data
switch (comptype) { switch (comptype) {
case NUV_LZO:
case NUV_UNCOMPRESSED: { case NUV_UNCOMPRESSED: {
int height = c->height; int height = c->height;
if (buf_size < c->width * height * 3 / 2) { if (buf_size < c->width * height * 3 / 2) {
...@@ -128,24 +136,11 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, ...@@ -128,24 +136,11 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size,
copy_frame(&c->pic, buf, c->width, height); copy_frame(&c->pic, buf, c->width, height);
break; break;
} }
case NUV_RTJPEG_IN_LZO:
case NUV_RTJPEG: { case NUV_RTJPEG: {
rtjpeg_decode_frame_yuv420(&c->rtj, &c->pic, buf, buf_size); rtjpeg_decode_frame_yuv420(&c->rtj, &c->pic, buf, buf_size);
break; break;
} }
case NUV_RTJPEG_IN_LZO: {
int outlen = c->decomp_size, inlen = buf_size;
if (lzo1x_decode(c->decomp_buf, &outlen, buf, &inlen))
av_log(avctx, AV_LOG_ERROR, "error during lzo decompression\n");
rtjpeg_decode_frame_yuv420(&c->rtj, &c->pic, c->decomp_buf, c->decomp_size);
break;
}
case NUV_LZO: {
int outlen = c->decomp_size, inlen = buf_size;
if (lzo1x_decode(c->decomp_buf, &outlen, buf, &inlen))
av_log(avctx, AV_LOG_ERROR, "error during lzo decompression\n");
copy_frame(&c->pic, c->decomp_buf, c->width, c->height);
break;
}
case NUV_BLACK: { case NUV_BLACK: {
memset(c->pic.data[0], 0, c->width * c->height); memset(c->pic.data[0], 0, c->width * c->height);
memset(c->pic.data[1], 128, c->width * c->height / 4); memset(c->pic.data[1], 128, c->width * c->height / 4);
......
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