看看ARM处理器存储访问一致性问题_第1页
看看ARM处理器存储访问一致性问题_第2页
看看ARM处理器存储访问一致性问题_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第第页看看ARM处理器存储访问一致性问题

1.3DMA造成的数据不一致问题DMA操作直接访问主存,而不会更新cache和WriteBuffer中相应的内容,这样就可能造成数据的不一致。

如果DMA从主存中读取的数据已经包含在cache中,而且cache中对应的数据已经被更新,这样DMA读到的将不是系统中最新的数据。同样DMA写操作直接更新主存中的数据,如果该数据已经包含在cache中,则cache中的数据将会比主存中对应的数据“老”,也将造成数据的不一致。

为了避免这种数据不一致情况的发生,根据系统的具体情况,执行下面操作序列中的一种或几种:

1)将DMA访问的存储区域设置成非缓冲的,即uncachable及unbufferable;2)将DMA访问的存储区域所涉及数据cache中的块设置成无效,或者清空数据cache;3)清空WriteBuffer(执行WriteBuffer中延迟的所有写操作);4)在DMA操作期间限制处理器访问DMA所访问的存储区域。1.4指令预取和自修改代码在ARM中允许指令预取,在CPU执行当前指令的同时,可以从存储器中预取其后若干条指令,具体预取多少条指令,不同的ARM实现中有不同的数值。

当用户读取PC(寄存器)的值时,返回的是当前指令下面第2条指令的地址。比如当前执行的是第N条指令,当用户读取PC寄存器的值时,返回的是指令N+2的地址。对于ARM指令来说,读取PC寄存器的值时,返回当前指令地址值加8个字节;对于Thumb指令来说,读取PC寄存器的值时,返回当前指令地址值加4个字节。

2Linux中解决存储访问一致性问题的方法

在Linux中,是用barrier()宏来解决以上存储访问一致性问题的,barrier()的定义如下所示:

#definebarrier()__asm____volatile__("":::"memory")另外在barrier()的基础上还衍生出了很多类似的定义,如:

#definemb()__asm____volatile__("":::"memory")#definermb()mb()#definewmb()mb()#definesmp_mb()barrier()#definesmp_rmb()barrier()#definesmp_wmb()barrier()barrier是内存屏障的意思,CPU越过内存屏障后,将刷新自己对存储器的缓冲状态。barrier()宏定义这条语句实际上不生成任何代码,但可使gcc在barrier()之后刷新寄存器对变量的分配。具体分析如下。

概括起来说barrier()起到两个作用:

1)告诉编译器不要优化这部分代码,保持原有的指令执行顺序;2)告诉CPU执行完barrier()之后要进行同步操作,更新registers、cache、写缓存和内存中的内容

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论