IIC挂死问题解决过程

猜测1:认为IIC device程序有问题

检查1:查看程序发现有可能溢出的部分,使用IIC 工具刷过量数据到slave,未出问题。

猜测2:认为IIC device寄存器进入异常状态未能恢复

检查2:检查正常IIC寄存器和异常状态IIC寄存器,未能发现问题。

猜测3:时钟分频问题

检查3:询问同事,答固定分频。

猜测4:看波形分析

检查4:波形未量到,测量波形导致通信异常,部分设备破坏,放弃该方法。

猜测1:串口中断导致IIC初始化时被打断产生问题。

检查1:删除调试串口设备树节点,发现IIC启动100%出现问题 T-T。

猜测2: 100%复现的问题和之前的概率出现的问题相同

检查2:检查寄存器,检查设备detect 表现,认为是相同问题。

删除串口设备树节点,IIC device 必出问题。

猜测1:怀疑调试串口外部硬件电平高低导致IIC外设受影响

检查1:检查原理图,未发现影响的可能性。

猜测2:怀疑串口初始化部分处理了部分IIC设备依赖的初始化(导致不初始化串口IIC不能正常工作)。

检查2:查看串口初始化代码未能发现有值得注意的初始化。

猜测3:怀疑串口初始化影响公共寄存器间接影响IIC。

检查3:发现公共寄存器IIC div分频部分和正常工作的分频不一样,改回后问题解决。

删除串口设备后公共寄存器值不正常,串口收到数据后公共寄存器值不正常。

猜测1:调试串口或IIC代码异常导致寄存器值被修改。

检查1:增加打印,发现问题原因在于IIC初始化过程中分频寄存器设置失败。但是同样方法在IIC device端初始化时设置该寄存器是成功的。

猜测1: 特定配置下IIC 分频寄存器为只读

检查1:芯片设计方核实不存在这样的设计。

检查1:在写入分频寄存器前增加打印,dump所有公共寄存器。和正常公共寄存器做比较,未发现问题。写入IIC分频器成功。

猜测2:增加打印信息后写入成功为必现,去掉打印会写入不成功。

检查2:证实猜测。

猜测3:写入成功和读取公共寄存器相关

检查3:减少dump范围,小范围dump写入失败,大范围dump写入成功。

猜测4:写入成功和写入时间相关

检查4:dump的寄存器次数不变dump相同寄存器。证实写入成功与写入时间相关。

思考:可能和时钟初始化相关,但是公共寄存器的时钟初始化状态dump是正常的。

猜测1:dump过程中时钟初始化完成(证据:增加dump后写入正常)。

检查1:减少dump范围,发现公共寄存器的mpll稳定寄存器未稳定。

猜测2:时钟相关初始化未完成导致写入失败。

检查2:根据时钟依赖,在写入前增加等待,同时去掉打印,写入成功。

去掉串口设备导致问题100%复现,原因是串口不用初始化导致IIC 时钟分频更早初始化,写入IIC分频寄存器失败。

1.解决问题过程中,曾经怀疑过时钟分频问题但是未检查寄存器,导致问题解决时间拉长。

2.最开始未能考虑问题和时间相关的情况,如果直接思考该可能性,预计提高解决问题速度。

