用自制PCB,用KEIL MDK和JLINK裸奔调试F1C100S
填坑开始
第一坑 JLINK连接
第一坑拜晕哥所赐
如下图
如果只连图上4根线,那么调试时会出来如下提示,然后退出调试
连上地和电源到JLINK后,就能正常调试了
离线
第二坑 下载
由于以前一直用的是有内部FLASH的,所以调试的第一步自然是下载
对于F1C100S没有内部FLASH的,下载自然是有问题的,JLINK信息如下
Load "D:\\maojing\\hdy-radio\\1-templete\\mdk\\Objects\\templete.axf"
ProjectFile = D:\maojing\hdy-radio\1-templete\mdk\JLinkArm_debug_in_dram.ini
Info: Device "ARM7" selected (0 KB flash, 0 KB RAM).
Device = TMPA900CMXBG
Info: Device "ARM7" selected (0 KB flash, 0 KB RAM).
VTarget = 3.261V
Info: TotalIRLen = 4, IRPrint = 0x01
***JLink Warning: Identified core does not match configuration. (Found: ARM9, Configured: ARM7)
Info: CP15.0.0: 0x41069265: ARM, Architecure 5TEJ
Info: CP15.0.1: 0x1D152192: ICache: 32kB (4*256*32), DCache: 16kB (4*128*32)
Info: Cache type: Separate, Write-back, Format C (WT supported)
Info: RTCK is not connected
Info: Auto JTAG speed: 8000 kHz
Info: J-Link: ARM9 CP15 Settings changed: 52078 from 78, MMU Off, ICache Off, DCache Off
***JLink Warning: RESET (pin 15) high, but should be low. Please check target hardware.
***JLink Warning: PC of target system has unexpected value of 0xFFFF00D8 after reset.
Info: CP15.0.0: 0x41069265: ARM, Architecure 5TEJ
Info: CP15.0.1: 0x1D152192: ICache: 32kB (4*256*32), DCache: 16kB (4*128*32)
Info: Cache type: Separate, Write-back, Format C (WT supported)
DLL version V4.50l, compiled Jul 9 2012 15:02:49
Firmware: J-Link ARM V8 compiled Nov 28 2014 13:44:46
Hardware: V8.00
Hardware-Breakpoints: 2
Software-Breakpoints: 8192
Watchpoints: 0
Found 1 JTAG device, Total IRLen = 4:
Id of device #0: 0x07926F0F
ARM9 identified.
JTAG speed: 1000 kHz
Info: RTCK is not connected
Info: Auto JTAG speed: 8000 kHz
***JLink Warning: RESET (pin 15) high, but should be low. Please check target hardware.
***JLink Warning: PC of target system has unexpected value of 0xFFFF018C after reset.
Info: CP15.0.0: 0x41069265: ARM, Architecure 5TEJ
Info: CP15.0.1: 0x1D152192: ICache: 32kB (4*256*32), DCache: 16kB (4*128*32)
Info: Cache type: Separate, Write-back, Format C (WT supported)
JTAG speed: 1000 kHz
No Algorithm found for: 00000000H - 00001357H
Erase skipped!
Error: Flash Download failed - ARM926EJ-S
Info: RTCK is not connected
Info: Auto JTAG speed: 8000 kHz
Flash Load finished at 10:13:14
我知道需要下到SRAM或DRAM,但怎么下进去就不知道了
在参考了网友的例程,和网友晕哥和aozima的帮忙下,总算清楚了这个过程,填坑如下
1)在编译通过后,不需要download,直接开始debug就可以
2)如果要在SRAM中运行,那么project options需要设置如下
A)Linker tab中的Scatter file和Misc controls分别设置如下
run_in_sram.sct文件代码如下
LR_IROM1 0x00000000 { ; load region size_region
ER_IROM1 0x00000000 { ; load address = execution address
*.o (F1C100S_INIT, +First)
*(InRoot$$Sections)
.ANY (+RO)
}
RW_RAM1 +0 { ; RW_RAM1 start address is after ER_ROM1
.ANY (+RW +ZI)
}
}
B)Debug tab中的Initialization File中设置如下
run_in_sram.ini代码如下
FUNC void SET_PC_SRAM(void)
{
PC = 0x00000000;
}
SET_PC_SRAM();
C)Utilities tab设置如下
如果要运行在DRAM中,那么设置如下:
A)Linker tab中的Scatter file和Misc controls分别设置如下
run_in_dram.sct文件代码如下
LR_IROM1 0x80000000 { ; load region size_region
ER_IROM1 0x80000000 { ; load address = execution address
*.o (F1C100S_INIT, +First)
*(InRoot$$Sections)
.ANY (+RO)
}
RW_RAM1 +0 { ; RW_RAM1 start address is after ER_ROM1
.ANY (+RW +ZI)
}
}
B)Debug tab中的Initialization File中设置如下
run_in_sram.ini代码如下
FUNC void INIT_CLOCK(void)
{
int val;
//先把CPU时钟源设置为24Mhz晶振
val = _RDWORD(0x01c20050);
val &= ~(3 << 16);
val |= (1 << 16);
_WDWORD(0x01c20050, val);
//设置PLL_PERIPH(N=25,M=1) to 600Mhz
_WDWORD(0x01c20028, 0x80041800);
//设置AHB/APB/HCLKC的工作频率 200MHz/100MHz
_WDWORD(0x01c20054, 0x00003180);
//开启DRAM的front-end和back-end的DCLK门
_WDWORD(0x01c20100, 0x05000000);
//配置PLL_CPU的值408MHz
_WDWORD(0x01c20000, 0x80001000);
//把CPU时钟源设置为PLL_CPU
val = _RDWORD(0x01c20050);
val &= ~(3 << 16);
val |= (2 << 16);
_WDWORD(0x01c20050, val);
}
FUNC void INIT_DRAM(void)
{
int val;
//初始化DRAM
val = _RDWORD(0x01c20824);
val |= (7 << 12);
_WDWORD(0x01c20824, val);
//设置DRAM时钟 156MHz
_WDWORD(0x01c20020, 0x80100c00);
//开启DRAM时钟
val = _RDWORD(0x01c20060);
val |= (1 << 14);
_WDWORD(0x01c20060, val);
//DRAM软件复位失效
val = _RDWORD(0x01c202c0);
val |= (1 << 14);
_WDWORD(0x01c202c0, val);
//设置DRAM参数
_WDWORD(0x01c01000, 0x0001318a); //f1c100s设置
//_WDWORD(0x01c01000, 0x0001338a); //f1c200s设置
val = _RDWORD(0x01c0100c);
val &= ~(7 << 6);
val |= ((4 << 6) | (1 << 0));
_WDWORD(0x01c0100c, val);
}
FUNC void SET_PC_DRAM(void)
{
PC = 0x80000000;
}
INIT_CLOCK();
INIT_DRAM();
SET_PC_DRAM();
现在能正常在SRAM和DRAM中调试了
在此感谢@晕哥和@aozima的帮助
离线
帖子不错,没看到你的板子呀,还有哪些坑?继续观望
离线
帖子质量非常高,非常不错,不过帖子有个小笔误,最后一段ini代码上面的文字应该是run_in_dram.ini代码如下,帖子写成(run_in_sram.ini代码如下)。 最后有个小建议,如果能够把JLINK的信号名称和板子连接的IO口用文字描述出来就更好了。帖子贴出的JLINK和板子的连接图看得不是太清楚,比如没看懂CLK连接的是E6还是E7
离线
厉害,我用IAR,倒腾了一晚上,也没搞定。
离线
jlink可否直接把固件下载到spi flash
离线
问一下,如果焊接这spiflash,而且里面有程序,也可以正常进入ddr中调试吗
离线
jlink的电源是接vref到板子的3.3吗
离线
地线肯定要接的, 不接地址, 就没有 相对电平的.
离线
跟着上面的步骤做,我在keil下的工程中使用的freertos,仿真时一直开在abort handler中,这个怎么解决呢
离线
我之前也是J LINK调试. 但是一中断就无法继续执行. 我来试试你的初始化
离线
请问mdk版本是多少,为啥我的Linker tab和你的不一样,工程可以正常编译了。
离线
按照你的方式,能直接下载到SPI FLASH中吗?按照社区帖子,我试了好多方式,都没有反应!出坑困难啊!
离线