Chinaunix

标题: 能抓到icmp包,但是却select超时? [打印本页]

作者: yangyi33855    时间: 2013-12-11 09:45
标题: 能抓到icmp包,但是却select超时?
select函数部分代码如下:
    while (1) {
        FD_ZERO(&readfds);
        FD_SET(pingsock, &readfds);
        maxfdp = pingsock + 1;
        timeout.tv_sec = PINGINTERVAL;      /*2s的阻塞时延 */
        timeout.tv_usec = 0;
        /* 保护select不受其他线程的信号干扰 */
        ret = select(maxfdp, &readfds, NULL, NULL, &timeout);
        if (ret <= 0) {
            switch (ret) {
            case 0:
                DEBUG_PRINT("ping [%s] timeout, [%d] packets transmitted!\n", ping_s->pingip.ss_padding,
                    ntransmitted);
                break;
            case -1:
                DEBUG_PRINT("select error!\n");
                break;
            default:
                DEBUG_PRINT("select: error unknow!\n");
                break;
            }
            FD_CLR(pingsock, &readfds);
       }

程序跑起来之后,一直在打印ping超时,而用wireshark抓包却能抓到发出去的和返回的icmp报文。
请教各位,这是什么情况。哎,解决问题的一点头绪都没有啊。
作者: yangyi33855    时间: 2013-12-11 10:30
select返回0的原因是没有可读文件,我这里是开多个线程来操作ping,就是说多个线程都会执行到上面这个循环,这么说的话,是不是pingsock的值和对应的ping线程对应不上,导致select检测不到pingsock上有没有的可读数据?那这样的话,是bind()函数方面的问题么?
作者: yangyi33855    时间: 2013-12-12 08:57
顶一个,求大神看看,给点思路吧
作者: whatever890603    时间: 2013-12-12 09:40
回复 3# yangyi33855

帮顶一个,我也碰到类似的问题,求思路。




   
作者: heartless_cu    时间: 2013-12-12 10:27
你的socket是如何创建的?请仔细检查一下。
作者: yangyi33855    时间: 2013-12-12 11:35
heartless_cu 发表于 2013-12-12 10:27
你的socket是如何创建的?请仔细检查一下。

我的socket是这样创建的:
    int skt;

    skt = socket(AF_INET, SOCK_RAW, 1);
    if (skt < 0) {
        APMLOG_PRINT("the skt is %d\n", skt);
    }
不知道有问题没?
作者: heartless_cu    时间: 2013-12-12 16:18
sockfd = socket(PF_INET,SOCK_RAW,IPPROTO_ICMP)
有问题先搜搜别人的实现。
参考下面的文章:
在linux中用C语言实现ping命令的部分功能 - 无心出岫 - 博客园
http://www.cnblogs.com/linuxer/archive/2012/06/20/2870517.html
作者: 井蛙夏虫    时间: 2013-12-12 18:27
回复 2# yangyi33855
你的多个线程用了几个socket

   
作者: yangyi33855    时间: 2013-12-17 20:07
井蛙夏虫 发表于 2013-12-12 18:27
回复 2# yangyi33855
你的多个线程用了几个socket

我10个线程,用一个socket在弄,不知道可以否?
作者: linux_c_py_php    时间: 2013-12-18 09:36
10个线程操作同一个socket除非你操作的协议是UDP形式的报文,否则一定是错乱的。
作者: 井蛙夏虫    时间: 2013-12-18 19:23
回复 9# yangyi33855
建议不要这样做。
将同一个描述符添加到多个select中,应当是未定义行为。没有看到有文档说这种情况下怎么做。
可能只有一个select返回,也可能所有的select都返回。这种情况下超时是怎么处理的,也不知道。



   
作者: yangyi33855    时间: 2013-12-19 08:49
谢谢你的指导回复 11# 井蛙夏虫


   
作者: 流氓无产者    时间: 2013-12-19 09:25
yangyi33855 发表于 2013-12-17 20:07
我10个线程,用一个socket在弄,不知道可以否?

上次,我一个朋友也是这样的,被其他线程收走了




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2