微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > S3C2440无MMU_Init不能进中断的原因

S3C2440无MMU_Init不能进中断的原因

时间:11-28 来源:互联网 点击:
纠结了一个下午,总算有些头绪了,所谓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处,中断向量表正在此处,所以,中断函数就顺理成章的执行了。

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top