VxWorks 内存管理(3)

虚拟内存管理

对于带MMU的目标板,VxWorks提供虚拟内存的支持,VxWorks提供了两种虚拟内存管理单元(MMU)的支持: 基本MMU和VxVMI

基本MMU邦定于VxWorks中,可以通过config.h中宏定义INCLUDE MMU BASIC或Tornado工程配置中包含基本MMU组件

VxVMI是wind River公司推出的一个可选软件模块,实现了MMU的全部功能

VxWorks中有关MMU的配置包括以下内容INCLUDE MMU BASIC: 基本MMU的支持。

        INCLUDE MMU FULL: 完整MMU的支持(需要VxVMD

        INCLUDE PROTECT TEXT: 代码段写保护支持(需要VVMD

        INCLUDE PROTECT VEC TABLE: 中断向量表写保护支持需要VxVMI

虚拟内存几个名词:

  1. 虚拟地址空间:由程序计数器的寻址能力来决定其大小,如32位的i86虚拟地址空间=4GB
  2. 物理地址:用于内存芯片级的单元寻址,与处理器连接的地址总线相对应(与地址总线相对应 )
  3. 虚拟地址:虚拟地址空间中的地址,程序中使用的都是虚拟地址
  1. 内存映射:建立虚拟地址与物理地址之间的对应关系一-处理器中MMU可以完成此功能

基本MMU与VxWorks捆绑在一起,可以指定基于页的内存区域为不可缓存,该特性能够使直接内存访问(DMA)和处理其内部通信更为有效、迅速。如当其它处理器或DMA设备访问同一段地址空间时,可以保证这些数据不被缓存。

如果系统不具备这样的不可缓存特性,那么在访问这些地址空间时,必须从全局上关闭高速缓存Cache或者手工清洗缓冲区(flush)或使缓冲区无效(invalidate)。

  1. 基本MMU使用物理内存描述来建立一种地址映射关系,这种方式是平面型的,实地址和虚地址一一对应
  2. BSP负责提供物理内存描述的支持:

1:sysLib.c中定义PHYS MEM DESC 结构体类型的数组sysPhysMemDesc[]。

2:sysPhysMemdesc[]描述了虚拟地址和实地址之间的对应关系及内存页的初始状态

3:定义的内存区必须是页对齐的,并且必须跨越完整的页

4:页面大小VM PAGE SIZE在config.h中定义,一般为4KB或8KB

·PHYS MEM DESC 数据结构定义如下( vmLib.h) :

typedef struct phys_mem_desc

{

        void *virtualAddr;void *physicalAddr;UNIT len;

        UNIT initialStateMask;

        UNIT initialState;

} PHYS MEM DESC;

virtualAddr和physicalAddr通常是相等的.

sysPhysMemDesc [] 中可能包含的映射空间有内存、flash、rom、I/O设备和外部总线地址空间等·

下面是多cpu嵌入式系统中使用共享内存网络时各目标板的MMU配置示例:

{

        (void *) 0x4000000,/* virtual address */

        (void *) 0x4000000,/* physical address */

        0x20000,/* length */

        /* initial state mask */

        VM_STATE_MASK_VALID | VM_STATE_MASK_WRITABLE | VM_STATE_CACHEABLE,

        /* initial state */

        VM_STATE_VALID | VM_STATE_WRITABLE | VM_STATE_CACHEABLE_NOT,

        ……

}

虚拟内存状态标志:

VM_STATE_VALID

VM_STATE_VALID_NOT

VM_STATE_WRITABLE

VM_STATE_WRITABLE_NOT

VM_STATE_CACHEABLE

VM_STATE_CACHEABLE_NOT

有效性: 有效状态指示虚到实转换是正确的。当转换表被初始化时,全局虚内存被标记为有效的,所有其他虚内存被初始化为无效的.

可写性:通过设置状态为不可写,也可以被设置为只读。这被VxWorks用于写保护所有text段.

可cache: 内存页的cache可以通过设置状态标志为cache被禁止。这对处理器间共享的内存及DMA设备是有用的.

屏蔽标志:描述哪一标志可以被改变

VM_STATE_MASK_VALID

VM_STATE_MASK WRITABLE

VM_STATE_MASK_CACHEABLE

有两种方法可以修改虚地址和实地址之间的映射关系;

        静态方式:通过修改结构体sysPhyMemDesc的内容

        动态方式:通过调用vmBaseStateSet函数来修改一块虚拟内存空间的状态

        所有可能会在应用程序中被访问的物理内存(包括内存映射设备,比如以太网设备、PCI设备、SCSI设备等) 都应该被映射到不同的虚拟内存空间.

在MMU使能的情况下,如果某一段物理地址没有被映射,而试图对这样的地址进行些操作时,将会引起总线错误.

        一个较完整的内存映射实例, 此实例是一款基于mpc860开发板的内存映射表。这款开发板上的器件有mpc860, mpc860内嵌64K存储器, 外挂内存(SDRAM) 、Boot flash、版本fIash.

PHYS MEM_DESC sysPhysMemDesc [] =
{

    {

        (void*)LOCAL_MEM_LOCAL_ADRS,

        (void*)LOCAL_MEM_LOCAL ADRS,

        LOCAL_MEM_SIZE, /*SDRAM*/

        VM_STATE_MASK_VALID | VM_STATE_MASK_ WRITABLE |

        VM_STATE_MASK_CACHEABLE |

        VW_STATE_VALID | VM_STATE_WRITABLE | VM_STATE_CACHEABLE

    },

    ……


}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值