处女座,为了板子走线美观,拉线方便,在项目量产前,还更改了原来外设的IO口,埋头苦干一天,移植ok,发现PB3一直不听使唤,好,加班检查代码,检查初始化,时钟,IO对应,然后试PCB板,是否短路,断路等等等,试遍了,纹丝不动,拉不高也拉不低。。。这是为什么呢,百度一下,才发现,PB3是JTAG口之一,需要把IO重映射为普通IO口使用,于是看着大大神们的帖子,回答,代码中,加入了以下两句话:

RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE); //开启AFIO时钟

GPIO_PinRemapConfig(GPIO_Remap_SWJ_Disable, ENABLE);// 改变指定管脚的映射 GPIO_Remap_SWJ_Disable SWJ 完全禁用(JTAG+SW-DP)

没多看,就加入了初始化的行列,下载了进去,好使,好使,PB3听话了,可是呢,当我再次调试完代码准备下载进去板子的时候,发现,不能下载了!

回头仔细一看,是完全禁用JTAG+SWD啊,我可是SWD口进行调试下载的啊!!!这可怎么办。。。

于是又去互联网搜索一番,乱七八糟一大堆,我比较懒,不喜欢折腾那么复杂,找到一个简单粗暴的好办法,分享给大家:

短路复位电容,点下载,稍等几秒(这个靠感觉喽),断开短路的电容,OK!大功告成!

这是因为复位的时候,禁止JTAG的寄存器也是复位状态,所以JTAG就自动启动,未被禁止。

最红附上我最后使用的实际代码:

RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE); //开启AFIO时钟

GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable , ENABLE);// 改变指定管脚的映射 GPIO_Remap_SWJ_JTAGDisable ,JTAG-DP 禁用 + SW-DP 使能

以上内容均来源于互联网,还给互联网,只为大家某天碰到这个坑,可以早日出坑~

05-11 15:51