免费注册 查看新帖 |

Chinaunix

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

[内核入门] per-cpu变量之间是如何同步的? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2016-06-02 20:34 |只看该作者 |倒序浏览
我想问问,per-cpu变量之间是如何同步的?即当cpu3更改了它本地的per-cpu变量之后,如果cpu0去读取该变量(cpu0本地副本),它应该读到修改后的值吧。那么该变量是如何从cpu3本地副本更新到cpu0本地副本的?

论坛徽章:
9
辰龙
日期:2014-08-18 20:38:42未羊
日期:2014-09-04 08:50:45丑牛
日期:2014-09-06 00:12:55寅虎
日期:2014-12-22 20:50:56摩羯座
日期:2015-01-14 22:28:15巳蛇
日期:2015-01-23 20:39:272015年辞旧岁徽章
日期:2015-03-03 16:54:1515-16赛季CBA联赛之青岛
日期:2016-03-13 23:37:1915-16赛季CBA联赛之深圳
日期:2016-03-29 18:52:38
2 [报告]
发表于 2016-06-02 22:01 |只看该作者
回复 1# tomxue0126


为什么要更新,本来PER CPU变量就是一人CPU一个副本,互相独立的。这是它的本意,一个核改了,如果去同步修改到其它核的副本那不就成全局变量了吗。

访问别人的核的副本,用per_cpu就行了。它会下接算出对应的核的副本的地址的。

论坛徽章:
0
3 [报告]
发表于 2016-06-03 01:12 |只看该作者
回复 2# Tinnal

谢谢答复!
不过还是没理解。
你也说每个CPU一个变量副本,既然是副本,好歹也要和原始变量保持一致吧?
如果每个CPU看到的变量副本值都不同,那这程序还能正常工作吗?
如果不需要和原始变量保持一致,那为什么不直接用4个不同的变量?(假设是个4核处理器)

per-cpu的出现是为了解决加锁的问题,但没说不要同步啊

   

论坛徽章:
11
程序设计版块每日发帖之星
日期:2015-09-09 06:20:00CU十四周年纪念徽章
日期:2016-05-16 11:11:112016科比退役纪念章
日期:2016-05-04 17:16:57程序设计版块每日发帖之星
日期:2016-02-20 06:20:00程序设计版块每周发帖之星
日期:2015-11-06 19:30:58程序设计版块每日发帖之星
日期:2015-09-12 06:20:00程序设计版块每日发帖之星
日期:2015-09-11 06:20:00每日论坛发贴之星
日期:2015-09-10 06:20:00程序设计版块每日发帖之星
日期:2015-09-10 06:20:00每日论坛发贴之星
日期:2015-09-09 06:20:0015-16赛季CBA联赛之四川
日期:2016-12-15 15:52:10
4 [报告]
发表于 2016-06-03 09:07 |只看该作者
你的论据基础就是错的,per-cpu字面意思就是一人一份,不用同步,自己用自己的

论坛徽章:
9
程序设计版块每日发帖之星
日期:2016-02-13 06:20:00数据库技术版块每日发帖之星
日期:2016-06-15 06:20:00数据库技术版块每日发帖之星
日期:2016-06-16 06:20:00数据库技术版块每日发帖之星
日期:2016-06-18 06:20:00程序设计版块每日发帖之星
日期:2016-06-27 06:20:00程序设计版块每日发帖之星
日期:2016-07-09 06:20:00IT运维版块每日发帖之星
日期:2016-07-15 06:20:00IT运维版块每日发帖之星
日期:2016-07-27 06:20:00程序设计版块每日发帖之星
日期:2016-08-18 06:20:00
5 [报告]
发表于 2016-06-03 10:26 |只看该作者
tomxue0126 发表于 2016-06-03 01:12
回复 2# Tinnal

谢谢答复!


你把per-CPU的需求正好搞反了
说方案就是错的

论坛徽章:
9
辰龙
日期:2014-08-18 20:38:42未羊
日期:2014-09-04 08:50:45丑牛
日期:2014-09-06 00:12:55寅虎
日期:2014-12-22 20:50:56摩羯座
日期:2015-01-14 22:28:15巳蛇
日期:2015-01-23 20:39:272015年辞旧岁徽章
日期:2015-03-03 16:54:1515-16赛季CBA联赛之青岛
日期:2016-03-13 23:37:1915-16赛季CBA联赛之深圳
日期:2016-03-29 18:52:38
6 [报告]
发表于 2016-06-06 10:29 |只看该作者
本帖最后由 Tinnal 于 2016-06-06 10:30 编辑

回复 3# tomxue0126


回复 2# Tinnal

谢谢答复!
不过还是没理解。
你也说每个CPU一个变量副本,既然是副本,好歹也要和原始变量保持一致吧?
不会,各是各的。


如果每个CPU看到的变量副本值都不同,那这程序还能正常工作吗?
为什么不能呢


PERCPU变量的目的就是每核一份,不共享。 如果要共享,用全局变量就行了。


C语言有局部变量的概念,每个函数都是独立的,那程序会出问题吗?
   

论坛徽章:
9
辰龙
日期:2014-08-18 20:38:42未羊
日期:2014-09-04 08:50:45丑牛
日期:2014-09-06 00:12:55寅虎
日期:2014-12-22 20:50:56摩羯座
日期:2015-01-14 22:28:15巳蛇
日期:2015-01-23 20:39:272015年辞旧岁徽章
日期:2015-03-03 16:54:1515-16赛季CBA联赛之青岛
日期:2016-03-13 23:37:1915-16赛季CBA联赛之深圳
日期:2016-03-29 18:52:38
7 [报告]
发表于 2016-06-06 10:34 |只看该作者
如果不需要和原始变量保持一致,那为什么不直接用4个不同的变量?(假设是个4核处理器)
用4个不同的变量,不同核的代码就不能复用了呀。


per-cpu的出现是为了解决加锁的问题,但没说不要同步啊
没说,不代表要做。per_CPU的目的,是解决各核的数据依赖,让和个能并行工作,互相不阻塞。

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-08-17 06:20:00程序设计版块每日发帖之星
日期:2016-07-16 06:20:00程序设计版块每日发帖之星
日期:2016-07-18 06:20:00每日论坛发贴之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16赛季CBA联赛之江苏
日期:2017-06-26 11:05:5615-16赛季CBA联赛之上海
日期:2017-07-21 18:12:5015-16赛季CBA联赛之青岛
日期:2017-09-04 17:32:0515-16赛季CBA联赛之吉林
日期:2018-03-26 10:02:16程序设计版块每日发帖之星
日期:2016-07-15 06:20:0015-16赛季CBA联赛之江苏
日期:2016-07-07 18:37:512015亚冠之萨济拖拉机
日期:2015-08-17 12:21:08
8 [报告]
发表于 2016-06-06 10:40 |只看该作者
>> 如果不需要和原始变量保持一致,那为什么不直接用4个不同的变量?(假设是个4核处理器)

可以用4个不同的变量,per_cpu的一种“朴素”实现是全局数组,每个core使用不同的下标/索引。

但如果是4个不同名字的变量的话,想象一下代码会写成什么样子?
if (core == 0) use_var(var_0);
else if (core == 1) use_var(var_1);
....

论坛徽章:
0
9 [报告]
发表于 2016-06-06 11:26 |只看该作者
本帖最后由 tomxue0126 于 2016-06-06 11:50 编辑

谢谢楼上各位!
我大致理解了。主要是应用场景没想明白,后来找到一处代码如下,即各个CPU的中断mask。
这个在多核处理器中肯定是各个CPU独立标示的,这样就容易理解per-cpu为什么要这样设计了。
  1. struct irq_desc {
  2.     ...
  3.     unsigned int __percpu   *kstat_irqs;   // @kstat_irqs:     irq stats per cpu
  4.     ...
  5.     struct cpumask      *percpu_enabled;
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP