还可以通过tftp的方式,开发板启动后,按下除回车之外任意键,进入vivi的shell,然后输入
load flash vivi t
windows 里面命令行里进入c;\(之前先把mytftp.exe拷到c盘根目录下),输入:
mytftp -i 192.168.0.15 PUT vivi
开发板上的VIVI在完成接收新的VIVI文件后将把其烧入VIVI分区中,通过tftp比jtag快多了,一秒钟就搞定了!^_^
下面是超级中断的vivi tftp方式烧写界面
vivi> load flash vivi t
Ready for downloading using tftp...
Waiting...
Setting MAC address...
Type "tftp -i 192.168.0.15 PUT {input-filename}" on the host PC
Press ESC key to exit
Starting the TFTP download...
..
Received 12ea0 Bytes, END...
Download end
Downloaded file at 0x30000000, size = 77472 bytes
Found block size = 0x00014000
Erasing... ... done
Writing... ... done
Written 77472 bytes
vivi>
烧写wince启动的eboot同样采用tftp的方式,
烧写wince的镜像文件到nand flash,有两种方法,一是直接烧写没有展开的wince镜像nk.bin到开发板,第二种方法是通过platform builder将展开后的nk.bin烧写到开发板。
开发板的vivi有三个相关的参数:
wince_part_name (指定wince镜像nk.bin放置的分区名);
wincesource (0表示从以太网启动wince,如果用platform builder来引导wince则需选0;
1表示从 nand flash启动);
wincedeploy (0表示存放的nk.bin文件没展开,1表示展开的,展开后wince启动会比较快)
方法一,直接烧写
先定义好参数,输入命令如下:
设好参数后,通过tftp烧写
vivi将把nk,bin烧写到nand flash中,在直接从nand flash读取nk,bin,展开到sdram中,然后从sdram中启动wince。这样启动时间一般在45妙左右。
还可以用开发板的vivi提供的wince rewrite命令,将nk.bin展开后保存到flash中,以后nand flash启动展开后的nk.bin。
方法二,利用plarform builder直接下载展开的镜像
先定义好参数,输入命令如下:
param wincesource 0
下面是platform builder(一下简称PB),的具体操作看开发板的用户说明。^_^不想打了!
附录:vivi 命令详解
在超级终端界面中键入任意键(除enter外)进入vivi命令界面
vivi>
输入help 可以见到开发板上的vivi 支持的命令
vivi>
cpu [{cmds}] -- Manage cpu clocks
bon [{cmds}] -- Manage the bon file system
reset -- Reset the system
param [set|show|save|reset] -- set/get parameter
part [add|del|show|reset] -- Manage MTD partitions
mem [{cmds}] -- Manage Memory
load {...} -- Load a file to RAM/Flash
go <addr> <a0> <a1> <a2> <a3> -- jump to <addr>
dump <addr> <length> -- Display (hex dump) a range of memory.
call <addr> <a0> <a1> <a2> <a3> -- jump_with_return to <addr>
boot [{cmds}] -- Booting linux kernel
help [{cmds}] -- Help about help?
display <vga|pal> -- Set the display format
flash [{cmds}] -- Manage Flash memory
wince [rewrite] -- boot wince from ethernet or f
lash by eboot
os <linux|wince> -- set the default os
vivi>
----------command parameter list-----------
mem size -- probe dram size
mem read <addr> -- read a word(4bytes) from special dram address
mem write <addr> <vlaue> -- write a word(4bytes) into special dram
address
mem test <start_addr> <size> [<quiet>] -- memory test
-----------sub command list-------------
mem cmp <dst_addr> <src_addr> <length> -- compare
mem copy <dst_addr> <src_addr> <length> -- copy memory from
<src_addr> to <dst_a
ddr>
mem info -- display memory infomation
mem reset -- reset memory control register
mem search <start_addr> <end_addr> <value> -- search memory address
that contain value in the special memory address range
vivi>
RAM Information:
Default ram size: 64M
Real ram size : 64M
Free memory : 61M
RAM mapped to : 0x30000000 - 0x34000000 (SDRAM映射的地址范围)
Flash memory mapped to : 0x10000000 - 0x12000000 (Flash映射的地址范围)
Available memory region : 0x30000000 - 0x33de4000 (用户可以使用的有效的内存区域地址范围)
Stack base address : 0x33debffc (栈的基地址)
Current stack pointer : 0x33debc78 (当前栈指针的值)
Memory control register vlaues (S3C2410的内存控制寄存器的当前值)
BWSCON = 0x22111d10
BANKCON0 = 0x00000700
BANKCON1 = 0x00000700
BANKCON2 = 0x00001f7c
BANKCON3 = 0x00000700
BANKCON4 = 0x00000700
BANKCON5 = 0x00000700
BANKCON6 = 0x00018001
BANKCON7 = 0x00018001
REFRESH = 0x008e01e9
BANKSIZE = 0x000000b1
MRSRB6 = 0x00000020
MRSRB7 = 0x00000020
vivi>
load 命令下载程序到存储器中(Flash或者 RAM中)过 load help 可
以显示系统对 load系列命令的帮助提示
vivi>
load <flash|ram> [ <partname> | <addr> <size> ] <x|y|z|t>
关键字参数 flash 和 ram 用于选择目标介质是 Flash还是 RAM
到 Flash 中还是先要下载到 RAM 中(临时下载到 SDRAM 的起始地址处
0x30000000保存一下,然后再转写入 FLASH),然后再通过 Flash驱动程
序提供的写操作,将数据写入到 Flash中选择了 flash 参数,那名
到底是对 NOR Flash操作还是对 NAND Flash操作,这取决于 bootloader
编译的过程中,所进行的配置,这就要看配置的时候将MTD设备配置成NOR
Flash还是 NAND Flash
参数 partname 和 addr size二者选其一,partname是 vivi的 MTD分区表中
的分区名 MTD分区的起始地址;addr和
size是让用户自己选择下载的目标存储区域,而不是使用 vivi的 MTD分区,
addr表示下载的目标地址,size表示下载的文件大小,单位字节,size参数
不一定非要指定得和待下载的文件大小一样大,但是一定要大于等于待下载
的文件的字节数
关键字参数 x y 和 z 分别表示从 PC主机上下载文件到 ARMer9系统中,
采用哪种串行文件传送协议,x表示采用XModem协议,y表示采用Ymodem协议,z表示采用 ZModem协议请注意目前该 bootloader vivi 还没有
实现 ZModem协议,所以该参数只能选择 x和 y
关键字参数t应该是开发板vivi增加的,是tftp下载!很好用的!速度比jtag要快多了!
开发板的vivi eboot烧写都要通过
如:要烧写eboot.nb0到flash的eboot分区,首先在超级中断进入vivi的shell,输入
使用交叉网线连好PC与开发板,把eboot.nb0拷贝到于mtftp.exe同一目录下,在windows命令行输入
等待烧写完成即可
显示系统对 param系列命令的帮助提示
vivi>
Usage:
param help -- Help aout 'param' command
param reset -- Reset parameter table to default table
param save -- Save parameter table to flash memeory
param set <name> <value> -- Reset value of parameter
param set linux_cmd_line "..." -- set boot parameter
param set wince_part_name "..." -- set the name of partition wich wince
will be stored in
param show -- Display parameter table
vivi>
vivi>
Number of parameters: 19
name : hex integer
-------------------------------------------------------------
mach_type : 000000c1 193 //机器类型,193表示 S3C2410的开发系统
media_type : 00000003 3 //媒介类型,即指示了bootloader从哪个媒介启动起来的
boot_mem_base : 30000000 805306368
/*引导 linux 内核启动的基地址映像将被从 Flash 中拷贝到
boot_mem_base + 0x8000 的地址处,内核参数将被建立在
boot_mem_base+0x100的地址处 */
baudrate : 0001c200 115200 //bootloader启动时,默认设置的串口波特率
/*以上三个参数和 Xmodem文件传送协议相关
xmodem_one_nak表示接收端(即 ARMer9系统这端)发起第一个 NAK信
号给发送端(即 PC主机这端)到启动;
xmodem_initial_timeout表示接收端(即 ARMer9系统这端)启动 XModem
协议后的初始超时时间,第一次接收超时按照这个参数的值来设置,但是超
时一次后,后面的超时时间就不再是这个参数的值了,而是xmodem_timeout
的值;
xmodem_timeout表示在接收端(即 ARMer9系统这端)等待接受发送端(即
PC 主机这端)送来的数据字节过程中,如果发生了一次超时,那么后面的
超时时间就设置成参数 xmodem_timeout的值了
这三个参数不需要修改,系统默认的值就可以了,不建议用户去修改这几个
参数值 */
xmodem_one_nak : 00000000 0
xmodem_initial_timeout : 000493e0 300000
xmodem_timeout : 000f4240 1000000
/*ymodem_initial_timeout
ymodem_initial_timeout 表示接收端(即 ARMer9 系统这端)在启动了
YModem协议后的初始超时时间
这个参数不需要修改,系统默认的值就可以了,不建议用户去修改这几个参
数值 */
ymodem_initial_timeout : 0016e360 1500000
/*boot_delay是 bootloader自动引导 linux kernel功能的延时时间*/
boot_delay : 00300000 3145728
os : WINCE
display : VGA 640X480
ip : 192.168.0.15
host : 192.168.0.1
gw : 192.168.0.1
mask : 255.255.255.0
wincesource : 00000001 1
wincedeploy : 00000000 0
mac : 00:00:c0:ff:ee:08
wince part name: wince
Linux command line: noinitrd root=/dev/mtdblock/3 init=/linuxrc console=ttyS0
/*Linux command line 不是bootloader的参数,而是kernel启动的时候,kernel
不能自动检测到的必要的参数些参数需要 bootloader 传递给 linux
kernel Linux command line就是设置 linux kernel启动时,需要手工
传给 kernel的参数 */
vivi>
name offset size flag
------------------------------------------------
vivi : 0x00000000 0x00020000 0 128k
param : 0x00020000 0x00010000 0 64k
kernel : 0x00030000 0x001c0000 0 1M+768k
root : 0x00200000 0x00400000 0 4M
eboot : 0x00600000 0x00080000 0 512k
wince : 0x00680000 0x01c80000 0 28M+512k
flashdisk : 0x02300000 0x01d00000 0 29M
MTD分区是针对 Flash(NOR Flash或者 NAND Flash)的分区,以便于对
bootloader对 Flash进行管理
命令的详细格式如下:
part add name offset size flag
参数 name是要添加的分区的分区名
参数 offset 是要添加的分区的偏移(相对于整个 MTD 设备的起始地址的偏
移,在 ARMer9系统中不论配置的是 NOR Flash,还是 NAND Flash,都只
注册了一个 mtd_info结构,也就是说逻辑上只有一个 MTD设备,这个 MTD
设备的起始地址为 0x00000000);
参数 size是要添加的分区的大小,单位为字节;
参数 flag是要添加的分区的标志,参数 flag的取值只能为以下字符串(请注
意必须为大写)或者通过连接符 |
这个标志表示了这个分区的用途
“BONFS” 作为 BONFS文件系统的分区;
“JFFS2” 作为 JFFS2文件系统的分区;
“LOCK” 该分区被锁定了;
“RAM” 该分区作为RAM使用
例如,添加新的 MTD分区 mypart
vivi> part add mypart 0x500000 0x100000 JFFS2
mypart: offset = 0x00500000, size = 0x00100000, flag = 8
命令的详细格式如下:
part del name
参数 name是要删除的 MTD分区的分区名
BON 分区是只针对 NAND Flash 设备的一种简单的分区管理方式
Bootloader支持BON分区,同时Samsung提供的针对S3C2410移植的linux
版本中也支持了 BON分区,这样就可以利用 BON分区来加载 linux的 root
根文件系统了 MTD 分区和 BON 分区,当 ARMer9 系统配置
了 NAND Flash 作为 MTD 设备,那么 MTD 分区和 BON 分区都在同一片
NAND Flash上
vivi>
Usage:
boot <media_type> -- booting kernel
value of media_type (location of kernel image
1 = RAM
2 = NOR Flash Memory
3 = SMC (On S3C2410)
boot <media_type> <mtd_part> -- boot from specific mtd partition
boot <media_type> <addr> <size>
boot help -- help about 'boot' command
boot 关键字后面 media_type 必须指定媒介类型,因为 boot命令对不同媒介的处理方式
是不同的,例如如果 kernel在 SDRAM中,那么 boot执行的过程中就可以
跳过拷贝 kernel映像到 SDRAM中这一步骤了
Boot命令识别的媒介类型有以下三种:
linux kernel必须要放在 RAM中
了 NOR Flash中
到了 NAND Flash中
取值参数意义如下:
参数 mtd_part是 MTD分区的名 MTD设备的一个
分区中启动 linux kernel,kernel映像必须被放到这个分区中;
<addr> <size>分别表示 linux kernel起始地址和 kernel的大小为什么要指定
kernel大小呢?因为kernel首先要被copy到boot_mem_base + 0x8000的
地方,然后在 boot_mem_base + 0x100开始的地方设置内核启动参数,要
拷贝 kernel,当然需要知道 kernel的大小啦,这个大小不一定非要和 kernel
实际大小一样,但是必须许大于等于 kernel的大小,单位字节
reset 命令
复位Arm9系统
part 命令
part 命令用于对分区进行操作。通过part help 可以显示系统对part
系列命令的帮助提示。
• part show 显示分区信息
• part add partname part_start_addr part_leng flag 添加分区,参数flag为分区类型
• part del partname 删除分区
• part save 保存part 分区信息
• part reset 恢复为系统默认part分区
----------------------------------------------------------------------
load 命令
load 命令下载程序到存储器中(Flash 或者RAM 中)。通过load help可以显示系统对load 系列命令的帮助提示。
• load flash partname x 使用xmodom 协议通过串口下载文件并且烧写带partname 分区
例:
-load flash vivi x //注意,这里的vivi是分区名
-load flash kernel x
-load flash root x
• load ram partname or addr x 使用xmodom 协议通过串口下载文件到内存中
param命令
param 命令用于对bootloader 的参数进行操作。通过param help 可以
显示系统对param 系列命令的帮助提示。
• param show 命令用于显示bootloader 的当前参数值。
• param reset 将bootloader 参数值复位成系统默认值。
• param set paramname value 设置参数值
• param set linux_cmd_line ”linux bootparam” 设置linux 启动参数,参数linux bootparam 表示要设置的linux kernel 命令行参数。
• param save 保存参数设置
boot命令
boot命令用于引导linux kernel 启动。通过boot help 可以显示系统对boot命令的帮助提示。
• boot 默认方式启动
• boot ram ramaddr lenth 启动sdram 中ramaddr处长度为lenth的linux 内核。
bon 命令
bon 命令用于对bon分区进行操作。通过bon help 可以显示系统对bon
系列命令的帮助提示。bon分区是nand flash 设备的一种简单的分区管理方式。
• bon part info命令用于显示系统中bon分区的信息。
• bon part命令用于建立系统的bon分区表。bon分区表被保存到nand flash
的最后0x4000 个字节中,即在nand flash的0x03FFC000 ~0x33FFFFFF 范围内,分区表起始于0x03FFC000。
例如分为3个区:0~192k,192k~1M,1M~
vivi> bon part 0 192k 1M
doing partition
size = 0
size = 196608
size = 1048576
check bad block
part = 0 end = 196608
go 命令
go 命令用于跳转到指定地址处执行该地址处的代码。
• go addr 跳转到指定地址运行该处程序。