socfpga armv7 u-boot学习记录

2024-02-17 07:48
文章标签 学习 记录 boot armv7 socfpga

本文主要是介绍socfpga armv7 u-boot学习记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

https://blog.csdn.net/helonglong88/article/details/51209876

最近在学习altera的socfpga,写一下关于它的u-boot的学习心得。

关于altera的u-boot与linux的交叉编译环境可以在如下网页上查看:

http://www.alterawiki.com/wiki/Compiling_u-boot_and_Linux_Kernel_for_Cyclone_V_SoC

一、 u-boot编译环境的搭建:

下载编译软件: https://sourcery.mentor.com/GNUToolchain/package10928/public/arm-none-eabi/arm-2012.09-63-arm-none-eabi.bin
安装步骤如下:
1. sudo dpkg-reconfigure -plow dash //此步骤弹出对话框,要选择NO,即使用bash,不是dash
2. ls -lh /bin/sh //用来验证sh指向bash还是dash,应指向bash
3. sudo mkdir -p /usr/local/codebench_2012_09_63
4. sudo chown $USER.users /usr/local/codebench_2012_09_63/
5. echo "export PATH=/usr/local/codebench_2012_09_63/bin:\$PATH" >~/CodeBench_setup_linux.sh
6. /bin/sh arm-2012.09-63-arm-none-eabi.bin
 

 

二、u-boot安装编译下载步骤

从altera官方下载uboot原码 ftp://ftp.altera.com/outgoing/SoC_FPGA/ethernet_3.7/u-bootaltera-2012.10.tgz

1.tar xvzf u-boot-altera-2012.10.tgz  //Please make sure your PATH variable is set in the rightway so that thecompile tool armnone-eabi-gcc is available.
2. cd u-boot-altera-2012.10
3. export CROSS_COMPILE=arm-none-eabi-
4. ./MAKEALL socfpga_cyclone5
 

 

三、u-boot代码学习

3.1 socfpga芯片启动流程简介

socfpga的启动主要分为3步:首先执行片内ROM进行一般初始化,如一些外部载入设备的确定等基本信息,然后从外部存储器将preloader(u-boot-spl.bin)复制到片内RAM执行,执行完毕后将bootloader(u-boot.bin)从外部存储器复制到RAM中,跳转到uboot起始地址运行u-boot,u-boot将内核加载环境准备好后就复制内核映像到RAM中启动内核,u-boot使命完成。uboot编译后自动会生成uboot-spl.bin与u-boot.bin两个二进制文件。

socfpga的片内ROM固化了对nand flash,sd/mmc flash与spi flash的最基本支持。对于sd/mmc flash的支持是受限的,它不支持sd卡中有文件系统,支持两种方式MBR方式与RAW方式。由于固化的驱动不支持文件系统,因此在MBR模式下需要将存储preloader与bootloader的分区类型设置为0xA2,即无文件系统,芯片reset后选择SD/MMC启动方式(根据外部引脚电平设置选择),片内ROM经过简单初始化SD/MMC后,分别在MBR方式与RAW方式下去读取flash。若发现SD卡是MBR格式,则搜索类型为0xA2类型的分区,搜索到后读取该分区首地址开始的前64kB内容,即preloader,将其加载到片内RAM中,地址为0xFFFF0000,跳转到preloader的首地址,转移控制权,即PC指针指向了preloader。

3.2 u-boot代码启动流程简介

3.2.1 u-boot-spl启动流程

u-boot-spl代码与u-boot代码有很多是重合的。u-boot-spl的执行过程是start.s(位于/arch/arm/cpu/armv7/)——>board_init_f(位于/arch/arm/lib/board.c)——>board_init_r(位于/common/spl,完成环境变量、串口、DDR等初始化)——>spl_mmc_load_image(位于/drivers/mmc,这是从sd卡启动,从其他设备启动可以类推,将u-boot.bin加载到loadaddr地址)——>jump_to_image_no_args(位于/common/spl),跳转到u-boot的entypoint,一般与loadaddr相同。

