Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 9 Aug 2006 16:34:04 GMT
From:      Michael Bushkov <bushman@FreeBSD.org>
To:        Perforce Change Reviews <perforce@freebsd.org>
Subject:   PERFORCE change 103514 for review
Message-ID:  <200608091634.k79GY4Jv069467@repoman.freebsd.org>

next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=103514

Change 103514 by bushman@bushman_nss_ldap_cached on 2006/08/09 16:33:48

	Possible memory errors in usr.sbin/cached are now properly handled. No more asserts after mallocs, asprintfs, vasprintfs and strdups. Some minor memory error handling issues fixed.

Affected files ...

.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agent.c#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agent.h#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/group.c#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/hosts.c#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/net.c#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/passwd.c#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/proto.c#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/rpc.c#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/services.c#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cached.c#4 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cachedcli.c#2 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cachelib.c#2 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cacheplcs.c#2 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/config.c#2 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/config.h#2 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/hashtable.h#2 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/log.c#2 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/log.h#2 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/mp_rs_query.c#3 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/mp_ws_query.c#2 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/parser.c#2 edit
.. //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/query.c#3 edit

Differences ...

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agent.c#4 (text) ====

@@ -109,14 +109,17 @@
 
 	TRACE_IN(init_agent_table);
 	retval = (struct agent_table *)malloc(sizeof(struct agent_table));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(init_agent_table);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct agent_table));
 
 	TRACE_OUT(init_agent_table);
 	return (retval);
 }
 
-void
+int
 register_agent(struct agent_table *at, struct agent *a)
 {
 	struct agent **new_agents;
@@ -124,11 +127,20 @@
 
 	TRACE_IN(register_agent);
 	assert(at != NULL);
-	assert(a != NULL);
+
+	if (a == NULL) {
+		TRACE_OUT(register_agent);
+		return (-1);
+	}
+
 	new_agents_num = at->agents_num + 1;
 	new_agents = (struct agent **)malloc(sizeof(struct agent *) *
 		new_agents_num);
-	assert(new_agents != NULL);
+	if (new_agents == NULL) {
+		TRACE_OUT(register_agent);
+		return (-1);
+	}
+	
 	memcpy(new_agents, at->agents, at->agents_num * sizeof(struct agent *));
 	new_agents[new_agents_num - 1] = a;
 	qsort(new_agents, new_agents_num, sizeof(struct agent *),
@@ -138,6 +150,8 @@
 	at->agents = new_agents;
 	at->agents_num = new_agents_num;
     	TRACE_OUT(register_agent);
+	
+	return (0);
 }
 
 struct agent *

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agent.h#4 (text) ====

@@ -158,7 +158,7 @@
 extern int agent_marshal_results(char **, size_t *, agent_marshal_func, 
 	void *, void *, ...);
 extern struct agent_table *init_agent_table();
-extern void register_agent(struct agent_table *, struct agent *);
+extern int register_agent(struct agent_table *, struct agent *);
 extern struct agent *find_agent(struct agent_table *, const char *,
 	enum agent_type);
 extern void destroy_agent_table(struct agent_table *);

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/group.c#4 (text) ====

@@ -188,7 +188,10 @@
 	case nss_lt_name:
 		size = key_size - sizeof(enum nss_lookup_type)  + 1;
 		name = (char *)malloc(size);
-		assert(name != NULL);
+		if (name == NULL) {
+			TRACE_OUT(group_lookup_func);
+			return (NS_UNAVAIL);
+		}
 		memset(name, 0, size);
 		memcpy(name, key + sizeof(enum nss_lookup_type), size - 1);
                 break;
@@ -330,11 +333,18 @@
 
 	TRACE_IN(init_group_agent);
 	retval = (struct common_agent *)malloc(sizeof(struct common_agent));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(init_group_agent);
+		return (NULL);
+	}	
 	memset(retval, 0, sizeof(struct common_agent));
 
 	retval->parent.name = strdup("group");
-	assert(retval->parent.name != NULL);
+	if (retval->parent.name == NULL) {
+		free(retval);
+		TRACE_OUT(init_group_agent);
+		return (NULL);
+	}
 
 	retval->parent.type = COMMON_AGENT;
 	retval->lookup_func = group_lookup_func;
