suricata
|
#include "suricata-common.h"
#include "suricata.h"
#include "app-layer.h"
#include "app-layer-parser.h"
#include "app-layer-protos.h"
#include "app-layer-expectation.h"
#include "app-layer-ftp.h"
#include "app-layer-detect-proto.h"
#include "app-layer-frames.h"
#include "stream-tcp-reassemble.h"
#include "stream-tcp-private.h"
#include "stream-tcp-inline.h"
#include "stream-tcp.h"
#include "flow.h"
#include "flow-util.h"
#include "flow-private.h"
#include "ippair.h"
#include "util-debug.h"
#include "util-print.h"
#include "util-profiling.h"
#include "util-validate.h"
#include "decode-events.h"
#include "app-layer-htp-mem.h"
#include "util-exception-policy.h"
#include "pkt-var.h"
#include "stream-tcp-util.h"
#include "stream.h"
#include "util-unittest.h"
Go to the source code of this file.
Data Structures | |
struct | AppLayerThreadCtx_ |
This is for the app layer in general and it contains per thread context relevant to both the alpd and alp. More... | |
struct | AppLayerCounterNames_ |
struct | AppLayerCounters_ |
Macros | |
#define | FLOW_PROTO_CHANGE_MAX_DEPTH 4096 |
#define | MAX_COUNTER_SIZE 64 |
#define | TEST_START |
#define | TEST_END |
Typedefs | |
typedef struct AppLayerCounterNames_ | AppLayerCounterNames |
typedef struct AppLayerCounters_ | AppLayerCounters |
Functions | |
void | AppLayerSetupCounters (void) |
void | AppLayerDeSetupCounters (void) |
void | AppLayerIncTxCounter (ThreadVars *tv, Flow *f, uint64_t step) |
void | AppLayerIncGapErrorCounter (ThreadVars *tv, Flow *f) |
void | AppLayerIncAllocErrorCounter (ThreadVars *tv, Flow *f) |
void | AppLayerIncParserErrorCounter (ThreadVars *tv, Flow *f) |
void | AppLayerIncInternalErrorCounter (ThreadVars *tv, Flow *f) |
int | AppLayerHandleTCPData (ThreadVars *tv, TcpReassemblyThreadCtx *ra_ctx, Packet *p, Flow *f, TcpSession *ssn, TcpStream **stream, uint8_t *data, uint32_t data_len, uint8_t flags, enum StreamUpdateDir app_update_dir) |
handle TCP data for the app-layer. More... | |
int | AppLayerHandleUdp (ThreadVars *tv, AppLayerThreadCtx *tctx, Packet *p, Flow *f) |
Handle a app layer UDP message. More... | |
AppProto | AppLayerGetProtoByName (char *alproto_name) |
Given a protocol string, returns the corresponding internal protocol id. More... | |
const char * | AppLayerGetProtoName (AppProto alproto) |
Given the internal protocol id, returns a string representation of the protocol. More... | |
void | AppLayerListSupportedProtocols (void) |
int | AppLayerSetup (void) |
Setup the app layer. More... | |
int | AppLayerDeSetup (void) |
De initializes the app layer. More... | |
AppLayerThreadCtx * | AppLayerGetCtxThread (void) |
Creates a new app layer thread context. More... | |
void | AppLayerDestroyCtxThread (AppLayerThreadCtx *app_tctx) |
Destroys the context created by AppLayerGetCtxThread(). More... | |
void | AppLayerProfilingResetInternal (AppLayerThreadCtx *app_tctx) |
void | AppLayerProfilingStoreInternal (AppLayerThreadCtx *app_tctx, Packet *p) |
void | AppLayerRegisterGlobalCounters (void) |
HACK to work around our broken unix manager (re)init loop. More... | |
void | AppLayerRegisterThreadCounters (ThreadVars *tv) |
Registers per flow counters for all protocols. More... | |
void | AppLayerUnittestsRegister (void) |
Generic App-layer functions
Definition in file app-layer.c.
#define FLOW_PROTO_CHANGE_MAX_DEPTH 4096 |
Definition at line 75 of file app-layer.c.
#define MAX_COUNTER_SIZE 64 |
Definition at line 77 of file app-layer.c.
#define TEST_END |
Definition at line 1403 of file app-layer.c.
#define TEST_START |
Definition at line 1321 of file app-layer.c.
typedef struct AppLayerCounterNames_ AppLayerCounterNames |
typedef struct AppLayerCounters_ AppLayerCounters |
int AppLayerDeSetup | ( | void | ) |
De initializes the app layer.
Includes de initializing protocol detection and the protocol parser.
Definition at line 1046 of file app-layer.c.
References AppLayerDeSetupCounters(), AppLayerParserDeSetup(), AppLayerProtoDetectDeSetup(), SCEnter, and SCReturnInt.
Referenced by GlobalsDestroy().
void AppLayerDeSetupCounters | ( | void | ) |
Definition at line 1306 of file app-layer.c.
References applayer_counter_names, and applayer_counters.
Referenced by AppLayerDeSetup().
void AppLayerDestroyCtxThread | ( | AppLayerThreadCtx * | tctx | ) |
Destroys the context created by AppLayerGetCtxThread().
tctx | Pointer to the thread context to destroy. |
Definition at line 1079 of file app-layer.c.
References AppLayerThreadCtx_::alp_tctx, AppLayerThreadCtx_::alpd_tctx, AppLayerParserThreadCtxFree(), AppLayerProtoDetectDestroyCtxThread(), SCEnter, SCFree, and SCReturn.
Referenced by AppLayerGetCtxThread(), DecodeThreadVarsFree(), and StreamTcpReassembleFreeThreadCtx().
AppLayerThreadCtx* AppLayerGetCtxThread | ( | void | ) |
Creates a new app layer thread context.
Pointer | to the newly create thread context, on success; NULL, on failure. |
Definition at line 1058 of file app-layer.c.
References AppLayerThreadCtx_::alp_tctx, AppLayerThreadCtx_::alpd_tctx, AppLayerDestroyCtxThread(), AppLayerParserThreadCtxAlloc(), AppLayerProtoDetectGetCtxThread(), SCCalloc, SCEnter, and SCReturnPtr.
Referenced by DecodeThreadVarsAlloc(), and StreamTcpReassembleInitThreadCtx().
AppProto AppLayerGetProtoByName | ( | char * | alproto_name | ) |
Given a protocol string, returns the corresponding internal protocol id.
The | internal protocol id. |
Definition at line 997 of file app-layer.c.
References AppLayerProtoDetectGetProtoByName(), SCEnter, and SCReturnCT.
const char* AppLayerGetProtoName | ( | AppProto | alproto | ) |
Given the internal protocol id, returns a string representation of the protocol.
alproto | The internal protocol id. |
String | representation of the protocol. |
Definition at line 1004 of file app-layer.c.
References AppLayerProtoDetectGetProtoName(), SCEnter, and SCReturnCT.
Referenced by AppLayerListSupportedProtocols().
int AppLayerHandleTCPData | ( | ThreadVars * | tv, |
TcpReassemblyThreadCtx * | ra_ctx, | ||
Packet * | p, | ||
Flow * | f, | ||
TcpSession * | ssn, | ||
TcpStream ** | stream, | ||
uint8_t * | data, | ||
uint32_t | data_len, | ||
uint8_t | flags, | ||
enum StreamUpdateDir | app_update_dir | ||
) |
handle TCP data for the app-layer.
Handles reassembled tcp stream.
First run protocol detection and then when the protocol is known invoke the app layer parser.
stream | ptr-to-ptr to stream object. Might change if flow dir is reversed. |
Definition at line 707 of file app-layer.c.
References Flow_::alproto, Flow_::alproto_tc, Flow_::alproto_ts, ALPROTO_UNKNOWN, TcpReassemblyThreadCtx_::app_tctx, DEBUG_ASSERT_FLOW_LOCKED, DEBUG_VALIDATE_BUG_ON, flags, TcpSession_::flags, SCEnter, SCLogDebug, STREAMTCP_FLAG_APP_LAYER_DISABLED, and StreamTcpSetStreamFlagAppProtoDetectionCompleted.
Referenced by StreamTcpReassembleAppLayer().
int AppLayerHandleUdp | ( | ThreadVars * | tv, |
AppLayerThreadCtx * | tctx, | ||
Packet * | p, | ||
Flow * | f | ||
) |
Handle a app layer UDP message.
Handles an udp chunk.
If the protocol is yet unknown, the proto detection code is run first.
dp_ctx | Thread app layer detect context |
f | locked flow |
p | UDP packet |
0 | ok |
-1 | error |
Definition at line 873 of file app-layer.c.
References AppLayerThreadCtx_::alpd_tctx, Flow_::alproto, ALPROTO_FAILED, Flow_::alproto_tc, Flow_::alproto_ts, ALPROTO_UNKNOWN, Packet_::app_layer_events, APPLAYER_MISMATCH_PROTOCOL_BOTH_DIRECTIONS, AppLayerDecoderEventsSetEventRaw(), AppLayerProfilingReset, AppLayerProtoDetectGetProto(), flags, FLOW_PKT_TOSERVER, Packet_::flowflags, PACKET_PROFILING_APP_PD_END, PACKET_PROFILING_APP_PD_START, Packet_::payload, Packet_::payload_len, SCEnter, SCLogDebug, and SCReturnInt.
void AppLayerIncAllocErrorCounter | ( | ThreadVars * | tv, |
Flow * | f | ||
) |
Definition at line 169 of file app-layer.c.
References AppLayerCounters_::alloc_error_id, Flow_::alproto, applayer_counters, likely, Flow_::protomap, StatsIncr(), and tv.
void AppLayerIncGapErrorCounter | ( | ThreadVars * | tv, |
Flow * | f | ||
) |
Definition at line 161 of file app-layer.c.
References Flow_::alproto, applayer_counters, AppLayerCounters_::gap_error_id, likely, Flow_::protomap, StatsIncr(), and tv.
void AppLayerIncInternalErrorCounter | ( | ThreadVars * | tv, |
Flow * | f | ||
) |
Definition at line 185 of file app-layer.c.
References Flow_::alproto, applayer_counters, AppLayerCounters_::internal_error_id, likely, Flow_::protomap, StatsIncr(), and tv.
void AppLayerIncParserErrorCounter | ( | ThreadVars * | tv, |
Flow * | f | ||
) |
Definition at line 177 of file app-layer.c.
References Flow_::alproto, applayer_counters, likely, AppLayerCounters_::parser_error_id, Flow_::protomap, StatsIncr(), and tv.
void AppLayerIncTxCounter | ( | ThreadVars * | tv, |
Flow * | f, | ||
uint64_t | step | ||
) |
Definition at line 153 of file app-layer.c.
References Flow_::alproto, applayer_counters, AppLayerCounters_::counter_tx_id, likely, Flow_::protomap, StatsAddUI64(), and tv.
void AppLayerListSupportedProtocols | ( | void | ) |
Definition at line 1011 of file app-layer.c.
References ALPROTO_MAX, AppLayerGetProtoName(), AppLayerProtoDetectSupportedAppProtocols(), SCEnter, and SCReturn.
Referenced by ListAppLayerProtocols().
void AppLayerProfilingResetInternal | ( | AppLayerThreadCtx * | app_tctx | ) |
Definition at line 1096 of file app-layer.c.
References PACKET_PROFILING_APP_RESET.
void AppLayerProfilingStoreInternal | ( | AppLayerThreadCtx * | app_tctx, |
Packet * | p | ||
) |
Definition at line 1101 of file app-layer.c.
References PACKET_PROFILING_APP_STORE.
void AppLayerRegisterGlobalCounters | ( | void | ) |
HACK to work around our broken unix manager (re)init loop.
Definition at line 1109 of file app-layer.c.
References ExpectationGetCounter(), FTPMemcapGlobalCounter(), FTPMemuseGlobalCounter(), HTPMemcapGlobalCounter(), HTPMemuseGlobalCounter(), and StatsRegisterGlobalCounter().
Referenced by PreRunInit().
void AppLayerRegisterThreadCounters | ( | ThreadVars * | tv | ) |
Registers per flow counters for all protocols.
Definition at line 1242 of file app-layer.c.
References ALPROTO_MAX, AppLayerProtoDetectSupportedAppProtocols(), EXCEPTION_POLICY_MAX, EXCEPTION_POLICY_NOT_SET, and g_applayerparser_error_policy.
int AppLayerSetup | ( | void | ) |
Setup the app layer.
Includes protocol detection setup and the protocol parser setup.
0 | On success. |
-1 | On failure. |
Definition at line 1031 of file app-layer.c.
References AppLayerParserRegisterProtocolParsers(), AppLayerParserSetup(), AppLayerProtoDetectPrepareState(), AppLayerProtoDetectSetup(), AppLayerSetupCounters(), SCEnter, and SCReturnInt.
Referenced by ListAppLayerProtocols(), ListKeywords(), PostConfLoadedSetup(), and RunUnittests().
void AppLayerSetupCounters | ( | void | ) |
Definition at line 1142 of file app-layer.c.
References ALPROTO_MAX, EXCEPTION_POLICY_MAX, EXCEPTION_POLICY_NOT_SET, g_applayerparser_error_policy, and str.
Referenced by AppLayerSetup().
void AppLayerUnittestsRegister | ( | void | ) |
Definition at line 2945 of file app-layer.c.
References SCEnter, and UtRegisterTest().
ExceptionPolicyStatsSetts app_layer_error_eps_stats |
Definition at line 106 of file app-layer.c.
AppLayerCounterNames applayer_counter_names[FLOW_PROTO_APPLAYER_MAX][ALPROTO_MAX] |
Definition at line 98 of file app-layer.c.
Referenced by AppLayerDeSetupCounters().
AppLayerCounters applayer_counters[FLOW_PROTO_APPLAYER_MAX][ALPROTO_MAX] |
Definition at line 100 of file app-layer.c.
Referenced by AppLayerDeSetupCounters(), AppLayerIncAllocErrorCounter(), AppLayerIncGapErrorCounter(), AppLayerIncInternalErrorCounter(), AppLayerIncParserErrorCounter(), and AppLayerIncTxCounter().
ExceptionPolicyCounters eps_error_summary |
Definition at line 102 of file app-layer.c.
enum ExceptionPolicy g_applayerparser_error_policy |
Definition at line 1 of file app-layer-parser.c.
Referenced by AppLayerRegisterThreadCounters(), and AppLayerSetupCounters().
bool g_stats_eps_per_app_proto_errors |
add per-proto app-layer error counters for exception policies stats? disabled by default
Definition at line 214 of file suricata.c.
Referenced by PostConfLoadedSetup().