diff --git a/src/include/switch_types.h b/src/include/switch_types.h index b48ec2ed0d..ed737e77fc 100644 --- a/src/include/switch_types.h +++ b/src/include/switch_types.h @@ -1008,7 +1008,8 @@ typedef enum { SCSC_HUPALL, SCSC_SHUTDOWN, SCSC_CHECK_RUNNING, - SCSC_LOGLEVEL + SCSC_LOGLEVEL, + SCSC_SPS } switch_session_ctl_t; typedef struct apr_pool_t switch_memory_pool_t; diff --git a/src/mod/applications/mod_commands/mod_commands.c b/src/mod/applications/mod_commands/mod_commands.c index ba1e1ffc79..106e28e64a 100644 --- a/src/mod/applications/mod_commands/mod_commands.c +++ b/src/mod/applications/mod_commands/mod_commands.c @@ -127,7 +127,15 @@ SWITCH_STANDARD_API(ctl_function) arg = -1; } switch_core_session_ctl(SCSC_LOGLEVEL, &arg); - stream->write_function(stream, "log level %s [%d]\n", switch_log_level2str(arg), arg); + stream->write_function(stream, "log level: %s [%d]\n", switch_log_level2str(arg), arg); + } else if (!strcasecmp(argv[0], "sps")) { + if (argc > 1) { + arg = atoi(argv[1]); + } else { + arg = 0; + } + switch_core_session_ctl(SCSC_SPS, &arg); + stream->write_function(stream, "sessions per second: %d\n", arg); } else { stream->write_function(stream, "INVALID COMMAND\nUSAGE: fsctl [hupall|pause|resume|shutdown]\n"); goto end; diff --git a/src/switch_core.c b/src/switch_core.c index 7962cebe86..693c01cb28 100644 --- a/src/switch_core.c +++ b/src/switch_core.c @@ -648,16 +648,22 @@ SWITCH_DECLARE(int32_t) switch_core_session_ctl(switch_session_ctl_t cmd, int32_ break; case SCSC_LOGLEVEL: if (*val > -1) { - printf("WTF %d\n", *val); runtime.hard_log_level = *val; } if (runtime.hard_log_level > SWITCH_LOG_CONSOLE) { - printf("WTF %d\n", *val); runtime.hard_log_level = SWITCH_LOG_CONSOLE; } *val = runtime.hard_log_level; break; + case SCSC_SPS: + switch_mutex_lock(runtime.throttle_mutex); + if (*val > 0) { + runtime.sps_total = *val; + } + *val = runtime.sps_total; + switch_mutex_unlock(runtime.throttle_mutex); + break; } return 0;