很多人学习2440都是从裸机开始的。刚开始的小菜LED,然后定时器、按键这些常用内部外设,最后则是LCD、Nand等复杂外设。
用Jlink裸机调试2440小程序时,中断的调试是一个重要内容。像定时器、按键等外设调试都需要用到中断。
今天在调试以前写的定时器测试工程时活见鬼的总是不成功。因为是以前调试ok的工程,所以可以肯定代码没有错的,应该是调试方面的错误。于是乎:
(1)换了下MDK的版本,从4.1.2降到之前的3.5,一样不行。
(2)调试时单步执行,在Memory栏内输入SRCPND和INTPND寄存器的地址,单步时通过观察这两个寄存器的值,确定中断是否真的发生。结果中断确实发生,证明程序真的是无误的,那一定就是中断发生了而没有被正确响应。
(3)怀疑是Jlink的问题,于是将链接地址设置到0x0开始,编译得到bin后,使用Jlink Commander的loadbin setpc等命令加载到0x0地址(即内部SRAM)运行。ok,结果中断被响应了。彻底证明了程序是正确的,而是中断发生后没有被正确响应。
(4)将链接地址修改为0x0的工程再次用JLink单路调试。OK的,中断也可以被响应。到这里问题就已经明了了。之前我用Jlink调试程序时都是直接加载到0x30000000开始的地址的(SDRAM中),这样在不适用中断的例程中没有问题,而在使用了中断时,因为0x0地址开始的硬件中断向量表是空的,因此发生中断时程序便会跑飞。
结论:
一级中断向量表在0x0位置开始,因此不管代码加载到哪里执行,这个向量表都得链接到0x0地址才行。但是0x0地址开始只有4k字节大小,如果工程太大放不下呢?这就需要合理设置ROM,或者是编排一个scatter文件,时加载时boot部分加载到0x开始的4k范围内,而其他部分再加载到SDRAM内,就可以正确响应中断了。
上一篇:S3C2440 cp15协处理器详解
下一篇:S3C2440 外部按键中断解析
推荐阅读最新更新时间:2023-11-30 20:29






推荐帖子
- 编译vdw_wdm.lib是出现以下问题
- 我在编译vdw_wdm.lib时出现以下问题,还请多多指教我在生成lib库的时候,kndiswdm.lib和vdw.lib都没有问题但在生成vdw_wdm.lib时--------------------Configuration:VdwLibs-Win32WDMChecked--------------------CompilingwithDDKcompiler...khidaux.cppC:\\ProgramFiles\\Compuware\\DriverSt
-
小粉果
嵌入式系统
- 关于PCB地的问题
- 各位前辈好,我是刚学PCB一直有个问题搞不明白,就是PCB板上所有的地是怎么相互连起来的,如果只是用线的话那地线岂不是得很长,因为需要接地的引脚太多,我看见有的人在(比如一个贴片电容的接地端)放置了一些不知道是通孔焊盘还是过孔(这个也不明白)作为接地,那么这些过孔或者焊盘又是怎么和其他地是相连的,是通过铺铜吗?如果用了这些通孔焊盘或是过孔为什么在制成的板子上面看不见关于PCB地的问题
-
lym1210
PCB设计
- 隔离变压器的作用到底是什么?我有点看不懂啊
- 隔离变压器的作用到底是什么?有点看不懂。。。隔离变压器的作用到底是什么?我有点看不懂啊
-
secondlife110
模拟电子
- 实用晶闸管电路大全
- 很实用的一本书实用晶闸管电路大全
-
sh-caideqing
模拟电子
- 【空气净化器评测】-松下F-30C3PD完全拆解+使用感受
- 响应论坛号召,趁着周日有空把用了两年多的空气净化器拆开看看。今天的主角,两年前公司发的周年庆礼品。当时售价大概699,一款松下低档空气净化器。自带简单的PM2.5传感器,空气污染重时指示灯红色,好时显示蓝色。缺点是不能定量测量PM2.5值。所以有了先前的一篇DIYPM2.5空气质量检测仪的帖子http://bbs.eeworld.com.cn/thread-492618-1-1.html。背面照身份证标识拿下正面的挡板,滤尘网已经有些灰了,大概两个月没有清理了,家里
-
mcu200689
DIY/开源硬件专区
- STM32F429IGT6移植micropython如何挂载NAND FLASH
- 如题,用的是正点原子的开发板,现在已经可以运行,但是文件系统只能识别到flash翻了原理图,发现有一个512MB的NANDFLASH可以用,如图不知道如何挂载,不知道是不是在mpconfigboard.h文件里,新人发帖,求助各位大大STM32F429IGT6移植micropython如何挂载NANDFLASH
-
yyyzyyyz
MicroPython开源版块