1. 简要说明<br />JLink的调试功能、烧写Flash的功能都很强大,但是对于S3C2410、S3C2440的Flash操作有些麻烦:烧写Nor Flash时需要设置SDRAM,否则速率很慢;烧写Nand Flash只是从理论上能够达到,但是还没有人直接实现这点。<br />本文使用一个间接的方法来实现对S3C2410、S3C2440开发板的Nor、Nand Flash的烧写。原理为:JLink可以很方便地读写内存、启动程序,那么可以把一个特制的程序下载到开发板上的SDRAM去,并运行它,然后使用这个程序来烧写。<br /><br />2. 操作步骤<br />2.1 连接硬件<br />对于大多数的S3C2410、S3C2440开发板而言,它们所用的JTAG接口一般有3种。<br /><br />但是市面上的JLink,大多只支持2.54mm间距20pin的JTAG接口,所以需要用到转接板。或者直接使用JLink的变种,如下面网址所示的两种改进版JLink:<br />http://item.taobao.com/auction/item_detail-db1-757658496f103f39f75c9c1a97a0333d.htm<br />http://item.taobao.com/auction/item_detail-0db1-23f1c5b6f377845658eeb8e092859552.htm<br /><br />以mini2440为例,如下图接好JTAG线。<br />https://bbs.21ic.com/upfiles/img/20093/20093416117925.jpg<br /><br /><br />2.2 运行J-Link commander<br />J-Link commander启动后会自动化检测CPU,如果没有发现检测到CPU,就在里面执行usb命令连接JLink,再执行r命令识别处理器。<br /><br />2.3 下载运行特制的程序<br />对于S3C2410、S3C2440处理器,它们内部有4K的SRAM,当使用Nor Flash启动时,地址为0x40000000;当使用Nand Flash启动时,地址为0。<br />对于S3C2410、S3C2440开发板,一般都外接64M的SDRAM。SDRAM能被使用之前,需要经过初始化。<br />所以,先把一个init.bin下载到内部SRAM去运行,它执行SDRAM的初始化;然后再下载一个比较大的程序,比如u-boot到SDRAM去动行,它将实现对Nor、Nand Flash的操作。<br />以下是在J-Link commander里的命令,假设init.bin、u-boot.bin在e:盘下。<br />1. speed 12000 //设置TCK为12M,下载程序时会很快 <br /><br />2. 下载并运行init.bin,这是用来初始化SDRAM的 <br />2.1 如果是NAND启动: <br />loadbin e:\init.bin 0 <br />setpc 0 <br />g <br />2.2 如果是Nor启动: <br />loadbin e:\init.bin 0x40000000 <br />setpc 0x40000000 <br />g <br /><br />3. 下载特制的uboot: <br />h <br />loadbin e:\u-boot.bin 0x33f80000 <br />setpc 0x33f80000 <br />g <br /><br /><br />现在,u-boot已经启动了,在串口工具上可以看到uboot的启动信息了,以后就可以通过网络、串口下载文件,然后使用u-boot里的命令进行烧写。 <br /><br />当然,如果没有网络,也不想忍受串口的速率,也可以通过jlink commander下载,比如: <br />h <br />loadbin your_file.bin 0x30000000 <br />g <br /><br />这时,你的文件已经被下载到SDRAM 0x30000000去了。 <br />后面的操作就是u-boot的命令了。<br /><br /><br />2.4 使用u-boot烧写Flash<br />以例子为例,假设需要烧写一个名为leds.bin的程序到Nor、Nand Flash,那么请参考:<br />(1).通过Jlink下载:<br />在J-Link commander里执行:<br />h<br />loadbin e:\leds.bin 0x30000000<br />g<br /><br />注意leds.bin的大小<br /><br />(2).通过u-boot烧写到Nor Flash:<br />在u-boot里执行:<br />protect off all // 解锁<br />erase 0 2ffff // 擦除从0地址开始的大小为0x30000的NOR Flash扇区(大小为可擦除块的整数倍,可以运行flash info命令查看)<br />cp.b 0x30000000 0 30000 // 把前面下载到0x30000000的程序烧写到NOR去<br /><br />(3).通过u-boot烧写到Nand Flash:<br />在u-boot里执行:<br />nand erase 0 30000 // 擦除从0地址开始的大小为0x30000的Nnad Flash扇区<br />nand write.jffs2 30000000 0 30000 // 把前面下载到0x30000000的程序烧写到Nand去<br /><br /><br />注意,上面用的2ffff、30000等数字是192K,如果你的程序比较小,请自行设置。<br /><br /><br /><br />init.bin用汇编写成,位置无关,可以在任何地方执行。 <br />u-boot.bin也是经过了我的大量修改,可以适用于友善之臂、优龙、扬创等等开发板,具备以下特点: <br />1. 支持CFI、JEDEC接口的NOR FLASH <br />2. 支持各种NAND FLASH <br />3. 支持网络CS8900、DM9000 <br />4. 支持USB下载 <br />5. 支持烧写YAFFS文件系统映象 <br /><br />下载地址为(文件太大了,本站上传不了):http://**.com/bbs/bbs_upload34876/files_12/**_422781.rar <br /><br />这两个程序是我为了基于FT2232D的OpenJTAG编写、修改的,后来想想在JLink上也可以使用。 <br />实际上,针对基于FT2232D的USB JTAG工具,我已经编写了一个NOR、NAND FLASH烧写器,目前JLINK烧写NAND的工具还在研究中。 <br />这是一种间接的、麻烦的、通过u-boot烧写NOR、NAND的方法,但是:速度很快,并且对于JLink似乎也没人搞定烧写NAND。<br /><br /> |
|