• 使用JLink间接烧写S3C2410、S3C2440开发板Nor、Nand Flash的方法


    1. 简要说明
    JLink的调试功能、烧写Flash的功能都很强大,但是对于S3C2410、S3C2440的Flash操作有些麻烦:烧写Nor Flash时需要设置SDRAM,否则速率很慢;烧写Nand Flash只是从理论上能够达到,但是还没有人直接实现这点。
    本文使用一个间接的方法来实现对S3C2410、S3C2440开发板的Nor、Nand Flash的烧写。原理为:JLink可以很方便地读写内存、启动程序,那么可以把一个特制的程序下载到开发板上的SDRAM去,并运行它,然后使用这个程序来烧写。

    2. 运行J-Link commander
    J-Link commander启动界面如图4所示,(如果没有发现检测到CPU,就在里面执行usb命令连接JLink,再执行r命令识别处理器)。

    2011-09-06

    3 下载运行特制的程序
    对于S3C2410、S3C2440处理器,它们内部有4K的SRAM,当使用Nor Flash启动时,地址为0x40000000;当使用Nand Flash启动时,地址为0。
    对于S3C2410、S3C2440开发板,一般都外接64M的SDRAM。SDRAM能被使用之前,需要经过初始化。
    所以,先把一个init.bin下载到内部SRAM去运行,它执行SDRAM的初始化;然后再下载一个比较大的程序,比如u-boot到SDRAM去动行,它将实现对Nor、Nand Flash的操作。
    以下是在J-Link commander里的命令,假设init.bin、u-boot.bin在e:盘下。
    1. speed 12000               //设置TCK为12M,下载程序时会很快 
    2. 下载并运行init.bin,这是用来初始化SDRAM的 
    2.1 如果是NAND启动: 
    loadbin e:\init.bin 0      
    setpc 0 

    2.2 如果是Nor启动: 
    loadbin e:\init.bin 0x40000000      
    setpc 0x40000000 

    3. 下载特制的uboot: 

    loadbin e:\u-boot.bin 0x33f80000 
    setpc 0x33f80000 
    g

    当然,如果没有网络,也不想忍受串口的速率,也可以通过jlink commander下载,比如: 

    loadbin your_file.bin 0x30000000 

    这时,你的文件已经被下载到SDRAM 0x30000000去了。 
    后面的操作就是u-boot的命令了。
    2.4 使用u-boot烧写Flash
    以例子为例,假设需要烧写一个名为leds.bin的程序到Nor、Nand Flash,那么请参考:
    (1).通过Jlink下载:
    在J-Link commander里执行:
    h
    loadbin e:\leds.bin 0x30000000
    g
    注意leds.bin的大小
    (2).通过u-boot烧写到Nor Flash:
    在u-boot里执行:
    protect off all        // 解锁
    erase 0 2ffff         // 擦除从0地址开始的大小为0x30000的NOR Flash扇区(大小为可擦除块的整数倍,可以运行flash info命令查看)
    cp.b 0x30000000 0 30000   // 把前面下载到0x30000000的程序烧写到NOR去
    (3).通过u-boot烧写到Nand Flash:
    在u-boot里执行:
    nand erase 0 30000           // 擦除从0地址开始的大小为0x30000的Nnad Flash扇区
    nand write.jffs2 30000000 0 30000   // 把前面下载到0x30000000的程序烧写到Nand去
    注意,上面用的2ffff、30000等数字是192K,如果你的程序比较小,请自行设置。

  • 相关阅读:
    oracle拆分逗号分隔字符串 实现split[转]
    Oracle 编译、调用或调试Procedure、Function或Package时卡死问题
    The log sequence numbers 1602631 and 1602631 in ibdata files do not match the log sequence number 2188207 in the ib_logfiles!
    win10下安装pl/sql developer 10.0.5.1710 报错ORA-12154
    Oracle EBS-SQL (INV-5):检查期间拉式物料领用记录数.sql
    Oracle EBS-SQL (INV-4):检查负库存记录数.sql
    Oracle EBS-SQL (WIP-16):检查期间手工下达的车间任务数.sql
    Oracle EBS-SQL (WIP-15):检查车间任务物料未发数量与现有量对照.sql
    Oracle EBS-SQL (WIP-14):检查车间需求与BOM差异对照.sql
    Oracle EBS-SQL (WIP-13):检查任务组件未选MRP净值.sql
  • 原文地址:https://www.cnblogs.com/xmphoenix/p/2168828.html
Copyright © 2020-2023  润新知