Commit 52c01356 authored by reimar's avatar reimar

Merge the 3 COPY_FROM_* macros with lots of duplicated code into a single

copy_from function.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@18225 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 139cec79
...@@ -82,85 +82,36 @@ typedef struct IpvideoContext { ...@@ -82,85 +82,36 @@ typedef struct IpvideoContext {
return -1; \ return -1; \
} }
#define COPY_FROM_CURRENT() \ static int copy_from(IpvideoContext *s, AVFrame *src, int delta_x, int delta_y)
motion_offset = current_offset; \
motion_offset += y * s->stride; \
motion_offset += x; \
if (motion_offset < 0) { \
av_log(s->avctx, AV_LOG_ERROR, " Interplay video: motion offset < 0 (%d)\n", motion_offset); \
return -1; \
} else if (motion_offset > s->upper_motion_limit_offset) { \
av_log(s->avctx, AV_LOG_ERROR, " Interplay video: motion offset above limit (%d >= %d)\n", \
motion_offset, s->upper_motion_limit_offset); \
return -1; \
} \
s->dsp.put_pixels_tab[1][0](s->pixel_ptr, \
s->current_frame.data[0] + motion_offset, s->stride, 8);
#define COPY_FROM_PREVIOUS() \
motion_offset = current_offset; \
motion_offset += y * s->stride; \
motion_offset += x; \
if (motion_offset < 0) { \
av_log(s->avctx, AV_LOG_ERROR, " Interplay video: motion offset < 0 (%d)\n", motion_offset); \
return -1; \
} else if (motion_offset > s->upper_motion_limit_offset) { \
av_log(s->avctx, AV_LOG_ERROR, " Interplay video: motion offset above limit (%d >= %d)\n", \
motion_offset, s->upper_motion_limit_offset); \
return -1; \
} \
s->dsp.put_pixels_tab[1][0](s->pixel_ptr, \
s->last_frame.data[0] + motion_offset, s->stride, 8);
#define COPY_FROM_SECOND_LAST() \
motion_offset = current_offset; \
motion_offset += y * s->stride; \
motion_offset += x; \
if (motion_offset < 0) { \
av_log(s->avctx, AV_LOG_ERROR, " Interplay video: motion offset < 0 (%d)\n", motion_offset); \
return -1; \
} else if (motion_offset > s->upper_motion_limit_offset) { \
av_log(s->avctx, AV_LOG_ERROR, " Interplay video: motion offset above limit (%d >= %d)\n", \
motion_offset, s->upper_motion_limit_offset); \
return -1; \
} \
s->dsp.put_pixels_tab[1][0](s->pixel_ptr, \
s->second_last_frame.data[0] + motion_offset, s->stride, 8);
static int ipvideo_decode_block_opcode_0x0(IpvideoContext *s)
{ {
int x, y;
int motion_offset;
int current_offset = s->pixel_ptr - s->current_frame.data[0]; int current_offset = s->pixel_ptr - s->current_frame.data[0];
int motion_offset = current_offset + delta_y * s->stride + delta_x;
/* copy a block from the previous frame */ if (motion_offset < 0) {
x = y = 0; av_log(s->avctx, AV_LOG_ERROR, " Interplay video: motion offset < 0 (%d)\n", motion_offset);
COPY_FROM_PREVIOUS(); return -1;
} else if (motion_offset > s->upper_motion_limit_offset) {
/* report success */ av_log(s->avctx, AV_LOG_ERROR, " Interplay video: motion offset above limit (%d >= %d)\n",
motion_offset, s->upper_motion_limit_offset);
return -1;
}
s->dsp.put_pixels_tab[1][0](s->pixel_ptr, src->data[0] + motion_offset, s->stride, 8);
return 0; return 0;
} }
static int ipvideo_decode_block_opcode_0x1(IpvideoContext *s) static int ipvideo_decode_block_opcode_0x0(IpvideoContext *s)
{ {
int x, y; return copy_from(s, &s->last_frame, 0, 0);
int motion_offset; }
int current_offset = s->pixel_ptr - s->current_frame.data[0];
/* copy block from 2 frames ago */
x = y = 0;
COPY_FROM_SECOND_LAST();
/* report success */ static int ipvideo_decode_block_opcode_0x1(IpvideoContext *s)
return 0; {
return copy_from(s, &s->second_last_frame, 0, 0);
} }
static int ipvideo_decode_block_opcode_0x2(IpvideoContext *s) static int ipvideo_decode_block_opcode_0x2(IpvideoContext *s)
{ {
unsigned char B; unsigned char B;
int x, y; int x, y;
int motion_offset;
int current_offset = s->pixel_ptr - s->current_frame.data[0];
/* copy block from 2 frames ago using a motion vector; need 1 more byte */ /* copy block from 2 frames ago using a motion vector; need 1 more byte */
CHECK_STREAM_PTR(1); CHECK_STREAM_PTR(1);
...@@ -175,18 +126,13 @@ static int ipvideo_decode_block_opcode_0x2(IpvideoContext *s) ...@@ -175,18 +126,13 @@ static int ipvideo_decode_block_opcode_0x2(IpvideoContext *s)
} }
debug_interplay (" motion byte = %d, (x, y) = (%d, %d)\n", B, x, y); debug_interplay (" motion byte = %d, (x, y) = (%d, %d)\n", B, x, y);
COPY_FROM_SECOND_LAST(); return copy_from(s, &s->second_last_frame, x, y);
/* report success */
return 0;
} }
static int ipvideo_decode_block_opcode_0x3(IpvideoContext *s) static int ipvideo_decode_block_opcode_0x3(IpvideoContext *s)
{ {
unsigned char B; unsigned char B;
int x, y; int x, y;
int motion_offset;
int current_offset = s->pixel_ptr - s->current_frame.data[0];
/* copy 8x8 block from current frame from an up/left block */ /* copy 8x8 block from current frame from an up/left block */
...@@ -203,18 +149,13 @@ static int ipvideo_decode_block_opcode_0x3(IpvideoContext *s) ...@@ -203,18 +149,13 @@ static int ipvideo_decode_block_opcode_0x3(IpvideoContext *s)
} }
debug_interplay (" motion byte = %d, (x, y) = (%d, %d)\n", B, x, y); debug_interplay (" motion byte = %d, (x, y) = (%d, %d)\n", B, x, y);
COPY_FROM_CURRENT(); return copy_from(s, &s->current_frame, x, y);
/* report success */
return 0;
} }
static int ipvideo_decode_block_opcode_0x4(IpvideoContext *s) static int ipvideo_decode_block_opcode_0x4(IpvideoContext *s)
{ {
int x, y; int x, y;
unsigned char B, BL, BH; unsigned char B, BL, BH;
int motion_offset;
int current_offset = s->pixel_ptr - s->current_frame.data[0];
/* copy a block from the previous frame; need 1 more byte */ /* copy a block from the previous frame; need 1 more byte */
CHECK_STREAM_PTR(1); CHECK_STREAM_PTR(1);
...@@ -226,17 +167,12 @@ static int ipvideo_decode_block_opcode_0x4(IpvideoContext *s) ...@@ -226,17 +167,12 @@ static int ipvideo_decode_block_opcode_0x4(IpvideoContext *s)
y = -8 + BH; y = -8 + BH;
debug_interplay (" motion byte = %d, (x, y) = (%d, %d)\n", B, x, y); debug_interplay (" motion byte = %d, (x, y) = (%d, %d)\n", B, x, y);
COPY_FROM_PREVIOUS(); return copy_from(s, &s->last_frame, x, y);
/* report success */
return 0;
} }
static int ipvideo_decode_block_opcode_0x5(IpvideoContext *s) static int ipvideo_decode_block_opcode_0x5(IpvideoContext *s)
{ {
signed char x, y; signed char x, y;
int motion_offset;
int current_offset = s->pixel_ptr - s->current_frame.data[0];
/* copy a block from the previous frame using an expanded range; /* copy a block from the previous frame using an expanded range;
* need 2 more bytes */ * need 2 more bytes */
...@@ -246,10 +182,7 @@ static int ipvideo_decode_block_opcode_0x5(IpvideoContext *s) ...@@ -246,10 +182,7 @@ static int ipvideo_decode_block_opcode_0x5(IpvideoContext *s)
y = *s->stream_ptr++; y = *s->stream_ptr++;
debug_interplay (" motion bytes = %d, %d\n", x, y); debug_interplay (" motion bytes = %d, %d\n", x, y);
COPY_FROM_PREVIOUS(); return copy_from(s, &s->last_frame, x, y);
/* report success */
return 0;
} }
static int ipvideo_decode_block_opcode_0x6(IpvideoContext *s) static int ipvideo_decode_block_opcode_0x6(IpvideoContext *s)
......
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