ARM 学习笔记(四) 快速上下文切换(FCSE)技术

原创 2011年10月21日 20:02:48

接上回说,

       我们已经了解存储器管理的方法,现在我们来看一下,ARM 对不同进程的地址管理-------快速上下文切换技术(Fast Context Switch Extension ,FCSE ).    FCSE 通过修改系统中不同进程的虚拟地址,避免在进行进程间切换时造成的虚拟地址到物理地址的重映射,从而提高系统的性能。

      FCSE的原理

      通常情况下,如果两个进程占用的虚拟地址空间由重叠,系统在这两个进程之间进行切换时,必须进行虚拟地址到物理地址的重映射。而虚拟地址到物理地址的重映射涉及到重建MMU中的页表,而且cache 及TLB中的内容都必须使无效(通过设置协处理器寄存器的相关位)。这些操作将带类巨大的系统开销,一方面重建MMU和使无效cache及TLB的内容需要很大的开销,另一方面重建cache和TLB内容也需要很大的开销。

      FCSE的引入避免了这种系统开销。它位于CPU和MMU 之间。 如果两个进程使用了同样的虚拟地址空间,则对CPU而言,两个进程使用了同样的虚拟地址空间;快速上下文切换机构对各进程的虚拟地址进行变换,这样的系统中除了CPU之外的部分看到的时经过快速上下文切换机构变换的虚拟地址。快速上下文切换机构将个进程的虚拟地址空间变换成不同的虚拟地址空间。这样在进行进程间切换时就不需要进行虚拟地址到物理地址的重映射。

      ARM系统中,4GB的虚拟空间被分成了128个进程空间块,每一个进程空间块大小为32MB。每个进程空间块中可以包含一个进程,该进程可以使用虚拟地址空间0x0~0x01FFFFFF,这个地址范围也就是CPU看到的进程的虚拟空间。系统128个进程空间块的编号0~127, 标号为X 的进程空间块中的进程实际使用的虚拟地址空间为(X *0x02000000)到(X*0x02000000+0x01FFFFFF),这个地址空间是系统中除了CPU 之外的其他部分看到的该进程所占用的虚拟地址空间。

      快速上下文切换机构将CPU发出的每个虚拟地址按照上述的规则进行变换,然后发送到系统的其他部分。变换过程如下图:

由地址VA到MVA的变换算法如下所示;

if (VA[31:25]==0b0000000)then

MVA=VA|(PID<<25)

else

MVA=VA

其中。PID为当前进程的所在进程空间的编号,即当前进程的进程标识符。其取值为0~127。

        系统中,每个进程都使用虚拟地址空间0x0~0x01FFFFFF,当进程访问本进程的指令和数据时,它产生的为虚拟地址VA的高7位为0;快速上下文切换机构用该进程的进程标示符代替VA的高7位,从而得到变换后的虚拟地址MVA,这个MVA在该进程对应的进程空间块内。

        当VA的高7位不全是0时,MVA=VA。这种VA是本进程用于访问别的进程中的数据和指令的虚拟地址,注意这时被访问的进程标识符不能为0.

        CP15中的寄存器C13用于快速上下文切换。其编码格式如下所示。

访问寄存器C13的指令格式如下所示。

MCR           p15, 0,<Rd>,<c13>,c0,0

MRC           P15,0,<Rd>,<c13>,c0,0

其中, 在读操作时,结果中位[31::25]返回PID,其他位 的数值是不可以预知的。写操作将设置PID的值。

        当PID的值为0时,MVA=VA,相当于禁止了FCSE。系统复位后PID即为0.

        当PID的值不为0时,相当于使能了FCSE。

 

                                                                                                                                                                                                        Atlas.dayong

 

arm架构基础知识小结

从单片机转到
  • zbffff
  • zbffff
  • 2014年01月31日 23:13
  • 7363

ARM9开发之实现多任务操作系统的基本技术

/** * I has illustrated a way to using exception handling mechanism to implement * a operating ...
  • wenshifang
  • wenshifang
  • 2015年08月07日 16:38
  • 1322

ARM9学习笔记之——MMU

我记得有一次我去应聘ARM-Linux软件工程师。结果被问到ARM中的虚拟内存是怎么管理的。由于我只对X86平台下的MMU了解,所以我被问倒了。原来我所学的只是皮毛。还有很多东西值得我去深入。要做AR...
  • hevake_lcj
  • hevake_lcj
  • 2012年03月27日 22:38
  • 8285

VA、MVA、PA

VA(虚地址),MVA(修正后虚地址),PA(物理地址) 1)VA,是程序中的逻辑地址,0x00000000~0xFFFFFFFF。 2)MVA,由于多个进程执行,逻辑地址会重合。所以,跟据进程号将逻...
  • qwaszx523
  • qwaszx523
  • 2017年06月22日 16:11
  • 251

ARM处理器的快速上下文切换技术

5.3.1  FCSE概述FCSE(Fast Context Switch Extension,快速上下文切换)位于CPU和MMU之间,如果两个进程使用了同样的虚拟地址空间,则对CPU而言,两个进程使...
  • jinzheng_2010
  • jinzheng_2010
  • 2011年06月23日 08:42
  • 2821

ARM的快速上下文切换(FCSE)

一、FCSE的原理       通常情况下,如果两个进程占用的虚拟地址空间由重叠,系统在这两个进程之间进行切换时,必须进行虚拟地址到物理地址的重映射。而虚拟地址到物理地址的重映射涉及到重建MMU中的...
  • y695385603
  • y695385603
  • 2013年10月27日 14:05
  • 1601

ARM内存管理(MMU)详解

嵌入式系统中,存储系统差别很大,可包含多种类型的存储器件,如 FLASH , SRAM , SDRAM , ROM 等,这些不同类型的存储器件速度和宽度等各不相同;在访问存储单元时,可能采取平板式的地...
  • yimu13
  • yimu13
  • 2010年11月28日 10:46
  • 10758

arm MMU原理

虚拟存储器使得程序并发执行得以实现,并且可以让大程序在较小的内存中也能运行,因为在程序本身看来他们似乎拥有了可寻址长度大小的内存,比如你是32位的地址线位宽存,但是你只有1G的内存条,使用虚拟地址映射...
  • qq_35144795
  • qq_35144795
  • 2017年10月14日 22:37
  • 108

ARM 学习笔记(四) 快速上下文切换(FCSE)技术

接上回说,        我们已经了解存储器管理的方法,现在我们来看一下,ARM 对不同进程的地址管理-------快速上下文切换技术(Fast Context Switch Extension ,...
  • prike
  • prike
  • 2017年08月04日 09:59
  • 175

ARM 学习笔记(四) 快速上下文切换(FCSE)技术

接上回说,        我们已经了解存储器管理的方法,现在我们来看一下,ARM 对不同进程的地址管理-------快速上下文切换技术(Fast Context Switch Extension ,...
  • prike
  • prike
  • 2017年08月04日 09:59
  • 175
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ARM 学习笔记(四) 快速上下文切换(FCSE)技术
举报原因:
原因补充:

(最多只允许输入30个字)