Merged revisions 151905 via svnmerge from
[asterisk/asterisk.git] / main / asterisk.c
index 782d697..7da70c2 100644 (file)
@@ -3342,11 +3342,6 @@ int main(int argc, char *argv[])
 
        ast_channels_init();
 
-       if (init_manager()) {
-               printf("%s", term_quit());
-               exit(1);
-       }
-
        if (ast_cdr_engine_init()) {
                printf("%s", term_quit());
                exit(1);
@@ -3398,6 +3393,15 @@ int main(int argc, char *argv[])
                exit(1);
        }
 
+       /* AMI is initialized after loading modules because of a potential
+        * conflict between issuing a module reload from manager and
+        * registering manager actions.  This will cause reversed locking
+        * order between the module list and manager actions list. */
+       if (init_manager()) {
+               printf("%s", term_quit());
+               exit(1);
+       }
+
        dnsmgr_start_refresh();
 
        /* We might have the option of showing a console, but for now just