LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 2311|回复: 7

再请教一个linux下多线程的时间片分配问题

[复制链接]
发表于 2005-7-13 09:48:37 | 显示全部楼层 |阅读模式
据我所知,linux下的时间片是固定的,大约200ms,所有线程形成一个队列,一个线程的时间片用完了就到队尾再排队(默认相同优先级的情况)。
我想知道的是当一个线程在调用函数过程中(有些是实时的函数),如果时间片用完了,调度器或者系统是怎样处理这个线程的?
谁能给解释一下,越详细越好。
或者推荐一下哪本书或者哪段源代码能帮我把这个问题弄明白的。我找了很久都没找到详细的资料。
多谢了
发表于 2005-7-13 11:21:50 | 显示全部楼层
讲Linux内核的书不会连线程切换都不讲吧?

不外乎是保存寄存器,修改线程结构的某些域,比如线程状态,线程
运行时间,等等,以后切换回来时再恢复寄存器,检查信号等等。
回复 支持 反对

使用道具 举报

 楼主| 发表于 2005-7-13 11:34:22 | 显示全部楼层
之所以问这样的问题是因为我现在用8个线程分别读8个串口的数据,如果单起一个线程的话是没有问题的,但8个线程同时运行就会有大约1%的错误率,我弄不明白其中的原因
回复 支持 反对

使用道具 举报

发表于 2005-7-13 12:51:59 | 显示全部楼层
说明运行在你线程里的函数不是线程安全的。内核没问题的。
回复 支持 反对

使用道具 举报

 楼主| 发表于 2005-7-13 12:57:41 | 显示全部楼层
什么是线程安全的函数啊,read函数不是安全的吗?
回复 支持 反对

使用道具 举报

发表于 2005-7-13 13:09:50 | 显示全部楼层
http://lxr.linux.no/source/kernel/sched.c?v=2.4.28#L547
这个地方应该就是Linux的Task切换的地方,貌似Linux下面没有通常的process和thread
的概念,取而代之的是task.

你的问题跟你使用的线程库可能有关系,如果是用户级线程(多个thread对应到
一个task),那么一个线程阻塞会导致所有线程阻塞,这样可能导致来不及读取串口
的数据。貌似Linux有提供内核级线程(每一个thread对应一个task??),具体的
你可以看看这儿。

http://pauillac.inria.fr/~xleroy/linuxthreads/
http://www-128.ibm.com/developer ... _thread1/index.html
http://www-128.ibm.com/developerworks/cn/linux/l-nptl/index.html 这篇挺好的.
http://www-128.ibm.com/developer ... -kn26sch/index.html
http://www-128.ibm.com/developer ... l-k24sch/index.html
http://www-128.ibm.com/developer ... realtime/index.html

另外啰嗦几句, 你提的问题信息太少了, "但8个线程同时运行就会有大约1%的错误率", 具体
这个错误是什么?读漏了还是读错了? 最好是能给个小程序再现你的问题, 别人也好帮你看看,
lkml上面有很多牛人,可以去试试,一定要注意提问的方式
回复 支持 反对

使用道具 举报

发表于 2005-7-13 13:11:52 | 显示全部楼层
嗯,看看你是不是在线程里面是用了全局变量或者文件内的静态变量而又没有使用互斥机制。
回复 支持 反对

使用道具 举报

 楼主| 发表于 2005-7-13 14:39:46 | 显示全部楼层
多谢dieken_qfz !
我看看那些文章先。
回复 支持 反对

使用道具 举报

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

本版积分规则

快速回复 返回顶部 返回列表