Commit cfd0c557 authored by tmmm's avatar tmmm

correct the custom coding mode alphabet, add some validation on the

motion vectors (which are not completely correct yet)


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@1844 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 8614a0f0
...@@ -1287,7 +1287,7 @@ static void unpack_modes(Vp3DecodeContext *s, GetBitContext *gb) ...@@ -1287,7 +1287,7 @@ static void unpack_modes(Vp3DecodeContext *s, GetBitContext *gb)
if (scheme == 0) { if (scheme == 0) {
debug_modes(" custom mode alphabet ahead:\n"); debug_modes(" custom mode alphabet ahead:\n");
for (i = 0; i < 8; i++) for (i = 0; i < 8; i++)
ModeAlphabet[0][i] = get_bits(gb, 3); ModeAlphabet[scheme][get_bits(gb, 3)] = i;
} }
for (i = 0; i < 8; i++) for (i = 0; i < 8; i++)
...@@ -1662,11 +1662,11 @@ static void unpack_dct_coeffs(Vp3DecodeContext *s, GetBitContext *gb) ...@@ -1662,11 +1662,11 @@ static void unpack_dct_coeffs(Vp3DecodeContext *s, GetBitContext *gb)
residual_eob_run = unpack_vlcs(s, gb, &s->dc_vlc[dc_c_table], 0, residual_eob_run = unpack_vlcs(s, gb, &s->dc_vlc[dc_c_table], 0,
plane_split, s->coded_fragment_list_index, residual_eob_run); plane_split, s->coded_fragment_list_index, residual_eob_run);
/* fetch the level 1 AC table indices */ /* fetch the AC table indices */
ac_y_table = get_bits(gb, 4); ac_y_table = get_bits(gb, 4);
ac_c_table = get_bits(gb, 4); ac_c_table = get_bits(gb, 4);
/* unpack the level 1 AC coefficients (coeffs 1-5) */ /* unpack the group 1 AC coefficients (coeffs 1-5) */
for (i = 1; i <= 5; i++) { for (i = 1; i <= 5; i++) {
debug_vp3(" vp3: unpacking level %d Y plane AC coefficients using table %d\n", debug_vp3(" vp3: unpacking level %d Y plane AC coefficients using table %d\n",
...@@ -1680,7 +1680,7 @@ static void unpack_dct_coeffs(Vp3DecodeContext *s, GetBitContext *gb) ...@@ -1680,7 +1680,7 @@ static void unpack_dct_coeffs(Vp3DecodeContext *s, GetBitContext *gb)
plane_split, s->coded_fragment_list_index, residual_eob_run); plane_split, s->coded_fragment_list_index, residual_eob_run);
} }
/* unpack the level 2 AC coefficients (coeffs 6-14) */ /* unpack the group 2 AC coefficients (coeffs 6-14) */
for (i = 6; i <= 14; i++) { for (i = 6; i <= 14; i++) {
debug_vp3(" vp3: unpacking level %d Y plane AC coefficients using table %d\n", debug_vp3(" vp3: unpacking level %d Y plane AC coefficients using table %d\n",
...@@ -1694,7 +1694,7 @@ static void unpack_dct_coeffs(Vp3DecodeContext *s, GetBitContext *gb) ...@@ -1694,7 +1694,7 @@ static void unpack_dct_coeffs(Vp3DecodeContext *s, GetBitContext *gb)
plane_split, s->coded_fragment_list_index, residual_eob_run); plane_split, s->coded_fragment_list_index, residual_eob_run);
} }
/* unpack the level 3 AC coefficients (coeffs 15-27) */ /* unpack the group 3 AC coefficients (coeffs 15-27) */
for (i = 15; i <= 27; i++) { for (i = 15; i <= 27; i++) {
debug_vp3(" vp3: unpacking level %d Y plane AC coefficients using table %d\n", debug_vp3(" vp3: unpacking level %d Y plane AC coefficients using table %d\n",
...@@ -1708,7 +1708,7 @@ static void unpack_dct_coeffs(Vp3DecodeContext *s, GetBitContext *gb) ...@@ -1708,7 +1708,7 @@ static void unpack_dct_coeffs(Vp3DecodeContext *s, GetBitContext *gb)
plane_split, s->coded_fragment_list_index, residual_eob_run); plane_split, s->coded_fragment_list_index, residual_eob_run);
} }
/* unpack the level 4 AC coefficients (coeffs 28-63) */ /* unpack the group 4 AC coefficients (coeffs 28-63) */
for (i = 28; i <= 63; i++) { for (i = 28; i <= 63; i++) {
debug_vp3(" vp3: unpacking level %d Y plane AC coefficients using table %d\n", debug_vp3(" vp3: unpacking level %d Y plane AC coefficients using table %d\n",
...@@ -1731,7 +1731,6 @@ static void unpack_dct_coeffs(Vp3DecodeContext *s, GetBitContext *gb) ...@@ -1731,7 +1731,6 @@ static void unpack_dct_coeffs(Vp3DecodeContext *s, GetBitContext *gb)
#define COMPATIBLE_FRAME(x) \ #define COMPATIBLE_FRAME(x) \
(compatible_frame[s->all_fragments[x].coding_method] == current_frame_type) (compatible_frame[s->all_fragments[x].coding_method] == current_frame_type)
#define FRAME_CODED(x) (s->all_fragments[x].coding_method != MODE_COPY) #define FRAME_CODED(x) (s->all_fragments[x].coding_method != MODE_COPY)
#define HIGHBITDUPPED(X) (((signed short) X) >> 15)
static inline int iabs (int x) { return ((x < 0) ? -x : x); } static inline int iabs (int x) { return ((x < 0) ? -x : x); }
static void reverse_dc_prediction(Vp3DecodeContext *s, static void reverse_dc_prediction(Vp3DecodeContext *s,
...@@ -2020,7 +2019,7 @@ static void render_fragments(Vp3DecodeContext *s, ...@@ -2020,7 +2019,7 @@ static void render_fragments(Vp3DecodeContext *s,
unsigned char *golden_plane; unsigned char *golden_plane;
int stride; int stride;
int motion_x, motion_y; int motion_x, motion_y;
int motion_x_limit, motion_y_limit; int upper_motion_limit, lower_motion_limit;
int motion_halfpel_index; int motion_halfpel_index;
unsigned int motion_source; unsigned int motion_source;
...@@ -2034,23 +2033,26 @@ static void render_fragments(Vp3DecodeContext *s, ...@@ -2034,23 +2033,26 @@ static void render_fragments(Vp3DecodeContext *s,
last_plane = s->last_frame.data[0]; last_plane = s->last_frame.data[0];
golden_plane = s->golden_frame.data[0]; golden_plane = s->golden_frame.data[0];
stride = -s->current_frame.linesize[0]; stride = -s->current_frame.linesize[0];
upper_motion_limit = 7 * s->current_frame.linesize[0];
lower_motion_limit = height * s->current_frame.linesize[0] + width - 8;
} else if (plane == 1) { } else if (plane == 1) {
dequantizer = s->intra_c_dequant; dequantizer = s->intra_c_dequant;
output_plane = s->current_frame.data[1]; output_plane = s->current_frame.data[1];
last_plane = s->last_frame.data[1]; last_plane = s->last_frame.data[1];
golden_plane = s->golden_frame.data[1]; golden_plane = s->golden_frame.data[1];
stride = -s->current_frame.linesize[1]; stride = -s->current_frame.linesize[1];
upper_motion_limit = 7 * s->current_frame.linesize[1];
lower_motion_limit = height * s->current_frame.linesize[1] + width - 8;
} else { } else {
dequantizer = s->intra_c_dequant; dequantizer = s->intra_c_dequant;
output_plane = s->current_frame.data[2]; output_plane = s->current_frame.data[2];
last_plane = s->last_frame.data[2]; last_plane = s->last_frame.data[2];
golden_plane = s->golden_frame.data[2]; golden_plane = s->golden_frame.data[2];
stride = -s->current_frame.linesize[2]; stride = -s->current_frame.linesize[2];
upper_motion_limit = 7 * s->current_frame.linesize[2];
lower_motion_limit = height * s->current_frame.linesize[2] + width - 8;
} }
motion_x_limit = width - 8;
motion_y_limit = height - 8;
/* for each fragment row... */ /* for each fragment row... */
for (y = 0; y < height; y += 8) { for (y = 0; y < height; y += 8) {
...@@ -2064,21 +2066,19 @@ static void render_fragments(Vp3DecodeContext *s, ...@@ -2064,21 +2066,19 @@ static void render_fragments(Vp3DecodeContext *s,
motion_x = s->all_fragments[i].motion_x; motion_x = s->all_fragments[i].motion_x;
motion_y = s->all_fragments[i].motion_y; motion_y = s->all_fragments[i].motion_y;
motion_halfpel_index = s->all_fragments[i].motion_halfpel_index; motion_halfpel_index = s->all_fragments[i].motion_halfpel_index;
/*
if (motion_x < 0)
motion_x = 0;
if (motion_y < 0)
motion_y = 0;
if (motion_x > motion_x_limit)
motion_x = motion_x_limit;
if (motion_y > motion_y_limit)
motion_y = motion_y_limit;
*/
motion_source = s->all_fragments[i].first_pixel; motion_source = s->all_fragments[i].first_pixel;
motion_source += motion_x; motion_source += motion_x;
motion_source += (motion_y * stride); motion_source += (motion_y * stride);
/* if the are any problems with a motion vector, refuse
* to render the block */
if ((motion_source < upper_motion_limit) ||
(motion_source > lower_motion_limit)) {
// printf (" vp3: help! motion source (%d) out of range (%d..%d)\n",
// motion_source, upper_motion_limit, lower_motion_limit);
}
/* first, take care of copying a block from either the /* first, take care of copying a block from either the
* previous or the golden frame */ * previous or the golden frame */
if ((s->all_fragments[i].coding_method == MODE_USING_GOLDEN) || if ((s->all_fragments[i].coding_method == MODE_USING_GOLDEN) ||
...@@ -2270,22 +2270,22 @@ static int vp3_decode_init(AVCodecContext *avctx) ...@@ -2270,22 +2270,22 @@ static int vp3_decode_init(AVCodecContext *avctx)
&dc_bias[i][0][1], 4, 2, &dc_bias[i][0][1], 4, 2,
&dc_bias[i][0][0], 4, 2); &dc_bias[i][0][0], 4, 2);
/* level 1 AC histograms */ /* group 1 AC histograms */
init_vlc(&s->ac_vlc_1[i], 5, 32, init_vlc(&s->ac_vlc_1[i], 5, 32,
&ac_bias_0[i][0][1], 4, 2, &ac_bias_0[i][0][1], 4, 2,
&ac_bias_0[i][0][0], 4, 2); &ac_bias_0[i][0][0], 4, 2);
/* level 2 AC histograms */ /* group 2 AC histograms */
init_vlc(&s->ac_vlc_2[i], 5, 32, init_vlc(&s->ac_vlc_2[i], 5, 32,
&ac_bias_1[i][0][1], 4, 2, &ac_bias_1[i][0][1], 4, 2,
&ac_bias_1[i][0][0], 4, 2); &ac_bias_1[i][0][0], 4, 2);
/* level 3 AC histograms */ /* group 3 AC histograms */
init_vlc(&s->ac_vlc_3[i], 5, 32, init_vlc(&s->ac_vlc_3[i], 5, 32,
&ac_bias_2[i][0][1], 4, 2, &ac_bias_2[i][0][1], 4, 2,
&ac_bias_2[i][0][0], 4, 2); &ac_bias_2[i][0][0], 4, 2);
/* level 4 AC histograms */ /* group 4 AC histograms */
init_vlc(&s->ac_vlc_4[i], 5, 32, init_vlc(&s->ac_vlc_4[i], 5, 32,
&ac_bias_3[i][0][1], 4, 2, &ac_bias_3[i][0][1], 4, 2,
&ac_bias_3[i][0][0], 4, 2); &ac_bias_3[i][0][0], 4, 2);
......
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