Commit c86d068a authored by michael's avatar michael

h264 deblocking crash patch by (Loren Merritt <lorenm at u dot washington dot edu>)


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@3427 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 13be75c1
...@@ -2321,6 +2321,8 @@ static inline void xchg_mb_border(H264Context *h, uint8_t *src_y, uint8_t *src_c ...@@ -2321,6 +2321,8 @@ static inline void xchg_mb_border(H264Context *h, uint8_t *src_y, uint8_t *src_c
MpegEncContext * const s = &h->s; MpegEncContext * const s = &h->s;
int temp8, i; int temp8, i;
uint64_t temp64; uint64_t temp64;
int deblock_left = (s->mb_x > 0);
int deblock_top = (s->mb_y > 0);
src_y -= linesize + 1; src_y -= linesize + 1;
src_cb -= uvlinesize + 1; src_cb -= uvlinesize + 1;
...@@ -2331,21 +2333,29 @@ t= a;\ ...@@ -2331,21 +2333,29 @@ t= a;\
if(xchg)\ if(xchg)\
a= b;\ a= b;\
b= t; b= t;
for(i=0; i<17; i++){ if(deblock_left){
XCHG(h->left_border[i ], src_y [i* linesize], temp8, xchg); for(i = !deblock_top; i<17; i++){
XCHG(h->left_border[i ], src_y [i* linesize], temp8, xchg);
}
}
if(deblock_top){
XCHG(*(uint64_t*)(h->top_border[s->mb_x]+0), *(uint64_t*)(src_y +1), temp64, xchg);
XCHG(*(uint64_t*)(h->top_border[s->mb_x]+8), *(uint64_t*)(src_y +9), temp64, 1);
} }
XCHG(*(uint64_t*)(h->top_border[s->mb_x]+0), *(uint64_t*)(src_y +1), temp64, xchg);
XCHG(*(uint64_t*)(h->top_border[s->mb_x]+8), *(uint64_t*)(src_y +9), temp64, 1);
if(!(s->flags&CODEC_FLAG_GRAY)){ if(!(s->flags&CODEC_FLAG_GRAY)){
for(i=0; i<9; i++){ if(deblock_left){
XCHG(h->left_border[i+17 ], src_cb[i*uvlinesize], temp8, xchg); for(i = !deblock_top; i<9; i++){
XCHG(h->left_border[i+17+9], src_cr[i*uvlinesize], temp8, xchg); XCHG(h->left_border[i+17 ], src_cb[i*uvlinesize], temp8, xchg);
XCHG(h->left_border[i+17+9], src_cr[i*uvlinesize], temp8, xchg);
}
}
if(deblock_top){
XCHG(*(uint64_t*)(h->top_border[s->mb_x]+16), *(uint64_t*)(src_cb+1), temp64, 1);
XCHG(*(uint64_t*)(h->top_border[s->mb_x]+24), *(uint64_t*)(src_cr+1), temp64, 1);
} }
XCHG(*(uint64_t*)(h->top_border[s->mb_x]+16), *(uint64_t*)(src_cb+1), temp64, 1);
XCHG(*(uint64_t*)(h->top_border[s->mb_x]+24), *(uint64_t*)(src_cr+1), temp64, 1);
} }
} }
......
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