当前位置:首页 > 嵌入式 > 嵌入式软件

1引言  linux具备良好的裁剪性和移植性,并且开源、资源丰富,已成为嵌入式系统的开发热点。一个完整的嵌入式linux系通通常包括bootloader、内核、文件系统三部分,目标板上电后由bootloader初始化硬件,引导内核和文件系统来启动linux。但由于在嵌入式开发中基于mips体系的bootloader较少,开发者在移植mips bootloader需花费大量精力。结合octeon3010(mips64)的u-boot移植经验,分析嵌入式linuxbootloader的工作原理及功能,设计了一个基于mips体系的bootloader模型。对octeon系列的mips处理器bootloader的设计具有参考价值和指导意义。  2 bootloader原理分析  bootloader是在运行操作系统内核前所执行的一段小程序。通过执行这段小程序,实现初始化硬件设备、建立内存空间的映射图,从而为系统的软硬件环境设置一个合适状态,以便为最终调用操作系统内核准备好正确环境。  大多数bootloader包含"启动加载"和"下载"两种操作模式。从最终用户来看,bootloader就是用来加载操作系统,而无工作模式区别。其中,启动加载模式是bootloader从目标机上的某个固态存储设备将操作系统加载到ram中运行,整个过程并没有用户介入。这种模式是bootloader的正常工作模式。而在下载模式下,目标机上的bootloader通过串口连接或网络连接从主机(host)下载文件,例如下载内核映像和根文件系统映像等。  由于实现bootloader依赖cpu的体系结构,因此大多数bootloader分为stage1和stage2两部分,并依赖于cpu体系结构的代码,例如:设备初始化代码等,通常放在stage1中,一般采用汇编语言。而stage2则通常采用c语言实现复杂功能,而且代码具有良好的可读性和移植性。stage1步骤通常包括:硬件设备初始化;为加载bootloader的stage2准备ram空间;拷贝bootloader的stage2到ram空间中;设置好堆栈;跳转到stage2的c入口点。bootloader的stage2步骤通常包括:初始化当前阶段使用的硬件设备;检测系统内存映射;将kernel映像和根文件系统映像从flash上读到ram空间中;为内核设置启动参数;调用内核。  3设计移植  3.1启动流程  针对具体的硬件内容,详细分析u-boot的启动流程后,给出启动流程中需要修改的代码。  3.2移植分析  片级移植主要是针对具体cpu初始化代码的修改,针对对应的mips平台,主要包括:通用寄存器的初始化、cp0的初始化(status,config,watch,count,compare,etc.)、watchdog初始化、cache初始化、tlb初始化。板级移植包括:串口驱动、flash读写驱动(nor,nand)、hd读写驱动、网卡驱动。而功能层扩展可根据需求添加新功能或裁减优化,包括调试功能、启动功能、下载功能等。  3.3修改代码  主要修改的代码为:makefile添加开发板的编译支持;include/configs/myboard.h开发板的定义,启动参数等;cpu/mips/start.s修改初始化代码和入口;board/myboard/flash.c对应的nor flash驱动;board/myboard/myboard.c对应的板级初始化代码;board/myboard/lowlevel_init.s初始化硬件的汇编代码;board/myboard/serial.c串口驱动。  4 octeon系列cpu的硬件初始化实例  4.1开发环境及硬件平台简介  采用的是宿主机+目标板的开发模式,宿主机为pc+fc6,目标板的cpu采用基于mips64 v2体系结构的处理器octeon_cn3010,nor flash采用amd公司8 mb的am-29dl640g.sdram采用三星公司512 mb的m378t6553cz3-cd5(64 mb×8 bit)。存储部分的硬件连接如图1所示。
  4.2具体实现代码  系统的起始地址统一规定为0xbfc00000,加电后,cpu从该地址开始执行。该地址也就是系统异常处理向量表的第一项(reset)。0xbfc00000处的中断向量表起始处的跳转命令,跳到了inittlbstart中,完成了系统的大部分初始化,例如设置寄存器、cpu、sdram、flash等。以下为具体程序代码:
  系统完成初始化后,跳转到board.c。在board.c中的checkboard()函数将进一步设置cpu、sdram、cache、串口等,并将硬件初始化代码从flash拷贝到sdram中继续运行,最后调用main_loop()函数,进入bootloader的第一个c函数-main_loop()函数,在这个函数中将初始化硬件平台相关的参数、模块,并优化参数,设置loader参数等硬件初始化。  4.3 bootloader的烧录和启动  使用flash烧录器把生成的u-boot.bin文件烧录到flash后,将其放人目标板的flash槽。目标板通电后,串口输出数据。至此,bootloader被成功移植。  5结语  通过分析引导转载系统在嵌入式linux系统中的工作原理及功能,结合移植经验,设计了一个基于mips体系

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

德国康佳特亮相上海工博会,展示多款应用就绪的嵌入式解决方案平台

关键字: 嵌入式 传感器 处理器

双方携手为客户打造以存储为核心的模块化基础架构,支持先进的多裸片架构设计

关键字: 非易失性存储 半导体 嵌入式

本届年会将在上海(11月13-14日)、北京(11月19-20日)和深圳(11月27-28日)举行,面向嵌入式设计工程师推出25门技术课程

关键字: 嵌入式 MCU 模拟

上海2025年9月5日 /美通社/ -- 由纽伦堡会展(上海)有限公司举办的上海国际嵌入式会议将于 2025 年 10 月 16-17 日在上海世博展览馆举办。 此次会议将由三个版块组成:嵌入式技术会议、汽...

关键字: 嵌入式 CE CHINA EMBEDDED

从外部看,电子系统仿佛一个统一的学科或设备,各组成部分协同工作,浑然一体。然而揭开表象,其内在却是另一番景象:一个碎片化、多层次的世界——其中每一层都独立且复杂,衍生出各自特有的工具、专家、工作流程,甚至哲学体系。

关键字: 嵌入式 电子系统 半导体

8位单片机在嵌入式设计领域已经成为半个多世纪以来的主流选择。尽管嵌入式系统市场日益复杂,8位单片机依然不断发展,积极应对新的挑战和系统需求。如今,Microchip推出的8位PIC®和AVR®单片机系列,配备了先进的独立...

关键字: 单片机 嵌入式 CPU

深圳2025年8月28日 /美通社/ -- 8月26日,2025 ELEXCON深圳国际电子展盛大启幕。本届大会以"All for AI"为主题,深圳市德...

关键字: AI 工业级 SSD 嵌入式

深圳2025年8月26日 /美通社/ -- 8月26日,由博闻创意会展主办的 第22届深圳国际电子展暨嵌入式展(elexcon2025)在深圳(福田)会展中心隆重开幕。 作为中国电子与嵌入式技术领域的专业大展,本届展会...

关键字: 嵌入式 电子 高通 AI

模块化设计作为一种将系统拆分为独立、可复用组件的方法,能够在低代码平台中实现功能的灵活组合,并最大限度地提升系统性能。本文将探讨如何通过模块化设计,使得低代码平台既能快速适应变化,又能保持高效稳定的运行。

关键字: 模块化设计 嵌入式

CPU亲和度通过限制进程或线程可以运行的CPU核心集合,使得它们只能在指定的CPU核心上执行。这可以减少CPU缓存的失效次数,提高缓存命中率,从而提升系统性能。

关键字: Linux 嵌入式
关闭