suricata
app-layer-frames.h
Go to the documentation of this file.
1 /* Copyright (C) 2021 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_APP_LAYER_FRAMES_H
25 #define SURICATA_APP_LAYER_FRAMES_H
26 
27 /** special value for matching any type */
28 #define FRAME_ANY_TYPE 62
29 /** max 63 to fit the 64 bit per protocol space */
30 #define FRAME_STREAM_TYPE 63
31 
32 typedef int64_t FrameId;
33 
34 enum {
36 #define FRAME_FLAG_TX_ID_SET BIT_U8(FRAME_FLAGE_TX_ID_SET)
38 #define FRAME_FLAG_ENDS_AT_EOF BIT_U8(FRAME_FLAGE_ENDS_AT_EOF)
40 #define FRAME_FLAG_LOGGED BIT_U8(FRAME_FLAGE_LOGGED)
41 };
42 
43 typedef struct Frame {
44  uint8_t type; /**< protocol specific field type. E.g. NBSS.HDR or SMB.DATA */
45  uint8_t flags; /**< frame flags: FRAME_FLAG_* */
46  uint8_t event_cnt;
47  // TODO one event per frame enough?
48  uint8_t events[4]; /**< per frame store for events */
49  uint64_t offset; /**< offset from the start of the stream */
50  int64_t len;
51  int64_t id;
52  uint64_t tx_id; /**< tx_id to match this frame. UINT64T_MAX if not used. */
53  uint64_t inspect_progress; /**< inspection tracker relative to the start of the frame */
55 
56 #define FRAMES_STATIC_CNT 3
57 
58 typedef struct Frames {
59  uint16_t cnt;
60  uint16_t dyn_size; /**< size in elements of `dframes` */
61  uint32_t left_edge_rel;
62  uint64_t base_id;
63  Frame sframes[FRAMES_STATIC_CNT]; /**< static frames */
64  Frame *dframes; /**< dynamically allocated space for more frames */
65 #ifdef DEBUG
66  uint8_t ipproto;
67  AppProto alproto;
68 #endif
70 
71 typedef struct FramesContainer {
75 
76 void FramesFree(Frames *frames);
77 #ifndef SURICATA_BINDGEN_H
78 // do not let bindgen see Packet
79 void FramesPrune(Flow *f, Packet *p);
80 #endif
81 
82 Frame *AppLayerFrameNewByPointer(Flow *f, const StreamSlice *stream_slice,
83  const uint8_t *frame_start, const int64_t len, int dir, uint8_t frame_type);
84 Frame *SCAppLayerFrameNewByRelativeOffset(Flow *f, const void *stream_slice,
85  const uint32_t frame_start_rel, const int64_t len, int dir, uint8_t frame_type);
87  const uint64_t frame_start, const int64_t len, int dir, uint8_t frame_type);
88 void AppLayerFrameDump(Flow *f);
89 
90 Frame *FrameGetByIndex(Frames *frames, const uint32_t idx);
91 Frame *FrameGetById(Frames *frames, const int64_t id);
92 Frame *FrameGetLastOpenByType(Frames *frames, const uint8_t frame_type);
93 
94 Frame *AppLayerFrameGetById(const Flow *f, const int direction, const FrameId frame_id);
95 Frame *AppLayerFrameGetLastOpenByType(Flow *f, const int direction, const uint8_t frame_type);
96 
97 void AppLayerFrameAddEvent(Frame *frame, uint8_t e);
98 void SCAppLayerFrameAddEventById(const Flow *f, const int dir, const FrameId id, uint8_t e);
99 void AppLayerFrameSetLength(Frame *frame, int64_t len);
100 void SCAppLayerFrameSetLengthById(const Flow *f, const int dir, const FrameId id, int64_t len);
101 void AppLayerFrameSetTxId(Frame *r, uint64_t tx_id);
102 void SCAppLayerFrameSetTxIdById(const Flow *f, const int dir, const FrameId id, uint64_t tx_id);
103 
104 void AppLayerFramesSlide(Flow *f, const uint32_t slide, const uint8_t direction);
105 
108 
109 void FrameConfigInit(void);
110 void FrameConfigDeInit(void);
111 void FrameConfigEnableAll(void);
112 void FrameConfigEnable(const AppProto p, const uint8_t type);
113 
114 #endif
Frame::inspect_progress
uint64_t inspect_progress
Definition: app-layer-frames.h:53
len
uint8_t len
Definition: app-layer-dnp3.h:2
Frame::tx_id
uint64_t tx_id
Definition: app-layer-frames.h:52
StreamSlice
struct StreamSlice StreamSlice
Definition: app-layer-parser.h:38
AppLayerFramesGetContainer
FramesContainer * AppLayerFramesGetContainer(const Flow *f)
Definition: app-layer-parser.c:184
FrameConfigDeInit
void FrameConfigDeInit(void)
Definition: app-layer-frames.c:51
FrameConfigInit
void FrameConfigInit(void)
Definition: app-layer-frames.c:40
Frame::events
uint8_t events[4]
Definition: app-layer-frames.h:48
AppProto
uint16_t AppProto
Definition: app-layer-protos.h:86
FramesContainer::toserver
Frames toserver
Definition: app-layer-frames.h:72
AppLayerFramesSetupContainer
FramesContainer * AppLayerFramesSetupContainer(Flow *f)
Definition: app-layer-parser.c:191
Frame::offset
uint64_t offset
Definition: app-layer-frames.h:49
Frame
Definition: app-layer-frames.h:43
Flow_
Flow data structure.
Definition: flow.h:348
Frames::cnt
uint16_t cnt
Definition: app-layer-frames.h:59
FrameGetLastOpenByType
Frame * FrameGetLastOpenByType(Frames *frames, const uint8_t frame_type)
Definition: app-layer-frames.c:102
Frame::id
int64_t id
Definition: app-layer-frames.h:51
FramesFree
void FramesFree(Frames *frames)
Definition: app-layer-frames.c:454
Frames
Definition: app-layer-frames.h:58
FramesContainer
Definition: app-layer-frames.h:71
AppLayerFramesSlide
void AppLayerFramesSlide(Flow *f, const uint32_t slide, const uint8_t direction)
Definition: app-layer-frames.c:409
FramesContainer
struct FramesContainer FramesContainer
Frames::left_edge_rel
uint32_t left_edge_rel
Definition: app-layer-frames.h:61
SCAppLayerFrameAddEventById
void SCAppLayerFrameAddEventById(const Flow *f, const int dir, const FrameId id, uint8_t e)
Definition: app-layer-frames.c:661
FrameGetById
Frame * FrameGetById(Frames *frames, const int64_t id)
Definition: app-layer-frames.c:125
FrameConfigEnableAll
void FrameConfigEnableAll(void)
Definition: app-layer-frames.c:56
AppLayerFrameNewByAbsoluteOffset
Frame * AppLayerFrameNewByAbsoluteOffset(Flow *f, const StreamSlice *stream_slice, const uint64_t frame_start, const int64_t len, int dir, uint8_t frame_type)
create new frame using the absolute offset from the start of the stream
Definition: app-layer-frames.c:609
Frames::dframes
Frame * dframes
Definition: app-layer-frames.h:64
AppLayerFrameGetById
Frame * AppLayerFrameGetById(const Flow *f, const int direction, const FrameId frame_id)
Definition: app-layer-frames.c:696
SCAppLayerFrameSetTxIdById
void SCAppLayerFrameSetTxIdById(const Flow *f, const int dir, const FrameId id, uint64_t tx_id)
Definition: app-layer-frames.c:690
FramesContainer::toclient
Frames toclient
Definition: app-layer-frames.h:73
AppLayerFrameAddEvent
void AppLayerFrameAddEvent(Frame *frame, uint8_t e)
Definition: app-layer-frames.c:651
AppLayerFrameDump
void AppLayerFrameDump(Flow *f)
Definition: app-layer-frames.c:594
AppLayerFrameSetTxId
void AppLayerFrameSetTxId(Frame *r, uint64_t tx_id)
Definition: app-layer-frames.c:681
Frames
struct Frames Frames
FrameId
int64_t FrameId
Definition: app-layer-frames.h:32
FRAMES_STATIC_CNT
#define FRAMES_STATIC_CNT
Definition: app-layer-frames.h:56
Packet_
Definition: decode.h:501
type
uint16_t type
Definition: decode-vlan.c:106
FRAME_FLAGE_LOGGED
@ FRAME_FLAGE_LOGGED
Definition: app-layer-frames.h:39
FramesPrune
void FramesPrune(Flow *f, Packet *p)
Definition: app-layer-frames.c:836
AppLayerFrameSetLength
void AppLayerFrameSetLength(Frame *frame, int64_t len)
Definition: app-layer-frames.c:667
Frame::len
int64_t len
Definition: app-layer-frames.h:50
Frame
struct Frame Frame
AppLayerFrameNewByPointer
Frame * AppLayerFrameNewByPointer(Flow *f, const StreamSlice *stream_slice, const uint8_t *frame_start, const int64_t len, int dir, uint8_t frame_type)
create new frame using a pointer to start of the frame
Definition: app-layer-frames.c:464
FrameConfigEnable
void FrameConfigEnable(const AppProto p, const uint8_t type)
Definition: app-layer-frames.c:65
Frame::flags
uint8_t flags
Definition: app-layer-frames.h:45
FrameGetByIndex
Frame * FrameGetByIndex(Frames *frames, const uint32_t idx)
Definition: app-layer-frames.c:145
Frame::type
uint8_t type
Definition: app-layer-frames.h:44
Frame::event_cnt
uint8_t event_cnt
Definition: app-layer-frames.h:46
Frames::sframes
Frame sframes[FRAMES_STATIC_CNT]
Definition: app-layer-frames.h:63
FRAME_FLAGE_TX_ID_SET
@ FRAME_FLAGE_TX_ID_SET
Definition: app-layer-frames.h:35
Frames::base_id
uint64_t base_id
Definition: app-layer-frames.h:62
SCAppLayerFrameNewByRelativeOffset
Frame * SCAppLayerFrameNewByRelativeOffset(Flow *f, const void *stream_slice, const uint32_t frame_start_rel, const int64_t len, int dir, uint8_t frame_type)
create new frame using a relative offset from the start of the stream slice
Definition: app-layer-frames.c:543
FRAME_FLAGE_ENDS_AT_EOF
@ FRAME_FLAGE_ENDS_AT_EOF
Definition: app-layer-frames.h:37
AppLayerFrameGetLastOpenByType
Frame * AppLayerFrameGetLastOpenByType(Flow *f, const int direction, const uint8_t frame_type)
Definition: app-layer-frames.c:714
Frames::dyn_size
uint16_t dyn_size
Definition: app-layer-frames.h:60
SCAppLayerFrameSetLengthById
void SCAppLayerFrameSetLengthById(const Flow *f, const int dir, const FrameId id, int64_t len)
Definition: app-layer-frames.c:675