返回首页  设为首页  加入收藏  今天是:
网站首页电脑主板电脑cpu电脑内存电脑硬盘电脑显卡电脑电源显示器电脑配件电脑维修
相关文章
 X86和ARM中的指令集支持原子…
 多设备连接出差也能用双屏关…
 便携显示器的用处究竟有多大…
 FS-3080C植物气孔计(新型)
 UPERFECT UStation Delta 双…
 三大产业集体暴跌!韩外长求…
 暑期笔记本选购必看!一文理…
 鲁大师PC半年报:AMD锐龙跑分…
 职场精英最强生产力工具全新…
 锐龙7 4700u
 华为数字系列笔记本电脑大更…
 华勤技术上交所主板IPO过会要…
 2023年cpu 排行榜天梯图
 白色高颜值18相供电轻松超频…
 技嘉主板固件被发现内置了后…
 白色高颜值18相供电轻松超频…
 16G+1T大内存骁龙8G2+144Hz屏…
 内存 - 站长百科
 信仰无价 威刚推出ROG专属DD…
 对存储的一些思考
 业界最低功耗 三星宣布量产汽…
 40系显卡架构是什么 40系显卡…
 百川智能发布Baichuan-13B开…
 机构研选 AI需求大增+技术变…
 参数量再加大百川智能发布13…
 亚马逊和英伟达也卷入“反性…
 优派爆款24吋Fast IPS电竞1m…
 轻薄移动办公利器 华硕灵耀1…
 优派爆款24吋Fast IPS电竞1m…
 2600nit超高亮屏硕腾HUGEROC…
 每天对着电脑十个小时如何科…
 Win11 23H2年度更新确认:四…
 优化风道是电脑散热的关键 风…
 14秒!中国人自己的CPU+操作…
 三款主流跑分软件对比:就CP…
 cpu散热器上的几根线分别是什…
 一文看懂显示器所有指标参数…
 笔记本电脑为什么要另外买显…
 不太懂装机近期想配一台电脑…
 55寸防爆电视防爆显示器电脑…
 北斗系统总设计师杨长风:北…
 一季度IPO过会率八成
 今日关注]从金融业年报内容看…
 遭泥石流反复“洗劫”的汶川…
 “在这里工作家人为我感到骄…
 内存条的作用
 dram是内存条吗
 DDR5
 微机中的内存条指的是什么
 数码专业网站头条PK - 网易数…
