news 2026/3/17 23:56:19

华大HC32F460配置JTAG调试引脚为普通GPIO(PB03、PA15等)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
华大HC32F460配置JTAG调试引脚为普通GPIO(PB03、PA15等)

背景

由于项目需要,使用的SWD调试对芯片进行下载与调试,未使用JTAG相关功能,同时GPIO引脚不够用,于是需要将PB03(JTDO/SWO)和PA15(JTDI)设置为普通的GPIO来使用;

问题

由于PB03(JTDO/SWO)和PA15(JTDI)默认用于JTAG功能,其无法直接像普通的IO口那样直接配置引脚复用,需要先关闭引脚对应的debug功能。
直接像普通GPIO引脚一样配置是无效的。

处理方法

使用GPIO_SetDebugPort函数进行配置。
该函数位于hc32_II_gpio.c文件中,函数定义如下:

/** * @brief GPIO debug port configure. Set debug pins to GPIO * @param [in] u8DebugPort: @ref GPIO_DebugPin_Sel for each product * @param [in] enNewState: An @ref en_functional_state_t enumeration value. * @arg ENABLE: set to debug port (SWD/JTAG) * @arg DISABLE: set to GPIO * @retval None */voidGPIO_SetDebugPort(uint8_tu8DebugPort,en_functional_state_tenNewState){/* Parameter validity checking */DDL_ASSERT(IS_GPIO_DEBUG_PORT(u8DebugPort));DDL_ASSERT(IS_FUNCTIONAL_STATE(enNewState));DDL_ASSERT(IS_GPIO_UNLOCK());if(ENABLE==enNewState){SET_REG16_BIT(CM_GPIO->PSPCR,((uint16_t)u8DebugPort&GPIO_PSPCR_SPFE));}else{CLR_REG16_BIT(CM_GPIO->PSPCR,((uint16_t)u8DebugPort&GPIO_PSPCR_SPFE));}}

其中输入参数定义为:

/** * @defgroup GPIO_DebugPin_Sel GPIO Debug Pin Selection * @{ */#defineGPIO_PIN_TCK(0x01U)#defineGPIO_PIN_TMS(0x02U)#defineGPIO_PIN_TDO(0x04U)#defineGPIO_PIN_TDI(0x08U)#defineGPIO_PIN_TRST(0x10U)#defineGPIO_PIN_DEBUG_JTAG(0x1FU)#defineGPIO_PIN_SWCLK(0x01U)#defineGPIO_PIN_SWDIO(0x02U)#defineGPIO_PIN_SWO(0x04U)#defineGPIO_PIN_DEBUG_SWD(0x07U)#defineGPIO_PIN_DEBUG(0x1FU)/** * @brief Functional state */typedefenum{DISABLE=0U,ENABLE=1U,}en_functional_state_t;

针对于我的关闭PA15和PB03的需求,进行如下配置即可:

// 关闭 PA15 (JTDI) 的调试功能,释放为普通 GPIOGPIO_SetDebugPort(GPIO_PIN_TDI,DISABLE);// 关闭 PB03 (JTDO/TRACESWO) 的调试功能,释放为普通 GPIOGPIO_SetDebugPort(GPIO_PIN_TDO,DISABLE);

而后即可按照普通的GPIO进行配置。

额外需要注意的

观察GPIO_DebugPin_Sel 的定义可以发现,JTAG和SWD的部分引脚底层是相同的,例如:

#define GPIO_PIN_TCK (0x01U)
#define GPIO_PIN_SWCLK (0x01U)
#define GPIO_PIN_TMS (0x02U)
#define GPIO_PIN_SWDIO (0x02U)

这意味着部分JTAG功能引脚被关闭会导致SWD引脚也无法工作。
例如关闭JTAG所有功能GPIO_PIN_DEBUG_JTAG,或TCK和SWCLK,均会导致SWD调试下载使用的GPIO_PIN_SWCLK、GPIO_PIN_SWDIO无法工作。
进而导致你没有一个口可用于调试和下载了。
此时,只能通过在线烧录器或离线烧录器,按下图所示,将芯片切换到串口烧写模式,从而擦除错误的代码,抢救芯片。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/14 7:45:41

文献学开卷考试复习指南与应试策略

① WisPaper(文献聚类 术语辅助) 官网:https://www.wispaper.ai 帮助快速理解陌生领域的核心概念和研究主题。 ② Elicit 自动列出最相关论文和方法,为跨学科快速扫文献提供便利。 ③ Explainpaper 逐段解释论文内容&#xff0c…

作者头像 李华
网站建设 2026/3/16 11:07:01

文献学期末论文写作指南:理论、方法与实践应用研究

① WisPaper(文献聚类 术语辅助) 官网:https://www.wispaper.ai 帮助快速理解陌生领域的核心概念和研究主题。 ② Elicit 自动列出最相关论文和方法,为跨学科快速扫文献提供便利。 ③ Explainpaper 逐段解释论文内容&#xff0c…

作者头像 李华
网站建设 2026/3/13 1:16:01

paperzz AI 藏着的论文写作 “隐形 buff”:从选题卡壳到成稿丝滑,3000 字扒透智能工具的 “轻辅助” 逻辑

Paperzz-AI官网免费论文查重复率AIGC检测/开题报告/文献综述/论文初稿 paperzz - 毕业论文-AIGC论文检测-AI智能降重-ai智能写作https://www.paperzz.cc/dissertation 每到毕业季,“论文进度 0%” 的焦虑能精准击中多数学生:选题怕撞款、文献翻到眼酸、…

作者头像 李华
网站建设 2026/3/15 1:19:33

从选题到成稿:paperzz AI 如何让毕业论文写作跳出 “重复循环”?3000 字拆解智能工具的「隐形辅助」逻辑

Paperzz-AI官网免费论文查重复率AIGC检测/开题报告/文献综述/论文初稿 paperzz - 毕业论文-AIGC论文检测-AI智能降重-ai智能写作https://www.paperzz.cc/dissertation 毕业论文写作,大概是每个学生绕不开的 “痛点集合体”:选题怕撞车、文献找不全、框…

作者头像 李华
网站建设 2026/3/14 11:37:07

Pytorch安装多版本共存环境下切换运行Qwen3-VL-8B

PyTorch多版本共存环境下切换运行Qwen3-VL-8B 在当前AI系统日益复杂的背景下,一个典型的问题摆在了工程师面前:如何让多个依赖不同框架版本的模型,在同一台GPU服务器上稳定共存?尤其是在部署像Qwen3-VL-8B这样的多模态大模型时&a…

作者头像 李华
网站建设 2026/3/15 10:38:51

无代码:打破技术桎梏,重构企业数字化落地新范式

数字化转型已成为企业生存发展的必答题,但传统开发模式的高门槛、长周期、高成本,让许多企业尤其是中小企业陷入“想转不会转、想做没钱做”的困境。无代码解决方案以“可视化配置拖拽式操作”为核心,将复杂的代码逻辑转化为直观的图形化界面…

作者头像 李华