mirror of
				https://github.com/alsa-project/alsa-lib.git
				synced 2025-11-03 09:01:52 -05:00 
			
		
		
		
	Add snd_lib_error_set_local() to install a thread-local error handler.
This is required so we can make other functions reentrant (such as snd_device_name_hint()). The default error handling function snd_lib_error_default() now checks if a local handler exists, and if so, calls it. Otherwise, the previous behavior is unchanged. Signed-off-by: Jerome Forissier <jerome@taodyne.com> Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
		
							parent
							
								
									2cfc8b9b44
								
							
						
					
					
						commit
						44c1a623dd
					
				
					 3 changed files with 39 additions and 1 deletions
				
			
		
							
								
								
									
										10
									
								
								configure.in
									
										
									
									
									
								
							
							
						
						
									
										10
									
								
								configure.in
									
										
									
									
									
								
							| 
						 | 
					@ -281,6 +281,16 @@ else
 | 
				
			||||||
  AC_MSG_RESULT(no)
 | 
					  AC_MSG_RESULT(no)
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					dnl Check for __thread
 | 
				
			||||||
 | 
					AC_MSG_CHECKING([for __thread])
 | 
				
			||||||
 | 
					AC_LINK_IFELSE([AC_LANG_PROGRAM([#if defined(__GNUC__) && (defined(__i386__) || defined(__x86_64__)) && ((__GNUC__ < 4) || (__GNUC__ == 4 && __GNUC_MINOR__ < 1) || (__GNUC__ == 4 && __GNUC_MINOR__ == 1 && __GNUC_PATCHLEVEL__ < 2))
 | 
				
			||||||
 | 
					#error gcc has this bug: http://gcc.gnu.org/ml/gcc-bugs/2006-09/msg02275.html
 | 
				
			||||||
 | 
					#endif], [static __thread int p = 0])],
 | 
				
			||||||
 | 
					[AC_DEFINE(HAVE___THREAD, 1,
 | 
				
			||||||
 | 
					Define to 1 if compiler supports __thread)
 | 
				
			||||||
 | 
					AC_MSG_RESULT([yes])],
 | 
				
			||||||
 | 
					[AC_MSG_RESULT([no])])
 | 
				
			||||||
 | 
					
 | 
				
			||||||
dnl Check for librt
 | 
					dnl Check for librt
 | 
				
			||||||
AC_MSG_CHECKING(for librt)
 | 
					AC_MSG_CHECKING(for librt)
 | 
				
			||||||
AC_ARG_WITH(librt,
 | 
					AC_ARG_WITH(librt,
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -74,5 +74,11 @@ extern int snd_lib_error_set_handler(snd_lib_error_handler_t handler);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					typedef void (*snd_local_error_handler_t)(const char *file, int line,
 | 
				
			||||||
 | 
										  const char *func, int err,
 | 
				
			||||||
 | 
										  const char *fmt, va_list arg);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					snd_local_error_handler_t snd_lib_error_set_local(snd_local_error_handler_t func);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#endif /* __ALSA_ERROR_H */
 | 
					#endif /* __ALSA_ERROR_H */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										24
									
								
								src/error.c
									
										
									
									
									
								
							
							
						
						
									
										24
									
								
								src/error.c
									
										
									
									
									
								
							| 
						 | 
					@ -60,6 +60,21 @@ const char *snd_strerror(int errnum)
 | 
				
			||||||
	return snd_error_codes[errnum];
 | 
						return snd_error_codes[errnum];
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef HAVE___THREAD
 | 
				
			||||||
 | 
					#define TLS_PFX		__thread
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					#define TLS_PFX		/* NOP */
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static TLS_PFX snd_local_error_handler_t local_error = NULL;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					snd_local_error_handler_t snd_lib_error_set_local(snd_local_error_handler_t func)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						snd_local_error_handler_t old = local_error;
 | 
				
			||||||
 | 
						local_error = func;
 | 
				
			||||||
 | 
						return old;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * \brief The default error handler function.
 | 
					 * \brief The default error handler function.
 | 
				
			||||||
 * \param file The filename where the error was hit.
 | 
					 * \param file The filename where the error was hit.
 | 
				
			||||||
| 
						 | 
					@ -69,12 +84,19 @@ const char *snd_strerror(int errnum)
 | 
				
			||||||
 * \param fmt The message (including the format characters).
 | 
					 * \param fmt The message (including the format characters).
 | 
				
			||||||
 * \param ... Optional arguments.
 | 
					 * \param ... Optional arguments.
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * Prints the error message including location to \c stderr.
 | 
					 * If a local error function has been installed for the current thread by
 | 
				
			||||||
 | 
					 * \ref snd_lib_error_set_local, it is called. Otherwise, prints the error
 | 
				
			||||||
 | 
					 * message including location to \c stderr.
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
static void snd_lib_error_default(const char *file, int line, const char *function, int err, const char *fmt, ...)
 | 
					static void snd_lib_error_default(const char *file, int line, const char *function, int err, const char *fmt, ...)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	va_list arg;
 | 
						va_list arg;
 | 
				
			||||||
	va_start(arg, fmt);
 | 
						va_start(arg, fmt);
 | 
				
			||||||
 | 
						if (local_error) {
 | 
				
			||||||
 | 
							local_error(file, line, function, err, fmt, arg);
 | 
				
			||||||
 | 
							va_end(arg);
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
	fprintf(stderr, "ALSA lib %s:%i:(%s) ", file, line, function);
 | 
						fprintf(stderr, "ALSA lib %s:%i:(%s) ", file, line, function);
 | 
				
			||||||
	vfprintf(stderr, fmt, arg);
 | 
						vfprintf(stderr, fmt, arg);
 | 
				
			||||||
	if (err)
 | 
						if (err)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue