rmb() --- 提供了 “读” 内存屏障,它确保跨越rmb()之前不会发生重排序。也就是rmb()之前的载入操作不会被重新排在该调用之后。
wmb() --- 提供了“写”内存屏障, 如rmb()类似,区别仅仅是它针对存储,而非载入。
mb() --- 即提供了读屏障,也提供了写屏障。载入和存储的动作都不会跨越屏障重新排序。
read_barrier_depends() --- 是rmb()的一个变种,它提供了一个读屏障,但是仅仅是针对后续读操作所依赖的那些载入而言。
read_barrier_depends() 比 rmb() 执行的快。
对于SMP,内核也提供了响应的屏障:
smp_rmb();
smp_read_barrier_depends();
smp_wmb();
smp_mb();
barrier(); //阻止编译器对载入或存储操作进行优化
不同体系结构,屏障的实际效果差别很大