有误或者表述不清楚请指出,谢谢
硬件: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。
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
具体设置如图: