OpenEdv-开源电子网

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

写F767串口程序的时候发现卡在延时函数中,以前在学F103的时候也遇到这样的问题,解决办法如下图,我想问问F767该怎么解决?

[复制链接]

8

主题

82

帖子

0

精华

初级会员

Rank: 2

积分
162
金钱
162
注册时间
2017-11-4
在线时间
88 小时
发表于 2018-2-1 22:01:15 | 显示全部楼层 |阅读模式
10金钱
以前在学F103的时候,在串口程序里面用延时的时候会出现卡在延时函数那行代码的这种情况,通过一些途径,找到解决办法如图1所示。现在学F767的时候,也遇到了一样的问题。我在程序中不注释掉那行delay_ms(500);代码的时候,发现程序没法执行到 HAL_GPIO_WritePin(GPIOB,GPIO_PIN_0,GPIO_PIN_RESET);        这行代码。但是我把delay_ms(500)注释掉后,中间加一行空延时,发现可以执行到 HAL_GPIO_WritePin(GPIOB,GPIO_PIN_0,GPIO_PIN_RESET)这一行指令,因为 HAL_GPIO_WritePin(GPIOB,GPIO_PIN_0,GPIO_PIN_RESET)是让LED灯亮,所以可以很方便的观察到现象。说明程序就是卡死在了delay_ms(500)这一行指令中了。不知道该怎么解决?原子哥、各路大哥,有能帮着解答一下吗?好糟心啊!难道在串口程序里面没办法延时?还是要用i++这种形式来实现延时?

图2,F767遇到问题

图2,F767遇到问题

图1,F103解决办法

图1,F103解决办法

最佳答案

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2018-2-1 22:01:16 | 显示全部楼层
天人一口12 发表于 2018-2-2 09:52
我在delay_ms之前写了两行PB0=1和PB1=0,延时之后写了一行PB0=0;串口助手发送数后,PB1亮了,PB0应该是 ...

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

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2018-2-2 01:16:30 | 显示全部楼层
这个根本不需要延时啊,和延时无关的。你不能执行到,是怎么判别的?
回复

使用道具 举报

8

主题

82

帖子

0

精华

初级会员

Rank: 2

积分
162
金钱
162
注册时间
2017-11-4
在线时间
88 小时
 楼主| 发表于 2018-2-2 07:32:57 来自手机 | 显示全部楼层
正点原子 发表于 2018-2-2 01:16
这个根本不需要延时啊,和延时无关的。你不能执行到,是怎么判别的?

我在延时函数之前写了PB0=1和PB1=0这两行,在延时函数后面写了PB0=0这一行,串口助手发送数以后,PB1亮了,PB0应该延时500ms之后亮,但是实际开发板上现实的结果是PB1会亮,PB0不会亮。而我把delay_ms那个延时函数换成__nop()指令的时候PB0会亮。我以前在F103的时候遇到过这个情况,一个网友指点说把delay.c里面的一行代码注释掉,换成另一行代码就行了,如下面的一幅图。我照做之后果然就好了,现在用F7同样遇到了这个问题,不知道该怎么办!
回复

使用道具 举报

8

主题

82

帖子

0

精华

初级会员

Rank: 2

积分
162
金钱
162
注册时间
2017-11-4
在线时间
88 小时
 楼主| 发表于 2018-2-2 07:45:37 来自手机 | 显示全部楼层
正点原子 发表于 2018-2-2 01:16
这个根本不需要延时啊,和延时无关的。你不能执行到,是怎么判别的?

我在delay_ms之前写了两行PB0=1和PB1=0,延时之后写了一行PB0=0;串口助手发送数后,PB1亮了,PB0应该是延时500ms后亮,但是实际情况是PB1受控制良了,PB0一直暗着!把delay_ms换成__nop()后,再用串口控制,两个灯都亮了,说明以前用delay_ms的时候灯PB0不亮就是卡在delay那了啊!我以前用F103的时候遇到过这个情况,网友指点按上面的一张图,将delay.c中的一行代码注释掉,换成另一行就可以了!所以想问问F7的该怎么办。
回复

使用道具 举报

8

主题

82

帖子

0

精华

初级会员

Rank: 2

积分
162
金钱
162
注册时间
2017-11-4
在线时间
88 小时
 楼主| 发表于 2018-2-2 09:52:23 | 显示全部楼层
正点原子 发表于 2018-2-2 01:16
这个根本不需要延时啊,和延时无关的。你不能执行到,是怎么判别的?

我在delay_ms之前写了两行PB0=1和PB1=0,延时之后写了一行PB0=0;串口助手发送数后,PB1亮了,PB0应该是延时500ms后亮,但是实际情况是PB1受控制良了,PB0一直暗着!把delay_ms换成__nop()后,再用串口控制,两个灯都亮了,说明以前用delay_ms的时候灯PB0不亮就是卡在delay那了啊!我以前用F103的时候遇到过这个情况,网友指点按上面的一张图,将delay.c中的一行代码注释掉,换成另一行就可以了!所以想问问F7的该怎么办。
回复

使用道具 举报

3

主题

26

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
218
金钱
218
注册时间
2018-7-12
在线时间
34 小时
发表于 2018-7-24 21:29:11 | 显示全部楼层
请问楼主这个问题解决了吗?我也遇到类似的问题
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-1 02:28

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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