项目场景:
项目中的一个芯片的待机控制引脚使用PB3作为高低电平控制端口。
问题描述
PB3进行正常的GPIO配置为推挽输出后,实际无输出。
原因分析:
经过多次测试之后,PB3还是无输出,还以为是单片机硬件问题,考虑更换芯片之前,重新翻阅了一下STM32数据手册,发现PB3复位后主功能为JTDO,用作PB3时须重定义功能;
除了PB3,PB4/PA15都为JTAG接口,如不使用JTAG而用作他用,均需重定义。
解决方案:
GPIO配置前打开端口重定义时钟,再重定义端口(禁用JTAG),代码如下:
__HAL_RCC_AFIO_CLK_ENABLE();
__HAL_AFIO_REMAP_SWJ_NOJTAG();
__HAL_RCC_AFIO_CLK_ENABLE(); //端口重定义功能时钟
__HAL_AFIO_REMAP_SWJ_NOJTAG(); //PB3用到了默认为JTAG-JTDO,用作PB3时须重定义,我通常使用ST-Link调试,因此SWJ需保留,只禁用JTAG即可。
端口重定义后问题解决。