笔记整理—uboot启动过程(5)BL2板级初始化

2024-08-25 17:52

本文主要是介绍笔记整理—uboot启动过程(5)BL2板级初始化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

         上一章说到了uboot在BL2阶段大概都要干什么,也说到了为了实现这些要先进行内存排布,实现了这些后便可实现BL2部分的板级初始化。首先先来看一下init_fnc_ptr函数指针。

for(init_fnc_ptr=init_sequence;*init_fnc_ptr;++init_fnc_ptr){if((*init_fnc_ptr)()!0){hang();}
}

        init_fnc_ptr是一个二重(函数)指针。

        init_sequence是一个函数指针数组,存了许多个函数指针类型为init_fnc_t类型特征为返回值int类型,输入void。

        init_fnc_ptr 二重指针,能指向函数指针数组。

        结束于(*init_fnc_t)开始于init_sequence[]第一个函数地址,没有函数就结束,每for一次,指针指向下一个函数。在init_sequence的最后一个值为NULL,所以其结束于NULL。

        通过去用指针指向函数名,去一个个执行函数(遍历),遍历数组的方法有两种:1.下标法。2.在最后放一个flag(NULL)像是字符串‘\0’。

        由于数组中全是函数指针所以以NULL结束,这样做的好处是不用去人为的统计数组元素。

        所调用的if((*init_fnc_ptr)()!0)的所有函数,正确的时候都会返回值为0,执行不正确时返回-1,如果有执行失败则hang()挂起。

        init_fnc_t是负责进行板级初始化的init函数。其中包括cpu_init以及bord_init。cpu_init(),cpu初始化在start.S中已经结束了,所以一般为空函数。bord_init()是相关开发板的板级初始化相关函数,对于X210而言,将DECLARE_GLOBAL_DATA_PTR进行声明,这是一个宏,是为了使用相关的gd。在bord_init()中初始化网卡CONFIG_DRIVER_DM9000,这是一个DM9000的配置宏,dm9000_pre_init()不是驱动,而是gpio等硬件的相关。

        bord_init()中初始化DDR,第二次初始化的DDR与lowlevel_init中不同,在当时DDR进行的硬件初始化,现在互补性的是软件层次的初始化,如属性、地址设置等让uboot知道有几个DDR、地址起始等,使用宏去进行这些软件级别的初始化。

        PC上的BIOS能去自动读取硬件信息是因为有标准化的规定。而X210是使用PHYS_SDRAM_1宏进行初始化(是一个标准宏,可以改值,但别改名)。

        bi_boot_params(不是DDR)是用于相关DDR传参到kernel的,其中信息包括:

CONFIG_NR_DRAM_BANKS    几片内存
SDRAM_BANK_SIZE         内存大小
PHYS_SDRAM_1            1号基地址
PHY_SDRAM_1_SIZE        1号片大小
PHYS_SDRAM_2            2号基地址
PHY_SDRAM_2_SIZE        2号片大小
等等

        bd->bi_arch_number就是开发板机器码,用处就是uboot与内核进行适配,因为嵌入式的设备有着高度的定制化所以内核不会与别的开发板正常适配。所以需要开发板、uboot、kernel进行机器码对比,对于x210设备的机器码为2456,这个数字非法,但是能用。

        bd->bi_boot_params是uboot给kernel传递了一些内存地址与信息(其实就是放某些地址)0x30000100<-PHYS_SDRAM_1+0x100。

        uboot传给kernel的三个参数就放在r0、r1、r2中。

        interrupt_init看似像是与中断相关,但实际上在x210中是用于初始化timer4定时器。

        在PWM设置中,Timer0~3都可以输出PWM波形,但Timer4没有引脚输出,只有TCNTB没TCMPB且No PIN。可见Timer4就不是用于输出PWM波形的这个计算器是用作计时的。

        TCONB定时次数(每一次时间由时钟决定),定时时间/基准时间=TCONB,用TCNT0去观察TCONB有没有减到0,当到0时TCONT0可观察到。

        Timer4没有中断,所以cpu要论调方法进行查看TCONT0。uboot中定时,就是通过Timer4做定时,不可做别的事,如bootdelay(其处理回车就是轮询实现的)。

        Timer4在初始化中定时10ms:get_PCLK();得到66Mhz/(16*100)=TCONTB然后自动重装载就可以了,但是开始的时候还是要进行一次手动装载。

        这一章先写到这,主要说了一下BL2的板级初始化,和Timer4用来干什么的。下一章说一下env_init与环境变量初始化相关的内容。

这篇关于笔记整理—uboot启动过程(5)BL2板级初始化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1106246

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

作业提交过程之HDFSMapReduce

作业提交全过程详解 (1)作业提交 第1步:Client调用job.waitForCompletion方法,向整个集群提交MapReduce作业。 第2步:Client向RM申请一个作业id。 第3步:RM给Client返回该job资源的提交路径和作业id。 第4步:Client提交jar包、切片信息和配置文件到指定的资源提交路径。 第5步:Client提交完资源后,向RM申请运行MrAp

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

springboot3打包成war包,用tomcat8启动

1、在pom中,将打包类型改为war <packaging>war</packaging> 2、pom中排除SpringBoot内置的Tomcat容器并添加Tomcat依赖,用于编译和测试,         *依赖时一定设置 scope 为 provided (相当于 tomcat 依赖只在本地运行和测试的时候有效,         打包的时候会排除这个依赖)<scope>provided

内核启动时减少log的方式

内核引导选项 内核引导选项大体上可以分为两类:一类与设备无关、另一类与设备有关。与设备有关的引导选项多如牛毛,需要你自己阅读内核中的相应驱动程序源码以获取其能够接受的引导选项。比如,如果你想知道可以向 AHA1542 SCSI 驱动程序传递哪些引导选项,那么就查看 drivers/scsi/aha1542.c 文件,一般在前面 100 行注释里就可以找到所接受的引导选项说明。大多数选项是通过"_

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识