FM24V10是i2c接口的非易失性RAM,通信时序与EEPROM一致。使用系统自带的at24.c驱动进行相关修改,使它适用与FM24V10。
EEPROM均配有写保护引脚(WP),故在驱动中与写入相关的函数首尾要加入WP引脚的处理,FM24V10写入时需WP为低时才有效。内核空间中使用gpio,需包含头文件<linux/gpio.h>,调用gpio_request()函数申请gpio,调用gpio_direction_output()设置引脚为输出,调用__gpio_set_value()设置引脚输出值。
因为FM24V10包含了一位页地址,故需要加入AT24_FLAG_ADDR16,才能访问到全部地址空间。
static const struct i2c_device_id at24_ids[] = {
{ "fm24v10", AT24_DEVICE_MAGIC(1048576 / 8, AT24_FLAG_ADDR16) },
{ /* END OF LIST */ }
};
static const struct of_device_id at24_of_match[] = {
{ .compatible = "xxxx,fm24v10"},
{}
};
static struct i2c_driver at24_driver = {
.driver = {
.name = "fm24v10",
.owner = THIS_MODULE,
.of_match_table = of_match_ptr(at24_of_match),
},
.probe = at24_probe,
.remove = at24_remove,
.id_table = at24_ids,
};
修改配置驱动目录下的Makefile,加入文件编译
obj-$(CONFIG_EEPROM_FM24V10) += fram24v10.o
修改.config文件加入CONFIG_EEPROM_FM24V10宏配置
CONFIG_EEPROM_AT24=m
CONFIG_EEPROM_FM24V10=y
在sys_config.fex文件中对对应的i2c接口进行配置
[twi2/twi_boardX]
compatible = "xxx,fm24v10"
reg = 0x54
reg值为FM24V10地址。
修改驱动目录下的Kconfig,增加如下内容
config EEPROM_FM24V10
bool "FM24V10"
default y
help
修改完成,编译下载验证。(可参照博客LinuxI2C驱动--从两个访问eeprom的例子开始)
本文介绍如何将系统自带的at24.c驱动修改以适配FM24V10非易失性RAM,包括配置WP引脚、加入AT24_FLAG_ADDR16标志以访问完整地址空间,以及具体的驱动配置步骤。

565

被折叠的 条评论
为什么被折叠?



