Commit 1a14b4ec authored by michael's avatar michael

lowres support


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@4545 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 22c00792
...@@ -228,6 +228,12 @@ static int dvvideo_init(AVCodecContext *avctx) ...@@ -228,6 +228,12 @@ static int dvvideo_init(AVCodecContext *avctx)
/* 248DCT setup */ /* 248DCT setup */
s->fdct[1] = dsp.fdct248; s->fdct[1] = dsp.fdct248;
s->idct_put[1] = simple_idct248_put; // FIXME: need to add it to DSP s->idct_put[1] = simple_idct248_put; // FIXME: need to add it to DSP
if(avctx->lowres){
for (i=0; i<64; i++){
int j= ff_zigzag248_direct[i];
s->dv_zigzag[1][i] = dsp.idct_permutation[(j&7) + (j&8)*4 + (j&48)/2];
}
}else
memcpy(s->dv_zigzag[1], ff_zigzag248_direct, 64); memcpy(s->dv_zigzag[1], ff_zigzag248_direct, 64);
/* XXX: do it only for constant case */ /* XXX: do it only for constant case */
...@@ -377,6 +383,7 @@ static inline void dv_decode_video_segment(DVVideoContext *s, ...@@ -377,6 +383,7 @@ static inline void dv_decode_video_segment(DVVideoContext *s,
DCTELEM sblock[5*6][64] __align8; DCTELEM sblock[5*6][64] __align8;
uint8_t mb_bit_buffer[80 + 4] __align8; /* allow some slack */ uint8_t mb_bit_buffer[80 + 4] __align8; /* allow some slack */
uint8_t vs_bit_buffer[5 * 80 + 4] __align8; /* allow some slack */ uint8_t vs_bit_buffer[5 * 80 + 4] __align8; /* allow some slack */
const int log2_blocksize= 3-s->avctx->lowres;
assert((((int)mb_bit_buffer)&7)==0); assert((((int)mb_bit_buffer)&7)==0);
assert((((int)vs_bit_buffer)&7)==0); assert((((int)vs_bit_buffer)&7)==0);
...@@ -482,39 +489,38 @@ static inline void dv_decode_video_segment(DVVideoContext *s, ...@@ -482,39 +489,38 @@ static inline void dv_decode_video_segment(DVVideoContext *s,
v = *mb_pos_ptr++; v = *mb_pos_ptr++;
mb_x = v & 0xff; mb_x = v & 0xff;
mb_y = v >> 8; mb_y = v >> 8;
y_ptr = s->picture.data[0] + (mb_y * s->picture.linesize[0] * 8) + (mb_x * 8); y_ptr = s->picture.data[0] + ((mb_y * s->picture.linesize[0] + mb_x)<<log2_blocksize);
if (s->sys->pix_fmt == PIX_FMT_YUV411P) if (s->sys->pix_fmt == PIX_FMT_YUV411P)
c_offset = (mb_y * s->picture.linesize[1] * 8) + ((mb_x >> 2) * 8); c_offset = ((mb_y * s->picture.linesize[1] + (mb_x >> 2))<<log2_blocksize);
else else
c_offset = ((mb_y >> 1) * s->picture.linesize[1] * 8) + ((mb_x >> 1) * 8); c_offset = (((mb_y >> 1) * s->picture.linesize[1] + (mb_x >> 1))<<log2_blocksize);
for(j = 0;j < 6; j++) { for(j = 0;j < 6; j++) {
idct_put = s->idct_put[mb->dct_mode]; idct_put = s->idct_put[mb->dct_mode && log2_blocksize==3];
if (j < 4) { if (j < 4) {
if (s->sys->pix_fmt == PIX_FMT_YUV411P && mb_x < (704 / 8)) { if (s->sys->pix_fmt == PIX_FMT_YUV411P && mb_x < (704 / 8)) {
/* NOTE: at end of line, the macroblock is handled as 420 */ /* NOTE: at end of line, the macroblock is handled as 420 */
idct_put(y_ptr + (j * 8), s->picture.linesize[0], block); idct_put(y_ptr + (j<<log2_blocksize), s->picture.linesize[0], block);
} else { } else {
idct_put(y_ptr + ((j & 1) * 8) + ((j >> 1) * 8 * s->picture.linesize[0]), idct_put(y_ptr + (((j & 1) + (j >> 1) * s->picture.linesize[0])<<log2_blocksize),
s->picture.linesize[0], block); s->picture.linesize[0], block);
} }
} else { } else {
if (s->sys->pix_fmt == PIX_FMT_YUV411P && mb_x >= (704 / 8)) { if (s->sys->pix_fmt == PIX_FMT_YUV411P && mb_x >= (704 / 8)) {
uint64_t aligned_pixels[64/8]; uint64_t aligned_pixels[64/8];
uint8_t *pixels= (uint8_t*)aligned_pixels; uint8_t *pixels= (uint8_t*)aligned_pixels;
uint8_t *c_ptr, *c_ptr1, *ptr; uint8_t *c_ptr, *c_ptr1, *ptr, *ptr1;
int y, linesize; int x, y, linesize;
/* NOTE: at end of line, the macroblock is handled as 420 */ /* NOTE: at end of line, the macroblock is handled as 420 */
idct_put(pixels, 8, block); idct_put(pixels, 8, block);
linesize = s->picture.linesize[6 - j]; linesize = s->picture.linesize[6 - j];
c_ptr = s->picture.data[6 - j] + c_offset; c_ptr = s->picture.data[6 - j] + c_offset;
ptr = pixels; ptr = pixels;
for(y = 0;y < 8; y++) { for(y = 0;y < (1<<log2_blocksize); y++) {
/* convert to 411P */ ptr1= ptr + (1<<(log2_blocksize-1));
c_ptr1 = c_ptr + 8*linesize; c_ptr1 = c_ptr + (linesize<<log2_blocksize);
c_ptr[0]= ptr[0]; c_ptr1[0]= ptr[4]; for(x=0; x < (1<<(log2_blocksize-1)); x++){
c_ptr[1]= ptr[1]; c_ptr1[1]= ptr[5]; c_ptr[x]= ptr[x]; c_ptr1[x]= ptr1[x];
c_ptr[2]= ptr[2]; c_ptr1[2]= ptr[6]; }
c_ptr[3]= ptr[3]; c_ptr1[3]= ptr[7];
c_ptr += linesize; c_ptr += linesize;
ptr += 8; ptr += 8;
} }
...@@ -924,8 +930,7 @@ static int dvvideo_decode_frame(AVCodecContext *avctx, ...@@ -924,8 +930,7 @@ static int dvvideo_decode_frame(AVCodecContext *avctx,
s->picture.key_frame = 1; s->picture.key_frame = 1;
s->picture.pict_type = FF_I_TYPE; s->picture.pict_type = FF_I_TYPE;
avctx->pix_fmt = s->sys->pix_fmt; avctx->pix_fmt = s->sys->pix_fmt;
avctx->width = s->sys->width; avcodec_set_dimensions(avctx, s->sys->width, s->sys->height);
avctx->height = s->sys->height;
if(avctx->get_buffer(avctx, &s->picture) < 0) { if(avctx->get_buffer(avctx, &s->picture) < 0) {
av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n"); av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n");
return -1; return -1;
......
...@@ -593,8 +593,10 @@ static int dv_extract_video_info(DVDemuxContext *c, uint8_t* frame) ...@@ -593,8 +593,10 @@ static int dv_extract_video_info(DVDemuxContext *c, uint8_t* frame)
av_set_pts_info(c->vst, 64, sys->frame_rate_base, sys->frame_rate); av_set_pts_info(c->vst, 64, sys->frame_rate_base, sys->frame_rate);
avctx->time_base= (AVRational){sys->frame_rate_base, sys->frame_rate}; avctx->time_base= (AVRational){sys->frame_rate_base, sys->frame_rate};
if(!avctx->width){
avctx->width = sys->width; avctx->width = sys->width;
avctx->height = sys->height; avctx->height = sys->height;
}
avctx->pix_fmt = sys->pix_fmt; avctx->pix_fmt = sys->pix_fmt;
/* finding out SAR is a little bit messy */ /* finding out SAR is a little bit messy */
......
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