Skip to content
Snippets Groups Projects
Commit 8badb23e authored by Kostya Shishkov's avatar Kostya Shishkov
Browse files

Recognize 16-bit Interplay Video variant

Originally committed as revision 20927 to svn://svn.ffmpeg.org/ffmpeg/trunk
parent 9156a5ad
No related branches found
No related tags found
No related merge requests found
...@@ -67,6 +67,7 @@ typedef struct IpvideoContext { ...@@ -67,6 +67,7 @@ typedef struct IpvideoContext {
const unsigned char *buf; const unsigned char *buf;
int size; int size;
int is_16bpp;
const unsigned char *stream_ptr; const unsigned char *stream_ptr;
const unsigned char *stream_end; const unsigned char *stream_end;
unsigned char *pixel_ptr; unsigned char *pixel_ptr;
...@@ -620,7 +621,12 @@ static av_cold int ipvideo_decode_init(AVCodecContext *avctx) ...@@ -620,7 +621,12 @@ static av_cold int ipvideo_decode_init(AVCodecContext *avctx)
return -1; return -1;
} }
avctx->pix_fmt = PIX_FMT_PAL8; s->is_16bpp = avctx->bits_per_coded_sample == 16;
avctx->pix_fmt = s->is_16bpp ? PIX_FMT_RGB555 : PIX_FMT_PAL8;
if (s->is_16bpp) {
av_log(avctx, AV_LOG_ERROR, "16-bit Interplay video is not supported yet.\n");
return -1;
}
dsputil_init(&s->dsp, avctx); dsputil_init(&s->dsp, avctx);
/* decoding map contains 4 bits of information per 8x8 block */ /* decoding map contains 4 bits of information per 8x8 block */
......
...@@ -93,6 +93,7 @@ typedef struct IPMVEContext { ...@@ -93,6 +93,7 @@ typedef struct IPMVEContext {
uint64_t frame_pts_inc; uint64_t frame_pts_inc;
unsigned int video_bpp;
unsigned int video_width; unsigned int video_width;
unsigned int video_height; unsigned int video_height;
int64_t video_pts; int64_t video_pts;
...@@ -375,6 +376,11 @@ static int process_ipmovie_chunk(IPMVEContext *s, ByteIOContext *pb, ...@@ -375,6 +376,11 @@ static int process_ipmovie_chunk(IPMVEContext *s, ByteIOContext *pb,
} }
s->video_width = AV_RL16(&scratch[0]) * 8; s->video_width = AV_RL16(&scratch[0]) * 8;
s->video_height = AV_RL16(&scratch[2]) * 8; s->video_height = AV_RL16(&scratch[2]) * 8;
if (opcode_version < 2 || !AV_RL16(&scratch[6])) {
s->video_bpp = 8;
} else {
s->video_bpp = 16;
}
debug_ipmovie("video resolution: %d x %d\n", debug_ipmovie("video resolution: %d x %d\n",
s->video_width, s->video_height); s->video_width, s->video_height);
break; break;
...@@ -565,6 +571,7 @@ static int ipmovie_read_header(AVFormatContext *s, ...@@ -565,6 +571,7 @@ static int ipmovie_read_header(AVFormatContext *s,
st->codec->codec_tag = 0; /* no fourcc */ st->codec->codec_tag = 0; /* no fourcc */
st->codec->width = ipmovie->video_width; st->codec->width = ipmovie->video_width;
st->codec->height = ipmovie->video_height; st->codec->height = ipmovie->video_height;
st->codec->bits_per_coded_sample = ipmovie->video_bpp;
/* palette considerations */ /* palette considerations */
st->codec->palctrl = &ipmovie->palette_control; st->codec->palctrl = &ipmovie->palette_control;
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment