怎么通过verilog对spi flash读写

如题所述

最近在调试spi flash的擦写,问题是flash擦写uboot时,不成功。原来的uboot丢失。 测试发现是因为擦能成功,但是写时的地址不是secent大小,一个secent大小为64K. 看datasheet上说,擦的长度可以是page,secent或block,即4K,32K,64K. 我就用4K来擦除,但是不行。还是一样。 之后在网上看了看,貌似听说4K擦除的flash很少。我用的是mxic的flash。 就改为64K擦除。 出现只能写一次,第二次写就会失败。 原因一直不明白。 最后也不知道动了什么地方造成其好了。 动的地方为: 改spi mode3为mode0. 改spi clk从1M到2M.最大支持50M 改bootload的引导,从0x8400到0x10000. 改擦写大小为0x80000。 写了五六次,没啥事。 什么原因也懒的查了。 应该是flash未写数据时,可以写数据,但写了数据之后,一定要先擦除再写数据才行。应该是这个原因造成只能擦一次。
温馨提示:答案为网友推荐,仅供参考
相似回答