摘要:JEDEC标准(JESD216)Serial Flash Discoverable Parameter (SFDP)[1]是在串行Flash中建立一个可供查询的描述串行Flash功能的参数表。文章主要介绍了这个串行Flash功能参数表的结构、功能和作用,并给出其在系统设计中的具体应用。
关键词:JEDEC JESD216;SFDP;串行Flash;SPI

1 串行Flash的基本介绍
    串行Flash是一种SPI接口的NOR Flash,属于非挥发性储存器件,主要被用来存放系统的启动程序。其特点是体积小、引脚少、接口简单和易于扩展。主要封装为8个引脚,有片选、数据输入、写保护、接地、数据输出、时钟、暂停和电压引脚,见图1。常用一进一出的串行数据传输方式,省去了并行Flash的大量数据线、地址线和控制线。有些串行Flash在封装引脚数目不变的情况下,通过引脚的功能复用,还可以支持四进四出的数据传输方式,极大地提升数据的输出速率。目前最大频率可以支持到104MHz以上,整体数据传输速率已经超过了一般并行Flash的数据传输速率。在主芯片功能和端口的支持下,串行Flash在一些系统应用中可替代并行Flash,不但可以减少系统印制电路板体积,而且可以减少系统的布线,增强了系统整体的电磁兼容性。从整体系统方案的角度来看,相比支持并行Flash的主芯片而言,只支持串行Flash的主芯片可以在存储端口的引脚数量上有大幅的减少,不仅有利于主芯片面积的缩减,对于整体的方案报价也非常有利。因此,串行Flash受到越来越多开发和设计人员的接受和青睐,也被广泛地应用在计算机、消费类电子、无线通讯、车载和工控等众多领域。

2 JESD216 SFDP标准产生的背景
    随着串行Flash市场不断的扩张,串行Flash的指令、功能和特性也日趋增多,而且各个厂商在串行Flash器件上的功能和特性也无法完全一致。例如,在扇区擦除功能上,支持4kB、32kB、64kB的擦除操作虽然分别有相应的指令,但是不同厂商的器件还是会存在一些指令和功能的差异。为了准确地完成系统的兼容性测试或者是考虑到容量的升级,开发和设计人员需要详细阅读每一份串行Flash的产品规范,了解引脚的分布和定义是否一致,操作所需要用到的功能指令是否完全兼容,从而对底层设备驱动软件做相应的增补和修改,甚至改动到硬件,这无疑给项目的设计、维护和更新带来一些不便。因此,串行Flash器件迫切需要一个统一规范的功能参数表,可以让开发和设计人员明确地读取到每一个所使用串行Flash的功能和参数特性。JEDEC的新规范JESD216 SFDP就是在这样的一个市场环境下孕育而生的。

3 JESD216 SFDP的功能和结构
    SFDP是JEDEC发布的JESD216的一个新标准,目前的版本号是V1.0,用来规范存放串行Flash相关信息的功能参数表。其实现方式是在串行Flash中内置一个可供查询的统一规范的功能参数表,不占用串行Flash正常的容量大小。目前SFDP支持的读取频率为50MHz以下,即尽管串行Flash可以支持更高的系统频率,但是系统主芯片只需要在50MHz及以下的频率下即可顺利读取到SFDP的资料。为进一步便于系统的灵活读取,该标准还支持串行Flash的一进一出、两进两和四进四出的数据传输方式。SFDP的数据在出厂时就被固定住,无法修改,只供查询使用。其作用有些类似于并行Flash中的公共闪存接口Common Flash Interface(CFI)的功能。开发和设计人员在通过0x5A的操作指令来读取查询SFDP时,可以将串行Flash包含其厂商识别码等一系列的功能和参数信息快速地呈现出来。这样不仅增加了器件本身的辨识度,提升了主芯片与串行Flash的沟通运作效能和便利性,也让开发和设计人员可以快速了解到不同串行Flash之间的特性和差异,从而在底层设备驱动软件上做出相应的调整,完成设计和兼容测试。
    在SFDP的功能和结构上,SFDP标准强制规范必须要有SFDP标题档、1st参数标题档和对应的JEDEC Flash基本参数表格,结构见图2。SFDP标题档主要设置了供开发和设计人员查询确认的签名信息0X50444653(“S”、“F”、“D”、“P”的ASCII码),在读取确认签名信息正确后,方可认为该串行Flash器件支持SFDP标准。在JEDEC Flash基本参数表格里面规范和定义了该器件的一些最基本的读取方式、指令内容、扇区大小和芯片容量等信息。其次,各家串行Flash厂商可以按照SFDP的规范依次增加2nd、3rd参数标题档以及对应的参数表来扩充一些参数特性,增强器件本体的参数识别度,结构见图3。在厂商标题档中,主要规范和预留了串行Flash的厂商ID识别号、SFDP版本号、参数长度以及存放参数表格的地址指针。其参数表格中则可以让厂商根据可以放入其器件的一些其它的参数信息如电压、特殊指令和功能支持的状况,也可以在读取中明确地显示出来,但不是SFDP标准所强制规范的,属于可选项。

4 在系统软件上读取SFDP的操作流程及代码
    系统对于串行Flash的任何操作,在软件上必须按照相应的指令和规范的流程才可以正确地操作串行Flash。读取SFDP也必须按照规定的操作流程。开启片选选通芯片——>发送0x5A的读取SFDP的指令——>发送3byte的地址——>发送1byte的空周期——>在输出脚上读取SFDP数据——>关闭片选结束操作。 通过一进一出方式读取SFDP数据的时序如图4所示。

SFDP参数表的部分软件读取代码参考如下:

JEDEC标准(JESD216)S FDP对串行Flash在系统中的应用的更多相关文章

  1. 第24章 SPI—读写串行FLASH—零死角玩转STM32-F429系列

    第24章     SPI—读写串行FLASH 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/ ...

  2. 第24章 QSPI—读写串行FLASH

    本章参考资料:<STM32F76xxx参考手册>.<STM32F76xxx规格书>.库帮助文档<STM32F779xx_User_Manual.chm>及<S ...

  3. 第25章 串行FLASH文件系统FatFs—零死角玩转STM32-F429系列

    第25章     串行FLASH文件系统FatFs 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.c ...

  4. 玩转X-CTR100 l STM32F4 l W25Q64 SPI串行FLASH存储

    我造轮子,你造车,创客一起造起来!塔克创新资讯[塔克社区 www.xtark.cn ][塔克博客 www.cnblogs.com/xtark/ ]      本文介绍X-CTR100控制器 板载FLA ...

  5. SPI—读写串行 FLASH

    SPI协议简介SPI 协议是由摩托罗拉公司提出的通讯协议(Serial Peripheral Interface),即串行外围设备接口,是一种高速全双工的通信总线.它被广泛地使用在 ADC. LCD ...

  6. 串行FLASH文件系统FatFs---转自野火论坛

    为了支持长文件名,需要用到FATFS源码中的cc936.c的两个函数ff_convert,ff_wtoupper:这里面直接用了两个大数组(127KB)来做unicode转gbk(OEM)的对照表,这 ...

  7. 第25章 串行FLASH文件系统FatFs

    25.1  文件系统 即使读者可能不了解文件系统,读者也一定对“文件”这个概念十分熟悉.数据在PC上是以文件的形式储存在磁盘中的,这些数据的形式一般为ASCII码或二进制形式.在上一章我们已经写好了Q ...

  8. 原创:应用串行NOR闪存提升内存处理能力

    在嵌入式系统中,NOR闪存一直以来仍然是较受青睐的非易失性内存,NOR器件的低延时特性可以接受代码执行和数据存储在一个单一的产品.虽然NAND记忆体已成为许多高密度应用的首选解决方案,但NOR仍然是低 ...

  9. 痞子衡嵌入式:导致串行NOR Flash在i.MXRT下无法正常下载/启动的常见因素之SFDP

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是导致串行NOR Flash在i.MXRT下无法正常下载/启动的常见因素之SFDP. i.MXRT系列MCU发布已两年多了,基于i.MXR ...

随机推荐

  1. 【转】关于大型网站技术演进的思考(二十一)--网站静态化处理—web前端优化—下【终篇】(13)

    本篇继续web前端优化的讨论,开始我先讲个我所知道的一个故事,有家大型的企业顺应时代发展的潮流开始投身于互联网行业了,它们为此专门设立了一个事业部,不过该企业把这个事业部里的人事成本,系统运维成本特别 ...

  2. 七牛云成功通过 CMMI3 认证

    10 月 31 日,在上海七牛信息技术有限公司青岛会议室举行的 CMMI3 级认证结果发布会上,主任评估师王庆付老师和评估组向公司高层及参与评审的 EPG 成员及项目组成员郑重宣布:经过严格的现场审核 ...

  3. [POJ1797] Heavy Transportation(最大生成树 || 最短路变形)

    传送门 1.最大生成树 可以求出最大生成树,其中权值最小的边即为答案. 2.最短路 只需改变spfa里面的松弛操作就可以求出答案. ——代码 #include <queue> #inclu ...

  4. (在线工具)JSON字符串转换成Java实体类(POJO)

    http://www.bejson.com/json2javapojo/ 付代码代码转换示例: public static FixMixedOrderResponse serialization(St ...

  5. 安装Android SDK(东软开源镜像介绍)

    启动 Android SDK Manager ,打开主界面,依次选择「Tools」.「Options...」,弹出『Android SDK Manager - Settings』窗口: 在『Andro ...

  6. Wannafly挑战赛2_D Delete(拓扑序+最短路+线段树)

    Wannafly挑战赛2_D Delete Problem : 给定一张n个点,m条边的带权有向无环图,同时给定起点S和终点T,一共有q个询问,每次询问删掉某个点和所有与它相连的边之后S到T的最短路, ...

  7. Python()- 面向对象三大特性----继承

    继承: 继承是一种创建新类的方式,在python中,新建的类可以继承一个或多个父类(基类或超类),新建的类是所继承的类的(派生类或子类) 人类和狗 有相同的属性, 提取了一个__init__方法,在这 ...

  8. 网络安全法与LogSec日志安全大数据审计平台

    https://blog.csdn.net/chengpeng1144/article/details/73555331 https://blog.csdn.net/dcbeyond/article/ ...

  9. Django学习之 - 基础ORM

    ORM操作参考: http://www.cnblogs.com/wupeiqi/articles/5246483.html 1:根据类自动创建数据库表,(类创建文件:models.py) 2:根据类对 ...

  10. zoj4027 Sequence Swapping

    首先容易想到二维方程dp(i,j),表示第i个左括号去匹配到第j个右括号时产生的最大值,但如果如此表示的话,首先需要枚举(i,j)以及一个k即dp(i-1,k). 考虑变化dp(i,j)的表示方法,可 ...