These functions are using the POSIX clock_gettime() function with the CLOCK_MONOTONIC clock id. If these are not present on the targeted platform, the new functions will fallback on using the original realtime functions av_gettime() and av_usleep(). Monotonic support can be added on other platforms with their equivalent native system API eventually if possible. Whenever time is requested to measure relative time, the monotonic clock, when available, is superior to the system realtime clock because it is not affected by discontinuous jumps in the system time In a future step, offering the flexibility to let the user choose between rt and monotonic clock for avdevices packets will be investigated. It is very easy to experience the issues that this patch attempt to address by rewinding back in the past the system time while ffmpeg is running. this is breaking the ffmpeg report printing (ffmepg.c:print_report()) and the the rate emulator functionality (-re) without the patch. Signed-off-by: Olivier Langlois <olivier@trillion01.com> Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
		
			
				
	
	
		
			57 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2000-2003 Fabrice Bellard
 | |
|  *
 | |
|  * This file is part of FFmpeg.
 | |
|  *
 | |
|  * FFmpeg is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU Lesser General Public
 | |
|  * License as published by the Free Software Foundation; either
 | |
|  * version 2.1 of the License, or (at your option) any later version.
 | |
|  *
 | |
|  * FFmpeg is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
|  * Lesser General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Lesser General Public
 | |
|  * License along with FFmpeg; if not, write to the Free Software
 | |
|  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 | |
|  */
 | |
| 
 | |
| #ifndef AVUTIL_TIME_H
 | |
| #define AVUTIL_TIME_H
 | |
| 
 | |
| #include <stdint.h>
 | |
| 
 | |
| /**
 | |
|  * Get the current time in microseconds.
 | |
|  */
 | |
| int64_t av_gettime(void);
 | |
| 
 | |
| /**
 | |
|  * Get the current time in microseconds since some unspecified starting point.
 | |
|  * On platforms that support it, the time comes from a monotonic clock
 | |
|  * This property makes this time source ideal for measuring relative time.
 | |
|  * If a monotonic clock is not available on the targeted platform, the
 | |
|  * implementation fallsback on using av_gettime().
 | |
|  */
 | |
| int64_t av_gettime_relative(void);
 | |
| 
 | |
| /**
 | |
|  * Indicates with a boolean result if the av_gettime_relative() time source
 | |
|  * is monotonic.
 | |
|  */
 | |
| int av_gettime_relative_is_monotonic(void);
 | |
| 
 | |
| /**
 | |
|  * Sleep for a period of time.  Although the duration is expressed in
 | |
|  * microseconds, the actual delay may be rounded to the precision of the
 | |
|  * system timer.
 | |
|  *
 | |
|  * @param  usec Number of microseconds to sleep.
 | |
|  * @return zero on success or (negative) error code.
 | |
|  */
 | |
| int av_usleep(unsigned usec);
 | |
| 
 | |
| #endif /* AVUTIL_TIME_H */
 |