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 计数器并没有产生逻辑上的联系。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值