U-boot 命令的使用

转载 2016年08月29日 11:14:31
TI8148_EVM#
?       - alias for 'help'
base    - print or set address offset
bdinfo  - print Board Info structure
bmp     - manipulate BMP image data
boot    - boot default, i.e., run 'bootcmd'
bootd   - boot default, i.e., run 'bootcmd'
bootm   - boot application image from memory
bootp   - boot image via network using BOOTP/TFTP protocol
cmp     - memory compare
coninfo - print console devices and information
cp      - memory copy
crc32   - checksum calculation
dcache  - enable or disable data cache
dhcp    - boot image via network using DHCP/TFTP protocol
echo    - echo args to console
editenv - edit environment variable
exit    - exit script
false   - do nothing, unsuccessfully
fatinfo - print information about filesystem
fatload - load binary file from a dos filesystem
fatls   - list files in a directory (default /)
go      - start application at address 'addr'
help    - print command description/usage
i2c     - I2C sub-system
icache  - enable or disable instruction cache
iminfo  - print header information for application image
imxtract- extract a part of a multi-image
itest   - return true/false on integer compare
loadb   - load binary file over serial line (kermit mode)
loads   - load S-Record file over serial line
loady   - load binary file over serial line (ymodem mode)
loop    - infinite loop on address range
md      - memory display
mm      - memory modify (auto-incrementing address)
mmc     - MMC sub system
mmcinfo - mmcinfo <dev num>-- display MMC info
mtest   - simple RAM read/write test
mw      - memory write (fill)
nand    - NAND sub-system
nandecc - Switch NAND ECC calculation algorithm b/w hardware and software
nboot   - boot from NAND device
nfs     - boot image via network using NFS protocol
nm      - memory modify (constant address)
ping    - send ICMP ECHO_REQUEST to network host
printenv- print environment variables
rarpboot- boot image via network using RARP/TFTP protocol
reset   - Perform RESET of the CPU
run     - run commands in an environment variable
saveenv - save environment variables to persistent storage
setenv  - set environment variables
sf      - SPI flash sub-system
showvar - print local hushshell variables
sleep   - delay execution for some time
source  - run script from memory
test    - minimal test like /bin/sh
tftpboot- boot image via network using TFTP protocol
true    - do nothing, successfully
version - print monitor version







TI8148_EVM#nand    
nand - NAND sub-system

Usage:
nand info - show available NAND devices
nand device [dev] - show or set current device
nand read - addr off|partition size
nand write - addr off|partition size
    read/write 'size' bytes starting at offset 'off'
    to/from memory address 'addr', skipping bad blocks.
nand erase [clean] [off size] - erase 'size' bytes from
    offset 'off' (entire device if not specified)
nand bad - show bad blocks
nand dump[.oob] off - dump page
nand scrub - really clean NAND erasing bad blocks (UNSAFE)
nand markbad off [...] - mark bad block(s) at offset (UNSAFE)
nand biterr off - make a bit error at offset (UNSAFE)
TI8148_EVM#


uboot mmc命令详解
一:mmc的命令如下:
1:对mmc读操作
mmc read addr blk# cnt

2:对mmc写操作
mmc write addr blk# cnt

3:对mmc擦除操作
mmc erase blk# cnt

4:重新搜索mmc设备
mmc rescan

5:列出mmc的分区
mmc part - lists available partition oncurrent mmc device

6:查看当前的设备号,或者设置设备号及分区
mmc dev [dev] [part] - show or set currentmmc device [partition]

7:显示boot分区号
mmc bootpart [dev] [part] - show or setboot partition

8:列出当前的mmc设备
mmc list - lists available devices

9: 打印一些当前mmc设备的信息
mmcinfo

二:mmc的命令详解
1:mmcinfo
输入:
mmcinfo
显示结果:
Manufacturer ID: 45
OEM: 100
Name: SEM08
Tran Speed: 25000000
Rd Block Len: 512
MMC version 4.0
Clock: 52000000
High Capacity: Yes
Capacity: 7944011776 Bytes
Bus Width: 8-bit DDR
Current Partition for boot: Boot partition 1

2:mmc list -lists available devices

输入:
mmc list
显示如下:
FSL_USDHC: 0
FSL_USDHC: 1
FSL_USDHC: 2
FSL_USDHC: 3

分析:boot中配置了四个mmc资源,SD卡是2,EMMC是3

3:mmc dev[dev] [part] - show or set current mmc device [partition]

输入:
mmc dev 3
显示如下:
mmc3(part 0) is current device

分析:表示当前处于EMMC设备的第0个分区

输入:
mmc dev 3 1
显示如下:
mmc3(part 1) is current device

分析:设置当前处于EMMC设备的第1个分区

4:mmc bootpart [dev] [part] - show or set boot partition

输入:
mmc bootpart
显示如下:
Device 3: boot partition 1 is for boot

分析:uboot处于第一个分区

5:mmc part -lists available partition on current mmc device

输入:
mmc part
显示如下:
Partition Map for UNKNOWN device 3 – Partition Type: DOS

Partition Start Sector Num Sectors Type
1 16384 16384 83
2 32768 16384 83
3 49152 6397952 5 Extd
4 6447104 9150464 83
5 49153 3145727 83
6 3194881 3145727 83
7 6340609 16383 83
8 6356993 8191 83

分析:显示当前EMMC的所有分区

6:mmc read addr blk# cnt
这个命令的作用是读取mmc上的数据到内存上

参数:
addr: 读取到内存的位置
blk: 读取block位置,这个位置是mmc的0地址的偏移量,是16进 制,block单位是512字节
cnt: 读取block个数,要读取到内存的数据大小,是16进制
block单位是512字节

例:
mmc dev 3 0
mmc read 0x10800000 600 10

命令分析:表示从mmc上1536×512个字节开始处(1536是600的十进制),读取16×512个字节(16是10的10进制)到内存0x10800000 处

显示结果:
MMC read: dev #3, block # 1536, count 16 … 16 blocks read: OK
结果分析:
我们只能从结果看出来读取成功,但不能确定读取的内容是否正确,所以打印下内存的数据,看是否与mmc中的内容一致

输入:
md.b 0x10800000 100
命令分析:打印内存位置0x10800000的100个字节
显示结果:
10800000: b15ecb3c 6f62 746f 6564 616c 3d79 0033 ^.<.bootdelay=3.
10800010: 61626475 6172 6574 313d 3531 3032 0030 baudrate=115200.
10800020: 70696461 7264 313d 3239 312e 3836 312e ipaddr=192.168.1
10800030: 312e3330 7300 7265 6576 6972 3d70 3931 .103.serverip=19
10800040: 2e323631 2e38 2e31 3031 0031 656e 6d74 2.168.1.101.netm
10800050: 73613d6b 3532 2e35 3532 2e35 3532 2e35 ask=255.255.255.
…..
…….
结果分析:
我在mmc位置1536×512的位置储存的是环境变量,与内存打印的一致,读取正确

7:mmc write addr blk# cnt
这个命令的作用是将内存上的数据写入mmc中

参数:
addr: 从内存读取的位置
blk: 写入到mmc中block位置,这个位置是mmc的0地址的偏移量,是16进制,block单位是512字节
cnt: 写入到mmc中block个数,要写入的数据大小,是16进制,
block单位是512字节

例:
mmc dev 3
mmc write 0x108000000 0 100

命令分析:表示从内存0x108000000的位置上读取256*512的数据(256是100的十进制)到mmc上0的位置处,这里就不举例验证了

mmc上0的位置处是分区表,我把内存上的乱数据写进去后,uboot检测不到分区了

8:mmc erase blk# cnt
参数:
blk: 擦除的mmc中block位置,这个位置是mmc的0地址的偏移量,是16进制,block单位是512字节
cnt: 擦除的mmc中block个数,是16进制,block单位是512字节
Nand flash uboot 命令详解
nand info & nand device
显示flash的信息:
DM365 :>nand info
Device 0: NAND 32MiB 3,3V 8-bit, sector size 16 KiB
DM365 :>nand device
Device 0: NAND 32MiB 3,3V 8-bit

