Linux Uboot 打印系统时间的方法 (linux uboot打印系统时间)

如何使用Linux Uboot打印系统时间?

在Linux系统中,Uboot是一个很重要的组件,它是个可移植的bootloader,主要用来引导操作系统的启动。在Uboot中,有很多自定义的指令可以帮助我们实现我们想要的功能。今天,我们来探讨一下如何使用Uboot打印系统时间。

步骤一:配置串口

在我们开始之前,我们需要先在Uboot中配置串口,这样我们才能通过串口打印输出信息。具体步骤如下:

1. 我们需要在Uboot中找到串口配置文件。在Uboot的配置文件中,一般在“include/configs/”下面,可以找到与我们使用的板子相对应的配置文件。

2. 打开配置文件,在文件中搜索“SERIAL_ PORT”,我们可以看到这是关于串口的配置。一般来说,我们需要配置对应的串口设备号、波特率等参数。

3. 根据自己的需要进行调整,在完成配置之后保存配置文件,重新编译Uboot。

步骤二:在Uboot中打印系统时间

接下来,我们将使用Uboot提供的一些指令,来打印系统时间。具体步骤如下:

1. 在Uboot中进入命令行界面。可以通过串口连接之后按下“Ctrl+C”进入Uboot的命令行模式。

2. 然后,在命令行中输入“printenv”,这将打印Uboot的环境变量。我们可以看到其中包含一些系统设置,比如bootargs(Linux内核启动参数)等。

3. 接下来,我们要使用Uboot提供的“date”命令来获取系统当前的时间。直接在命令行中输入“date”,系统就会返回当前的时间。

4. 如果你想获取更详细的时间信息,可以通过命令“date -u”来获取UTC时间。这需要我们的板子已经连接到了网络。

5. 如果你希望在启动时自动打印系统时间,可以在Uboot的启动脚本中添加打印时间的命令,比如“echo ‘current time:’ ; date”。

通过这些步骤,我们就可以很容易的在Uboot中打印系统时间。同时,我们也可以在Uboot中利用其它自定义的指令,实现我们想要的功能。在操作Uboot时,一定要小心谨慎,以免错误操作导致系统崩溃。

相关问题拓展阅读:

linux系统如何传递信息给uboot

建立一个裸分区保存所有你陵扮哗想要的信息,尺行使得boot/kernel都有读写能力,我就缺乎是这么干的。

Linux启动后U-Boot就基本没有用了。U-Boot将一些信息传给Linux,纤薯然后引导Linux。

不知道你的U-Boot能不能进入命毁扰者令行界面?你可以修改Linux的MTD分区,将新的Linux和文件系统烧写在其他的MTD分李哪区,然后在U-Boot中引导新的linux和文件系统。

#make at91rm9200dk_config

#make oldcnofig //使用dk板默认配置

如果想定制,可以继续执行

#make menuconfig

#make Image

#/usr/local/arm/2.95.3/bin/arm-linux-objcopy -O binary -S vmlinux linux.bin

#gzip -v9 linux.bin

#mkimage -A arm -O linux -C gzip -a 0xe 0xd linux.bin.gz uImage

这样我们得到了Linux启动压缩内核uImage,默认运行地址为0x,

还有一个RAM启动盘-名字为ramdisk-rmk7,在普通的PC机上叫initrd-2.4.20-8.img,在

/boot/grub/menu.lst文件中,我们可以看到它的使用方法穗闭:

***********************

root (hd0,6)

kernel /boot/vmlinuz-2.4.20-8 ro root=LABEL=/ ##########内核文件

initrd /boot/initrd-2.4.20-8.img##########RAM启动盘文件

***********************

ramdisk-rmk7的默认运行地址为0x,

只要有上边的两个文件,Linux内核就能够正常的工作了。

uBoot中进行如下设置

Uboot > tftpuImage##########装载内核到内存处

Uboot > tftpramdisk-rmk ##########装载RAM启动盘到处

Uboot > setenv bootargs root=/dev/ram rw initrd=0x,ramdisk_size=15360 console=ttyS0,mem=32M

Uboot > bootm

如上是通过tftp直接将内核文件uImage和RAM启动盘加载到内存中,然后运行,下面讲讲如何

将这两个文件固化到Flash中,然后通过Flash进行加载启动:

1)将RAM启动盘固化到c为起始地址的Flash中

U-Boot > tftpPATH/ramdisk-rmk7

U-Boot > cp.bcramdisk_size

2)将uImage内核镜像固陆衫化到紧跟RAM盘存储空间之后

U-Boot > tftpPATH/uImage

U-Boot > cp.bc+ramdisk_size image_size

3)存储之后,就要配置uBoot启动加载参数了

U-Boot > setenv ramdisk cp.b c00 ramdisk_size

U-Boot > setenv image cp.b c+ramdisk_sizeimage_size setenv boot bootm

U-Boot > setenv bootcmd run ramdisk\早族腔; run image\; run boot

U-Boot > saveenv

U-Boot > run bootcmd

*************************************************

arch/arm/Makefile

//内核运行虚拟地址TEXTADDR = 0xC

*************************************************

arch/arm/boot/Makefile

//内核加载地址ZRELADDR = 0x

*************************************************

arch/arm/boot/compressed/Makefile

//自解压程序地址ZTEXTADDR = 0x

(linux-2.4.19-rmk7内核的自解压函数gunzip位于

/lib/inflate.c中,为gzip-1.0.3版本,现在在PC上使用gzip

函数压缩出来的文件不能被gzip-1.0.3版本的gunzip识别,所以linux-2.4.19-rmk7

内核自解压的功能等于不能使用,默认值ZTEXTADDR= 0x

表示不使用。(只能通过uBoot的gunzip解压加载)

***********************************************

//uImage存放地址= 0x

***********************************************

mkimage -A arm -O linux -C gzip -a 0xe 0xd linux.bin.gz uImage

-A:CPU类型

-O:操作系统

-C:采用的压缩方式

-a:内核加载地址

-e:内核入口地址

***********************************************

uBoot的do_bootm(cmd_tbl_t *cmdtp, int flag, int argc, char *argv);

函数将检验存放到0x地址处的经过mkimage格式化的uImage数据的头部

typedef struct image_header {

uint32_t ih_magic; /* Image Header Magic Number */

uint32_t ih_hcrc; /* Image Header CRC Checksum */

uint32_t ih_time; /* Image Creation Timestamp */

uint32_t ih_size; /* Image Data Size */

uint32_t ih_load; /* Data Load Address */

uint32_t ih_ep; /* Entry Point Address */

uint32_t ih_dcrc; /* Image Data CRC Checksum */

uint8_t ih_os; /* Operating System */

uint8_t ih_arch; /* CPU architecture */

uint8_t ih_type; /* Image Type */

uint8_t ih_comp; /* Compression Type */

uint8_t ih_name; /* Image Name */

}image_header_t;

(ih_ep值为0x,ih_load值为0x)

如果头部各个域值和crc合法,那么do_bootm将调用如下gunzip解压函数对

0x+sizeof(image_header_t)地址处的压缩内核进行解压:

gunzip((void*)ntohl(hdr->ih_load),0x400000,data,(int*)&len);

1.hdr->ih_load 为输出数据地址0x

2.0x为gunzip解压输出数据上限值-4M

3.data为输入数据地址data=0x+sizeof(image_header_t);

4.Len为输入数据长度len = ntohl(hdr->ih_size );

解压完成后将会存储解压后数据的实际大小

压缩的Linux内核文件uImage,经由gunzip解压函数后,通过

do_bootm_linux (cmdtp, flag, argc, argv,addr, len_ptr, verify);

函数向Linux内核传递内核运行所需的5个参数

kernel = (void (*)(bd_t *, ulong, ulong, ulong, ulong))hdr->ih_ep ;

1.hdr->ih_ep 为0x

/*

* Linux Kernel Parameters:

* r3: ptr to board info data

* r4: initrd_start or 0 if no initrd

* r5: initrd_end – unused if r4 is 0

* r6: Start of command line string

* r7: End of command line string

*/

(*kernel) (kbd, initrd_start, initrd_end, cmd_start, cmd_end);

linux SD卡启动uboot不正常

通过dd命令制作镜像, 是看不到写入的镜拦冲派像文件的。

能够看到的,是镜像文件里简贺面包判携含的内容。

linux uboot打印系统时间的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux uboot打印系统时间,Linux Uboot 打印系统时间的方法,linux系统如何传递信息给uboot,linux SD卡启动uboot不正常的信息别忘了在本站进行查找喔。


数据运维技术 » Linux Uboot 打印系统时间的方法 (linux uboot打印系统时间)