SPI FLASH学习笔记(二) 写操作

写操作

PAGE PROGRAM操作序列对页面内1字节至2176字节的数据进行编程。写页面
顺序如下:
•02H(写加载)/ 32H(写负载x4)
•06H(写允许)
•10H(执行写)
•0FH(读取命令状态)
首先,发出PROGRAM LOAD(02H / 32H)命令。程序加载由8位操作码组成,后跟4虚拟位和12位列地址,然后是要编程的数据字节。数据字节被加载到缓存中长度为2176字节的寄存器。如果加载了超过2176个字节,则高速缓存将忽略这些额外的字节寄存器。当CS#从LOW变为HIGH时,命令序列结束。图10-1显示了程序加载操作。其次,在执行PROGRAM EXECUTE操作之前,必须先执行WRITE ENABLE(06H)命令发行。与更改存储器内容的任何命令一样,必须执行WRITE ENABLE才能将WEL位置1。如果未发出此命令,则将忽略其余程序序列。

注意:
1.当写加载(02h)命令,写随机加载(84h)命令时,缓存寄存器的内容不会重置命令和RESET(FFh)命令。
2.当在烈军属加载(02h)命令之后发出了程序执行(10h)命令时,SPI-NAND控制器将0xFF数据输出到NAND,以获取程序加载(02h)命令未加载数据的地址。
3.在“程序加载随机数据(84h)”命令之后立即发出“写执行(10h)”命令时,SPI-NAND控制器将缓存寄存器的内容输出到NAND。
4.寻址应按顺序在一个块中完成。

Program Load (PL) (02H)

注意:当内部ECC禁用时,数据字节为2176,当内部ECC启用时,数据字节为2112。

Program Load x4 (PL x4) (32H)

Program Load x4命令(32H)与Program Load命令(02H)类似,但具有输入数据字节由四个引脚组成:SIO0,SIO1,SIO2和SIO3。 命令序列如下所示。 四通道使能位(QE)
必须设置功能(B0 [0])的最大值以启用写加载x4命令。

 

 

注意:当内部ECC禁用时,数据字节为2176,当内部ECC启用时,数据字节为2112。

Program Execute (PE) (10H) 

加载数据后,必须发出PROGRAM EXECUTE(10H)命令以启动从PC的数据传输。缓存寄存器到主数组。 写执行命令由8位操作码和24位地址组成。 后页面/块地址被注册,存储设备开始从高速缓存寄存器到主阵列的传输,并且忙了tPROG时间。 该操作如图10-3所示。 在这个繁忙的时间里,状态寄存器可以被轮询到监视操作状态(请参阅状态寄存器)。 操作成功完成后,下一个系列数据可以使用PROGRAM LOAD命令加载。

 

 Internal Data Move

INTERNAL DATA MOVE命令序列编程或用现有数据替换页面中的数据。 INTERNAL DATA MOVE命令序列如下:
  •13H(页面读取以缓存)
  •可选的84H / C4H / 34H(程序加载随机数据)
  •06H(写使能)
  •10H(程序执行)
  •0FH(获取功能命令以读取状态)
在执行内部数据移动操作之前,必须通过以下方式将目标页面内容读入高速缓存寄存器:发出PAGE READ(13H)命令。 PROGRAM LOAD RANDOM DATA命令可以是(84H / C4H / 72H)如果用户要更新页面中的数据字节,则发出此消息。 新数据将加载到12位列地址中。 如果随机如果数据不是顺序的,则必须使用以下命令发出另一个PROGRAM LOAD RANDOM DATA(84H / C4H / 72H)命令新列地址。 加载数据后,必须发出WRITE ENABLE命令,然后发出PROGRAM可以发出EXECUTE(10H)命令开始编程操作。

Program Load Random Data(84H)

该命令由一个8位的操作码,后面的4个虚拟位和一个12位的列地址组成。 新数据已加载12位提供的列地址。 如果随机数据不是顺序数据,则另一个程序加载必须使用新的列地址发出RANDOM DATA(84H)命令,有关详细信息,请参见图10-4。 该命令是仅在内部数据移动序列期间可用。

 

注意:当内部ECC禁用时,数据字节为2176,当内部ECC启用时,数据字节为2112。

Program Load Random Data x4 (C4H/34H)

程序加载随机数据x4命令(C4H / 34H)与程序加载随机数据命令(84H)类似但具有通过四个引脚输入数据字节的功能:SIO0,SIO1,SIO2和SIO3。 显示命令顺序下面。 必须将功能(B0 [0])的四元使能位(QE)设置为启用,以允许程序加载随机数据x4命令。有关详细信息,请参见图10-5。 这两个命令仅在内部数据移动序列期间可用。

 

注意:当内部ECC禁用时,数据字节为2176,当内部ECC启用时,数据字节为2112。

Program Load Random Data Quad IO (72H) 

程序加载随机数据四线IO命令(72H)与程序加载随机数据x4命令相似(C4H),但具有通过四个引脚(SIO0,SIO1,SIO2和SPIN)输入4个虚拟位和12位列地址的功能。
SIO3。 命令序列如下所示。 必须将功能(B0 [0])的Quad Enable位(QE)设置为启用程序加载随机数据x4命令。 有关详细信息,请参见图10-6。 该命令仅在内部数据期间可用
移动顺序。

 

 注意:当内部ECC禁用时,数据字节为2176,当内部ECC启用时,数据字节为2112。

 

原文地址:https://www.cnblogs.com/xgj-0817/p/14061779.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


  译序:JWMediaPlayer是开源的网页使用的Flash播放器。本文采摘于JWPlayer的官方文档,讲解了JWPlayer对于RTMP的使用方法,我们可以从JWPlayer客户端的角度来了解RTMP协议。以下是官方原文:      简介    RTMP(RealTimeMessagingProtocol
    Flash编程原理都是只能将1写为0,而不能将0写成1.所以在Flash编程之前,必须将对应的块擦除,而擦除的过程就是将所有位都写为1的过程,块内的所有字节变为0xFF.因此可以说,编程是将相应位写0的过程,而擦除是将相应位写1的过程,两者的执行过程完全相反.一、Nor和NandFlash
 上传setenvgatewayip192.168.1.1;setenvserverip192.168.1.7;setenvipaddr192.168.1.156;mw.b0x820000000xff0x1000000sfprobe0sfread0x8200000000x1000000tftp0x82000000test.bin0x1000000 下载mw.b82000000ff1000000tftp82000000test.bi
Error:FlashDownloadFailed-"Cortex-M3"出现一般有两种情况:1.SWD模式下,Debug菜单中,Reset菜单选项(Autodetect/HWreset/sysresetReq/Vectreset)默认是AutoDetect,改成SysResetReq即可。2.Jtag模式下,主要是芯片大小选错。Flash->ConfigureFalshTools配置窗口,切换到“Utilities"
jPlayer是一个用于控制和播放mp3文件的jQuery插件。它在后台使用Flash来播放mp3文件,前台播放器外观完全可以使用XHML/CSS自定义。支持:有一点比较好的是,在支持html5的浏览器上会使用html5的标签audio或者video,而不支持的浏览器上使用swf来播放选择需要播放的Mp3文件。播放、暂停
#ifndef__FONTUPD_H__#define__FONTUPD_H__#include"sys.h" //字库信息结构体定义33字节__packedtypedefstruct{u8fontok;//字库存在标志,0XAA,字库正常;其他,字库不存在u32ugbkaddr;//unigbk的地址u32ugbksize;//unigbk的大小u32f12addr;//gbk12地址u32g
ROM(ReadOnlyMemory)和RAM(RandomAccessMemory)指的都是半导体存储器。ROM在系统停止供电的时候仍然可以保持数据,而RAM通常都是在掉电之后就丢失数据,但是访问速度快。典型的RAM就是计算机的内存。RAM有两大类,一种称为静态RAM(StaticRAM/SRAM),SRAM速度非常快,是目前读写最快的存储
JSpc端和移动端实现复制到剪贴板功能实现在网页上复制文本到剪切板,一般是使用JS+Flash结合的方法,网上有很多相关文章介绍。随着HTML5技术的发展,Flash已经在很多场合不适用了,甚至被屏蔽。本文介绍的一款JS插件,实现了纯JS方法复制文本到剪切板。插件名是Clipboard.js,该插件不依
例子:R0=1R1=1R2=10R3=e000ed10R12=0LR=fffffff9(中断返回值)PC=0PSR=60000013或60000016或60000036(Z、C、EXCEPT_NUM:RTC_WKUP_IRQn、EXTI0_IRQn、USART2_IRQn)BFAR=e000ed38(不关心)CFSR=20000(INVSTATE:Invalidstateusagefault thePCvaluestackedf
 内存接口概念首先来分析下操作GPIO控制器和操作UART控制器两者的区别如图是S3C2440是个片上系统,有GPIO控制器(接有GPIO管脚),有串口控制器(接有TXDRXD引脚)配置GPIO控制器相应的寄存器,即可让引脚输出高低电平;配置UART控制器相应的寄存器,即可让引脚输出波形。前者相对简单,类
小编导语:    近几年来,网页游戏成为了游戏界关注的焦点,由于其制作简单,成本低并且收益率较高,因此成为了众多游戏厂商追逐的对象,但是除了商家夸张的炒作宣传外,很少有页游佳作出现。然而,随着Unity3D游戏引擎的出现,网页游戏的3D化成了页游冲出重围的杀手锏,那么在flash网页游戏称
1.指定数组到特定的Flash单元#pragmalocation=0x000FFF00 __rootconstcharFlash_config[]={0x0,0x1,0x2,0x3,0x4,0x5,0x6,0x7,0x8,0x9,0xA,0xB,0xC,0xD,0xE,0xF,0x10,0x11,0x12,0x13,0x14,0x15,0x16,0x17,0x18,0x19,0x1A,0x1B,0x1C,0x1D,0x1E,0x1F,0x20,0x21,0x22,0x23,0
继续研究发现,计算机的固件真的很有趣。参考了一些重要的资料,比如http://donovan6000.blogspot.com/2013/06/insyde-bios-modding-advanced-and-power-tabs.html等,对于IDA的使用也了解了一些。最后,总结一下目前看来可行性的方案:0.基础知识储备,包括UEFIBIOS的概念,InsydeBIOS的
<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>navigator对象<itle></head><body><buttononclick="checkFlash()">检测</button>
修改网上流传的flash-marker.js(function(global,factory){typeofexports==='object'&&typeofmodule!=='undefined'?module.exports=factory():typeofdefine==='function'&&define.amd?define(factory
shareObject本地缓存存储位置:win7系统用户到C:\Users\[你的用户名]\AppData\Roaming\Macromedia\FlashPlayer\#SharedObjects\XP或2003用户到:C:\DocumentsandSettings\用户名\ApplicationData\Macromedia\FlashPlayer\#SharedObjects\ ---------------------作者:iteye_
安装谷歌浏览器之后经常遇到Flash崩溃或者浏览器在浏览Flash内容时卡死的情况。在网上查找资料大多都认为应该是浏览器自带的Flash插件工作模式引起的问题,解决方法如下:首先在地址栏输入chrome://plugins/显示浏览器使用的插件。点击右上角的详细信息,可以看到Flash插件为进程外
之前一直使用的W25Q16spiflash都没问题,换了一款W25Q80后发现工作不正常,经过测试,初步定位到问题在于初始化SPI后是否将CS拉高。于是又去查看了一下原厂代码:发现原厂的代码初始化SPI接口时是专门拉高CS的。结论:网上很多代码初始化SPI接口时没有专门拉高CS,对某些型号可能确实
======================================================NANDFlash最小存储单元:写数据操作:通过对控制闸(ControlGate)施加高电压,然后允许源极(SOURCE)和汲极(RRAIN)间的N信道(N-Channel)流入电子,等到电流够强,电子获得足够能量时,便会越过浮置闸(FloatingGate)底下的二氧化硅层(S
安装CnarioPlayer3.8.1.156或其他版本时,有时会出现如下提示:Warning4154.AdobeFlashPlayer13...notcorrectlyinstalled:请前往AdobeFlash网站,并选择下图示的版本下载安装: