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怎么操作?

    往地址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
    读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
    读数据:        读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     

                                                
                        
           

  • 相关阅读:
    HDU 6166
    codeforces 798D Mike and distribution
    Codeforces Round #409 (Div. 2) D Volatile Kite
    Codeforces Round #409 (Div. 2) C Voltage Keepsake(二分)
    HDU 4609 3-idiots(FFT计数)
    LightOJ 1236 Pairs Forming LCM(算术基本定理)
    HDU 1540 Tunnel Warfare(线段树,单点更新,区间查询)
    创建最简单的Struts2项目
    java自定义拦截器
    java拦截器和过滤器的区别
  • 原文地址:https://www.cnblogs.com/liulipeng/p/3377626.html
Copyright © 2011-2022 走看看