Go to the documentation of this file.
42 static int g_tcphdr_buffer_id = 0;
62 BUG_ON(g_tcphdr_buffer_id < 0);
101 if (!PacketIsTCP(p)) {
106 const TCPHdr *tcph = PacketGetTCP(p);
108 if (((uint8_t *)tcph + (ptrdiff_t)hlen) >
110 SCLogDebug(
"data out of range: %p > %p", ((uint8_t *)tcph + (ptrdiff_t)hlen),
115 const uint32_t data_len = hlen;
116 const uint8_t *data = (
const uint8_t *)tcph;
int PrefilterGenericMpmPktRegister(DetectEngineCtx *de_ctx, SigGroupHead *sgh, MpmCtx *mpm_ctx, const DetectBufferMpmRegistry *mpm_reg, int list_id)
#define SIGMATCH_INFO_STICKY_BUFFER
SigTableElmt * sigmatch_table
void DetectPktMpmRegister(const char *name, int priority, int(*PrefilterRegister)(DetectEngineCtx *de_ctx, SigGroupHead *sgh, MpmCtx *mpm_ctx, const DetectBufferMpmRegistry *mpm_reg, int list_id), InspectionBufferGetPktDataPtr GetData)
register a MPM engine
int DetectBufferSetActiveList(DetectEngineCtx *de_ctx, Signature *s, const int list)
main detection engine ctx
void DetectTcphdrRegisterTests(void)
this function registers unit tests for DetectTcphdr
#define TCP_GET_RAW_HLEN(tcph)
void DetectTcphdrRegister(void)
Registration function for tcp.hdr: keyword.
int(* Setup)(DetectEngineCtx *, Signature *, const char *)
InspectionBuffer * InspectionBufferGet(DetectEngineThreadCtx *det_ctx, const int list_id)
void DetectBufferTypeSupportsPacket(const char *name)
void DetectPktInspectEngineRegister(const char *name, InspectionBufferGetPktDataPtr GetPktData, InspectionBufferPktInspectFunc Callback)
register inspect engine at start up time
int DetectBufferTypeRegister(const char *name)
void InspectionBufferApplyTransforms(InspectionBuffer *buffer, const DetectEngineTransforms *transforms)
void InspectionBufferSetup(DetectEngineThreadCtx *det_ctx, const int list_id, InspectionBuffer *buffer, const uint8_t *data, const uint32_t data_len)
setup the buffer with our initial data
int DetectEngineInspectPktBufferGeneric(DetectEngineThreadCtx *det_ctx, const DetectEnginePktInspectionEngine *engine, const Signature *s, Packet *p, uint8_t *_alert_flags)
Do the content inspection & validation for a signature.
void(* RegisterTests)(void)
int DetectProtoContainsProto(const DetectProto *dp, int proto)
see if a DetectProto contains a certain proto
#define SIG_FLAG_REQUIRE_PACKET