|  | @@ -61,7 +61,7 @@ static void svq3_luma_dc_dequant_idct_c(DCTELEM *block, int qp); | 
														
													
														
															
																|  |  | static void svq3_add_idct_c(uint8_t *dst, DCTELEM *block, int stride, int qp, int dc); |  |  | static void svq3_add_idct_c(uint8_t *dst, DCTELEM *block, int stride, int qp, int dc); | 
														
													
														
															
																|  |  | static void filter_mb( H264Context *h, int mb_x, int mb_y, uint8_t *img_y, uint8_t *img_cb, uint8_t *img_cr, unsigned int linesize, unsigned int uvlinesize); |  |  | static void filter_mb( H264Context *h, int mb_x, int mb_y, uint8_t *img_y, uint8_t *img_cb, uint8_t *img_cr, unsigned int linesize, unsigned int uvlinesize); | 
														
													
														
															
																|  |  | static void filter_mb_fast( H264Context *h, int mb_x, int mb_y, uint8_t *img_y, uint8_t *img_cb, uint8_t *img_cr, unsigned int linesize, unsigned int uvlinesize); |  |  | static void filter_mb_fast( H264Context *h, int mb_x, int mb_y, uint8_t *img_y, uint8_t *img_cb, uint8_t *img_cr, unsigned int linesize, unsigned int uvlinesize); | 
														
													
														
															
																|  |  | static void remove_long_at_index(H264Context *h, int i); |  |  |  | 
														
													
														
															
																|  |  |  |  |  | static Picture * remove_long(H264Context *h, int i); | 
														
													
														
															
																|  |  | 
 |  |  | 
 | 
														
													
														
															
																|  |  | static av_always_inline uint32_t pack16to32(int a, int b){ |  |  | static av_always_inline uint32_t pack16to32(int a, int b){ | 
														
													
														
															
																|  |  | #ifdef WORDS_BIGENDIAN |  |  | #ifdef WORDS_BIGENDIAN | 
														
													
												
													
														
															
																|  | @@ -3299,7 +3299,7 @@ static void idr(H264Context *h){ | 
														
													
														
															
																|  |  | for(i=0; i<16; i++){ |  |  | for(i=0; i<16; i++){ | 
														
													
														
															
																|  |  | if (h->long_ref[i] != NULL) { |  |  | if (h->long_ref[i] != NULL) { | 
														
													
														
															
																|  |  | unreference_pic(h, h->long_ref[i], 0); |  |  | unreference_pic(h, h->long_ref[i], 0); | 
														
													
														
															
																|  |  | remove_long_at_index(h, i); |  |  |  | 
														
													
														
															
																|  |  |  |  |  | remove_long(h, i); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  | assert(h->long_ref_count==0); |  |  | assert(h->long_ref_count==0); | 
														
													
												
													
														
															
																|  | @@ -3390,27 +3390,19 @@ static Picture * remove_short(H264Context *h, int frame_num){ | 
														
													
														
															
																|  |  | 
 |  |  | 
 | 
														
													
														
															
																|  |  | /** |  |  | /** | 
														
													
														
															
																|  |  | * Remove a picture from the long term reference list by its index in |  |  | * Remove a picture from the long term reference list by its index in | 
														
													
														
															
																|  |  | * that list.  This does no checking on the provided index; it is assumed |  |  |  | 
														
													
														
															
																|  |  | * to be valid. The removed entry is set to NULL. Other entries are unaffected. |  |  |  | 
														
													
														
															
																|  |  | * @param i index into h->long_ref of picture to remove. |  |  |  | 
														
													
														
															
																|  |  | */ |  |  |  | 
														
													
														
															
																|  |  | static void remove_long_at_index(H264Context *h, int i){ |  |  |  | 
														
													
														
															
																|  |  | assert(h->long_ref[i]->long_ref == 1); |  |  |  | 
														
													
														
															
																|  |  | h->long_ref[i]->long_ref= 0; |  |  |  | 
														
													
														
															
																|  |  | h->long_ref[i]= NULL; |  |  |  | 
														
													
														
															
																|  |  | h->long_ref_count--; |  |  |  | 
														
													
														
															
																|  |  | } |  |  |  | 
														
													
														
															
																|  |  | 
 |  |  |  | 
														
													
														
															
																|  |  | /** |  |  |  | 
														
													
														
															
																|  |  | * |  |  |  | 
														
													
														
															
																|  |  |  |  |  | * that list. | 
														
													
														
															
																|  |  | * @return the removed picture or NULL if an error occurs |  |  | * @return the removed picture or NULL if an error occurs | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | static Picture * remove_long(H264Context *h, int i){ |  |  | static Picture * remove_long(H264Context *h, int i){ | 
														
													
														
															
																|  |  | Picture *pic; |  |  | Picture *pic; | 
														
													
														
															
																|  |  | 
 |  |  | 
 | 
														
													
														
															
																|  |  | pic= h->long_ref[i]; |  |  | pic= h->long_ref[i]; | 
														
													
														
															
																|  |  | if (pic) |  |  |  | 
														
													
														
															
																|  |  | remove_long_at_index(h, i); |  |  |  | 
														
													
														
															
																|  |  |  |  |  | if (pic){ | 
														
													
														
															
																|  |  |  |  |  | assert(h->long_ref[i]->long_ref == 1); | 
														
													
														
															
																|  |  |  |  |  | h->long_ref[i]->long_ref= 0; | 
														
													
														
															
																|  |  |  |  |  | h->long_ref[i]= NULL; | 
														
													
														
															
																|  |  |  |  |  | h->long_ref_count--; | 
														
													
														
															
																|  |  |  |  |  | } | 
														
													
														
															
																|  |  | 
 |  |  | 
 | 
														
													
														
															
																|  |  | return pic; |  |  | return pic; | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
												
													
														
															
																|  | @@ -3497,7 +3489,7 @@ static int execute_ref_pic_marking(H264Context *h, MMCO *mmco, int mmco_count){ | 
														
													
														
															
																|  |  | pic = h->long_ref[j]; |  |  | pic = h->long_ref[j]; | 
														
													
														
															
																|  |  | if (pic) { |  |  | if (pic) { | 
														
													
														
															
																|  |  | if (unreference_pic(h, pic, structure ^ PICT_FRAME)) |  |  | if (unreference_pic(h, pic, structure ^ PICT_FRAME)) | 
														
													
														
															
																|  |  | remove_long_at_index(h, j); |  |  |  | 
														
													
														
															
																|  |  |  |  |  | remove_long(h, j); | 
														
													
														
															
																|  |  | } else if(s->avctx->debug&FF_DEBUG_MMCO) |  |  | } else if(s->avctx->debug&FF_DEBUG_MMCO) | 
														
													
														
															
																|  |  | av_log(h->s.avctx, AV_LOG_DEBUG, "mmco: unref long failure\n"); |  |  | av_log(h->s.avctx, AV_LOG_DEBUG, "mmco: unref long failure\n"); | 
														
													
														
															
																|  |  | break; |  |  | break; | 
														
													
												
													
														
															
																|  | @@ -3599,7 +3591,7 @@ static int execute_ref_pic_marking(H264Context *h, MMCO *mmco, int mmco_count){ | 
														
													
														
															
																|  |  | 
 |  |  | 
 | 
														
													
														
															
																|  |  | assert(i < 16); |  |  | assert(i < 16); | 
														
													
														
															
																|  |  | pic = h->long_ref[i]; |  |  | pic = h->long_ref[i]; | 
														
													
														
															
																|  |  | remove_long_at_index(h, i); |  |  |  | 
														
													
														
															
																|  |  |  |  |  | remove_long(h, i); | 
														
													
														
															
																|  |  | } else { |  |  | } else { | 
														
													
														
															
																|  |  | pic = h->short_ref[h->short_ref_count - 1]; |  |  | pic = h->short_ref[h->short_ref_count - 1]; | 
														
													
														
															
																|  |  | remove_short_at_index(h, h->short_ref_count - 1); |  |  | remove_short_at_index(h, h->short_ref_count - 1); | 
														
													
												
													
														
															
																|  | 
 |