suricata
flow.h
Go to the documentation of this file.
1 /* Copyright (C) 2007-2025 Open Information Security Foundation
2  *
3  * You can copy, redistribute or modify this Program under the terms of
4  * the GNU General Public License version 2 as published by the Free
5  * Software Foundation.
6  *
7  * This program is distributed in the hope that it will be useful,
8  * but WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10  * GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License
13  * version 2 along with this program; if not, write to the Free Software
14  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
15  * 02110-1301, USA.
16  */
17 
18 /**
19  * \file
20  *
21  * \author Victor Julien <victor@inliniac.net>
22  */
23 
24 #ifndef SURICATA_FLOW_H
25 #define SURICATA_FLOW_H
26 
27 /* forward declaration for macset include */
28 typedef struct FlowStorageId FlowStorageId;
29 
30 #include "decode.h"
31 #include "util-time.h"
32 #include "util-exception-policy.h"
34 #include "util-var.h"
35 #include "util-optimize.h"
36 #include "util-validate.h"
37 #include "app-layer-protos.h"
38 
39 /* Part of the flow structure, so we declare it here.
40  * The actual declaration is in app-layer-parser.c */
42 
43 #define FLOW_QUIET true
44 
45 #define TOSERVER 0
46 #define TOCLIENT 1
47 
48 /* per flow flags */
49 
50 /** At least one packet from the source address was seen */
51 #define FLOW_TO_SRC_SEEN BIT_U64(0)
52 /** At least one packet from the destination address was seen */
53 #define FLOW_TO_DST_SEEN BIT_U64(1)
54 
55 /** next packet in toclient direction will act on updated app-layer state */
56 #define FLOW_TC_APP_UPDATE_NEXT BIT_U64(2)
57 
58 /** Flow is marked an elephant flow */
59 #define FLOW_IS_ELEPHANT_TOSERVER BIT_U64(3)
60 #define FLOW_IS_ELEPHANT_TOCLIENT BIT_U64(4)
61 
62 /** All packets in this flow should be accepted */
63 #define FLOW_ACTION_ACCEPT BIT_U64(5)
64 
65 /** Packet payloads belonging to this flow should not be inspected */
66 #define FLOW_NOPAYLOAD_INSPECTION BIT_U64(6)
67 
68 /** All packets in this flow should be dropped */
69 #define FLOW_ACTION_DROP BIT_U64(7)
70 
71 /** Sgh for toserver direction set (even if it's NULL) */
72 #define FLOW_SGH_TOSERVER BIT_U64(8)
73 /** Sgh for toclient direction set (even if it's NULL) */
74 #define FLOW_SGH_TOCLIENT BIT_U64(9)
75 
76 /** packet to server direction has been logged in drop file (only in IPS mode) */
77 #define FLOW_TOSERVER_DROP_LOGGED BIT_U64(10)
78 /** packet to client direction has been logged in drop file (only in IPS mode) */
79 #define FLOW_TOCLIENT_DROP_LOGGED BIT_U64(11)
80 
81 /** flow has alerts */
82 #define FLOW_HAS_ALERTS BIT_U64(12)
83 
84 /** Pattern matcher alproto detection done */
85 #define FLOW_TS_PM_ALPROTO_DETECT_DONE BIT_U64(13)
86 /** Probing parser alproto detection done */
87 #define FLOW_TS_PP_ALPROTO_DETECT_DONE BIT_U64(14)
88 /** Expectation alproto detection done */
89 #define FLOW_TS_PE_ALPROTO_DETECT_DONE BIT_U64(15)
90 /** Pattern matcher alproto detection done */
91 #define FLOW_TC_PM_ALPROTO_DETECT_DONE BIT_U64(16)
92 /** Probing parser alproto detection done */
93 #define FLOW_TC_PP_ALPROTO_DETECT_DONE BIT_U64(17)
94 /** Expectation alproto detection done */
95 #define FLOW_TC_PE_ALPROTO_DETECT_DONE BIT_U64(18)
96 #define FLOW_TIMEOUT_REASSEMBLY_DONE BIT_U64(19)
97 
98 /** flow is ipv4 */
99 #define FLOW_IPV4 BIT_U64(20)
100 /** flow is ipv6 */
101 #define FLOW_IPV6 BIT_U64(21)
102 
103 #define FLOW_PROTO_DETECT_TS_DONE BIT_U64(22)
104 #define FLOW_PROTO_DETECT_TC_DONE BIT_U64(23)
105 
106 /** Indicate that alproto detection for flow should be done again */
107 #define FLOW_CHANGE_PROTO BIT_U64(24)
108 
109 #define FLOW_WRONG_THREAD BIT_U64(25)
110 /** Protocol detection told us flow is picked up in wrong direction (midstream) */
111 #define FLOW_DIR_REVERSED BIT_U64(26)
112 /** Indicate that the flow did trigger an expectation creation */
113 #define FLOW_HAS_EXPECTATION BIT_U64(27)
114 
115 /** All packets in this flow should be passed */
116 #define FLOW_ACTION_PASS BIT_U64(28)
117 
118 #define FLOW_TS_APP_UPDATED BIT_U64(29)
119 #define FLOW_TC_APP_UPDATED BIT_U64(30)
120 
121 /** next packet in toserver direction will act on updated app-layer state */
122 #define FLOW_TS_APP_UPDATE_NEXT BIT_U64(31)
123 
124 /* File flags */
125 
126 #define FLOWFILE_INIT 0
127 
128 /** no magic on files in this flow */
129 #define FLOWFILE_NO_MAGIC_TS BIT_U16(0)
130 #define FLOWFILE_NO_MAGIC_TC BIT_U16(1)
131 
132 /** even if the flow has files, don't store 'm */
133 #define FLOWFILE_NO_STORE_TS BIT_U16(2)
134 #define FLOWFILE_NO_STORE_TC BIT_U16(3)
135 /** no md5 on files in this flow */
136 #define FLOWFILE_NO_MD5_TS BIT_U16(4)
137 #define FLOWFILE_NO_MD5_TC BIT_U16(5)
138 
139 /** no sha1 on files in this flow */
140 #define FLOWFILE_NO_SHA1_TS BIT_U16(6)
141 #define FLOWFILE_NO_SHA1_TC BIT_U16(7)
142 
143 /** no sha256 on files in this flow */
144 #define FLOWFILE_NO_SHA256_TS BIT_U16(8)
145 #define FLOWFILE_NO_SHA256_TC BIT_U16(9)
146 
147 // vacancy(2)
148 
149 /** store files in the flow */
150 #define FLOWFILE_STORE_TS BIT_U16(12)
151 #define FLOWFILE_STORE_TC BIT_U16(13)
152 
153 #define FLOWFILE_NONE_TS \
154  (FLOWFILE_NO_MAGIC_TS | FLOWFILE_NO_STORE_TS | FLOWFILE_NO_MD5_TS | FLOWFILE_NO_SHA1_TS | \
155  FLOWFILE_NO_SHA256_TS)
156 #define FLOWFILE_NONE_TC \
157  (FLOWFILE_NO_MAGIC_TC | FLOWFILE_NO_STORE_TC | FLOWFILE_NO_MD5_TC | FLOWFILE_NO_SHA1_TC | \
158  FLOWFILE_NO_SHA256_TC)
159 #define FLOWFILE_NONE (FLOWFILE_NONE_TS|FLOWFILE_NONE_TC)
160 
161 #define FLOW_IS_IPV4(f) \
162  (((f)->flags & FLOW_IPV4) == FLOW_IPV4)
163 #define FLOW_IS_IPV6(f) \
164  (((f)->flags & FLOW_IPV6) == FLOW_IPV6)
165 
166 #define FLOW_GET_SP(f) \
167  ((f)->flags & FLOW_DIR_REVERSED) ? (f)->dp : (f)->sp;
168 #define FLOW_GET_DP(f) \
169  ((f)->flags & FLOW_DIR_REVERSED) ? (f)->sp : (f)->dp;
170 
171 #define FLOW_COPY_IPV4_ADDR_TO_PACKET(fa, pa) do { \
172  (pa)->family = AF_INET; \
173  (pa)->addr_data32[0] = (fa)->addr_data32[0]; \
174  } while (0)
175 
176 #define FLOW_COPY_IPV6_ADDR_TO_PACKET(fa, pa) do { \
177  (pa)->family = AF_INET6; \
178  (pa)->addr_data32[0] = (fa)->addr_data32[0]; \
179  (pa)->addr_data32[1] = (fa)->addr_data32[1]; \
180  (pa)->addr_data32[2] = (fa)->addr_data32[2]; \
181  (pa)->addr_data32[3] = (fa)->addr_data32[3]; \
182  } while (0)
183 
184 /* Set the IPv4 addressesinto the Addrs of the Packet.
185  * Make sure p->ip4h is initialized and validated.
186  *
187  * We set the rest of the struct to 0 so we can
188  * prevent using memset. */
189 #define FLOW_SET_IPV4_SRC_ADDR_FROM_PACKET(ip4h, a) \
190  do { \
191  (a)->addr_data32[0] = (uint32_t)(ip4h)->s_ip_src.s_addr; \
192  (a)->addr_data32[1] = 0; \
193  (a)->addr_data32[2] = 0; \
194  (a)->addr_data32[3] = 0; \
195  } while (0)
196 
197 #define FLOW_SET_IPV4_DST_ADDR_FROM_PACKET(ip4h, a) \
198  do { \
199  (a)->addr_data32[0] = (uint32_t)(ip4h)->s_ip_dst.s_addr; \
200  (a)->addr_data32[1] = 0; \
201  (a)->addr_data32[2] = 0; \
202  (a)->addr_data32[3] = 0; \
203  } while (0)
204 
205 /* Set the IPv6 addressesinto the Addrs of the Packet.
206  * Make sure p->ip6h is initialized and validated. */
207 #define FLOW_SET_IPV6_SRC_ADDR_FROM_PACKET(ip6h, a) \
208  do { \
209  (a)->addr_data32[0] = (ip6h)->s_ip6_src[0]; \
210  (a)->addr_data32[1] = (ip6h)->s_ip6_src[1]; \
211  (a)->addr_data32[2] = (ip6h)->s_ip6_src[2]; \
212  (a)->addr_data32[3] = (ip6h)->s_ip6_src[3]; \
213  } while (0)
214 
215 #define FLOW_SET_IPV6_DST_ADDR_FROM_PACKET(ip6h, a) \
216  do { \
217  (a)->addr_data32[0] = (ip6h)->s_ip6_dst[0]; \
218  (a)->addr_data32[1] = (ip6h)->s_ip6_dst[1]; \
219  (a)->addr_data32[2] = (ip6h)->s_ip6_dst[2]; \
220  (a)->addr_data32[3] = (ip6h)->s_ip6_dst[3]; \
221  } while (0)
222 
223 /* pkt flow flags */
224 #define FLOW_PKT_TOSERVER 0x01
225 #define FLOW_PKT_TOCLIENT 0x02
226 #define FLOW_PKT_ESTABLISHED 0x04
227 #define FLOW_PKT_TOSERVER_FIRST 0x08
228 #define FLOW_PKT_TOCLIENT_FIRST 0x10
229 /** last pseudo packet in the flow. Can be used to trigger final clean,
230  * logging, etc. */
231 #define FLOW_PKT_LAST_PSEUDO 0x20
232 
233 #define FLOW_END_FLAG_EMERGENCY 0x01
234 #define FLOW_END_FLAG_TIMEOUT 0x02
235 #define FLOW_END_FLAG_FORCED 0x04
236 #define FLOW_END_FLAG_SHUTDOWN 0x08
237 #define FLOW_END_FLAG_TCPREUSE 0x10
238 
239 /** Mutex or RWLocks for the flow. */
240 //#define FLOWLOCK_RWLOCK
241 #define FLOWLOCK_MUTEX
242 
243 #ifdef FLOWLOCK_RWLOCK
244  #ifdef FLOWLOCK_MUTEX
245  #error Cannot enable both FLOWLOCK_RWLOCK and FLOWLOCK_MUTEX
246  #endif
247 #endif
248 
249 #ifdef FLOWLOCK_RWLOCK
250  #define FLOWLOCK_INIT(fb) SCRWLockInit(&(fb)->r, NULL)
251  #define FLOWLOCK_DESTROY(fb) SCRWLockDestroy(&(fb)->r)
252  #define FLOWLOCK_RDLOCK(fb) SCRWLockRDLock(&(fb)->r)
253  #define FLOWLOCK_WRLOCK(fb) SCRWLockWRLock(&(fb)->r)
254  #define FLOWLOCK_TRYRDLOCK(fb) SCRWLockTryRDLock(&(fb)->r)
255  #define FLOWLOCK_TRYWRLOCK(fb) SCRWLockTryWRLock(&(fb)->r)
256  #define FLOWLOCK_UNLOCK(fb) SCRWLockUnlock(&(fb)->r)
257 #elif defined FLOWLOCK_MUTEX
258  #define FLOWLOCK_INIT(fb) SCMutexInit(&(fb)->m, NULL)
259  #define FLOWLOCK_DESTROY(fb) SCMutexDestroy(&(fb)->m)
260  #define FLOWLOCK_RDLOCK(fb) SCMutexLock(&(fb)->m)
261  #define FLOWLOCK_WRLOCK(fb) SCMutexLock(&(fb)->m)
262  #define FLOWLOCK_TRYRDLOCK(fb) SCMutexTrylock(&(fb)->m)
263  #define FLOWLOCK_TRYWRLOCK(fb) SCMutexTrylock(&(fb)->m)
264  #define FLOWLOCK_UNLOCK(fb) SCMutexUnlock(&(fb)->m)
265 #else
266  #error Enable FLOWLOCK_RWLOCK or FLOWLOCK_MUTEX
267 #endif
268 
269 #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))
270 #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))
271 #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))
272 
273 #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))
274 #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))
275 #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))
276 
277 #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))
278 #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))
279 #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))
280 
281 /* global flow config */
282 typedef struct FlowCnf_
283 {
284  uint32_t hash_rand;
285  uint32_t hash_size;
286  uint32_t prealloc;
287 
288  uint32_t timeout_new;
289  uint32_t timeout_est;
290 
292 
294 
295  SC_ATOMIC_DECLARE(uint64_t, memcap);
297 
298 /* Hash key for the flow hash */
299 typedef struct FlowKey_
300 {
303  uint8_t proto;
305  uint16_t livedev_id;
308 
309 typedef struct FlowAddress_ {
310  union {
311  uint32_t address_un_data32[4]; /* type-specific field */
312  uint16_t address_un_data16[8]; /* type-specific field */
313  uint8_t address_un_data8[16]; /* type-specific field */
316 
317 #define addr_data32 address.address_un_data32
318 #define addr_data16 address.address_un_data16
319 #define addr_data8 address.address_un_data8
320 
321 typedef unsigned short FlowStateType;
322 
323 /** Local Thread ID */
324 typedef uint16_t FlowThreadId;
325 
326 #include "util-storage.h"
327 
328 /**
329  * \brief Flow data structure.
330  *
331  * The flow is a global data structure that is created for new packets of a
332  * flow and then looked up for the following packets of a flow.
333  *
334  * Locking
335  *
336  * The flow is updated/used by multiple packets at the same time. This is why
337  * there is a flow-mutex. It's a mutex and not a spinlock because some
338  * operations on the flow can be quite expensive, thus spinning would be
339  * too expensive.
340  *
341  * The flow "header" (addresses, ports, proto, recursion level) are static
342  * after the initialization and remain read-only throughout the entire live
343  * of a flow. This is why we can access those without protection of the lock.
344  */
345 
346 typedef struct Flow_
347 {
348  /* flow "header", used for hashing and flow lookup. Static after init,
349  * so safe to look at without lock */
351  union {
352  Port sp; /**< tcp/udp source port */
353  struct {
354  uint8_t type; /**< icmp type */
355  uint8_t code; /**< icmp code */
357 
358  struct {
359  uint32_t spi; /**< esp spi */
360  } esp;
361  };
362  union {
363  Port dp; /**< tcp/udp destination port */
364  struct {
365  uint8_t type; /**< icmp type */
366  uint8_t code; /**< icmp code */
368  };
369  uint8_t proto; /**< ip proto of the flow */
372 
373  uint8_t vlan_idx;
374 
375  /* track toserver/toclient flow timeout needs */
376  union {
377  struct {
378  uint8_t ffr_ts:4;
379  uint8_t ffr_tc:4;
380  };
381  uint8_t ffr;
382  };
383 
384  /** Thread ID for the stream/detect portion of this flow */
386 
387  /** flow hash - the flow hash before hash table size mod. Used for calculating
388  * the flow_id. */
389  uint32_t flow_hash;
390 
391  /** Incoming interface */
393 
394  struct Flow_ *next; /* (hash) list next */
395 
396  uint64_t flags; /**< generic flags */
397 
398  uint16_t file_flags; /**< file tracking/extraction flags */
399 
400  /** destination port to be used in protocol detection. This is meant
401  * for use with STARTTLS and HTTP CONNECT detection */
402  uint16_t protodetect_dp; /**< 0 if not used */
403 
404  /** timeout in seconds by policy, add to Flow::lastts to get actual time this times out.
405  * Ignored in emergency mode. */
406  uint32_t timeout_policy;
407 
408  /** time stamp of last update (last packet). Set/updated under the
409  * flow and flow hash row locks, safe to read under either the
410  * flow lock or flow hash row lock. */
412 
414 
415  /** flow tenant id, used to setup flow timeout and stream pseudo
416  * packets with the correct tenant id set */
417  uint32_t tenant_id;
418 
421 
422  /* Parent flow id for protocol like ftp */
423  int64_t parent_id;
424 
425  /** protocol specific data pointer, e.g. for TcpSession */
426  void *protoctx;
427 
428 #ifdef FLOWLOCK_RWLOCK
429  SCRWLock r;
430 #elif defined FLOWLOCK_MUTEX
432 #else
433  #error Enable FLOWLOCK_RWLOCK or FLOWLOCK_MUTEX
434 #endif
435 
436  /** mapping to Flow's protocol specific protocols for timeouts
437  and state and free functions. */
438  uint8_t protomap;
439 
440  uint8_t flow_end_flags;
441  /* coccinelle: Flow:flow_end_flags:FLOW_END_FLAG_ */
442 
443  AppProto alproto; /**< \brief application level protocol */
446 
447  /** original application level protocol. Used to indicate the previous
448  protocol when changing to another protocol , e.g. with STARTTLS. */
450  /** expected app protocol: used in protocol change/upgrade like in
451  * STARTTLS. */
453 
454  /** detection engine ctx version used to inspect this flow. Set at initial
455  * inspection. If it doesn't match the currently in use de_ctx, the
456  * stored sgh ptrs are reset. */
457  uint32_t de_ctx_version;
458 
459  /** ttl tracking */
464 
465  /** which exception policies were applied, if any */
467 
468  /** application level storage ptrs.
469  *
470  */
471  AppLayerParserState *alparser; /**< parser internal state */
472  void *alstate; /**< application layer state */
473 
474  /** toclient sgh for this flow. Only use when FLOW_SGH_TOCLIENT flow flag
475  * has been set. */
477  /** toserver sgh for this flow. Only use when FLOW_SGH_TOSERVER flow flag
478  * has been set. */
480 
481  /* pointer to the var list */
483 
484  struct FlowBucket_ *fb;
485 
487 
488  uint32_t todstpktcnt;
489  uint32_t tosrcpktcnt;
490  uint64_t todstbytecnt;
491  uint64_t tosrcbytecnt;
492 
495 
496 enum FlowState {
501 #ifdef CAPTURE_OFFLOAD
502  FLOW_STATE_CAPTURE_BYPASSED,
503 #endif
504 };
505 #ifdef CAPTURE_OFFLOAD
506 #define FLOW_STATE_SIZE 5
507 #else
508 #define FLOW_STATE_SIZE 4
509 #endif
510 
511 typedef struct FlowProtoTimeout_ {
512  uint32_t new_timeout;
513  uint32_t est_timeout;
514  uint32_t closed_timeout;
517 
518 typedef struct FlowProtoFreeFunc_ {
519  void (*Freefunc)(void *);
521 
522 typedef struct FlowBypassInfo_ {
523  bool (* BypassUpdate)(Flow *f, void *data, time_t tsec);
524  void (* BypassFree)(void *data);
525  void *bypass_data;
526  uint64_t tosrcpktcnt;
527  uint64_t tosrcbytecnt;
528  uint64_t todstpktcnt;
529  uint64_t todstbytecnt;
531 
532 #include "flow-queue.h"
533 
534 typedef struct FlowLookupStruct_ // TODO name
535 {
536  /** thread store of spare queues */
542 
543 /** \brief prepare packet for a life with flow
544  * Set PKT_WANTS_FLOW flag to indicate workers should do a flow lookup
545  * and calc the hash value to be used in the lookup and autofp flow
546  * balancing. */
547 void FlowSetupPacket(Packet *p);
549 void FlowInitConfig(bool);
550 void FlowReset(void);
551 void FlowShutdown(void);
552 void FlowSetHasAlertsFlag(Flow *);
553 int FlowHasAlerts(const Flow *);
556 int FlowChangeProto(Flow *);
557 void FlowSwap(Flow *);
558 
559 void FlowRegisterTests(void);
560 int FlowSetProtoFreeFunc(uint8_t, void (*Free)(void *));
561 
562 static inline void FlowSetNoPayloadInspectionFlag(Flow *);
563 
564 int FlowGetPacketDirection(const Flow *, const Packet *);
565 
566 void FlowCleanupAppLayer(Flow *);
567 
568 void FlowUpdateState(Flow *f, enum FlowState s);
569 
570 int FlowSetMemcap(uint64_t size);
571 uint64_t FlowGetMemcap(void);
572 uint64_t FlowGetMemuse(void);
574 
576 void RegisterFlowBypassInfo(void);
577 
578 /** ----- Inline functions ----- */
579 
580 static inline AppProto FlowGetAppProtocol(const Flow *f)
581 {
582  return f->alproto;
583 }
584 
585 static inline void *FlowGetAppState(const Flow *f)
586 {
587  return f->alstate;
588 }
589 
590 /** \brief Set the No payload inspection Flag without locking the flow.
591  *
592  * \param f Flow to set the flag in
593  */
594 static inline void FlowSetNoPayloadInspectionFlag(Flow *f)
595 {
596  SCEnter();
597 
598  SCLogDebug("flow %p", f);
600 
601  SCReturn;
602 }
603 
604 /** \brief Reference the flow
605  * \note This should only be called once for a destination
606  * pointer */
607 static inline void FlowReference(Flow **d, Flow *f)
608 {
609  if (likely(f != NULL)) {
610  DEBUG_VALIDATE_BUG_ON(*d == f);
611  if (*d == f)
612  return;
613  *d = f;
614  }
615 }
616 
617 static inline void FlowDeReference(Flow **d)
618 {
619  if (likely(*d != NULL)) {
620  *d = NULL;
621  }
622 }
623 
624 /** \brief create a flow id that is as unique as possible
625  * \retval flow_id unsigned 64bit id
626  */
627 static inline uint64_t FlowGetId(const Flow *f)
628 {
629  uint64_t id = (uint64_t)(SCTIME_SECS(f->startts) & 0xFFFF) << 48 |
630  (uint64_t)(SCTIME_USECS(f->startts) & 0xFFFF) << 32 | (uint64_t)f->flow_hash;
631  /* reduce to 51 bits as JavaScript and even JSON often seem to
632  * max out there. */
633  id &= 0x7ffffffffffffLL;
634  return id;
635 }
636 
637 static inline bool FlowIsBypassed(const Flow *f)
638 {
639  if (
640 #ifdef CAPTURE_OFFLOAD
641  f->flow_state == FLOW_STATE_CAPTURE_BYPASSED ||
642 #endif
644  return true;
645  }
646  return false;
647 }
648 
649 int FlowClearMemory(Flow *,uint8_t );
650 
651 AppProto FlowGetAppProtocol(const Flow *f);
652 void *FlowGetAppState(const Flow *f);
653 uint8_t FlowGetDisruptionFlags(const Flow *f, uint8_t flags);
654 
656 
657 #endif /* SURICATA_FLOW_H */
FlowStorageId
Definition: flow-storage.h:31
Flow_::ffr_tc
uint8_t ffr_tc
Definition: flow.h:379
FlowLookupStruct_::work_queue
FlowQueuePrivate work_queue
Definition: flow.h:539
FlowSetMemcap
int FlowSetMemcap(uint64_t size)
Update memcap value.
Definition: flow.c:108
FlowGetDisruptionFlags
uint8_t FlowGetDisruptionFlags(const Flow *f, uint8_t flags)
get 'disruption' flags: GAP/DEPTH/PASS
Definition: flow.c:1165
FlowBucket_
Definition: flow-hash.h:43
Flow_::ffr_ts
uint8_t ffr_ts
Definition: flow.h:378
Flow_::recursion_level
uint8_t recursion_level
Definition: flow.h:370
Flow_::flags
uint64_t flags
Definition: flow.h:396
FlowAddress_
Definition: flow.h:309
FLOW_STATE_ESTABLISHED
@ FLOW_STATE_ESTABLISHED
Definition: flow.h:498
FlowLookupStruct_::dtv
DecodeThreadVars * dtv
Definition: flow.h:538
Flow_::startts
SCTime_t startts
Definition: flow.h:486
SigGroupHead_
Container for matching data for a signature group.
Definition: detect.h:1628
FlowKey_::src
Address src
Definition: flow.h:301
FlowBypassInfo_
Definition: flow.h:522
FlowCnf_::emergency_recovery
uint32_t emergency_recovery
Definition: flow.h:291
FlowCnf_::hash_size
uint32_t hash_size
Definition: flow.h:285
FlowHandlePacket
void FlowHandlePacket(ThreadVars *, FlowLookupStruct *, Packet *)
Entry point for packet flow handling.
Definition: flow.c:557
FlowAddress_::address_un_data32
uint32_t address_un_data32[4]
Definition: flow.h:311
SCLogDebug
#define SCLogDebug(...)
Definition: util-debug.h:282
FlowLookupStruct
struct FlowLookupStruct_ FlowLookupStruct
Flow_::esp
struct Flow_::@121::@128 esp
Flow_::proto
uint8_t proto
Definition: flow.h:369
AppProto
uint16_t AppProto
Definition: app-layer-protos.h:86
FlowInitConfig
void FlowInitConfig(bool)
initialize the configuration
Definition: flow.c:571
FlowGetPacketDirection
int FlowGetPacketDirection(const Flow *, const Packet *)
determine the direction of the packet compared to the flow
Definition: flow.c:286
FlowClearMemory
int FlowClearMemory(Flow *, uint8_t)
Function clear the flow memory before queueing it to spare flow queue.
Definition: flow.c:1121
Flow_
Flow data structure.
Definition: flow.h:347
Flow_::protomap
uint8_t protomap
Definition: flow.h:438
LiveDevice_
Definition: util-device-private.h:32
FlowProtoTimeout_
Definition: flow.h:511
FLOW_NOPAYLOAD_INSPECTION
#define FLOW_NOPAYLOAD_INSPECTION
Definition: flow.h:66
FlowLookupStruct_
Definition: flow.h:535
Flow_::alproto_orig
AppProto alproto_orig
Definition: flow.h:449
Flow
struct Flow_ Flow
Flow data structure.
util-exception-policy-types.h
FlowProtoTimeout_::bypassed_timeout
uint32_t bypassed_timeout
Definition: flow.h:515
FlowBypassInfo_::tosrcbytecnt
uint64_t tosrcbytecnt
Definition: flow.h:527
Address_
Definition: decode.h:112
FlowSetupPacket
void FlowSetupPacket(Packet *p)
prepare packet for a life with flow Set PKT_WANTS_FLOW flag to indicate workers should do a flow look...
Definition: flow-hash.c:533
Flow_::max_ttl_toserver
uint8_t max_ttl_toserver
Definition: flow.h:461
Flow_::dp
Port dp
Definition: flow.h:363
Flow_::protoctx
void * protoctx
Definition: flow.h:426
FlowUnsetChangeProtoFlag
void FlowUnsetChangeProtoFlag(Flow *)
Unset flag to indicate to change proto for the flow.
Definition: flow.c:187
util-var.h
Storage
Definition: util-storage.h:40
FlowCnf_::prealloc
uint32_t prealloc
Definition: flow.h:286
Flow_::flow_state
FlowStateType flow_state
Definition: flow.h:413
Flow_::spi
uint32_t spi
Definition: flow.h:359
Flow_::sgh_toserver
const struct SigGroupHead_ * sgh_toserver
Definition: flow.h:479
FlowLookupStruct_::emerg_spare_sync_stamp
uint32_t emerg_spare_sync_stamp
Definition: flow.h:540
Flow_::tosrcbytecnt
uint64_t tosrcbytecnt
Definition: flow.h:491
FlowConfig
struct FlowCnf_ FlowConfig
Flow_::alparser
AppLayerParserState * alparser
Definition: flow.h:471
Flow_::dst
FlowAddress dst
Definition: flow.h:350
FlowProtoFreeFunc
struct FlowProtoFreeFunc_ FlowProtoFreeFunc
Flow_::fb
struct FlowBucket_ * fb
Definition: flow.h:484
FLOW_STATE_LOCAL_BYPASSED
@ FLOW_STATE_LOCAL_BYPASSED
Definition: flow.h:500
Flow_::min_ttl_toserver
uint8_t min_ttl_toserver
Definition: flow.h:460
Flow_::protodetect_dp
uint16_t protodetect_dp
Definition: flow.h:402
decode.h
FlowBypassInfo_::todstbytecnt
uint64_t todstbytecnt
Definition: flow.h:529
AppLayerParserState_
Definition: app-layer-parser.c:135
RegisterFlowBypassInfo
void RegisterFlowBypassInfo(void)
Definition: flow-util.c:240
FlowBypassInfo_::BypassUpdate
bool(* BypassUpdate)(Flow *f, void *data, time_t tsec)
Definition: flow.h:523
FlowBypassInfo_::BypassFree
void(* BypassFree)(void *data)
Definition: flow.h:524
Flow_::todstpktcnt
uint32_t todstpktcnt
Definition: flow.h:488
util-exception-policy.h
Flow_::lastts
SCTime_t lastts
Definition: flow.h:411
FlowSwap
void FlowSwap(Flow *)
swap the flow's direction
Definition: flow.c:246
FlowKey_::recursion_level
uint8_t recursion_level
Definition: flow.h:304
SCEnter
#define SCEnter(...)
Definition: util-debug.h:284
ThreadVars_
Per thread variable structure.
Definition: threadvars.h:58
FlowShutdown
void FlowShutdown(void)
shutdown the flow engine
Definition: flow.c:715
FlowGetMemuse
uint64_t FlowGetMemuse(void)
Definition: flow.c:129
Flow_::flow_end_flags
uint8_t flow_end_flags
Definition: flow.h:440
FlowCnf_
Definition: flow.h:283
FlowState
FlowState
Definition: flow.h:496
FlowBypassInfo_::todstpktcnt
uint64_t todstpktcnt
Definition: flow.h:528
FlowProtoTimeout_::new_timeout
uint32_t new_timeout
Definition: flow.h:512
FlowProtoTimeout_::closed_timeout
uint32_t closed_timeout
Definition: flow.h:514
util-time.h
FlowBypassInfo_::bypass_data
void * bypass_data
Definition: flow.h:525
Flow_::m
SCMutex m
Definition: flow.h:431
FlowBypassInfo
struct FlowBypassInfo_ FlowBypassInfo
FlowCnf_::timeout_new
uint32_t timeout_new
Definition: flow.h:288
FlowKey_::livedev_id
uint16_t livedev_id
Definition: flow.h:305
Flow_::todstbytecnt
uint64_t todstbytecnt
Definition: flow.h:490
Flow_::sgh_toclient
const struct SigGroupHead_ * sgh_toclient
Definition: flow.h:476
FlowChangeProto
int FlowChangeProto(Flow *)
Check if change proto flag is set for flow.
Definition: flow.c:197
FlowThreadId
uint16_t FlowThreadId
Definition: flow.h:324
FlowKey_::sp
Port sp
Definition: flow.h:302
SCReturn
#define SCReturn
Definition: util-debug.h:286
Packet_
Definition: decode.h:501
Flow_::type
uint8_t type
Definition: flow.h:354
FlowRegisterTests
void FlowRegisterTests(void)
Function to register the Flow Unitests.
Definition: flow.c:1469
Port
uint16_t Port
Definition: decode.h:218
SCTime_t
Definition: util-time.h:40
FlowProtoFreeFunc_::Freefunc
void(* Freefunc)(void *)
Definition: flow.h:519
FlowAddress_::address_un_data16
uint16_t address_un_data16[8]
Definition: flow.h:312
FlowCnf_::hash_rand
uint32_t hash_rand
Definition: flow.h:284
Flow_::vlan_idx
uint8_t vlan_idx
Definition: flow.h:373
FlowHandlePacketUpdate
void FlowHandlePacketUpdate(Flow *f, Packet *p, ThreadVars *tv, DecodeThreadVars *dtv)
Update Packet and Flow.
Definition: flow.c:424
Flow_::min_ttl_toclient
uint8_t min_ttl_toclient
Definition: flow.h:462
flow-queue.h
FlowCleanupAppLayer
void FlowCleanupAppLayer(Flow *)
Definition: flow.c:140
FlowBypassInfo_::tosrcpktcnt
uint64_t tosrcpktcnt
Definition: flow.h:526
Flow_::probing_parser_toclient_alproto_masks
uint32_t probing_parser_toclient_alproto_masks
Definition: flow.h:420
FlowCnf_::SC_ATOMIC_DECLARE
SC_ATOMIC_DECLARE(uint64_t, memcap)
Flow_::flow_hash
uint32_t flow_hash
Definition: flow.h:389
Flow_::alproto_expect
AppProto alproto_expect
Definition: flow.h:452
GetFlowBypassInfoID
FlowStorageId GetFlowBypassInfoID(void)
Definition: flow-util.c:222
Flow_::src
FlowAddress src
Definition: flow.h:350
Flow_::flowvar
GenericVar * flowvar
Definition: flow.h:482
FlowReset
void FlowReset(void)
Definition: flow.c:697
Flow_::next
struct Flow_ * next
Definition: flow.h:394
Flow_::probing_parser_toserver_alproto_masks
uint32_t probing_parser_toserver_alproto_masks
Definition: flow.h:419
dtv
DecodeThreadVars * dtv
Definition: fuzz_decodepcapfile.c:34
FlowLookupStruct_::spare_queue
FlowQueuePrivate spare_queue
Definition: flow.h:537
FlowProtoTimeout
struct FlowProtoTimeout_ FlowProtoTimeout
Flow_::ffr
uint8_t ffr
Definition: flow.h:381
FlowStateType
unsigned short FlowStateType
Definition: flow.h:321
flags
uint8_t flags
Definition: decode-gre.h:0
Flow_::applied_exception_policy
uint8_t applied_exception_policy
Definition: flow.h:466
FLOW_STATE_NEW
@ FLOW_STATE_NEW
Definition: flow.h:497
Flow_::icmp_d
struct Flow_::@123::@129 icmp_d
Flow_::code
uint8_t code
Definition: flow.h:355
GenericVar_
Definition: util-var.h:53
FlowAddress
struct FlowAddress_ FlowAddress
FlowKey_::dst
Address dst
Definition: flow.h:301
SCTIME_SECS
#define SCTIME_SECS(t)
Definition: util-time.h:57
FlowGetMemcapExceptionPolicy
enum ExceptionPolicy FlowGetMemcapExceptionPolicy(void)
Definition: flow.c:135
VLAN_MAX_LAYERS
#define VLAN_MAX_LAYERS
Definition: decode-vlan.h:51
Flow_::max_ttl_toclient
uint8_t max_ttl_toclient
Definition: flow.h:463
Flow_::parent_id
int64_t parent_id
Definition: flow.h:423
FlowCnf_::timeout_est
uint32_t timeout_est
Definition: flow.h:289
Flow_::timeout_policy
uint32_t timeout_policy
Definition: flow.h:406
tv
ThreadVars * tv
Definition: fuzz_decodepcapfile.c:33
Flow_::livedev
struct LiveDevice_ * livedev
Definition: flow.h:392
util-optimize.h
util-validate.h
FlowQueuePrivate_
Definition: flow-queue.h:40
FlowCnf_::memcap_policy
enum ExceptionPolicy memcap_policy
Definition: flow.h:293
FlowAddress_::address_un_data8
uint8_t address_un_data8[16]
Definition: flow.h:313
FlowKey_::proto
uint8_t proto
Definition: flow.h:303
FLOW_STATE_CLOSED
@ FLOW_STATE_CLOSED
Definition: flow.h:499
FlowAddress_::address
union FlowAddress_::@120 address
DecodeThreadVars_
Structure to hold thread specific data for all decode modules.
Definition: decode.h:959
Flow_::alproto_ts
AppProto alproto_ts
Definition: flow.h:444
Flow_::alstate
void * alstate
Definition: flow.h:472
SCRWLock
#define SCRWLock
Definition: threads-debug.h:364
FlowGetMemcap
uint64_t FlowGetMemcap(void)
Return memcap value.
Definition: flow.c:123
FlowKey_
Definition: flow.h:300
app-layer-protos.h
Flow_::vlan_id
uint16_t vlan_id[VLAN_MAX_LAYERS]
Definition: flow.h:371
likely
#define likely(expr)
Definition: util-optimize.h:32
Flow_::icmp_s
struct Flow_::@121::@127 icmp_s
FlowProtoTimeout_::est_timeout
uint32_t est_timeout
Definition: flow.h:513
Flow_::sp
Port sp
Definition: flow.h:352
FlowKey_::vlan_id
uint16_t vlan_id[VLAN_MAX_LAYERS]
Definition: flow.h:306
Flow_::alproto_tc
AppProto alproto_tc
Definition: flow.h:445
FlowSetChangeProtoFlag
void FlowSetChangeProtoFlag(Flow *)
Set flag to indicate to change proto for the flow.
Definition: flow.c:178
Flow_::file_flags
uint16_t file_flags
Definition: flow.h:398
Flow_::alproto
AppProto alproto
application level protocol
Definition: flow.h:443
FlowUpdateState
void FlowUpdateState(Flow *f, enum FlowState s)
Definition: flow.c:1186
ExceptionPolicy
ExceptionPolicy
Definition: util-exception-policy-types.h:26
FlowKey_::dp
Port dp
Definition: flow.h:302
Flow_::storage
Storage storage[]
Definition: flow.h:493
FlowKey
struct FlowKey_ FlowKey
SCMutex
#define SCMutex
Definition: threads-debug.h:114
DEBUG_VALIDATE_BUG_ON
#define DEBUG_VALIDATE_BUG_ON(exp)
Definition: util-validate.h:102
FlowSetProtoFreeFunc
int FlowSetProtoFreeFunc(uint8_t, void(*Free)(void *))
Function to set the function to get protocol specific flow state.
Definition: flow.c:1149
Flow_::tenant_id
uint32_t tenant_id
Definition: flow.h:417
Flow_::tosrcpktcnt
uint32_t tosrcpktcnt
Definition: flow.h:489
FlowSetHasAlertsFlag
void FlowSetHasAlertsFlag(Flow *)
Set flag to indicate that flow has alerts.
Definition: flow.c:154
util-storage.h
Flow_::thread_id
FlowThreadId thread_id[2]
Definition: flow.h:385
FlowHasAlerts
int FlowHasAlerts(const Flow *)
Check if flow has alerts.
Definition: flow.c:165
SCTIME_USECS
#define SCTIME_USECS(t)
Definition: util-time.h:56
FlowProtoFreeFunc_
Definition: flow.h:518
Flow_::de_ctx_version
uint32_t de_ctx_version
Definition: flow.h:457