Original: https://www.cnblogs.com/fanguang/p/11808700.html
Author: 反光
Title: IIC挂死问题解决过程

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/578093/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • ASP.NET Core 3.0 : 二十八. 在Docker中的部署以及docker-compose的使用

    本文简要说一下ASP.NET Core 在Docker中部署以及docker-compose的使用 (ASP.NET Core 系列目录)。 系统环境为CentOS 8 。 一、概…

    Linux 2023年6月7日
    0108
  • 标签泄露 Label leaking

    404. 抱歉,您访问的资源不存在。 可能是网址有误,或者对应的内容被删除,或者处于私有状态。 代码改变世界,联系邮箱 contact@cnblogs.com 园子的商业化努力-困…

    Linux 2023年6月7日
    096
  • Cisco GNS3教程,GNS3搭建IPv6 6rd环境,Linux 配置 IPv6 6rd详析

    Cisco GNS3 IPv6 6rd实验 1、回顾 前文:https://www.cnblogs.com/kingpop/p/14054321.html在描述Cisco GNS3…

    Linux 2023年6月6日
    0101
  • 【Example】C++ 标准库 std::atomic 及 std::memory_order

    C++ 标准库提供了原子操作。(我已经懒得写序言了) ==================================== 先来说原子操作的概念: 原子操作是多线程当中对资源进…

    Linux 2023年6月13日
    079
  • 【总结】瞬时高并发(秒杀/活动)Redis方案

    1,Redis 丰富的数据结构(Data Structures) * 字符串(String) – Redis字符串能包含 任意类型的数据 一个字符串类型的值最多能存储 …

    Linux 2023年5月28日
    089
  • powershell 编写的tui界面脚本《电壳别名宝》

    中文名: 《电壳别名宝》 English name: 《Power Alias》 powershell 编写的tui界面脚本。 用途:保存容易记住的别名(支持中文),保存linux…

    Linux 2023年5月27日
    0145
  • 计算机硬件的读写速度差异

    现代计算机系统 存储器 寄存器 CPU时钟周期 高速缓存 主存 固态硬盘 机械硬盘 压榨CPU性能带来的问题 有序性问题 可见性问题 原子性问题 作者:小牛呼噜噜 | https:…

    Linux 2023年6月6日
    0131
  • redis持久化存储

    redis持久化存储 redis多被用于缓存和消息中间件,当被用作缓存时,数据的读写都是在内存中进行的,而内存一旦在主机断电或者主机重启时里面的数据将被清空,为保证数据不被丢失,r…

    Linux 2023年6月7日
    0112
  • 安装及管理文件

    优点: 契合系统兼容性强 如果你可以看懂源代码,修改新增功能 比较自由 缺点: 如果编译出了问题,你看不懂源代码,无法解决 安装过程复杂 没有统一的管理人员 安装过程 程序包编译安…

    Linux 2023年6月6日
    0106
  • ThinkPHP5浏览器关闭,继续执行php脚本

    ignore_user_abort(); //即使Client断开(如关掉浏览器),PHP脚本也可以继续执行. set_time_limit(0); //执行时间为无限制,php默…

    Linux 2023年6月7日
    094
  • Linux高可用之Keepalived

    注意: 各节点时间必须同步 确保各节点的用于集群服务的接口支持MULTICAST通信(组播); 安装 从CentOS 6.4开始keepalived随系统base仓库提供,可以使用…

    Linux 2023年5月27日
    0141
  • redis的三种集群方式

    博客园 :当前访问的博文已被密码保护 请输入阅读密码: Original: https://www.cnblogs.com/heqiyoujing/p/14494037.htmlA…

    Linux 2023年5月28日
    0106
  • SpringBoot中通过AOP整合日志文件

    1.SpringBoot中通过AOP整合日志文件 1. 导入相关的依赖 org.springframework.boot spring-boot-starter org.sprin…

    Linux 2023年6月14日
    0102
  • Android 图片设置圆角

    Android 开发中,经常需要对图片进行二次处理,比如添加圆角效果 或 显示圆形图片; 通过第三方框架 Glide 设置圆角效果; 写法1: RequestOptions opt…

    Linux 2023年6月13日
    087
  • Spring Boot中异步调用的正确使用姿势(详解)【转】

    介绍:异步请求的处理。除了异步请求,一般上我们用的比较多的应该是异步调用。通常在开发过程中,会遇到一个方法是和实际业务无关的,没有紧密性的。比如记录日志信息等业务。这个时候正常就是…

    Linux 2023年6月8日
    0106
  • termius好用的shell终端

    ipad下可用 posted @2022-07-23 12:41 jiftle 阅读(75 ) 评论() 编辑 Original: https://www.cnblogs.com/…

    Linux 2023年5月28日
    0115
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球