SMP的同步机制

随着 SMP(对称多处理器架构) 的发展,在享受处理器更快的执行效率的同时,也为数据同步带来了更大的挑战,因为在 SMP 架构中,程序确实是在并发执行,从单 CPU 只需要考虑调度风险到 SMP 中还需要考虑到多 CPU 中同时执行的风险,而且在单 CPU 下的乱序执行也会在 SMP 架构中带来,从而也衍生了一些新的同步机制,比如:内存屏障、perCPU 机制等等。

percpu

对于读而言,cache 带来了巨大的性能提升,当涉及到修改时,也是在缓存中进行操作,然后同步到内存中,对于单 CPU 而言,这没有什么问题,但是对于 SMP 架构而言,一个 CPU 对全局数据的修改将会导致所有其它 CPU 上对该全局数据的缓存失效,需要全部进行更新,这个操作将带来性能上的损失。

事实上,percpu 只适合在特殊条件下使用:也就是当它确定在系统的 CPU 上的数据在逻辑上是独立的时候。正因为它的这种应用场景,CPU 之间的 percpu 变量并不需要同步,在整个 percpu 的生命周期内, percpu 变量对应的 CPU 副本都被对应的 CPU 独占使用。

比较经典的应用场景是作为计数器使用,在网络接收程序中,接收数据包的程序可能先后运行在不同的 CPU 上,采用 percpu 变量进行计数,最后将所有 CPU 上的 percpu 副本相加就可以得到所接收数据包的总和,在这里,每个 CPU 上的 percpu 计数器并没有产生逻辑上的联系。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值