免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123
最近访问板块 发新帖
楼主: jiufei19

[网络子系统] tcp_rcv_established函数中的一个问题【已解决】 [复制链接]

论坛徽章:
0
发表于 2013-12-05 09:48 |显示全部楼层
回复 20# jiufei19

个人理解流程是这样的:

tcp_recvmsg -> install ucopy reader -> no data so call sk_wait_data() -> set task to TASK_INTERRUPTIBLE -> sk_wait_event -> release_sock

If at this time, we received a skb in softirq which is added into backlog queue (since lock is owned by user), then we call into __release_sock(sk).

In __release_sock, we call into sk_backlog_rcv() -> tcp_v4_do_rcv-> tcp_rcv_established, 这个时候 tp->ucopy.task == current && socked_owned_by_user(sk) 都满足了。

因为在sk_wait_data()里已经把task设为INTERRUPTIBLE了,所以在tcp_rcv_established里需要把task重新设为RUNNING,因为在__release_sock里会调用cond_reschedule_softirq(),如果不设成RUNNING的话,current_task 就会被schedule出去,运行不了了。

所以,tcp_recvmsg就是在这里主动的等skb (通过cond_sched_softirq,enable softirq后,把自己schedule出去,但是需要自己一直保持RUNNING的状态),softirq把skb加到backlog里 (tcp_v4_rcv ),由tcp_recvmsg主动调tcp_v4_do_rcv()来处理。
   

评分

参与人数 1可用积分 +8 收起 理由
瀚海书香 + 8 很给力!

查看全部评分

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
发表于 2013-12-05 10:10 |显示全部楼层
回复 21# eexplorer
tcp_recvmsg -> install ucopy reader -> no data so call sk_wait_data() -> set task to TASK_INTERRUPTIBLE -> sk_wait_event -> release_sock

If at this time, we received a skb in softirq which is added into backlog queue (since lock is owned by user), then we call into __release_sock(sk).

In __release_sock, we call into sk_backlog_rcv() -> tcp_v4_do_rcv-> tcp_rcv_established, 这个时候 tp->ucopy.task == current && socked_owned_by_user(sk) 都满足了。

因为在sk_wait_data()里已经把task设为INTERRUPTIBLE了,所以在tcp_rcv_established里需要把task重新设为RUNNING,因为在__release_sock里会调用cond_reschedule_softirq(),如果不设成RUNNING的话,current_task 就会被schedule出去,运行不了了。

所以,tcp_recvmsg就是在这里主动的等skb (通过cond_sched_softirq,enable softirq后,把自己schedule出去,但是需要自己一直保持RUNNING的状态),softirq把skb加到backlog里 (tcp_v4_rcv ),由tcp_recvmsg主动调tcp_v4_do_rcv()来处理。


Cool, man!

   

论坛徽章:
1
IT运维版块每日发帖之星
日期:2015-11-17 06:20:00
发表于 2013-12-05 10:23 |显示全部楼层
eexplorer老友别来无恙!

感谢eexplorer,应该如你所说。我忽略了应继续跟踪进__release_sock函数,当时只是想当然了。的确在__release_sock函数中就有对backlog队列的处理,此时必然满足owner为真,且current指向自己的条件。

再次感谢论坛版主和其他参与讨论的朋友!

论坛徽章:
17
水瓶座
日期:2013-08-29 12:09:27白羊座
日期:2014-08-07 12:36:42丑牛
日期:2014-07-24 12:44:41寅虎
日期:2014-04-16 16:15:33寅虎
日期:2014-03-12 09:28:43摩羯座
日期:2014-03-06 13:22:04技术图书徽章
日期:2014-03-06 11:34:50天蝎座
日期:2014-01-09 11:31:44寅虎
日期:2013-12-27 17:01:44双子座
日期:2013-12-27 12:32:29双子座
日期:2013-12-25 09:03:33丑牛
日期:2013-12-24 16:18:44
发表于 2013-12-05 10:37 |显示全部楼层
回复 21# eexplorer

非常感谢eexplorer的精彩回复!
   

论坛徽章:
0
发表于 2013-12-05 13:42 |显示全部楼层
回复 23# jiufei19

jiufei19, 论坛上好久没见你了。

还在专研linux network,对你的毅力非常钦佩!


   

论坛徽章:
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
发表于 2013-12-09 12:32 |显示全部楼层
eexplorer 发表于 2013-12-05 09:48
回复 20# jiufei19

个人理解流程是这样的:

学习学习了~~,感谢!

论坛徽章:
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
发表于 2013-12-09 12:36 |显示全部楼层
humjb_1983 发表于 2013-12-04 17:19
呵呵,应该就是当用户接收进程正在执行,且在走到sk_wait_event->release_sock之前(即还没有真正被调度出 ...

不好意思了,之前确实没有去理清楚~,前几天生病请假没时间深究~,现在有专家解答了,顺便学习~~,看来问题是越讨论越有意思~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP