FlashROM驱动示例
Flash ROM驱动示例
Intel Flash芯片 i28f160,i28f320:
i28F320B: 64*64K,64个blocks,4M空间,每个block 64K,第一个64K由8个8*8K小blocks组成.
每个Black可以被独立擦写(寿命周期) 100,000次以上
Flash操作的大概步骤:
flash读写操作中,读应该很简单,和RAM一样,写就复杂一点.
Intel TE28F320C3的flash是4M空间
flash空间,划分成许多的block,Intel TE28F320C3的flash是4M空间,64个block,每个block由64K.
要对所有的block单独进行操作, 每个操作结束,都需要判断状态,
每个block操作的大概步骤如下:
1.unlock
2.erase
3.check empty
所有的block完成上述操作,且状态正确,才能进行下一步,写
4.write
ARM汇编程序
LDR r2, =FlashBase ;Flash起始地址
//第一步,UNLOCK的64个block,步骤和上边一样
MOV r1,#63 ;63x64k block 计数
01 LDRB r3, =X16_FLASH_COMMAND_CONFIG_SETUP
STRB r3, [r2] ;该block的首地址
LDRB r3, =X16_FLASH_COMMAND_UNLOCK_BLOCK
STRB r3, [r2] ;将Unlock命令写入
ADD r2, r2, #0x10000 ;64K
SUBS r1, r1, #1
BNE %b01
;Unlock OK ;Unlock 完成
//第二布,擦除blocks
LDR r0, =FlashBase
LDR r1,=63 ;擦除 63x64k block
01 LDR r3, =X16_FLASH_COMMAND_ERASE
LDR r2, =X16_FLASH_COMMAND_CONFIRM
ORR r3, r3, r2, LSL #16
STR r3, [r0]
LDR r3, =X16_FLASH_COMMAND_STATUS ;检查寄存器状态
STRB r3, [r0]
02 LDRB r3, [r0] ;读状态
TST r3, #X16_FLASH_STATUS_READY
BEQ %b02 ;若状态ready,执行下一个
TST r3, #X16_FLASH_STATUS_ERROR
BNE error_erase_block
ADD r0, r0, #0x10000
SUBS r1, r1, #1
BNE %b01
B EraseOK
error_erase_block
..............
;EraseOK ;擦除完成
//第三步,检查flash是否为空
;Check Flash Empty
LDR r4, =FlashBase
LDR r5, =0x100000 ;检查 1MB
LDR r0, =0xffffffff
loop_1
LDR r1, [r4]
CMP r1, r0 ;比较地址内容和0xffffffff
BNE empty_error
ADD r4, r4, #4
CMP r4, r5
BLO loop_1
B CheckOK
empty_error
.................
CheckOK
.................
;Check empty OK ;检查完成
//第四步,写flash
;Burn data to Flash ROM
LDR r6, =Length_Flash ;定义数据长度
LDR r0, =FlashBase
LDR r1, =BufferBase
MOV r9, #0
LDR r4,=0x10000000
LDR r7,=0xc0001000
STR r4, [r7]
LDR r1, [r1, r9]
03 LDR r3, =X16_FLASH_COMMAND_WRITE
STRB r3, [r0] ;把写命令放入Block首地址
LDR r3, =X16_FLASH_COMMAND_STATUS
LDR r2, [r7]
LDR r5, =0x0000ffff
AND r2, r2, r5
ORR r2, r2, r3, LSL #16
STR r2, [r0]
02 LDR r3, [r0] ;读状态寄存器状态
TST r3, #X16_FLASH_STATUS_READY
BEQ %b02 ;若状态ready,执行下一个
LDR r3, =X16_FLASH_COMMAND_WRITE
LDR r2, [r7]
LDR r5, =0xffff0000 ;
AND r2, r2, r5
ORR r3, r3, r2
STR r3, [r0]
LDR r3, =X16_FLASH_COMMAND_STATUS
STRB r3, [r0]
02 LDR r3, [r0] ; read status
TST r3, #X16_FLASH_STATUS_READY
BEQ %b02
LDR r4, =X16_FLASH_COMMAND_READ
STRB r4, [r0]
ADD r0, r0, #4
LDR r8, [r7]
ADD r8, r8,#1
STR r8, [r7]
ADD r8, r8, #4
writenext
SUBS r6, r6, #4 ;if no finished goto 03
BHI %b03
TST r3, #X16_FLASH_STATUS_ERROR
BNE error_write
LDR r3, =X16_FLASH_COMMAND_READ
STRB r3, [r0]
B BurnOK
error_write
..........
BurnOK
专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们
相关推荐
周立功的板子怎么样?请赐教
EEPW专访ERNI公司高管
用于医疗保健领域的ADI公司身体传感器和MEMS器件(上)
英飞凌推出先进的800V AI数据中心电源供电架构,实现更高效率与易用性
《嵌入式Linux驱动程序设计》讲课视频下载
SoC,尽在掌握!借PMIC赋能增效
《嵌入式Linux驱动程序设计》PDF课件下载(1)
《嵌入式Linux内核移植及驱动开发》视频下载
适用于隔离式ADC信号链解决方案的低EMI设计
Arm加入OCP董事会,推动开放融合型 AI 数据中心的标准制定
MAX4106/4107极低噪声运算放大器
生物医学传感与检测技术(下)
多款英特尔锐炫多卡方案上线,让全场景AI部署更高效
生物医学传感与检测技术(上)
《嵌入式Linux内核移植及驱动开发》PDF课件下载
尼得科家电产业事业本部的北京工厂提前五年实现“碳中和”
英飞凌推出专为PSOC™ Edge微控制器优化的DEEPCRAFT™ AI套件
三星Exynos 2600性能超越苹果
热烈庆祝CIRRUS ARM论坛开张
《嵌入式Linux驱动程序设计》PDF课件下载
由MAX4107构成的同相增益电路
寻找USB控制器代理商
英飞凌OPTIGA™ Trust M为Thistle Technologies的安全边缘AI解决方案提供支持
在S3C4510B上运行uClinux-2.6的过程(romfs直接链入image.ram)
由MAX4108/4109/4308/4309驱动大电容性负载放大电路
由MAX4104/4105/4304/4305构成的视频电缆驱动放大电路
用于医疗保健领域的ADI公司身体传感器和MEMS器件(下)
Supermicro推出数据中心建构组件解决方案的全新业务线
寻找USB控制器代理商
由MAX4106/4107构成的驱动电容性负载电路