海思Hi3521/Hi3520A/Hi3520D/Hi3515A/Hi3515C U-boot 移植应用 开发指南

本文主要是介绍海思Hi3521/Hi3520A/Hi3520D/Hi3515A/Hi3515C U-boot 移植应用 开发指南,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文档主要介绍本在Hi3521/Hi3520A/Hi3520D/Hi3515A/Hi3515C单板上如何移植和烧写 U-boot(Hi3521 单板的 Bootloader)的相关操作及如何使用ARM 调试工具。

Hi3521单板的Bootloader 采用U-boot。当选用的外围芯片的型号与单板上外围芯片的型号不同时,需要修改 U-boot 配置文件,主要包括存储器配置、管脚复用。

1.2 U-boot 目录结构
U-boot 的主要目录结构如表 1-1 所示,详细目录说明请阅读 U-boot 目录下的 README文档。

表1-1 U-boot 的主要目录结构

2.1 概述
在 Hi3521 单板上所选用的外围芯片型号如下:
DDR SDRAM:K4B2G1646C-HCK0 
NAND Flash:TC58NVG1S3ETA00 
SPI Flash:FL128PIFL121QQ030 
如果选用的外围芯片不是以上型号时,需要适当修改 SDK 中的“osdrv/ 
tools/pc_tools/uboot_tools/”目录下的配置表格,对应的单板才能正常运行。

2.2 编译 U-boot 
当所有以上移植步骤完成后,就可以编译 U-boot,操作如下:
make ARCH=arm CROSS_COMPILE=arm-hisivXXX-linux- godarm_config //选择Hi3521 
make ARCH=arm CROSS_COMPILE=arm-hisivXXX-linux- godcare_config //选择Hi3520A 
make ARCH=arm CROSS_COMPILE=arm-hisivXXX-linux- hi3520d_config //选择Hi3520D/Hi3515A 
编译成功后,将在 U-boot 目录下生成 u-boot.bin。

其中 CROSS_COMPILE 表示工具链。文档中统一以 CROSS_COMPILE=arm-hisiXXX-linux-来
表示两种情况。
Hi35xx_V100R001C01SPCxxx 对应 uclibc,使用 uclibc 工具链时,CROSS_COMPILE=armhisiv100nptl-linux-。
Hi35xx_V100R001C02SPCxxx 对应 glibc,使用 glibc 工具链时,CROSS_COMPILE=armhisiv200-linux-。

2.3 配置 DDR 存储器
在 Windows 下打开 SDK 中的“osdrv/ tools/pc_tools/uboot_tools/”目录下的配置表格。
当选用不同的 DDR SDRAM 时,需要针对不同器件的特性,对配置工作表中的相关标签页进行修改。

2.4 配置管脚复用
如果管脚复用有变化,还需要对配置表格中的相关标签页进行修改。

2.5 生成最终使用的 U-boot 镜像
完成配置表格的修改后,保存表格。单击表格第一个标签页上的按钮“Generage reg bin file”,生成临时文件 reg_info.bin。
将临时文件 reg_info.bin 和编译 u-boot 得到的 u-boot.bin 都拷贝到 SDK 中的“osdrv/tools/pc_tools/uboot_tools/目录下,执行命令:
mkboot.sh reg_info.bin u-boot-hi3521_930MHz.bin
其中 u-boot-hi3521_930MHz.bin 就是能够在单板上运行的 U-boot 镜像。

目前是将 Hi3520D 和 Hi3515A/Hi3515C 做成一个 U-boot 镜像,需要将 Hi3520D、Hi3515A 表格生成的临时文件,分别命名为 reg_info_hi3520d.bin、reg_info_hi3515a.bin,然后将两个临时文件和编译好的 u-boot.bin 一起拷贝到 SDK 中的“osdrv/tools/pc_tools/uboot_tools/目录下,执行命令:mkboot-hi3520d.sh 
reg_info_hi3520d.bin reg_info_hi3515a.bin u-boot-hi3520d.bin 
需要特别注意 Hi3520D 的 reg_info 在前、15a 的 reg_info 在后,这个顺序不能随意更改。

在 u-boot 的代码段中需要预留 4800Byte 的空白区,用来存放 reg_info_hi3520d.bin、reg_info_hi3515a.bin 文件的内容,两个文件各占 2400Byte。由于受片内 RAM 的限制,预留空白区的大小最好不要超过 4800Byte,如果超过这个限制将会导致 FastBoot
无法正常烧写。如果确实需要预留超过 4800Byte 的空白区,可以考虑先用 FastBoot 工具烧写一个未超过 4800Byte 限制的 U-boot 镜像,然后通过网络把超过限制的 U-boot镜像烧进 Flash。

如果只需将 Hi3520D 或者 Hi3515A/Hi3515C 的 reg_info 文件放入 U-boot 镜像,需要把U-boot 目录下./include/configs/hi3520d.h 文件中的 ENABLE_HI3520D_BLANK 或者ENABLE_HI3515A_BLANK 宏注释掉即可。

为临时文件(reg_info_xxx.bin)预留的空白区的大小由宏 REG_INFO_BLANK_SIZE决定,默认是 2400,如果需要可以调整 REG_INFO_BLANK_SIZE 的大小。

