首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Uboot 大全 | uboot 启动流程(二)

为了方便对硬件和驱动的管理,uboot还引入了类似linux内核的设备树和驱动模型特性。...文件,并通过以下命令将它们连接为最终的uboot.bin文件: cat u-boot-nodtb.bin u-boot.dtb >uboot.bin 驱动模型DM U-boot驱动模型与linux的设备模型比较类似...环境变量 环境变量可以为uboot提供在运行时动态配置参数的能力,如在命令行通过修改环境变量bootargs可以改变内核的启动参数。它以env=value格式存储,其中每条环境变量之间以’\0’结尾。...board_init_r流程 board_init_r是uboot重定位后需要执行的流程,它包含基础模块、硬件驱动以及板级特性等的初始化,并最终通过run_main_loop启动os会进入命令行窗口。...还有待于完善 do_bootcmd 加载linux内核

1.4K40

Uboot 大全 | uboot 启动流程(一)

– BL32 – BL33(uboot),即在bl32启动完成后再启动ubootuboot作为启动链中作为最后一级镜像,用于启动最终的os。...因此默认情况下uboot并不需要与atf共同启动,而其自身就被设计为支持完整的多级启动链,该启动链被设计为最多可包含spl、tpl和uboot三个阶段。...若不需要支持tpl,则uboot的典型启动流程可精简为如下方式(这也是uboot最常见的运行方式): 对于有些启动速度要求较高的场景,可以进一步简化其启动流程。...如可将其设计为下面这种跳过uboot,直接通过spl启动操作系统的方式,此时其启动流程如下: Atf与U-boot组合方式启动 若系统需要支持secure和non secure两种执行状态,则必须要从...spl初始化流程在另一篇文章中已经做了较详细的介绍,> 故文本将主要介绍uboot特有部分的内容,其它代码只做简要分析。

3.2K30
您找到你想要的搜索结果了吗?
是的
没有找到

Uboot到底如何启动内核

1.uboot启动内核的代码缩减如下: Uboot 1.16/lib_arm/board.c中start_armboot()函数调用/common/main.c中main_loop()函数,在main_loop...使用在/lib_arm/bootm.c定义的do_bootm_linux(),我们已经知道入口地址,只需跳到入口地址就可以启动linux内核了,在这之前需要做一件事———— uboot传递参数(启动参数...启动代码在do_bootm_linux()函数: void (*theKernel)(int zero, int arch,uint params);  //定义函数指针theKernel theKernel...tag结构体,所谓的设置传递参数其实就是初始化这些tag的值,想了解这个结构体以及这些tag的值是如何设置的请看嵌入式Linux应用开发完全手册的uboot章节 我们来看setup_start_tag...更多uboot启动内核的细节观看毕业班视频自己写uboot

1.4K10

26000字剖析uboot启动过程

更好的阅读体验请见: uboot启动流程分析汇编阶段最先执行的是汇编文件start.S,这个文件跟架构有关,例如芯片架构是arm926ejs,那路径就在*arch/arm/cpu/start.S*。...初始化shell环境,我们可以在uboot里执行相关的命令,跟在linux上执行命令类似 cli_init(); run_preboot_environment_command();#if defined...启动内核前会有个倒计时,如果我们在这个倒计时前中断,就可以停在uboot设置环境变量里,就可以做修改环境变量、升级、更新镜像、用相关命令调试等。...跳转到内核镜像的地址执行 **kernel_entry(0, machid, r2);** }#endif}到此uboot的正常启动流程就结束了。...uboot启动流程面试中经常会问到,因此熟悉它是非常必要的。

1.6K21

一.linux开发之uboot移植(一)——初识uboot

(所以uboot启动了内核后uboot自己本身就死了,要想再次看到 uboot界面只能重启系统。...重启并不是复活了刚才的uboot,重启只是uboot的另一生) 2. **uboot的入口就是开机自动启动uboot的唯一出口就是启动内核** 。...uboot还可以执行很多别的任务(譬如烧录系统),但是其他任务执行完后都可以回到uboot的命令行继续执行uboot命令,而启动内核命令一旦执行就回不来了 二、uboot的工作模式 * U-Boot的工作模式有启动加载模式和下载模式...串口控制台的波特率 netmask 以太网的网络掩码 ethaddr 以太网的MAC地址 bootfile 默认的下载文件名 bootargs 传递给Linux内核的启动参数 bootcmd 自动启动时执行命令...给kernel传参:bootargs(内核移植中必定使用) (1)linux内核启动时可以接收uboot给他传递的启动参数,这些启动参数是uboot和内核约定好的形式、内容,linux内核在这些启动参数的指导下完成启动过程

92430

全志 Linux 系统启动优化 启动优化速度方式 优化启动流程 优化uboot 优化kernel等

2.2.4 bootchart bootchart是一个用于linux启动过程性能分析的开源软件工具,在系统启动过程自动收集CPU 占用率、进程等信息,并以图形方式显示分析结果,可用作指导优化系统启动过程...2.3.2 uboot启动优化 uboot主要功能是引导内核、量产升级、电源管理、开机音乐/logo、fastboot刷机等。...2.3.2.8 uboot重定位 目前的启动过程中,uboot在执行过程中会进行一次重定位,可以在串口中打印出这个值,然后 修改uboot的加载地址使得boot0将uboot加载进DRAM的时候就直接加载到这个地址...3 Tina启动速度优化 Tina中启动优化主要依靠宏CONFIG_BOOT_TIME_OPTIMIZATION来完成,该宏会进行如 下工作: 调整Linux内核镜像的压缩方式,调整rootfs的压缩方式...如下: Linux内核镜像压缩方式从GZIP换成LZO,优化> 0.2s。

3K30

【专业技术】Android 启动性能优化 - uboot

时间测量 在mx51平台的uboot里,使用get_timer可以获得比较精确的计时,get_timer的使用贯穿了uboot性能调整的整个过程。...性能优化方法 减小uboot镜像的大小,去掉不需要的驱动,不需要的命令,减少uboot的大小可以从两个方面获得好处,首先会节省驱动初始化时间,其次会使uboot镜像变小,从磁盘读取uboot镜像所需的时间也变小了...IO占据了uboot启动时间的大部分,这部分的优化是必须的。 合并kernel和ramdisk镜像的读取过程,一次读取两个镜像,这样可以合并两次启动IO开销为一次。...结论 uboot启动过程 读取kernel 和ramdisk镜像的IO占了较大部分时间,优化的上限可以参考IO设备的速度上限;其他部分优化后总占用时间不应该超过100ms。...在我的开发板上,优化后启动时间大概为300多ms,其中load image大概为200ms 文章转载自:罗索实验室 [http://www.rosoo.net/a/201208/16227.html]

1.6K80

海思uboot启动流程详细分析(一)

2. normal_start_flow流程 这里是正常启动流程 normal_start_flow: /* set stack for C code */ ldr x0, =(...bne ufs_boot //如果不是,则进入ufs_boot 4. ziju_flow流程 自举模式从这里我可以推断出,芯片的启动分为两种,一种是自举模式也就是本地的spiflash或...nand或emmc等启动,另一种就是pcie启动模式。...不同启动模式对应不同的启动流程。但不同启动模式代码是相互交织的,需要分清楚! 1) 初始化PLL和DDRC控制器和管脚复用情况。...,也包括是冷启动还是热启动 串口初始化 DDR初始化和DDR training 正常启动时,会检测启动方式,对代码进行相应的拷贝,重定位 设置堆栈 清bss段 跳转到第二阶段,即C语言阶段

2.6K50

海思uboot启动流程详细分析(二)

并通过对启动流程的简单分析,掌握u-boot移植的基本方法。 2. 多平台架构 这些问题的本质,是软件工程中的抽象和封装,以最简洁、最高效的方式,实现尽可能多的功能。...基于图片1的架构,u-boot和平台有关的初始化流程,显得比较直观、清晰: 1)u-boot启动后,会先执行CPU(如armv8)的初始化代码。...board_init_f() - this is almost never needed - return normally from this function 海思的和原生uboot...如果使用了SPL功能,u-boot的启动流程通常是: ROM code加载SPL并运行; SPL进行必要的初始化之后,加载u-boot并运行; u-boot进行后续的操作。...4.2 配置项总结 经过第3章的流程分析,我们可以总结出和“平台相关部分的启动流程”有关的配置项,记录如下: CONFIG_SYS_RESET_SCTRL,控制是否在启动的时候reset SCTRL寄存器

2.4K20

uboot 解析

uboot 执行流程 uboot 属于bootloader(引导程序)的一种,是用来引导启动内核的,它的最终目的就是,从flash中读出内核,放到内存中,启动内核。...uboot刚开始被放到flash中,板子上电后,会自动把其中的一部分代码拷到内存中执行,这部分代码负责把剩余的uboot代码拷到内存中,然后uboot代码再把kernel部分代码也拷到内存中,并且启动,...start_arm_boot的主要流程为,设置机器id,初始化flash,然后进入main_loop,等待uboot命令; uboot启动内核,主要经过两个函数,第一个是s=getenv(“bootcmd...uboot启动的内核为uImage,这种格式的内核是由两部分组成:真正的内核和内核头部组成,头部中包括内核中的一些信息,比如内核的加载地址,入口地址。...uboot在接受到启动命令后,要做的主要是: 【1】读取内核头部, 【2】移动内核到合适的加载地址, 【3】启动内核,执行do_bootm_linux do_bootm_linux主要做的为:

97630

Uboot学习(二)之Uboot能够实现哪些功能

举个例子来说,Uboot 可以支持 嵌入式 Linux 系统的引导启动,同时它也支持 NetBSD ,VxWorks , android 等嵌入式操作系统,而且它还能支持 MIPS 、x86 等常用系列的处理器...现在一般来说,Uboot对 PowerPC 系列处理器支持最为完整丰富,对 Linux 系统支持最为完善。所以总的来说,Uboot 的可移植性非常好。...的启动设计来设计uboot; 而且Uboot 必须进行和硬件相对应的代码级别的更改和移植,才能够保证可以从相应的启动介质启动Uboot 中第一阶段的 start .s 文件中具体处理了这一块。...二、能够引导操作系统内核启动并给内核传参: Uboot的最终目的是为了启动内核;Linux 内核在设计的时候,设计为是可以被传参的,也就是说我们可以在 Uboot 中事先给 Linux 内核准备一些启动参数放在内存中特定位置...,然后再传给Linux内核,Linux内核启动后就会到这个特定的位置拿 Uboot传给它的参数,然后再 Linux 内核中解析这些参数,这些参数将被用来指导 Linux内核的启动过程。

1.3K30
领券