亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? perf.c

?? 著名的入侵檢測系統snort的最新版本的源碼
?? C
字號:
/***  $Id$****  perf.c**** Copyright (C) 2002 Sourcefire,Inc** Dan Roelker <droelker@sourcefire.com>**** This program is free software; you can redistribute it and/or modify** it under the terms of the GNU General Public License Version 2 as** published by the Free Software Foundation.  You may not use, modify or** distribute this program under any other version of the GNU General** Public License.**** 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** along with this program; if not, write to the Free Software** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.******  DESCRIPTION**    These are the basic functions that are needed to call performance**    functions.***/#include <stdlib.h>#include <stdio.h>#include <string.h>#include <sys/types.h>#include <sys/stat.h>#include <errno.h>#ifndef WIN32#include <time.h>#include <unistd.h>#endif /* WIN32 */#include "util.h"#include "perf.h"int InitPerfStats(SFPERF *sfPerf);int UpdatePerfStats(SFPERF *sfPerf, const unsigned char *pucPacket, int len,        int iRebuiltPkt);int ProcessPerfStats(SFPERF *sfPerf);int sfInitPerformanceStatistics(SFPERF *sfPerf){    memset(sfPerf, 0x00, sizeof(SFPERF));    sfSetPerformanceSampleTime(sfPerf, 0);    sfSetPerformanceStatistics(sfPerf, 0);    return 0;}int sfSetPerformanceSampleTime(SFPERF *sfPerf, int iSeconds){    sfPerf->sample_time = 0;        if(iSeconds < 0)    {        iSeconds = 0;    }    sfPerf->sample_interval = iSeconds;    return 0;}int sfSetPerformanceAccounting(SFPERF *sfPerf, int iReset){    sfPerf->sfBase.iReset = iReset;        return 0;}int sfSetPerformanceStatistics(SFPERF *sfPerf, int iFlag){    if(iFlag & SFPERF_BASE)    {        sfPerf->iPerfFlags = sfPerf->iPerfFlags | SFPERF_BASE;    }#ifndef LINUX_SMP    if(iFlag & SFPERF_BASE_MAX)    {        sfPerf->sfBase.iFlags |= MAX_PERF_STATS;    }#endif    if(iFlag & SFPERF_FLOW)    {        sfPerf->iPerfFlags = sfPerf->iPerfFlags | SFPERF_FLOW;    }    if(iFlag & SFPERF_EVENT)    {        sfPerf->iPerfFlags = sfPerf->iPerfFlags | SFPERF_EVENT;    }    if(iFlag & SFPERF_CONSOLE)    {        sfPerf->iPerfFlags = sfPerf->iPerfFlags | SFPERF_CONSOLE;    }        return 0;}int sfSetPerformanceStatisticsEx(SFPERF *sfPerf, int iFlag, void * p){#ifndef WIN32        mode_t old_umask;#endif         if(iFlag & SFPERF_FILE)    {        static char start_up = 1;        sfPerf->iPerfFlags = sfPerf->iPerfFlags | SFPERF_FILE;                SnortStrncpy(sfPerf->file, (char *)p, sizeof(sfPerf->file));        /* this file needs to be readable by everyone */#ifndef WIN32        old_umask = umask(022);#endif                 /* append to existing perfmon file if just starting up */        if (start_up)        {            sfPerf->fh = fopen(sfPerf->file, "a");            start_up = 0;        }        /* otherwise we've rotated - start a new one */        else        {            sfPerf->fh = fopen(sfPerf->file, "w");        }#ifndef WIN32        umask(old_umask);#endif                if( !sfPerf->fh )            return -1;    }    else if(iFlag & SFPERF_FILECLOSE)    {        if (sfPerf->fh)        {            fclose(sfPerf->fh);            sfPerf->fh = NULL;        }    }    else if(iFlag & SFPERF_PKTCNT)    {        sfPerf->iPktCnt = *(int*)p;    }    else if (iFlag & SFPERF_SUMMARY)    {        sfPerf->iPerfFlags |= SFPERF_SUMMARY;    }    return 0;}#ifndef PATH_MAX#define PATH_MAX 1024#endif#ifndef FILE_MAX#define FILE_MAX  (PATH_MAX + 256)#endifint sfRotatePerformanceStatisticsFile(SFPERF *sfPerf){    int        ret;    time_t     t;    struct tm *tm;    char       newfile[FILE_MAX];    char      *ptr;    int        prefix_len = 0;#ifdef WIN32    struct _stat stat_buf;#else    struct stat stat_buf;#endif    /* Close current stats file - if it is open already */    if(!sfPerf->fh)    {        LogMessage("Performance log file '%s' not open",                        sfPerf->file);        return(1);    }        ret = fclose(sfPerf->fh);        if ( ret != 0 )    {        FatalError("Cannot close performance log file '%s': %s\n",                                    sfPerf->file, strerror(errno));    }        /* Rename current stats file with yesterday's date */#ifndef WIN32    ptr = strrchr(sfPerf->file, '/');#else    ptr = strrchr(sfPerf->file, '\\');#endif    if (ptr != NULL)    {        /* take length of string up to path separator and add          * one to include path separator */        prefix_len = (ptr - &sfPerf->file[0]) + 1;    }    /* Get current time, then subtract one day to get yesterday */    t = time(&t);    t -= (24*60*60);    tm = localtime(&t);    SnortSnprintf(newfile, FILE_MAX, "%.*s%d-%02d-%02d",                  prefix_len, sfPerf->file, tm->tm_year + 1900,                  tm->tm_mon + 1, tm->tm_mday);    /* Checking return code from rename */#ifdef WIN32    if (_stat(newfile, &stat_buf) == -1)#else    if (stat(newfile, &stat_buf) == -1)#endif    {        /* newfile doesn't exist - just rename sfPerf->file to newfile */        if(rename(sfPerf->file, newfile) != 0)        {            LogMessage("Cannot move performance log file '%s' to '%s': %s\n",                       sfPerf->file, newfile,strerror(errno));        }    }    else    {        /* append to current archive file */        FILE *newfh, *curfh;        char read_buf[1024];        size_t num_read, num_wrote;        do        {            newfh = fopen(newfile, "a");            if (newfh == NULL)            {                LogMessage("Cannot open performance log archive file "                           "'%s' for writing: %s\n",                           newfile, strerror(errno));                break;            }            curfh = fopen(sfPerf->file, "r");            if (curfh == NULL)            {                LogMessage("Cannot open performance log file '%s' for reading: %s\n",                           sfPerf->file, strerror(errno));                fclose(newfh);                break;            }            while (!feof(curfh))            {                num_read = fread(read_buf, sizeof(char), sizeof(read_buf), curfh);                if (num_read < sizeof(read_buf))                {                    if (ferror(curfh))                    {                        /* a read error occurred */                        LogMessage("Error reading performance log file '%s': %s\n",                                   sfPerf->file, strerror(errno));                        break;                    }                }                if (num_read > 0)                {                    num_wrote = fwrite((const char *)read_buf, sizeof(char), num_read, newfh);                    if (num_wrote != num_read)                    {                        if (ferror(newfh))                        {                            /* a bad write occurred */                            LogMessage("Error writing to performance log "                                       "archive file '%s': %s\n",                                       newfile, strerror(errno));                            break;                        }                    }                }            }            fclose(newfh);            fclose(curfh);        } while (0);    }    ret = sfSetPerformanceStatisticsEx(sfPerf, SFPERF_FILE, sfPerf->file);    if( ret != 0 )    {        FatalError("Cannot open performance log file '%s': %s\n",                                    sfPerf->file, strerror(errno));    }    return 0;}int sfPerformanceStats(SFPERF *sfPerf, const unsigned char *pucPacket, int len,                       int iRebuiltPkt){    static unsigned int cnt=0;    if (( cnt==0 || cnt >= sfPerf->iPktCnt ) &&        !(sfPerf->iPerfFlags & SFPERF_SUMMARY))    {       cnt=1;       CheckSampleInterval(time(NULL), sfPerf);    }    cnt++;    UpdatePerfStats(sfPerf, pucPacket, len, iRebuiltPkt);    return 0;}int CheckSampleInterval(time_t curr_time, SFPERF *sfPerf){    time_t prev_time = sfPerf->sample_time;    /*    *  This is for when sfBasePerformance is    *  starting up.    */    if(prev_time == 0)    {        InitPerfStats(sfPerf);    }    else if((curr_time - prev_time) >= sfPerf->sample_interval)    {        ProcessPerfStats(sfPerf);        InitPerfStats(sfPerf);    }    return 0;}int InitPerfStats(SFPERF *sfPerf){    static int first = 1;    /*    *  Reset sample time for next sampling    */    sfPerf->sample_time = time(NULL);    if(sfPerf->iPerfFlags & SFPERF_BASE)    {          if(InitBaseStats(&(sfPerf->sfBase)))            return -1;    }    if(sfPerf->iPerfFlags & SFPERF_FLOW)    {          if(first) InitFlowStats(&(sfPerf->sfFlow));        first = 0;    }    if(sfPerf->iPerfFlags & SFPERF_EVENT)    {          InitEventStats(&(sfPerf->sfEvent));    }    return 0;}int UpdatePerfStats(SFPERF *sfPerf, const unsigned char *pucPacket, int len,                    int iRebuiltPkt){    if(sfPerf->iPerfFlags & SFPERF_BASE)    {        UpdateBaseStats(&(sfPerf->sfBase), len, iRebuiltPkt);    }    if(sfPerf->iPerfFlags & SFPERF_FLOW)    {        UpdateFlowStats(&(sfPerf->sfFlow), pucPacket, len, iRebuiltPkt);    }    return 0;}int sfProcessPerfStats(SFPERF *sfPerf){    return ProcessPerfStats(sfPerf);}int ProcessPerfStats(SFPERF *sfPerf){    if(sfPerf->iPerfFlags & SFPERF_BASE)    {        /* Allow this to go out to console and/or a file */        ProcessBaseStats(&(sfPerf->sfBase),                sfPerf->iPerfFlags & SFPERF_CONSOLE,                sfPerf->iPerfFlags & SFPERF_FILE,                sfPerf->fh );    }        /* Always goes to the console */    if(sfPerf->iPerfFlags & SFPERF_FLOW)    {        if( sfPerf->iPerfFlags & SFPERF_CONSOLE )            ProcessFlowStats(&(sfPerf->sfFlow));    }       if(sfPerf->iPerfFlags & SFPERF_EVENT)    {        if( sfPerf->iPerfFlags & SFPERF_CONSOLE )            ProcessEventStats(&(sfPerf->sfEvent));    }    return 0;}    

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本不卡一区二区三区| 亚洲欧洲一区二区在线播放| 日韩中文欧美在线| 4438成人网| 久久不见久久见免费视频1| 337p日本欧洲亚洲大胆色噜噜| 久久国产精品第一页| 久久精品水蜜桃av综合天堂| 成人做爰69片免费看网站| 国产精品国产三级国产三级人妇| 97精品久久久久中文字幕 | 日韩一区二区不卡| 国内精品伊人久久久久av一坑| 精品少妇一区二区三区在线视频| 国产美女娇喘av呻吟久久| 国产精品久久久久久久久久久免费看 | 99免费精品视频| 亚洲自拍偷拍图区| 日韩欧美的一区| 成人午夜激情在线| 亚洲网友自拍偷拍| 欧美www视频| 波多野结衣在线aⅴ中文字幕不卡| 亚洲另类春色国产| 欧美一级高清片在线观看| 丁香婷婷深情五月亚洲| 亚洲国产精品人人做人人爽| 精品国产三级a在线观看| 北条麻妃一区二区三区| 天天综合网 天天综合色| 欧美高清在线精品一区| 7777精品伊人久久久大香线蕉完整版| 国产一区 二区| 亚洲国产日韩av| 国产午夜亚洲精品羞羞网站| 欧美在线播放高清精品| 国产精品亚洲第一| 亚洲123区在线观看| 国产精品免费久久| 欧美一区二区三区视频免费| 99精品一区二区三区| 久草在线在线精品观看| 亚洲电影在线播放| 中文字幕一区二区三| 欧美xxxxxxxx| 欧美一区二区三区成人| 日本精品一区二区三区高清| 国产成人av电影免费在线观看| 丝袜脚交一区二区| 亚洲免费在线观看视频| 久久精品综合网| 日韩精品综合一本久道在线视频| 色嗨嗨av一区二区三区| 国产成人免费视| 激情综合色丁香一区二区| 午夜精彩视频在线观看不卡| 国产精品久久免费看| 久久久亚洲午夜电影| 日韩精品一区二区三区三区免费| 91欧美激情一区二区三区成人| 国产伦精品一区二区三区免费迷 | 一区二区三区成人| 国产精品丝袜一区| 中文字幕第一区第二区| 精品国产sm最大网站免费看| 日韩欧美中文字幕制服| 精品视频一区二区三区免费| 99久久精品久久久久久清纯| 高潮精品一区videoshd| 高清不卡一区二区| 风间由美一区二区三区在线观看| 狠狠色狠狠色综合日日91app| 日韩电影一二三区| 婷婷成人综合网| 日韩av不卡在线观看| 天堂在线亚洲视频| 青青草一区二区三区| 欧美aaaaa成人免费观看视频| 天天综合天天综合色| 蜜臀av性久久久久蜜臀aⅴ流畅| 天天色综合成人网| 日韩 欧美一区二区三区| 男人的天堂亚洲一区| 蜜桃在线一区二区三区| 国产制服丝袜一区| 国产夫妻精品视频| av电影在线观看完整版一区二区| 不卡大黄网站免费看| 91麻豆免费视频| 欧美性生活久久| 日韩欧美在线网站| 久久久亚洲精华液精华液精华液| 国产精品区一区二区三区| 最新国产成人在线观看| 亚洲图片欧美色图| 久久精品国产久精国产| 国产成人综合亚洲网站| 91麻豆国产福利精品| 欧美午夜电影一区| 日韩免费性生活视频播放| 国产欧美日本一区二区三区| 自拍偷拍亚洲激情| 日本中文字幕一区二区视频| 国内外成人在线| 99精品欧美一区二区三区小说| 在线观看欧美精品| 日韩欧美一卡二卡| 亚洲国产高清不卡| 亚洲成a天堂v人片| 国产一区二区视频在线| 91碰在线视频| 欧美不卡一二三| 一区二区三区欧美激情| 美女任你摸久久| 99久久99久久综合| 日韩美女主播在线视频一区二区三区| 欧美激情一区二区三区在线| 亚洲成人久久影院| 国产+成+人+亚洲欧洲自线| 91高清视频免费看| 久久久久国产精品麻豆| 亚洲18影院在线观看| 懂色av一区二区三区免费观看| 欧美性感一区二区三区| 久久久久国产一区二区三区四区 | 亚洲日本一区二区三区| 蜜桃视频一区二区三区在线观看| 波多野结衣欧美| 精品久久久久久亚洲综合网| 亚洲情趣在线观看| 国产美女视频91| 欧美一区二区三区影视| 亚洲欧美视频在线观看视频| 精品一区二区三区欧美| 欧美视频在线观看一区| 国产精品久久午夜夜伦鲁鲁| 蜜臂av日日欢夜夜爽一区| 色噜噜夜夜夜综合网| 国产无遮挡一区二区三区毛片日本| 五月天欧美精品| 99久久精品国产毛片| 国产日韩在线不卡| 美女一区二区三区| 欧美日韩成人综合| 一区二区视频免费在线观看| 丰满白嫩尤物一区二区| 日韩视频国产视频| 亚欧色一区w666天堂| 一本一道久久a久久精品综合蜜臀| 久久精品欧美日韩| 久久99国内精品| 91精品视频网| 水蜜桃久久夜色精品一区的特点| 成年人国产精品| 日本一区二区三区四区| 国产一区二区在线影院| 日韩欧美激情在线| 免费成人小视频| 91麻豆精品国产自产在线观看一区 | 欧美经典三级视频一区二区三区| 激情欧美日韩一区二区| 精品少妇一区二区三区日产乱码 | 2024国产精品| 精品在线亚洲视频| 精品国偷自产国产一区| 免费在线成人网| 日韩欧美不卡一区| 韩国理伦片一区二区三区在线播放| 91精品国产色综合久久久蜜香臀| 午夜成人在线视频| 9191久久久久久久久久久| 亚洲成av人在线观看| 欧美高清激情brazzers| 五月天久久比比资源色| 欧美精选一区二区| 麻豆视频观看网址久久| 精品免费视频一区二区| 国产一区二区三区最好精华液| 精品国产91久久久久久久妲己 | 91最新地址在线播放| 亚洲欧美日本在线| 欧美日韩中文字幕一区| 亚洲成a人v欧美综合天堂下载| 制服丝袜亚洲色图| 狠狠色伊人亚洲综合成人| 欧美国产97人人爽人人喊| 91久久免费观看| 日本成人在线一区| 精品国产污污免费网站入口| 国产成人av电影免费在线观看| 国产精品久久久99| 欧美日韩综合色| 久久99精品久久久| 国产精品灌醉下药二区| 欧美图片一区二区三区| 秋霞电影网一区二区| 国产精品成人免费在线| 欧美吻胸吃奶大尺度电影| 经典三级视频一区| 亚洲视频一区在线观看|