Go to the documentation of this file.
114 Packet *p1 = NULL, *p2 = NULL;
115 const int server = f->
ffr_tc;
116 const int client = f->
ffr_ts;
140 FlowDeReference(&p1->
flow);
164 FlowWorkerFlowTimeout(
tv, p1, fw, detect_thread);
167 FlowWorkerFlowTimeout(
tv, p2, fw, detect_thread);
187 if (f->
proto == IPPROTO_TCP) {
193 int cnt = FlowFinish(
tv, f, fw, detect_thread);
205 FlowEndCountersUpdate(
tv, &fw->
fec, f);
223 if (max_work != 0 && ++i == max_work)
226 if (ret_queue.
len > 0) {
243 #ifdef CAPTURE_OFFLOAD
244 case FLOW_STATE_CAPTURE_BYPASSED: {
248 FlowDeReference(&p->
flow);
257 FlowDeReference(&p->
flow);
289 if (fw->
dtv == NULL) {
290 FlowWorkerThreadDeinit(
tv, fw);
296 FlowWorkerThreadDeinit(
tv, fw);
302 void *detect_thread = NULL;
304 FlowWorkerThreadDeinit(
tv, fw);
312 FlowWorkerThreadDeinit(
tv, fw);
316 SCLogError(
"initializing flow log API for thread failed");
317 FlowWorkerThreadDeinit(
tv, fw);
342 if (detect_thread != NULL) {
388 void *detect_thread,
const bool timeout)
406 if (detect_thread != NULL) {
422 FlowDeReference(&x->
flow);
445 FlowWorkerStreamTCPUpdate(
tv, fw, p, detect_thread,
true);
451 if (detect_thread != NULL) {
465 STREAM_TOSERVER : STREAM_TOCLIENT);
471 FlowDeReference(&p->
flow);
478 static inline void FlowWorkerProcessInjectedFlows(
486 if (injected.
len > 0) {
502 uint32_t max_work = 2;
510 UpdateCounters(
tv, fw, &counters);
518 static void PacketAppUpdate2FlowFlags(
Packet *p)
601 if (detect_thread == NULL &&
607 FlowWorkerStreamTCPUpdate(
tv, fw, p, detect_thread,
false);
608 PacketAppUpdate2FlowFlags(p);
615 PacketAppUpdate2FlowFlags(p);
624 if (detect_thread != NULL) {
634 if (p->
flow != NULL) {
637 if (FlowIsBypassed(p->
flow)) {
639 if (p->
proto == IPPROTO_TCP) {
646 STREAM_TOSERVER : STREAM_TOCLIENT);
648 }
else if (p->
proto == IPPROTO_UDP) {
667 SCLogDebug(
"not pseudo, no app update: skip");
671 SCLogDebug(
"flow drop in place: remove app update flags");
676 FlowDeReference(&p->
flow);
683 FlowWorkerProcessInjectedFlows(
tv, fw, p);
686 FlowWorkerProcessLocalFlows(
tv, fw, p);
719 return "flow-inject";
728 static void FlowWorkerExitPrintStats(
ThreadVars *
tv,
void *data)
734 static bool FlowWorkerIsBusy(
ThreadVars *
tv,
void *flow_worker)
@ STREAM_HAS_UNPROCESSED_SEGMENTS_NEED_ONLY_DETECTION
#define PKT_IS_TOCLIENT(p)
bool PacketCheckAction(const Packet *p, const uint8_t a)
FlowQueuePrivate work_queue
struct FlowQueue_ * flow_queue
TmEcode OutputFlowLog(ThreadVars *tv, void *thread_data, Flow *f)
Run flow logger(s)
void FlowCleanupAppLayer(Flow *f)
@ PROFILE_FLOWWORKER_DETECT
uint16_t counter_flow_active
@ PROFILE_FLOWWORKER_FLOW_INJECTED
struct FlowWorkerThreadData_ FlowWorkerThreadData
#define PKT_IS_PSEUDOPKT(p)
return 1 if the packet is a pseudo packet
void PacketPoolReturnPacket(Packet *p)
Return packet to Packet pool.
#define FLOW_PKT_LAST_PSEUDO
#define SC_ATOMIC_SET(name, val)
Set the value for the atomic variable.
void AppLayerParserTransactionsCleanup(Flow *f, const uint8_t pkt_dir)
remove obsolete (inspected and logged) transactions
@ PROFILE_FLOWWORKER_FLOW_EVICTED
const char * ProfileFlowWorkerIdToString(enum ProfileFlowWorkerId fwi)
void OutputLoggerExitPrintStats(ThreadVars *tv, void *thread_data)
@ PROFILE_FLOWWORKER_TCPPRUNE
#define TM_FLAG_DETECT_TM
@ PKT_SRC_CAPTURE_TIMEOUT
#define FLOW_TC_APP_UPDATED
void StatsSetUI64(ThreadVars *tv, uint16_t id, uint64_t x)
Sets a value of type double to the local counter.
uint32_t flows_aside_pkt_inject
void AppLayerRegisterThreadCounters(ThreadVars *tv)
Registers per flow counters for all protocols.
TmEcode StreamTcpThreadInit(ThreadVars *tv, void *initdata, void **data)
#define FLOW_PKT_TOSERVER
void FlowHandlePacket(ThreadVars *tv, FlowLookupStruct *fls, Packet *p)
Entry point for packet flow handling.
void FlowQueuePrivatePrependFlow(FlowQueuePrivate *fqc, Flow *f)
uint16_t flows_aside_needs_work
StreamTcpThread * stream_thread
uint16_t counter_tcp_active_sessions
bool(* ThreadBusy)(ThreadVars *tv, void *thread_data)
void TmqhOutputPacketpool(ThreadVars *t, Packet *p)
@ PROFILE_FLOWWORKER_STREAM
#define APP_LAYER_PARSER_EOF_TS
TmEcode OutputLoggerThreadDeinit(ThreadVars *tv, void *thread_data)
void DisableDetectFlowFileFlags(Flow *f)
disable file features we don't need Called if we have no detection engine.
simple fifo queue for packets
#define FLOW_TIMEOUT_REASSEMBLY_DONE
#define FLOWWORKER_PROFILING_START(p, id)
void FlowSparePoolReturnFlows(FlowQueuePrivate *fqp)
#define FLOWLOCK_UNLOCK(fb)
TmEcode(* ThreadDeinit)(ThreadVars *, void *)
#define PKT_SET_SRC(p, src_val)
AppLayerParserState * alparser
void DecodeRegisterPerfCounters(DecodeThreadVars *dtv, ThreadVars *tv)
DetectEngineThreadCtx * DetectEngineThreadCtxPtr
void StatsDecr(ThreadVars *tv, uint16_t id)
Decrements the local counter.
uint16_t StatsRegisterMaxCounter(const char *name, struct ThreadVars_ *tv)
Registers a counter, whose value holds the maximum of all the values assigned to it.
uint16_t flows_aside_pkt_inject
@ FLOW_STATE_LOCAL_BYPASSED
#define PKT_IS_TOSERVER(p)
TmEcode OutputFlowLogThreadInit(ThreadVars *tv, void *initdata, void **data)
thread init for the flow logger This will run the thread init functions for the individual registered...
Packet * PacketDequeueNoLock(PacketQueueNoLock *qnl)
uint16_t local_bypass_bytes
struct FlowTimeoutCounters FlowTimeoutCounters
void FlowHandlePacketUpdate(Flow *f, Packet *p, ThreadVars *tv, DecodeThreadVars *dtv)
Update Packet and Flow.
#define FLOWLOCK_WRLOCK(fb)
#define STREAM_FLAGS_FOR_PACKET(p)
int FlowForceReassemblyNeedReassembly(Flow *f)
Check if a flow needs forced reassembly, or any other processing.
TmEcode StreamTcp(ThreadVars *, Packet *, void *, PacketQueueNoLock *pq)
Per thread variable structure.
int DetectEngineEnabled(void)
Check if detection is enabled.
TmEcode(* Func)(ThreadVars *, Packet *, void *)
#define FLOW_PKT_TOCLIENT_FIRST
uint32_t flow_spare_pool_block_size
uint16_t local_bypass_pkts
@ PROFILE_FLOWWORKER_APPLAYERUDP
Flow * FlowQueuePrivateGetFromTop(FlowQueuePrivate *fqc)
#define FLOWWORKER_PROFILING_END(p, id)
void StreamTcpPruneSession(Flow *f, uint8_t flags)
Remove idle TcpSegments from TcpSession.
TmEcode OutputLoggerThreadInit(ThreadVars *tv, const void *initdata, void **data)
TmModule tmm_modules[TMM_SIZE]
#define APP_LAYER_PARSER_EOF_TC
int AppLayerHandleUdp(ThreadVars *tv, AppLayerThreadCtx *tctx, Packet *p, Flow *f)
Handle a app layer UDP message.
#define DEBUG_ASSERT_FLOW_LOCKED(f)
int FlowClearMemory(Flow *f, uint8_t proto_map)
Function clear the flow memory before queueing it to spare flow queue.
void TmModuleFlowWorkerRegister(void)
void FlowQueuePrivateAppendPrivate(FlowQueuePrivate *dest, FlowQueuePrivate *src)
void TimeSetByThread(const int thread_id, SCTime_t tv)
FlowQueuePrivate spare_queue
void AppLayerParserStateSetFlag(AppLayerParserState *pstate, uint16_t flag)
void * FlowWorkerGetDetectCtxPtr(void *flow_worker)
FlowQueuePrivate FlowQueueExtractPrivate(FlowQueue *fq)
TmEcode DetectEngineThreadCtxInit(ThreadVars *, void *, void **)
initialize thread specific detection engine context
void DecodeThreadVarsFree(ThreadVars *tv, DecodeThreadVars *dtv)
void FlowFree(Flow *f)
cleanup & free the memory of a flow
TmEcode DetectEngineThreadCtxDeinit(ThreadVars *, void *)
@ PROFILE_FLOWWORKER_SIZE
uint8_t app_update_direction
uint16_t both_bypass_bytes
#define FLOW_TS_APP_UPDATED
TmEcode(* ThreadInit)(ThreadVars *, const void *, void **)
void PacketUpdateEngineEventCounters(ThreadVars *tv, DecodeThreadVars *dtv, Packet *p)
void(* ThreadExitPrintStats)(ThreadVars *, void *)
TmEcode Detect(ThreadVars *tv, Packet *p, void *data)
Detection engine thread wrapper.
void StreamTcpDetectLogFlush(ThreadVars *tv, StreamTcpThread *stt, Flow *f, Packet *p, PacketQueueNoLock *pq)
create packets in both directions to flush out logging and detection before switching protocols....
void StatsAddUI64(ThreadVars *tv, uint16_t id, uint64_t x)
Adds a value of type uint64_t to the local counter.
void * output_thread_flow
struct FlowWorkerThreadData_::@113 cnt
#define SCLogError(...)
Macro used to log ERROR messages.
TmEcode OutputFlowLogThreadDeinit(ThreadVars *tv, void *thread_data)
void FramesPrune(Flow *f, Packet *p)
TmEcode OutputLoggerLog(ThreadVars *tv, Packet *p, void *thread_data)
Structure to hold thread specific data for all decode modules.
void StreamTcpSessionCleanup(TcpSession *ssn)
Session cleanup function. Does not free the ssn.
#define SC_ATOMIC_INITPTR(name)
DecodeThreadVars * DecodeThreadVarsAlloc(ThreadVars *tv)
Alloc and setup DecodeThreadVars.
@ PROFILE_FLOWWORKER_FLOW
TcpReassemblyThreadCtx * ra_ctx
#define FLOW_END_FLAG_TIMEOUT
int FlowChangeProto(Flow *f)
Check if change proto flag is set for flow.
#define SC_ATOMIC_GET(name)
Get the value from the atomic variable.
void FlowEndCountersRegister(ThreadVars *t, FlowEndCounters *fec)
SC_ATOMIC_DECLARE(DetectEngineThreadCtxPtr, detect_thread)
uint16_t StatsRegisterCounter(const char *name, struct ThreadVars_ *tv)
Registers a normal, unqualified counter.
#define FLOW_PKT_TOSERVER_FIRST
uint16_t both_bypass_pkts
#define DEBUG_VALIDATE_BUG_ON(exp)
#define TM_FLAG_STREAM_TM
TmEcode StreamTcpThreadDeinit(ThreadVars *tv, void *data)
uint16_t flows_injected_max
void FlowWorkerReplaceDetectCtx(void *flow_worker, void *detect_ctx)
Packet * FlowForceReassemblyPseudoPacketGet(int direction, Flow *f, TcpSession *ssn)
uint32_t flows_aside_needs_work