有误或者表述不清楚请指出,谢谢
硬件:TQ2440开发板、jlink V8 固件
软件:J-LINK ARM 4.08i、MDK4.20
先解释下MDK中三种linker之间的区别
设置集中在option linker选项卡
1.采用Target对话框中的ram和rom地址。采用此方式,需在linker选项卡中的Use Memort Layout from
Target Diaglog选项选中,并且在Target中设置好ram、rom地址。MDK会根据Target对话框中设定的ram
和rom地址自动生成一个分散加载文件。最后链接器会根据此文件中的信息对目标文件进行连接,生成axf文件。
如下图:
至于rom和ram是片内还是片外,容量多大就需要根据芯片和开发板来决定了。
2.直接通过linker选项卡中的R/O Base和R/W Base来设定链接信息。链接器最后可根据此处指定的地址信息进
行连接,连接的文件应该是顺序存放了,最多RO和RW分开。此时需要注意的是应将 Use Memort Layout from
Target Diaglog前的勾去掉,且保证Scatter File中未包含分散加载文件。并且要在Misc control中设定镜像的入口点,如:
--first 2440init.o(Init)
2440init.o对应的是启动代码汇编源文件2440init.s,Init是对应的是段名在异常向量表之前。此处需要根据具体文件修改。
3.最后一种为直接采用分散加载文件。
在设置linker的时候可以注意下linker control string的信息,看看linker的输入信息是否符合自己的要求。
此处应该是只要选择使用scatter file文件,那么其他链接方式的设置自动失效。
可以从linker control string的信息看出来。
对应TQ2440开发板的设置
由于TQ2440开发板采用的是片外的ram和片外的flash,所以我这里直接采用前面说到的第二种方法。
就是通过手动设置ro的地址,其中0x30000000就是片外ram的地址。rw未指定,则说明rw数据顺序
存存放到ro段之后。
MDK Jlink 外部RAM调试设置
设置集中在option 的debug选项卡下
1.先将黑点调到右边,然后在右边的下拉框中选中J-LINK/J-TRACE,然后点击Setting,找到Info中的JLink,点击查看Jlink和MDK能否连接起来,在点击下面的Target查看仿真器能否找到cpu。
load Application at startup貌似去掉和不去掉的效果是一样的,猜测这个选项和前面Target中的rom地址有关,因为rom地址的后面有startup这个选项。我这里未采用Target方式链接,所以将此勾去掉了。
2.然后是ram调试是最重要的init文件。这个文件的作用是在加载axf调试文件前先将ram初始化完毕,需要完成设置总线时钟,设置bank控制寄存器等(sdram直接挂在bank6上)。本来想偷懒,直接将MDK安装文件夹下Clabsys公司的2440开发板的Ext_RAM.ini拷贝出来,结果调试的时候出现了莫名其妙的错误,猜测是初始化的问题。打开看了下,发现能看懂,MDK自带的文件只初始化了bank6。于是动手将TQ2440的init_sdram改造了下,做了个新的Ext_RAM.ini,可以顺利调试。需要注意的是,Init文件需要根据工程做一定修改,具体是在LOAD命令处。附init文件:
- FUNC void SetupForStart (void) {
- // <o> Program Entry Point
- PC = 0x30000000;
- }
- FUNC void Init (void) {
- _WDWORD(0x53000000, 0x00000000);
- _WDWORD(0x4A000008, 0xFFFFFFFF);
- _WDWORD(0x4A00001C, 0x000007FF);
- _WDWORD(0x53000000, 0x00000000);
- _WDWORD(0x56000050, 0x000055AA);
- _WDWORD(0x4C000014, 0x00000007);
- _WDWORD(0x4C000000, 0x00FFFFFF);
- _WDWORD(0x4C000004, 0x00061012);
- _WDWORD(0x4C000008, 0x00040042);
- _WDWORD(0x48000000, 0x22111120);
- _WDWORD(0x48000004, 0x00002F50);
- _WDWORD(0x48000008, 0x00000700);
- _WDWORD(0x4800000C, 0x00000700);
- _WDWORD(0x48000010, 0x00000700);
- _WDWORD(0x48000014, 0x00000700);
- _WDWORD(0x48000018, 0x0007FFFC);
- _WDWORD(0x4800001C, 0x00018005);
- _WDWORD(0x48000020, 0x00018005);
- _WDWORD(0x48000024, 0x008E0459);
- _WDWORD(0x48000028, 0x00000032);
- _WDWORD(0x4800002C, 0x00000030);
- _WDWORD(0x48000030, 0x00000030);
- }
- // Reset chip with watchdog, because nRST line is routed on hardware in a way
- // that it can not be pulled low with ULINK
- _WDWORD(0x40000000, 0xEAFFFFFE); // Load RAM addr 0 with branch to itself
- CPSR = 0x000000D3; // Disable interrupts
- PC = 0x40000000; // Position PC to start of RAM
- _WDWORD(0x53000000, 0x00000021); // Enable Watchdog
- g, 0 // Wait for Watchdog to reset chip
- Init(); // Initialize memory
- LOAD ..\output\codec.axf INCREMENTAL // 此处需修改axf文件的路径各工程设置可能不一样需要在此处修改!
- SetupForStart(); // Setup for Running
- stop, pc // 想要直接到main可设置为 g, main
FUNC void SetupForStart (void) {// <o> Program Entry PointPC = 0x30000000;
}FUNC void Init (void) {_WDWORD(0x53000000, 0x00000000);_WDWORD(0x4A000008, 0xFFFFFFFF);_WDWORD(0x4A00001C, 0x000007FF);_WDWORD(0x53000000, 0x00000000);_WDWORD(0x56000050, 0x000055AA);_WDWORD(0x4C000014, 0x00000007);_WDWORD(0x4C000000, 0x00FFFFFF);_WDWORD(0x4C000004, 0x00061012);_WDWORD(0x4C000008, 0x00040042);_WDWORD(0x48000000, 0x22111120);_WDWORD(0x48000004, 0x00002F50);_WDWORD(0x48000008, 0x00000700);_WDWORD(0x4800000C, 0x00000700);_WDWORD(0x48000010, 0x00000700);_WDWORD(0x48000014, 0x00000700);_WDWORD(0x48000018, 0x0007FFFC);_WDWORD(0x4800001C, 0x00018005);_WDWORD(0x48000020, 0x00018005);_WDWORD(0x48000024, 0x008E0459);_WDWORD(0x48000028, 0x00000032);_WDWORD(0x4800002C, 0x00000030);_WDWORD(0x48000030, 0x00000030);
}// Reset chip with watchdog, because nRST line is routed on hardware in a way
// that it can not be pulled low with ULINK_WDWORD(0x40000000, 0xEAFFFFFE); // Load RAM addr 0 with branch to itself
CPSR = 0x000000D3; // Disable interrupts
PC = 0x40000000; // Position PC to start of RAM
_WDWORD(0x53000000, 0x00000021); // Enable Watchdog
g, 0 // Wait for Watchdog to reset chipInit(); // Initialize memory
LOAD ..\output\codec.axf INCREMENTAL // 此处需修改axf文件的路径各工程设置可能不一样需要在此处修改!
SetupForStart(); // Setup for Running
stop, pc // 想要直接到main可设置为 g, main
具体设置如图:
转载:http://blog.csdn.net/rockrockwu/article/details/7093435