startup/shutdown: cleanup and unify with unix mode

pull/2524/head
Victor Julien 9 years ago
parent 3c64cfb384
commit babe8a299e

@ -299,44 +299,13 @@ TmEcode UnixSocketPcapFilesCheck(void *data)
} }
this->currentfile = NULL; this->currentfile = NULL;
/* needed by FlowForceReassembly */ PostRunDeinit(RUNMODE_PCAP_FILE, NULL /* no ts */);
PacketPoolInit(); }
if (TAILQ_EMPTY(&this->files)) {
/* handle graceful shutdown of the flow engine, it's helper // nothing to do
* threads and the packet threads */ return TM_ECODE_OK;
FlowDisableFlowManagerThread();
TmThreadDisableReceiveThreads();
FlowForceReassembly();
TmThreadDisablePacketThreads();
FlowDisableFlowRecyclerThread();
/* kill the stats threads */
TmThreadKillThreadsFamily(TVT_MGMT);
TmThreadClearThreadsFamily(TVT_MGMT);
/* kill packet threads -- already in 'disabled' state */
TmThreadKillThreadsFamily(TVT_PPT);
TmThreadClearThreadsFamily(TVT_PPT);
PacketPoolDestroy();
/* mgt and ppt threads killed, we can run non thread-safe
* shutdown functions */
StatsReleaseResources();
RunModeShutDown();
FlowShutdown();
IPPairShutdown();
HostCleanup();
StreamTcpFreeConfig(STREAM_VERBOSE);
DefragDestroy();
TmqResetQueues();
#ifdef PROFILING
if (profiling_rules_enabled)
SCProfilingDump();
SCProfilingDestroy();
#endif
} }
if (!TAILQ_EMPTY(&this->files)) {
PcapFiles *cfile = TAILQ_FIRST(&this->files); PcapFiles *cfile = TAILQ_FIRST(&this->files);
TAILQ_REMOVE(&this->files, cfile, next); TAILQ_REMOVE(&this->files, cfile, next);
SCLogInfo("Starting run for '%s'", cfile->filename); SCLogInfo("Starting run for '%s'", cfile->filename);
@ -374,27 +343,13 @@ TmEcode UnixSocketPcapFilesCheck(void *data)
return TM_ECODE_FAILED; return TM_ECODE_FAILED;
} }
PcapFilesFree(cfile); PcapFilesFree(cfile);
StatsInit();
#ifdef PROFILING PreRunInit(RUNMODE_PCAP_FILE);
SCProfilingRulesGlobalInit(); PreRunPostPrivsDropInit(RUNMODE_PCAP_FILE);
SCProfilingKeywordsGlobalInit();
SCProfilingSghsGlobalInit();
SCProfilingInit();
#endif /* PROFILING */
DefragInit();
FlowInitConfig(FLOW_QUIET);
IPPairInitConfig(FLOW_QUIET);
StreamTcpInitConfig(STREAM_VERBOSE);
AppLayerRegisterGlobalCounters();
RunModeInitializeOutputs();
StatsSetupPostConfig();
RunModeDispatch(RUNMODE_PCAP_FILE, NULL); RunModeDispatch(RUNMODE_PCAP_FILE, NULL);
FlowManagerThreadSpawn();
FlowRecyclerThreadSpawn();
StatsSpawnThreads();
/* Un-pause all the paused threads */ /* Un-pause all the paused threads */
TmThreadContinueThreads(); TmThreadContinueThreads();
}
return TM_ECODE_OK; return TM_ECODE_OK;
} }
#endif #endif

