如何防止PSD8XX芯片的JTAG接口死锁——如何使用PSD的C口作为复用方式
|
PSD8XX的C口可以配置为复用方式,在非编程状态下用做一般I/O口,在编程时定义为JTAG接口。那么,PSD如何知道是处于JTAG编程方式还是一般I/O方式,一种实现方法是使用一个引脚来区别,如使用PB0来实现,在Abel文件中要加入如下描述: 方法一 pb0 pin; jtagsel node 102; EQUATIONS jtagsel = pb0; 这样,在PB0接‘0’(地)时,JTAG使能被打开,可能通过JTAG对PSD进行编程;在PB0接‘1’(+5V)时,JTAG使能被禁止,C口用于一般I/O方式。 这种方式实现C口的复用简单可靠,缺点是还是占用了一个引脚。 方法二 使用PSD内部JTAG控制使用的第二项��Jtag-FF,在MCU运行中更改此控制寄存器(CSOIP+C7)中JTAG-EN位(位0)。在使用JTAG编程时先将JTAG-EN写为‘1’,在编程结束后再写为‘0’,程序就可以正常运行。实现方法是在PSD配置时将JTAG口设为复用,并且内部节点jtagsel(node 102)也设为‘1’,这样JTAG的使能就完全由JTAG控制寄存器来控制。在编写的程序开头中加入否编程的判断,如使用单片机(以8031为例)的P10口,程序编写如下: MOV C, P1.0 JC NORMAL MOV DPTR, #(CSIOP_ADDRESS+0C7H) MOV A, #01H MOVX @DPTR, A ; 置位JTAG-EN,使能C口的JTAG功能 JMP $ ; 循环,等待编程 NORMAL: MOV DPTR, #(CSIOP_ADDRESS+0C7H) MOV A, #00H MOVX @DPTR, A ; 复位JTAG-EN,禁止C口JTAG功能,工作于一般I/O方式 ; 程序正常运行 如果上电时P10口为低,则使能JTAG接口;反之则禁止JTAG接口进行正常的程序运行。 这种实现C口复用的方式占用零硬件资源,但要求用户有较高的编程经验并且程序一定要运行可靠。 |
回复
| 有奖活动 | |
|---|---|
| 这个春节你犒赏自己什么了?分享你的故事,有奖征集 | |
| 2026年“我要开发板活动”第三季,开始了! | |
| 硬核工程师专属补给计划——填盲盒 | |
| “我踩过的那些坑”主题活动——第002期 | |
| 【EEPW电子工程师创研计划】技术变现通道已开启~ | |
| 发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
| 【EEPW在线】E起听工程师的声音! | |
| 高校联络员开始招募啦!有惊喜!! | |
我要赚赏金打赏帖 |
|
|---|---|
| Gravity:中英文语音合成模块V2.0及其串口控制被打赏¥24元 | |
| 全彩色度变化图的绘制被打赏¥27元 | |
| 【FreeRtos】FreeRtos任务栈的生长方向管理方式被打赏¥20元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】LVGL添加输入设备:EC11旋转编码器被打赏¥39元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】RA8D1部署FreeRTOS+LVGL被打赏¥33元 | |
| 空气质量检测器设计与实现被打赏¥24元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】LWIP进行UDP、TCP、HTTP、MQTT功能联合测试被打赏¥41元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】RA8D1部署FreeRTOS+LWIP被打赏¥36元 | |
| RTOS怎么选?让我来给你答案!被打赏¥15元 | |
| 【S32K3XX】Flash驱动使用被打赏¥26元 | |
我要赚赏金
