笔记整理—uboot启动过程(7)malloc初始化与内存环境变量

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

        上一章说到了env环境变量并对前两章有关init_sequence部分做了总结,这一章将要对uboot部分的malloc初始化以及内存环境变量进行相关的说明。

        mem_malloc_init是用于初始化uboot堆管理器的。自己维护了一段内存,就可用进行malloc和free的操作了。那么这个维护的堆大小是多少呢?

CFG_UBOOT_BASE+CFG_UBOOT_SIZE-CFG_MALLOC_LEN-CFG_STACK_SIZE

        给堆留了896Kb的大小,并在其中将这段内存进行清理。

memset((void*)mem_malloc_start,0,mem_malloc_end-mem_malloc_start);

        Board specific开发板特别初始化。以#if配合CONFIG_xxx进行条件编译。

#if define(CONFIG_X210)
#if define(CONFIG_GENERIC_MMC)//用MMC/sd卡启动

        mmc_initialize(gd->bd):MMC相关基础初始化(SD/MMC控制器)源与内核。

        INIT_LIST_HEAD:用链表进行管理(&mmc_devices)。        

        set_hsmmc_clock()给sd卡控制器时钟。

        set_hsmmc_cfg_gpio() mmc的gpio初始化。

        smdk_s3c_hsmmc_init() 驱动控制器。

        IROM中进行的简单初始化,这个初始化是不完整的所以要在这个进行全面的初始化控制器。

         

         

        1个扇区512字节,最后得出nMB。

        DATAFLASH:SPI/I2C的FLASH如E2PROM,在X210开发板上是没有的。

        env_relocate()完成从SD卡到DDR中的读取环境变量。

        ENV_IS_EMBEDDED内嵌环境变量,在代码段中(本版本放在SD卡中)。

        env_ptr=(env_t*)malloc(CFG_ENV_SIZE)给环境变量开辟内存。

        做env CRC校验失败,于是使用uboot的默认env,被写入DDR中,并写入一份到sd卡的env扇区,下次再次开机就能从env分区得到env变量使得CRC校验成功。

        set_default_env设置默认env,在其中做变量移动与CRC更新gd_env=1。

        env_relocate_spec环境变量重定位。其内部使用movi_read_env()实现。raw_area_control原始分区信息表,gd_env_addr=(ulong)&(env_ptr->data)使用该方法将环境变量赋值到全局环境变量。

        本章讲述了一些关于uboot的BL2部分的malloc初始化以及相关内存环境变量的重定位,下一章将会对uboot的其余剩余部分进行讲解(直到uboot的第二部分结束)。 

这篇关于笔记整理—uboot启动过程(7)malloc初始化与内存环境变量的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

Nexus安装和启动的实现教程

《Nexus安装和启动的实现教程》:本文主要介绍Nexus安装和启动的实现教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Nexus下载二、Nexus安装和启动三、关闭Nexus总结一、Nexus下载官方下载链接:DownloadWindows系统根

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

Java中实现线程的创建和启动的方法

《Java中实现线程的创建和启动的方法》在Java中,实现线程的创建和启动是两个不同但紧密相关的概念,理解为什么要启动线程(调用start()方法)而非直接调用run()方法,是掌握多线程编程的关键,... 目录1. 线程的生命周期2. start() vs run() 的本质区别3. 为什么必须通过 st

Redis过期删除机制与内存淘汰策略的解析指南

《Redis过期删除机制与内存淘汰策略的解析指南》在使用Redis构建缓存系统时,很多开发者只设置了EXPIRE但却忽略了背后Redis的过期删除机制与内存淘汰策略,下面小编就来和大家详细介绍一下... 目录1、简述2、Redis http://www.chinasem.cn的过期删除策略(Key Expir

详解Linux中常见环境变量的特点与设置

《详解Linux中常见环境变量的特点与设置》环境变量是操作系统和用户设置的一些动态键值对,为运行的程序提供配置信息,理解环境变量对于系统管理、软件开发都很重要,下面小编就为大家详细介绍一下吧... 目录前言一、环境变量的概念二、常见的环境变量三、环境变量特点及其相关指令3.1 环境变量的全局性3.2、环境变

MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)

《MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)》掌握多表联查(INNERJOIN,LEFTJOIN,RIGHTJOIN,FULLJOIN)和子查询(标量、列、行、表子查询、相关/非相关、... 目录第一部分:多表联查 (JOIN Operations)1. 连接的类型 (JOIN Types)

Oracle修改端口号之后无法启动的解决方案

《Oracle修改端口号之后无法启动的解决方案》Oracle数据库更改端口后出现监听器无法启动的问题确实较为常见,但并非必然发生,这一问题通常源于​​配置错误或环境冲突​​,而非端口修改本身,以下是系... 目录一、问题根源分析​​​二、保姆级解决方案​​​​步骤1:修正监听器配置文件 (listener.