登录 免费注册 首页 | 行业黑名单 | 帮助
维库电子市场网
技术交流 | 电路欣赏 | 工控天地 | 数字广电 | 通信技术 | 电源技术 | 测控之家 | EMC技术 | ARM技术 | EDA技术 | PCB技术 | 嵌入式系统
驱动编程 | 集成电路 | 器件替换 | 模拟技术 | 新手园地 | 单 片 机 | DSP技术 | MCU技术 | IC 设计 | IC 产业 | CAN-bus/DeviceNe

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 TE28F320C3FLASH是4M空间
FLASH空间,划分成许多的block,INTEL TE28F320C3FLASH是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, =FLASH

参与讨论
昵称:
讨论内容:
 
 
相关帖子
高手来看看
我设计的-12v开关电源,有点小问题,请高手指导一下
诺基亚8210手机旅行充电器电路
菜鸟求用液晶模块显示的脉冲计数器的电路设计思路和图...
请问电视机同频信号原理是怎样
免费注册为维库电子开发网会员,参与电子工程师社区讨论,点此进入


Copyright © 1998-2006 www.dzsc.com 浙ICP证030469号