/************************************************
NAME : MMU.C
DESC :
Revision: 2002.2.28 ver 0.0
************************************************/
#include "def.h"
#include "option.h"
#include "2440addr.h"
#include "2440lib.h"
#include "2440slib.h"
#include "mmu.h"
//段(section)是大小为1MB的存储块
// 1) Only the section table is used. 只有段存储块被使用
// 2) The cachable/non-cachable area can be changed by MMT_DEFAULT value.
// The section size is 1MB.段大小为1MB
extern char __ENTRY[];
void MMU_Init(void)
{
int i,j;
//========================== IMPORTANT NOTE =========================
这段程序不能实现当前堆栈和代码区域的重新映射,假如你想让存储区域自由
映射,需要你自己编写一个细致入微的MMU初始化代码
//===================================================================
MMU_DisableDCache(); //禁止数据高速缓存
MMU_DisableICache(); //禁止指令高速缓存
//要使用回写操作,一定要对DCache进行清除
---------------------------------------------------------------------------------------
| for(i=0;i<64;i++) !!!! 我要详细讲解这段!!!! |
| for(j=0;j<8;j++) |
| MMU_CleanInvalidateDCacheIndex((i<<26)|(j<<5)); //使整个DCache的数据无效 |
| MMU_InvalidateICache(); //使整个指令Cache无效 |
| |
---------------------------------------------------------------------------------------
#if 0
//为了快速完成MMU_Init(), Icache在这打开
MMU_EnableICache();
#endif
MMU_DisableMMU(); //禁止MMU
MMU_InvalidateTLB(); //使快表无效
//MMU_SetMTT(int vaddrStart,int vaddrEnd,int paddrStart,int attr)
//MMU_SetMTT(0x00000000,0x07f00000,0x00000000,RW_CNB); //bank0
MMU_SetMTT(0x00000000,0x03f00000,(int)__ENTRY,RW_CB); //bank0
MMU_SetMTT(0x04000000,0x07f00000,0,RW_NCNB); //bank0
MMU_SetMTT(0x08000000,0x0ff00000,0x08000000,RW_CNB); //bank1
MMU_SetMTT(0x10000000,0x17f00000,0x10000000,RW_NCNB); //bank2
MMU_SetMTT(0x18000000,0x1ff00000,0x18000000,RW_NCNB); //bank3
//MMU_SetMTT(0x20000000,0x27f00000,0x20000000,RW_CB); //bank4
MMU_SetMTT(0x20000000,0x27f00000,0x20000000,RW_CNB); //bank4 for STRATA Flash
///Strata Flash是Intel的NOR型闪存
MMU_SetMTT(0x28000000,0x2ff00000,0x28000000,RW_NCNB); //bank5
//30f00000->30100000, 31000000->30200000
//下面3条代码是对s3c2440虚拟地址映射到物理地址(内存)的操作,2440的SDRAM是bank6
MMU_SetMTT(0x30000000,0x30100000,0x30000000,RW_CB); //bank6-1 1M
MMU_SetMTT(0x30200000,0x33e00000,0x30200000,RW_NCNB); //bank6-2 60M
MMU_SetMTT(0x33f00000,0x33f00000,0x33f00000,RW_CB); //bank6-3
MMU_SetMTT(0x38000000,0x3ff00000,0x38000000,RW_NCNB); //bank7 127M
MMU_SetMTT(0x40000000,0x47f00000,0x40000000,RW_NCNB); //SFR 127M
MMU_SetMTT(0x48000000,0x5af00000,0x48000000,RW_NCNB); //SFR 303M
MMU_SetMTT(0x5b000000,0x5b000000,0x5b000000,RW_NCNB); //SFR
MMU_SetMTT(0x5b100000,0xfff00000,0x5b100000,RW_FAULT); //not used 如果应用层访问到该区域MMU会报错
MMU_SetTTBase(_MMUTT_STARTADDRESS); //写转换表基地址到C2
MMU_SetDomain(0x55555550|DOMAIN1_ATTR|DOMAIN0_ATTR); //写域访问控制位到C3
//上句最后C3中内容为0101 0101 0101 0101 0101 0101 0101 0001
//DOMAIN1: no_access, DOMAIN0,2~15=client(AP is checked)
MMU_SetProcessId(0x0); //关闭FCSE(快速上下文切换)
MMU_EnableAlignFault(); //开启对齐检测
MMU_EnableMMU(); //使能MMU
MMU_EnableICache(); //使能ICache
MMU_EnableDCache(); //当MMU打开后,DCache必须要打开
}
// attr=RW_CB,RW_CNB,RW_NCNB,RW_FAULT
void ChangeRomCacheStatus(int attr)
{
int i,j;
MMU_DisableDCache(); //禁止数据高速缓存
MMU_DisableICache(); //禁止指令高速缓存
//要使用回写操作,一定要对DCache进行清除
for(i=0;i<64;i++)
for(j=0;j<8;j++)
MMU_CleanInvalidateDCacheIndex((i<<26)|(j<<5)); //使整个DCache的数据无效
MMU_InvalidateICache(); //使整个指令Cache无效
MMU_DisableMMU(); //禁止MMU
MMU_InvalidateTLB(); //使快表无效
MMU_SetMTT(0x00000000,0x07f00000,0x00000000,attr); //bank0
MMU_SetMTT(0x08000000,0x0ff00000,0x08000000,attr); //bank1
MMU_EnableMMU(); //使能MMU
MMU_EnableICache(); //使能ICahe
MMU_EnableDCache(); //当MMU打开后,DCache必须要打开
}
//设置页表函数
//vaddrStart:虚拟起始地址
//vaddrEnd:虚拟结束地址
//paddrStart:物理起始地址
//attr:访问属性
//虚拟存储空间到物理存储空间的映射是以内存块为单位的:分为1MB/64KB/4KB/1KB
//虚拟存储空间中的一块连续的存储空间被映射成物理存储空间中同样大小的一块连续
//存储空间页表中,每一个地址变换条目实际上就记录了一个虚拟存储空间的存储块的基
//地址与物理存储空间相应的一个存储块的基地址的对应关系
void MMU_SetMTT(int vaddrStart,int vaddrEnd,int paddrStart,int attr)
{
volatile U32 *pTT; //定义了页表的指针
volatile int i,nSec;
pTT=(U32 *)_MMUTT_STARTADDRESS+(vaddrStart>>20); //由于内存块是1M(20bit),写页表的基地址
nSec=(vaddrEnd>>20)-(vaddrStart>>20); // nSec:段大小
for(i=0;i<=nSec;i++)*pTT++=attr |(((paddrStart>>20)+i)<<20);
//页表存储访问信息和存储块的基地址
//(((paddrStart>>20)+i)<<20) :对应的物理内存页的地址
// attr:访问权限和缓冲属性
}
参考网址:
http://bbs.21ic.com/icview-127516-1-1.html
http://blog.csdn.net/woshixingaaa/article/details/6255870
http://blog.sina.com.cn/s/blog_651c92d3010107qr.html
http://6xudonghai.blog.163.com/blog/static/336406292008724103317304/
上一篇:mini2440LED驱动程序开发
下一篇:s3c2440 内存管理单元MMU学习笔记
推荐阅读最新更新时间:2024-11-11 10:26
设计资源 培训 开发板 精华推荐
- 发原创书评 赢MSP430开发板
- 【泰克注册观看有礼】 PCI-SIG 前主席解析:PCI Express5.0测试方案和测量挑战
- 免费领取|射频年度大会EDI CON VIP全场通票(注册到场100%中奖!)
- 【免费申请】英飞凌PSoC 62S4 先锋套件 (CY8CKIT-062S4)
- 收藏英飞凌天猫店 或 下单都有礼、打折满减同享!
- VISHAY新能源主题月,幸运闯关赢大奖!
- WEBENCH轻松注册,尽享精彩好礼!
- 有奖直播预报名|与英飞凌一同探寻网络摄像机的黑科技
- 有奖直播|贝能国际推出基于英飞凌技术的毫米波雷达模组,完美解决PIR市场痛点
- 报名直播赢【保温杯】等好礼|TI MSPM0 MCU 在汽车系统中的应用