mirror of
				https://gitlab.freedesktop.org/pipewire/pipewire.git
				synced 2025-11-03 09:01:54 -05:00 
			
		
		
		
	alsa: reset dll when we reprogram the timers
This commit is contained in:
		
							parent
							
								
									7d2e824e97
								
							
						
					
					
						commit
						c153f39720
					
				
					 1 changed files with 10 additions and 6 deletions
				
			
		| 
						 | 
					@ -850,8 +850,11 @@ static int set_timers(struct seq_state *state)
 | 
				
			||||||
	int res;
 | 
						int res;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if ((res = spa_system_clock_gettime(state->data_system, CLOCK_MONOTONIC, &now)) < 0)
 | 
						if ((res = spa_system_clock_gettime(state->data_system, CLOCK_MONOTONIC, &now)) < 0)
 | 
				
			||||||
	    return res;
 | 
							return res;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						state->queue_time = 0;
 | 
				
			||||||
 | 
						state->queue_corr = 1.0;
 | 
				
			||||||
 | 
						spa_dll_init(&state->dll);
 | 
				
			||||||
	state->next_time = SPA_TIMESPEC_TO_NSEC(&now);
 | 
						state->next_time = SPA_TIMESPEC_TO_NSEC(&now);
 | 
				
			||||||
	if (state->following) {
 | 
						if (state->following) {
 | 
				
			||||||
		set_timeout(state, 0);
 | 
							set_timeout(state, 0);
 | 
				
			||||||
| 
						 | 
					@ -898,11 +901,9 @@ int spa_alsa_seq_start(struct seq_state *state)
 | 
				
			||||||
	state->source.rmask = 0;
 | 
						state->source.rmask = 0;
 | 
				
			||||||
	spa_loop_add_source(state->data_loop, &state->source);
 | 
						spa_loop_add_source(state->data_loop, &state->source);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	state->queue_time = 0;
 | 
						res = set_timers(state);
 | 
				
			||||||
	spa_dll_init(&state->dll);
 | 
					 | 
				
			||||||
	set_timers(state);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return 0;
 | 
						return res;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int do_reassign_follower(struct spa_loop *loop,
 | 
					static int do_reassign_follower(struct spa_loop *loop,
 | 
				
			||||||
| 
						 | 
					@ -913,7 +914,10 @@ static int do_reassign_follower(struct spa_loop *loop,
 | 
				
			||||||
			    void *user_data)
 | 
								    void *user_data)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct seq_state *state = user_data;
 | 
						struct seq_state *state = user_data;
 | 
				
			||||||
	set_timers(state);
 | 
						int res;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if ((res = set_timers(state)) < 0)
 | 
				
			||||||
 | 
							spa_log_error(state->log, "can't set timers: %s", spa_strerror(res));
 | 
				
			||||||
	return 0;
 | 
						return 0;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue