DSP

limp mode下对芯片进行恢复

2019-07-13 11:43发布

有些客户遇到如下问题: 将使用外部晶振的工程烧写到没有外部晶振的板子上,导致芯片能够连接上仿真器,但是没法烧写程序,C2000芯片就再也没法下载使用了。 原理: 如果误将使用外部晶振的程序下载到没有外部晶振的板子上。这时候,芯片会进入limp mode, 在limp mode下,CPU的工作频率为1~5MHz,没法进行flash操作,所以没法进行芯片编程。 解决方法: 在芯片技术指南的《1.4.2.3.2 Switching to INTOSC2 in the Absence of External Clocks 》提到了恢复的办法。 1. 在CCS下面,将CCS连接上芯片; 2. 通过veiw->register, 将 First write → CLKCTL.XTALOSCOFF=1 and CLKCTL.XCLKINOFF=1
Second write → CLKCTL.OSCCLKLSRCSEL=1 and CLKCTL.OSCCLKSRC2SEL=1
也就是对CLKCTL手动进行写入0x6000和0x6003,将时钟切换到内部INTOSC2上面去,随后即可恢复芯片。 SysCtrlRegs.CLKCTL.all = 0x6000; // Set XTALOSCOFF=1 & XCLKINOFF=1
SysCtrlRegs.CLKCTL.all = 0x6003; // Set OSCCLKLSRCSEL=1 & OSCCLKSRC2SEL=1