Lattice FPGA flash写保护解除

实验背景
https://blog.youkuaiyun.com/sinat_25428663/article/details/143027011?spm=1001.2014.3001.5501分享中说到,当前板子是无法下载程序到片外flash的。本次分享介绍解除flash芯片的写保护。
实验目的
解除板子上flash芯片的写保护。
实验步骤
板子上用到的flash型号如下:
在这里插入图片描述
flash芯片有对应的状态寄存器(status register)来说明当前该芯片的一些设置和状态。
在这里插入图片描述
其中BP4-BP0和CMP共同决定flash芯片哪些block被保护。如下表
在这里插入图片描述
首先我们来读取状态寄存器,来确认flash的哪些block被设置了保护,读状态寄存器的指令如下:
在这里插入图片描述
在这里插入图片描述
读取的状态寄存器的值如下:
S15-S8
在这里插入图片描述
S7-S0
在这里插入图片描述
可以知道CMP的值为0,BP4-BP0的值为5’b01010,则如下的flash block被设置了写保护:
在这里插入图片描述
解除写保护的方法就是重写状态寄存器,将BP4-BP0的值写为5’b00000。写状态寄存器的指令如下:
在这里插入图片描述
这里需要注意的是,在写状态寄存器指令(WRSR)执行之前,需要执行写使能(WREN)指令。
写状态寄存器之后,再读取状态寄存器,如下:
在这里插入图片描述
可以看到BP4-BP0的值已经被成功设置为5’b00000, 说明所有的flash block的写保护都被解除了。测试一下,固化一个程序到片外flash,固化成功,打印信息如下:
在这里插入图片描述
至此,解除板子上flash芯片写保护的内容介绍完毕。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值