OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 12875|回复: 14

关于例程中JTAG_Set();函数的疑问

[复制链接]
头像被屏蔽

93

主题

160

帖子

0

精华

禁止发言

积分
457
金钱
457
注册时间
2012-4-3
在线时间
7 小时
发表于 2012-4-3 20:26:10 | 显示全部楼层 |阅读模式
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2012-4-3 21:01:35 | 显示全部楼层
嗯,按你的意思,应该如何写?
你按自己的意思修改一下,再测试一下就知道我对还是你对了.
不难吧?
事实说话.
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

头像被屏蔽

93

主题

160

帖子

0

精华

禁止发言

积分
457
金钱
457
注册时间
2012-4-3
在线时间
7 小时
 楼主| 发表于 2012-4-4 00:31:55 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2012-4-4 00:47:28 | 显示全部楼层
数值就是根据这个寄存器描述来的。
没什么问题。

 
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

头像被屏蔽

93

主题

160

帖子

0

精华

禁止发言

积分
457
金钱
457
注册时间
2012-4-3
在线时间
7 小时
 楼主| 发表于 2012-4-4 01:02:09 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2012-4-4 01:35:20 | 显示全部楼层
看代码,然后用笔在你的本子上模拟一下代码的执行过程
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

1

主题

14

帖子

0

精华

新手上路

积分
39
金钱
39
注册时间
2012-3-24
在线时间
0 小时
发表于 2012-4-8 21:07:15 | 显示全部楼层
其实原子少写了一行注释,就是宏定义的值是pdf的3bit设置值的高2位,不是低2位啊!
我也疑问过的
回复 支持 反对

使用道具 举报

96

主题

247

帖子

1

精华

高级会员

Rank: 4

积分
801
金钱
801
注册时间
2012-6-29
在线时间
0 小时
发表于 2012-9-24 20:12:05 | 显示全部楼层
那些参数是原子设定的,(注意移位是<<25,而不是24,移位后只有CWJ_CFG[2:0]=0b000、0b010、0b100,;少了一个0b001~!)
我们可以修改一下函数,用调用库函数实现:
void JTAG_Set(u8 mode)
{
RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE);
if(mode == JTAG_SWD_DISABLE)//2
{
GPIO_PinRemapConfig(GPIO_Remap_SWJ_Disable, ENABLE);//关闭JTAG-DP,关闭SW-DP
}
else if(mode == SWD_ENABLE)//1
{
GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable, ENABLE);//关闭JTAG-DP,启用SW-DP
}
else if(mode == JTAG_SWD_ENABLE)//0 
{
GPIO_PinRemapConfig(GPIO_Remap_SWJ_Disable, DISABLE);//完全SWJ(JTAG-DP + SW-DP):复位状态
//库函数没有设置SWJ_CFG[2:0]=0b000值,采用任何设置参数,然后用“Disable”,可以实现“全开启模式”
}
else//本函数没有用到的值:SWJ_CFG[2:0]=0b001
{
GPIO_PinRemapConfig(GPIO_Remap_SWJ_NoJTRST, ENABLE);//完全SWJ(JTAG-DP + SW-DP)但没有JNTRST
}
}
http://blog.tianya.cn/blogger/blog_main.asp?BlogID=4666068
回复 支持 反对

使用道具 举报

96

主题

247

帖子

1

精华

高级会员

Rank: 4

积分
801
金钱
801
注册时间
2012-6-29
在线时间
0 小时
发表于 2012-9-24 20:12:49 | 显示全部楼层
改用这个函数,我运行过,与原来的函数没有区别~!
http://blog.tianya.cn/blogger/blog_main.asp?BlogID=4666068
回复 支持 反对

使用道具 举报

4

主题

70

帖子

0

精华

初级会员

Rank: 2

积分
110
金钱
110
注册时间
2013-3-21
在线时间
0 小时
发表于 2013-5-14 23:15:43 | 显示全部楼层
回复【楼主位】noip0726:
---------------------------------
首先看一下这些:
void JTAG_Set(u8 mode)
{
u32 temp;
temp=mode;
temp<<=25;
RCC->APB2ENR|=1<<0;     //开启辅助时钟    
AFIO->MAPR&=0XF8FFFFFF; //清除MAPR的[26:24]
AFIO->MAPR|=temp;       //设置jtag模式

JTAG_Set(JTAG_SWD_DISABLE);
#define JTAG_SWD_DISABLE   0X02
0x02=0010,左移25位后MAPR的[26:24]为:100  ;此刻,你再看手册里面的100,呵呵就是关闭JTAG,SWD. 我反正看懂了……
原子哥威武,欧耶耶,欧拉拉。遇事不要心急,不然你就吃不成豆腐了
等待就是浪费时间!
回复 支持 反对

使用道具 举报

2

主题

8

帖子

0

精华

初级会员

Rank: 2

积分
53
金钱
53
注册时间
2014-9-21
在线时间
4 小时
发表于 2014-12-23 20:36:29 | 显示全部楼层
回复【7楼】zb213015:
---------------------------------
喔  原来如此
回复 支持 反对

使用道具 举报

2

主题

8

帖子

0

精华

初级会员

Rank: 2

积分
53
金钱
53
注册时间
2014-9-21
在线时间
4 小时
发表于 2014-12-23 20:37:51 | 显示全部楼层
@zb213015  你讲的很对
回复 支持 反对

使用道具 举报

28

主题

140

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
461
金钱
461
注册时间
2013-10-18
在线时间
72 小时
发表于 2015-3-21 15:34:02 | 显示全部楼层
回复【2楼】正点原子:
---------------------------------
JTAG_Set(0);     //JTAG  +  SW  都能用
JTAG_Set(1);    //JTAG  +  SW  都能用,手动复位

JTAG_Set(2);   //全部不能用    ,为何啊!!!!!!我想用SW,来省下上面的几个管脚

JTAG_Set(3);   //JTAG  +  SW  都能用,复位没有测试     


我就想用SW下载,但是

JTAG_Set(2)把所有的全关了,还得用串口下载


============================

//JTAG模式设定,P118
//mode:0,1,2,3
//0: 完全SWJ(JTAG-DP + SW-DP):复位状态; 
//1:完全SWJ(JTAG-DP + SW-DP)但没有NJTRST; 
//2:关闭JTAG-DP,启用SW-DP; 
//3:关闭JTAG-DP,关闭SW-DP; 其它组合:无作用。
void JTAG_Set(u8 mode)
{
u32 temp=0;
switch(mode)
{
case 0:  temp = 0;  break;
case 1:  temp = 1;  break;
case 2:  temp = 2;  break;
case 3:  temp = 4;  break;
}
RCC->APB2ENR |= 1;  //开启辅助时钟
AFIO->MAPR &= 0xf8ffffff;  //清除JTAG设定位
AFIO->MAPR |= temp<<24;   //不知道您为何左移25位,我左移24对了
}







回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2015-3-21 23:03:22 | 显示全部楼层
[mw_shl_code=c,true]//JTAG模式设置,用于设置JTAG的模式 //mode:jtag,swd模式设置;00,全使能;01,使能SWD;10,全关闭; //#define JTAG_SWD_DISABLE 0X02 //#define SWD_ENABLE 0X01 //#define JTAG_SWD_ENABLE 0X00 void JTAG_Set(u8 mode) { u32 temp; temp=mode; temp<<=25; RCC->APB2ENR|=1<<0; //开启辅助时钟 AFIO->MAPR&=0XF8FFFFFF; //清除MAPR的[26:24] AFIO->MAPR|=temp; //设置jtag模式 } [/mw_shl_code]
根据这个参数说明设置即可.
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

8

主题

63

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2497
金钱
2497
注册时间
2014-12-2
在线时间
210 小时
发表于 2017-11-23 16:57:26 | 显示全部楼层
正点原子 发表于 2015-3-21 23:03
[mw_shl_code=c,true]//JTAG模式设置,用于设置JTAG的模式
//mode:jtag,swd模式设置;00,全使能;01,使能SW ...

调用 void JTAG_Set(u8 mode)这个函数确实有问题,今天就是在测试这个,实在没招了,直接:
RCC->APB2ENR |= 1<<0;//开启辅助时钟         
AFIO->MAPR |= (1 << 24);//jtag njrst复用输出I/O
所涉及的问题迎刃而解,所使用的软件MDK5.14,寄存器版本;
------------------------------------------------------------------
!!! 在调用JTAG_Set(SWD_ENABLE)时,会导致后续不能SWD调试以及下载 !!!
------------------------------------------------------------------
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-12 22:06

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表