1048|1

3713

帖子

0

资源

纯净的硅(中级)

一个eCAN bug引发的TMS320F2812的奇怪问题 [复制链接]

最近在调F2812实现CANOpen协议的时候,发现一个奇怪的问题,读取F2812的CAN消息数据寄存器MDL和MDH时,出现读取为0的情况,如下所示,局部变量DataL和DataH有概率出现值为0的情况,万般无奈之下,又增加了回读判断的语句,概率大幅度减小,也没有从本质解决这个问题,而且也没法解释这个问题。

image.png

和TI的技术人员了解,最后从勘误表上找到了问题的解释和解决方案,如下所示:

image.png

大概意思是,当eCAN模块访问eCAN寄存器的时候,如果同时CPU读取eCAN寄存器,会出现读取失败的情况。我们的现象就是Case1中描述的。

image.png

在勘误表中,也给出了解决办法及参考代码

对于Case1,那么需要额外增加一个判断语句,判断读取到的值是不是全零,如果全零的话,那么再进行第二步读取。同时TI提供了参考代码的解决方案,增加二次回读的函数,如下:

image.png

附上代码链接:
http://www.ti.com/general/docs/lit/getliterature.tsp?literatureNumber=sprc180&fileType=zip

 


回复

530

帖子

0

资源

一粒金砂(高级)

谢谢分享学习一下


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

查找数据手册?

EEWorld Datasheet 技术支持

最新文章 更多>>
    关闭
    站长推荐上一条 1/10 下一条

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

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

    北京市海淀区知春路23号集成电路设计园量子银座1305 电话:(010)82350740 邮编:100191

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