nand read(.oob) addr off size
不管是读取data, 使用nand read,还是读取oob,使用命令nand read.oob, 后面跟的地址addr,都是ram的地址, off指的是nand flash的地址, size:指要读取nand flash的数据大小, 但是如果是读取oob, size不能超过一个page的oob size, 如果page size为512个字节, oob size就是16个字节.
DM365 :>nand read 86000000 58000 100
NAND read: device 0 offset 0x58000, size 0x100
256 bytes read: OK
DM365 :>md 86000000 40
86000000: ea000012 e59ff014 e59ff014 e59ff014 …………….
…………
860000f0: e1a0000d eb00022e 00000000 00000000 …………….
DM365 :>nand read.oob 86000000 58000 10
NAND read: device 0 offset 0x58000, size 0x10
16 bytes read: OK
DM365 :>md 86000000 40
86000000: ffffffff 2707ffff 33e316ad 44b2e1a1 …….’…3…D
如果一次想读取完整的一个page 的值,包含oob, 使用下面将的命令, nand dump.

nand dump [addr] [size]
调用过程: nand dump addr size (common/cmd_nand.c)==> nand_dump() ==> nand_read_raw();
nand dump 不管你的size有多大,至少会dump出一个page的大小:
SMDK2440 # nand dump 0 100
Page 00000000 dump:
12 00 00 ea 14 f0 9f e5 14 f0 9f e5 14 f0 9f e5
14 f0 9f e5 14 f0 9f e5 14 f0 9f e5 14 f0 9f e5
00 02 f8 33 60 02 f8 33 c0 02 f8 33 20 03 f8 33
80 03 f8 33 e0 03 f8 33 40 04 f8 33 ef be ad de
00 00 f8 33 00 00 f8 33 58 19 fa 33 34 6d fa 33
00 00 0f e1 1f 00 c0 e3 d3 00 80 e3 00 f0 29 e1
…………
04 30 8c e5 fc 4d 00 eb 00 01 9f e5 f0 3c 00 eb
02 0d 00 eb 41 42 00 eb f4 00 9f e5 00 40 98 e5
04 02 00 eb 0d 10 a0 e1 04 00 84 e5 40 20 a0 e3
OOB:
ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff
69 a6 ab 3c 33 cf 66 5a
a7 cf f0 33 a6 96 97 3f
0c c3 30 30 c3 cc 33 f3

nand write - addr off size
这个命令和nand read一样, 只是方向是反的, 是把ram的值写到 nand flash中, 但是这个写只能将1改为0, 不能将0写成1. 这个command会自动skipping bad blocks。

nand erase [clean] [off size]
在擦之前会先check是不是坏块,如果是坏块,就不能做擦的动作了。
DM365 :>nand dump 1cc000 10
Page 001cc000 dump:
68 73 71 73 12 05 00 00 87 04 08 78 19 00 40 02
…………
df 88 5b 80 bb 11 32 11 6e e7 77 5a 3d b9 c8 bf
OOB:
ff ff ff ff ff ff ff 45
ed cc 3a e0 8e 52 f9 ad
DM365 :>nand erase 1cc000 100
NAND erase: device 0 offset 0x1cc000, size 0x100
Warning: Erase size 0x00000100 smaller than one erase block 0x00004000
Erasing 0x00004000 instead
Erasing at 0x1cc000 – 100% complete.
OK
DM365 :>nand dump 1cc000 10
Page 001cc000 dump:
ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff
…………
ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff
OOB:
ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff
DM365 :>mw 86000000 00000000
DM365 :>mw 86000004 00000000
DM365 :>mw 86000008 00000000
DM365 :>mw 8600000c 00000000
DM365 :>md 86000000
86000000: 00000000 00000000 00000000 00000000 …………….
DM365 :>nand write.oob 86000000 1cc000 10
NAND write: device 0 offset 0x1cc000, size 0x10
16 bytes written: OK
DM365 :>nand dump 1cc000 10
Page 001cc000 dump:
ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff
…………
ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff ff
OOB:
00 00 00 00 00 00 00 00
00 00 00 00 00 00 00 00
DM365 :>nand erase 1cc000 100
NAND erase: device 0 offset 0x1cc000, size 0x100
Warning: Erase size 0x00000100 smaller than one erase block 0x00004000
Erasing 0x00004000 instead
Skipping bad block at 0x001cc000
OK

