S3C2440无MMU_Init不能进中断的原因

发布者:caoxians4589最新更新时间:2015-08-25 来源: eefocus关键字:S3C2440  MMU_Init  中断 手机看文章 扫描二维码
随时随地手机看文章
纠结了一个下午,总算有些头绪了,所谓MMU(虚拟内存管理单元),无非就是把物理地址转换为虚拟地址。所谓物理地址,用的STM32的都知道,它的RAM是从0x20000000开始的,ROM是从0x8000000开始的,这就是物理地址,也就是说在0x20000000这个地址里面放的就是一个值(当然你放的是几,里面存放的就是几),你给RAM一个地址0x20000000并给了读信号,数据线上就会出现你放进去的值,这就是实实在在的物理地址。而虚拟地址,就和它的位段有些相似,你访问的地址,并不是真正的物理介质里面的地址。你访问一个地址,比如0x20,可能会被MMU映射到0x80里面去了,在开启MMU之后,你写了一条指令,往0x20这个地址里面写了一个数,比如8,然后MMU就会向存储器发出命令,向0x80这个物理地址写入数据8。当然,这些你都不知道,这是MMU私下干的。当你要求读这个值的时候,写了从0x20读指令,然后MMU就会从物理地址0x80把这个数(8)读出来,并送给你,然后你并不知道他私下已经干了那么多事,你表面看来就是往0x20这个地址写了一个数8,然后读出来也是8,这就对了。
 
  而在2440要进中断的时候,它会去地址0x0找中断向量表,然后找到是哪个中断发生了,该跳到哪个函数里面去。如果你是在SDRAM或者NAND FLASH里面调试的话,如果没开MMU,那么0x0就指的物理地址,这个地址在2440内部的4K RAM里面,而这4K的RAM里面其实并没有放中断向量表,而是放的bootloader,bootloader把实际的程序都搬到外部的SDRAM去了,物理地址是0x30000000。所以当中断发生时,PC指到了0x0处,这里却没有中断向量表,当然没法执行。如果开启了MMU的话,MMU会把地址0x0(这时就是指虚拟地址)映射到物理地址0x30000000去,也就是发生中断时,PC看似跳到了地址0x0处,但因为MMU的存在,其实是跳到了物理地址的0x30000000处,中断向量表正在此处,所以,中断函数就顺理成章的执行了。
 
关键字:S3C2440  MMU_Init  中断 引用地址:S3C2440无MMU_Init不能进中断的原因

上一篇:一起学mini2440裸机开发(十)--mini2440外部中断实验
下一篇:嵌入式linux与ARM开发板的入门建议

推荐阅读最新更新时间:2024-03-16 14:30

