当前位置: 首页 > article >正文

嵌入式Linux系统TF卡热插拔检测问题

一、背景介绍

项目上使用linux系统,运行主控是君正T41,遇到一个系统无法识别TF卡的问题,经过一番探索最终成功解决。感觉挺有意思的,记录下分析和解决的过程。

二、现象描述

插入TF卡后系统无任何反应,也没有生成 /dev/mmcblk0 这个文件,但是在uboot里可以正常识别和读取。起初怀疑是内核配置问题,将mmc相关的配置检查了一遍,并未发现什么异常。正在苦思无果时,我注意到内核启动时有打印这么两行:

三、分析过程

既然在uboot里识别和读取正常,说明至少硬件上读写是没问题的,结合内核启动时的打印信息,我推测问题应该是出在卡检测上面。TF卡是通过SDIO接口连接到主控芯片,除了基本的通信脚,还有一个CD脚用于TF卡热插拔检测。

推测应该是CD脚有差异,在板子上执行如下指令查看系统GPIO管脚定义:

mount -t debugfs debugfs /sys/kernel/debug
cat /sys/kernel/debug/gpio

得到如下结果:

终于发现端倪,可以看到系统默认的CD脚是gpio-59,也就是PB27。但我这块板子的CD脚实际连的是PB26,硬件与驱动对应不上,导致内核无法检测到TF卡。像这种基础功能,原则上按芯片厂商的参考设计来,就没任何问题了,可能是硬件团队的同事出于某种考虑,将这个CD脚调整了。

四、解决方法

问题已经明确,接下来就是考虑如何将驱动程序里的管脚定义改过来。这里涉及到几层关系,系统mmc调用SDHCI这个标准接口,SDHCI由ingenic-sdhci实现,于是决定就从这里入手。打开内核路径下的sdhci相关的源码 kernel-4.4.94/drivers/mmc/host/sdhci-ingenic.c 搜索关键字“SDHCI EXT CD”,果真还让我找到了一个函数:

这个函数的功能是设置卡检测的管脚,但是管脚的信息是通过参数传进来的,于是向上一层层追溯,最终发现这个CD脚的定义并不在这里,而是通过dts也就是设备树动态传递过来的。有了这个信息就好办了,开始挖dts的代码,路径 kernel-4.4.94/arch/mips/boot/dts/ingenic/marmot.dts 我这里使用的君正T41(mips架构),内核默认配置是marmot,如果是其他处理器会不一样,要根据实际。

找到对应的dts文件后就简单了,很容易就找到了定义CD脚的地方:

可以看到当前是PB27,改成PB26后,重新编译内核,烧录,成功检测到TF卡!

五、结束


http://www.kler.cn/a/323551.html

相关文章:

  • LlamaFactory介绍
  • 基于Matlab的碎纸片的自动拼接复原技术
  • 基于OpenCV的图片人脸检测研究
  • 浅谈React的虚拟DOM
  • 利用python 检测当前目录下的所有PDF 并转化为png 格式
  • LeetCode654.最大二叉树
  • 递归,搜索与回溯40道算法题
  • Android 保存本地图片
  • 深度学习(入门)03:监督学习
  • 9.24 C++ 常成员,运算符重载
  • 人工智能-机器学习-深度学习-分类与算法梳理
  • qt 模仿简易的软狗实现
  • Java NIO 全面详解:掌握 `Path` 和 `Files` 的一切
  • Keysight 下载信源 Visa 指令
  • 蓝桥杯模块二:数码管的静态、动态实现
  • 电脑录屏怎么录视频和声音?苹果macOS、windows10都可以用的原神录屏工具来啦
  • 【JAVA】算法笔记
  • Linux用户管理
  • 面试遇到的质量体系10个问题(深度思考)
  • 论文阅读 | 可证安全隐写(网络空间安全科学学报 2023)
  • 神经网络(二):卷积神经网络
  • Vscode 远程切换Python虚拟环境
  • 解决Android中使用jdk 9以上中的某个类(AbstractProcessor)但是无法导入的问题
  • Java中通过方法上注解实现入参校验
  • 计算机毕业设计 在线问诊系统的设计与实现 Java实战项目 附源码+文档+视频讲解
  • C++那些你不得不知道的(2)