CFI(Common Flash Interface)简介

        CFI定义了符合CFI规则设备的基本Query接口,包括已知或待拟定的flash Read/Write/Program/Erase控制接口。Query接口以结构体形式定义与flash设备相关的关键参数,但是CFI不会对单个flash设备厂家指定详细的指令集、状态轮询模式以及软件算法。

1.操作概要

设备接收到Query command code后进入Query模式,允许对CFI Query数据结构进行访问。CFI Query data structure包含16bit指令集、Control Interface ID code(控制接口)、通用flash内存参数和算法指定的数据域。

上述信息主要用于给指定的flash提供读写、擦除等操作。

2. 硬件接口

2.1 Query command interface

        CFI Query结构的访问与NVM现有的”ID Mode”或”JEDEC ID”访问类似,但是使用不同的指令代码。Query 访问指令为98h,JEDEC ID 模式访问为90h。

        上电后,假设NvM处于制度模式,Query 结构的内容必须能够在单个系统写周期的特定地址位置读取:1)98h被写入到设备地址空间内55h的地址位置(以最大设备总线宽度),2)设备处于任何有效的读状态,如“读阵列”或“读ID数据”。其他设备状态可能存在于一长串命令或数据输入中;在编写98h Query命令代码产生有效的Query数据结构输出之前,必须先完成或终止这些序列。

        设备驱动程序应该始终在地址总线上提供55h,在数据总线上提供98h以进入查询模式;或者Flash设备可以选择忽略地址总线并进入查询模式,如果98h只在数据总线上看到。

        Flash供应商必须为其他模式访问定义其他命令序列。

2.2 Query structure output

        Query 数据只在数据输出(D7 - D0)上显示。

        因此,对于字节宽(x8)设备,Query结构的前两个字节,即ASCII中的“Q”和“R”,出现在设备地址10h和11h处,这与绝对字节地址相同。相同逻辑应用到x16、x32设备。下表Query数据输出的示例:

3 Query Structure

3.1 Query结构总览

Offset

Section名称

描述

00h

Reserved

指令算法信息

10h

CFI Query Identification

命令集ID和算法数据偏移量

1Bh

System Interface Information

设备时间、电压信息

27h

Device Geomerty Definition

Flash设备的layout

P

主算法的特定扩展

主算法的特定扩展

A

选算法的特定扩展

选算法的特定扩展

3.2 CFI Query Identification

Offset

Length

(bytes)

Description

10h

03h

三字节的“QRY”查询结构标记

13h

02h

两字节的主算法命令集和控制接口ID码

15h

02h

Value=P

主算法扩展表的地址P

17h

02h

备选算法命令集和控制接口ID码

19h

02h

Value=A

备选算法扩展表的地址A

3.3 System Interface Information

Offset

Length(Bytes)

含义

举例(Intel 28 F800BVT)

10H

03H

查询ASCII字符串“QRY”

10:0051H ‘Q’

11:0052H ‘R’

12:0059H ‘Y’

13H

02H

制造商命令集和控制接口识别码ID

13:0003H

14:0000H

1BH

01H

逻辑供电Vcc最小电压。位7-4:BCD伏 位3-0:BCD100毫伏

1B:0030H(3伏)

1CH

01H

逻辑供电Vcc最大电压。位7-4:BCD伏 位3-0:BCD100毫伏

1C:0055H(5.5伏)

1DH

01H

编程/擦除供电Vpp最小电压。位7-4:HEX伏 位3-0:BCD100毫伏

1D:0045H(4.5伏)

1EH

01H

编程/擦除供电Vpp最大电压。位7-4:HEX伏 位3-0:BCD100毫伏

1E:00C6H(12.6伏)

1FH

01H

典型单字节/字写周期定时时间,2Nus

1F:0003H(3.8us)

21H

01H

典型单块擦除定时时间,2Nms

21:000AH(1.024s)

22H

01H

典型整片擦除定时时间,2Nms

22:0000H(不支持)

23H

01H

单字节/字写周期最大定时时间,2Nx典型单字节/字写周期定时时间

23:0004H(24x8us)

25H

01H

单块擦除最大定时时间,2Nx典型单块擦除定时时间

25:0004H(24x1.024s)

26H

01H

整片擦除最大定时时间,2Nx典型整片擦除定时时间

26:0000H(不支持)

3.4 Device geometry definition

Offset

Length(Bytes)

含义

举例(Intel 28 F800BVT)

28H

02H

Flash器件接口识别码ID

28:0002H  29:0000H

2CH

01H

器件可擦除块区域个数。Bit7-0=可擦除块个数

2C:0004H  4个擦除块

2DH

04H

擦除块信息域1。Bit31-16=z(高两字节表示擦除块大小对于256字节的倍数,0表示128B)。Bit15-0=y(低两字节+1表示擦除块的个数,0表示没有块)

2D:0006H  2E:0000H

7个擦除块

2F:0000H   30:0002H

256x200H=128K字节

31H

04H

擦除块信息域2。

31:0000H  32:0000H

33:0080H  34:0001H

35H

04H

擦除块信息域3。

35:0001H  36:0000H

37:0020H  38:0001H

39H

04H

擦除块信息域4。

39:0000H  3A:0000H

3B:0040H  3C:0000H

3.5 主算法的特定扩展

如下表所示:

Offset

Length

(bytes)

Description

Ph

03h

主算法扩展查询表标记字符串“PRI”

(P+3)h

01h

主版本号

(P+4)h

01h

次版本号

(P+5)h

Variable

主算法扩展查询结构内容

3.6 备用算法的特定扩展

如下表所示

Offset

Length

(bytes)

Description

Ah

03h

备用算法扩展查询表标记字符串“ALT”

(A+3)h

01h

主版本号

(A+4)h

01h

次版本号

(A+5)h

Variable

备用算法扩展查询结构内容

4. CFI代码示例

        

Std_ReturnType Fls_HwCfiQuery(uint32 CfiBaseAddr,uint8 CfiCmd, _CfiValueType *CfiValueBuf)
{
    Std_ReturnType retVal = E_NOT_OK;
    uint16 i=0;

    /* #10 Handle CFI query cmd */
    Fls_lCmdProcessing((_FLS_CFI_BASE_ADDRESS + CfiBaseAddr),CfiCmd);
    /* #20  Check that the CFI interface is operable */
    if ((Fls_lCfiReadValue(_FLS_CFI_BASE_ADDRESS + _FLS_CFI_QUERY_OFFSET_ONE)   != 0x51U)
      ||(Fls_lCfiReadValue(_FLS_CFI_BASE_ADDRESS + _FLS_CFI_QUERY_OFFSET_TWO)   != 0x52U)
      ||(Fls_lCfiReadValue(_FLS_CFI_BASE_ADDRESS + _FLS_CFI_QUERY_OFFSET_THREE) != 0x59U))
    {
        retVal = E_NOT_OK;
    }
    else
    {
         /* #30: Read the required CFI Info */
        for(i = 0; i < 256; i++)
        {
            CfiValueBuf[i] = Fls_lCfiReadValue(_FLS_CFI_BASE_ADDRESS + (uint32)i);
        }
        retVal = E_OK;
    }
    return retVal;

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/157896.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

电子商务税收问题:跨境电商的挑战与解决

随着电子商务的崛起&#xff0c;跨境电商已经成为全球贸易的主要动力之一。然而&#xff0c;电子商务的快速发展也带来了一系列税收问题&#xff0c;尤其是涉及跨境交易的税收问题。本文将深入探讨跨境电商所面临的税收挑战&#xff0c;以及政府和国际组织正在采取的解决方案。…

开源与闭源:驾驭大模型未来的关键决断

在数字化的时代洪流中&#xff0c;开源与闭源的选择不断成为技术界的重要分水岭。随着特斯拉CEO埃隆马斯克的言论及其决策&#xff0c;公开支持开源&#xff0c;并糅合商业理念与技术革新&#xff0c;使得这场辩论再次成为公众关注的焦点。那么&#xff0c;在这场关乎技术发展脉…

Java和JavaScript是一样的技术吗?

目录 一、Java 是什么 二、JavaScript 是什么 三、Java 和 JavaScript 的区别 一、Java 是什么 Java是一种广泛使用的计算机编程语言&#xff0c;最初由Sun Microsystems&#xff08;后被Oracle收购&#xff09;于1995年发布。Java是一种面向对象的语言&#xff0c;设计初衷…

STM32定时器实现毫秒/秒级任务框架

STM32定时器实现毫秒/秒级任务框架 CubeMX配置代码分享总结 这是一期代码思路分&#xff0c;通过定时器&#xff08;以定时器10为例&#xff09;实现规定时间间隔执行指定任务。。。。。。 CubeMX配置 关于定时器的配置&#xff0c;这里不做介绍&#xff0c;不懂的可以看&#…

【小收获】数组在声明时整体赋值的细节

在C中&#xff0c;在全局区声明的数组会自动初始化 如果没有为全局区的整数类型的数组指定初始值&#xff0c;那么它的元素都会被自动初始化为0。该特性适用于所有整数类型的数组&#xff0c;包括char、short、int、long等。&#xff08;注:char类型数组自动初始化为0&#xff…

漏电继电器 JELR-(120)FG AC220V 零序电流互感器 孔径φ45 上海约瑟

JELR-FG系列漏电继电器 JELR-15FG漏电继电器&#xff1b; JELR-25FG漏电继电器&#xff1b; JELR-32FG漏电继电器&#xff1b; JELR-63FG漏电继电器&#xff1b; JELR-100FG漏电继电器; JELR-120FG漏电继电器&#xff1b; JELR-160FG漏电继电器&#xff1b; JELR-200FG…

在已安装Anaconda环境下配置沐神(李沐老师)动手学深度学习环境

沐神配置环境视频 B站李沐老师动手学深度学习环境配置视频 在windows中配置沐神深度学习环境 前提&#xff1a;安装了Anaconda基本环境&#xff0c;了解Jupyter NoteBook 1.打开 Anaconda Prompt 2.创建虚拟环境 create conda -n d2l-zh python3.8 pip3.激活虚拟环境 con…

canal1.1.7实战

1.环境搭建 canal可以用来监听mysql数据库的变化&#xff0c;用来同步数据 先下载最新的部署版本&#xff0c;release地址:Releases alibaba/canal GitHub 包下载地址: https://github.com/alibaba/canal/releases/download/canal-1.1.7/canal.deployer-1.1.7.tar.gz 下载…

《Effective C++》条款20

宁以pass-by-reference-to-const替换pass-by-value class A { public:A() {cout << "A()" << endl;}A(const A& a){cout << "A(const A& a)" << endl;}~A(){cout << "~A()" << endl;} private:stri…

如何选择数据恢复软件?前 5 名免费数据恢复软件榜单供参考

我们都知道开源数据恢复软件有很多优点。搜索免费解决方案的用户会被其可用性所吸引&#xff0c;而那些拥有足够技术技能的用户可能会被其定制软件以满足其需求的灵活性所吸引。在本文中&#xff0c;我们为您挑选了最好的开源数据恢复软件&#xff0c;并将尝试回答开源软件是否…

基于SpringBoot的SSMP整合案例(在Linux中发布项目的注意事项与具体步骤步骤)

前言与注意 这几天在Linux中上线之前的小项目时&#xff0c;遇到了很多的问题&#xff0c;Linux镜像的选择&#xff0c;jdk&#xff0c; mysql在linux中的下载&#xff0c;使用finallshell连接linux&#xff0c;使用tomcat连接linux中的数据库........ 在下面的注意事项中我会将…

C#学习相关系列之Linq常用方法---排序(一)

一、构建数据 public class Student_1{public int ID { get; set; }public string Name { get; set; }public int Chinese { get; set; }public int Math { get; set; }public int English { get; set; }public override string ToString(){return string.Format("ID:{0},…

PostgreSQL按月计算每天值的累加

要按月计算每天值的累加&#xff0c;您可以使用PostgreSQL中的日期函数和窗口函数。下面是一个示例查询&#xff0c;假设您有一个名为"table_name"的表&#xff0c;其中包含一个日期列"date_column"和一个数值列"value_column"&#xff1a; SELE…

FindMy技术用于保温杯

在即将到来的冬季&#xff0c;每个人都开始给自己准备一个保温杯&#xff0c;保温杯是一种盛水的容器&#xff0c;主要由陶瓷或不锈钢制成&#xff0c;并加入真空层&#xff0c;以实现保温效果。这种杯子顶部有盖&#xff0c;密封严实&#xff0c;能够延缓内部液体散热&#xf…

Taro编译警告解决方案:Error: chunk common [mini-css-extract-plugin]

文章目录 1. 背景2. 问题分析3. 解决方案3.1 更新 Taro 版本3.2 更新相关依赖3.3 调整 webpack 配置3.4 检查依赖版本 4. 拓展与分析4.1 拓展4.2 避免不必要的依赖4.3 查阅 Taro GitHub 仓库 5. 总结 &#x1f389;欢迎来到Java学习路线专栏~Taro编译警告解决方案&#xff1a;E…

59 权限提升-Win溢出漏洞及ATSCPS提权

目录 知识点必备&#xff1a;windows权限认识(用户及用户组)0x01 普通权限0x02特殊权限 演示案例:基于WEB环境下的权限提升-阿里云靶机基于本地环境下的权限提升-系统溢出漏洞基于本地环境下的权限提升-AT&SC&PS命令 案例给到的思路点总结如下:涉及资源: 这个章节会讲到…

【论文解读】CP-SLAM: Collaborative Neural Point-based SLAM System_神经点云协同SLAM系统(上)

目录 1 Abstract 2 Related Work 2.1 单一智能体视觉SLAM&#xff08;Single-agent Visual SLAM&#xff09; 2.2 协同视觉SLAM&#xff08;Collaborative Visual SLAM&#xff09; 2.3 神经隐式表示&#xff08;Neural Implicit Representation&#xff09; 3 Method 3.…

这款IDEA插件真的爱了

IDEA是一款功能强大的集成开发环境&#xff08;IDE&#xff09;&#xff0c;它可以帮助开发人员更加高效地编写、调试和部署软件应用程序。我们在编写完接口代码后需要进行接口调试等操作&#xff0c;一般需要打开额外的调试工具。 今天给大家介绍一款IDEA插件&#xff1a;Api…