分类: 嵌入式

http://blog.chinaunix.net/uid-26435987-id-3082166.html(转)

/************************************************ 
  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:访问权限和缓冲属性
}
 

mini2440裸机之MMU(二)(mmu.c) (转)的更多相关文章

  1. 十三、S3C2440 裸机 — 初始化代码及MMU

    13.1 NOR FLASH 搬运 把程序从 nor flash 上搬运到 SDRAM 中 程序存储在 nor flash 上,运行时将程序搬运到 SDRAM 中运行 nor flash 启动:nor ...

  2. mini2440裸机试炼之—RTC闹钟中断,节拍中断

    版权声明:博客地址:http://blog.csdn.net/muyang_ren.源代码能够在我的github上找看看 https://blog.csdn.net/muyang_ren/articl ...

  3. mini2440裸机试炼之——DMA直接存取 实现Uart(串口)通信

    这个仅仅能作为自己初步了解MDA的开门篇 实现功能: 将字符串数据通过DMA0通道传递给UTXH0,然后在终端 显示.传输数据完后.DMA0产生中断,beep声, LED亮. DMA基本知识 计算机系 ...

  4. mini2440裸机音乐播放器(非常久曾经的笔记)

    [这是好久曾经写的.有点乱,没时间整理.当做记录用的.] 图片粘贴失效.没上传图,想要的直接下载文档吧. 项目目的:通过IIS,触摸屏,LCD模块实现音乐播放器功能(button上一首.下一首.播放. ...

  5. mini2440裸机试炼之——Uart与pc端实现文件、字符传输

    1.  波特率(Baud rate)即调制速率,1波特即指每秒传输1个符号. 2.  非FIFO模式,即数据传输不利用FIFO缓存,一个字节一个字节地传输. 3.  位能够用来推断发送缓存器中是否为空 ...

  6. s3c2440裸机-时钟编程(二、配置时钟寄存器)

    s3c2440裸机编程-时钟编程(二.配置时钟寄存器) 1.2440时钟时序 下图是2440时钟配置时序: 1.上电后,nRESET复位信号拉低,此时cpu还无法取指令工作. 2.nRESET复位信号 ...

  7. mini2440移植uboot-2008.10 (二) DM9000网卡驱动移植

    还是利用 mini2440移植uboot-2008.10 (一)  修改好的代码 通过观察可以发现,mini2400使用的网卡芯片是DM9000,在uboot-2008.10源码中已经支持该芯片的驱动 ...

  8. 八、mini2440裸机程序之UART(1)简单介绍【转】

    转自:http://blog.csdn.net/shengnan_wu/article/details/8298869 一.概述          S3C2440通用异步接收和发送(UART)提供了三 ...

  9. mini2440裸机试炼之——看门狗中断和复位操作

    看门狗的工作原理: 设本系统程序完整执行一周期的时间是Tp,看门狗的定时周期为Ti,Ti>Tp,在程序正常执行时,定时器就不会溢出,若因为干扰等原因使系统不能在Tp时刻改动定时器的记数值,定时器 ...

随机推荐

  1. HQL: Hibernate查询语言

    HQL: Hibernate查询语言 Hibernate配备了一种非常强大的查询语言,这种语言看上去很像SQL.但是不要被语法结构 上的相似所迷惑,HQL是非常有意识的被设计为完全面向对象的查询,它可 ...

  2. 转 UITabBarController简单介绍

    文顶顶 iOS开发UI篇—UITabBarController简单介绍 iOS开发UI篇—UITabBarController简单介绍 一.简单介绍 UITabBarController和UINavi ...

  3. DZ!NT论坛 3.6.711删除用户各种错解决方案

    DZ!NT论坛 3.6.711删除用户各种错解决方案   首先删除一个用户~ado.net报错 对象名  'dnt_spaceposts' 无效. 对象名 'dnt_spaceconfigs' 无效. ...

  4. 死锁及oracle死锁--转载

    今天看群里在讨论数据库死锁的问题,也一起研究了下,查了些资料在这里总结下. 所谓死锁: 是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去. ...

  5. 【CImg】三角形绘制算法实现

    这周的CV基础练习是简单的图形绘制:比如说矩形.三角形和圆心什么的.会发现其实矩形和圆形的实现思路都很直白,矩形只需要确认两个对角坐标就可以了,圆心只需要确认圆心和半径,接着就是简单的遍历各个像素点判 ...

  6. Testing and Checking Refined

    还是James大叔的文章:http://www.satisfice.com/blog/archives/856 本文提出了Testing和checking的定义和他们之间的区别. ========== ...

  7. 利用Oracle VM VirtualBox部署自己的owncloud存储服务器

    最近在弄文档方面的工作,所以想找个能够自动备份且带历史版本的网盘,找了很久没找到,所以决定自己部署一个私人服务器. 找了很久.试了很久终于确定owncloud能够满足自己的要求,而且还是开源免费的. ...

  8. PMP--项目经理解决冲突的模式

    如果你对项目管理.系统架构有兴趣,请加微信订阅号"softjg",加入这个PM.架构师的大家庭 在实际工作过程中,作为一个项目经理,在解决冲突的时候可以通过多种模式解决,项目经理在 ...

  9. 终于解决了PHP调用SOAP过程中的种种问题。(转)

    最近在做公司和第三方的一个合作项目,需要调用统一验证接口和统一支付接口.由于牵涉公司机密,所以我要单独写一层PHP的接口给第三方用.前面那个验证接口主要卡在了des加密的方式上,这个有时间再说.这篇主 ...

  10. [前端 2]常用的JQuery和Dom页面取值与赋值

    导读:书到用时方恨少,需要基础知识的时候,才悔恨自己没有总结学习好.前段时间调了好长时间的页面,突然发现自己之前不怎么在意的取值和赋值,真的是自己一个很薄弱的地方,有时候查半天都找不到一个对的,现在用 ...