mirror of
				https://gitlab.freedesktop.org/pulseaudio/pulseaudio.git
				synced 2025-11-03 09:01:50 -05:00 
			
		
		
		
	timeval: make timeval conversion routines handle PA_USEC_INVALID special
This commit is contained in:
		
							parent
							
								
									a1da83b206
								
							
						
					
					
						commit
						c024aeaae9
					
				
					 2 changed files with 17 additions and 2 deletions
				
			
		| 
						 | 
				
			
			@ -193,6 +193,13 @@ underflow:
 | 
			
		|||
struct timeval* pa_timeval_store(struct timeval *tv, pa_usec_t v) {
 | 
			
		||||
    pa_assert(tv);
 | 
			
		||||
 | 
			
		||||
    if (PA_UNLIKELY(v == PA_USEC_INVALID)) {
 | 
			
		||||
        tv->tv_sec = PA_INT_TYPE_MAX(time_t);
 | 
			
		||||
        tv->tv_usec = (suseconds_t) (PA_USEC_PER_SEC-1);
 | 
			
		||||
 | 
			
		||||
        return tv;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    tv->tv_sec = (time_t) (v / PA_USEC_PER_SEC);
 | 
			
		||||
    tv->tv_usec = (suseconds_t) (v % PA_USEC_PER_SEC);
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -200,7 +207,9 @@ struct timeval* pa_timeval_store(struct timeval *tv, pa_usec_t v) {
 | 
			
		|||
}
 | 
			
		||||
 | 
			
		||||
pa_usec_t pa_timeval_load(const struct timeval *tv) {
 | 
			
		||||
    pa_assert(tv);
 | 
			
		||||
 | 
			
		||||
    if (PA_UNLIKELY(!tv))
 | 
			
		||||
        return PA_USEC_INVALID;
 | 
			
		||||
 | 
			
		||||
    return
 | 
			
		||||
        (pa_usec_t) tv->tv_sec * PA_USEC_PER_SEC +
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -132,6 +132,8 @@ struct timeval* pa_rtclock_from_wallclock(struct timeval *tv) {
 | 
			
		|||
 | 
			
		||||
    pa_assert(tv);
 | 
			
		||||
 | 
			
		||||
    /* pa_timeval_sub() saturates on underflow! */
 | 
			
		||||
 | 
			
		||||
    if (pa_timeval_cmp(&wc_now, tv) < 0)
 | 
			
		||||
        pa_timeval_add(&rt_now, pa_timeval_diff(tv, &wc_now));
 | 
			
		||||
    else
 | 
			
		||||
| 
						 | 
				
			
			@ -144,7 +146,9 @@ struct timeval* pa_rtclock_from_wallclock(struct timeval *tv) {
 | 
			
		|||
}
 | 
			
		||||
 | 
			
		||||
pa_usec_t pa_timespec_load(const struct timespec *ts) {
 | 
			
		||||
    pa_assert(ts);
 | 
			
		||||
 | 
			
		||||
    if (PA_UNLIKELY(!ts))
 | 
			
		||||
        return PA_USEC_INVALID;
 | 
			
		||||
 | 
			
		||||
    return
 | 
			
		||||
        (pa_usec_t) ts->tv_sec * PA_USEC_PER_SEC +
 | 
			
		||||
| 
						 | 
				
			
			@ -176,6 +180,8 @@ static struct timeval* wallclock_from_rtclock(struct timeval *tv) {
 | 
			
		|||
 | 
			
		||||
    pa_assert(tv);
 | 
			
		||||
 | 
			
		||||
    /* pa_timeval_sub() saturates on underflow! */
 | 
			
		||||
 | 
			
		||||
    if (pa_timeval_cmp(&rt_now, tv) < 0)
 | 
			
		||||
        pa_timeval_add(&wc_now, pa_timeval_diff(tv, &rt_now));
 | 
			
		||||
    else
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue