前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【Linux 内核 内存管理】优化内存屏障 ② ( 内存屏障 | 编译器屏障 | 处理器内存屏障 | 内存映射 I/O 写屏障 )

【Linux 内核 内存管理】优化内存屏障 ② ( 内存屏障 | 编译器屏障 | 处理器内存屏障 | 内存映射 I/O 写屏障 )

作者头像
韩曙亮
发布2023-03-30 14:13:22
2.3K0
发布2023-03-30 14:13:22
举报
文章被收录于专栏:韩曙亮的移动开发专栏

文章目录

一、内存屏障


内存屏障 , 又称为 " 屏障指令 " , 用于保证 " 编译器 “ 或 ” CPU “ 访问内存时 , 保证 按照顺序执行 , 即 ” 内存屏障 之前 “ 的指令 与 ” 内存屏障 之后 " 的指令 不会犹豫 编译器 和 CPU 优化导致 顺序混乱 ;

" 指令 " 优化主要分

2

种 :

  • ① 编译器优化 : 为了 提高程序执行性能 , 编译器会在 不影响 程序逻辑的前提下 , 对程序指令进行优化 , 主要操作是 调整程序指令的执行顺序 ;
  • ② CPU 执行优化 : 该优化是为了 提高 " 流水线 " 性能 , 但是 CPU 执行优化会导致 指令乱序执行 , 后面的指令先于前面的指令执行 , 导致 寄存器中的值冲突 ;

Linux 内核支持的

3

种内核屏障 :

  • ① 编译器屏障
  • ② 处理器内存屏障
  • ③ 内存映射 I/O 写屏障 , 全称 Memory Mapping I/O , 简称 MMIO , 目前已经被弃用 ;

二、编译器屏障


" 编译器屏障 “ 针对 ” 编译器优化 " ;

编译器优化 是 为了 提高程序执行性能 ,

编译器会在编译代码时 ,

在 不影响 程序逻辑的前提下 , 对程序指令进行重排 , 主要操作是 调整程序指令的执行顺序 ;

优化后的结果 , 可能 不符合软件开发想要开发的需求 ;

三、处理器内存屏障


" 处理器内存屏障 “ 针对 ” CPU " 之间的内存访问乱序 和 CPU 访问外设乱序 问题 ;

为了 提高 " 流水线 " 性能 , 新式处理器可以采用 " 超标量 体系结构 “ 和 ” 乱序执行 " 技术 , 可以在 一个时钟周期 中 并行执行多条指令 ;

但是 CPU 执行优化会导致 指令乱序执行 , 后面的指令先于前面的指令执行 , 导致 寄存器中的值冲突 ;

CPU 执行优化总结 :

  • 顺序取指令 ,
  • 乱序执行 ,
  • 执行结果顺序提交 ;
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-04-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 一、内存屏障
  • 二、编译器屏障
  • 三、处理器内存屏障
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档