diff options
author | Ashlee Young <ashlee@wildernessvoice.com> | 2016-01-20 01:10:01 +0000 |
---|---|---|
committer | Ashlee Young <ashlee@wildernessvoice.com> | 2016-01-20 01:10:11 +0000 |
commit | 19d701ddf07d855128ded0cf2b573ce468e3bdd6 (patch) | |
tree | 0edcd3461ca903c76e431bb7c6348c42a0f12488 /framework/src/suricata/src/source-erf-file.c | |
parent | fac6fbefbfad1cf837ddd88bc0d330559c8eb6f9 (diff) |
Removing Suricata and Audit from source repo, and updated build.sh to avoid building suricata. Will re-address this in C release via tar balls.
Change-Id: I3710076f8b7f3313cb3cb5260c4eb0a6834d4f6e
Signed-off-by: Ashlee Young <ashlee@wildernessvoice.com>
Diffstat (limited to 'framework/src/suricata/src/source-erf-file.c')
-rw-r--r-- | framework/src/suricata/src/source-erf-file.c | 308 |
1 files changed, 0 insertions, 308 deletions
diff --git a/framework/src/suricata/src/source-erf-file.c b/framework/src/suricata/src/source-erf-file.c deleted file mode 100644 index 938621c4..00000000 --- a/framework/src/suricata/src/source-erf-file.c +++ /dev/null @@ -1,308 +0,0 @@ -/* Copyright (C) 2010-2014 Open Information Security Foundation - * - * You can copy, redistribute or modify this Program under the terms of - * the GNU General Public License version 2 as published by the Free - * Software Foundation. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * version 2 along with this program; if not, write to the Free Software - * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA - * 02110-1301, USA. - */ - -/** - * \file - * - * \author Endace Technology Limited. - * - * Support for reading ERF files. - * - * Only ethernet supported at this time. - */ - -#include "suricata-common.h" -#include "suricata.h" -#include "tm-threads.h" - -#define DAG_TYPE_ETH 2 - -typedef struct DagFlags_ { - uint8_t iface:2; - uint8_t vlen:1; - uint8_t trunc:1; - uint8_t rxerror:1; - uint8_t dserror:1; - uint8_t reserved:1; - uint8_t direction:1; -} DagFlags; - -typedef struct DagRecord_ { - uint64_t ts; - uint8_t type; - DagFlags flags; - uint16_t rlen; - uint16_t lctr; - uint16_t wlen; - uint16_t pad; -} __attribute__((packed)) DagRecord; - -typedef struct ErfFileThreadVars_ { - ThreadVars *tv; - TmSlot *slot; - - FILE *erf; - - uint32_t pkts; - uint64_t bytes; -} ErfFileThreadVars; - -static inline TmEcode ReadErfRecord(ThreadVars *, Packet *, void *); -TmEcode ReceiveErfFileLoop(ThreadVars *, void *, void *); -TmEcode ReceiveErfFileThreadInit(ThreadVars *, void *, void **); -void ReceiveErfFileThreadExitStats(ThreadVars *, void *); -TmEcode ReceiveErfFileThreadDeinit(ThreadVars *, void *); - -TmEcode DecodeErfFileThreadInit(ThreadVars *, void *, void **); -TmEcode DecodeErfFileThreadDeinit(ThreadVars *tv, void *data); -TmEcode DecodeErfFile(ThreadVars *, Packet *, void *, PacketQueue *, PacketQueue *); - -/** - * \brief Register the ERF file receiver (reader) module. - */ -void -TmModuleReceiveErfFileRegister(void) -{ - tmm_modules[TMM_RECEIVEERFFILE].name = "ReceiveErfFile"; - tmm_modules[TMM_RECEIVEERFFILE].ThreadInit = ReceiveErfFileThreadInit; - tmm_modules[TMM_RECEIVEERFFILE].Func = NULL; - tmm_modules[TMM_RECEIVEERFFILE].PktAcqLoop = ReceiveErfFileLoop; - tmm_modules[TMM_RECEIVEERFFILE].ThreadExitPrintStats = - ReceiveErfFileThreadExitStats; - tmm_modules[TMM_RECEIVEERFFILE].ThreadDeinit = NULL; - tmm_modules[TMM_RECEIVEERFFILE].RegisterTests = NULL; - tmm_modules[TMM_RECEIVEERFFILE].cap_flags = 0; - tmm_modules[TMM_RECEIVEERFFILE].flags = TM_FLAG_RECEIVE_TM; -} - -/** - * \brief Register the ERF file decoder module. - */ -void -TmModuleDecodeErfFileRegister(void) -{ - tmm_modules[TMM_DECODEERFFILE].name = "DecodeErfFile"; - tmm_modules[TMM_DECODEERFFILE].ThreadInit = DecodeErfFileThreadInit; - tmm_modules[TMM_DECODEERFFILE].Func = DecodeErfFile; - tmm_modules[TMM_DECODEERFFILE].ThreadExitPrintStats = NULL; - tmm_modules[TMM_DECODEERFFILE].ThreadDeinit = DecodeErfFileThreadDeinit; - tmm_modules[TMM_DECODEERFFILE].RegisterTests = NULL; - tmm_modules[TMM_DECODEERFFILE].cap_flags = 0; - tmm_modules[TMM_DECODEERFFILE].flags = TM_FLAG_DECODE_TM; -} - -/** - * \brief ERF file reading loop. - */ -TmEcode ReceiveErfFileLoop(ThreadVars *tv, void *data, void *slot) -{ - Packet *p = NULL; - ErfFileThreadVars *etv = (ErfFileThreadVars *)data; - - etv->slot = ((TmSlot *)slot)->slot_next; - - while (1) { - if (suricata_ctl_flags & (SURICATA_STOP | SURICATA_KILL)) { - SCReturnInt(TM_ECODE_OK); - } - - /* Make sure we have at least one packet in the packet pool, - * to prevent us from alloc'ing packets at line rate. */ - PacketPoolWait(); - - p = PacketGetFromQueueOrAlloc(); - if (unlikely(p == NULL)) { - SCLogError(SC_ERR_MEM_ALLOC, "Failed to allocate a packet."); - EngineStop(); - SCReturnInt(TM_ECODE_FAILED); - } - PKT_SET_SRC(p, PKT_SRC_WIRE); - - if (ReadErfRecord(tv, p, data) != TM_ECODE_OK) { - TmqhOutputPacketpool(etv->tv, p); - EngineStop(); - SCReturnInt(TM_ECODE_FAILED); - } - - if (TmThreadsSlotProcessPkt(etv->tv, etv->slot, p) != TM_ECODE_OK) { - EngineStop(); - SCReturnInt(TM_ECODE_FAILED); - } - } - SCReturnInt(TM_ECODE_FAILED); -} - -static inline TmEcode ReadErfRecord(ThreadVars *tv, Packet *p, void *data) -{ - SCEnter(); - - ErfFileThreadVars *etv = (ErfFileThreadVars *)data; - DagRecord dr; - - int r = fread(&dr, sizeof(DagRecord), 1, etv->erf); - if (r < 1) { - if (feof(etv->erf)) { - SCLogInfo("End of ERF file reached"); - } - else { - SCLogInfo("Error reading ERF record"); - } - SCReturnInt(TM_ECODE_FAILED); - } - int rlen = ntohs(dr.rlen); - int wlen = ntohs(dr.wlen); - r = fread(GET_PKT_DATA(p), rlen - sizeof(DagRecord), 1, etv->erf); - if (r < 1) { - if (feof(etv->erf)) { - SCLogInfo("End of ERF file reached"); - } - else { - SCLogInfo("Error reading ERF record"); - } - SCReturnInt(TM_ECODE_FAILED); - } - - /* Only support ethernet at this time. */ - if (dr.type != DAG_TYPE_ETH) { - SCLogError(SC_ERR_UNIMPLEMENTED, - "DAG record type %d not implemented.", dr.type); - SCReturnInt(TM_ECODE_FAILED); - } - - GET_PKT_LEN(p) = wlen; - p->datalink = LINKTYPE_ETHERNET; - - /* Convert ERF time to timeval - from libpcap. */ - uint64_t ts = dr.ts; - p->ts.tv_sec = ts >> 32; - ts = (ts & 0xffffffffULL) * 1000000; - ts += 0x80000000; /* rounding */ - p->ts.tv_usec = ts >> 32; - if (p->ts.tv_usec >= 1000000) { - p->ts.tv_usec -= 1000000; - p->ts.tv_sec++; - } - - etv->pkts++; - etv->bytes += wlen; - - SCReturnInt(TM_ECODE_OK); -} - -/** - * \brief Initialize the ERF receiver thread. - */ -TmEcode -ReceiveErfFileThreadInit(ThreadVars *tv, void *initdata, void **data) -{ - SCEnter(); - - if (initdata == NULL) { - SCLogError(SC_ERR_INVALID_ARGUMENT, "Error: No filename provided."); - SCReturnInt(TM_ECODE_FAILED); - } - - FILE *erf = fopen((const char *)initdata, "r"); - if (erf == NULL) { - SCLogError(SC_ERR_FOPEN, "Failed to open %s: %s", (char *)initdata, - strerror(errno)); - exit(EXIT_FAILURE); - } - - ErfFileThreadVars *etv = SCMalloc(sizeof(ErfFileThreadVars)); - if (unlikely(etv == NULL)) { - SCLogError(SC_ERR_MEM_ALLOC, "Failed to allocate memory for ERF file thread vars."); - fclose(erf); - SCReturnInt(TM_ECODE_FAILED); - } - memset(etv, 0, sizeof(*etv)); - etv->erf = erf; - etv->tv = tv; - *data = (void *)etv; - - SCLogInfo("Processing ERF file %s", (char *)initdata); - - SCReturnInt(TM_ECODE_OK); -} - -/** - * \brief Initialize the ERF decoder thread. - */ -TmEcode -DecodeErfFileThreadInit(ThreadVars *tv, void *initdata, void **data) -{ - SCEnter(); - DecodeThreadVars *dtv = NULL; - dtv = DecodeThreadVarsAlloc(tv); - - if (dtv == NULL) - SCReturnInt(TM_ECODE_FAILED); - - DecodeRegisterPerfCounters(dtv, tv); - - *data = (void *)dtv; - - SCReturnInt(TM_ECODE_OK); -} - -TmEcode DecodeErfFileThreadDeinit(ThreadVars *tv, void *data) -{ - if (data != NULL) - DecodeThreadVarsFree(tv, data); - SCReturnInt(TM_ECODE_OK); -} - -/** - * \brief Decode the ERF file. - * - * This function ups the decoder counters and then passes the packet - * off to the ethernet decoder. - */ -TmEcode -DecodeErfFile(ThreadVars *tv, Packet *p, void *data, PacketQueue *pq, PacketQueue *postpq) -{ - SCEnter(); - DecodeThreadVars *dtv = (DecodeThreadVars *)data; - - /* XXX HACK: flow timeout can call us for injected pseudo packets - * see bug: https://redmine.openinfosecfoundation.org/issues/1107 */ - if (p->flags & PKT_PSEUDO_STREAM_END) - return TM_ECODE_OK; - - /* Update counters. */ - DecodeUpdatePacketCounters(tv, dtv, p); - - DecodeEthernet(tv, dtv, p, GET_PKT_DATA(p), GET_PKT_LEN(p), pq); - - PacketDecodeFinalize(tv, dtv, p); - - SCReturnInt(TM_ECODE_OK); -} - -/** - * \brief Print some stats to the log at program exit. - * - * \param tv Pointer to ThreadVars. - * \param data Pointer to data, ErfFileThreadVars. - */ -void -ReceiveErfFileThreadExitStats(ThreadVars *tv, void *data) -{ - ErfFileThreadVars *etv = (ErfFileThreadVars *)data; - - SCLogInfo("Packets: %"PRIu32"; Bytes: %"PRIu64, etv->pkts, etv->bytes); -} |