如果想要把更多的临时文件放入 U-boot 镜像,需要以下步骤:
首先,需要修改./arch/arm/cpu/hi3520d/start.S54~61 行代码,具体代码如下:
__blank_zone_start: 
#ifdef ENABLE_HI3520D_BLANK 
.fill REG_INFO_BLANK_SIZE,1,0 /* 空白区*/ 
#endif 
#ifdef ENABLE_HI3515A_BLANK 
.fill REG_INFO_BLANK_SIZE,1,0 /* 空白区*/ 
#endif 
/* 在此处新增空白区 */ 
__blank_zone_end: 
其次,需要修改 osdrv/tools/pc_tools/uboot_tools/ mkboot-hi3520d.sh 文件,如下:
dd if=$1 of=./fb2 bs=2400 conv=sync 
dd if=$2 of=./fb3 bs=2400 conv=sync 
/* 可以在此处增加类似上面两个命令 */ 
dd if=./u-boot.bin of=./fb4 bs=1 skip=4864 /* 大小为 64 + 所有空白区的大小 */ 
cat fb1 fb2 fb3 fb4 > $3

3.1 概述
如果待移植单板中已有 U-boot 运行,则可以通过串口或网口与服务器连接,直接更新U-boot。
如果是第一次烧写,则需要通过网口使用 RVDS 工具进行烧写。由于芯片特性,必须有通过 RVDS 下载到单板的脚本,该脚本能够对存储器和芯片进行初始化。在  SDK 中提供了相应的初始化脚本,当选用了不同的外围芯片,则需要重新配置初始化脚本才能使用。

3.2 通过 bootrom 工具烧写 U-boot 
具体操作方式请参考《Fastboot 工具使用说明 Application Notes》。

3.3 两种 Flash 的 U-boot 烧写方法
3.3.1 SPI Flash 烧写方法
SPI Flash 烧写方法如下:
1. 在内存中运行起来之后在超级终端中输入:
hisilicon# mw.b 0x82000000 ff 0x100000 /* 对内存初始化*/ 
hisilicon# tftp 0x82000000 u-boot-hi3521_930MHz.bin /*U-boot下载到内存
*/ 
hisilicon# sf probe 0 /*探测并初始化SPI flash*/ 
hisilicon# sf erase 0x0 0x100000 /*擦除 1M大小*/ 
hisilicon# sf write 0x82000000 0x0 0x100000 /*从内存写入SPI Flash*/

这篇关于海思Hi3521/Hi3520A/Hi3520D/Hi3515A/Hi3515C U-boot 移植应用 开发指南的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python使用Reflex构建现代Web应用的完全指南

《Python使用Reflex构建现代Web应用的完全指南》这篇文章为大家深入介绍了Reflex框架的设计理念,技术特性,项目结构,核心API,实际开发流程以及与其他框架的对比和部署建议,感兴趣的小伙... 目录什么是 ReFlex?为什么选择 Reflex?安装与环境配置构建你的第一个应用核心概念解析组件

Spring Boot 集成 Solr 的详细示例

《SpringBoot集成Solr的详细示例》:本文主要介绍SpringBoot集成Solr的详细示例,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录环境准备添加依赖配置 Solr 连接定义实体类编写 Repository 接口创建 Service 与 Controller示例运行

Spring Boot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)

《SpringBoot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)》:本文主要介绍SpringBoot拦截器Interceptor与过滤器Filter深度解析... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现与实

C#通过进程调用外部应用的实现示例

《C#通过进程调用外部应用的实现示例》本文主要介绍了C#通过进程调用外部应用的实现示例,以WINFORM应用程序为例,在C#应用程序中调用PYTHON程序,具有一定的参考价值,感兴趣的可以了解一下... 目录窗口程序类进程信息类 系统设置类 以WINFORM应用程序为例,在C#应用程序中调用python程序

Java应用如何防止恶意文件上传

《Java应用如何防止恶意文件上传》恶意文件上传可能导致服务器被入侵,数据泄露甚至服务瘫痪,因此我们必须采取全面且有效的防范措施来保护Java应用的安全,下面我们就来看看具体的实现方法吧... 目录恶意文件上传的潜在风险常见的恶意文件上传手段防范恶意文件上传的关键策略严格验证文件类型检查文件内容控制文件存储

MyBatis分页插件PageHelper深度解析与实践指南

《MyBatis分页插件PageHelper深度解析与实践指南》在数据库操作中,分页查询是最常见的需求之一,传统的分页方式通常有两种内存分页和SQL分页,MyBatis作为优秀的ORM框架,本身并未提... 目录1. 为什么需要分页插件?2. PageHelper简介3. PageHelper集成与配置3.

Java实现视频格式转换的完整指南

《Java实现视频格式转换的完整指南》在Java中实现视频格式的转换,通常需要借助第三方工具或库,因为视频的编解码操作复杂且性能需求较高,以下是实现视频格式转换的常用方法和步骤,需要的朋友可以参考下... 目录核心思路方法一:通过调用 FFmpeg 命令步骤示例代码说明优点方法二:使用 Jaffree(FF

Python日期和时间完全指南与实战

《Python日期和时间完全指南与实战》在软件开发领域,‌日期时间处理‌是贯穿系统设计全生命周期的重要基础能力,本文将深入解析Python日期时间的‌七大核心模块‌,通过‌企业级代码案例‌揭示最佳实践... 目录一、背景与核心价值二、核心模块详解与实战2.1 datetime模块四剑客2.2 时区处理黄金法

CSS3 布局样式及其应用举例

《CSS3布局样式及其应用举例》CSS3的布局特性为前端开发者提供了无限可能,无论是Flexbox的一维布局还是Grid的二维布局,它们都能够帮助开发者以更清晰、简洁的方式实现复杂的网页布局,本文给... 目录深入探讨 css3 布局样式及其应用引言一、CSS布局的历史与发展1.1 早期布局的局限性1.2

Spring Boot项目打包和运行的操作方法

《SpringBoot项目打包和运行的操作方法》SpringBoot应用内嵌了Web服务器,所以基于SpringBoot开发的web应用也可以独立运行,无须部署到其他Web服务器中,下面以打包dem... 目录一、打包为JAR包并运行1.打包为可执行的 JAR 包2.运行 JAR 包二、打包为WAR包并运行