专题栏目
网络
您现在的位置: 电脑评测网 >> 电脑内存 >> 正文
高级搜索
X86和ARM中的指令集支持原子操作
作者:佚名 文章来源:本站原创 点击数: 更新时间:2023/7/16 20:27:22 | 【字体:

  老婆只许我宠你开发一个非常重要的区别在于多线程之间的消息传递和数据共享问题,然而在这中间变量的原子操作是一个非常重要的架构和编译选项都可能生成不同的指令,从而影响到变量的原子操作,导致一些异常、数据错乱等问题。

  这个是在面试的时候遇到的问题,当时没有答出来。回到家以后查了查,整理记录下来。

  原问题:什么指令集支持原子操作?其原理是什么? 如果考虑到全部的指令集,问题太大了,这里简化下。以X86和ARM为例。

  原子操作是不可分割的操作,在执行完毕时它不会被任何事件中断。在单处理器系统(UniProcessor,简称 UP)中,能够在单条指令中完成的操作都可以认为是原子操作,因为中断只能发生在指令与指令之间。

  在单处理器中,解决这个问题的方法是,将count++语句翻译成单指令操作

  进程的上下文切换总是在一条指令执行之后完成,所以不会出现上述的并发问题。对于单处理器来说,一条处理器指令就是一个原子操作。

  同样,ARM里的SWP和X86里的XCHG都是对于单处理器来说,是原子操作。

  但是,在多处理器系统(Symmetric Multi-Processor,简称 SMP)中情况有所不同,由于系统中有多个处理器在独立的运行,即使在能单条指令中完成的操作也可能受到干扰。因为这个时候并发的主题不再是进程,而是处理器。

  IntelX86指令集提供了指令前缀lock用于锁定前端串行总线FSB,保证了指令执行时不会收到其他处理器的干扰。

  使用lock指令前缀之后,处理期间对count内存的并发访问(Read/Write)被禁止,从而保证了指令的原子性。

  在执行伴随的指令期间使处理器的LOCK#信号有效(将指令变为原子指令)。在多处理器环境中,LOCK#信号确保处理器在信号有效时独占使用任何共享存储器。

  如果LOCK前缀与这些指令之一一起使用,并且源操作数是内存操作数,则可能会生成未定义的操作码异常(#UD)。如果LOCK前缀与任何不在上述列表中的指令一起使用,也会产生未定义的操作码异常。无论是否存在LOCK前缀,XCHG指令都始终声明LOCK#信号。

  LOCK前缀通常与BTS指令一起使用,以在共享存储器环境中的存储器位置上执行读取 – 修改 – 写入操作。

  LOCK前缀的完整性不受存储器字段对齐的影响。内存锁定是针对任意不对齐的字段。

  可见:在对称多处理器架构的情况下,LOCK_PREFIX被解释为指令前缀lock。而对于单处理器架构,LOCK_PREFIX不包含任何内容。

  在ARM架构下,没有LOCK#指令,其具体实现如下:## ARMv6之前 早期的ARM架构是不支持SMP的,这些单核架构的CPU实现原子操作的方式就是通过关闭CPU中断来完成的。

  可以看到,对v->

  counter的操作是一个临界区,指令的执行不能被打断,内存的访问也需要保持没有干扰。

  ARMv6以前的版本通过关本地中断来保护这块临界区,看起来相当简单,其奥秘就在于ARMv6以前的版本不支持SMP。

  比如经典的read-modify-write问题,其本质是保持一个对内存read和write访问的原子性问题,也就是说内存的读和写的访问不能被打断。对该问题的解决可以通过硬件、软件或者软硬件结合的方法来进行。

  早期的ARM CPU给出的方案就是依赖硬件:SWP这个汇编指令执行了一次读内存操作、一次写内存操作,但是从程序员的角度看,SWP这条指令就是原子的,读写之间不会被任何的异步事件打断。

  具体底层的硬件是如何做的呢?这时候,硬件会提供一个lock signal,在进行memory操作的时候设定lock信号,告诉总线这是一个不可被中断的内存访问,直到完成了SWP需要进行的两次内存访问之后再clear lock信号。

  这两个指令是用来同步的,不是用来执行原子操作的。在将独占访问引入ARM架构之前,SWP和SWPB指令常用于同步。

  其局限性是:如果中断在触发交换操作时触发,则处理器必须在执行中断之前完成指令的加载和存储部分,从而增加中断延迟。由于独立加载和独占存储是单独的指令,因此在使用新的同步基元时会降低此效果。

  但是在多核系统中,交换指令期间阻止所有处理器访问主存会降低系统性能。在处理器工作在不同频率但是共享相同主存的多核系统中,情况尤其如此。

  所以在ARMv6及以后的版本中,弃用了SWP, ARMv6架构引入了独占访问内存为止的概念,提供了更灵活的原子内存更新。

  访存指令LDREX/STREX和普通的LDR/STR访存指令不一样,它是“独占”访存指令。这对指令访存过程由一个称作“exclusive monitor”的部件来监视是否可以进行独占访问。

  (1)LDREX R1 ,[R0] 指令是以独占的方式从R0所指的地址中取一个字存放到R0中;

  (2)STREX R2,R1,[R0] 指令是以独占的方式用R1来更新内存,如果独占访问条件允许,则更新成功并返回0到R2,否则失败返回1到R2。

  微处理器之间的许多差异都很细微,并且与内存寻址方式、分支执行方式、异常处理方式等有关。本文将考虑更高层次的差异,并将简要比较精简

  架构实际上就是CISC与RISC之间的区别,很多用户不理解它们两个之间到底有哪些区别,实际就是它们的领域不太相同,然后追求也不相同。

  ,指一个intel通用计算机系列的标准编号缩写,也标识一套通用的计算机

  架构不同,其特点就是完全开源。今天跟大家一起盘点一下国产RISC-V内核的单片机。

  架构并立,形成处理器主流架构的“三足鼎立”之势。   当前,RISC-V International会员阵容

  星光闪耀,阿里、谷歌、华为、英伟达、高通等国际顶级大厂都在其中,就连英特

  这个是在面试的时候遇到的问题,当时没有答出来。回到家以后查了查,整理记录下来。 原问题:什么

  机器(AdvancedRISCMachine,更早称作:AcornRISCMachine),是一个32位精简

  。即对存储单元的一次读和一次不可被切割。 SWP和SWPB分别完毕存储器和寄存器之间 一个字(32bit)和一个字节(8bit)的数据交换

  之于Android,而龙芯LoongArch架构从设计上考虑到兼容生态需求,除了自主设计的

  编码、寻址模式之外,还融合了龙芯在二进制翻译方面的积累,通过翻译的方式兼容MIPS、

  ,开源的CPU核和SoC芯片不断涌现,生态环境逐渐丰富,开发者社区愈来愈活跃。

  是美国Intel公司为其第一块16位CPU(i8086)专门开发的,美国IBM公司1981年推出的世界第一台PC机

  ,指一个intel通用计算机系列的标准编号缩写,也标识一套通用的计算机

  和平板用户带来超长待机。下面联智通达小编就从5个方面为您分享一下两者之间的区别,一起来看看吧 1、性能 经历30多年的发展,

  系统的兼容性、软件开发的方便性及可使用工具的多样性及功耗这五个方面详细的对比了

  机器(AdvancedRISCMachine,更早称作:AcornRISCMachine),是一个32位精简

  ,指一个intel通用计算机系列的标准编号缩写,也标识一套通用的计算机

  ,指一个intel通用计算机系列的标准编号缩写,也标识一套通用的计算机

  的应用,尤其是在国防和军事上的一些高精尖技术及实时性要求极高的领域中,就更体现出了其优越的性能。

  架构这两者谁将统一市场的争执一直都有,但是也有人说这两者根本不具备可比性,

  寄存器和处理器模式(26-bit 体系) 寄存器和处理器模式(32-bit 体系) 程序状态寄存器和操纵它的

电脑内存录入:admin    责任编辑:admin 
  • 上一个电脑内存:

  • 下一个电脑内存: 没有了
  •  
     栏目文章
    普通电脑内存 X86和ARM中的指令集支持原子操作 (07-16)
    普通电脑内存 16G+1T大内存骁龙8G2+144Hz屏+200W快充这才是… (07-16)
    普通电脑内存 内存 - 站长百科 (07-16)
    普通电脑内存 信仰无价 威刚推出ROG专属DDR5内存 (07-16)
    普通电脑内存 对存储的一些思考 (07-16)
    普通电脑内存 业界最低功耗 三星宣布量产汽车UFS 31内存解决… (07-16)
    普通电脑内存 内存条的作用 (07-15)
    普通电脑内存 dram是内存条吗 (07-15)
    普通电脑内存 DDR5 (07-15)
    普通电脑内存 微机中的内存条指的是什么 (07-15)
    普通电脑内存 数码专业网站头条PK - 网易数码 (07-15)
    普通电脑内存 优米手机维修培训学校-难得一见内存96MB和176… (07-15)
    普通电脑内存 涨价更应该认准了选 值得选购的内存推荐 (07-15)
    普通电脑内存 电脑cpu温度过高怎么解决 电脑cpu内存占用过高… (07-15)
    普通电脑内存 DDR5内存时代来了!英睿达DDR5 16GB内存图赏 (07-15)
    普通电脑内存 难得一见!内存仅96MB和176MB的电脑:运行Win… (07-15)
    普通电脑内存 苹果手机升内存好不好?有风险吗?苹果手机升… (07-14)
    普通电脑内存 内存是什么 内存解释 (07-14)
    普通电脑内存 运行内存4g和6g的区别 (07-14)
    普通电脑内存 影响手机流畅性的主要因素是什么?这部机型证… (07-14)