完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
|
最近遇到了这样一个问题:写入下面 FLEXCAN 区域的数据怎么会和写入的数据不一致呢?
当前工程中有这样一个功能:上电后,会查看该区域的数据。预定义值将被写入 CAN 控制器的邮箱数据寄存器(ID、DLC、数据),然后数据将被读回以进行比较。如果它们不匹配,将报告错误: 预定义的模式被写入相应的邮箱寄存器,并且读取作不会返回预期的模式。 客户正在使用 Vector 的协议栈,其中已经包含了此功能的实现。但是,Vector 并不清楚如何产生这种错误,这可能与芯片的底层有关。 之后,参考了“FlexCAN 模块安全措施”部分和参考手册第 73.3.15 节中的相关描述,我了解到 CAN 控制器中的 RAM 硬件包括 ECC 检查,并且 IP 设计还包括故障注入寄存器。其中,有一种叫做 “flipping data read from the memory” 的 fault injection 方法。我尝试调用这些 API(包括对 ERRIDPR 寄存器的作),但我没有找到任何效果(使用 S32K312EVK 进行复制)。因此,我想请求您的帮助,以了解应该如何使用这些 API?如何翻转读取数据以验证客户的功能“写入 FLEXCAN 的以下区域并将其读取出来,使其与写入的内容不一致”? |
|
相关推荐
1个回答
|
|
|
在S32K312的FLEXCAN模块中,写入邮箱数据寄存器(如ID、DLC、数据字段)后读取不一致的问题可能由以下原因导致。以下是逐步排查和解决方案: 1. 检查时钟配置
2. 邮箱状态检查
3. 寄存器写保护
4. 数据对齐与位宽
5. 保留位或只读位
6. 缓存/内存屏障
7. 协议栈干扰
8. 硬件连接问题
参考手册关键点
调试建议
通过上述步骤,应能定位到数据不一致的根本原因。如果问题仍存在,建议联系NXP技术支持并提供寄存器快照(Register Snapshot)以进一步分析。 |
|
|
|
|
只有小组成员才能发言,加入小组>>
2135个成员聚集在这个小组
加入小组我的项目我做主,使用GN+Ninja来完成构建系统(VSCode开发RT106X)
37379 浏览 0 评论
NXP IMX8应用处理器快速入门必备:技巧、使用、设计指南
6778 浏览 1 评论
7796 浏览 1 评论
7646 浏览 0 评论
NXP i.MX6UL开发板(linux系统烧录+规格+硬件+模块移植)使用手册
5074 浏览 0 评论
1559浏览 2评论
关于NINA-W132 Wi-Fi模块SPI通信遇到的疑问求解
1211浏览 2评论
如何在MPC PowerPC MCU上首次刷写后禁用BDM?
750浏览 1评论
将HFREFR和LFREFR寄存器值设置为错误的值来将故障注入CMU,但CMU_ISR值始终为零,为什么?
737浏览 1评论
将SPSDK for FRDM-MCX-W71 SDK与VS一起安装时出现hidapi构建错误怎么解决?
681浏览 1评论
/9
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-12-3 07:23 , Processed in 0.540893 second(s), Total 44, Slave 37 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191

淘帖
850