如何判断硬件是否支持嵌入式Linux

描述

在为您的定制电子设计挑选零件时,预先检查 Linux 驱动程序支持是值得的。为不受支持的硬件编写新的驱动程序既费时又会带来风险并增加项目的复杂性。

最好选择支持的硬件。我们如何首先检查硬件是否受支持?首先,您需要找到您将使用的 Linux 的确切版本。

获得正确的 Linux 内核

您可能使用的是 kernel.org 的内核版本,但更有可能使用的是 SOC 供应商提供的任何定制内核。例如,如果您使用带有 BSP imx_4.9.88_2.0.0_ga 的 NXP i.MX 处理器,那么您将使用这个。

您需要确保您拥有将要使用的 Linux 内核的确切版本。支持一直在添加和删除,不能保证在两个不同版本的 Linux 内核中会找到相同的代码。

寻找驱动程序支持

既然您拥有正确的内核源代码,那么如何检查给定的硬件部件号是否受支持?

最好的方法是对您要查找的部件号进行文本搜索。我将用几个例子来说明这一点。

注意:在这些示例中,我们使用的是 kernel.org 的内核版本 v5.0-rc1。搜索我们将使用“git grep”,这是一个非常快速的命令行工具,用于搜索 git 存储库的全部内容。

示例 1:S25FL512SAGMFI011 闪存

您可能会尝试的第一件事是搜索整个零件编号。

源代码

这没什么好说的。下一步是在不区分大小写的情况下进行搜索。最好不区分大小写搜索,因为 Linux 内核更喜欢驱动程序名称的小写标识符,但您可能会在大写或小写中找到线索。

源代码

不幸的是,这仍然没有提出任何建议。接下来要尝试的是从部件号中删除一些尾随字符,因为其中一些可能是指封装、温度范围和其他不影响设备逻辑操作的内容,并且不影响Linux驱动程序的运行。

您可以从搜索字符串中逐个删除字符,直到找到匹配项,然后根据数据表和结果做出明智的决定,以查看您的部分是否受支持。查看数据表,我们可以看到只有 S25FL512S 部分与设备的逻辑操作相关。

源代码

现在我们有了一些有趣的结果。第一个结果是“jedec,spi-nor”设备树绑定的一些文档。最后一个结果是“spi-nor.c”驱动程序中的一个表条目,该表描述了这个特定闪存芯片的一些属性。

由此我们可以推断该芯片是受支持的,并且可以在启动时通过其 JEDEC ID 检测到,如果按照第一个结果的文档中的描述添加了正确的设备树条目。

示例 2:MCP79411-I/SN 实时时钟

同样,搜索整个零件编号也不会显示任何内容。查看数据表,MCP79410、MCP79411 和 MCP79412 有一个数据表。唯一的区别是设备内部存储中提供的“唯一 ID”类型。因此我们可以尝试搜索“MCP7941”。

源代码

我们再次获得一些驱动程序结果和一些关于如何通过设备树添加支持的文档。

最终积分

有时不会明确支持确切的部分,但它可能在功能上与另一部分相同,在这种情况下,可以对两者使用相同的驱动程序。

如果该部分不受支持,则值得拥有一份最新的 Linux 内核源代码以进行交叉引用。如果最近添加了支持,您可以将驱动程序“反向移植”到您的内核版本。

有时,驱动程序已经编写完成,但尚未包含在官方内核源代码中。它可能已提交到邮件列表,您或许可以尽早试用。在任何情况下,“谷歌”都可以提供很大的帮助。

审核编辑:郭婷

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分