Răsfoiți Sursa

Merge trunk revision 2835:
r2835 | asalkeld | 2010-05-16 14:29:30 -0700 (Sun, 16 May 2010) | 2 lines

cov 10371: check return of lcr_ifact_reference



git-svn-id: http://svn.fedorahosted.org/svn/corosync/branches/flatiron@2877 fd59a12c-fef9-0310-b244-a6a79926bd2f

Steven Dake 15 ani în urmă
părinte
comite
2cdb067b13
1 a modificat fișierele cu 3 adăugiri și 3 ștergeri
  1. 3 3
      exec/service.c

+ 3 - 3
exec/service.c

@@ -160,7 +160,7 @@ unsigned int corosync_service_link_and_init (
 	void *iface_ver0_p;
 	void *iface_ver0_p;
 	hdb_handle_t handle;
 	hdb_handle_t handle;
 	struct corosync_service_engine *service;
 	struct corosync_service_engine *service;
-	unsigned int res;
+	int res;
 	hdb_handle_t object_service_handle;
 	hdb_handle_t object_service_handle;
 	hdb_handle_t object_stats_handle;
 	hdb_handle_t object_stats_handle;
 	int fn;
 	int fn;
@@ -172,7 +172,7 @@ unsigned int corosync_service_link_and_init (
 	 * reference the service interface
 	 * reference the service interface
 	 */
 	 */
 	iface_ver0_p = NULL;
 	iface_ver0_p = NULL;
-	lcr_ifact_reference (
+	res = lcr_ifact_reference (
 		&handle,
 		&handle,
 		service_name,
 		service_name,
 		service_ver,
 		service_ver,
@@ -181,7 +181,7 @@ unsigned int corosync_service_link_and_init (
 
 
 	iface_ver0 = (struct corosync_service_engine_iface_ver0 *)iface_ver0_p;
 	iface_ver0 = (struct corosync_service_engine_iface_ver0 *)iface_ver0_p;
 
 
-	if (iface_ver0 == 0) {
+	if (res == -1 || iface_ver0 == 0) {
 		log_printf(LOGSYS_LEVEL_ERROR, "Service failed to load '%s'.\n", service_name);
 		log_printf(LOGSYS_LEVEL_ERROR, "Service failed to load '%s'.\n", service_name);
 		return (-1);
 		return (-1);
 	}
 	}