Asterisk module definitions. More...
#include "asterisk/utils.h"
Go to the source code of this file.
Data Structures | |
| struct | ast_module_info |
Defines | |
| #define | __MODULE_INFO_GLOBALS |
| #define | __MODULE_INFO_SECTION |
| #define | AST_MODULE_CONFIG "modules.conf" |
| Module configuration file. | |
| #define | AST_MODULE_INFO(keystr, flags_to_set, desc, fields...) |
| #define | AST_MODULE_INFO_STANDARD(keystr, desc) |
| #define | ast_module_user_add(chan) __ast_module_user_add(ast_module_info->self, chan) |
| #define | ast_module_user_hangup_all() __ast_module_user_hangup_all(ast_module_info->self) |
| #define | ast_module_user_remove(user) __ast_module_user_remove(ast_module_info->self, user) |
| #define | ast_register_application(app, execute, synopsis, description) ast_register_application2(app, execute, synopsis, description, ast_module_info->self) |
| Register an application. | |
| #define | ast_register_application_xml(app, execute) ast_register_application(app, execute, NULL, NULL) |
| Register an application using XML documentation. | |
| #define | ASTERISK_GPL_KEY "This paragraph is copyright (c) 2006 by Digium, Inc. \In order for your module to load, it must return this \key via a function called \"key\". Any code which \includes this paragraph must be licensed under the GNU \General Public License version 2 or later (at your \option). In addition to Digium's general reservations \of rights, Digium expressly reserves the right to \allow other parties to license this paragraph under \different terms. Any use of Digium, Inc. trademarks or \logos (including \"Asterisk\" or \"Digium\") without \express written permission of Digium, Inc. is prohibited.\n" |
| The text the key() function should return. | |
Enumerations | |
| enum | ast_module_flags { AST_MODFLAG_DEFAULT = 0, AST_MODFLAG_GLOBAL_SYMBOLS = (1 << 0), AST_MODFLAG_LOAD_ORDER = (1 << 1) } |
| enum | ast_module_load_result { AST_MODULE_LOAD_SUCCESS = 0, AST_MODULE_LOAD_DECLINE = 1, AST_MODULE_LOAD_SKIP = 2, AST_MODULE_LOAD_PRIORITY = 3, AST_MODULE_LOAD_FAILURE = -1 } |
| enum | ast_module_unload_mode { AST_FORCE_SOFT = 0, AST_FORCE_FIRM = 1, AST_FORCE_HARD = 2 } |
Functions | |
| struct ast_module_user * | __ast_module_user_add (struct ast_module *, struct ast_channel *) |
| void | __ast_module_user_hangup_all (struct ast_module *) |
| void | __ast_module_user_remove (struct ast_module *, struct ast_module_user *) |
| enum ast_module_load_result | ast_load_resource (const char *resource_name) |
| Load a module. | |
| int | ast_loader_register (int(*updater)(void)) |
| Add a procedure to be run when modules have been updated. | |
| int | ast_loader_unregister (int(*updater)(void)) |
| Remove a procedure to be run when modules are updated. | |
| int | ast_module_check (const char *name) |
| Check if module with the name given is loaded. | |
| char * | ast_module_helper (const char *line, const char *word, int pos, int state, int rpos, int needsreload) |
| Match modules names for the Asterisk cli. | |
| struct ast_module * | ast_module_ref (struct ast_module *) |
| void | ast_module_register (const struct ast_module_info *) |
| void | ast_module_shutdown (void) |
| Run the unload() callback for all loaded modules. | |
| void | ast_module_unref (struct ast_module *) |
| void | ast_module_unregister (const struct ast_module_info *) |
| int | ast_register_application2 (const char *app, int(*execute)(struct ast_channel *, void *), const char *synopsis, const char *description, void *mod) |
| Register an application. | |
| int | ast_unload_resource (const char *resource_name, enum ast_module_unload_mode) |
| Unload a module. | |
| int | ast_unregister_application (const char *app) |
| Unregister an application. | |
| int | ast_update_module_list (int(*modentry)(const char *module, const char *description, int usecnt, const char *like), const char *like) |
| Ask for a list of modules, descriptions, and use counts. | |
| void | ast_update_use_count (void) |
| Notify when usecount has been changed. | |
Variables | |
| static struct ast_module_info * | ast_module_info |
Asterisk module definitions.
This file contains the definitons for functions Asterisk modules should provide and some other module related functions.
Definition in file module.h.
| #define AST_MODULE_CONFIG "modules.conf" |
| #define AST_MODULE_INFO | ( | keystr, | |||
| flags_to_set, | |||||
| desc, | |||||
| fields... | ) |
| #define AST_MODULE_INFO_STANDARD | ( | keystr, | |||
| desc | ) |
AST_MODULE_INFO(keystr, AST_MODFLAG_DEFAULT, desc, \ .load = load_module, \ .unload = unload_module, \ )
| #define ast_module_user_add | ( | chan | ) | __ast_module_user_add(ast_module_info->self, chan) |
Definition at line 240 of file module.h.
Referenced by canmatch(), dundi_query_read(), dundi_result_read(), dundifunc_read(), exec(), exists(), local_new(), login_exec(), matchmore(), nbs_new(), smdi_msg_read(), and smdi_msg_retrieve_read().
| #define ast_module_user_hangup_all | ( | ) | __ast_module_user_hangup_all(ast_module_info->self) |
Definition at line 242 of file module.h.
Referenced by unload_module().
| #define ast_module_user_remove | ( | user | ) | __ast_module_user_remove(ast_module_info->self, user) |
Definition at line 241 of file module.h.
Referenced by canmatch(), dundi_query_read(), dundi_result_read(), dundifunc_read(), exec(), exists(), local_hangup(), login_exec(), matchmore(), nbs_destroy(), smdi_msg_read(), and smdi_msg_retrieve_read().
| #define ast_register_application | ( | app, | |||
| execute, | |||||
| synopsis, | |||||
| description | ) | ast_register_application2(app, execute, synopsis, description, ast_module_info->self) |
Register an application.
| app | Short name of the application | |
| execute | a function callback to execute the application. It should return non-zero if the channel needs to be hung up. | |
| synopsis | a short description (one line synopsis) of the application | |
| description | long description with all of the details about the use of the application |
This registers an application with Asterisk's internal application list.
| 0 | success | |
| -1 | failure. |
Definition at line 390 of file module.h.
Referenced by load_module().
| #define ast_register_application_xml | ( | app, | |||
| execute | ) | ast_register_application(app, execute, NULL, NULL) |
Register an application using XML documentation.
| app | Short name of the application | |
| execute | a function callback to execute the application. It should return non-zero if the channel needs to be hung up. |
This registers an application with Asterisk's internal application list.
| 0 | success | |
| -1 | failure. |
Definition at line 406 of file module.h.
Referenced by load_module().
| #define ASTERISK_GPL_KEY "This paragraph is copyright (c) 2006 by Digium, Inc. \In order for your module to load, it must return this \key via a function called \"key\". Any code which \includes this paragraph must be licensed under the GNU \General Public License version 2 or later (at your \option). In addition to Digium's general reservations \of rights, Digium expressly reserves the right to \allow other parties to license this paragraph under \different terms. Any use of Digium, Inc. trademarks or \logos (including \"Asterisk\" or \"Digium\") without \express written permission of Digium, Inc. is prohibited.\n" |
| enum ast_module_flags |
Definition at line 190 of file module.h.
00190 { 00191 AST_MODFLAG_DEFAULT = 0, 00192 AST_MODFLAG_GLOBAL_SYMBOLS = (1 << 0), 00193 AST_MODFLAG_LOAD_ORDER = (1 << 1), 00194 };
Definition at line 60 of file module.h.
00060 { 00061 AST_MODULE_LOAD_SUCCESS = 0, /*!< Module loaded and configured */ 00062 AST_MODULE_LOAD_DECLINE = 1, /*!< Module is not configured */ 00063 AST_MODULE_LOAD_SKIP = 2, /*!< Module was skipped for some reason */ 00064 AST_MODULE_LOAD_PRIORITY = 3, /*!< Module is not loaded yet, but is added to prioity heap */ 00065 AST_MODULE_LOAD_FAILURE = -1, /*!< Module could not be loaded properly */ 00066 };
Definition at line 53 of file module.h.
00053 { 00054 AST_FORCE_SOFT = 0, /*!< Softly unload a module, only if not in use */ 00055 AST_FORCE_FIRM = 1, /*!< Firmly unload a module, even if in use */ 00056 AST_FORCE_HARD = 2, /*!< as FIRM, plus dlclose() on the module. Not recommended 00057 as it may cause crashes */ 00058 };
| struct ast_module_user* __ast_module_user_add | ( | struct ast_module * | , | |
| struct ast_channel * | ||||
| ) | [read] |
Definition at line 195 of file loader.c.
References ast_atomic_fetchadd_int(), ast_calloc, AST_LIST_INSERT_HEAD, AST_LIST_LOCK, AST_LIST_UNLOCK, ast_update_use_count(), ast_module_user::chan, ast_module::usecount, and ast_module::users.
Referenced by ast_func_read(), ast_func_write(), and pbx_exec().
00197 { 00198 struct ast_module_user *u = ast_calloc(1, sizeof(*u)); 00199 00200 if (!u) 00201 return NULL; 00202 00203 u->chan = chan; 00204 00205 AST_LIST_LOCK(&mod->users); 00206 AST_LIST_INSERT_HEAD(&mod->users, u, entry); 00207 AST_LIST_UNLOCK(&mod->users); 00208 00209 ast_atomic_fetchadd_int(&mod->usecount, +1); 00210 00211 ast_update_use_count(); 00212 00213 return u; 00214 }
| void __ast_module_user_hangup_all | ( | struct ast_module * | ) |
Definition at line 227 of file loader.c.
References ast_atomic_fetchadd_int(), ast_free, AST_LIST_LOCK, AST_LIST_REMOVE_HEAD, AST_LIST_UNLOCK, ast_softhangup(), AST_SOFTHANGUP_APPUNLOAD, ast_update_use_count(), ast_module_user::chan, ast_module::usecount, and ast_module::users.
Referenced by ast_unload_resource().
00228 { 00229 struct ast_module_user *u; 00230 00231 AST_LIST_LOCK(&mod->users); 00232 while ((u = AST_LIST_REMOVE_HEAD(&mod->users, entry))) { 00233 ast_softhangup(u->chan, AST_SOFTHANGUP_APPUNLOAD); 00234 ast_atomic_fetchadd_int(&mod->usecount, -1); 00235 ast_free(u); 00236 } 00237 AST_LIST_UNLOCK(&mod->users); 00238 00239 ast_update_use_count(); 00240 }
| void __ast_module_user_remove | ( | struct ast_module * | , | |
| struct ast_module_user * | ||||
| ) |
Definition at line 216 of file loader.c.
References ast_atomic_fetchadd_int(), ast_free, AST_LIST_LOCK, AST_LIST_REMOVE, AST_LIST_UNLOCK, ast_update_use_count(), ast_module::usecount, and ast_module::users.
Referenced by ast_func_read(), ast_func_write(), and pbx_exec().
00217 { 00218 AST_LIST_LOCK(&mod->users); 00219 AST_LIST_REMOVE(&mod->users, u, entry); 00220 AST_LIST_UNLOCK(&mod->users); 00221 ast_atomic_fetchadd_int(&mod->usecount, -1); 00222 ast_free(u); 00223 00224 ast_update_use_count(); 00225 }
| enum ast_module_load_result ast_load_resource | ( | const char * | resource_name | ) |
Load a module.
| resource_name | The name of the module to load. |
This function is run by the PBX to load the modules. It performs all loading and initialization tasks. Basically, to load a module, just give it the name of the module and it will do the rest.
Definition at line 831 of file loader.c.
References AST_LIST_LOCK, AST_LIST_UNLOCK, and load_resource().
Referenced by file_ok_sel(), handle_load(), load_module(), manager_moduleload(), and reload().
00832 { 00833 int res; 00834 AST_LIST_LOCK(&module_list); 00835 res = load_resource(resource_name, 0, NULL); 00836 AST_LIST_UNLOCK(&module_list); 00837 00838 return res; 00839 }
| int ast_loader_register | ( | int(*)(void) | updater | ) |
Add a procedure to be run when modules have been updated.
| updater | The function to run when modules have been updated. |
This function adds the given function to a linked list of functions to be run when the modules are updated.
| 0 | on success | |
| -1 | on failure. |
Definition at line 1131 of file loader.c.
References AST_LIST_INSERT_HEAD, AST_LIST_LOCK, AST_LIST_UNLOCK, ast_malloc, and loadupdate::updater.
Referenced by show_console().
01132 { 01133 struct loadupdate *tmp; 01134 01135 if (!(tmp = ast_malloc(sizeof(*tmp)))) 01136 return -1; 01137 01138 tmp->updater = v; 01139 AST_LIST_LOCK(&updaters); 01140 AST_LIST_INSERT_HEAD(&updaters, tmp, entry); 01141 AST_LIST_UNLOCK(&updaters); 01142 01143 return 0; 01144 }
| int ast_loader_unregister | ( | int(*)(void) | updater | ) |
Remove a procedure to be run when modules are updated.
| updater | The updater function to unregister. |
This removes the given function from the updater list.
| 0 | on success | |
| -1 | on failure. |
Definition at line 1146 of file loader.c.
References AST_LIST_LOCK, AST_LIST_REMOVE_CURRENT, AST_LIST_TRAVERSE_SAFE_BEGIN, AST_LIST_TRAVERSE_SAFE_END, AST_LIST_UNLOCK, and loadupdate::updater.
Referenced by exit_now().
01147 { 01148 struct loadupdate *cur; 01149 01150 AST_LIST_LOCK(&updaters); 01151 AST_LIST_TRAVERSE_SAFE_BEGIN(&updaters, cur, entry) { 01152 if (cur->updater == v) { 01153 AST_LIST_REMOVE_CURRENT(entry); 01154 break; 01155 } 01156 } 01157 AST_LIST_TRAVERSE_SAFE_END; 01158 AST_LIST_UNLOCK(&updaters); 01159 01160 return cur ? 0 : -1; 01161 }
| int ast_module_check | ( | const char * | name | ) |
Check if module with the name given is loaded.
| name | Module name, like "chan_sip.so" |
| 1 | if true | |
| 0 | if false |
Definition at line 1118 of file loader.c.
References ast_strlen_zero(), and find_resource().
Referenced by ifmodule_read(), load_module(), manager_modulecheck(), and unload_module().
01119 { 01120 struct ast_module *cur; 01121 01122 if (ast_strlen_zero(name)) 01123 return 0; /* FALSE */ 01124 01125 cur = find_resource(name, 1); 01126 01127 return (cur != NULL); 01128 }
| char* ast_module_helper | ( | const char * | line, | |
| const char * | word, | |||
| int | pos, | |||
| int | state, | |||
| int | rpos, | |||
| int | needsreload | |||
| ) |
Match modules names for the Asterisk cli.
| line | Unused by this function, but this should be the line we are matching. | |
| word | The partial name to match. | |
| pos | The position the word we are completing is in. | |
| state | The possible match to return. | |
| rpos | The position we should be matching. This should be the same as pos. | |
| needsreload | This should be 1 if we need to reload this module and 0 otherwise. This function will only return modules that are reloadble if this is 1. |
| A | possible completion of the partial match. | |
| NULL | if no matches were found. |
Definition at line 542 of file loader.c.
References AST_LIST_LOCK, AST_LIST_TRAVERSE, AST_LIST_UNLOCK, ast_strdup, ast_module::info, name, ast_module_info::reload, and ast_module::resource.
Referenced by handle_modlist(), handle_reload(), handle_unload(), and load_module().
00543 { 00544 struct ast_module *cur; 00545 int i, which=0, l = strlen(word); 00546 char *ret = NULL; 00547 00548 if (pos != rpos) 00549 return NULL; 00550 00551 AST_LIST_LOCK(&module_list); 00552 AST_LIST_TRAVERSE(&module_list, cur, entry) { 00553 if (!strncasecmp(word, cur->resource, l) && 00554 (cur->info->reload || !needsreload) && 00555 ++which > state) { 00556 ret = ast_strdup(cur->resource); 00557 break; 00558 } 00559 } 00560 AST_LIST_UNLOCK(&module_list); 00561 00562 if (!ret) { 00563 for (i=0; !ret && reload_classes[i].name; i++) { 00564 if (!strncasecmp(word, reload_classes[i].name, l) && ++which > state) 00565 ret = ast_strdup(reload_classes[i].name); 00566 } 00567 } 00568 00569 return ret; 00570 }
| struct ast_module* ast_module_ref | ( | struct ast_module * | ) | [read] |
Definition at line 1163 of file loader.c.
References ast_atomic_fetchadd_int(), ast_update_use_count(), and ast_module::usecount.
Referenced by __oh323_new(), agi_handle_command(), alsa_new(), ast_agi_register(), ast_iax2_new(), ast_timer_open(), dahdi_new(), find_best_technology(), fn_wrapper(), gtalk_new(), handle_cli_file_convert(), handle_orig(), load_module(), mgcp_new(), moh_alloc(), moh_files_alloc(), newpvt(), oss_new(), phone_check_exception(), phone_new(), sip_new(), skinny_new(), smdi_load(), and usbradio_new().
01164 { 01165 ast_atomic_fetchadd_int(&mod->usecount, +1); 01166 ast_update_use_count(); 01167 01168 return mod; 01169 }
| void ast_module_register | ( | const struct ast_module_info * | ) |
Definition at line 133 of file loader.c.
References ast_calloc, AST_LIST_HEAD_INIT, AST_LIST_INSERT_TAIL, AST_LIST_LOCK, AST_LIST_UNLOCK, embedding, ast_module::info, ast_module::resource, and ast_module::users.
00134 { 00135 struct ast_module *mod; 00136 00137 if (embedding) { 00138 if (!(mod = ast_calloc(1, sizeof(*mod) + strlen(info->name) + 1))) 00139 return; 00140 strcpy(mod->resource, info->name); 00141 } else { 00142 mod = resource_being_loaded; 00143 } 00144 00145 mod->info = info; 00146 AST_LIST_HEAD_INIT(&mod->users); 00147 00148 /* during startup, before the loader has been initialized, 00149 there are no threads, so there is no need to take the lock 00150 on this list to manipulate it. it is also possible that it 00151 might be unsafe to use the list lock at that point... so 00152 let's avoid it altogether 00153 */ 00154 if (embedding) { 00155 AST_LIST_INSERT_TAIL(&embedded_module_list, mod, entry); 00156 } else { 00157 AST_LIST_LOCK(&module_list); 00158 /* it is paramount that the new entry be placed at the tail of 00159 the list, otherwise the code that uses dlopen() to load 00160 dynamic modules won't be able to find out if the module it 00161 just opened was registered or failed to load 00162 */ 00163 AST_LIST_INSERT_TAIL(&module_list, mod, entry); 00164 AST_LIST_UNLOCK(&module_list); 00165 } 00166 00167 /* give the module a copy of its own handle, for later use in registrations and the like */ 00168 *((struct ast_module **) &(info->self)) = mod; 00169 }
| void ast_module_shutdown | ( | void | ) |
Run the unload() callback for all loaded modules.
This function should be called when Asterisk is shutting down gracefully.
Definition at line 444 of file loader.c.
References AST_LIST_HEAD_DESTROY, AST_LIST_LOCK, AST_LIST_REMOVE_CURRENT, AST_LIST_TRAVERSE_SAFE_BEGIN, AST_LIST_TRAVERSE_SAFE_END, AST_LIST_UNLOCK, free, ast_module::info, ast_module_info::unload, ast_module::usecount, and ast_module::users.
Referenced by quit_handler().
00445 { 00446 struct ast_module *mod; 00447 int somethingchanged = 1, final = 0; 00448 00449 AST_LIST_LOCK(&module_list); 00450 00451 /*!\note Some resources, like timers, are started up dynamically, and thus 00452 * may be still in use, even if all channels are dead. We must therefore 00453 * check the usecount before asking modules to unload. */ 00454 do { 00455 if (!somethingchanged) { 00456 /*!\note If we go through the entire list without changing 00457 * anything, ignore the usecounts and unload, then exit. */ 00458 final = 1; 00459 } 00460 00461 /* Reset flag before traversing the list */ 00462 somethingchanged = 0; 00463 00464 AST_LIST_TRAVERSE_SAFE_BEGIN(&module_list, mod, entry) { 00465 if (!final && mod->usecount) { 00466 continue; 00467 } 00468 AST_LIST_REMOVE_CURRENT(entry); 00469 if (mod->info->unload) { 00470 mod->info->unload(); 00471 } 00472 AST_LIST_HEAD_DESTROY(&mod->users); 00473 free(mod); 00474 somethingchanged = 1; 00475 } 00476 AST_LIST_TRAVERSE_SAFE_END; 00477 } while (somethingchanged && !final); 00478 00479 AST_LIST_UNLOCK(&module_list); 00480 }
| void ast_module_unref | ( | struct ast_module * | ) |
Definition at line 1171 of file loader.c.
References ast_atomic_fetchadd_int(), ast_update_use_count(), and ast_module::usecount.
Referenced by agi_handle_command(), alsa_hangup(), ast_agi_unregister(), ast_bridge_check(), ast_smdi_interface_destroy(), ast_timer_close(), dahdi_destroy_channel_bynum(), dahdi_hangup(), destroy(), destroy_bridge(), filestream_destructor(), gtalk_hangup(), handle_cli_file_convert(), handle_orig(), iax2_predestroy(), local_ast_moh_cleanup(), mgcp_hangup(), oh323_hangup(), oss_hangup(), phone_check_exception(), phone_hangup(), sip_hangup(), skinny_hangup(), smart_bridge_operation(), and usbradio_hangup().
01172 { 01173 ast_atomic_fetchadd_int(&mod->usecount, -1); 01174 ast_update_use_count(); 01175 }
| void ast_module_unregister | ( | const struct ast_module_info * | ) |
Definition at line 171 of file loader.c.
References ast_free, AST_LIST_HEAD_DESTROY, AST_LIST_LOCK, AST_LIST_REMOVE_CURRENT, AST_LIST_TRAVERSE_SAFE_BEGIN, AST_LIST_TRAVERSE_SAFE_END, AST_LIST_UNLOCK, ast_module::info, and ast_module::users.
00172 { 00173 struct ast_module *mod = NULL; 00174 00175 /* it is assumed that the users list in the module structure 00176 will already be empty, or we cannot have gotten to this 00177 point 00178 */ 00179 AST_LIST_LOCK(&module_list); 00180 AST_LIST_TRAVERSE_SAFE_BEGIN(&module_list, mod, entry) { 00181 if (mod->info == info) { 00182 AST_LIST_REMOVE_CURRENT(entry); 00183 break; 00184 } 00185 } 00186 AST_LIST_TRAVERSE_SAFE_END; 00187 AST_LIST_UNLOCK(&module_list); 00188 00189 if (mod) { 00190 AST_LIST_HEAD_DESTROY(&mod->users); 00191 ast_free(mod); 00192 } 00193 }
| int ast_register_application2 | ( | const char * | app, | |
| int(*)(struct ast_channel *, void *) | execute, | |||
| const char * | synopsis, | |||
| const char * | description, | |||
| void * | mod | |||
| ) |
Register an application.
| app | Short name of the application | |
| execute | a function callback to execute the application. It should return non-zero if the channel needs to be hung up. | |
| synopsis | a short description (one line synopsis) of the application | |
| description | long description with all of the details about the use of the application | |
| mod | module this application belongs to |
This registers an application with Asterisk's internal application list.
| 0 | success | |
| -1 | failure. |
Definition at line 5062 of file pbx.c.
References ast_app::arguments, ast_calloc, ast_free, ast_log(), AST_RWLIST_INSERT_BEFORE_CURRENT, AST_RWLIST_INSERT_TAIL, AST_RWLIST_TRAVERSE, AST_RWLIST_TRAVERSE_SAFE_BEGIN, AST_RWLIST_TRAVERSE_SAFE_END, AST_RWLIST_UNLOCK, AST_RWLIST_WRLOCK, AST_STATIC_DOC, ast_string_field_init, ast_string_field_set, ast_strlen_zero(), ast_verb, AST_XML_DOC, ast_xmldoc_build_arguments(), ast_xmldoc_build_description(), ast_xmldoc_build_seealso(), ast_xmldoc_build_synopsis(), ast_xmldoc_build_syntax(), COLOR_BRCYAN, ast_app::docsrc, ast_app::execute, LOG_WARNING, ast_app::module, ast_app::name, ast_app::seealso, ast_app::syntax, and term_color().
Referenced by ast_features_init(), and load_pbx().
05063 { 05064 struct ast_app *tmp, *cur = NULL; 05065 char tmps[80]; 05066 int length, res; 05067 #ifdef AST_XML_DOCS 05068 char *tmpxml; 05069 #endif 05070 05071 AST_RWLIST_WRLOCK(&apps); 05072 AST_RWLIST_TRAVERSE(&apps, tmp, list) { 05073 if (!(res = strcasecmp(app, tmp->name))) { 05074 ast_log(LOG_WARNING, "Already have an application '%s'\n", app); 05075 AST_RWLIST_UNLOCK(&apps); 05076 return -1; 05077 } else if (res < 0) 05078 break; 05079 } 05080 05081 length = sizeof(*tmp) + strlen(app) + 1; 05082 05083 if (!(tmp = ast_calloc(1, length))) { 05084 AST_RWLIST_UNLOCK(&apps); 05085 return -1; 05086 } 05087 05088 if (ast_string_field_init(tmp, 128)) { 05089 AST_RWLIST_UNLOCK(&apps); 05090 ast_free(tmp); 05091 return -1; 05092 } 05093 05094 #ifdef AST_XML_DOCS 05095 /* Try to lookup the docs in our XML documentation database */ 05096 if (ast_strlen_zero(synopsis) && ast_strlen_zero(description)) { 05097 /* load synopsis */ 05098 tmpxml = ast_xmldoc_build_synopsis("application", app); 05099 ast_string_field_set(tmp, synopsis, tmpxml); 05100 ast_free(tmpxml); 05101 05102 /* load description */ 05103 tmpxml = ast_xmldoc_build_description("application", app); 05104 ast_string_field_set(tmp, description, tmpxml); 05105 ast_free(tmpxml); 05106 05107 /* load syntax */ 05108 tmpxml = ast_xmldoc_build_syntax("application", app); 05109 ast_string_field_set(tmp, syntax, tmpxml); 05110 ast_free(tmpxml); 05111 05112 /* load arguments */ 05113 tmpxml = ast_xmldoc_build_arguments("application", app); 05114 ast_string_field_set(tmp, arguments, tmpxml); 05115 ast_free(tmpxml); 05116 05117 /* load seealso */ 05118 tmpxml = ast_xmldoc_build_seealso("application", app); 05119 ast_string_field_set(tmp, seealso, tmpxml); 05120 ast_free(tmpxml); 05121 tmp->docsrc = AST_XML_DOC; 05122 } else { 05123 #endif 05124 ast_string_field_set(tmp, synopsis, synopsis); 05125 ast_string_field_set(tmp, description, description); 05126 tmp->docsrc = AST_STATIC_DOC; 05127 #ifdef AST_XML_DOCS 05128 } 05129 #endif 05130 05131 strcpy(tmp->name, app); 05132 tmp->execute = execute; 05133 tmp->module = mod; 05134 05135 /* Store in alphabetical order */ 05136 AST_RWLIST_TRAVERSE_SAFE_BEGIN(&apps, cur, list) { 05137 if (strcasecmp(tmp->name, cur->name) < 0) { 05138 AST_RWLIST_INSERT_BEFORE_CURRENT(tmp, list); 05139 break; 05140 } 05141 } 05142 AST_RWLIST_TRAVERSE_SAFE_END; 05143 if (!cur) 05144 AST_RWLIST_INSERT_TAIL(&apps, tmp, list); 05145 05146 ast_verb(2, "Registered application '%s'\n", term_color(tmps, tmp->name, COLOR_BRCYAN, 0, sizeof(tmps))); 05147 05148 AST_RWLIST_UNLOCK(&apps); 05149 05150 return 0; 05151 }
| int ast_unload_resource | ( | const char * | resource_name, | |
| enum | ast_module_unload_mode | |||
| ) |
Unload a module.
| resource_name | The name of the module to unload. | |
| ast_module_unload_mode | The force flag. This should be set using one of the AST_FORCE flags. |
This function unloads a module. It will only unload modules that are not in use (usecount not zero), unless AST_FORCE_FIRM or AST_FORCE_HARD is specified. Setting AST_FORCE_FIRM or AST_FORCE_HARD will unload the module regardless of consequences (NOT RECOMMENDED).
| 0 | on success. | |
| -1 | on error. |
Definition at line 482 of file loader.c.
References __ast_module_user_hangup_all(), AST_FORCE_FIRM, AST_LIST_LOCK, AST_LIST_UNLOCK, ast_log(), ast_update_use_count(), ast_module::declined, find_resource(), ast_module::flags, ast_module::info, ast_module::lib, LOG_WARNING, ast_module_info::restore_globals, ast_module::running, ast_module_info::unload, unload_dynamic_module(), and ast_module::usecount.
Referenced by exit_now(), handle_unload(), manager_moduleload(), reload(), and remove_module().
00483 { 00484 struct ast_module *mod; 00485 int res = -1; 00486 int error = 0; 00487 00488 AST_LIST_LOCK(&module_list); 00489 00490 if (!(mod = find_resource(resource_name, 0))) { 00491 AST_LIST_UNLOCK(&module_list); 00492 ast_log(LOG_WARNING, "Unload failed, '%s' could not be found\n", resource_name); 00493 return 0; 00494 } 00495 00496 if (!(mod->flags.running || mod->flags.declined)) 00497 error = 1; 00498 00499 if (!error && (mod->usecount > 0)) { 00500 if (force) 00501 ast_log(LOG_WARNING, "Warning: Forcing removal of module '%s' with use count %d\n", 00502 resource_name, mod->usecount); 00503 else { 00504 ast_log(LOG_WARNING, "Soft unload failed, '%s' has use count %d\n", resource_name, 00505 mod->usecount); 00506 error = 1; 00507 } 00508 } 00509 00510 if (!error) { 00511 __ast_module_user_hangup_all(mod); 00512 res = mod->info->unload(); 00513 00514 if (res) { 00515 ast_log(LOG_WARNING, "Firm unload failed for %s\n", resource_name); 00516 if (force <= AST_FORCE_FIRM) 00517 error = 1; 00518 else 00519 ast_log(LOG_WARNING, "** Dangerous **: Unloading resource anyway, at user request\n"); 00520 } 00521 } 00522 00523 if (!error) 00524 mod->flags.running = mod->flags.declined = 0; 00525 00526 AST_LIST_UNLOCK(&module_list); 00527 00528 if (!error && !mod->lib && mod->info && mod->info->restore_globals) 00529 mod->info->restore_globals(); 00530 00531 #ifdef LOADABLE_MODULES 00532 if (!error) 00533 unload_dynamic_module(mod); 00534 #endif 00535 00536 if (!error) 00537 ast_update_use_count(); 00538 00539 return res; 00540 }
| int ast_unregister_application | ( | const char * | app | ) |
Unregister an application.
| app | name of the application (does not have to be the same string as the one that was registered) |
This unregisters an application from Asterisk's internal application list.
| 0 | success | |
| -1 | failure |
Definition at line 6403 of file pbx.c.
References ast_free, AST_RWLIST_REMOVE_CURRENT, AST_RWLIST_TRAVERSE_SAFE_BEGIN, AST_RWLIST_TRAVERSE_SAFE_END, AST_RWLIST_UNLOCK, AST_RWLIST_WRLOCK, ast_string_field_free_memory, ast_verb, ast_app::name, and unreference_cached_app().
Referenced by __unload_module(), load_module(), and unload_module().
06404 { 06405 struct ast_app *tmp; 06406 06407 AST_RWLIST_WRLOCK(&apps); 06408 AST_RWLIST_TRAVERSE_SAFE_BEGIN(&apps, tmp, list) { 06409 if (!strcasecmp(app, tmp->name)) { 06410 unreference_cached_app(tmp); 06411 AST_RWLIST_REMOVE_CURRENT(list); 06412 ast_verb(2, "Unregistered application '%s'\n", tmp->name); 06413 ast_string_field_free_memory(tmp); 06414 ast_free(tmp); 06415 break; 06416 } 06417 } 06418 AST_RWLIST_TRAVERSE_SAFE_END; 06419 AST_RWLIST_UNLOCK(&apps); 06420 06421 return tmp ? 0 : -1; 06422 }
| int ast_update_module_list | ( | int(*)(const char *module, const char *description, int usecnt, const char *like) | modentry, | |
| const char * | like | |||
| ) |
Ask for a list of modules, descriptions, and use counts.
| modentry | A callback to an updater function. | |
| like | For each of the modules loaded, modentry will be executed with the resource, description, and usecount values of each particular module. |
Definition at line 1097 of file loader.c.
References AST_LIST_TRAVERSE, AST_LIST_TRYLOCK, AST_LIST_UNLOCK, ast_module_info::description, ast_module::info, ast_module::resource, and ast_module::usecount.
Referenced by ast_var_Modules(), handle_modlist(), and mod_update().
01099 { 01100 struct ast_module *cur; 01101 int unlock = -1; 01102 int total_mod_loaded = 0; 01103 01104 if (AST_LIST_TRYLOCK(&module_list)) 01105 unlock = 0; 01106 01107 AST_LIST_TRAVERSE(&module_list, cur, entry) { 01108 total_mod_loaded += modentry(cur->resource, cur->info->description, cur->usecount, like); 01109 } 01110 01111 if (unlock) 01112 AST_LIST_UNLOCK(&module_list); 01113 01114 return total_mod_loaded; 01115 }
| void ast_update_use_count | ( | void | ) |
Notify when usecount has been changed.
This function calulates use counts and notifies anyone trying to keep track of them. It should be called whenever your module's usecount changes.
Definition at line 1085 of file loader.c.
References AST_LIST_LOCK, AST_LIST_TRAVERSE, AST_LIST_UNLOCK, and loadupdate::updater.
Referenced by __ast_module_user_add(), __ast_module_user_hangup_all(), __ast_module_user_remove(), ast_module_ref(), ast_module_unref(), ast_unload_resource(), exit_now(), handle_request_do(), load_module(), oh323_request(), scheduler_process_request_queue(), sip_request_call(), start_resource(), and unistim_new().
01086 { 01087 /* Notify any module monitors that the use count for a 01088 resource has changed */ 01089 struct loadupdate *m; 01090 01091 AST_LIST_LOCK(&updaters); 01092 AST_LIST_TRAVERSE(&updaters, m, entry) 01093 m->updater(); 01094 AST_LIST_UNLOCK(&updaters); 01095 }
struct ast_module_info* ast_module_info [static] |
1.6.2