C ++とrawソケットを使用してICMP要求をルーターに送信していますが、その後、ICMP応答を読み取ります。私の問題は、select()が常にリプレイとタイムアウトを受信していないことです。エラーが発生していません(errnoが成功を返しています)。Wiresharkを使用して応答を確認できるため、ルーターはICMP応答を送信しています。
http://i.imgur.com/0Wra1.pngwireshark のスクリーンショット
プログラムをテストするために、VirtualBox4.2.6で実行されているUbuntu12.10と仮想ネットワーク用のGN3を使用しています。
私のソースコード:
char buffer[IP_MAXPACKET]; // for the received ICMP reply
struct iphdr *ipRec; // ICMP header
timeval tv; // timeout
fd_set mySet; // descriptor set
...
tv.tv_sec = 3; // default time-out 3s
tv.tv_usec = 0;
int retval; // select
...
do {
        FD_ZERO(&mySet);
        FD_SET(mysocket, &mySet);
        retval = select(mysocket+1, &mySet, NULL, NULL, &tv);
        cout << "Errno after select:" << strerror(errno) << endl;
        if(retval == -1) {
            cerr << "select error" << endl;
            break;
        }
        else if (retval) {
            if((length = recvfrom(mysocket, buffer, MAX, 0, result->ai_addr, &(result->ai_addrlen))) == -1) {
                cerr << "Error: while receiving data." << endl;
            }
            else {
                cout << "good" << endl;
                ipRec = (struct iphdr*) buffer;
                icmpRec = (struct icmphdr*) (buffer + ipRec->ihl * 4);
                cout << "the packet." << " PID: " << ntohs(icmpRec->un.echo.id) << " Seq: " << ntohs(icmpRec->un.echo.sequence) << endl;
                if ((icmpRec->type == ICMP_ECHOREPLY) && (ntohs(icmpRec->un.echo.id) == pid) && (ntohs(icmpRec->un.echo.sequence) == (seq - 1))) {
                    minBuff = lengthBuff;
                }
            }
        } else {
            // getting here all the time = select times-out and reads no data
            cout << "mysocket:" << mysocket << endl;
            cout << "retval:" << retval << endl;
            maxBuff = lengthBuff;
            break;
        }
    } while (!((icmpRec->type == ICMP_ECHOREPLY) && (ntohs(icmpRec->un.echo.id) == pid) && (ntohs(icmpRec->un.echo.sequence) == (seq - 1))));
    if (packet)
        delete(packet);
    ...
助けてくれてありがとう。