免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2233 | 回复: 9
打印 上一主题 下一主题

[网络子系统] 内核 swapper问题 [复制链接]

论坛徽章:
2
天秤座
日期:2014-01-09 21:41:17双鱼座
日期:2014-02-20 21:50:54
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-03-31 11:03 |只看该作者 |倒序浏览
修改了下网络层发送端的源码,随后用 scp指令传输数据。数据依然可以传输,但数据大时会出如下提示:

从图看出文件传输过程 stack call trace...process swapper:出现了3次,想问下 这是什么原因,有人说是 开什么检测的原因是这样么?怎样来解决,谢谢。

另外查看日志,出现如下报警:


想问下 这种问题 应如何调试,怎样来找问题。求调试方法,谢谢

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
2 [报告]
发表于 2014-04-01 08:42 |只看该作者
先走查下你修改的代码吧,肯定是你打代码问题~

论坛徽章:
2
天秤座
日期:2014-01-09 21:41:17双鱼座
日期:2014-02-20 21:50:54
3 [报告]
发表于 2014-04-01 10:30 |只看该作者
本帖最后由 duoniK 于 2014-04-01 11:46 编辑

是这样,我复制了tcp传输协议中 sock的发送队列,并构造了删除函数分别如下:
看了下,感觉缓存区的释放应该没有问题,不知道为什么出现如上报警? 大家有明白的么?

ps:协议栈能正常工作,就是总出现如上的报警,什么 页交换出现问题,请大家给些指点。谢谢
回复 2# humjb_1983


   

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
4 [报告]
发表于 2014-04-01 12:25 |只看该作者
这个不是页交换,swapper是0号进程,即idle进程,截图中没有打出告警的具体原因。

从后面截图的堆栈中看,应该是tcp相关代码流程的问题,你的代码需要再仔细走查下~

论坛徽章:
2
天秤座
日期:2014-01-09 21:41:17双鱼座
日期:2014-02-20 21:50:54
5 [报告]
发表于 2014-04-01 17:05 |只看该作者
谢谢。问题解决了。是内存分配方式的问题。
之前采用的是GFP_KERNERL, 这样的分配只能使用在进程上下文中,而在中断处理中应使用GFP_ATOMIC,保证操作不被中断回复 4# humjb_1983


   

论坛徽章:
1
拜羊年徽章
日期:2015-03-03 16:15:43
6 [报告]
发表于 2014-04-02 06:31 来自手机 |只看该作者
内存页面是在中断子程序里动态分配?从低端内存还是高端内存?有没有考虑内存资源紧张时分配页面可能需要较长的时间?

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
7 [报告]
发表于 2014-04-02 08:55 |只看该作者
duoniK 发表于 2014-04-01 17:05
谢谢。问题解决了。是内存分配方式的问题。
之前采用的是GFP_KERNERL, 这样的分配只能使用在进程上下文中, ...

呵呵,那就对了

论坛徽章:
2
天秤座
日期:2014-01-09 21:41:17双鱼座
日期:2014-02-20 21:50:54
8 [报告]
发表于 2014-04-02 18:00 |只看该作者
我用的是 skb_copy 这个函数,会调用内存分配函数。 我把这个函数放在tcp_write_xmit函数中 使用,tcp_write_xmit是发送数据包函数,会被中断,所以使用了 原子级的分配函数。
另外 你说的从从低端内存还是高端内存 我不太懂,目前菜鸟
内存资源紧张问题,个人是这样理解的  内存分配的方式主要有 GFP_KERNERL和GFP_ATOMIC 这两种方式, 前者在内存不足时会进程休眠,知道收集到足够空闲内存,而后者是不休眠,使用系统备用的 页面缓存(这个缓存 大小数量有限 ,一般不用,只在GFP_ATOMIC时使用)
不知道上述理解是否正确,还请 扫盲,谢谢
回复 6# linuxfellow


   

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
9 [报告]
发表于 2014-04-03 08:56 |只看该作者
duoniK 发表于 2014-04-02 18:00
内存资源紧张问题,个人是这样理解的  内存分配的方式主要有 GFP_KERNERL和GFP_ATOMIC 这两种方式, 前者在内存不足时会进程休眠,知道收集到足够空闲内存,而后者是不休眠,使用系统备用的 页面缓存(这个缓存 大小数量有限 ,一般不用,只在GFP_ATOMIC时使用)
不知道上述理解是否正确,还请 扫盲,谢谢
...

内存分配方式(标志)有很多的,但只要不带GFP_WAIT标记的话(比如GFP_ATOMIC),在内存紧张时,就不会进行内存回收操作,但GFP_ATOMIC标记的内存分配方式可以穿越内存水线的1/2,当穿越水线后,内存仍不足时,会直接返回失败。这种内存分配过程不会发生调度。
而如果带GFP_WAIT标记(通常的内存分配方式都带,包括GFP_KERNERL),那么当内存不足时,会先进行内存回收操作,回收过程中,可能会发生调度,如果经回收后仍不能满足要求,最终会发生oom,oom会kill进程,如果仍无效,最终会panic。大概过程就这样~
  1. #define GFP_ATOMIC        (__GFP_HIGH)
  2. #define GFP_NOIO        (__GFP_WAIT)
  3. #define GFP_NOFS        (__GFP_WAIT | __GFP_IO)
  4. #define GFP_KERNEL        (__GFP_WAIT | __GFP_IO | __GFP_FS)
  5. #define GFP_USER        (__GFP_WAIT | __GFP_IO | __GFP_FS)
  6. #define GFP_HIGHUSER        (__GFP_WAIT | __GFP_IO | __GFP_FS | __GFP_HIGHMEM)
复制代码

论坛徽章:
2
天秤座
日期:2014-01-09 21:41:17双鱼座
日期:2014-02-20 21:50:54
10 [报告]
发表于 2014-04-03 10:58 |只看该作者
大神,thanks:wink: 回复 9# humjb_1983


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

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP