0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

RK3568笔记分享——如何挂载SPI FRAM铁电存储芯片

飞凌嵌入式 2023-09-22 08:01 次阅读

对于做快速存储采集数据类产品的用户来说,在处理突发掉电情况时需要保存现有数据并避免数据丢失,这种情况下有很多种解决方案,铁电存储器(FRAM) 就是个很好的选择。FRAM是一种具有快速写入速度的非易失性存储器,既可以进行非易失性数据存储,又可以像RAM一样操作。

本文将借助飞凌嵌入式OK3568-C开发板来为大家介绍一种采用FRAM的方案——使用SPI0挂载PB85RS2MC (FRAM) 芯片。本文所描述的驱动文件和应用文件,可联系飞凌嵌入式的技术支持获取。

wKgaomUNLLWAGEVUAAswXLOa2P8057.png

修改思路——

我们要添加一个SPI设备,需要进行如下操作:在设备树中添加描述→设备树描述中对应设备驱动→设备驱动添加到内核。

修改结果——

修改 OK3568-linux-source/kernel/arch/arm64/boot/dts/rockchip/OK3568-C-common.dtsi

修改如下:

wKgZomUNLLSANdvaAABPzdVFgIY691.png

接下来笔者为大家介绍一下适配的过程。

1驱动程序

我们在menuconfig中搜索fm25、pb85等比较常用的FRAM字眼,发现并没有类似的驱动程序,这时就需要手写或者移植一个驱动程序。在搜遍各大网站之后找到了一个W25Q64的驱动,对比了一下PB85RS2MC的各种操作码以后,发现两者的操作码大差不差,因此就决定将W25Q64的驱动移植过来。根据PB85RS2MC芯片手册中叙述,各种操作码为:

wKgaomUNLLSALoEvAABtDv-Auc8420.pngwKgaomUNLLSAZXBHAACtEB3NdO8457.png

因此,在驱动程序中宏定义以下操作码,以便在接下来的驱动程序中使用:

wKgaomUNLLSAEDX6AABfbutbbhc581.png

首先要在驱动程序中进行初始化函数和退出函数,也就是spidev_init和spidev_exit,init函数里就是进行字符设备的初始化,注册等的操作,exit函数就是要把我们注册的东西在退出时都释放掉,再者就是驱动程序和设备树匹配,匹配是通过compatible属性值匹配的,这里我们一定要和设备树中的compatible属性值一致,否则会匹配不成功。驱动程序中.compatible值如下图所示。

wKgZomUNLLSADSg2AAAn3A8N7PU443.png

驱动和设备树匹配成功以后就要执行probe函数,这里probe函数执行了一些初始化和注册主次设备号的操作。我们可以通过是否打印spi_probesuccess!来判断驱动程序,是否和设备树匹配成功。

wKgaomUNLLWAE5y9AAEy-kKXQ6A161.png

从PB85RS2MC芯片手册中看读的条件,读取FRAM存储单元的数据,需要READ的操作码,任意24位地址输入到SI。第一个spi_transfer 结构体用于发送命令cmd 到SPI设备,在读取数据之前准备设备,第二个是发送地址到SPI设备,第三个是接收从设备读取的数据。

wKgZomUNLLWAW-zNAAEMDpORhwQ830.png

这段代码实现了从 SPI设备中同步读取数据,并将数据复制到用户空间的功能。

wKgZomUNLLWAdGWzAADO54z3BBY537.png

从PB85RS2MC芯片手册中看写的条件,WREN命令用于设置写使能锁存器。需要在写操作(WRITE命令)之前使用WREN命令设置写使能锁存器,WRITE命令将数据写入 FRAM存储单元阵列。WRITE操作码、任意24位地址和8位写入数据输入到 SI。

下面这段代码实现了向SPI设备发送写入使能命令的功能。

wKgZomUNLLaAZW4qAACHMMXcNdA300.png

这段代码实现了向SPI设备同步写入数据的功能。它先发送写入使能命令,然后发送地址信息和数据。

wKgZomUNLLaAV59NAAEcFHGFPcA629.png

下面这段代码向 SPI设备中同步写入数据的功能,将用户空间的数据复制到设备的发送缓冲区,并调用spidev_sync_write 函数将数据写入SPI 设备。

wKgaomUNLLWAKSgqAAC3OevAyvI947.png

2应用程序

向SPI设备写数据,调用lseek来改变写入数据的位置,这样就可以在整个SPI设备里写数据,如./writeframAPP /dev/pb85rs 0 forlinx

0是要写入的地址,forlinx是要写入的内容)。

wKgZomUNLLWAH16AAABAno9ueFo543.png

从SPI设备读数据,调用lseek来改变读取数据的位置,这样就可以在整个SPI设备里读数据,如./readframAPP /dev/pb85rs 0

0是要读取数据的地址)

wKgaomUNLLWAYI3SAACa-WUUmYY162.png

3实际测试

(1)首先将fram.ko,readframAPP, writefram APP拷贝到OK3568-C开发板的任意文件夹中。

wKgZomUNLLaAFlqKAAAHj-gd_2M770.png

(2)用insmod加载fram.ko模块,出现spi_probesuccess!说明驱动和设备树匹配成功。

wKgaomUNLLaAO9AAAAAQhaNT3o0389.png

(3)在/dev/下看有没有pb85rs设备。

wKgZomUNLLaAPZrEAABAHQ86q0g442.png

(4)使用./writeframAPP /dev/pb85rs 1500 forlinx

向设备写数据,1500是地址,forlinx是要写入的内容。

wKgaomUNLLaAaw_yAAAHhKDczY0550.png

(5)使用./readframAPP /dev/pb85rs 1500

1500是要读取数据的地址)

wKgaomUNLLaARx76AAAH51tqjbc199.png

4断电测试

断电一天后重新读取PB85RS2MC的数据,发现数据仍然存在。验证了PB85RS2MC铁电存储芯片的断电数据保留特性。

wKgaomUNLLaARky6AAAH3EAxK3A543.png

至此,我们就完成了在OK3568-C开发板上添加一个新的SPI铁电存储芯片的操作!

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

    关注

    452

    文章

    50117

    浏览量

    420318
  • SPI
    SPI
    +关注

    关注

    17

    文章

    1686

    浏览量

    91129
  • 嵌入式开发
    +关注

    关注

    18

    文章

    1013

    浏览量

    47452
  • fram
    +关注

    关注

    2

    文章

    279

    浏览量

    79335
  • RK3568
    +关注

    关注

    4

    文章

    484

    浏览量

    4866
收藏 人收藏

    评论

    相关推荐

    迅为RK3568驱动指南|如何在Linux中使用模拟SPI

    瑞芯微RK3568芯片是一款定位中高端的通用型SOC,采用22nm制程工艺,搭载一颗四核Cortex-A55处理器和MaliG522EE图形处理器。RK3568支持4K解码和1080P编码,支持
    的头像 发表于 08-01 13:37 1562次阅读
    迅为<b class='flag-5'>RK3568</b>驱动指南|如何在Linux中使用模拟<b class='flag-5'>SPI</b>

    RK3568开发板支持AMP双系统

    RK3568开发板支持AMP双系统
    的头像 发表于 06-04 15:33 584次阅读
    <b class='flag-5'>RK3568</b>开发板支持AMP双系统

    基于HD-RK3568-CORE设计的HD-RK3568-OPS主板上新!

    HD-RK3568-OPS主板基于HD-RK3568-CORE 工业级核心板设计,支持标准OPS接口,具有即插即用、操作简单的特点,适用于数字标牌、自助终端、教育一体机等应用场景。
    的头像 发表于 04-19 18:08 976次阅读
    基于HD-<b class='flag-5'>RK3568</b>-CORE设计的HD-<b class='flag-5'>RK3568</b>-OPS主板上新!

    rv1126和rk3568对比

    rv1126和rk3568对比: 瑞芯微智能视觉芯片RV1126是瑞芯微新一代智能视觉芯片,基于四核ARM Cortex-A7内核,内置2T算力 NPU,支持4K30FPS H.264/H.265
    的头像 发表于 01-23 18:05 1w次阅读
    rv1126和<b class='flag-5'>rk3568</b>对比

    RK3568-GDB程序调试方法说明

    RK3568-GDB程序调试方法说明
    的头像 发表于 01-19 16:16 1677次阅读
    <b class='flag-5'>RK3568</b>-GDB程序调试方法说明

    RK3568-MQTT通信协议案例

    RK3568-MQTT通信协议案例
    的头像 发表于 01-19 15:31 1680次阅读
    <b class='flag-5'>RK3568</b>-MQTT通信协议案例

    RK3568-IgH EtherCAT主站开发案例

    RK3568-IgH EtherCAT主站开发案例
    的头像 发表于 01-19 15:20 1600次阅读
    <b class='flag-5'>RK3568</b>-IgH EtherCAT主站开发案例

    RK3568--Acontis EtherCAT主站开发案例

    RK3568--Acontis EtherCAT主站开发案例
    的头像 发表于 01-19 14:59 708次阅读
    <b class='flag-5'>RK3568</b>--Acontis EtherCAT主站开发案例

    RK3568--系统启动阶段LOGO显示

    RK3568--系统启动阶段LOGO显示
    的头像 发表于 01-19 14:44 925次阅读
    <b class='flag-5'>RK3568</b>--系统启动阶段LOGO显示

    RK3568---NPU开发案例

    RK3568---NPU开发案例
    的头像 发表于 01-19 13:50 789次阅读
    <b class='flag-5'>RK3568</b>---NPU开发案例

    RK3568-ISP图像处理开发案例

    RK3568-ISP图像处理开发案例
    的头像 发表于 01-19 11:46 887次阅读
    <b class='flag-5'>RK3568</b>-ISP图像处理开发案例

    RK3568-ARM+FPGA通信案例开发手册 (一)

    RK3568-ARM+FPGA通信案例开发手册 (一)
    的头像 发表于 01-19 10:31 965次阅读
    <b class='flag-5'>RK3568</b>-ARM+FPGA通信案例开发手册 (一)

    RK3568--基于AMP的多通道AD采集开发案

    RK3568--基于AMP的多通道AD采集开发案
    的头像 发表于 01-19 10:03 847次阅读
    <b class='flag-5'>RK3568</b>--基于AMP的多通道AD采集开发案

    RK3568-视频开发案例

    RK3568-视频开发案例
    的头像 发表于 01-18 15:51 748次阅读
    <b class='flag-5'>RK3568</b>-视频开发案例

    rk3568和3588对比

    在现代高科技领域中,芯片的选择对于软件和硬件开发的成功至关重要。而在市场上最具影响力的芯片制造商之一,在旗下推出了RK3568和3588芯片。这两款
    的头像 发表于 12-27 15:57 1.2w次阅读