u-boot中filesize环境变量

U-Boot中的环境命令可以使用$(filesize)来确定刚下载(传输)得到的文件大小.

因为使用类似tftp命令传输文件后,会自动更新filesize环境变量。
如:setenv updaterootfs nand write.yaffs 30000000 200000 $(filesize)
这时如果printenv,会发现updaterootfs=nand write.yaffs 30000000 200000 6365D0 
这里的6365D0为setenv语句时环境变量filesize的大小.

需要引起注意的是:当执行setenv时,获取filesize的值6365D0 ,而不是每次间接获取获取filesize的值
所以导致 尽管每次tftp下载文件后(假如大小发生变话),updaterootfs=nand write.yaffs 30000000 200000 6365D0 updaterootfs中的大小依然是6365D0, 不会随每次传输文件后而更改。
所以如果run updaterootfs,则这里的6365D0这个值就不是我们想要的了,我们想要的是当前传输的文件大小。

正确的做法是使用单引号:setenv updaterootfs nand write.yaffs 30000000 200000 '$(filesize)'
这时printenv,则会显示 updaterootfs=nand write.yaffs 30000000 200000 $(filesize) 
### RK 芯片相关的 U-Boot 命令列表及用法 #### 1. 加载和启动命令 `load` 和 `boot` 是 U-Boot 中最常用的两个命令,用于加载镜像文件并启动操作系统。 - **`tftp`**: 使用 TFTP 协议从网络服务器下载文件到内存中。 ```bash => tftp ${loadaddr} u-boot.img ``` 上述命令会将 `u-boot.img` 文件加载到地址 `${loadaddr}`[^3]。 - **`fatload` 或 `ext4load`**: 从存储设备(如 SD 卡、eMMC)加载文件到内存中。 ```bash => fatload mmc 0:1 ${loadaddr} uImage ``` - **`go` 或 `bootm`**: 启动已加载的镜像文件。 ```bash => bootm ${loadaddr} ``` #### 2. 配置环境变量 U-Boot 的行为可以通过设置环境变量来控制。 - **`setenv` 和 `saveenv`**: 设置环境变量并将更改保存到持久化存储中。 ```bash => setenv bootcmd 'run distro_boot' => saveenv ``` - **常用环境变量**: - `bootargs`: 定义传递给内核的参数字符串。 ```bash => setenv bootargs console=ttyS2,1500000 root=/dev/mmcblk0p2 rw rootwait ``` - `loadaddr`: 指定加载地址。 ```bash => setenv loadaddr 0x82000000 ``` #### 3. 更新固件 RK 系列芯片支持通过 U-Boot 进行固件更新操作。 - **TFTP 更新 U-Boot**: ```bash => tftp ${loadaddr} u-boot.itb => sf probe 0 => sf erase 0x0 0x200000 => sf write ${loadaddr} 0x0 ${filesize} ``` - **SD/eMMC 更新 U-Boot**: ```bash => ext4load mmc 0:1 ${loadaddr} /path/to/u-boot.bin => mmc write ${loadaddr} 0x0 ${filesize} ``` #### 4. USB 设备管理 对于带有 USB 控制器的 RK 芯片,可以使用以下命令查看和调试 USB 设备。 - **`usb start`**: 初始化 USB 主机控制器。 ```bash => usb start ``` - **`usb tree`**: 显示当前连接的 USB 设备树结构。 ```bash => usb tree ``` 输出类似于: ```plaintext USB device tree: 1 Hub (5 Gb/s, 0mA) U-Boot XHCI Host Controller ... ``` #### 5. SPL/TPL 支持 某些 RK 芯片支持 Secondary Program Loader (SPL) 和 Tertiary Program Loader (TPL),这些阶段负责初始化硬件以便加载完整的 U-Boot- 编译带 SPL/TPL 的 U-Boot: ```bash make rk3399_defconfig make -j$(nproc) ``` 此过程会在编译目录下生成 `spl/u-boot-spl.bin` 和 `u-boot.img`[^1]。 - 刷写 SPL/TPL: ```bash dd if=spl/u-boot-spl.bin of=/dev/mmcblk0 bs=1k seek=16 conv=notrunc dd if=u-boot.img of=/dev/mmcblk0 bs=1k seek=328 conv=notrunc ``` #### 6. 获取源码 可以从官方 FTP 站点获取最新版本的 U-Boot 源码压缩包。 ```bash wget ftp://ftp.denx.de/pub/u-boot-2024.07-rc3.tar.bz2 tar jxf u-boot-2024.07-rc3.tar.bz2 cd u-boot-2024.07-rc3/ ``` 上述方法适用于任何需要定制开发的情况[^2]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值