[svn-commits] mmichelson: branch group/CCSS r215885 - /team/group/CCSS/main/ccss.c

SVN commits to the Digium repositories svn-commits at lists.digium.com
Thu Sep 3 07:13:50 CDT 2009


Author: mmichelson
Date: Thu Sep  3 07:13:47 2009
New Revision: 215885

URL: http://svn.asterisk.org/svn-view/asterisk?view=rev&rev=215885
Log:
Remove more comments, fix refcount bugs.

Modified:
    team/group/CCSS/main/ccss.c

Modified: team/group/CCSS/main/ccss.c
URL: http://svn.asterisk.org/svn-view/asterisk/team/group/CCSS/main/ccss.c?view=diff&rev=215885&r1=215884&r2=215885
==============================================================================
--- team/group/CCSS/main/ccss.c (original)
+++ team/group/CCSS/main/ccss.c Thu Sep  3 07:13:47 2009
@@ -834,9 +834,6 @@
 
 static struct ast_cc_monitor *find_or_create_monitor(struct ast_cc_monitor *parent, struct ast_cc_interface *interface, const int core_id)
 {
-	/* I'll leave the finding part for later. For now, I'll place the
-	 * creation code here
-	 */
 	struct ast_cc_monitor *new_monitor;
 	struct ast_cc_monitor_link *new_link;
 	struct ast_cc_monitor *finder = alloca(sizeof(finder) + strlen(interface->name));
@@ -853,9 +850,8 @@
 	}
 
 	if (!(new_link = ast_calloc(1, sizeof(*new_link)))) {
-		if (monitor_created) {
-			ao2_ref(new_monitor, -1);
-		}
+		ao2_ref(new_monitor, -1);
+		ao2_unlink(cc_monitors, new_monitor);
 		return NULL;
 	}
 
@@ -867,33 +863,12 @@
 	ao2_ref(new_link->parent, +1);
 	AST_LIST_INSERT_TAIL(&parent->child_links, new_link, next);
 	AST_LIST_INSERT_TAIL(&new_monitor->parent_links, new_link, next);
+	ao2_ref(new_monitor, -1);
 	return new_monitor;
 }
 
 static void interface_tree_to_monitor(struct core_pending_cc_offer *pending_offer, struct cc_core_instance *core_instance)
 {
-	/* Oh boy
-	 *
-	 * Steps
-	 *
-	 * 1. Give the core_instance a reference to the root monitor.
-	 *
-	 * 2. Loop through the pending_offer's interface tree.
-	 * 
-	 * 3. For each interface encountered, see if there is
-	 * already a monitor for that interface set up.
-	 *
-	 * 		3a. If there is, create a new link from whatever
-	 * 		the appropriate parent is to the pre-existing monitor
-	 *
-	 * 		3b. If not, then create the new monitor, create a
-	 * 		link from the appropriate parent to a newly created
-	 * 		monitor.
-	 *
-	 * 4. unref the pending_offer's ref to the interface tree. This
-	 * SHOULD cause the interface_tree's destructor to be called.
-	 */
-
 	struct ast_cc_interface *parent_interface_iterator;
 
 	/* The way that the interface tree is set up, and the way this loop works, the
@@ -1241,6 +1216,7 @@
 	if (!(cc_sched_thread = ast_sched_thread_create())) {
 		return -1;
 	}
+	ast_log(LOG_NOTICE, "Successfully created CC sched_thread context\n");
 	/* Root monitor doesn't care about the core id. The root monitor uses
 	 * extension monitor callbacks since the gist of those will be to traverse
 	 * their child links and call each of their children's callbacks
@@ -1248,7 +1224,8 @@
 	if (!(root_monitor = cc_monitor_instance_init(AST_CC_ROOT_MONITOR, "extension", "root", -1))) {
 		return -1;
 	}
-	ast_log(LOG_NOTICE, "Successfully created CC sched_thread context\n");
+	ao2_ref(root_monitor, -1);
+	ast_log(LOG_NOTICE, "Successfully created root monitor\n");
 	res = ast_register_application2(ccreq_app, ccreq_exec, NULL, NULL, NULL);
 	res |= ast_register_application2(cccancel_app, cccancel_exec, NULL, NULL, NULL);
 	res |= ast_cc_monitor_register(&extension_monitor_cbs);




More information about the svn-commits mailing list