忘记密码   免费注册 查看新帖 | 论坛精华区

ChinaUnix.net

  平台 论坛 博客 认证专区 大话IT 视频 徽章 文库 沙龙 自测 下载 频道自动化运维 虚拟化 储存备份 C/C++ PHP MySQL 嵌入式 Linux系统
最近访问板块 发新帖
查看: 480 | 回复: 2

linux如何做到让多个进程运行在多个cpu core上?是内核还是硬件 [复制链接]

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
发表于 2017-01-15 20:40 |显示全部楼层
本帖最后由 asker160 于 2017-01-15 20:45 编辑

假定系统不忙,那么两个进程同时运行,linux会把两个进程放到两个cpu core上运行对吧?

这种调度需要cpu本身有什么硬件机制来配合吗? 如果只是linux本身的算法实现,那么让哪个cpu来启动哪个进程,读取哪个进程的task_struct,是如何做到呢?换句话说,软硬件如何配合,才能做到让软件能调度多个cpu核心?


论坛徽章:
0
发表于 2017-04-08 01:14 |显示全部楼层
如何调度完全看调度算法,不能够认为2个进程肯定放在2个核上。

os完成进程调度,必须一种能够中断当前进程执行的方式。 这里包括2种经典方式:
1 非剥夺,  进程A看没什么事情做了,主动出让处理器,让os调度进程B上来执行; 这种方式很古老,不公平
2 剥夺式, 系统定时中断(采用定时器),不管当前进程执行到哪里了,都会先进os中断,中断处理完毕,退出之前完成调度,根据不同算法调度不同的进程上去执行。

以上是在单处理器情况下,执行多个进程。  如果是多个处理器核,更有意思的事情就来了。...

评分

参与人数 1信誉积分 +5 收起 理由
asker160 + 5 神马都是浮云

查看全部评分

论坛徽章:
0
发表于 2017-04-12 09:08 |显示全部楼层
楼主关注的应该是如何控制某个cpu core启动某个进程细节。

关于这个问题,各种体系(包括同一种体系不同芯片厂家)具体实现方式大同小异。通常做法是:
刚刚上电复位之后,只有cpu 0是active并可以执行bootloader code(兼容以前单核),其他cpu core(s)都是disabled/sleep这类非活动状态。但是cpu 0可以通过相关寄存器来enable or reset其他cpu core(s)。其他cpu core再刚刚被reset之后,有相应的寄存器可以配置他们的其实代码的物理地址。

另外,cpu core之间还有IPI中断通信机制。

以上是ARM体系的做法,但是在x86上面,cpu core的启动会复杂一些(HW INIT时间比较长,还要load micro code。。。)

评分

参与人数 1信誉积分 +10 收起 理由
asker160 + 10 很给力!

查看全部评分

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

本版积分规则

久等啦!10张门票开启你的DTCC2017之旅

2017中国数据库技术大会将于2017年5月11-13日如约而至,本届大会以“数据驱动•价值发现”为主题,共设定2大主场和21个技术专场,云集海内外120+位技术大牛,共同探讨Oracle、MySQL、NoSQL、云端数据库、区块链、深度学习等领域的前瞻性热点话题。
即日起,填写DTCC2017会前调查问卷,即有机会赢取价值2600元的大会门票1张!仅限10张!
----------------------------------------
活动截止时间:2017年5月5日统一公布

问卷入口>>
  

北京皓辰网域网络信息技术有限公司. 版权所有 京ICP证:060528号 北京市公安局海淀分局网监中心备案编号:1101082001
广播电视节目制作经营许可证(京) 字第1234号 中国互联网协会会员  联系我们:
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP