免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: crazyhadoop
打印 上一主题 下一主题

[Linux] Linux系统开发那点事儿 分享经验得牛人力作!(获奖名单已公布-2014-5-28) [复制链接]

论坛徽章:
0
51 [报告]
发表于 2014-05-02 11:01 |只看该作者
学习中,正在看文件I/O一章,体会一切即文件的思想

论坛徽章:
0
52 [报告]
发表于 2014-05-03 03:26 |只看该作者
回复 48# crazyhadoop

精力有限,工作大部分都是做驱动,只有调试驱动的时候,偶尔写一点应用空间的调试程序

   

论坛徽章:
26
CU十二周年纪念徽章
日期:2013-10-24 15:41:34技术图书徽章
日期:2014-07-11 16:27:52辰龙
日期:2014-09-04 13:40:43白羊座
日期:2014-09-09 12:51:55双子座
日期:2014-09-26 11:00:042014年中国系统架构师大会
日期:2014-10-14 15:59:00子鼠
日期:2014-10-23 16:48:23巨蟹座
日期:2014-10-27 08:21:10申猴
日期:2014-12-08 10:16:282015年辞旧岁徽章
日期:2015-03-03 16:54:15NBA常规赛纪念章
日期:2015-05-04 22:32:03IT运维版块每日发帖之星
日期:2016-01-29 06:20:00
53 [报告]
发表于 2014-05-05 14:21 |只看该作者
围观中..................

求职 : 系统工程师等
论坛徽章:
5
技术图书徽章
日期:2014-04-19 22:01:05天蝎座
日期:2014-05-09 13:49:28双子座
日期:2014-06-16 15:08:042015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:55:28
54 [报告]
发表于 2014-05-06 10:36 |只看该作者
本帖最后由 qxhgd 于 2014-05-06 10:37 编辑

开发中使用tcpdump的时候,遇到过select的副作用引起的故障。
select的原型:
  1. int select(int nfds, fd_set *rdfds, fd_set *wtfds, fd_set *exfds, struct timeval *timeout)
复制代码
不同系统上的实现:
POSIX.1标准是允许在实现中修改timeval的值的。
FreeBSD、Mac OS X、Solaris里一般维持不变。
Linux的实现中,几乎一定要被修改的只要配了超时时间,最终或者被修改为0或者被修改为剩余时间。

开始是每隔一定时间发消息出去,但是间隔在调用select之后,被修改导致出现问题。

附:Linux上的select的实现分析:
  1. SYSCALL_DEFINE5(select)
  2. {
  3.     if(tvp)            //如果配置了超时时间,select最后一个参数非NULL的情况
  4.     {
  5.        endtime=xxx;     //修改endtime,有点乱,主要是通过timespec_add_safe实现的。
  6.     }
  7.     ret = core_sys_select(n, inp, outp, exp, to);//真正实现超时的地方
  8.     ret = poll_select_copy_remaining(&end_time, tvp, 1, ret);//注意这个1
  9.    
  10.     return ret;
  11. }


  12. static int poll_select_copy_remaining(struct timespec *end_time, void __user *p,
  13.                                       int timeval, int ret)
  14. {

  15.        if (!end_time->tv_sec && !end_time->tv_nsec) //如果前面tvp为Null,那么endtime没被赋值,值未定,这里可能就有问题了。
  16.            return ret;
  17.        ktime_get_ts(&rts);                 //获取当前时间
  18.         rts = timespec_sub(*end_time, rts); //计算剩余时间
  19.         if (rts.tv_sec < 0)                 //如果为负说明已经超时
  20.                 rts.tv_sec = rts.tv_nsec = 0; //清0

  21.         if (timeval) {                       //select系统调用中,timeval为1
  22.                 rtv.tv_sec = rts.tv_sec;      //存的是剩余时间(以endtime为参照物),可能为0,
  23.                 rtv.tv_usec = rts.tv_nsec / NSEC_PER_USEC;

  24.                 if (!copy_to_user(p, &rtv, sizeof(rtv))) //将剩余时间还给用户态
  25.                         return ret;

  26.         }

  27. }
复制代码

论坛徽章:
0
55 [报告]
发表于 2014-05-06 19:13 |只看该作者
表示这是c不过关回复 6# sxcong


   

论坛徽章:
6
CU大牛徽章
日期:2013-03-14 14:14:08CU大牛徽章
日期:2013-03-14 14:14:26CU大牛徽章
日期:2013-03-14 14:14:29处女座
日期:2014-04-21 11:51:59辰龙
日期:2014-05-12 09:15:10NBA常规赛纪念章
日期:2015-05-04 22:32:03
56 [报告]
发表于 2014-05-12 09:15 |只看该作者
qxhgd 发表于 2014-05-06 10:36
开发中使用tcpdump的时候,遇到过select的副作用引起的故障。
select的原型:不同系统上的实现:
POSIX.1 ...


这个是啥经验?上来就是一段代码,让我等小白情何以堪啊

求职 : 系统工程师等
论坛徽章:
5
技术图书徽章
日期:2014-04-19 22:01:05天蝎座
日期:2014-05-09 13:49:28双子座
日期:2014-06-16 15:08:042015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:55:28
57 [报告]
发表于 2014-05-12 09:32 |只看该作者
回复 56# wang290


    select的副作用,超时时间会被select修改。如果循环调用select的话,需要重新对超时时间赋值。

    (*^__^*) 嘻嘻!

论坛徽章:
6
CU大牛徽章
日期:2013-03-14 14:14:08CU大牛徽章
日期:2013-03-14 14:14:26CU大牛徽章
日期:2013-03-14 14:14:29处女座
日期:2014-04-21 11:51:59辰龙
日期:2014-05-12 09:15:10NBA常规赛纪念章
日期:2015-05-04 22:32:03
58 [报告]
发表于 2014-05-12 09:57 |只看该作者
qxhgd 发表于 2014-05-12 09:32
回复 56# wang290


不明觉厉

论坛徽章:
0
59 [报告]
发表于 2014-05-12 11:43 |只看该作者
样章好像没法下载
那两个压缩包下下来后解压都显示错误

论坛徽章:
0
60 [报告]
发表于 2014-05-16 10:36 |只看该作者
回复 55# 256893

这个和c没关系的,是从dos转向linux时对路径的理解问题。


   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP