怎么进入uboot命令行(如何进入uboot)

http://www.itjxue.com  2023-01-29 04:32  来源:未知  点击次数: 

华为ap进入uboot

启动AP。在出现以下信息后3秒内按下F键,进入Uboot命令行视图。

Uboot菜单缺省密码为admin@huawei.com

Press f or F to stop Auto-Boot in 3 seconds: 3

Password for uboot cmd line :

ar7240

配置AP和tftp服务器的IP地址,使AP和服务器的IP地址处于同一网段,保证AP能够从tftp服务器获取升级文件

ar7240 setenv ipaddr 192.168.10.13 #AP的IP地址

ar7240 setenv serverip 192.168.10.11 #服务器的IP地址

ar7240 saveenv

Saving Environment to Flash

Erasing Flash…Writing to Flash… done

ar7240 update system FatAP5X30XN_V200R007C20SPC100.bin #FatAP5X30XN_V200R007C20SPC100.bin存放在TFTP目录下

dup 1 speed 1000

Upgrade Firmware to A Successful

The current device is a FIT AP, but the upgrade package is for a FAT AP. Continue? [y/n]:y 按y

配置完成后,在命令行中键入reset

ar7240 reset

Resetting…

升级完成后,可执行命令display version

ckermit下怎样进入下位机的uboot

加电后等串口输出相应提示,如果是标准uboot,按任意键可中断启动过程,进入uboot命令行界面

华为AP版本切换命令

Uboot下用TFTP的方法升级AP 请事先配置好tftp工具,指向升级文件所在目录;保证在AP上能ping通PC。

1. 使用串口线将AP的串口和PC的串口相连,使用“超级终端”等软件,进入命令行界面。超级终端设置如下:

Baud:9600 Data bits:8 Stop bits:1 Parity: none Flow Control: none

2. 执行命令reboot,重新启动AP。在出现以下信息后3秒内按下F键,进入uboot命令行视图。Uboot菜单缺省密码为admin。

Press f or F to stop AutoBoot in 3 seconds:

3 Password for uboot cmd line :

3. 配置AP和tftp服务器的IP地址,保证AP能够从tftp服务器获取升级文件。ar7240setenv ipaddr 169.254.1.1 #AP的IP地址ar7240setenv serverip 169.254.1.3 #服务器的IP地址ar7240saveenvSaving Environment to Flash...Erasing Flash...Writing to Flash... done

4. 在命令行中键入update boot,在下面的显示信息中作相应的配置:

a. 升级uboot:ar7240update boot

#u-boot.bin存放在TFTP目录下dup 1 speed 1000......Copy to Flash... donear7240reset

#以新加载的uboot启动 升级uboot时不能断电,否则AP无法启动。

b. 重新启动AP。在出现以下信息后3秒内按下F键,进入uboot命令行视图。Uboot菜单缺省密码为admin@huawei.com。若V200R002版本中修改过密码,升级到V200R003版本后使用的密码为V200R002版本中修改的密码。若在V200R002版本时修改过密码,后又将密码改回为huawei,则版本升级到V200R003版本后使用V200R003版本缺省密码admin@huawei.com。

Press f or F to stop Auto-Boot in 3 seconds:

3 Password for uboot cmd line :

c. 加载需要升级的V200R003C00SPC300 AP系统软件:ar7240update system FitAP6X10XN_V200R003C00SPC300.bin #FitAP6X10XN_V200R003C00SPC300.bin存放在TFTP目录下dup 1 speed 1000 ......Upgrade Firmware to A Successful

5. 配置完成后,在命令行中键入reset,AP就会使用指定的网络启动固件文件启动了。用这种方式启动后,固件被读入AP的flash。ar7240resetResetting...

2

创维电视开机显示连接网络更精彩就不动了怎么办?

创维47E600F开机显示 “连接网络更精彩”停止不变刷程序解决。

附创维其它安卓系统智能电视官网下载地址。

有客户反映:电视出现问题期间找创维售后,上门不管三七二十一就要收150块RMB,什么问题都没有搞明白就要钱,致电客服居然就是说我们的维修师傅都是经验丰富专业的售后人员,还问我电视是什么问题。

还是自己研究修理找售后朋友,官网下载程序到优盘后,把U盘插入USB1口,可是怎么也没有反应。

强刷办法,买编程器推荐j1199和rt809f,把升级文件等一些文件放于U盘中插入USB2口就是下边的口中,用强刷的办法U盘居然有反应了,我认为应该是可以的,然后看左下角的等红绿闪烁一会电视恢复正常了,所以说47E600F用强刷的方式应该是没有问题的,据此我认为其它机型应该也是可以用同样的方法解决“连接网络更精彩”。

一,按住确定返回键(电视机上)在开机,然后松开,然后U盘灯闪烁,然后电视机黑屏,然后电视机左下等红绿闪烁,然后电视恢复正常。

文件准备,将优盘插入电视机USB接口,让其等待。

二、实操篇

各项工具都准备就绪之后,可以进行实际操作了。步骤如下:

1、将VGA串口接如电视后的VGA接口上。

2、将USB接口接在电脑上。

3、安装CH341SER.EXE驱动程序,并查看串口号

4、配置超级终端

5、进入配置

最后检查,优盘文件数据是否到位,串口驱动是否到位,数据线连接是否到位。一切就绪。打开电视机电源开关,迅速按动回车键,进入UBOOT命令行界面。至于你要问我什么是uboot,那是Linux嵌入式开发里的东西,我也不是太懂。

进入uboot界面之后,输入这过程中的唯一一条命令,

run recoverynand。至此电视进入自动升级程序,自行刷写Flash,大家知道这个过程也很重要,不要管他,电视做完之后,会自动启动,令人厌烦的“连接网络更精彩”又会出现,不过,你可别着急,过一会儿,电视就进入了系统主界面。

android怎么进入uboot

本人用的android平台用的bootloader用的是uboot,貌似大多数手持设备平台都不用这个,因为功能过于强大用不上,反而显得太复杂了。不知道这个平台开发者是怎么想的。既然用了那就来分析一下,顺便修改一下其中的几个小问题,以符合我们的要求。

uboot等同于其他所有的bootloader程序,从根本上讲是一个稍复杂的裸机程序,是最底层的东西,要分析裸机程序我们要从它的连接文件开始。连 接文件(.lds文件)定义了程序编译之后整个连接过程,这样我们就可以找到这个程序的第一句汇编代码,进而来下一步分析。uboot的链接文件代码在 android\bootable\bootloader\uboot-imx\u-boot.lds

[cpp] view plaincopy

OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm") //文件输出格式

OUTPUT_ARCH(arm)

ENTRY(_start) //首地址标示符

SECTIONS

{

. = 0x00000000; //其实地址0

. = ALIGN(4); //4字节对齐

.text : //代码段

{

board/freescale/mx6q_sabresd/flash_header.o (.text.flasheader) //第一个文件是board/freescale/mx6q_sabresd/flash_header.o

cpu/arm_cortexa8/start.o //第二个cpu/arm_cortexa8/start.o

board/freescale/mx6q_sabresd/libmx6q_sabresd.a (.text)

lib_arm/libarm.a (.text)

net/libnet.a (.text)

drivers/mtd/libmtd.a (.text)

drivers/mmc/libmmc.a (.text)

. = DEFINED(env_offset) ? env_offset : .;

common/env_embedded.o(.text)

*(.text) //剩余的所有代码

}

. = ALIGN(4);

.rodata : { *(SORT_BY_ALIGNMENT(SORT_BY_NAME(.rodata*))) } //readonly data 段

. = ALIGN(4);

.data : { *(.data) } //所有的readonly data

. = ALIGN(4);

.got : { *(.got) }

. = .;

__u_boot_cmd_start = .; //u_boot_cmd段,里面是所有uboot命令的一个列表

.u_boot_cmd : { *(.u_boot_cmd) }

__u_boot_cmd_end = .;

. = ALIGN(4);

_end_of_copy = .;

__bss_start = .; //bss段 就是内存数据段

.bss : { *(.bss) }

_end = .;

}

从上面的代码可以看出我们编译生成的二进制应用程序组成是:代码段-rodata段-uboot命令列表-bss段。我们启动这个应用程序时候是从,0地址开始的,因此我们来看

board/freescale/mx6q_sabresd/flash_header.s这个文件。

这个文件中除了分配内存和宏定义的伪汇编指令以外,真正执行的命令有一条

[cpp] view plaincopy

.section ".text.flasheader", "x"

b _start

.org CONFIG_FLASH_HEADER_OFFSET

也就是说,这个文件一执行就直接跳到_start 位置处。_start 在android\bootable\bootloader\uboot-imx\cpu\arm_cortexa8\ start.S中,因此我们来看这个文件代码

[cpp] view plaincopy

.globl _start

_start: b reset

这里直接跳转的reset中接下来看

[csharp] view plaincopy

reset:

/*

* set the cpu to SVC32 mode cpu设置成32位管理模式

*/

mrs r0, cpsr

bic r0, r0, #0x1f

orr r0, r0, #0xd3

msr cpsr,r0

#if (CONFIG_OMAP34XX) //因为我们的cpu不是ompa的 所以这段不会编译

.............................

#endif

/* the mask ROM code should have PLL and others stable */

#ifndef CONFIG_SKIP_LOWLEVEL_INIT

bl cpu_init_crit

#endif

这里接下来执行cpu_init_crit

[csharp] view plaincopy

/*************************************************************************

*

* CPU_init_critical registers

*

* setup important registers

* setup memory timing

*

*************************************************************************/

cpu_init_crit:

/*

* Invalidate L1 I/D

*/

mov r0, #0 @ set up for MCR

mcr p15, 0, r0, c8, c7, 0 @ invalidate TLBs

mcr p15, 0, r0, c7, c5, 0 @ invalidate icache

/*

* disable MMU stuff and caches //关闭mmu

*/

mrc p15, 0, r0, c1, c0, 0

bic r0, r0, #0x00002000 @ clear bits 13 (--V-)

bic r0, r0, #0x00000007 @ clear bits 2:0 (-CAM)

orr r0, r0, #0x00000002 @ set bit 1 (--A-) Align

orr r0, r0, #0x00000800 @ set bit 12 (Z---) BTB

mcr p15, 0, r0, c1, c0, 0

/*

* Jump to board specific initialization...

* The Mask ROM will have already initialized

* basic memory. Go here to bump up clock rate and handle

* wake up conditions.

*/

mov ip, lr @ persevere link reg across call

bl lowlevel_init @ go setup pll,mux,memory//执行lowlevel_init这个函数代码在

@\bootloader\uboot-imx\board\freescale\mx6q_sabresd\lowlevel_init.S中

@主要对时钟,外部ram,rom等进行了初始化代码不贴了。

mov lr, ip @ restore link

mov pc, lr @ back to my caller

初始化完成后,接下来执行

[csharp] view plaincopy

#ifndef CONFIG_SKIP_RELOCATE_UBOOT

relocate: @ relocate U-Boot to RAM 将uboot重新定位到内存中

adr r0, _start @ r0 - current position of code

ldr r1, _TEXT_BASE @ test if we run from flash or RAM

cmp r0, r1 @ don't reloc during debug测试当前代码是否已经在内存中

beq stack_setup @如果在的话就直接跳转到stack_setup

ldr r2, _armboot_start @如果不在的话,加载_armboot_start地址到r2中。_armboot_start是uboot执行的主体c函数。

ldr r3, _bss_start

sub r2, r3, r2 @ r2 - size of armboot计算bss_start-armboot_start 保存到R2中,也就是uboot的总大小

add r2, r0, r2 @ r2 - source end address 计算出uboot代码和rodata地址

copy_loop: @ copy 32 bytes at a time //开始拷贝

ldmia r0!, {r3 - r10} @ copy from source address [r0]

stmia r1!, {r3 - r10} @ copy to target address [r1]

cmp r0, r2 @ until source end addreee [r2]

ble copy_loop

#endif /* CONFIG_SKIP_RELOCATE_UBOOT */

linux怎么进入uboot菜单

linux下的dnw配置步骤以下:1

下载源码

源码:dnw_linux

这个是在1个论坛上搜到的,这个不需要注册,就能够免费下载奥,感谢作者的辛苦劳动和忘我的奉献精神,呵呵...2

解压这个下载完以后是rar格式的,还得到windows下解压。解压后copy到linux下便可。其中secbulk.c是pc端usb驱动,

dnw.c是写入工具。3

编译并加载secbulk模块$cd

secbulk$make

-c

/lib/modules/`uname

-r`/build

m=`pwd`

modules编译成功后在当前目录下可以看到secbulk.ko

用insmod命令加载模块,这需要root权限$sudo

insmod

./secbulk.ko4

编译dnw写入工具$gcc

-o

dnw

dnw.c编译成功后生成可履行dnw5

使用dnw下载使用方式和windows下基本1致。在终端下输入相应的uboot命令,当出现“usb

host

is

connected.

waiting

a

download.”时,在pc端linux上用dnw工具写入要下载的文件便可。切换到root权限,履行dnw下载.$./dnw

/path注:这个/path就是所要下载的文件的路径及名称,例:/home/linux⑵.6.30.4/arch/arm/boot/zimage写入完成后提示成功100%

xxxxxxx

bytes

ok可以把编译好的dnw拷贝到/usr/sbin下或是usr/bin下,以后使用就直接使用dnw

/path

便可。至此,完成内核的下载,下载文件系统一样的方法便可。注意:注意:有时候由于内核的升级,运行时会提示can

not

open

/dev/secbulk0的毛病,此时需要重新到secbulk目录履行$make

-c

/lib/modules/`uname

-r`/build

m=`pwd`

modules,然后加载模块$sudo

insmod

./secbulk.ko便可!

(责任编辑:IT教学网)

更多

推荐Illustrator教程文章