Commit 9f49d95c authored by michael's avatar michael

Factorize check of read symbols.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@18390 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 604aa0c3
...@@ -3553,6 +3553,14 @@ static void decode_qlogs(SnowContext *s){ ...@@ -3553,6 +3553,14 @@ static void decode_qlogs(SnowContext *s){
} }
} }
#define GET_S(dst, check) \
tmp= get_symbol(&s->c, s->header_state, 0);\
if(!(check)){\
av_log(s->avctx, AV_LOG_ERROR, "Error " #dst " is %d\n", tmp);\
return -1;\
}\
dst= tmp;
static int decode_header(SnowContext *s){ static int decode_header(SnowContext *s){
int plane_index, tmp; int plane_index, tmp;
uint8_t kstate[32]; uint8_t kstate[32];
...@@ -3570,10 +3578,7 @@ static int decode_header(SnowContext *s){ ...@@ -3570,10 +3578,7 @@ static int decode_header(SnowContext *s){
} }
if(s->keyframe){ if(s->keyframe){
s->version= get_symbol(&s->c, s->header_state, 0); s->version= get_symbol(&s->c, s->header_state, 0);
if(s->version>0){ GET_S(s->version, tmp <= 0U)
av_log(s->avctx, AV_LOG_ERROR, "version %d not supported", s->version);
return -1;
}
s->always_reset= get_rac(&s->c, s->header_state); s->always_reset= get_rac(&s->c, s->header_state);
s->temporal_decomposition_type= get_symbol(&s->c, s->header_state, 0); s->temporal_decomposition_type= get_symbol(&s->c, s->header_state, 0);
s->temporal_decomposition_count= get_symbol(&s->c, s->header_state, 0); s->temporal_decomposition_count= get_symbol(&s->c, s->header_state, 0);
...@@ -3583,12 +3588,8 @@ static int decode_header(SnowContext *s){ ...@@ -3583,12 +3588,8 @@ static int decode_header(SnowContext *s){
s->chroma_v_shift= get_symbol(&s->c, s->header_state, 0); s->chroma_v_shift= get_symbol(&s->c, s->header_state, 0);
s->spatial_scalability= get_rac(&s->c, s->header_state); s->spatial_scalability= get_rac(&s->c, s->header_state);
// s->rate_scalability= get_rac(&s->c, s->header_state); // s->rate_scalability= get_rac(&s->c, s->header_state);
tmp= get_symbol(&s->c, s->header_state, 0)+1; GET_S(s->max_ref_frames, tmp < (unsigned)MAX_REF_FRAMES)
if(tmp < 1 || tmp > MAX_REF_FRAMES){ s->max_ref_frames++;
av_log(s->avctx, AV_LOG_ERROR, "reference frame count is %d\n", tmp);
return -1;
}
s->max_ref_frames= tmp;
decode_qlogs(s); decode_qlogs(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