在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
芯片精品文章合集(500篇!)    创芯人才网--重磅上线啦!
查看: 1952|回复: 0

Flash ROM驱动示例

[复制链接]
发表于 2007-3-31 12:59:41 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
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
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条

小黑屋| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-5-19 06:47 , Processed in 0.029841 second(s), 10 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表