【NVMEM子系统】二、NVMEM驱动框架
创始人
2024-05-26 08:37:51
img
个人主页:董哥聊技术
我是董哥,嵌入式领域新星创作者
创作理念:专注分享高质量嵌入式文章,让大家读有所得!
img

文章目录

    • 1、前言
    • 2、驱动框架
    • 3、源码目录结构
    • 4、用户空间下的目录结构

1、前言

NVMEM SUBSYSTEM,该子系统整体架构不算太大,还是比较容易去理解的,下面我们一起去一探究竟!

NVMEM(Non Volatile Memory),该子系统主要用于实现EEPROMEfuse等非易失存储器的统一管理。

在早期,像EEPROM驱动是存放于/drivers/misc目录下,由于没有做到好的抽象,每次需要去访问相应内存空间,都需要去复制几乎一样的代码,去注册sysfs,这是一个相当大的抽象泄露。

NVMEM子系统就是为了解决以往的抽象泄露问题。
 

2、驱动框架

该驱动框架较为简单,也适合初学者去熟悉基本的驱动框架。

image-20230210071204144

应用层:可以通过用户空间所提供的文件节点,来读取或者修改nvmem存储器的数据。

NVMEM 核心层:统一管理NVMEM设备,向上实现文件系统接口数据的传递,向下提供统一的注册,注销nvmem设备接口。

NVMEM 总线驱动:注册NVMEM总线,实现NVMEM控制器的底层代码实现。

TIP

nvmem子系统提供读写存储器的接口有两种,一种是通过文件系统读写,一种是在内核驱动直接读写。

对于EEPROM,其可以进行读写操作,而对于efuse,更多用于读取密钥信息,进而判断镜像是否被篡改,在用户空间是不允许被更改的。

这种是通过驱动提供的开放接口,直接获取指定位置的数据,详细的后面展开来说。
 

3、源码目录结构

ketnel
│   └── driver
│   │   └── nvmem
│   │   │   ├──	core.c					# NVMEM核心层
│   │   │   ├──	rockchip-efuse.c		# NVMEM总线驱动

 

4、用户空间下的目录结构

我们可以在用户空间去读取/写入数据,其所在的目录:/sys/bus/nvmem/devices/dev-name/nvmem

hexdump /sys/bus/nvmem/devices/qfprom0/nvmem0000000 0000 0000 0000 0000 0000 0000 0000 0000
*
00000a0 db10 2240 0000 e000 0c00 0c00 0000 0c00
0000000 0000 0000 0000 0000 0000 0000 0000 0000
...
*
0001000
img

点赞+关注,永远不迷路

img

相关内容

热门资讯

胡忠雄主持召开贵阳贵安政法工作... 1月10日,省委常委、市委书记胡忠雄主持召开贵阳贵安政法工作专题会。他强调,要深入学习贯彻习近平法治...
格陵兰岛各政党领导人:格陵兰人... (来源:千龙网)格陵兰岛各政党领导人当地时间9日发表联合声明,指出“格陵兰人不想成为美国人”。声明重...
稀有“超人”漫画书1500万美... 一本将“超人”这个超级英雄角色带到世间的稀有漫画书日前以1500万美元易主,创漫画书转手价格最高纪录...
我市加大力度开展见义勇为英模“... 本报讯(记者 李晓娟)2025年以来,我市积极开展见义勇为英模“爱心救助工程”,强化权益保障,深化宣...
特朗普:美国和委内瑞拉“合作扣... 澎湃新闻2026-01-10 12:29:48新华社马天静、徐德智/央视新闻 据新华社报道,美国总统...