@ -50,6 +50,8 @@
#include "source-pfring.h" #include "source-pfring.h"
#include "tmqh-flow.h" #include "tmqh-flow.h"
#include "flow-manager.h"
#include "counters.h"
#ifdef __SC_CUDA_SUPPORT__ #ifdef __SC_CUDA_SUPPORT__
#include "util-cuda-buffer.h" #include "util-cuda-buffer.h"
@ -392,7 +394,12 @@ void RunModeDispatch(int runmode, const char *custom_mode)
/* Check if the alloted queues have at least 1 reader and writer */ /* Check if the alloted queues have at least 1 reader and writer */
TmValidateQueueState(); TmValidateQueueState();
return; if (runmode != RUNMODE_UNIX_SOCKET) {
/* spawn management threads */
FlowManagerThreadSpawn();
FlowRecyclerThreadSpawn();
StatsSpawnThreads();
}
} }
/** /**

@ -211,7 +211,7 @@ intmax_t max_pending_packets;
int g_detect_disabled = 0; int g_detect_disabled = 0;
/** set caps or not */ /** set caps or not */
int sc_set_caps; int sc_set_caps = FALSE;
int EngineModeIsIPS(void) int EngineModeIsIPS(void)
{ {
@ -314,6 +314,12 @@ void CreateLowercaseTable()
void GlobalInits() void GlobalInits()
{ {
#ifdef __SC_CUDA_SUPPORT__
/* Init the CUDA environment */
SCCudaInitCudaEnvironment();
CudaBufferInit();
#endif
memset(trans_q, 0, sizeof(trans_q)); memset(trans_q, 0, sizeof(trans_q));
memset(data_queues, 0, sizeof(data_queues)); memset(data_queues, 0, sizeof(data_queues));
@ -334,6 +340,9 @@ void GlobalInits()
} }
CreateLowercaseTable(); CreateLowercaseTable();
TimeInit();
SupportFastPatternForSigMatchTypes();
} }
/** \brief make sure threads can stop the engine by calling this /** \brief make sure threads can stop the engine by calling this
@ -1022,13 +1031,15 @@ static void SCSetStartTime(SCInstance *suri)
gettimeofday(&suri->start_time, NULL); gettimeofday(&suri->start_time, NULL);
} }
static void SCPrintElapsedTime(SCInstance *suri) static void SCPrintElapsedTime(struct timeval *start_time)
{ {
if (start_time == NULL)
return;
struct timeval end_time; struct timeval end_time;
memset(&end_time, 0, sizeof(end_time)); memset(&end_time, 0, sizeof(end_time));
gettimeofday(&end_time, NULL); gettimeofday(&end_time, NULL);
uint64_t milliseconds = ((end_time.tv_sec - suri->start_time.tv_sec) * 1000) + uint64_t milliseconds = ((end_time.tv_sec - start_time->tv_sec) * 1000) +
(((1000000 + end_time.tv_usec - suri->start_time.tv_usec) / 1000) - 1000); (((1000000 + end_time.tv_usec - start_time->tv_usec) / 1000) - 1000);
SCLogInfo("time elapsed %.3fs", (float)milliseconds/(float)1000); SCLogInfo("time elapsed %.3fs", (float)milliseconds/(float)1000);
} }
@ -2032,6 +2043,89 @@ static int InitSignalHandler(SCInstance *suri)
return TM_ECODE_OK; return TM_ECODE_OK;
} }
/* initialization code for both the main modes and for
* unix socket mode.
*
* Will be run once per pcap in unix-socket mode */
void PreRunInit(const int runmode)
{
if (runmode == RUNMODE_UNIX_SOCKET)
return;
StatsInit();
#ifdef PROFILING
SCProfilingRulesGlobalInit();
SCProfilingKeywordsGlobalInit();
SCProfilingSghsGlobalInit();
SCProfilingInit();
#endif /* PROFILING */
DefragInit();
FlowInitConfig(FLOW_QUIET);
IPPairInitConfig(FLOW_QUIET);
StreamTcpInitConfig(STREAM_VERBOSE);
AppLayerRegisterGlobalCounters();
}
/* tasks we need to run before packets start flowing,
* but after we dropped privs */
void PreRunPostPrivsDropInit(const int runmode)
{
if (runmode == RUNMODE_UNIX_SOCKET)
return;
RunModeInitializeOutputs();
StatsSetupPostConfig();
}
/* clean up / shutdown code for both the main modes and for
* unix socket mode.
*
* Will be run once per pcap in unix-socket mode */
void PostRunDeinit(const int runmode, struct timeval *start_time)
{
if (runmode == RUNMODE_UNIX_SOCKET)
return;
/* needed by FlowForceReassembly */
PacketPoolInit();
/* handle graceful shutdown of the flow engine, it's helper
* threads and the packet threads */
FlowDisableFlowManagerThread();
TmThreadDisableReceiveThreads();
FlowForceReassembly();
TmThreadDisablePacketThreads();
SCPrintElapsedTime(start_time);
FlowDisableFlowRecyclerThread();
/* kill the stats threads */
TmThreadKillThreadsFamily(TVT_MGMT);
TmThreadClearThreadsFamily(TVT_MGMT);
/* kill packet threads -- already in 'disabled' state */
TmThreadKillThreadsFamily(TVT_PPT);
TmThreadClearThreadsFamily(TVT_PPT);
PacketPoolDestroy();
/* mgt and ppt threads killed, we can run non thread-safe
* shutdown functions */
StatsReleaseResources();
RunModeShutDown();
FlowShutdown();
IPPairShutdown();
HostCleanup();
StreamTcpFreeConfig(STREAM_VERBOSE);
DefragDestroy();
TmqResetQueues();
#ifdef PROFILING
if (profiling_rules_enabled)
SCProfilingDump();
SCProfilingDestroy();
#endif
}
int StartInternalRunMode(SCInstance *suri, int argc, char **argv) int StartInternalRunMode(SCInstance *suri, int argc, char **argv)
{ {
/* Treat internal running mode */ /* Treat internal running mode */
@ -2319,9 +2413,6 @@ static int PostConfLoadedSetup(SCInstance *suri)
/* Load the Host-OS lookup. */ /* Load the Host-OS lookup. */
SCHInfoLoadFromConfig(); SCHInfoLoadFromConfig();
if (suri->run_mode != RUNMODE_UNIX_SOCKET) {
DefragInit();
}
if (suri->run_mode == RUNMODE_ENGINE_ANALYSIS) { if (suri->run_mode == RUNMODE_ENGINE_ANALYSIS) {
SCLogInfo("== Carrying out Engine Analysis =="); SCLogInfo("== Carrying out Engine Analysis ==");
@ -2341,14 +2432,6 @@ static int PostConfLoadedSetup(SCInstance *suri)
StorageInit(); StorageInit();
CIDRInit(); CIDRInit();
SigParsePrepare(); SigParsePrepare();
#ifdef PROFILING
if (suri->run_mode != RUNMODE_UNIX_SOCKET) {
SCProfilingRulesGlobalInit();
SCProfilingKeywordsGlobalInit();
SCProfilingSghsGlobalInit();
SCProfilingInit();
}
#endif /* PROFILING */
SCReputationInitCtx(); SCReputationInitCtx();
SCProtoNameInit(); SCProtoNameInit();
@ -2408,6 +2491,8 @@ static int PostConfLoadedSetup(SCInstance *suri)
CoredumpLoadConfig(); CoredumpLoadConfig();
PreRunInit(suri->run_mode);
SCReturnInt(TM_ECODE_OK); SCReturnInt(TM_ECODE_OK);
} }
@ -2418,25 +2503,16 @@ int main(int argc, char **argv)
SCInstanceInit(&suri); SCInstanceInit(&suri);
suri.progname = argv[0]; suri.progname = argv[0];
sc_set_caps = FALSE;
SC_ATOMIC_INIT(engine_stage); SC_ATOMIC_INIT(engine_stage);
/* initialize the logging subsys */ /* initialize the logging subsys */
SCLogInitLogModule(NULL); SCLogInitLogModule(NULL);
if (SCSetThreadName("Suricata-Main") < 0) { (void)SCSetThreadName("Suricata-Main");
SCLogWarning(SC_ERR_THREAD_INIT, "Unable to set thread name");
}
ParseSizeInit(); ParseSizeInit();
RunModeRegisterRunModes(); RunModeRegisterRunModes();
/* By default use IDS mode, but if nfq or ipfw
* are specified, IPS mode will overwrite this */
EngineModeSetIDS();
#ifdef OS_WIN32 #ifdef OS_WIN32
/* service initialization */ /* service initialization */
if (WindowsInit(argc, argv) != 0) { if (WindowsInit(argc, argv) != 0) {
@ -2462,19 +2538,8 @@ int main(int argc, char **argv)
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
#ifdef __SC_CUDA_SUPPORT__
/* Init the CUDA environment */
SCCudaInitCudaEnvironment();
CudaBufferInit();
#endif
/* Initializations for global vars, queues, etc (memsets, mutex init..) */ /* Initializations for global vars, queues, etc (memsets, mutex init..) */
GlobalInits(); GlobalInits();
TimeInit();
SupportFastPatternForSigMatchTypes();
if (suri.run_mode != RUNMODE_UNIX_SOCKET) {
StatsInit();
}
/* Load yaml configuration file if provided. */ /* Load yaml configuration file if provided. */
if (LoadYamlConfig(&suri) != TM_ECODE_OK) { if (LoadYamlConfig(&suri) != TM_ECODE_OK) {
@ -2502,13 +2567,6 @@ int main(int argc, char **argv)
exit(EXIT_FAILURE); exit(EXIT_FAILURE);
} }
if (suri.run_mode != RUNMODE_UNIX_SOCKET) {
FlowInitConfig(FLOW_VERBOSE);
StreamTcpInitConfig(STREAM_VERBOSE);
IPPairInitConfig(IPPAIR_VERBOSE);
AppLayerRegisterGlobalCounters();
}
DetectEngineCtx *de_ctx = NULL; DetectEngineCtx *de_ctx = NULL;
if (!suri.disabled_detect) { if (!suri.disabled_detect) {
SCClassConfInit(); SCClassConfInit();
@ -2558,11 +2616,7 @@ int main(int argc, char **argv)
SCSetStartTime(&suri); SCSetStartTime(&suri);
SCDropMainThreadCaps(suri.userid, suri.groupid); SCDropMainThreadCaps(suri.userid, suri.groupid);
PreRunPostPrivsDropInit(suri.run_mode);
if (suri.run_mode != RUNMODE_UNIX_SOCKET) {
RunModeInitializeOutputs();
StatsSetupPostConfig();
}
if (suri.run_mode == RUNMODE_CONF_TEST){ if (suri.run_mode == RUNMODE_CONF_TEST){
SCLogNotice("Configuration provided was successfully loaded. Exiting."); SCLogNotice("Configuration provided was successfully loaded. Exiting.");
@ -2573,23 +2627,8 @@ int main(int argc, char **argv)
} }
RunModeDispatch(suri.run_mode, suri.runmode_custom_mode); RunModeDispatch(suri.run_mode, suri.runmode_custom_mode);
/* In Unix socket runmode, Flow manager is started on demand */
if (suri.run_mode != RUNMODE_UNIX_SOCKET) { if (suri.run_mode != RUNMODE_UNIX_SOCKET) {
/* Spawn the unix socket manager thread */ UnixManagerThreadSpawnNonRunmode();
int unix_socket = ConfUnixSocketIsEnable();
if (unix_socket == 1) {
UnixManagerThreadSpawn(0);
#ifdef BUILD_UNIX_SOCKET
UnixManagerRegisterCommand("iface-stat", LiveDeviceIfaceStat, NULL,
UNIX_CMD_TAKE_ARGS);
UnixManagerRegisterCommand("iface-list", LiveDeviceIfaceList, NULL, 0);
#endif
}
/* Spawn the flow manager thread */
FlowManagerThreadSpawn();
FlowRecyclerThreadSpawn();
StatsSpawnThreads();
} }
/* Wait till all the threads have been initialized */ /* Wait till all the threads have been initialized */
@ -2617,7 +2656,6 @@ int main(int argc, char **argv)
SCLogNotice("Signature(s) loaded, Detect thread(s) activated."); SCLogNotice("Signature(s) loaded, Detect thread(s) activated.");
} }
#ifdef DBG_MEM_ALLOC #ifdef DBG_MEM_ALLOC
SCLogInfo("Memory used at startup: %"PRIdMAX, (intmax_t)global_mem); SCLogInfo("Memory used at startup: %"PRIdMAX, (intmax_t)global_mem);
#ifdef DBG_MEM_ALLOC_SKIP_STARTUP #ifdef DBG_MEM_ALLOC_SKIP_STARTUP
@ -2675,50 +2713,11 @@ int main(int argc, char **argv)
(void) SC_ATOMIC_CAS(&engine_stage, SURICATA_RUNTIME, SURICATA_DEINIT); (void) SC_ATOMIC_CAS(&engine_stage, SURICATA_RUNTIME, SURICATA_DEINIT);
UnixSocketKillSocketThread(); UnixSocketKillSocketThread();
PostRunDeinit(suri.run_mode, &suri.start_time);
if (suri.run_mode != RUNMODE_UNIX_SOCKET) {
/* First we need to disable the flow manager thread */
FlowDisableFlowManagerThread();
}
/* Disable packet acquisition first */
TmThreadDisableReceiveThreads();
if (suri.run_mode != RUNMODE_UNIX_SOCKET) {
/* we need a packet pool for FlowForceReassembly */
PacketPoolInit();
FlowForceReassembly();
/* kill receive threads when they have processed all
* flow timeout packets */
TmThreadDisablePacketThreads();
}
SCPrintElapsedTime(&suri);
/* before TmThreadKillThreads, as otherwise that kills it
* but more slowly */
if (suri.run_mode != RUNMODE_UNIX_SOCKET) {
FlowDisableFlowRecyclerThread();
}
/* kill remaining threads */ /* kill remaining threads */
TmThreadKillThreads(); TmThreadKillThreads();
if (suri.run_mode != RUNMODE_UNIX_SOCKET) {
/* destroy the packet pool for flow reassembly after all
* the other threads are gone. */
PacketPoolDestroy();
StatsReleaseResources();
IPPairShutdown();
FlowShutdown();
StreamTcpFreeConfig(STREAM_VERBOSE);
}
HostShutdown(); HostShutdown();
HTPFreeConfig(); HTPFreeConfig();
HTPAtExitPrintStats(); HTPAtExitPrintStats();
@ -2746,13 +2745,9 @@ int main(int argc, char **argv)
TagDestroyCtx(); TagDestroyCtx();
LiveDeviceListClean(); LiveDeviceListClean();
RunModeShutDown();
OutputDeregisterAll(); OutputDeregisterAll();
TimeDeinit(); TimeDeinit();
SCProtoNameDeInit(); SCProtoNameDeInit();
if (suri.run_mode != RUNMODE_UNIX_SOCKET) {
DefragDestroy();
}
if (!suri.disabled_detect) { if (!suri.disabled_detect) {
SCReferenceConfDeinit(); SCReferenceConfDeinit();
SCClassConfDeinit(); SCClassConfDeinit();
@ -2772,14 +2767,6 @@ int main(int argc, char **argv)
AFPPeersListClean(); AFPPeersListClean();
#endif #endif
#ifdef PROFILING
if (suri.run_mode != RUNMODE_UNIX_SOCKET) {
if (profiling_rules_enabled)
SCProfilingDump();
SCProfilingDestroy();
}
#endif
#ifdef OS_WIN32 #ifdef OS_WIN32
if (daemon) { if (daemon) {
return 0; return 0;

@ -195,5 +195,9 @@ int IsRuleReloadSet(int quiet);
extern int run_mode; extern int run_mode;
void PreRunInit(const int runmode);
void PreRunPostPrivsDropInit(const int runmode);
void PostRunDeinit(const int runmode, struct timeval *start_time);
#endif /* __SURICATA_H__ */ #endif /* __SURICATA_H__ */

@ -31,8 +31,8 @@
#include "util-privs.h" #include "util-privs.h"
#include "util-debug.h" #include "util-debug.h"
#include "util-device.h"
#include "util-signal.h" #include "util-signal.h"
#include "util-buffer.h" #include "util-buffer.h"
#include <sys/un.h> #include <sys/un.h>
@ -1011,6 +1011,19 @@ void UnixManagerThreadSpawn(int mode)
return; return;
} }
// TODO can't think of a good name
void UnixManagerThreadSpawnNonRunmode(void)
{
/* Spawn the unix socket manager thread */
int unix_socket = ConfUnixSocketIsEnable();
if (unix_socket == 1) {
UnixManagerThreadSpawn(0);
UnixManagerRegisterCommand("iface-stat", LiveDeviceIfaceStat, NULL,
UNIX_CMD_TAKE_ARGS);
UnixManagerRegisterCommand("iface-list", LiveDeviceIfaceList, NULL, 0);
}
}
/** /**
* \brief Used to kill unix manager thread(s). * \brief Used to kill unix manager thread(s).
* *
@ -1065,6 +1078,11 @@ void UnixSocketKillSocketThread(void)
return; return;
} }
void UnixManagerThreadSpawnNonRunmode(void)
{
return;
}
#endif /* BUILD_UNIX_SOCKET */ #endif /* BUILD_UNIX_SOCKET */
void TmModuleUnixManagerRegister (void) void TmModuleUnixManagerRegister (void)

@ -36,7 +36,6 @@ SCCtrlMutex unix_manager_ctrl_mutex;
void UnixManagerThreadSpawn(int mode); void UnixManagerThreadSpawn(int mode);
void UnixSocketKillSocketThread(void); void UnixSocketKillSocketThread(void);
#ifdef BUILD_UNIX_SOCKET #ifdef BUILD_UNIX_SOCKET
TmEcode UnixManagerRegisterCommand(const char * keyword, TmEcode UnixManagerRegisterCommand(const char * keyword,
TmEcode (*Func)(json_t *, json_t *, void *), TmEcode (*Func)(json_t *, json_t *, void *),
@ -47,5 +46,6 @@ TmEcode UnixManagerRegisterBackgroundTask(
#endif #endif
void TmModuleUnixManagerRegister(void); void TmModuleUnixManagerRegister(void);
void UnixManagerThreadSpawnNonRunmode(void);
#endif /* UNIX_MANAGER_H */ #endif /* UNIX_MANAGER_H */

Loading…
Cancel
Save