深入解析ARM与RISC-V架构的Bring-up核心流程
深入解析ARM与RISC-V架构的Bring-up核心流程
作者:嵌入式架构探索者 | 2023年10月
引言
在嵌入式开发中,处理器的Bring-up(启动初始化)是系统运行的第一道门槛。ARM和RISC-V作为两大主流架构,其Bring-up流程既有共性(如基础硬件验证)又存在显著差异(如安全模型和调试机制)。本文将从底层寄存器操作到工具链实践,深入解析两者的核心知识点。

一、架构级Bring-up的本质
定义:
架构级Bring-up是指针对特定处理器核心(如ARM Cortex-A53或RISC-V Rocket Core)的底层初始化,涉及以下核心任务:
- 复位向量(Reset Vector)配置
- 特权模式与异常处理设置
- 内存与缓存初始化
- 多核协同启动(SMP)
- 调试接口使能
与系统级Bring-up的区别:
- 架构级:聚焦CPU核心自身功能(如寄存器、流水线、中断控制器)
- 系统级:关注外设、操作系统和应用的协作
二、ARM架构Bring-up核心知识点
1. 复位与启动流程
复位向量表
- ARMv7/ARMv8复位向量地址:
- ARMv7:固定地址
0x00000000或0xFFFF0000(通过SCTLR.V位控制) - ARMv8:分四个异常级别(EL0-EL3),复位入口由配置寄存器(如RVBAR_EL3)定义
- ARMv7:固定地址
典型启动代码结构
/* ARMv7汇编示例:Cortex-A9启动代码 */
.section .vectors b _reset // 复位向量 b undefined_instruction b software_interrupt ... _reset: /* 1. 设置栈指针 */ ldr sp, =0x8000 /* 2. 关闭MMU和缓存 */ mrc p15, 0, r0, c1, c0, 0 bic r0, r0, #0x1 // 清除C1.M位(禁用MMU) bic r0, r0, #0x4 // 禁用数据缓存 mcr p15, 0, r0, c1, c0, 0 /* 3. 初始化中断向量表 */ ldr r0, =vectors mcr p15, 0, r0, c12, c0, 0 // 写入VBAR
2. 特权模式与安全扩展
ARM TrustZone安全启动
- 安全世界(Secure World)初始化流程:
- EL3 Monitor代码配置安全状态(SCR寄存器)
- 加载安全Bootloader(如ARM TF-A的BL1/BL2)
- 隔离安全内存(TZC-400控制器配置)
多核唤醒(PSCI协议)
// Cortex-A72唤醒从核示例
void wakeup_core(int core_id) { uint64_t entry = (uint64_t)&_start; // 设置从核入口地址 mmio_write(0x1008EC000, entry); // 写入CPU Release Address寄存器 // 发送SEV指令触发唤醒 __asm__ volatile("sev");
}
3. 调试与异常处理
CoreSight调试系统
- 关键组件:
- ETM(嵌入式跟踪宏单元)
- DAP(调试访问端口)
- 调试命令示例(通过OpenOCD):
arm mcr p15 0 <reg> c1 c0 0 // 直接操作协处理器寄存器
三、RISC-V架构Bring-up核心知识点
1. 精简的启动流程设计
复位向量与机器模式
- RISC-V复位向量地址通常为
0x80000000(可自定义) - 复位后自动进入Machine模式(最高特权级)
最小启动代码示例
.section .text.init
.global _start
_start: /* 1. 设置栈指针 */ la sp, _stack_end /* 2. 清零BSS段 */ la a0, _bss_start la a1, _bss_end bss_clear_loop: beq a0, a1, bss_clear_done sw zero, 0(a0) addi a0, a0, 4 j bss_clear_loop bss_clear_done: /* 3. 跳转到C入口 */ call main
2. 中断与异常机制
CLINT(核心本地中断器)配置
// RISC-V定时器中断初始化
void timer_init() { // 设置定时器比较值 uint64_t interval = 1000000; // 1秒(假设时钟频率1MHz) write_csr(mtimecmp, interval); // 启用机器模式定时器中断 set_csr(mie, MIE_MTIE); // 全局中断使能 set_csr(mstatus, MSTATUS_MIE);
}
PLIC(平台级中断控制器)路由
// 配置UART中断
void plic_init() { // UART中断号=3,优先级=1 volatile uint32_t *plic_priority = (uint32_t*)0x0C000000; plic_priority[3] = 1; // 启用目标核的中断 volatile uint32_t *plic_enable = (uint32_t*)0x0C002000; plic_enable[0] |= (1 << 3);
}
3. 物理内存保护(PMP)
// 配置PMP保护区域
void pmp_config() { // 允许0x80000000-0x8000FFFF的读写执行 pmpcfg0 = PMP_NAPOT | PMP_R | PMP_W | PMP_X; pmpaddr0 = (0x80000000 >> 2) | 0xFFF; // NAPOT模式覆盖64KB asm volatile("csrw pmpcfg0, %0" : : "r" (pmpcfg0)); asm volatile("csrw pmpaddr0, %0" : : "r" (pmpaddr0));
}
四、ARM vs RISC-V Bring-up对比
1. 启动复杂度
| 任务 | ARM | RISC-V |
|---|---|---|
| 复位向量配置 | 多级异常向量表(VBAR寄存器) | 单一入口地址(自由定义) |
| 特权模式切换 | 需处理EL3/EL2/EL1层级 | 仅需配置Machine/Supervisor模式 |
| 内存管理 | 必须初始化MMU | 可仅用PMP进行物理内存保护 |
2. 调试工具链
| 工具 | ARM | RISC-V |
|---|---|---|
| 硬件调试器 | J-Link、DS-5 | SiFive Freedom Debugger、FT2232 |
| 开源支持 | 有限(需商业授权) | 完善(OpenOCD + riscv-openocd) |
| 跟踪功能 | CoreSight ETM(高性能) | 自定义跟踪接口(如Nexus协议) |
五、实战案例分析
案例1:ARM Cortex-M4启动失败
现象:执行__main()前HardFault
排查步骤:
- 检查向量表地址(VTOR寄存器)是否对齐到512字节边界
- 验证栈指针初始值是否指向有效RAM区域
- 使用
arm-none-eabi-objdump反汇编,确认复位向量跳转正确
案例2:RISC-V HiFive1开发板无法调试
现象:OpenOCD连接超时
解决方案:
- 确认JTAG引脚连接(TCK、TMS、TDI、TDO)
- 添加复位信号控制配置:
adapter_nsrst_delay 100 reset_config srst_only
六、进阶方向与工具推荐
ARM开发者必备工具
- ARM Development Studio:全功能调试与性能分析
- Trusted Firmware-A (TF-A):官方参考启动代码库
- DS-5 Streamline:性能瓶颈分析工具
RISC-V开发者必备工具
- RISC-V GNU Toolchain:开源编译与调试套件
- Spike模拟器:指令集模拟与行为验证
- Chipyard框架:自定义RISC-V SoC生成
结语
无论是ARM还是RISC-V,架构级Bring-up的核心都在于对处理器设计哲学的深刻理解。
- ARM开发者需关注复杂的权限模型和安全扩展
- RISC-V开发者需善用其模块化设计带来的灵活性
掌握这些核心知识点,将助您在嵌入式系统的底层开发中游刃有余。
相关文章:
深入解析ARM与RISC-V架构的Bring-up核心流程
深入解析ARM与RISC-V架构的Bring-up核心流程 作者:嵌入式架构探索者 | 2023年10月 引言 在嵌入式开发中,处理器的Bring-up(启动初始化)是系统运行的第一道门槛。ARM和RISC-V作为两大主流架构,其Bring-up流程既有共性…...
关于UDP端口扫描概述
尽管互联网上大多数流行服务都基于 TCP 协议运行,但 UDP 服务也广泛部署。DNS、SNMP 和 DHCP(注册端口 53、161/162 和 67/68)是最常见的服务之一。 由于 UDP 扫描通常比 TCP 扫描更慢、更困难,一些安全审计人员可能会忽略这些端…...
C语言的操作系统
C语言的操作系统 引言 操作系统是一种系统软件,它管理计算机硬件和软件资源,并为计算机程序提供公共服务。在现代计算机科学中,操作系统是不可或缺的组成部分,而C语言则是实现高效操作系统的主要编程语言之一。本文将探讨C语言在…...
洛谷题单3-P5725 【深基4.习8】求三角形-python-流程图重构
题目描述 模仿例题,打印出不同方向的正方形,然后打印三角形矩阵。中间有个空行。 输入格式 输入矩阵的规模,不超过 9 9 9。 输出格式 输出矩形和正方形 输入输出样例 输入 4输出 01020304 05060708 09101112 13141516010203040506 …...
Lettuce与Springboot集成使用
一、Lettuce核心优势与Spring Boot集成背景 Lettuce特性 基于Netty的非阻塞I/O模型,支持同步/异步/响应式编程线程安全:共享单连接实现多线程并发操作,性能衰减低原生支持Redis集群、哨兵、主从架构,自动重连机制保障高可用Spring…...
C# 类库生成后自动复制到指定目录
C# 类库生成后自动复制到指定目录 在C#中,当你开发了一个类库项目(通常是.NET Core或.NET Framework项目),你可能会希望在构建(Build)完成后自动将生成的DLL文件复制到指定的目录。有几种方法可以实现这个需求,下面是一些常用的方法: 方法1:使用MSBuild的AfterBuild…...
《系统分析师-基础篇-1-6章总结》
第1章 绪论 系统分析师角色 职责:需求分析、系统设计、项目管理、技术协调。 能力要求:技术深度(架构设计、开发方法) 业务理解(企业流程、行业知识) 沟通能力。 系统开发生命周期 传统模型…...
一个完整的 HTTP/HTTPS 请求流程
HTTP 一个完整的 HTTP 请求流程可以分为以下几个步骤: 1. DNS 解析 当客户端(通常是浏览器)输入 URL(例如 https://www.example.com)时,它首先需要解析出对应的 IP 地址。这个过程涉及 DNS(域…...
go游戏后端开发25:红中麻将规则介绍
一、游戏基础规则介绍 在开发红中麻将游戏之前,我们需要先了解其基础规则。红中麻将的牌面由 a、b、c、d 四种花色组成,其中 a、b、c 分别代表万、条、筒,每种花色都有 1 - 9 的九种牌,每种牌各有四张,总计 36 张 4 …...
【YOLO系列(V5-V12)通用数据集-电梯内电动车检测数据集】
YOLO格式的电梯内电动车检测数据集,适用于YOLOv5-v11所有版本,可以用于本科毕设、发paper、做课设等等,有需要的在这里获取: 电梯内电动车检测数据集 数据集专栏地址:https://blog.csdn.net/qq_41304809/category_1290…...
Python每日一题(15)
Python每日一题2025.4.4 一、题目题目描述输入格式输出格式输入输出样例 #1输入 #1输出 #1 二、分析三、源代码四、deepseek 一、题目 题目描述 您需要写一种数据结构,来维护一些数(都是绝对值 1 0 9 10^9 109 以内的数)的集合,…...
算法题(114):矩阵距离
审题: 本题需要我们找出所有0距离最近的1的曼哈顿距离 思路: 方法一:多源bfs 分析曼哈顿距离: 求法1:公式法,带入题目公式,利用|x1-x2||y1-y2|求出 求法2:曼哈顿距离就是最短距离 本…...
0102-web架构网站搭建-基础入门-网络安全
文章目录 1. 常规2 站库分离3 前后端分离4 集成环境5 docker6 分配站结语 1. 常规 结构:源码数据都在同服务器 影响:无,常规安全测试手法 2 站库分离 结构:源码和数据库不在同服务器 存储:其他服务器上数据库或者…...
Linux系统编程:进程管理、内存对比与树莓派应用
一、认识进程和线程,在Linux系统下查看系统中各进程的编号pid并终止一个进程pid 1.进程和线程 进程:操作系统分配资源(如内存、CPU时间片)的基本单位。每个进程有独立的内存空间,进程间通信需要较复杂的机制…...
ue5 仿鬼泣5魂类游戏角色和敌人没有碰撞
UE5系列文章目录 文章目录 UE5系列文章目录前言一、问题原因二、设置碰撞2.读入数据 总结 前言 ue5 仿鬼泣5魂类游戏角色和敌人没有碰撞 一、问题原因 在UE5中,角色和敌人没有碰撞可能是由多种原因导致的,以下是一些可能的原因及解决方法:…...
基于Flask的MBA考生成绩查询系统设计与实现
基于Flask的MBA考生成绩查询系统设计与实现 序言 2024年吉林大学MBA在职研究生考试成绩公布后,考生收到的成绩单为PDF格式文档。为方便考生快速查询个人成绩及排名信息,笔者基于Python Flask框架开发了本查询系统。该系统支持关键词模糊查询、序号范围…...
GATT(Generic Attribute Profile)是蓝牙低功耗(Bluetooth Low Energy,简称BLE)协议栈中的一个核心协议
蓝牙的 GATT(Generic Attribute Profile) 是蓝牙低功耗(Bluetooth Low Energy,简称BLE)协议栈中的一个核心协议,用于定义设备如何通过蓝牙进行数据传输和交互。GATT 是基于 ATT(Attribute Proto…...
DHCP之报文格式
字段说明: op (op code): 表示报文的类型,取值为 1 或 2,含义如下 1:客户端请求报 2:服务器响应报文 Secs (seconds):由客户端填充,表示从客户端开始获得 IP 地址或 IP 地址续借后所使用了的秒数,缺省值为 3600s。 F…...
React 文件上传新玩法:Aliyun OSS 加持的智能上传组件
文件上传是前端开发中的“老朋友”,但如何让它既简单又强大,还能无缝对接云端存储?今天,我要带你认识一个超酷的 React 组件 AliUploader,它不仅支持拖拽上传、批量编辑和文件排序,还直接把文件传到 Aliyun…...
群体智能优化算法-变色龙优化算法(Chameleon Swarm Algorithm, CSA,含Matlab源代码)
摘要 变色龙优化算法(Chameleon Swarm Algorithm, CSA)是一种受变色龙行为启发的群体智能优化算法。该算法模拟了变色龙在自然界中通过变换颜色来适应环境的能力,以此为基础,设计了一个适应性强、搜索能力广泛的优化算法。CSA 通…...
使用 React 和 Konva 实现一个在线画板组件
文章目录 一、前言二、Konva.js 介绍三、创建 React 画板项目3.1 安装依赖3.2 创建 CanvasBoard 组件 四、增加画布控制功能4.1 清空画布4.2 撤销 & 重做功能 五、增加颜色和画笔大小选择5.1 选择颜色5.2 选择画笔大小 六、最终效果七、总结 一、前言 在线画板是许多应用&…...
GitHub高级筛选小白使用手册
GitHub高级筛选小白使用手册 GitHub 提供了强大的搜索功能,允许用户通过高级筛选器来精确查找仓库、Issues、Pull Requests、代码等。下面是一些常用的高级筛选用法,帮助你更高效地使用 GitHub 搜索功能。 目录 搜索仓库搜索Issues搜索Pull Requests搜…...
通过第k个最大元素深入浅出快排和堆排序
快排和堆排序在确定k个元素有着得天独厚的优势,原因是无论快排还是堆排序在每一轮排序中均可以确定一个元素 快排:每一轮排序均可以确定一个元素位置堆排序:每一轮排序都可以确定一个最小值或最大值 他们的时间复杂度都是O(nlogk)ÿ…...
NVR接入录像回放平台EasyCVR视频系统守护舌尖上的安全,打造“明厨亮灶”云监管平台
一、方案背景 近年来,餐饮行业食品安全和卫生等问题频发,比如后厨卫生脏乱差等,持续引发关注,这些事情导致连锁反应,使其收益遭受损失。同时,给消费者造成了心理和生理上的伤害。 加强餐饮行业的监管成为…...
Airflow+Spark/Flink vs. Kettle
在迁移亿级(单表超过1.3亿)结构化数据(达梦→星环)的场景下,Airflow(结合分布式计算框架)的综合效果优于Kettle,以下是详细对比与方案建议: 一、核心对比:Air…...
Cribl 导入文件来检查pipeline 的设定规则(eval 等)
Cribl 导入文件来检查pipeline 的设定规则(eval 等) 从这个页面先下载,或者copy 内容来创建pipeline: Reducing Windows XML Events | Cribl Docs...
[C++面试] new、delete相关面试点
一、入门 1、说说new与malloc的基本用途 int* p1 (int*)malloc(sizeof(int)); // C风格 int* p2 new int(10); // C风格,初始化为10 new 是 C 中的运算符,用于在堆上动态分配内存并调用对象的构造函数,会自动计算所需内存…...
一周学会Pandas2 Python数据处理与分析-Jupyter Notebook安装
锋哥原创的Pandas2 Python数据处理与分析 视频教程: 2025版 Pandas2 Python数据处理与分析 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili Jupyter (Project Jupyter | Home)项目是一个非营利性开源项目,于2014年由IPython项目中诞生…...
第30周Java分布式入门 消息队列 RabbitMQ
RabbitMQ章节介绍 一、RabbitMQ概述 RabbitMQ学习内容: 本章节将学习RabbitMQ的概念、安装启动、管理后台、代码实操、交换机工作模式以及Spring Boot整合RabbitMQ。消息队列定义: 消息队列是一种用于在分布式系统中传递消息的机制。消息队列特性: 消息队列具有异步、解耦、削…...
北斗导航 | THE GNSS AMBIGUITY RATIO-TEST REVISITED: A BETTER WAY OF USING IT【论文要点】
THE GNSS AMBIGUITY RATIO-TEST REVISITED: A BETTER WAY OF USING IT 总结该论文的核心贡献及关键方法如下:论文核心内容概述 传统比率测试的局限性 传统比率测试通过比较最优与次优模糊度解的残差平方和比值(即 R = q (...
