zoukankan      html  css  js  c++  java
  • NOR FLASH驱动程序

       NOR                                              NAND
    接口:    RAM-Like,引脚多                 引脚少,复用
    容量:  小 1M 2M 3M                   大:128M 256M G
    读:        简单                                   复杂
    写:        发出特定命令 慢                 发出特定命令 快
    价格:    贵                                         便宜
    特点:    无位反转、坏块                 位反转、坏块                                              
                    关键重要的程序                 大数据、容忍可以出错的程序
    xip            可以                                     不可以
    (execute in place)
    -----------------------------------------------------------
    (555<<1)                    (555)
    ---------              ---------           
    |       A1|---------|A0       |
    |       A2|---------|A1       |
    |       A3|---------|A2       |
    |         ..|---------|...       |
    ---------              ---------
    2440                            NOR


    使用UBOOT体验NOR FLASH的操作(开发板设为NOR启动,进入UBOOT)
    先使用OpenJTAG烧写UBOOT到NOR FLASH

    1. 读数据
    md.b 0 

    2. 读ID
    NOR手册上:
    往地址555H写AAH
    往地址2AAH写55H
    往地址555H写90H
    读0地址得到厂家ID: C2H
    读1地址得到设备ID: 22DAH或225BH
    退出读ID状态: 给任意地址写F0H

    2440的A1接到NOR的A0,所以2440发出(555h<<1), NOR才能收到555h这个地址
    UBOOT怎么操作?
                                                                                 (mw.w 是写,md.w是读,w:word 一个字,两个字节)
    往地址AAAH写AAH                            mw.w  aaa   aa
    往地址554写55H                               mw.w   554   55        //解锁
    往地址AAAH写90H                             mw.w  aaa   90         //写命令
    读0地址得到厂家ID: C2H                      md.w   0     1            (1表示读一次)
    读2地址得到设备ID: 22DAH或225BH      md.w   2   1
    退出读ID状态:                        mw.w 0 f0

    3. NOR有两种规范, jedec, cfi(common flash interface)
       读取CFI信息

    NOR手册:   
    进入CFI模式    往55H写入98H
    读数据:        读10H得到0051
                   读11H得到0052
                   读12H得到0059
                   读27H得到容量

    2440的A1接到NOR的A0,所以2440发出(555h<<1), NOR才能收到555h这个地址
    UBOOT怎么操作?
    进入CFI模式    往AAH写入98H            mw.w  aa  98      (AAH 是55H<<1 得到的 )
    读数据:        读20H得到0051             md.w  20   1
                   读22H得到0052                md.w  22  1
                   读24H得到0059               md.w  24  1
                   读4EH得到容量                md.w  4e  1
                   退出CFI模式                    mw.w  0  f0

    4. 写数据: 在地址0x100000写入0x1234
    md.w 100000 1     // 得到ffff
    mw.w 100000 1234
    md.w 100000 1     // 还是ffff

    NOR手册:
    往地址555H写AAH 
    往地址2AAH写55H 
    往地址555H写A0H 
    往地址PA写PD

    2440的A1接到NOR的A0,所以2440发出(555h<<1), NOR才能收到555h这个地址
    UBOOT怎么操作?
    往地址AAAH写AAH               mw.w aaa aa
    往地址554H写55H               mw.w 554 55
    往地址AAAH写A0H               mw.w aaa a0
    往地址0x100000写1234h         mw.w 100000 1234




    NOR FLASH驱动程序框架


    测试1:通过配置内核支持NOR FLASH
    1. make menuconfig
    -> Device Drivers
      -> Memory Technology Device (MTD) support
        -> Mapping drivers for chip access
        <M> CFI Flash device in physical memory map 
        (0x0) Physical start address of flash mapping  // 物理基地址
        (0x1000000) Physical length of flash mapping   // 长度
        (2)   Bank width in octets (NEW)               // 位宽
        
    2. make modules
       cp drivers/mtd/maps/physmap.ko /work/nfs_root/first_fs
    3. 启动开发板
       ls /dev/mtd*
       insmod physmap.ko
       ls /dev/mtd*
       cat /proc/mtd

    测试2: 使用自己写的驱动程序:

    1. ls /dev/mtd*
    2. insmod s3c_nor.ko
    3. ls /dev/mtd*
    4. 格式化: flash_eraseall -j /dev/mtd1
    5. mount -t jffs2 /dev/mtdblock1 /mnt
       在/mnt目录下操作文件
       
       
    NOR FLASH识别过程:
    do_map_probe("cfi_probe", s3c_nor_map);
        drv = get_mtd_chip_driver(name)
        ret = drv->probe(map);  // cfi_probe.c
                cfi_probe
                    mtd_do_chip_probe(map, &cfi_chip_probe);
                        cfi = genprobe_ident_chips(map, cp);
                                    genprobe_new_chip(map, cp, &cfi)
                                        cp->probe_chip(map, 0, NULL, cfi)
                                                cfi_probe_chip
                                                    // 进入CFI模式
                                                    cfi_send_gen_cmd(0x98, 0x55, base, map, cfi, cfi->device_type, NULL);
                                                    // 看是否能读出"QRY"
                                                    qry_present(map,base,cfi)
                                                    .....
                                                    
    do_map_probe("jedec_probe", s3c_nor_map);
        drv = get_mtd_chip_driver(name)
        ret = drv->probe(map);  // jedec_probe
                jedec_probe
                    mtd_do_chip_probe(map, &jedec_chip_probe);
                        genprobe_ident_chips(map, cp);
                            genprobe_new_chip(map, cp, &cfi)
                                cp->probe_chip(map, 0, NULL, cfi)
                                        jedec_probe_chip
                                            // 解锁
                                            cfi_send_gen_cmd(0xaa, cfi->addr_unlock1, base, map, cfi, cfi->device_type, NULL);
                                            cfi_send_gen_cmd(0x55, cfi->addr_unlock2, base, map, cfi, cfi->device_type, NULL);
                                            
                                            // 读ID命令
                                            cfi_send_gen_cmd(0x90, cfi->addr_unlock1, base, map, cfi, cfi->device_type, NULL);                                      
                                
                                            // 得到厂家ID,设备ID
                                            cfi->mfr = jedec_read_mfr(map, base, cfi);
                                            cfi->id = jedec_read_id(map, base, cfi);
                                            
                                            // 和数组比较

                                            jedec_table     


      附访问命令表:


  • 相关阅读:
    本地Grails配置与MyEclipse配置
    Linux下Apache James 邮件安装与发送程序
    MyEclipse8.6 安装groovy插件
    系统管理指南:基本管理 第21 章• 使用Sun PatchManager 管理Solaris 修补程序(任务)
    tar.bz2 解压命令。
    系统管理指南:基本管理 索引
    系统管理指南:基本管理 第22 章• 使用patchadd 命令管理Solaris 修补程序(任务)~附录A • SMF 服务
    如何安装gcc
    系统管理指南:基本管理 第20 章• 管理Solaris 修补程序和更新(概述)
    系统管理指南:基本管理 第18 章• 用Solaris 系统管理工具管理软件(任务)
  • 原文地址:https://www.cnblogs.com/alan666/p/8312370.html
Copyright © 2011-2022 走看看