S3C2440之ADC分析
一、硬件原理分析 我们从结构图和数据手册可以知道,该ADC模块总共有8个通道可以进行模拟信号的输入,分别是AIN0、AIN1、AIN2、AIN3、YM、YP、XM、XP。那么ADC是怎么实现模拟信号到数字信号的转换呢?首先模拟信号从任一通道输入,然后设定寄存器中预分频器的值来确定AD转换器频率,最后ADC将模拟信号转换为数字信号保存到ADC数据寄存器0中(ADCDAT0),然后ADCDAT0中的数据可以通过中断或查询的方式来访问。对于ADC的各寄存器的操作和注意事项请参阅数据手册。 开发板通过一个10K的电位器(可变电阻)来产生电压模拟信号,然后通过第一个通道(即:AIN0)将模拟信号输入ADC。左图中的Aref表示AD的参
[单片机]
对Nor Flash的操作(S3C2440)
Nor Flash介绍 Nor Flash的连接线有地址线,数据线,片选信号读写信号等,Nor Flash的接口属于内存类接口,Nor Flash可以向内存一样读,但是不能像内存一样写,需要做一些特殊的操作才能进行写操作,读只需像内存一样读很简单。 nor 的原理图 FLASH简介 常用的Flash类型有Nor Flash和NAND Flash两种。 Nor Flash由Intel公司在1988年发明,以替代当时在市场上占据主要地位的EPROM和E2PROM。NAND Flash由Toshiba公司在1989年发明。两者的主要差别如下表: Nor Flash支持XIP,即代码可以直接在Nor Flash上执行,无需复制
[单片机]
对Nor Flash的操作(<font color='red'>S3C2440</font>)
S3C2440 开发板实战(5):定时器中断
一、定时器大体结构 查看芯片手册,可以找到以下定时器结构框图 从做到右看,对该图进行分析:(不考虑) Prescaler:定时器0和1共享一个8位分频器,而定时器2、3、4共享另一个8位分频器。分频器将输入的PCLK分频为:PCLK/(prescaler+1)。 Clock divider & MUX:每个定时器有一个时钟分频器,它产生5个不同的分频信号(1/2,1/4,1/8,1/16,和TCLK)。每个定时器块从时钟分频器接收自己的时钟信号,时钟分频器从相应的8位分频器接收时钟。8位分频器是可编程的,根据加载值对PCLK进行划分,存储在TCFG0和TCFG1寄存器中。此时定时器的时钟频率为:Timer input
[单片机]
<font color='red'>S3C2440</font> 开发板实战(5):定时器<font color='red'>中断</font>
嵌入式实时系统中断管理技术研究
摘要:嵌入式实时系统中断管理技术直接影响到系统的实时响应性能。本文通过对嵌入式内核中断管理技术的研究,归结出“中断前-后段处理”模型;同时,针对一些处理器中多个外部中断共用一个向量的问题,提出一种单向量多中断处理映射技术,并在PowerPC MPC860处理器上实现Delta OS内核时,验证此技术的有效性。 关键词:实时性 中断 中断管理模式 嵌入式实时系统 引 言 嵌入式实时系统(Real-Time System)是一个能够在指定或者确定的时间内对外部事件作出响应的系统,其重要的特性是实时响应性。   嵌入式实时系统对外部事件的响应一般都是通过中断来处理的,其对中断的处理方式,直接影响到系统的实时性能。 1 嵌
[嵌入式]
第1课:S3C2440的烧写
首先明确要学什么? 1写Bootloader。会以u-boot为例。 2改内核。用ARM编译器对linux内核进行编译。并移植驱动 3制作文件系统,把shell放入开发板(串口shell),把应用程序植入。 那么先来介绍开发板的硬件: 现在手上拿到的是山寨的2440开发板,分上层核心板和下层母板。 有1个arm的cpu(片上系统,里面还包括外设,不只一个cpu),2个32m的内存,一个flash,和一个晶振提供的时钟。 母板则为4.3寸触摸屏和LCD屏(2个屏要分开驱动),USB的3个host端和1个device端。RJ45网络端口。Rs232串口(15电压)。 JTAG仿真接口。SD卡槽。3个指示灯。音频输入输出
[单片机]
USART发送与接收无意识中断嵌套
01 void USART1_IRQHandler(void) 02 { 03 static u8 i; 04 const u8 BufferSize = 20; 05 static u8 Counter = 0, index = 0; 06 static u8 RxBuffer ; 07 static u8 TxBuffer ; 08 09 if (USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) //接收中断 10 { 11 RxBuffer = USART_ReceiveData(USART1); 12 Counter++;//不会出错 13
[单片机]
STM32的串口空闲中断及接受数据
STM32的串口空闲中断及接受数据——STM32简介 STM32系列基于专为要求高性能、低成本、低功耗的嵌入式应用专门设计的ARM Cortex-M3内核 STM32的串口空闲中断及接受数据——关于什么是空闲中断: 检测到接收数据后,在数据总线上的一个字节时间内,没有接收到数据触发空闲中断。RXNE置位一次,空闲总线就检测一次。 关于STM32串口空闲中断的问题 1.空闲中断是接受数据后出现一个byte的高电平(空闲)状态,就会触发空闲中断。并不是空闲就会一直中断,准确的说应该是上升沿(停止位)后一个byte,如果一直是低电平是不会触发空闲中断的(会触发break中断)。 2.关于第二点有要铺垫的三个情况,datash
[单片机]
定时中断30秒倒计时闹铃程序
定时中断30秒倒计时闹铃程序 #include reg52.h char shuju ={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//0--9 char a=3,b=0,i=0; char flag; sbit f=P3^7; /********* 延时子程序 *********/ void delay(unsigned int x) { while(x--); } void  FM qdelay(unsigned int t) {  unsigned int i,j;   for(i=0;i t*5;i++)    for(j=0;j 255;j++); } /*
[单片机]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved