2730|1

49

帖子

0

TA的资源

一粒金砂(中级)

楼主
 

华大MCU端口使用时的竞争-冒险现象 [复制链接]

在使用华大单片机时对GPIO操作是最基础的操作,即使这种操作如果不注意还是会掉到坑里去。
   例如:使用同一组GPIO端口中的两个引脚(PA00和PA01)做输出,PA00在主循环中改变输出状态,PA01通过中断方式改变输出状态。正常的情况应该是PA00只在主循环中改变输出状态,而PA01只会在中断发生时改变输出状态。但是,随着程序运行时间的加长或者在主循环中提高PA00输出的频率,会发现本应该在中断中完成状态改变的PA01,个别时候状态会不发生改变。而在中断服务程序中设置断点,进行debug发现中断可以正常进入,也能正常改变PA01的输出状态。要想分析造成这个情况的原因可以从官方提供的DDL库入手来分析。华大单片机M0+系列芯片在对GPIO端口输出电平操作时,DDL库提供了如下两种方法:


方法1

<p><font face="微软雅黑" size="3">/*****************************************************************************

 ** \brief GPIO IO输出值写入

 **

 ** \param [in]  enPort          IO Port

 ** \param [in]  enPin           IO Pin

 ** \param [out] bVal            输出值

 **

 ** \retval en_result_t           Ok          设置成功

 **                                         其他值    设置失败 ******************************************************************************/

en_result_t Gpio_WriteOutputIO(en_gpio_port_t enPort, en_gpio_pin_t enPin, boolean_t bVal)

{

    SetBit(((uint32_t)&M0P_GPIO->PAOUT + enPort), enPin, bVal);</font></p><p><font face="微软雅黑" size="3">    return Ok;

}</font></p>

方法2:

<p><font face="微软雅黑" size="3">/*******************************************************************************

 ** \brief GPIO IO设置

 **

 ** \param [in]  enPort          IO Port

 ** \param [in]  enPin           IO Pin

 **

 ** \retval en_result_t           Ok        设置成功

 **                                        其他值   设置失败 ******************************************************************************/

en_result_t Gpio_SetIO(en_gpio_port_t enPort, en_gpio_pin_t enPin)

{

    SetBit(((uint32_t)&M0P_GPIO->PABSET + enPort), enPin, TRUE);</font></p><p><font face="微软雅黑" size="3">    return Ok;

}</font></p><p><font face="微软雅黑" size="3">

</font></p><p><font face="微软雅黑" size="3">/******************************************************************************

 ** \brief GPIO IO清零

 **

 ** \param [in]  enPort          IO Port

 ** \param [in]  enPin           IO Pin

 **

 ** \retval en_result_t           Ok        设置成功

 **                                         其他值  设置失败 ******************************************************************************/

en_result_t Gpio_ClrIO(en_gpio_port_t enPort, en_gpio_pin_t enPin)

{

    SetBit(((uint32_t)&M0P_GPIO->PABCLR + enPort), enPin, TRUE);</font></p><p><font face="微软雅黑" size="3">    return Ok;

}</font></p>

 

方法1是对整个PxOUT寄存器进行的操作,查看华大单片机用户手册关于此寄存器的说明; 当PxOUT寄存器对应位为1时,对应的引脚输出高电平,反之输出低电平。
   方法2是通过置位寄存器引脚对应位的置1完成引脚输出高电平的操作,寄存器说明。

通过清零寄存器引脚对应位的置1完成引脚输出低电平的操作,寄存器说明

如图:

 

上述输出不正常的现象是因为使用了方法1进行的操作。在主循环中对PA00输出状态的改变通过PAOUT寄存器来完成,假如PORTA所有引脚都为低电平时,让PA00输出高电平,方法1的操作是把0X0001写入到PAOUT寄存器就可以实现。在ARM的汇编指令中要把0X0001写入到PAOUT必须借助于通用寄存器 (r0~r7)来实现。当CPU刚完成0X0001移入到通用寄存器时,中断发生,CPU会把通用寄存器保存起来,然后响应中断,在中断中PA01输出高电平PAOUT值为0X0002,之后退出中断。退出中断后,CPU会恢复中断之前通用寄存器的值(0X0001),再继续把通用寄存器的值存入到PAOUT。这时PAOUT的值是0X0001,只有PA00输出高电平,而PA01没有输出高电平。这种现象就是华大MCU端口使用时的竞争-冒险现象。
   在使用华大芯片的时候不希望这竞争-冒险现象出现,通过方法2的操作完全可以避免此现象的出现。因为方法2是对寄存器的位进行操作,每次操作的时候只有对应的位进行置位或清零,其它位值为0的时候不影响输出的结果 。
   建议大家在开发的时候对GPIO端口输出操作时,使用方法2的方式来操作。

此帖出自51单片机论坛

最新回复

亲,不光是华大,任何单片机只要采取了 读改写 操作寄存器的方式来操作IO的输出寄存器,都会出现这问题。事实证明,尽量不要在中断里操作IO或者外设,因为中断和你的主循环现在相当于两个线程,两个线程访问的资源不加锁的话肯定会出问题,要么你在循环里操作IO前关中断,之后开中断,要么你给要操作的IO加锁标志,避免程序同时操作同一个寄存器。所以才有了单周期IO控制寄存器,你只需要往对应的set或者reset寄存器里填数就行了,只有写,没有读操作,安全许多。   详情 回复 发表于 2023-2-13 08:44
点赞(1) 关注
 

回复
举报

380

帖子

0

TA的资源

一粒金砂(高级)

沙发
 

亲,不光是华大,任何单片机只要采取了 读改写 操作寄存器的方式来操作IO的输出寄存器,都会出现这问题。事实证明,尽量不要在中断里操作IO或者外设,因为中断和你的主循环现在相当于两个线程,两个线程访问的资源不加锁的话肯定会出问题,要么你在循环里操作IO前关中断,之后开中断,要么你给要操作的IO加锁标志,避免程序同时操作同一个寄存器。所以才有了单周期IO控制寄存器,你只需要往对应的set或者reset寄存器里填数就行了,只有写,没有读操作,安全许多。

此帖出自51单片机论坛
 
 
 

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
推荐帖子
【注目】我觉得电子设计大赛最应该注意的

本帖最后由 paulhyde 于 2014-9-15 08:53 编辑 就是评分标准! 正弦信号发生器(A题) 一、任务 设计制作一个正弦信号发生 ...

C程序中嵌入汇编新方法

由于C语言在定时方面的缺陷,在某些场合下,C程序中需要嵌入汇编代码,以弥补C的缺陷。通常,在C语言程序中嵌入汇编的方法,无外 ...

C语言编程艺术--条件编译(zt)

有些程序在调试、兼容性、平台移植等情况下可能想要通过简单地设置一些参数就生成一个不同的软件,这当然可以通过变量设置,把所 ...

ADC/DAC应用设计宝典

第一章 ADC与DAC概念 ⋯⋯ 1 第二章 ADC与DAC原理 ⋯⋯ 1-3 第三章 ADC与DAC基础知识详解 ⋯⋯ ...

FPGA学习分享---初学者的快乐(记应用FPGA完成DS18B20的控制和读取)

各位坛友, 在国庆过后,我就开始在坛子空间里面念叨着老师给我的这个毕业设计热身题目:运用红色飓风二代alte ...

测评报告汇总:能点科技电容式、光电液位传感器

活动详情:【免费测评:电容式、光电液位传感器】测评|【免费测评:电容式、光电液位传感器】免费试用_电子工程世界 (eeworld.co ...

请教一个电阻测量电路

644780电路原理图如上图所示。 P16接负极板,该电路用于测量电阻值,P16阻值不一样的时候,T36处的波形不一样: 短接的时 ...

ARM核心板厂家对比

国内有一些公司提供ARM核心板,如果用ARM核心板厂家设计的核心板(主要包括CPU, DDR, EMMC, PMIC),自己设计底板用作工业控制器 ...

EEWorld邀你来拆解(第13期)——旧物大拆解

hello~大家好呀~~咱们EEWorld邀你来拆解活动又来啦~~~ 拆解的魅力就在于满足好奇心和破坏欲,让你越拆越上瘾~为让更多的网友 ...

【Raspberry Pi 5 测评】在树莓派5上使用OpenCV处理图像

【Raspberry Pi 5 测评】在树莓派5上使用OpenCV处理图像 【Raspberry Pi 5 测评】在树莓派5上使用OpenCV处理图像 一、OpenCV ...

关闭
站长推荐上一条 1/10 下一条
有奖直播:当AI遇见仿真,会有什么样的电子行业革新之路?
首场直播:Simcenter AI 赋能电子行业研发创新
直播时间:04月15日14:00-14:50

查看 »

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

 
机器人开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网 13

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表