PowerPcLinux内存管理优化设想

PowerPcLinux内存管理优化设想

ID:37923435

大小:64.50 KB

页数:2页

时间:2019-06-02

PowerPcLinux内存管理优化设想_第1页
PowerPcLinux内存管理优化设想_第2页
资源描述:

《PowerPcLinux内存管理优化设想》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、PowerPCLinux内存管理优化设想作者:harveywang邮箱:harvey.perfect@gmail.com新浪博客地址:http://blog.sina.com.cn/harveyperfect,有关于减肥和学习英语相关的博文,欢迎交流1、总体概述我们都知道在PowerPC处理器e500系列内核MMU单元分为两级结构,L1和L2。L1包括I-L1VSP、I-L1TLB4K、D-L1VSP、D-L1TLB4K(前缀I指示指令,D指示数据。后缀VSP指示可以变大小页,TLB4K指示固定大小页,4Kbyte大小)。即在L1中指令和数据的页转换模块是独立的。L2中包括TLB1

2、和TLB0,其中TLB1为可变大小的页,TLB0为固定大小的页(4Kbyte)。指令和数据共用L2的MMU模块。L1的页转换模块是L2页转换模块的cache。具体说L1的I-L1VSP和D-L1VSP是L2的TLB1的cache;L1的I-L1TLB4K和D-L1TLB4K是L2TLB0的cache。如下图所示图1e500mcMMUL2的TLB1和TLB0是用户可操作的,而L1模块是由硬件维护的,对用户透明。2、Linux基于e500V1内存管理在PowerPCe500V1MMU中有16个L2TLB1条目,页大小可以设置为4K、16K、64K、256K……256M。有256个TLB

3、0条目,每个固定4K大小。L2TLB1和TLB0是实现相同功能,在虚实地址转换时只要在其中之一找到对应的映射关系即可。它们之间的区别仅在于一次映射的区域大小的不同。LinuxPowerPC使用TLB1进行虚拟地址的段式映射,采用段式映射可以直接使用硬件提供的TLB1查找表,可以一次映射较大区域(可达256MB),从而减少缺页故障次数,其虚实地址转换效率高。但在e500V1TLB1中的条目有限,仅16个,LinuxPowerPC不可能使用TLB1完成所有的虚实转换。LinuxPowerPC使用的内核空间的虚实地址转换是由段式映射完成的,即32位系统中4G空间的高端1G,0xc000-

4、0000—0xffff-ffff。而32位系统中4G空间的低3G(0x000-0000—0xbfff-ffff)空间是采用页式映射。TLB0中一共有256个entry,每个4Kbyte,只能映射1Mbyte的空间。即使已经给某进程的虚拟空间分配了实际的物理页面,也会经常产生TLBmiss异常。尤其是操作系统中进程调度频繁,每次调度进程都要无效掉整个TLB0,产生很多的TLBmiss。这样应该会比较影响系统的性能。3、e500mcMMU介绍Freescale的多核处理,如P4080采用的内核是e500mc的内核,其MMU的架构和e500V1相同。在e500mcMMU中TLB1的条目增

5、加到了64个,单个条目最大支持到4GB。TLB0条目增加到512个,同一时刻可以映射2MB空间。如图1所示。4、基于e500mcMMU的Linux内存管理优化设想在e500mc内核中,TLB1的条目增加到了64个。是否可以把其中的8个或4个划分给用户空间使用,在进程创建或要被调度运行时,把分配给进程的代码空间、数据空间等物理地址连续的较大空间的映射关系填充到TLB1的entity中。当然,能使用段式映射的需要满足物理空间连续,且地址边界段对齐,如要映射1MB的空间,其虚拟地址和物理地址至少都要1MB边界对齐。如果进程的虚拟地址2M边界对齐,而实际分配的物理地址空间是1MB地址对齐,

6、此时只能使用1MB映射区域,当然可以使用多个1MB的映射区。以此类推。这种设想方式可能导致一个进程的代码段会同时使用段式映射和页式映射。大段的地址边界整齐(虚拟地址和物理地址都要边界对齐)的部分采用段式映射,其他区域采用页式映射。如果内核中创建进程部分内核代码模块能考虑到这种优化的话,在给进程分配大段的虚拟空间和物理空间时尽量做到一定的边界对齐的话。这种内存管理优化的方式应该能提高不少的性能。这可能需要对内核代码有不少的改动。请各位高手评价一下这种设想的方式是否可行?参考文档:1、LinuxPowerPC详解—核心篇作者王齐机械工业出版社2、e500mc_RM_RevF.pdffr

7、eescalemanual3、linux内核之内存管理.doc

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。