如何防止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口复用的方式占用零硬件资源,但要求用户有较高的编程经验并且程序一定要运行可靠。 |
回复
有奖活动 | |
---|---|
【EEPW电子工程师创研计划】技术变现通道已开启~ | |
发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
【EEPW在线】E起听工程师的声音! | |
“我踩过的那些坑”主题活动——第001期 | |
高校联络员开始招募啦!有惊喜!! | |
【工程师专属福利】每天30秒,积分轻松拿!EEPW宠粉打卡计划启动! | |
送您一块开发板,2025年“我要开发板活动”又开始了! | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
电流检测模块MAX4080S被打赏10分 | |
【我踩过的那些坑】calloc和malloc错误使用导致跑飞问题排查被打赏50分 | |
多组DCTODC电源方案被打赏50分 | |
【我踩过的那些坑】STM32cubeMX软件的使用过程中的“坑”被打赏50分 | |
新手必看!C语言精华知识:表驱动法被打赏50分 | |
【我踩过的那些坑】杜绑线问题被打赏50分 | |
【我踩过的那些坑】STM32的硬件通讯调试过程的“坑”被打赏50分 | |
【我踩过的那些坑】晶振使用的问题被打赏100分 | |
【我踩过的那些坑】电感选型错误导致的处理器连接不上被打赏50分 | |
【我踩过的那些坑】工作那些年踩过的记忆深刻的坑被打赏10分 |