不常用的命令
这些命令都是测试时使用的,正常是不会使用到的。
“nand scrub - really clean NAND erasing bad blocks (UNSAFE)\n”
“nand markbad off - mark bad block at offset (UNSAFE)\n”
“nand biterr off - make a bit error at offset (UNSAFE)\n”
“nand lock [tight] [status]\n”
” bring nand to lock state or display locked pages\n”
“nand unlock [offset] [size] - unlock section\n”);

u-boot学习(四):u-boot常用命令以及uboot命令的添加

u-boot的主要目的是启动内核,在启动内核之前,我们一般使用u-boot的命令来
  • To_Be_IT_1
  • To_Be_IT_1
  • 2014年06月03日 20:53
  • 2357

u-boot分析 七 (添加u-boot命令,学习u-boot命令实现原理)

u-boot分析 七(添加u-boot命令,学习u-boot命令实现原理)本文目标:理解u-boot命令的实现原理。上一篇文章分析了u-boot是如何启动kernel的,其中就涉及到bootm命令,考...
  • itxiebo
  • itxiebo
  • 2016年03月27日 12:13
  • 3491

u-boot——命令执行原理及自定义命令

一、u-boot命令 u-boot命令cmd_name cmd_param1 cmd_param2
  • hpr1992
  • hpr1992
  • 2014年11月11日 16:10
  • 353

Uboot关于i2c和EEPROM的命令

在uboot命令行下输入i2c并回车,会打印出i2c所有命令的使用方法: 比如i2c dev会打印出目前挂载的i2c设备: i2c probe是对i2c设备地址的寻找: ...
  • hahachenchen789
  • hahachenchen789
  • 2017年01月15日 19:56
  • 1511

u-boot go命令分析

在u-boot中提供了一个go命令,是可以跳到指定地址执行代码的命令,这实际上是执行了下面的函数:             int do_go(cmd_tbl_t * cmdtp,int flag,...
  • yuyinyuyin664
  • yuyinyuyin664
  • 2012年12月21日 21:47
  • 1630

uboot 的内存命令使用: mw (修改) md (显示),u-boot 内存 memory

修改: mw [内存地址] [值] [长度]例如:mw 0x02000000 0 128表示修改地址为0x02000000~0x02000000+128的内存值为0. //--------------...
  • lanmanck
  • lanmanck
  • 2009年06月10日 14:11
  • 16640

《转》u-boot移植烧写步骤、u-boot命令和kernel烧写步骤

转自:《http://blog.sina.com.cn/s/blog_726c4bd20100unjn.html》 移植烧写步骤   1. 解压u-boot源文件 2. 从u-boot/in...
  • fzxy002763
  • fzxy002763
  • 2016年07月08日 16:05
  • 1677

u-boot命令的添加

U-Boot的命令为用户提供了交互功能,并且已经实现了几十个常用的命令。如果开发板需要很特殊的操作,可以添加新的U-Boot命令。U-Boot的每一个命令都是通过U_Boot_CMD宏定义的。这个宏在...
  • menuconfig
  • menuconfig
  • 2008年04月14日 11:08
  • 887

U-Boot移植——修改提示符

0 开发环境     宿主机:Ubuntu14.04     开发板:Mini2440     U-Boot:u-boot-1.1.6      编译器:arm-linux-gc 1 修改配置头文件...
  • Q1302182594
  • Q1302182594
  • 2016年05月18日 20:01
  • 897

u-boot移植出现nand、mtd命令不能使用

问题背景: 这是我在公司做项目的时候遇到的问题,给公司新CPU平台的设备移植u-boot的时候编译没有错误,但是u-boot运行起来的时候出现nand命令和mtd无法使用。具体错误如下图: 这个错...
  • zengxianyang
  • zengxianyang
  • 2015年08月21日 11:43
  • 1300
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:U-boot 命令的使用
举报原因:
原因补充:

(最多只允许输入30个字)