@@ -351,15 +361,22 @@
 	TRACE_IN(init_group_mp_agent);
 	retval = (struct multipart_agent *)malloc(
 		sizeof(struct multipart_agent));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(init_group_mp_agent);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct multipart_agent));
 
 	retval->parent.name = strdup("group");
+	if (retval->parent.name == NULL) {
+		free(retval);
+		TRACE_OUT(init_group_mp_agent);
+		return (NULL);
+	}
 	retval->parent.type = MULTIPART_AGENT;
 	retval->mp_init_func = group_mp_init_func;
 	retval->mp_lookup_func = group_mp_lookup_func;
-	retval->mp_destroy_func = group_mp_destroy_func;
-	assert(retval->parent.name != NULL);
+	retval->mp_destroy_func = group_mp_destroy_func;	
 
 	TRACE_OUT(init_group_mp_agent);
 	return ((struct agent *)retval);

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/hosts.c#3 (text+ko) ====

@@ -302,7 +302,10 @@
 		
 		size = key_size + 1;
 		str = (char *)malloc(size);
-		assert(str != NULL);
+		if (str == NULL) {
+			TRACE_OUT(hosts_lookup_func);
+			return (NS_UNAVAIL);
+		}
 		memset(str, 0, size);
 		memcpy(str, key, key_size);
 		
@@ -336,7 +339,10 @@
 		case nss_lt_name:					
 			size = key_size + 1;
 			str = (char *)malloc(size);
-			assert(str != NULL);
+			if (str == NULL) {
+				TRACE_OUT(hosts_lookup_func);
+				return (NS_UNAVAIL);
+			}
 			memset(str, 0, size);
 			memcpy(str, key, key_size);
 			break;
@@ -440,11 +446,18 @@
 
 	TRACE_IN(init_hosts_agent);
 	retval = (struct common_agent *)malloc(sizeof(struct common_agent));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(init_hosts_agent);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct common_agent));
 
 	retval->parent.name = strdup("hosts");
-	assert(retval->parent.name != NULL);
+	if (retval->parent.name == NULL) {
+		free(retval);
+		TRACE_OUT(init_hosts_agent);
+		return (NULL);
+	}
 
 	retval->parent.type = COMMON_AGENT;
 	retval->lookup_func = hosts_lookup_func;

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/net.c#3 (text+ko) ====

@@ -184,7 +184,10 @@
 	case nss_lt_name:
 		size = key_size - sizeof(enum nss_lookup_type)  + 1;
 		name = (char *)malloc(size);
-		assert(name != NULL);
+		if (name == NULL) {
+			TRACE_OUT(networks_lookup_func);
+			return (NS_UNAVAIL);
+		}
 		memset(name, 0, size);
 		memcpy(name, key + sizeof(enum nss_lookup_type), size - 1);
 		break;
@@ -274,11 +277,18 @@
 
 	TRACE_IN(init_networks_agent);
 	retval = (struct common_agent *)malloc(sizeof(struct common_agent));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(init_networks_agent);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct common_agent));
 
 	retval->parent.name = strdup("networks");
-	assert(retval->parent.name != NULL);
+	if (retval->parent.name == NULL) {
+		free(retval);
+		TRACE_OUT(init_networks_agent);
+		return (NULL);
+	}
 
 	retval->parent.type = COMMON_AGENT;
 	retval->lookup_func = networks_lookup_func;

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/passwd.c#4 (text) ====

@@ -187,7 +187,10 @@
 	case nss_lt_name:
 		size = key_size - sizeof(enum nss_lookup_type)  + 1;
 		login = (char *)malloc(size);
-		assert(login != NULL);
+		if (login == NULL) {
+			TRACE_OUT(passwd_lookup_func);
+			return (NS_UNAVAIL);
+		}
 		memset(login, 0, size);
 		memcpy(login, key + sizeof(enum nss_lookup_type), size - 1);
 		break;
@@ -329,11 +332,18 @@
 
 	TRACE_IN(init_passwd_agent);
 	retval = (struct common_agent *)malloc(sizeof(struct common_agent));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(init_passwd_agent);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct common_agent));
 
 	retval->parent.name = strdup("passwd");
-	assert(retval->parent.name != NULL);
+	if (retval->parent.name == NULL) {
+		free(retval);
+		TRACE_OUT(init_passwd_agent);
+		return (NULL);
+	}
 
 	retval->parent.type = COMMON_AGENT;
 	retval->lookup_func = passwd_lookup_func;
