diff options
Diffstat (limited to 'usr/src/cmd/svc/startd')
| -rw-r--r-- | usr/src/cmd/svc/startd/method.c | 25 | ||||
| -rw-r--r-- | usr/src/cmd/svc/startd/restarter.c | 40 | ||||
| -rw-r--r-- | usr/src/cmd/svc/startd/startd.c | 15 | 
3 files changed, 63 insertions, 17 deletions
| diff --git a/usr/src/cmd/svc/startd/method.c b/usr/src/cmd/svc/startd/method.c index ddc0e5e844..076003e6c6 100644 --- a/usr/src/cmd/svc/startd/method.c +++ b/usr/src/cmd/svc/startd/method.c @@ -21,11 +21,7 @@  /*   * Copyright (c) 2004, 2010, Oracle and/or its affiliates. All rights reserved. - * Copyright 2011 Joyent Inc. - */ - -/* - * Copyright 2011 Joyent Inc. + * Copyright 2012 Joyent, Inc. All rights reserved.   */  /* @@ -933,7 +929,8 @@ method_run(restarter_inst_t **instp, int type, int *exit_code)  			goto contract_out;  		} -		if (!WIFEXITED(ret_status)) { +		if (!WIFEXITED(ret_status) && +		    WEXITSTATUS(ret_status) != SMF_EXIT_NODAEMON) {  			/*  			 * If method didn't exit itself (it was killed by an  			 * external entity, etc.), consider the entire @@ -962,7 +959,7 @@ method_run(restarter_inst_t **instp, int type, int *exit_code)  		}  		*exit_code = WEXITSTATUS(ret_status); -		if (*exit_code != 0) { +		if (*exit_code != 0 && *exit_code != SMF_EXIT_NODAEMON) {  			log_error(LOG_WARNING,  			    "%s: Method \"%s\" failed with exit status %d.\n",  			    inst->ri_i.i_fmri, method, WEXITSTATUS(ret_status)); @@ -971,6 +968,7 @@ method_run(restarter_inst_t **instp, int type, int *exit_code)  		log_instance(inst, B_TRUE, "Method \"%s\" exited with status "  		    "%d.", mname, *exit_code); +		/* Note: we will take this path for SMF_EXIT_NODAEMON */  		if (*exit_code != 0)  			goto contract_out; @@ -1017,7 +1015,10 @@ assured_kill:  	}  contract_out: -	/* Abandon contracts for transient methods & methods that fail. */ +	/* +	 * Abandon contracts for transient methods, methods that exit with +	 * SMF_EXIT_NODAEMON & methods that fail. +	 */  	transient = method_is_transient(inst, type);  	if ((transient || *exit_code != 0 || result != 0) &&  	    (restarter_is_kill_method(method) < 0)) @@ -1113,7 +1114,7 @@ retry:  	r = method_run(&inst, info->sf_method_type, &exit_code); -	if (r == 0 && exit_code == 0) { +	if (r == 0 && (exit_code == 0 || exit_code == SMF_EXIT_NODAEMON)) {  		/* Success! */  		assert(inst->ri_i.i_next_state != RESTARTER_STATE_NONE); @@ -1131,6 +1132,12 @@ retry:  			else  				method_remove_contract(inst, B_TRUE, B_TRUE);  		} + +		/* +		 * For methods that exit with SMF_EXIT_NODAEMON, we already +		 * called method_remove_contract in method_run. +		 */ +  		/*  		 * We don't care whether the handle was rebound because this is  		 * the last thing we do with it. diff --git a/usr/src/cmd/svc/startd/restarter.c b/usr/src/cmd/svc/startd/restarter.c index a088592d14..a55fb489ad 100644 --- a/usr/src/cmd/svc/startd/restarter.c +++ b/usr/src/cmd/svc/startd/restarter.c @@ -373,9 +373,11 @@ rep_retry:  	if (inst->ri_logstem != NULL)  		startd_free(inst->ri_logstem, PATH_MAX);  	if (inst->ri_common_name != NULL) -		startd_free(inst->ri_common_name, max_scf_value_size); +		startd_free(inst->ri_common_name, +		    strlen(inst->ri_common_name) + 1);  	if (inst->ri_C_common_name != NULL) -		startd_free(inst->ri_C_common_name, max_scf_value_size); +		startd_free(inst->ri_C_common_name, +		    strlen(inst->ri_C_common_name) + 1);  	snap = NULL;  	inst->ri_logstem = NULL;  	inst->ri_common_name = NULL; @@ -529,8 +531,25 @@ rep_retry:  		abort();  	} -	switch (libscf_get_template_values(scf_inst, snap, -	    &inst->ri_common_name, &inst->ri_C_common_name)) { +	r = libscf_get_template_values(scf_inst, snap, +	    &inst->ri_common_name, &inst->ri_C_common_name); + +	/* +	 * Copy our names to smaller buffers to reduce our memory footprint. +	 */ +	if (inst->ri_common_name != NULL) { +		char *tmp = safe_strdup(inst->ri_common_name); +		startd_free(inst->ri_common_name, max_scf_value_size); +		inst->ri_common_name = tmp; +	} + +	if (inst->ri_C_common_name != NULL) { +		char *tmp = safe_strdup(inst->ri_C_common_name); +		startd_free(inst->ri_C_common_name, max_scf_value_size); +		inst->ri_C_common_name = tmp; +	} + +	switch (r) {  	case 0:  		break; @@ -678,9 +697,11 @@ deleted:  	if (inst->ri_logstem != NULL)  		startd_free(inst->ri_logstem, PATH_MAX);  	if (inst->ri_common_name != NULL) -		startd_free(inst->ri_common_name, max_scf_value_size); +		startd_free(inst->ri_common_name, +		    strlen(inst->ri_common_name) + 1);  	if (inst->ri_C_common_name != NULL) -		startd_free(inst->ri_C_common_name, max_scf_value_size); +		startd_free(inst->ri_C_common_name, +		    strlen(inst->ri_C_common_name) + 1);  	startd_free(inst->ri_utmpx_prefix, max_scf_value_size);  	startd_free(inst, sizeof (restarter_inst_t));  	return (ENOENT); @@ -740,9 +761,11 @@ restarter_delete_inst(restarter_inst_t *ri)  	startd_free((void *)ri->ri_i.i_fmri, strlen(ri->ri_i.i_fmri) + 1);  	startd_free(ri->ri_logstem, PATH_MAX);  	if (ri->ri_common_name != NULL) -		startd_free(ri->ri_common_name, max_scf_value_size); +		startd_free(ri->ri_common_name, +		    strlen(ri->ri_common_name) + 1);  	if (ri->ri_C_common_name != NULL) -		startd_free(ri->ri_C_common_name, max_scf_value_size); +		startd_free(ri->ri_C_common_name, +		    strlen(ri->ri_C_common_name) + 1);  	startd_free(ri->ri_utmpx_prefix, max_scf_value_size);  	(void) pthread_mutex_destroy(&ri->ri_lock);  	(void) pthread_mutex_destroy(&ri->ri_queue_lock); @@ -1841,6 +1864,7 @@ cont:  	rip->ri_queue_thread = 0;  	MUTEX_UNLOCK(&rip->ri_queue_lock); +  out:  	(void) scf_handle_unbind(h);  	scf_handle_destroy(h); diff --git a/usr/src/cmd/svc/startd/startd.c b/usr/src/cmd/svc/startd/startd.c index f0c57d37eb..14180c5f54 100644 --- a/usr/src/cmd/svc/startd/startd.c +++ b/usr/src/cmd/svc/startd/startd.c @@ -21,6 +21,7 @@  /*   * Copyright (c) 2004, 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, Joyent, Inc. All rights reserved.   */  /* @@ -143,6 +144,7 @@ static uint8_t prop_reconfig = 0;  pthread_mutexattr_t mutex_attrs; +#ifdef DEBUG  const char *  _umem_debug_init(void)  { @@ -154,6 +156,19 @@ _umem_logging_init(void)  {  	return ("fail,contents");	/* UMEM_LOGGING setting */  } +#endif + +const char * +_umem_options_init(void) +{ +	/* +	 * To reduce our memory footprint, we set our UMEM_OPTIONS to indicate +	 * that we do not wish to have per-CPU magazines -- if svc.startd is so +	 * hot on CPU such that this becomes a scalability problem, there are +	 * likely deeper things amiss... +	 */ +	return ("nomagazines");		/* UMEM_OPTIONS setting */ +}  /*   * startd_alloc_retry() | 
