转载地址:https://blog.csdn.net/a624731186/article/details/37700205

一: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字节
---------------------
作者:wangqiang624731186
来源:CSDN
原文:https://blog.csdn.net/a624731186/article/details/37700205
版权声明:本文为博主原创文章,转载请附上博文链接!

uboot中的mmc命令(转)的更多相关文章

  1. uboot中的mmc命令

    一:mmc的命令例如以下: 1:对mmc读操作 mmc read addr blk# cnt 2:对mmc写操作 mmc write addr blk# cnt 3:对mmc擦除操作 mmc eras ...

  2. android uboot中的mmc命令

    一:mmc的命令如下: 1:对mmc读操作 mmc read addr blk# cnt 2:对mmc写操作 mmc write addr blk# cnt 3:对mmc擦除操作 mmc erase ...

  3. 【转】uboot中的mmc命令

    转自:https://www.cnblogs.com/yxwkf/p/3855383.html 1:mmcinfo 输入: mmcinfo 显示结果:Manufacturer ID: 45OEM: 1 ...

  4. 在uboot中加入cmd_run命令,运行环境变量

    在学习uboot的过程中会经常烧录程序,每次都要敲一些下载指令.这样是不是很麻烦,有什么办法能快速的烧写呢.很简单,将需要敲击的指令编译到uboot中,以环境变量的形式存在.但是环境变量很好加,如何运 ...

  5. loongson 2f 和u-boot中的cache命令对照

    00000 Index Invalidate INDEX_INVALIDATE_I (I) 00001 Index WriteBack Invalidate INDEX_WRITEBACK_INV_D ...

  6. uboot命令(1):mmc命令

    版权声明 更新:2017-06-07博主:LuckyAlan联系:liuwenvip163@163.com声明:吃水不忘挖井人,转载请注明出处! 1 文章介绍 今天在进行Android分区修改的时候发 ...

  7. u-boot中添加自定义命令

    1.u-boot命令机制u-boot中,每个命令都使用一个struct cmd_tbl_s结构体定义,该定义在include/command.h中实现:struct cmd_tbl_s{ char * ...

  8. U-Boot中的filesize环境变量

    U-Boot中的环境命令可以使用$(filesize)来确定刚下载(传输)得到的文件大小. 因为使用类似tftp命令传输文件后,会自动更新filesize环境变量.如:setenv updateroo ...

  9. u-boot中添加mtdparts支持以及Linux的分区设置

    简介 作者:彭东林 邮箱:pengdonglin137@163.com u-boot版本:u-boot-2015.04 Linux版本:Linux-3.14 硬件平台:tq2440, 内存:64M   ...

随机推荐

  1. cisco 路由与ASA SSH 设置

    转载于https://www.cnblogs.com/sun292393989/p/8980700.html 一 试验拓扑 二 Server配置 ①配置hostname和domain name 因为r ...

  2. ASP.NET LinqDataSource数据绑定后,遇到[MissingMethodException: 没有为该对象定义无参数的构造函数。]问题。

    问题出现的情形:LinqDataSource数据绑定到DetailsView或GridView均出错,错误如下: “/”应用程序中的服务器错误. 没有为该对象定义无参数的构造函数. 说明: 执行当前 ...

  3. 怎样在sql server profiler跟踪时只显示自己关心的内容

    当我们想知道.net程序到底执行了哪些SQL的时候,通常会使用sql server profiler,但是如果不加设置,我们程序执行的sql通常会被系统的SQL淹没,通过以下的方法,可以只显示我们需要 ...

  4. springboot放到linux启动报错:The temporary upload location [/tmp/tomcat.8524616412347407692.8111/work/Tomcat/localhost/ROOT/asset] is not valid

    1.背景 笔者的springboot在一个非root用户环境下运行,这种环境下可以保证不被潜在的jar/开源框架漏洞提权. 比如在防火墙上把外网访问来的443端口映射到本地8443的java web端 ...

  5. 【链接】在线压缩JS文件

    在线压缩JS文件: http://yui.2clics.net/ https://refresh-sf.com/

  6. Windows 10 多用户同时远程登录

    win服务器版默认是支持多用户登陆的,甚至可以在主机上用不同用户自己远程登陆自己,如window server 2016. Win10 正常情况下是不允许用户同时远程的,即一个用户远程进来会把另一个用 ...

  7. Redis Sentinel 高可用部署实践集群

    一.Redis Sentinel 介绍    1.Sentinel     数据库环境搭建,从单机版到主备.再到多数据库集群,我们需要一个高可用的监控:比如Mysql中,我们可能会采用MHA来搭建我们 ...

  8. 简单使用Moq框架

    Moq框架简单使用   系列目录 Moq库简介及安装 Moq简介 Moq是.net平台下的一个非常流行的模拟库,只要有一个接口它就可以动态生成一个对象,底层使用的是Castle的动态代理功能. 它的流 ...

  9. 修复Nginx报错:upstream sent too big header while reading response header from upstream

    在 nginx.conf 的http段,加入下面的配置: proxy_buffer_size 128k; proxy_buffers 32k; proxy_busy_buffers_size 128k ...

  10. remote origin already exists解决办法

    如图翻译过来就是:致命:远程来源已经存在 此时,我们可以先 git remote -v 查看远程库信息: 可以看到,本地库已经关联了origin的远程库,并且,该远程库指向GitHub. 解决办法如下 ...