@@ -350,15 +360,22 @@
 	TRACE_IN(init_passwd_mp_agent);
 	retval = (struct multipart_agent *)malloc(
 		sizeof(struct multipart_agent));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(init_passwd_mp_agent);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct multipart_agent));
 
 	retval->parent.name = strdup("passwd");
+	if (retval->parent.name == NULL) {
+		free(retval);
+		TRACE_OUT(init_passwd_mp_agent);
+		return (NULL);
+	}
 	retval->parent.type = MULTIPART_AGENT;
 	retval->mp_init_func = passwd_mp_init_func;
 	retval->mp_lookup_func = passwd_mp_lookup_func;
-	retval->mp_destroy_func = passwd_mp_destroy_func;
-	assert(retval->parent.name != NULL);
+	retval->mp_destroy_func = passwd_mp_destroy_func;	
 
 	TRACE_OUT(init_passwd_mp_agent);
 	return ((struct agent *)retval);

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/proto.c#3 (text+ko) ====

@@ -180,7 +180,10 @@
 	case nss_lt_name:
 		size = key_size - sizeof(enum nss_lookup_type)  + 1;
 		name = (char *)malloc(size);
-		assert(name != NULL);
+		if (name == NULL) {
+			TRACE_OUT(protocols_lookup_func);
+			return (NS_UNAVAIL);
+		}
 		memset(name, 0, size);
 		memcpy(name, key + sizeof(enum nss_lookup_type), size - 1);
 		break;
@@ -326,11 +329,18 @@
 
 	TRACE_IN(init_protocols_agent);
 	retval = (struct common_agent *)malloc(sizeof(struct common_agent));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(init_protocols_agent);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct common_agent));
 
 	retval->parent.name = strdup("protocols");
-	assert(retval->parent.name != NULL);
+	if (retval->parent.name == NULL) {
+		free(retval);
+		TRACE_OUT(init_protocols_agent);
+		return (NULL);
+	}
 
 	retval->parent.type = COMMON_AGENT;
 	retval->lookup_func = protocols_lookup_func;
@@ -347,15 +357,22 @@
 	TRACE_IN(init_protocols_mp_agent);
 	retval = (struct multipart_agent *)malloc(
 		sizeof(struct multipart_agent));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(init_protocols_mp_agent);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct multipart_agent));
 
 	retval->parent.name = strdup("protocols");
+	if (retval->parent.name == NULL) {
+		free(retval);
+		TRACE_OUT(init_protocols_mp_agent);
+		return (NULL);
+	}
 	retval->parent.type = MULTIPART_AGENT;
 	retval->mp_init_func = protocols_mp_init_func;
 	retval->mp_lookup_func = protocols_mp_lookup_func;
-	retval->mp_destroy_func = protocols_mp_destroy_func;
-	assert(retval->parent.name != NULL);
+	retval->mp_destroy_func = protocols_mp_destroy_func;	
 
 	TRACE_OUT(init_protocols_mp_agent);
 	return ((struct agent *)retval);

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/rpc.c#3 (text+ko) ====

@@ -176,7 +176,10 @@
 	case nss_lt_name:
 		size = key_size - sizeof(enum nss_lookup_type)  + 1;
 		name = (char *)malloc(size);
-		assert(name != NULL);
+		if (name == NULL) {
+			TRACE_OUT(rpc_lookup_func);
+			return (NS_UNAVAIL);
+		}
 		memset(name, 0, size);
 		memcpy(name, key + sizeof(enum nss_lookup_type), size - 1);
 		break;
@@ -322,11 +325,18 @@
 
 	TRACE_IN(init_rpc_agent);
 	retval = (struct common_agent *)malloc(sizeof(struct common_agent));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(init_rpc_agent);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct common_agent));
 
 	retval->parent.name = strdup("rpc");
-	assert(retval->parent.name != NULL);
+	if (retval->parent.name == NULL) {
+		free(retval);
+		TRACE_OUT(init_rpc_agent);
+		return (NULL);
+	}
 
 	retval->parent.type = COMMON_AGENT;
 	retval->lookup_func = rpc_lookup_func;
@@ -343,15 +353,22 @@
 	TRACE_IN(init_rpc_mp_agent);
 	retval = (struct multipart_agent *)malloc(
 		sizeof(struct multipart_agent));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(init_rpc_mp_agent);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct multipart_agent));
 
 	retval->parent.name = strdup("rpc");