3.2.2 u-boot启动流程

u-boot的启动流程也是从start.s开始,设置向量表等(位于/arch/arm/cpu/armv7/start.s)——>board_init_f(位于/arch/arm/lib/board.c)——>relocate_code(位于/arch/arm/cpu/armv7/start.s)——>board_init_r(位于/arch/arm/lib/board.c)——>main_loop (/common/main.c)——>run_command_list(位于/common/main.c)执行脚本命令“bootcmd”(/include/configs/socfpga_cyclone5.h中定义为"run mmcload; run mmcboot","run mmcload"与"run mmcboot"也定义在socfpga_cyclone5.h),内核开始加载并运行。

这篇关于socfpga armv7 u-boot学习记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Boot 3 整合 Spring Cloud Gateway实践过程

《SpringBoot3整合SpringCloudGateway实践过程》本文介绍了如何使用SpringCloudAlibaba2023.0.0.0版本构建一个微服务网关,包括统一路由、限... 目录引子为什么需要微服务网关实践1.统一路由2.限流防刷3.登录鉴权小结引子当前微服务架构已成为中大型系统的标

spring-boot-starter-thymeleaf加载外部html文件方式

《spring-boot-starter-thymeleaf加载外部html文件方式》本文介绍了在SpringMVC中使用Thymeleaf模板引擎加载外部HTML文件的方法,以及在SpringBoo... 目录1.Thymeleaf介绍2.springboot使用thymeleaf2.1.引入spring

在 Spring Boot 中使用 @Autowired和 @Bean注解的示例详解

《在SpringBoot中使用@Autowired和@Bean注解的示例详解》本文通过一个示例演示了如何在SpringBoot中使用@Autowired和@Bean注解进行依赖注入和Bean... 目录在 Spring Boot 中使用 @Autowired 和 @Bean 注解示例背景1. 定义 Stud

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

Spring Boot整合log4j2日志配置的详细教程

《SpringBoot整合log4j2日志配置的详细教程》:本文主要介绍SpringBoot项目中整合Log4j2日志框架的步骤和配置,包括常用日志框架的比较、配置参数介绍、Log4j2配置详解... 目录前言一、常用日志框架二、配置参数介绍1. 日志级别2. 输出形式3. 日志格式3.1 PatternL

如何使用Spring boot的@Transactional进行事务管理

《如何使用Springboot的@Transactional进行事务管理》这篇文章介绍了SpringBoot中使用@Transactional注解进行声明式事务管理的详细信息,包括基本用法、核心配置... 目录一、前置条件二、基本用法1. 在方法上添加注解2. 在类上添加注解三、核心配置参数1. 传播行为(

Spring Boot Actuator使用说明

《SpringBootActuator使用说明》SpringBootActuator是一个用于监控和管理SpringBoot应用程序的强大工具,通过引入依赖并配置,可以启用默认的监控接口,... 目录项目里引入下面这个依赖使用场景总结说明:本文介绍Spring Boot Actuator的使用,关于Spri

Spring Boot 整合 ShedLock 处理定时任务重复执行的问题小结

《SpringBoot整合ShedLock处理定时任务重复执行的问题小结》ShedLock是解决分布式系统中定时任务重复执行问题的Java库,通过在数据库中加锁,确保只有一个节点在指定时间执行... 目录前言什么是 ShedLock?ShedLock 的工作原理:定时任务重复执行China编程的问题使用 Shed

Spring Boot统一异常拦截实践指南(最新推荐)

《SpringBoot统一异常拦截实践指南(最新推荐)》本文介绍了SpringBoot中统一异常处理的重要性及实现方案,包括使用`@ControllerAdvice`和`@ExceptionHand... 目录Spring Boot统一异常拦截实践指南一、为什么需要统一异常处理二、核心实现方案1. 基础组件