6

以下のコードを実行している間、CPUコアの1つが100%の使用率に達します。トラフィックの有無にかかわらず。なにが問題ですか?

コード例:

#include <stdio.h>
#include <stdlib.h>
#include <pcap.h>
#include <errno.h>

void my_callback(u_char *args, const struct pcap_pkthdr* pkthdr, const u_char*
packet)
{
    //nothing, nothing at all...
    //printf("+");
}

int main(int argc,char **argv)
{
    int i;
    char *dev;
    char errbuf[PCAP_ERRBUF_SIZE];
    pcap_t* descr;
    const u_char *packet;
    struct bpf_program fp;        /* hold compiled program */
    bpf_u_int32 maskp;            /* subnet mask */
    bpf_u_int32 netp;             /* ip */

    if(argc != 2){
        fprintf(stdout, "Usage: %s \"expression\"\n"
            ,argv[0]);
        return 0;
    }

    /* Now get a device */
    dev = pcap_lookupdev(errbuf);

    if(dev == NULL) {
        fprintf(stderr, "%s\n", errbuf);
        exit(1);
    }
    /* Get the network address and mask */
    pcap_lookupnet(dev, &netp, &maskp, errbuf);
    /* open device for reading in promiscuous mode */
    descr = pcap_open_live(dev, BUFSIZ, 1,-1, errbuf);
    if(descr == NULL) {
        printf("pcap_open_live(): %s\n", errbuf);
        exit(1);
    }

    /* Now we'll compile the filter expression*/
    if(pcap_compile(descr, &fp, argv[1], 0, netp) == -1) {
        fprintf(stderr, "Error calling pcap_compile\n");
        exit(1);
    }

    /* set the filter */
    if(pcap_setfilter(descr, &fp) == -1) {
        fprintf(stderr, "Error setting filter\n");
        exit(1);
    }

    /* loop for callback function */
    pcap_loop(descr, -1, my_callback, NULL);
    return 0;
}

コンパイル:gcc example.c -o example -lpcap

で実行:./example "tcp"またはお好みのフィルター。

ご覧のとおり、これは典型的な例であり、ループのメイン関数とコールバック関数です。pcap_loop(descr, -1, my_callback, NULL);

コールバックは空です(役に立たない)が、問題がコールバックにないことを示すためだけのものです。

4

1 に答える 1

6

ここでタイムアウトを指定-1しました:

descr = pcap_open_live(dev, BUFSIZ, 1,-1, errbuf);

瞬時に継続的にタイムアウトするためpcap_loop、ビジーループになります。poll

1000他の値の理由がない場合は、(ミリ秒)のようなものを使用してください。

于 2013-01-18T17:39:28.443 に答える