suricata 3.1 源码分析2

原创 2016年08月29日 16:53:01

原文链接:http://www.9mblog.com/64.html
这次要说的是一个十分重要的函数

RunModeRegisterRunModes();

主要是完成运行模式的注册,我们添加的所有运行模式都要通过这个函数注册。下面是它的内部实现。

void RunModeRegisterRunModes(void)
{
    memset(runmodes, 0, sizeof(runmodes));

    RunModeIdsPcapRegister();           //Pcap模式注册
    RunModeFilePcapRegister();      //PcapFile模式注册,用于直接读取、解析pcap文件
    RunModeIdsPfringRegister();     //Pfring模式注册,用于解析通过Pfring抓到的包
    RunModeIpsNFQRegister();
    RunModeIpsIPFWRegister();
    RunModeErfFileRegister();
    RunModeErfDagRegister();
    RunModeNapatechRegister();      //Napatech模式注册,解析Napatech网卡抓到的包
    RunModeIdsAFPRegister();
    RunModeIdsNetmapRegister();     //Netmap模式注册,用于解析通过Netmap抓到的包
    RunModeIdsNflogRegister();
    RunModeTileMpipeRegister();
    RunModeUnixSocketRegister();

    #ifdef UNITTESTS
    UtRunModeRegister();
    #endif

    return;
}

其它模式没有了解过,也就不胡乱写了。
针对于运行模式注册这块的内容,后面会对Pcap,FilePcap,以及Netmap模式进行详细分析。

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

前言——鼓励自己的话

到新公司已经半年多了,对于产品的了解也逐渐加深。回想之前的时光,不得不承认我对于工作总是充满抵触。太过悠闲的生活让我对知识没有了追求。从今天开始,每天要分析一段suricata的源码。 一个励志的故...

suricata 3.1 源码分析1

首先进入main函数int main(int argc, char **argv) { SCInstance suri; SCInstanceInit(&suri); SCInstan...

suricata 3.1 源码分析5

if (PostConfLoadedSetup(&suri) != TM_ECODE_OK) { exit(EXIT_FAILURE); } 执行PostConfLoadedS...

suricata 3.1 源码分析6

if (suri.run_mode != RUNMODE_UNIX_SOCKET) { FlowInitConfig(FLOW_VERBOSE); 初始化Flow engine...

suricata 3.1 源码分析4

GlobalInits();初始化全局变量。包括:数据包队列trans_q、数据队列data_queues(干嘛的?)、对应的mutex和cond、建立小写字母表。TimeInit(); 初始化时间。...

suricata在netmap模式用autofp方式抓包有内存泄漏的相关信息

说个小的发现。 suricata在运行netmap模式进行抓包的时候默认使用的是”workers”的工作方式。 由于其它的都是“autofp”的方式,所以就带着疑问上google上查了一下。没想到...

suricata 3.1 源码分析7

DetectEngineCtx *de_ctx = NULL; if (!suri.disabled_detect) { //detect设为启用 SCClassCon...

suricata 3.1 源码分析3

继续main函数下面的内容。/* By default use IDS mode, but if nfq or ipfw * are specified, IPS mode wil...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)