mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-25 14:06:27 +00:00 
			
		
		
		
	autoservice: Do not sleep if autoservice_stop is called within autoservice thread
It's possible that ast_autoservice_stop is called within the autoservice thread.
In this case the autoservice thread is stuck in an endless sleep.
To avoid endless sleep ast_autoservice_stop must check that it's not called
within the autoservice thread.
Fixes: #763
(cherry picked from commit 9b3d3a7f0e)
			
			
This commit is contained in:
		
				
					committed by
					
						 Asterisk Development Team
						Asterisk Development Team
					
				
			
			
				
	
			
			
			
						parent
						
							beee92c909
						
					
				
				
					commit
					f435e28571
				
			| @@ -309,9 +309,16 @@ int ast_autoservice_stop(struct ast_channel *chan) | ||||
| 		return 0; | ||||
| 	} | ||||
|  | ||||
| 	/* Wait while autoservice thread rebuilds its list. */ | ||||
| 	while (chan_list_state == as_chan_list_state) { | ||||
| 		usleep(1000); | ||||
| 	if (asthread != AST_PTHREADT_NULL && pthread_equal(pthread_self(), asthread)) { | ||||
| 		/* Do not sleep if ast_autoservice_stop is called within the autoservice thread, | ||||
| 		   otherwise the thread will be stuck in an endless sleep. */ | ||||
| 		ast_debug(1, "ast_autoservice_stop is called within the autoservice thread, channel %s\n", | ||||
| 			ast_channel_name(chan)); | ||||
| 	} else { | ||||
| 		/* Wait while autoservice thread rebuilds its list. */ | ||||
| 		while (chan_list_state == as_chan_list_state) { | ||||
| 			usleep(1000); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	/* Now autoservice thread should have no references to our entry | ||||
|   | ||||
		Reference in New Issue
	
	Block a user