+	if (retval->parent.name == NULL) {
+		free(retval);
+		TRACE_OUT(init_rpc_mp_agent);
+		return (NULL);
+	}
 	retval->parent.type = MULTIPART_AGENT;
 	retval->mp_init_func = rpc_mp_init_func;
 	retval->mp_lookup_func = rpc_mp_lookup_func;
-	retval->mp_destroy_func = rpc_mp_destroy_func;
-	assert(retval->parent.name != NULL);
+	retval->mp_destroy_func = rpc_mp_destroy_func;	
 
 	TRACE_OUT(init_rpc_mp_agent);
 	return ((struct agent *)retval);

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/agents/services.c#4 (text) ====

@@ -185,7 +185,10 @@
 	switch (lookup_type) {
 		size = key_size - sizeof(enum nss_lookup_type);
 		name = (char *)malloc(size + 1);
-		assert(name != NULL);
+		if (name == NULL) {
+			result = NS_UNAVAIL;
+			goto fin;
+		}
 		memset(name, 0, size + 1);
 		memcpy(name, key + sizeof(enum nss_lookup_type), size);
 
@@ -209,7 +212,10 @@
 		size = key_size - sizeof(enum nss_lookup_type) - sizeof(int);
 		if (size > 0) {
 			proto = (char *)malloc(size + 1);
-			assert(proto != NULL);
+			if (proto == NULL) {
+				result = NS_UNAVAIL;
+				goto fin;
+			}
 			memset(proto, size + 1, 0);
 			memcpy(proto, key + sizeof(enum nss_lookup_type) +
 				sizeof(int), size);
@@ -347,11 +353,18 @@
 	TRACE_IN(init_services_agent);
 
 	retval = (struct common_agent *)malloc(sizeof(struct common_agent));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(init_services_agent);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct common_agent));
 
 	retval->parent.name = strdup("services");
-	assert(retval->parent.name != NULL);
+	if (retval->parent.name == NULL) {
+		free(retval);
+		TRACE_OUT(init_services_agent);
+		return (NULL);
+	}
 
 	retval->parent.type = COMMON_AGENT;
 	retval->lookup_func = services_lookup_func;
@@ -368,15 +381,22 @@
 	TRACE_IN(init_services_mp_agent);
 	retval = (struct multipart_agent *)malloc(
 		sizeof(struct multipart_agent));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(init_services_mp_agent);
+		return (NULL);
+	}		
 	memset(retval, 0, sizeof(struct multipart_agent));
 
 	retval->parent.name = strdup("services");
+	if (retval->parent.name == NULL) {
+		free(retval);
+		TRACE_OUT(init_services_mp_agent);
+		return (NULL);
+	}
 	retval->parent.type = MULTIPART_AGENT;
 	retval->mp_init_func = services_mp_init_func;
 	retval->mp_lookup_func = services_mp_lookup_func;
 	retval->mp_destroy_func = services_mp_destroy_func;
-	assert(retval->parent.name != NULL);
 
 	TRACE_OUT(init_services_mp_agent);
 	return ((struct agent *)retval);

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cached.c#4 (text) ====

@@ -135,6 +135,9 @@
 	    	 */
 		res = register_cache_entry(retval, (struct cache_entry_params *)
 			&config_entry->positive_cache_params);
+		if (res != 0)
+			break;
+		
 		config_entry->positive_cache_entry = find_cache_entry(retval,
 			config_entry->positive_cache_params.entry_name);
 		assert(config_entry->positive_cache_entry !=
@@ -142,6 +145,9 @@
 
 		res = register_cache_entry(retval, (struct cache_entry_params *)
 			&config_entry->negative_cache_params);
+		if (res != 0)
+			break;
+		
 		config_entry->negative_cache_entry = find_cache_entry(retval,
 			config_entry->negative_cache_params.entry_name);
 		assert(config_entry->negative_cache_entry !=
@@ -178,7 +184,10 @@
 
 	TRACE_IN(init_runtime_env);
 	retval = (struct runtime_env *)malloc(sizeof(struct runtime_env));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(init_runtime_env);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct runtime_env));
 
 	retval->sockfd = socket(PF_LOCAL, SOCK_STREAM, 0);
