免费注册 查看新帖 |

Chinaunix

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

深入Linux内核架构中有关pid_type的疑惑 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-11-06 16:58 |只看该作者 |倒序浏览
本帖最后由 flikelinux 于 2011-11-06 16:59 编辑

在本书的45页(中文版)中提到,一个进程ID可能用于几个进程。所有共享同一ID的task_struct实例,通过task散列表连接起来。pid的类型有:
enum pid_type
{
    PIDTYEP_PID,
    PIDTYEP_PGID,
    PIDTYPE_SID,
    PIDTYPE_MAX
};
然后画了一幅图,请问这个pid_type的作用是什么?是不是将pid相同的task_struct连入tasks[PIDTYPE_PID],然后其他两个也类似,但为什么一个pid结构体会对应这么多task_struct,他们是如加入散列表的?

QQ截图20111106165443.png (85.07 KB, 下载次数: 2)

QQ截图20111106165443.png

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
2 [报告]
发表于 2011-11-06 18:47 |只看该作者
回复 1# flikelinux


    首先要知道为什么引入pid_type,由于经常需要通过PID获得task_struct结构,如果遍历进程描述符的双向链表非常低效,所以使用哈希表。pid_type中的一个成员是一类,每类一个哈希表。比如要通过PIDTYPE_SID找到task_struct结构,就是使用PIDTYPE_SID的哈希表。如下边这张图,pidhash是一个二维数组,第一维就是这每一类,第二维是hash地址。每个地址会对应一个链表,哈希冲突的描述符放在一个链表上,使用pid_chain字段,同一个pid_type值的,比如PIDTYPE_SID,通过pid_list字段链在一起。有一个pid_hashfn宏,这个就是哈希函数,参数就是PID值了,这样就得到哈希地址。


论坛徽章:
0
3 [报告]
发表于 2011-11-07 08:51 |只看该作者
是不是说要找一个task_struct可以通过三种方式,1.TYPEPID_PID,通过进程号,2 TYPEPID_SID,通过进程会话ID,3 TYPEPID_PGID 通过进程组ID?

论坛徽章:
16
2015亚冠之吉达阿赫利
日期:2015-08-17 11:21:462015年迎新春徽章
日期:2015-03-04 09:58:11酉鸡
日期:2014-12-07 09:06:19水瓶座
日期:2014-11-04 14:23:29天秤座
日期:2014-03-02 08:57:52双鱼座
日期:2014-02-22 13:07:56午马
日期:2014-02-14 11:08:18双鱼座
日期:2014-02-13 11:09:37卯兔
日期:2014-02-06 15:10:34子鼠
日期:2014-01-20 14:48:19戌狗
日期:2013-12-19 09:37:46射手座
日期:2013-12-19 09:33:47
4 [报告]
发表于 2011-11-07 14:34 |只看该作者
回复 3# flikelinux


    这里只是说通过PID找task_struct!其方式不了解!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP