suricata
|
#include "decode.h"
#include "util-time.h"
#include "util-exception-policy.h"
#include "util-exception-policy-types.h"
#include "util-var.h"
#include "util-optimize.h"
#include "util-validate.h"
#include "app-layer-protos.h"
#include "util-storage.h"
#include "flow-queue.h"
Go to the source code of this file.
Data Structures | |
struct | FlowCnf_ |
struct | FlowKey_ |
struct | FlowAddress_ |
struct | Flow_ |
Flow data structure. More... | |
struct | FlowProtoTimeout_ |
struct | FlowProtoFreeFunc_ |
struct | FlowBypassInfo_ |
struct | FlowLookupStruct_ |
Typedefs | |
typedef struct FlowStorageId | FlowStorageId |
typedef struct AppLayerParserState_ | AppLayerParserState |
typedef struct FlowCnf_ | FlowConfig |
typedef struct FlowKey_ | FlowKey |
typedef struct FlowAddress_ | FlowAddress |
typedef unsigned short | FlowStateType |
typedef uint16_t | FlowThreadId |
typedef struct Flow_ | Flow |
Flow data structure. More... | |
typedef struct FlowProtoTimeout_ | FlowProtoTimeout |
typedef struct FlowProtoFreeFunc_ | FlowProtoFreeFunc |
typedef struct FlowBypassInfo_ | FlowBypassInfo |
typedef struct FlowLookupStruct_ | FlowLookupStruct |
Enumerations | |
enum | FlowState { FLOW_STATE_NEW = 0, FLOW_STATE_ESTABLISHED, FLOW_STATE_CLOSED, FLOW_STATE_LOCAL_BYPASSED } |
Functions | |
void | FlowSetupPacket (Packet *p) |
prepare packet for a life with flow Set PKT_WANTS_FLOW flag to indicate workers should do a flow lookup and calc the hash value to be used in the lookup and autofp flow balancing. More... | |
void | FlowHandlePacket (ThreadVars *, FlowLookupStruct *, Packet *) |
Entry point for packet flow handling. More... | |
void | FlowInitConfig (bool) |
initialize the configuration More... | |
void | FlowReset (void) |
void | FlowShutdown (void) |
shutdown the flow engine More... | |
void | FlowSetIPOnlyFlag (Flow *, int) |
Set the IPOnly scanned flag for 'direction'. More... | |
void | FlowSetHasAlertsFlag (Flow *) |
Set flag to indicate that flow has alerts. More... | |
int | FlowHasAlerts (const Flow *) |
Check if flow has alerts. More... | |
void | FlowSetChangeProtoFlag (Flow *) |
Set flag to indicate to change proto for the flow. More... | |
void | FlowUnsetChangeProtoFlag (Flow *) |
Unset flag to indicate to change proto for the flow. More... | |
int | FlowChangeProto (Flow *) |
Check if change proto flag is set for flow. More... | |
void | FlowSwap (Flow *) |
swap the flow's direction More... | |
void | FlowRegisterTests (void) |
Function to register the Flow Unitests. More... | |
int | FlowSetProtoFreeFunc (uint8_t, void(*Free)(void *)) |
Function to set the function to get protocol specific flow state. More... | |
int | FlowGetPacketDirection (const Flow *, const Packet *) |
determine the direction of the packet compared to the flow More... | |
void | FlowCleanupAppLayer (Flow *) |
void | FlowUpdateState (Flow *f, enum FlowState s) |
int | FlowSetMemcap (uint64_t size) |
Update memcap value. More... | |
uint64_t | FlowGetMemcap (void) |
Return memcap value. More... | |
uint64_t | FlowGetMemuse (void) |
enum ExceptionPolicy | FlowGetMemcapExceptionPolicy (void) |
FlowStorageId | GetFlowBypassInfoID (void) |
void | RegisterFlowBypassInfo (void) |
void | FlowGetLastTimeAsParts (Flow *flow, uint64_t *secs, uint64_t *usecs) |
Get flow last time as individual values. More... | |
uint32_t | FlowGetFlags (Flow *flow) |
Get flow flags. More... | |
uint16_t | FlowGetSourcePort (Flow *flow) |
Get flow source port. More... | |
uint16_t | FlowGetDestinationPort (Flow *flow) |
Get flow destination port. More... | |
int | FlowClearMemory (Flow *, uint8_t) |
Function clear the flow memory before queueing it to spare flow queue. More... | |
uint8_t | FlowGetDisruptionFlags (const Flow *f, uint8_t flags) |
get 'disruption' flags: GAP/DEPTH/PASS More... | |
void | FlowHandlePacketUpdate (Flow *f, Packet *p, ThreadVars *tv, DecodeThreadVars *dtv) |
Update Packet and Flow. More... | |
Definition in file flow.h.
#define FLOW_ACTION_DROP BIT_U32(7) |
#define FLOW_ACTION_PASS BIT_U32(28) |
#define FLOW_CHANGE_PROTO BIT_U32(24) |
#define FLOW_COPY_IPV4_ADDR_TO_PACKET | ( | fa, | |
pa | |||
) |
#define FLOW_COPY_IPV6_ADDR_TO_PACKET | ( | fa, | |
pa | |||
) |
#define FLOW_DIR_REVERSED BIT_U32(26) |
#define FLOW_GET_DP | ( | f | ) | ((f)->flags & FLOW_DIR_REVERSED) ? (f)->sp : (f)->dp; |
#define FLOW_GET_SP | ( | f | ) | ((f)->flags & FLOW_DIR_REVERSED) ? (f)->dp : (f)->sp; |
#define FLOW_HAS_EXPECTATION BIT_U32(27) |
#define FLOW_IS_PE_DONE | ( | f, | |
dir | |||
) | (((dir) & STREAM_TOSERVER) ? ((f)->flags & FLOW_TS_PE_ALPROTO_DETECT_DONE) : ((f)->flags & FLOW_TC_PE_ALPROTO_DETECT_DONE)) |
#define FLOW_IS_PM_DONE | ( | f, | |
dir | |||
) | (((dir) & STREAM_TOSERVER) ? ((f)->flags & FLOW_TS_PM_ALPROTO_DETECT_DONE) : ((f)->flags & FLOW_TC_PM_ALPROTO_DETECT_DONE)) |
#define FLOW_IS_PP_DONE | ( | f, | |
dir | |||
) | (((dir) & STREAM_TOSERVER) ? ((f)->flags & FLOW_TS_PP_ALPROTO_DETECT_DONE) : ((f)->flags & FLOW_TC_PP_ALPROTO_DETECT_DONE)) |
#define FLOW_NOPACKET_INSPECTION BIT_U32(5) |
#define FLOW_NOPAYLOAD_INSPECTION BIT_U32(6) |
#define FLOW_PKT_LAST_PSEUDO 0x80 |
#define FLOW_RESET_PE_DONE | ( | f, | |
dir | |||
) | (((dir) & STREAM_TOSERVER) ? ((f)->flags &= ~FLOW_TS_PE_ALPROTO_DETECT_DONE) : ((f)->flags &= ~FLOW_TC_PE_ALPROTO_DETECT_DONE)) |
#define FLOW_RESET_PM_DONE | ( | f, | |
dir | |||
) | (((dir) & STREAM_TOSERVER) ? ((f)->flags &= ~FLOW_TS_PM_ALPROTO_DETECT_DONE) : ((f)->flags &= ~FLOW_TC_PM_ALPROTO_DETECT_DONE)) |
#define FLOW_RESET_PP_DONE | ( | f, | |
dir | |||
) | (((dir) & STREAM_TOSERVER) ? ((f)->flags &= ~FLOW_TS_PP_ALPROTO_DETECT_DONE) : ((f)->flags &= ~FLOW_TC_PP_ALPROTO_DETECT_DONE)) |
#define FLOW_SET_IPV4_DST_ADDR_FROM_PACKET | ( | ip4h, | |
a | |||
) |
#define FLOW_SET_IPV4_SRC_ADDR_FROM_PACKET | ( | ip4h, | |
a | |||
) |
#define FLOW_SET_IPV6_DST_ADDR_FROM_PACKET | ( | ip6h, | |
a | |||
) |
#define FLOW_SET_IPV6_SRC_ADDR_FROM_PACKET | ( | ip6h, | |
a | |||
) |
#define FLOW_SET_PE_DONE | ( | f, | |
dir | |||
) | (((dir) & STREAM_TOSERVER) ? ((f)->flags |= FLOW_TS_PE_ALPROTO_DETECT_DONE) : ((f)->flags |= FLOW_TC_PE_ALPROTO_DETECT_DONE)) |
#define FLOW_SET_PM_DONE | ( | f, | |
dir | |||
) | (((dir) & STREAM_TOSERVER) ? ((f)->flags |= FLOW_TS_PM_ALPROTO_DETECT_DONE) : ((f)->flags |= FLOW_TC_PM_ALPROTO_DETECT_DONE)) |
#define FLOW_SET_PP_DONE | ( | f, | |
dir | |||
) | (((dir) & STREAM_TOSERVER) ? ((f)->flags |= FLOW_TS_PP_ALPROTO_DETECT_DONE) : ((f)->flags |= FLOW_TC_PP_ALPROTO_DETECT_DONE)) |
#define FLOW_SGH_TOCLIENT BIT_U32(9) |
#define FLOW_SGH_TOSERVER BIT_U32(8) |
#define FLOW_TC_APP_UPDATE_NEXT BIT_U32(2) |
#define FLOW_TC_PE_ALPROTO_DETECT_DONE BIT_U32(18) |
#define FLOW_TC_PM_ALPROTO_DETECT_DONE BIT_U32(16) |
#define FLOW_TC_PP_ALPROTO_DETECT_DONE BIT_U32(17) |
#define FLOW_TO_DST_SEEN BIT_U32(1) |
#define FLOW_TO_SRC_SEEN BIT_U32(0) |
#define FLOW_TOCLIENT_DROP_LOGGED BIT_U32(11) |
#define FLOW_TOCLIENT_IPONLY_SET BIT_U32(4) |
#define FLOW_TOSERVER_DROP_LOGGED BIT_U32(10) |
#define FLOW_TOSERVER_IPONLY_SET BIT_U32(3) |
#define FLOW_TS_APP_UPDATE_NEXT BIT_U32(31) |
#define FLOW_TS_PE_ALPROTO_DETECT_DONE BIT_U32(15) |
#define FLOW_TS_PM_ALPROTO_DETECT_DONE BIT_U32(13) |
#define FLOW_TS_PP_ALPROTO_DETECT_DONE BIT_U32(14) |
#define FLOWFILE_NO_MAGIC_TS BIT_U16(0) |
#define FLOWFILE_NO_MD5_TS BIT_U16(4) |
#define FLOWFILE_NO_SHA1_TS BIT_U16(6) |
#define FLOWFILE_NO_SHA256_TS BIT_U16(8) |
#define FLOWFILE_NO_SIZE_TS BIT_U16(10) |
#define FLOWFILE_NO_STORE_TS BIT_U16(2) |
#define FLOWFILE_NONE (FLOWFILE_NONE_TS|FLOWFILE_NONE_TC) |
#define FLOWFILE_NONE_TC |
#define FLOWFILE_NONE_TS |
#define FLOWFILE_STORE_TS BIT_U16(12) |
#define FLOWLOCK_DESTROY | ( | fb | ) | SCMutexDestroy(&(fb)->m) |
#define FLOWLOCK_INIT | ( | fb | ) | SCMutexInit(&(fb)->m, NULL) |
#define FLOWLOCK_RDLOCK | ( | fb | ) | SCMutexLock(&(fb)->m) |
#define FLOWLOCK_TRYRDLOCK | ( | fb | ) | SCMutexTrylock(&(fb)->m) |
#define FLOWLOCK_TRYWRLOCK | ( | fb | ) | SCMutexTrylock(&(fb)->m) |
#define FLOWLOCK_UNLOCK | ( | fb | ) | SCMutexUnlock(&(fb)->m) |
#define FLOWLOCK_WRLOCK | ( | fb | ) | SCMutexLock(&(fb)->m) |
typedef struct AppLayerParserState_ AppLayerParserState |
Flow data structure.
The flow is a global data structure that is created for new packets of a flow and then looked up for the following packets of a flow.
Locking
The flow is updated/used by multiple packets at the same time. This is why there is a flow-mutex. It's a mutex and not a spinlock because some operations on the flow can be quite expensive, thus spinning would be too expensive.
The flow "header" (addresses, ports, proto, recursion level) are static after the initialization and remain read-only throughout the entire live of a flow. This is why we can access those without protection of the lock.
typedef struct FlowAddress_ FlowAddress |
typedef struct FlowBypassInfo_ FlowBypassInfo |
typedef struct FlowCnf_ FlowConfig |
typedef struct FlowLookupStruct_ FlowLookupStruct |
typedef struct FlowProtoFreeFunc_ FlowProtoFreeFunc |
typedef struct FlowProtoTimeout_ FlowProtoTimeout |
typedef unsigned short FlowStateType |
typedef struct FlowStorageId FlowStorageId |
typedef uint16_t FlowThreadId |
enum FlowState |
int FlowChangeProto | ( | Flow * | f | ) |
Check if change proto flag is set for flow.
f | flow |
1 | change proto flag is set |
0 | change proto flag is not set |
Definition at line 204 of file flow.c.
References Flow_::flags, and FLOW_CHANGE_PROTO.
Referenced by AppLayerRequestProtocolChange(), and LLVMFuzzerTestOneInput().
void FlowCleanupAppLayer | ( | Flow * | ) |
Definition at line 137 of file flow.c.
References Flow_::alparser, Flow_::alstate, AppLayerParserStateCleanup(), and Flow_::proto.
int FlowClearMemory | ( | Flow * | f, |
uint8_t | proto_map | ||
) |
Function clear the flow memory before queueing it to spare flow queue.
f | pointer to the flow needed to be cleared. |
proto_map | mapped value of the protocol to FLOW_PROTO's. |
Definition at line 1092 of file flow.c.
References AppLayerExpectationClean(), Flow_::flags, flow_freefuncs, FLOW_HAS_EXPECTATION, FLOW_RECYCLE, FlowFreeStorage(), FlowProtoFreeFunc_::Freefunc, Flow_::protoctx, SCEnter, SCReturnInt, and unlikely.
Referenced by FlowReset(), and FlowShutdown().
uint16_t FlowGetDestinationPort | ( | Flow * | flow | ) |
uint8_t FlowGetDisruptionFlags | ( | const Flow * | f, |
uint8_t | flags | ||
) |
get 'disruption' flags: GAP/DEPTH/PASS
f | locked flow |
flags | existing flags to be amended |
flags | original flags + disrupt flags (if any) \TODO handle UDP |
Definition at line 1136 of file flow.c.
References TcpSession_::client, flags, TcpStream_::flags, Flow_::proto, Flow_::protoctx, TcpSession_::server, and STREAMTCP_STREAM_FLAG_DEPTH_REACHED.
uint32_t FlowGetFlags | ( | Flow * | flow | ) |
Get flow flags.
A function to get the flow flags useful when the caller only has an opaque pointer to the flow structure.
Definition at line 1223 of file flow.c.
References Flow_::flags.
void FlowGetLastTimeAsParts | ( | Flow * | flow, |
uint64_t * | secs, | ||
uint64_t * | usecs | ||
) |
Get flow last time as individual values.
Instead of returning a pointer to the timeval copy the timeval parts into output pointers to make it simpler to call from Rust over FFI using only basic data types.
Definition at line 1188 of file flow.c.
References Flow_::lastts, SCTIME_SECS, and SCTIME_USECS.
uint64_t FlowGetMemcap | ( | void | ) |
Return memcap value.
memcap | value |
Definition at line 120 of file flow.c.
References flow_config, and SC_ATOMIC_GET.
enum ExceptionPolicy FlowGetMemcapExceptionPolicy | ( | void | ) |
Definition at line 126 of file flow.c.
Referenced by DecodeRegisterPerfCounters().
uint64_t FlowGetMemuse | ( | void | ) |
Definition at line 126 of file flow.c.
References SC_ATOMIC_GET.
determine the direction of the packet compared to the flow
0 | to_server |
1 | to_client |
Definition at line 288 of file flow.c.
References CMP_ADDR, CMP_PORT, Packet_::dp, Flow_::flags, FLOW_DIR_REVERSED, IPPROTO_SCTP, Packet_::proto, Flow_::sp, Packet_::sp, Flow_::src, Packet_::src, TOCLIENT, and TOSERVER.
Referenced by FlowHandlePacketUpdate(), and StreamTcp().
uint16_t FlowGetSourcePort | ( | Flow * | flow | ) |
void FlowHandlePacket | ( | ThreadVars * | tv, |
FlowLookupStruct * | fls, | ||
Packet * | p | ||
) |
Entry point for packet flow handling.
This is called for every packet.
tv | threadvars |
dtv | decode thread vars (for flow output api thread data) |
p | packet to handle flow for |
Definition at line 515 of file flow.c.
References Packet_::flags, Packet_::flow, FlowGetFlowFromHash(), PKT_HAS_FLOW, and tv.
Referenced by UTHBuildPacketOfFlows().
void FlowHandlePacketUpdate | ( | Flow * | f, |
Packet * | p, | ||
ThreadVars * | tv, | ||
DecodeThreadVars * | dtv | ||
) |
Update Packet and Flow.
Updates packet and flow based on the new packet.
f | locked flow |
p | packet |
Definition at line 387 of file flow.c.
References BypassedFlowUpdate(), EngineModeIsIPS(), Flow_::flags, FLOW_BYPASSED_TIMEOUT, FLOW_PKT_TOSERVER, Flow_::flow_state, FLOW_STATE_LOCAL_BYPASSED, FLOW_TO_DST_SEEN, Packet_::flowflags, FlowGetPacketDirection(), FlowUpdateState(), GET_PKT_LEN, Flow_::lastts, Packet_::pcap_cnt, SCLogDebug, SCTIME_CMP_GT, SCTIME_SECS, Flow_::todstbytecnt, Flow_::todstpktcnt, TOSERVER, and Packet_::ts.
int FlowHasAlerts | ( | const Flow * | f | ) |
Check if flow has alerts.
f | flow |
1 | has alerts |
0 | has not alerts |
Definition at line 172 of file flow.c.
References Flow_::flags, and FLOW_HAS_ALERTS.
void FlowInitConfig | ( | bool | quiet | ) |
initialize the configuration
set config values for memcap, prealloc and hash_size
Definition at line 529 of file flow.c.
References CLS, ConfGet(), ConfGetInt(), FlowCnf_::emergency_recovery, ExceptionPolicyParse(), FatalError, FBLOCK_INIT, FLOW_CHECK_MEMCAP, flow_config, FLOW_DEFAULT_EMERGENCY_RECOVERY, FLOW_DEFAULT_HASHSIZE, FLOW_DEFAULT_MEMCAP, FLOW_DEFAULT_PREALLOC, flow_hash, flow_recycle_q, FlowInitFlowProto(), FlowQueueInit(), FlowSparePoolInit(), FlowStorageSize(), FlowCnf_::hash_rand, FlowCnf_::hash_size, FlowCnf_::memcap_policy, ParseSizeStringU64(), FlowCnf_::prealloc, RandomGet(), SC_ATOMIC_ADD, SC_ATOMIC_GET, SC_ATOMIC_INIT, SC_ATOMIC_SET, SCLogDebug, SCLogError, SCMallocAligned, StringParseUint32(), and unlikely.
Referenced by PreRunInit().
void FlowRegisterTests | ( | void | ) |
Function to register the Flow Unitests.
Definition at line 1440 of file flow.c.
References UtRegisterTest().
void FlowReset | ( | void | ) |
Definition at line 658 of file flow.c.
References flow_config, flow_hash, FlowClearMemory(), FlowFree(), FlowGetProtoMapping(), FlowCnf_::hash_size, Flow_::next, and Flow_::proto.
void FlowSetChangeProtoFlag | ( | Flow * | f | ) |
Set flag to indicate to change proto for the flow.
f | flow |
Definition at line 185 of file flow.c.
References Flow_::flags, and FLOW_CHANGE_PROTO.
Referenced by AppLayerRequestProtocolChange().
void FlowSetHasAlertsFlag | ( | Flow * | f | ) |
Set flag to indicate that flow has alerts.
f | flow |
Definition at line 161 of file flow.c.
References Flow_::flags, and FLOW_HAS_ALERTS.
void FlowSetIPOnlyFlag | ( | Flow * | f, |
int | direction | ||
) |
Set the IPOnly scanned flag for 'direction'.
f | Flow to set the flag in |
direction | direction to set the flag in |
Definition at line 152 of file flow.c.
References Flow_::flags, FLOW_TOCLIENT_IPONLY_SET, and FLOW_TOSERVER_IPONLY_SET.
int FlowSetMemcap | ( | uint64_t | size | ) |
Update memcap value.
size | new memcap value |
Definition at line 105 of file flow.c.
References flow_config, SC_ATOMIC_GET, and SC_ATOMIC_SET.
int FlowSetProtoFreeFunc | ( | uint8_t | proto, |
void(*)(void *) | Free | ||
) |
Function to set the function to get protocol specific flow state.
proto | protocol of which function is needed to be set. |
Free | Function pointer which will be called to free the protocol specific memory. |
Definition at line 1120 of file flow.c.
References flow_freefuncs, FlowGetProtoMapping(), FlowProtoFreeFunc_::Freefunc, and proto.
void FlowSetupPacket | ( | Packet * | p | ) |
prepare packet for a life with flow Set PKT_WANTS_FLOW flag to indicate workers should do a flow lookup and calc the hash value to be used in the lookup and autofp flow balancing.
Definition at line 522 of file flow-hash.c.
References Packet_::flags, Packet_::flow_hash, and PKT_WANTS_FLOW.
void FlowShutdown | ( | void | ) |
shutdown the flow engine
Definition at line 676 of file flow.c.
References DEBUG_VALIDATE_BUG_ON, FBLOCK_DESTROY, flow_config, flow_hash, flow_recycle_q, FlowClearMemory(), FlowDequeue(), FlowFree(), FlowGetProtoMapping(), FlowQueueDestroy(), FlowSparePoolDestroy(), FlowCnf_::hash_size, Flow_::next, Flow_::proto, SC_ATOMIC_GET, SC_ATOMIC_SUB, and SCFreeAligned.
void FlowSwap | ( | Flow * | f | ) |
swap the flow's direction
Definition at line 255 of file flow.c.
References Flow_::flags, FLOW_DIR_REVERSED, Flow_::probing_parser_toclient_alproto_masks, Flow_::probing_parser_toserver_alproto_masks, and SWAP_VARS.
void FlowUnsetChangeProtoFlag | ( | Flow * | f | ) |
Unset flag to indicate to change proto for the flow.
f | flow |
Definition at line 194 of file flow.c.
References Flow_::flags, and FLOW_CHANGE_PROTO.
Definition at line 1157 of file flow.c.
References Flow_::flow_state.
Referenced by FlowHandlePacketUpdate(), and PacketBypassCallback().
FlowStorageId GetFlowBypassInfoID | ( | void | ) |
Definition at line 212 of file flow-util.c.
References g_bypass_info_id.
Referenced by EveAddFlow(), and PacketBypassCallback().
void RegisterFlowBypassInfo | ( | void | ) |
Definition at line 230 of file flow-util.c.
References FlowStorageRegister(), and g_bypass_info_id.
Referenced by PostConfLoadedSetup().