@@ -215,7 +224,12 @@
 	fcntl(retval->sockfd, F_SETFL, O_NONBLOCK);
 
 	retval->queue = kqueue();
-	assert(retval->queue != -1);
+	if (retval->queue == -1) {
+		close(retval->sockfd);
+		free(retval);
+		TRACE_OUT(init_runtime_env);
+		return (NULL);
+	}
 
 	EV_SET(&eventlist, retval->sockfd, EVFILT_READ, EV_ADD | EV_ONESHOT,
 		0, 0, 0);
@@ -424,7 +438,12 @@
 
 			qstate->io_buffer = (char *)malloc(
 				qstate->kevent_watermark);
-			assert(qstate->io_buffer != NULL);
+			if (qstate->io_buffer == NULL) {
+				destroy_query_state(qstate);
+				close(event_data->ident);
+				TRACE_OUT(process_socket_event);
+				return;
+			}
 			memset(qstate->io_buffer, 0, qstate->kevent_watermark);
 
 			qstate->io_buffer_p = qstate->io_buffer;
@@ -653,15 +672,25 @@
 		case 'i':
 			clear_user_cache_entries = 1;
 			if (optarg != NULL)
-				if (strcmp(optarg, "all") != 0)
+				if (strcmp(optarg, "all") != 0) {
 					user_config_entry_name = strdup(optarg);
+					if (user_config_entry_name == NULL) {
+					    LOG_ERR_1("main",
+						"not enough memory");
+					    return (-1);
+					}
+				}
 			break;
 		case 'I':
 			clear_all_cache_entries = 1;
 			if (optarg != NULL)
-				if (strcmp(optarg, "all") != 0)
-					global_config_entry_name =
-						strdup(optarg);
+			    if (strcmp(optarg, "all") != 0) {
+				global_config_entry_name = strdup(optarg);
+				if (global_config_entry_name == NULL) {
+				    LOG_ERR_1("main", "not enough memory");
+				    return (-1);
+				}
+			    }
 			break;
 		case 'd':
 			show_statistics = 1;
@@ -780,31 +809,42 @@
 	pidfile_write(pidfile);
 
 	s_agent_table = init_agent_table();
-	register_agent(s_agent_table, init_passwd_agent());
-	register_agent(s_agent_table, init_passwd_mp_agent());
-	register_agent(s_agent_table, init_group_agent());
-	register_agent(s_agent_table, init_group_mp_agent());
-	register_agent(s_agent_table, init_hosts_agent());
-	register_agent(s_agent_table, init_networks_agent());
-	register_agent(s_agent_table, init_services_agent());
-	register_agent(s_agent_table, init_services_mp_agent());
-	register_agent(s_agent_table, init_protocols_agent());
-	register_agent(s_agent_table, init_protocols_mp_agent());
-	register_agent(s_agent_table, init_rpc_agent());
-	register_agent(s_agent_table, init_rpc_mp_agent());
+	if (s_agent_table == NULL) {
+		LOG_ERR_1("main", "not enough memory");
+		return (-1);		
+	}
+	
+	res = register_agent(s_agent_table, init_passwd_agent());
+	res |= register_agent(s_agent_table, init_passwd_mp_agent());
+	res |= register_agent(s_agent_table, init_group_agent());
+	res |= register_agent(s_agent_table, init_group_mp_agent());
+	res |= register_agent(s_agent_table, init_hosts_agent());
+	res |= register_agent(s_agent_table, init_networks_agent());
+	res |= register_agent(s_agent_table, init_services_agent());
+	res |= register_agent(s_agent_table, init_services_mp_agent());
+	res |= register_agent(s_agent_table, init_protocols_agent());
+	res |= register_agent(s_agent_table, init_protocols_mp_agent());
+	res |= register_agent(s_agent_table, init_rpc_agent());
+	res |= register_agent(s_agent_table, init_rpc_mp_agent());
+	if (res != 0) {
+		LOG_ERR_1("main", "request agetns registration failed: "
+			"not enough memory");
+		return (-1);		
+	}
 	LOG_MSG_1("main", "request agents registered successfully");
 
-	/*
- 	 * Hosts agent can't work properly until we have access to the
-	 * appropriate dtab structures, which are used in nsdispatch
-	 * calls
-	 *
-	 register_agent(s_agent_table, init_hosts_agent());
-	*/
-
 	/* configuration initialization */
 	s_configuration = init_configuration();
