mirror of
				https://github.com/nyanmisaka/ffmpeg-rockchip.git
				synced 2025-10-25 01:41:31 +08:00 
			
		
		
		
	ffmpeg: Fix initial dts for streamcopy, if the input packets lack dts.
Fixes Ticket1138 Based on a patch by: Eelco Lempsink <eml@tupil.com> Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
		
							
								
								
									
										11
									
								
								ffmpeg.c
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								ffmpeg.c
									
									
									
									
									
								
							| @@ -235,6 +235,7 @@ typedef struct InputStream { | |||||||
|     int64_t       pts;       ///< current pts of the decoded frame |     int64_t       pts;       ///< current pts of the decoded frame | ||||||
|     double ts_scale; |     double ts_scale; | ||||||
|     int is_start;            /* is 1 at the start and after a discontinuity */ |     int is_start;            /* is 1 at the start and after a discontinuity */ | ||||||
|  |     int saw_first_ts; | ||||||
|     int showed_multi_packet_warning; |     int showed_multi_packet_warning; | ||||||
|     AVDictionary *opts; |     AVDictionary *opts; | ||||||
|  |  | ||||||
| @@ -2691,6 +2692,15 @@ static int output_packet(InputStream *ist, const AVPacket *pkt) | |||||||
|     int64_t pkt_pts = AV_NOPTS_VALUE; |     int64_t pkt_pts = AV_NOPTS_VALUE; | ||||||
|  |  | ||||||
|     AVPacket avpkt; |     AVPacket avpkt; | ||||||
|  |     if (!ist->saw_first_ts) { | ||||||
|  |         ist->dts = ist->st->avg_frame_rate.num ? - ist->st->codec->has_b_frames * AV_TIME_BASE / av_q2d(ist->st->avg_frame_rate) : 0; | ||||||
|  |         ist->pts = 0; | ||||||
|  |         if (pkt != NULL && pkt->pts != AV_NOPTS_VALUE && !ist->decoding_needed) { | ||||||
|  |             ist->dts += av_rescale_q(pkt->pts, ist->st->time_base, AV_TIME_BASE_Q); | ||||||
|  |             ist->pts = ist->dts; //unused but better to set it to a value thats not totally wrong | ||||||
|  |         } | ||||||
|  |         ist->saw_first_ts = 1; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     if (ist->next_dts == AV_NOPTS_VALUE) |     if (ist->next_dts == AV_NOPTS_VALUE) | ||||||
|         ist->next_dts = ist->dts; |         ist->next_dts = ist->dts; | ||||||
| @@ -2872,7 +2882,6 @@ static int init_input_stream(int ist_index, char *error, int error_len) | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     ist->dts = ist->st->avg_frame_rate.num ? - ist->st->codec->has_b_frames * AV_TIME_BASE / av_q2d(ist->st->avg_frame_rate) : 0; |  | ||||||
|     ist->next_pts = AV_NOPTS_VALUE; |     ist->next_pts = AV_NOPTS_VALUE; | ||||||
|     ist->next_dts = AV_NOPTS_VALUE; |     ist->next_dts = AV_NOPTS_VALUE; | ||||||
|     ist->is_start = 1; |     ist->is_start = 1; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Michael Niedermayer
					Michael Niedermayer