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