-	fill_configuration_defaults(s_configuration);
+	if (s_configuration == NULL) {
+		LOG_ERR_1("main", "not enough memory");
+		return (-1);				
+	}
+	res = fill_configuration_defaults(s_configuration);
+	if (res != 0) {
+		LOG_ERR_1("main", "can't allocate configuration defaults");
+		destroy_configuration(s_configuration);
+		return (-1);
+	}
 
 	error_str = NULL;
 	error_line = 0;
@@ -854,11 +894,22 @@
 	if (s_configuration->threads_num > 1) {
 		threads = (pthread_t *)malloc(sizeof(pthread_t) *
 			s_configuration->threads_num);
+		if (threads == NULL) {
+			LOG_ERR_1("main", "can't allocate memory for threads");
+			destroy_configuration(s_configuration);
+			destroy_cache_(s_cache);
+			return (-1);			
+		}
 		memset(threads, 0, sizeof(pthread_t) *
 	    		s_configuration->threads_num);
 		for (i = 0; i < s_configuration->threads_num; ++i) {
 			thread_args = (struct processing_thread_args *)malloc(
 				sizeof(struct processing_thread_args));
+			if (thread_args == NULL) {
+				LOG_ERR_1("main", "can't allocate memory for"
+				    " thread args for thread #%d", i);
+				continue;
+			}
 			thread_args->the_cache = s_cache;
 			thread_args->the_runtime_env = s_runtime_env;
 			thread_args->the_configuration = s_configuration;
@@ -871,8 +922,10 @@
 			thread_args = NULL;
 		}
 
-		for (i = 0; i < s_configuration->threads_num; ++i)
-			pthread_join(threads[i], NULL);
+		for (i = 0; i < s_configuration->threads_num; ++i) {
+			if (threads[i] != NULL)
+				pthread_join(threads[i], NULL);
+		}
 	} else {
 		LOG_MSG_1("main", "working in single-threaded mode");
 		processing_loop(s_cache, s_runtime_env, s_configuration);

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cachedcli.c#2 (text) ====

@@ -202,20 +202,34 @@
 	fcntl(client_socket, F_SETFL, O_NONBLOCK);
 
 	retval = malloc(sizeof(struct cached_connection_));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(open_cached_connection);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct cached_connection_));
 
 	retval->sockfd = client_socket;
 
 	retval->write_queue = kqueue();
-	assert(retval->write_queue != -1);
+	if (retval->write_queue == -1) {
+		close(retval->sockfd);
+		free(retval);		
+		TRACE_OUT(open_cached_connection);
+		return (NULL);
+	}
 
 	EV_SET(&eventlist, retval->sockfd, EVFILT_WRITE, EV_ADD,
 		0, 0, NULL);
 	res = kevent(retval->write_queue, &eventlist, 1, NULL, 0, NULL);
 
 	retval->read_queue = kqueue();
-	assert(retval->read_queue != -1);
+	if (retval->read_queue != -1) {
+		close(retval->write_queue);
+		close(retval->sockfd);
+		free(retval);		
+		TRACE_OUT(open_cached_connection);
+		return (NULL);
+	}
 
 	EV_SET(&eventlist, retval->sockfd, EVFILT_READ, EV_ADD,
 		0, 0, NULL);

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cachelib.c#2 (text) ====

@@ -480,7 +480,10 @@
 	assert(params != NULL);
 
 	retval = (struct cache_ *)malloc(sizeof(struct cache_));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(init_cache);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct cache_));
 
 	assert(params != NULL);
@@ -488,7 +491,11 @@
 
 	retval->entries = (struct cache_entry_ **)malloc(
 		sizeof(struct cache_entry_ *) * INITIAL_ENTRIES_CAPACITY);
-	assert(retval->entries != NULL);
+	if (retval->entries == NULL) {
+		free(retval);
+		TRACE_OUT(init_cache);
+		return (NULL);
+	}
 	memset(retval->entries, 0, sizeof(sizeof(struct cache_entry_ *)
 		* INITIAL_ENTRIES_CAPACITY));
 
@@ -543,7 +550,10 @@
 			ENTRIES_CAPACITY_STEP;
 		new_entries = (struct cache_entry_ **)malloc(
 			sizeof(struct cache_entry_ *) * new_capacity);
-		assert(new_entries != NULL);
+		if (new_entries == NULL) {
+			TRACE_OUT(register_cache_entry);
+			return (-1);
+		}
 
 		memset(new_entries, 0, sizeof(struct cache_entry_ *) *
 		    new_capacity);
@@ -561,7 +571,10 @@
 	case CET_COMMON:
 		new_common_entry = (struct cache_common_entry_ *)malloc(
 			sizeof(struct cache_common_entry_));
-		assert(new_common_entry != NULL);
+		if (new_common_entry == NULL) {
+			TRACE_OUT(register_cache_entry);
+			return (-1);
+		}
 		memset(new_common_entry, 0, sizeof(struct cache_common_entry_));
 
 		memcpy(&new_common_entry->common_params, params,
@@ -570,8 +583,12 @@
 		  (struct cache_entry_params *)&new_common_entry->common_params;
 
 		new_common_entry->common_params.entry_name = (char *)malloc(
-			entry_name_size+1);
-		assert(new_common_entry->common_params.entry_name != NULL);
+			entry_name_size + 1);
+		if (new_common_entry->common_params.entry_name == NULL) {
+			free(new_common_entry);
+			TRACE_OUT(register_cache_entry);
+			return (-1);
+		}
 		memset(new_common_entry->common_params.entry_name, 0,
 			entry_name_size + 1);
 		strncpy(new_common_entry->common_params.entry_name,
@@ -582,6 +599,13 @@
 		HASHTABLE_INIT(&(new_common_entry->items),
 			struct cache_ht_item_data_, data,
 			new_common_entry->common_params.cache_entries_size);
+			
+		if (!HASHTABLE_OK(&(new_common_entry->items))) {
+			free(new_common_entry->common_params.entry_name);
+			free(new_common_entry);
+			TRACE_OUT(register_cache_entry);
+			return (-1);			
+		}
 
 		if (new_common_entry->common_params.policy == CPT_FIFO)
 			policies_size = 1;
@@ -590,27 +614,52 @@
 
 		new_common_entry->policies = (struct cache_policy_ **)malloc(
 			sizeof(struct cache_policy_ *) * policies_size);
-		assert(new_common_entry->policies != NULL);
+		if (new_common_entry->policies == NULL) {
+			HASHTABLE_DESTROY(&(new_common_entry->items), data);
+			free(new_common_entry->common_params.entry_name);
+			free(new_common_entry);
+			TRACE_OUT(register_cache_entry);
+			return (-1);				
+		}
 		memset(new_common_entry->policies, 0,
 			sizeof(struct cache_policy_ *) * policies_size);
 
 		new_common_entry->policies_size = policies_size;
 		new_common_entry->policies[0] = init_cache_fifo_policy();
 
-		if (policies_size > 1) {
+		if ((policies_size > 1) && 
+			(new_common_entry->policies[0] != NULL)) {
 			switch (new_common_entry->common_params.policy) {
 			case CPT_LRU:
 				new_common_entry->policies[1] =
 					init_cache_lru_policy();
+				if (new_common_entry->policies[1] == NULL) {
+					destroy_cache_fifo_policy(
+					    new_common_entry->policies[0]);
+					new_common_entry->policies[0] = NULL;
+				    }
 			break;
 			case CPT_LFU:
 				new_common_entry->policies[1] =
 					init_cache_lfu_policy();
+				if (new_common_entry->policies[1] == NULL) {
+					destroy_cache_fifo_policy(
+					    new_common_entry->policies[0]);
+					new_common_entry->policies[0] = NULL;
+				    }
 			break;
 			default:
 			break;
 			}
 		}
+		
+		if (new_common_entry->policies[0] == NULL) {
+			HASHTABLE_DESTROY(&(new_common_entry->items), data);
+			free(new_common_entry->common_params.entry_name);
+			free(new_common_entry);
+			TRACE_OUT(register_cache_entry);
+			return (-1);				
+		}
 
 		new_common_entry->get_time_func =
 			the_cache->params.get_time_func;
@@ -620,7 +669,10 @@
 	case CET_MULTIPART:
 		new_mp_entry = (struct cache_mp_entry_ *)malloc(
 			sizeof(struct cache_mp_entry_));
-		assert(new_mp_entry != NULL);
+		if (new_mp_entry == NULL) {
+			TRACE_OUT(register_cache_entry);
+			return (-1);
+		}
 		memset(new_mp_entry, 0, sizeof(struct cache_mp_entry_));
 
 		memcpy(&new_mp_entry->mp_params, params,
@@ -629,8 +681,12 @@
 			(struct cache_entry_params *)&new_mp_entry->mp_params;
 
 		new_mp_entry->mp_params.entry_name = (char *)malloc(
-			entry_name_size+1);
-		assert(new_mp_entry->mp_params.entry_name != NULL);
+			entry_name_size + 1);
+		if (new_mp_entry->mp_params.entry_name == NULL) {
+			free(new_mp_entry);
+			TRACE_OUT(register_cache_entry);
+			return (-1);
+		}
 		memset(new_mp_entry->mp_params.entry_name, 0,
 			entry_name_size + 1);
 		strncpy(new_mp_entry->mp_params.entry_name, params->entry_name,
@@ -844,15 +900,29 @@
 	}
 
 	item_data.key = (char *)malloc(key_size);
+	if (item_data.key == NULL) {
+		TRACE_OUT(cache_write);
+		return (-1);		
+	}
 	memcpy(item_data.key, key, key_size);
 
 	item_data.value = (char *)malloc(value_size);
-	assert(item_data.value != NULL);
+	if (item_data.value == NULL) {
+		free(item_data.key);
+		TRACE_OUT(cache_write);
+		return (-1);
+	}
 
 	memcpy(item_data.value, value, value_size);
 	item_data.value_size = value_size;
 
 	policy_item = common_entry->policies[0]->create_item_func();
+	if (policy_item == NULL) {
+		free(item_data.key);
+		free(item_data.value);
+		TRACE_OUT(cache_write);
+		return (-1);
+	}
 	policy_item->key = item_data.key;
 	policy_item->key_size = item_data.key_size;
 	common_entry->get_time_func(&policy_item->creation_time);
@@ -860,6 +930,14 @@
 	if (common_entry->policies_size > 1) {
 		connected_policy_item =
 			common_entry->policies[1]->create_item_func();
+		if (connected_policy_item == NULL) {
+			common_entry->policies[0]->destroy_item_func(
+				policy_item);
+			free(item_data.key);
+			free(item_data.value);
+			TRACE_OUT(cache_write);
+			return (-1);		
+		}
 		memcpy(&connected_policy_item->creation_time,
 			&policy_item->creation_time,
 			sizeof(struct timeval));
@@ -927,7 +1005,10 @@
 
 	retval = (struct cache_mp_write_session_ *)malloc(
 		sizeof(struct cache_mp_write_session_));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(open_cache_mp_write_session);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct cache_mp_write_session_));
 
 	TAILQ_INIT(&retval->items);
@@ -963,11 +1044,18 @@
 
 	new_item = (struct cache_mp_data_item_ *)malloc(
 		sizeof(struct cache_mp_data_item_));
-	assert(new_item != NULL);
+	if (new_item == NULL) {
+		TRACE_OUT(cache_mp_write);
+		return (-1);
+	}
 	memset(new_item, 0, sizeof(struct cache_mp_data_item_));
 
 	new_item->value = (char *)malloc(data_size);
-	assert(new_item->value != NULL);
+	if (new_item->value == NULL) {
+		free(new_item);
+		TRACE_OUT(cache_mp_write);
+		return (-1);
+	}
 	memcpy(new_item->value, data, data_size);
 	new_item->value_size = data_size;
 
@@ -1067,7 +1155,10 @@
 
 	retval = (struct cache_mp_read_session_ *)malloc(
 		sizeof(struct cache_mp_read_session_));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(open_cache_mp_read_session);
+		return (NULL);
+	}
 	memset(retval, 0, sizeof(struct cache_mp_read_session_));
 
 	retval->parent_entry = mp_entry;

==== //depot/projects/soc2006/nss_ldap_cached/src/usr.sbin/cached/cacheplcs.c#2 (text) ====

@@ -84,7 +84,10 @@
 	TRACE_IN(cache_queue_policy_create_item);
 	retval = (struct cache_queue_policy_item_ *)malloc(
 		sizeof(struct cache_queue_policy_item_));
-	assert(retval != NULL);
+	if (retval == NULL) {
+		TRACE_OUT(cache_queue_policy_create_item);

>>> TRUNCATED FOR MAIL (1000 lines) <<<



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200608091634.k79GY4Jv069467>