|
|
@ -33,10 +33,11 @@ uint8_t tv_aof = THV_RESTART_THREAD;
|
|
|
|
|
|
|
|
|
|
|
|
typedef struct TmSlot_ {
|
|
|
|
typedef struct TmSlot_ {
|
|
|
|
/* function pointers */
|
|
|
|
/* function pointers */
|
|
|
|
int (*SlotInit)(ThreadVars *, void *, void **);
|
|
|
|
|
|
|
|
int (*SlotFunc)(ThreadVars *, Packet *, void *, PacketQueue *);
|
|
|
|
int (*SlotFunc)(ThreadVars *, Packet *, void *, PacketQueue *);
|
|
|
|
void (*SlotExitPrintStats)(ThreadVars *, void *);
|
|
|
|
|
|
|
|
int (*SlotDeinit)(ThreadVars *, void *);
|
|
|
|
int (*SlotThreadInit)(ThreadVars *, void *, void **);
|
|
|
|
|
|
|
|
void (*SlotThreadExitPrintStats)(ThreadVars *, void *);
|
|
|
|
|
|
|
|
int (*SlotThreadDeinit)(ThreadVars *, void *);
|
|
|
|
|
|
|
|
|
|
|
|
/* data storage */
|
|
|
|
/* data storage */
|
|
|
|
void *slot_initdata;
|
|
|
|
void *slot_initdata;
|
|
|
@ -69,8 +70,8 @@ void *TmThreadsSlot1NoIn(void *td) {
|
|
|
|
if (tv->set_cpu_affinity == 1)
|
|
|
|
if (tv->set_cpu_affinity == 1)
|
|
|
|
SetCPUAffinity(tv->cpu_affinity);
|
|
|
|
SetCPUAffinity(tv->cpu_affinity);
|
|
|
|
|
|
|
|
|
|
|
|
if (s->s.SlotInit != NULL) {
|
|
|
|
if (s->s.SlotThreadInit != NULL) {
|
|
|
|
r = s->s.SlotInit(tv, s->s.slot_initdata, &s->s.slot_data);
|
|
|
|
r = s->s.SlotThreadInit(tv, s->s.slot_initdata, &s->s.slot_data);
|
|
|
|
if (r != 0) {
|
|
|
|
if (r != 0) {
|
|
|
|
EngineKill();
|
|
|
|
EngineKill();
|
|
|
|
|
|
|
|
|
|
|
@ -104,12 +105,12 @@ void *TmThreadsSlot1NoIn(void *td) {
|
|
|
|
run = 0;
|
|
|
|
run = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (s->s.SlotExitPrintStats != NULL) {
|
|
|
|
if (s->s.SlotThreadExitPrintStats != NULL) {
|
|
|
|
s->s.SlotExitPrintStats(tv, s->s.slot_data);
|
|
|
|
s->s.SlotThreadExitPrintStats(tv, s->s.slot_data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (s->s.SlotDeinit != NULL) {
|
|
|
|
if (s->s.SlotThreadDeinit != NULL) {
|
|
|
|
r = s->s.SlotDeinit(tv, s->s.slot_data);
|
|
|
|
r = s->s.SlotThreadDeinit(tv, s->s.slot_data);
|
|
|
|
if (r != 0) {
|
|
|
|
if (r != 0) {
|
|
|
|
tv->flags |= THV_CLOSED;
|
|
|
|
tv->flags |= THV_CLOSED;
|
|
|
|
pthread_exit((void *) -1);
|
|
|
|
pthread_exit((void *) -1);
|
|
|
@ -130,8 +131,8 @@ void *TmThreadsSlot1NoOut(void *td) {
|
|
|
|
if (tv->set_cpu_affinity == 1)
|
|
|
|
if (tv->set_cpu_affinity == 1)
|
|
|
|
SetCPUAffinity(tv->cpu_affinity);
|
|
|
|
SetCPUAffinity(tv->cpu_affinity);
|
|
|
|
|
|
|
|
|
|
|
|
if (s->s.SlotInit != NULL) {
|
|
|
|
if (s->s.SlotThreadInit != NULL) {
|
|
|
|
r = s->s.SlotInit(tv, s->s.slot_initdata, &s->s.slot_data);
|
|
|
|
r = s->s.SlotThreadInit(tv, s->s.slot_initdata, &s->s.slot_data);
|
|
|
|
if (r != 0) {
|
|
|
|
if (r != 0) {
|
|
|
|
EngineKill();
|
|
|
|
EngineKill();
|
|
|
|
|
|
|
|
|
|
|
@ -159,12 +160,12 @@ void *TmThreadsSlot1NoOut(void *td) {
|
|
|
|
run = 0;
|
|
|
|
run = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (s->s.SlotExitPrintStats != NULL) {
|
|
|
|
if (s->s.SlotThreadExitPrintStats != NULL) {
|
|
|
|
s->s.SlotExitPrintStats(tv, s->s.slot_data);
|
|
|
|
s->s.SlotThreadExitPrintStats(tv, s->s.slot_data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (s->s.SlotDeinit != NULL) {
|
|
|
|
if (s->s.SlotThreadDeinit != NULL) {
|
|
|
|
r = s->s.SlotDeinit(tv, s->s.slot_data);
|
|
|
|
r = s->s.SlotThreadDeinit(tv, s->s.slot_data);
|
|
|
|
if (r != 0) {
|
|
|
|
if (r != 0) {
|
|
|
|
tv->flags |= THV_CLOSED;
|
|
|
|
tv->flags |= THV_CLOSED;
|
|
|
|
pthread_exit((void *) -1);
|
|
|
|
pthread_exit((void *) -1);
|
|
|
@ -186,8 +187,8 @@ void *TmThreadsSlot1NoInOut(void *td) {
|
|
|
|
|
|
|
|
|
|
|
|
//printf("TmThreadsSlot1NoInOut: %s starting\n", tv->name);
|
|
|
|
//printf("TmThreadsSlot1NoInOut: %s starting\n", tv->name);
|
|
|
|
|
|
|
|
|
|
|
|
if (s->s.SlotInit != NULL) {
|
|
|
|
if (s->s.SlotThreadInit != NULL) {
|
|
|
|
r = s->s.SlotInit(tv, s->s.slot_initdata, &s->s.slot_data);
|
|
|
|
r = s->s.SlotThreadInit(tv, s->s.slot_initdata, &s->s.slot_data);
|
|
|
|
if (r != 0) {
|
|
|
|
if (r != 0) {
|
|
|
|
EngineKill();
|
|
|
|
EngineKill();
|
|
|
|
|
|
|
|
|
|
|
@ -215,12 +216,12 @@ void *TmThreadsSlot1NoInOut(void *td) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (s->s.SlotExitPrintStats != NULL) {
|
|
|
|
if (s->s.SlotThreadExitPrintStats != NULL) {
|
|
|
|
s->s.SlotExitPrintStats(tv, s->s.slot_data);
|
|
|
|
s->s.SlotThreadExitPrintStats(tv, s->s.slot_data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (s->s.SlotDeinit != NULL) {
|
|
|
|
if (s->s.SlotThreadDeinit != NULL) {
|
|
|
|
r = s->s.SlotDeinit(tv, s->s.slot_data);
|
|
|
|
r = s->s.SlotThreadDeinit(tv, s->s.slot_data);
|
|
|
|
if (r != 0) {
|
|
|
|
if (r != 0) {
|
|
|
|
tv->flags |= THV_CLOSED;
|
|
|
|
tv->flags |= THV_CLOSED;
|
|
|
|
pthread_exit((void *) -1);
|
|
|
|
pthread_exit((void *) -1);
|
|
|
@ -244,8 +245,8 @@ void *TmThreadsSlot1(void *td) {
|
|
|
|
|
|
|
|
|
|
|
|
//printf("TmThreadsSlot1: %s starting\n", tv->name);
|
|
|
|
//printf("TmThreadsSlot1: %s starting\n", tv->name);
|
|
|
|
|
|
|
|
|
|
|
|
if (s->s.SlotInit != NULL) {
|
|
|
|
if (s->s.SlotThreadInit != NULL) {
|
|
|
|
r = s->s.SlotInit(tv, s->s.slot_initdata, &s->s.slot_data);
|
|
|
|
r = s->s.SlotThreadInit(tv, s->s.slot_initdata, &s->s.slot_data);
|
|
|
|
if (r != 0) {
|
|
|
|
if (r != 0) {
|
|
|
|
EngineKill();
|
|
|
|
EngineKill();
|
|
|
|
|
|
|
|
|
|
|
@ -292,12 +293,12 @@ void *TmThreadsSlot1(void *td) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (s->s.SlotExitPrintStats != NULL) {
|
|
|
|
if (s->s.SlotThreadExitPrintStats != NULL) {
|
|
|
|
s->s.SlotExitPrintStats(tv, s->s.slot_data);
|
|
|
|
s->s.SlotThreadExitPrintStats(tv, s->s.slot_data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (s->s.SlotDeinit != NULL) {
|
|
|
|
if (s->s.SlotThreadDeinit != NULL) {
|
|
|
|
r = s->s.SlotDeinit(tv, s->s.slot_data);
|
|
|
|
r = s->s.SlotThreadDeinit(tv, s->s.slot_data);
|
|
|
|
if (r != 0) {
|
|
|
|
if (r != 0) {
|
|
|
|
tv->flags |= THV_CLOSED;
|
|
|
|
tv->flags |= THV_CLOSED;
|
|
|
|
pthread_exit((void *) -1);
|
|
|
|
pthread_exit((void *) -1);
|
|
|
@ -362,8 +363,8 @@ void *TmThreadsSlotVar(void *td) {
|
|
|
|
//printf("TmThreadsSlot1: %s starting\n", tv->name);
|
|
|
|
//printf("TmThreadsSlot1: %s starting\n", tv->name);
|
|
|
|
|
|
|
|
|
|
|
|
for (slot = s->s; slot != NULL; slot = slot->slot_next) {
|
|
|
|
for (slot = s->s; slot != NULL; slot = slot->slot_next) {
|
|
|
|
if (slot->SlotInit != NULL) {
|
|
|
|
if (slot->SlotThreadInit != NULL) {
|
|
|
|
r = slot->SlotInit(tv, slot->slot_initdata, &slot->slot_data);
|
|
|
|
r = slot->SlotThreadInit(tv, slot->slot_initdata, &slot->slot_data);
|
|
|
|
if (r != 0) {
|
|
|
|
if (r != 0) {
|
|
|
|
EngineKill();
|
|
|
|
EngineKill();
|
|
|
|
|
|
|
|
|
|
|
@ -404,12 +405,12 @@ void *TmThreadsSlotVar(void *td) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
for (slot = s->s; slot != NULL; slot = slot->slot_next) {
|
|
|
|
for (slot = s->s; slot != NULL; slot = slot->slot_next) {
|
|
|
|
if (slot->SlotExitPrintStats != NULL) {
|
|
|
|
if (slot->SlotThreadExitPrintStats != NULL) {
|
|
|
|
slot->SlotExitPrintStats(tv, slot->slot_data);
|
|
|
|
slot->SlotThreadExitPrintStats(tv, slot->slot_data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (slot->SlotDeinit != NULL) {
|
|
|
|
if (slot->SlotThreadDeinit != NULL) {
|
|
|
|
r = slot->SlotDeinit(tv, slot->slot_data);
|
|
|
|
r = slot->SlotThreadDeinit(tv, slot->slot_data);
|
|
|
|
if (r != 0) {
|
|
|
|
if (r != 0) {
|
|
|
|
tv->flags |= THV_CLOSED;
|
|
|
|
tv->flags |= THV_CLOSED;
|
|
|
|
pthread_exit((void *) -1);
|
|
|
|
pthread_exit((void *) -1);
|
|
|
@ -477,26 +478,26 @@ void Tm1SlotSetFunc(ThreadVars *tv, TmModule *tm, void *data) {
|
|
|
|
printf("Warning: slot 1 is already set tp %p, "
|
|
|
|
printf("Warning: slot 1 is already set tp %p, "
|
|
|
|
"overwriting with %p\n", s1->s.SlotFunc, tm->Func);
|
|
|
|
"overwriting with %p\n", s1->s.SlotFunc, tm->Func);
|
|
|
|
|
|
|
|
|
|
|
|
s1->s.SlotInit = tm->Init;
|
|
|
|
s1->s.SlotThreadInit = tm->ThreadInit;
|
|
|
|
s1->s.slot_initdata = data;
|
|
|
|
s1->s.slot_initdata = data;
|
|
|
|
s1->s.SlotFunc = tm->Func;
|
|
|
|
s1->s.SlotFunc = tm->Func;
|
|
|
|
s1->s.SlotExitPrintStats = tm->ExitPrintStats;
|
|
|
|
s1->s.SlotThreadExitPrintStats = tm->ThreadExitPrintStats;
|
|
|
|
s1->s.SlotDeinit = tm->Deinit;
|
|
|
|
s1->s.SlotThreadDeinit = tm->ThreadDeinit;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void TmVarSlotSetFuncAppend(ThreadVars *tv, TmModule *tm, void *data) {
|
|
|
|
void TmVarSlotSetFuncAppend(ThreadVars *tv, TmModule *tm, void *data) {
|
|
|
|
TmVarSlot *s = (TmVarSlot *)tv->tm_slots;
|
|
|
|
TmVarSlot *s = (TmVarSlot *)tv->tm_slots;
|
|
|
|
TmSlot *slot = malloc(sizeof(TmSlot));
|
|
|
|
TmSlot *slot = malloc(sizeof(TmSlot));
|
|
|
|
if (slot == NULL)
|
|
|
|
if (slot == NULL)
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
|
|
memset(slot, 0, sizeof(TmSlot));
|
|
|
|
memset(slot, 0, sizeof(TmSlot));
|
|
|
|
|
|
|
|
|
|
|
|
slot->SlotInit = tm->Init;
|
|
|
|
slot->SlotThreadInit = tm->ThreadInit;
|
|
|
|
slot->slot_initdata = data;
|
|
|
|
slot->slot_initdata = data;
|
|
|
|
slot->SlotFunc = tm->Func;
|
|
|
|
slot->SlotFunc = tm->Func;
|
|
|
|
slot->SlotExitPrintStats = tm->ExitPrintStats;
|
|
|
|
slot->SlotThreadExitPrintStats = tm->ThreadExitPrintStats;
|
|
|
|
slot->SlotDeinit = tm->Deinit;
|
|
|
|
slot->SlotThreadDeinit = tm->ThreadDeinit;
|
|
|
|
|
|
|
|
|
|
|
|
if (s->s == NULL) {
|
|
|
|
if (s->s == NULL) {
|
|
|
|
s->s = slot;
|
|
|
|
s->s = slot;
|
|
|
|