mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-24 21:50:53 +00:00 
			
		
		
		
	This patch addresses issues during immediate shutdowns, where modules are not unloaded, but Asterisk atexit handlers are run. In the typical case, this usually isn't a big deal. But the introduction of the Stasis message bus makes it much more likely for asynchronous activity to be happening off in some thread during shutdown. During an immediate shutdown, Asterisk skips unloading modules. But while it is processing the atexit handlers, there is a window of time where some of the core message types have been cleaned up, but the message bus is still running. Specifically, it's still running module subscriptions that might be using the core message types. If a message is received by that subscription in that window, it will attempt to use a message type that has been cleaned up. To solve this problem, this patch introduces ast_register_cleanup(). This function operates identically to ast_register_atexit(), except that cleanup calls are not invoked on an immediate shutdown. All of the core message type and topic cleanup was moved from atexit handlers to cleanup handlers. This ensures that core type and topic cleanup only happens if the modules that used them are first unloaded. This patch also changes the ast_assert() when accessing a cleaned up or uninitialized message type to an error log message. Message type functions are actually NULL safe across the board, so the assert was a bit heavy handed. Especially for anyone with DO_CRASH enabled. Review: https://reviewboard.asterisk.org/r/2562/ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@390122 65c4cc65-6c06-0410-ace0-fbb531ad65f3
		
			
				
	
	
		
			145 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			145 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Asterisk -- An open source telephony toolkit.
 | |
|  *
 | |
|  * Copyright (C) 2009, Digium, Inc.
 | |
|  *
 | |
|  * Russell Bryant <russell@digium.com>
 | |
|  *
 | |
|  * See http://www.asterisk.org for more information about
 | |
|  * the Asterisk project. Please do not directly contact
 | |
|  * any of the maintainers of this project for assistance;
 | |
|  * the project provides a web site, mailing lists and IRC
 | |
|  * channels for your use.
 | |
|  *
 | |
|  * This program is free software, distributed under the terms of
 | |
|  * the GNU General Public License Version 2. See the LICENSE file
 | |
|  * at the top of the source tree.
 | |
|  */
 | |
| 
 | |
| /*!
 | |
|  * \file
 | |
|  *
 | |
|  * \brief Security Event Reporting API
 | |
|  *
 | |
|  * \author Russell Bryant <russell@digium.com>
 | |
|  */
 | |
| 
 | |
| #ifndef __AST_SECURITY_EVENTS_H__
 | |
| #define __AST_SECURITY_EVENTS_H__
 | |
| 
 | |
| #include "asterisk/event.h"
 | |
| 
 | |
| /* Data structure definitions */
 | |
| #include "asterisk/security_events_defs.h"
 | |
| 
 | |
| #if defined(__cplusplus) || defined(c_plusplus)
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| /*!
 | |
|  * \brief Report a security event
 | |
|  *
 | |
|  * \param[in] sec security event data.  Callers of this function should never
 | |
|  *            declare an instance of ast_security_event_common directly.  The
 | |
|  *            argument should be an instance of a specific security event
 | |
|  *            descriptor which has ast_security_event_common at the very
 | |
|  *            beginning.
 | |
|  *
 | |
|  * \retval 0 success
 | |
|  * \retval non-zero failure
 | |
|  */
 | |
| int ast_security_event_report(const struct ast_security_event_common *sec);
 | |
| 
 | |
| struct ast_security_event_ie_type {
 | |
| 	enum ast_event_ie_type ie_type;
 | |
| 	/*! \brief For internal usage */
 | |
| 	size_t offset;
 | |
| };
 | |
| 
 | |
| /*!
 | |
|  * \brief A \ref stasis_topic which publishes messages for security related issues.
 | |
|  * \since 12
 | |
|  *
 | |
|  * \retval \ref stasis_topic for security related issues.
 | |
|  * \retval NULL on error
 | |
|  */
 | |
| struct stasis_topic *ast_security_topic(void);
 | |
| 
 | |
| /*!
 | |
|  * \brief A \ref stasis_message_type for security events
 | |
|  * \since 12
 | |
|  *
 | |
|  * \retval NULL on error
 | |
|  * \retval \ref stasis_message_type for security events
 | |
|  *
 | |
|  * \note Messages of this type should always be issued on and expected from
 | |
|  *       the \ref ast_security_topic \ref stasis_topic
 | |
|  */
 | |
| struct stasis_message_type *ast_security_event_type(void);
 | |
| 
 | |
| /*!
 | |
|  * \brief initializes stasis topic/event types for \ref ast_security_topic and \ref ast_security_event_type
 | |
|  * \since 12
 | |
|  *
 | |
|  * \retval 0 on success
 | |
|  * \retval -1 on failure
 | |
|  */
 | |
| int ast_security_stasis_init(void);
 | |
| 
 | |
| /*!
 | |
|  * \brief Get the list of required IEs for a given security event sub-type
 | |
|  *
 | |
|  * \param[in] event_type security event sub-type
 | |
|  *
 | |
|  * \retval NULL invalid event_type
 | |
|  * \retval non-NULL An array terminated with the value AST_EVENT_IE_END
 | |
|  *
 | |
|  * \since 1.8
 | |
|  */
 | |
| const struct ast_security_event_ie_type *ast_security_event_get_required_ies(
 | |
| 		const enum ast_security_event_type event_type);
 | |
| 
 | |
| /*!
 | |
|  * \brief Get the list of optional IEs for a given security event sub-type
 | |
|  *
 | |
|  * \param[in] event_type security event sub-type
 | |
|  *
 | |
|  * \retval NULL invalid event_type
 | |
|  * \retval non-NULL An array terminated with the value AST_EVENT_IE_END
 | |
|  *
 | |
|  * \since 1.8
 | |
|  */
 | |
| const struct ast_security_event_ie_type *ast_security_event_get_optional_ies(
 | |
| 		const enum ast_security_event_type event_type);
 | |
| 
 | |
| /*!
 | |
|  * \brief Get the name of a security event sub-type
 | |
|  *
 | |
|  * \param[in] event_type security event sub-type
 | |
|  *
 | |
|  * \retval NULL if event_type is invalid
 | |
|  * \retval non-NULL the name of the security event type
 | |
|  *
 | |
|  * \since 1.8
 | |
|  */
 | |
| const char *ast_security_event_get_name(const enum ast_security_event_type event_type);
 | |
| 
 | |
| /*!
 | |
|  * \brief Get the name of a security event severity
 | |
|  *
 | |
|  * \param[in] severity security event severity
 | |
|  *
 | |
|  * \retval NULL if severity is invalid
 | |
|  * \retval non-NULL the name of the security event severity
 | |
|  *
 | |
|  * \since 1.8
 | |
|  */
 | |
| const char *ast_security_event_severity_get_name(
 | |
| 		const enum ast_security_event_severity severity);
 | |
| 
 | |
| #if defined(__cplusplus) || defined(c_plusplus)
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif /* __AST_SECURITY_EVENTS_H__ */
 |