Go to the documentation of this file.
99 static void FlowWorkerFlowTimeout(
114 const int server = f->
ffr_tc;
115 const int client = f->
ffr_ts;
129 FlowWorkerFlowTimeout(
tv, p, fw, detect_thread);
141 FlowWorkerFlowTimeout(
tv, p, fw, detect_thread);
165 if (f->
proto == IPPROTO_TCP) {
170 int cnt = FlowFinish(
tv, f, fw, detect_thread);
182 FlowEndCountersUpdate(
tv, &fw->
fec, f);
200 if (max_work != 0 && ++i == max_work)
203 if (ret_queue.
len > 0) {
220 #ifdef CAPTURE_OFFLOAD
221 case FLOW_STATE_CAPTURE_BYPASSED: {
225 FlowDeReference(&p->
flow);
234 FlowDeReference(&p->
flow);
266 if (fw->
dtv == NULL) {
267 FlowWorkerThreadDeinit(
tv, fw);
273 FlowWorkerThreadDeinit(
tv, fw);
279 void *detect_thread = NULL;
281 FlowWorkerThreadDeinit(
tv, fw);
289 FlowWorkerThreadDeinit(
tv, fw);
293 SCLogError(
"initializing flow log API for thread failed");
294 FlowWorkerThreadDeinit(
tv, fw);
319 if (detect_thread != NULL) {
365 void *detect_thread,
const bool timeout)
372 bool setting_nopayload =
378 if (setting_nopayload) {
379 FlowSetNoPayloadInspectionFlag(p->
flow);
391 if (detect_thread != NULL) {
407 FlowDeReference(&x->
flow);
434 FlowWorkerStreamTCPUpdate(
tv, fw, p, detect_thread,
true);
440 if (detect_thread != NULL) {
454 STREAM_TOSERVER : STREAM_TOCLIENT);
460 FlowDeReference(&p->
flow);
467 static inline void FlowWorkerProcessInjectedFlows(
475 if (injected.
len > 0) {
491 uint32_t max_work = 2;
499 UpdateCounters(
tv, fw, &counters);
507 static void PacketAppUpdate2FlowFlags(
Packet *p)
525 SCLogDebug(
"pcap_cnt %" PRIu64
", FLOW_TS_APP_UPDATED|FLOW_TC_APP_UPDATE_NEXT set",
529 SCLogDebug(
"pcap_cnt %" PRIu64
", FLOW_TC_APP_UPDATED|FLOW_TS_APP_UPDATE_NEXT set",
536 SCLogDebug(
"pcap_cnt %" PRIu64
", FLOW_TC_APP_UPDATED|FLOW_TS_APP_UPDATE_NEXT set",
540 SCLogDebug(
"pcap_cnt %" PRIu64
", FLOW_TS_APP_UPDATED|FLOW_TC_APP_UPDATE_NEXT set",
593 ": direction %s FLOW_TS_APP_UPDATE_NEXT %s FLOW_TC_APP_UPDATE_NEXT %s",
608 if (PacketIsTCP(p)) {
615 if (detect_thread == NULL &&
621 FlowWorkerStreamTCPUpdate(
tv, fw, p, detect_thread,
false);
622 PacketAppUpdate2FlowFlags(p);
629 PacketAppUpdate2FlowFlags(p);
638 if (detect_thread != NULL) {
648 if (p->
flow != NULL) {
651 if (FlowIsBypassed(p->
flow)) {
653 if (p->
proto == IPPROTO_TCP) {
664 STREAM_TOSERVER : STREAM_TOCLIENT);
666 }
else if (p->
proto == IPPROTO_UDP) {
688 SCLogDebug(
"not pseudo, no app update: skip");
692 SCLogDebug(
"flow drop in place: remove app update flags");
697 FlowDeReference(&p->
flow);
704 FlowWorkerProcessInjectedFlows(
tv, fw, p);
707 FlowWorkerProcessLocalFlows(
tv, fw, p);
740 return "flow-inject";
749 static bool FlowWorkerIsBusy(
ThreadVars *
tv,
void *flow_worker)
#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)
#define FLOW_TC_APP_UPDATE_NEXT
void FlowCleanupAppLayer(Flow *f)
@ PROFILE_FLOWWORKER_DETECT
uint16_t counter_flow_active
TmEcode OutputFlowLogThreadInit(ThreadVars *tv, void **data)
thread init for the flow logger This will run the thread init functions for the individual registered...
@ 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)
@ PROFILE_FLOWWORKER_TCPPRUNE
#define TM_FLAG_DETECT_TM
@ STREAM_HAS_UNPROCESSED_SEGMENTS_NEED_ONLY_DETECTION
@ 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
Packet * FlowPseudoPacketGet(int direction, Flow *f, const TcpSession *ssn)
void FlowHandlePacket(ThreadVars *tv, FlowLookupStruct *fls, Packet *p)
Entry point for packet flow handling.
void FlowQueuePrivatePrependFlow(FlowQueuePrivate *fqc, Flow *f)
#define PKT_NOPAYLOAD_INSPECTION
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)
@ STREAM_HAS_UNPROCESSED_SEGMENTS_NONE
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)
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)
TmEcode StreamTcp(ThreadVars *, Packet *, void *, PacketQueueNoLock *pq)
Per thread variable structure.
int DetectEngineEnabled(void)
Check if detection is enabled.
TmEcode DetectEngineThreadCtxInit(ThreadVars *tv, void *initdata, void **data)
initialize thread specific detection engine context
TmEcode(* Func)(ThreadVars *, Packet *, void *)
#define FLOW_PKT_TOCLIENT_FIRST
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)
#define APP_LAYER_PARSER_NO_INSPECTION
FlowQueuePrivate spare_queue
void AppLayerParserStateSetFlag(AppLayerParserState *pstate, uint16_t flag)
void * FlowWorkerGetDetectCtxPtr(void *flow_worker)
FlowQueuePrivate FlowQueueExtractPrivate(FlowQueue *fq)
struct FlowWorkerThreadData_::@112 cnt
void DecodeThreadVarsFree(ThreadVars *tv, DecodeThreadVars *dtv)
void FlowFree(Flow *f)
cleanup & free the memory of a flow
@ PROFILE_FLOWWORKER_SIZE
TmEcode DetectEngineThreadCtxDeinit(ThreadVars *tv, void *data)
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)
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
#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
void PacketDrop(Packet *p, const uint8_t action, enum PacketDropReason r)
issue drop action
#define FLOW_END_FLAG_TIMEOUT
bool FlowNeedsReassembly(Flow *f)
Check if a flow needs forced reassembly, or any other processing.
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 AppLayerParserStateIssetFlag(AppLayerParserState *pstate, uint16_t flag)
uint16_t StatsRegisterCounter(const char *name, struct ThreadVars_ *tv)
Registers a normal, unqualified counter.
#define FLOW_SPARE_POOL_BLOCK_SIZE
#define FLOW_PKT_TOSERVER_FIRST
uint16_t both_bypass_pkts
#define DEBUG_VALIDATE_BUG_ON(exp)
#define TM_FLAG_STREAM_TM
@ PKT_DROP_REASON_FLOW_DROP
#define FLOW_TS_APP_UPDATE_NEXT
TmEcode StreamTcpThreadDeinit(ThreadVars *tv, void *data)
uint16_t flows_injected_max
void FlowWorkerReplaceDetectCtx(void *flow_worker, void *detect_ctx)
uint32_t flows_aside_needs_work