[架构之路-121]-《软考-系统架构设计师》-计算机体系结构 -3-汇编语言与ARM系统的初始化

news2025/1/11 12:43:15

第9章 计算机体系结构

第1-6节 参考前文

第7节 ARM汇编语言

7.1 程序框架

(1)数据段Data

  • 初始化的数据: 初始的全局变量

  • 未初始化的数据:未初始化的全局变量

  • 堆heap:malloc的内存或数据

  • 栈stack:函数的局部变量

(2)代码段Text:只读

7.2 ARM汇编语言基本框架

.data:数据段,包含固定的数据,如常量、字符串。

.bss:未初始化的数据段,包含未初始化的变量、数组等

.text:正文段,包含程序的指令代码。

; ARM汇编程序的框架结构(完整)

.section .data; 初始化的数据
.section .bss; 未初始化的数据

.section .text _start:; 汇编代码
; ARM汇编程序的框架结构(简化)

.text_global _start

_start:; 汇编代码

_start: 程序的入口

7.3 子程序编写

ARM汇编中,子程序的调用一般通过BL指令来实现,执行BL + 子程序即可完成子程序调用(之后细讲),而子程序的编写规则如下:function

function:; demomov pc, bl

7.4 汇编指令分类

第8节 ARM CPU的初始化:中断/内存/堆栈/模式

8.1 ARM的启动流程

基于ARM的芯片多数为复杂的片上系统。这种复杂系统里的多数硬件模块都是可配置的。

需要由软件来设置其需要的工作状态。因此在操作系统和用户的应用程序之前,需要由专门的一段代码来完成对系统的初始化。

由于这类代码直接面对处理器内核和硬件控制器进行编程,一般都是用汇编语言。

一般通用的内容包括:

  • 中断向量表

  • 初始化存储器系统

  • 初始化堆栈

  • 初始化有特殊要求的端口,设备

  • 初始化用户程序执行环境

  • 改变处理器模式

  • 调用主应用程序

8.2 ARM的启动文件

以stm32的启动文件为例,stm32的启动文件一般都是包含在具体单片机型号汇编文件中(.s文件),下图为启动文件的简述(description)

该启动文件主要包含了:

  • 初始化主堆栈指针(MSP)、

  • 初始化程序指针(PC)、

  • 初始化中断向量表、

  • 配置系统时钟

  • 外部Sram(可选)、

  • 跳转到c语言的main函数

8.3 启动文件代码具体分析

8.3.1 分配堆栈空间

第一部分配置堆内容和栈的大小(Stack_size Heap_size) 如下图

AREA STACK, NOINIT, READWRITE, ALIGN=3 ;定义栈,可初始为0,8字节对齐 (堆代码类似相同功能)

Stack_Mem SPACE Stack_Size ;分配0x400个连续字节,并初始化为0 (堆代码类似相同功能)

__initial_sp ;汇编代码地址标号 (堆代码类似相同功能)

PRESERVE8 ;指定当前文件堆栈8字节对齐

THUMB ;告诉汇编器下面是32为的Thumb指令,如果需要汇编器将插入位以保证对齐

8.3.2 定义中断向量标

第二部分定义中断向量表:

AREA RESET, DATA, READONLY ;定义复位向量段,只读

EXPORT __Vectors ;定义一个可以在其他文件中使用的全局标号。此处表示中断地址

__Vectors DCD __initial_sp ; 给__initial_sp分配4字节32位的地址0x0

DCD Reset_Handler ; 给标号Reset Handler分配地址为0x00000004

DCD NMI_Handler ; 给标号NMI Handler分配地址0x00000008

DCD HardFault_Handler ; Hard Fault Handler

DCD ……

__Vectors_End

【注】DCD表示分配一段内存单元,并用指令的数据初始化

8.3.3 复位向量程序

第三部分Reset_Handler 及假异常处理程序的定义

AREA |.text|, CODE, READONLY ;代码段定义为只读

Reset_Handler PROC

EXPORT Reset_Handler [WEAK]

IMPORT SystemInit

IMPORT __main

LDR R0, =SystemInit//把SystemInit 的地址加载到寄存器R0。

BLX R0//程序跳转到R0 中的地址执行程序

LDR R0, =__main//把_main 的地址加载到寄存器R0

BX R0//程序跳转到R0 中的地址执行程序,执行完毕之后就去到我们熟知的C 世界。

ENDP//表示子程序的结束

//PROC 定义了一个叫 Reset_Handler 的子程序

//EXPORT 表示Reset_Handler 这个子程序可供其他模块调用

//关键字[WEAK] 表示弱定义,如果编译器发现在别处定义了同名的函数,则在链接时用别处的地址进行链接,如果其它地方没有定义,编译器也不报错,以此处地址进行链接。

//IMPORT通知编译器要使用的标号在其他文件

//SystemInit为运行时库提供的函数,完成系统初始化

//__main为运行时库提供的函数,完成堆栈,堆的初始化

其他的中断处理子程序称为假异常处理子程序( Dummy Exception Handlers)默认为死循环可以被重新定义

NMI_Handler PROC

EXPORT NMI_Handler [WEAK]

B .//原地跳转(死循环)

ENDP

8.3.4 初始化堆和栈指针

第四部分堆和栈的初始化

IF :DEF:__MICROLIB//“DEF”的用法——:DEF:X 就是说X定义了则为真,否则为假//__MICROLIB编译选项表示是否受用了MICROLIB的C库而非标准C库

EXPORT __initial_sp

EXPORT __heap_base

EXPORT __heap_limit

ELSE

IMPORT __use_two_region_memory

EXPORT __user_initial_stackheap

__user_initial_stackheap

LDR R0, = Heap_Mem//R0地址指向堆起始地址

LDR R1, =(Stack_Mem + Stack_Size)//R1地址指向栈最高地址

LDR R2, = (Heap_Mem + Heap_Size)//R2地址指向堆最高地址

LDR R3, = Stack_Mem//R1地址指向栈起始地址

BX LR

ALIGN

ENDIF

END

第9节 ARM 软件启动流程

9.1 总体启动框架

以三星的四核处理器Exynos4412为例,该开发板属于armv7架构,contexA9系列,32bit,cpu4核心1.5GHZ主频,eMMC 大小型号为:KLM4G。

ARM里面,启动MMU以后,我们编程看到的地址都是虚拟地址,经过MMU以后才是具体的物理地址。

4412在上电以后,MMU是关闭的,也就是说这个时候其实和单片机差不多,可以直接跑裸机程序(裸机程序,就是直接对CPU进行编程),就跟单片机一样,但是,在Linux启动以后,操作系统就会把MMU打开,也就是说,虚拟地址就会出现。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/373848.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ubuntu20系统+RobotiQ 2F-85夹爪+Ros+VMware配置

文章目录环境说明Ros配置Vmware虚拟机串口通信配置运行节点并调试有关问题解决办法rosdep相关缺少ros有关的库与pymodbus相关参考环境说明 环境说明系统版本Ubuntu 20.04.4Ros版本noetic主机形式VMware虚拟机夹爪型号RobotiQ 2F-85 Ros配置 新建ros工作空间并进行初始化 mkdir…

Nginx配置web服务器及部署反向代理

Nginx配置web服务器及部署反向代理配置web服务器location语法部署反向代理代理转发配置web服务器 项目部署到linux上的静态文件代理给Nginx处理。当访问服务器IP时,可以自动返回静态文件主页。 主配置文件中server块对应的次配置include /etc/nginx/conf.d/*.conf…

ESP-01S烧录MQTT固件连接阿里云

烧录MQTT固件 资源下载包 用到的所有烧录攻击和固件都放百度云链接了 提取码:qwlo 烧录固件 淘宝上10块钱左右一个CH340C下载烧录器ESP8266的就可以了。 连接好硬件打开ESPFlashDownloadTool_v3.6.2.2.exe软件(记得放到英文目录下不然可能打不开&a…

windows服务编程

文章目录前言方案一:服务程序方案二:后台程序对比windows服务编程windows服务控制附录 - 完整代码前言 在linux中,如果需要一个程序在后台持续提供服务,我们一般会使用守护进程。 守护进程(daemon)是生存期长的一种进程。它们常…

Canonical为所有支持的Ubuntu LTS系统发布了新的Linux内核更新

导读Canonical近日为所有支持的Ubuntu LTS系统发布了新的Linux内核更新,以解决总共19个安全漏洞。新的Ubuntu内核更新仅适用于长期支持的Ubuntu系统,包括Ubuntu 22.04 LTS(Jammy Jellyfish)、Ubuntu 20.04 LTS(Focal F…

需求:节目上传至MINIO后,使用mqtt进行上报

需求:节目上传至MINIO后,使用mqtt进行上报 环境准备 文件管理平台:首先需要使用minio搭建属于自己的对象存储(此步骤跳过) 通信方式:MQTT方式,客户端测试工具:MQTTX(ht…

AI - stable-diffusion(AI绘画)的搭建与使用

最近 AI 火的一塌糊涂,除了 ChatGPT 以外,AI 绘画领域也有很大的进步,以下几张图片都是 AI 绘制的,你能看出来么? 一、环境搭建 上面的效果图其实是使用了开源的 AI 绘画项目 stable-diffusion 绘制的,这是…

《MySQL学习》 表中随机取记录的方式

一.初始化测试表 创建表 words CREATE TABLE words ( id int(11) NOT NULL AUTO_INCREMENT, word varchar(64) DEFAULT NULL, PRIMARY KEY (id)) ENGINEInnoDB;插入测试数据 create procedure idata()begin declare i int; set i 0; while i<10000 do insert into words…

【计算机网络】TCP的可靠性传输机制和常见配置讲解

文章目录1.TCP的可靠性传输机制2.TCP的传输优化机制 Nagle算法和延迟确认3.Linux服务器常见网络内核参数配置4. Linux服务器生产环境常见问题1.TCP的可靠性传输机制 TCP的可靠性传输机制 ACK机制 接收方收到TCP 数据包&#xff0c;要响应一个确认消息 acknowledgement&#xff…

Jinja2----------模板渲染、模板访问对象属性

目录 1.Jinja2 1.简介 2.Jinja2模板 2.模板渲染 app.py templates/index.html templates/blog_detail.html 效果 3.模板访问对象属性 app.py templates/index.html 效果 1.Jinja2 1.简介 Jinja2是Python下一个被广泛应用的模版引擎&#xff0c;他的设计思想来…

k8s-Pod基础

文章目录一、资源限制二、Pod 的两种使用方式三、Pod 资源共享四、底层容器Pause1、Pause共享资源1.1 网络1.2 存储1.3 小结2、Pause主要功能3、Pod 与 Pause 结构的设计初衷五、Pod容器的分类1、基础容器&#xff08;infrastructure container&#xff09;2、初始化容器&#…

行测-判断推理-图形推理-位置规律-平移

位置平移&#xff0c;选D空白每次顺时针移动一格&#xff0c;黑色圆每次逆时针移动2格选C两个黑色⚪&#xff0c;每次顺时针移动2格白色⚪&#xff0c;先到对角位置&#xff0c;再顺时针移动一格选B三角形的底&#xff0c;顺时针移动三角形的顶点&#xff0c;在正方形的内部顺时…

大数据周会-本周学习内容总结03

目录 01【大数据导论与Linux基础】 02【Apache Hadoop、HDFS】 03【Hadoop MapReduce与Hadoop YARN】 04【数据仓库基础与Apache Hive入门】 05【Apache Hive DML语句与函数使用】 06【Hadoop生态综合案例&#xff1a;陌陌聊天数据分析】 01【大数据导论与Linux基础】 大…

如何从0创建Spring Cloud Alibaba(多模块)

以一个父工程带两个Module&#xff08;test1、test2&#xff09;为例。 一、创建父工程 由于是模块化项目&#xff0c;那么父工程不需要实际的代码逻辑&#xff0c;因此无需创建src&#xff0c;那么可以有几种方式创建&#xff0c;例如&#xff1a; 使用Spring Initializr脚…

【跟着ChatGPT学深度学习】ChatGPT带我入门NLP

❤️觉得内容不错的话&#xff0c;欢迎点赞收藏加关注&#x1f60a;&#x1f60a;&#x1f60a;&#xff0c;后续会继续输入更多优质内容❤️&#x1f449;有问题欢迎大家加关注私戳或者评论&#xff08;包括但不限于NLP算法相关&#xff0c;linux学习相关&#xff0c;读研读博…

Unity Jobsystem ECS

简介随着ECS的加入&#xff0c;Unity基本上改变了软件开发方面的大部分方法。ECS的加入预示着OOP方法的结束。随着实体组件系统ECS的到来&#xff0c;我们在Unity开发中曾使用的大量实践方法都必须进行改变以适应ECS&#xff0c;也许不少人需要些时间适应ECS的使用&#xff0c;…

学python的第二天---差分

一、改变数组元素&#xff08;差分&#xff09;方法一&#xff1a;差分数组map(int,input().split())for b in arr[:n]:print(1 if b else 0,end )方法二&#xff1a;区间合并interval.sort(keylambda x:x[0])二、差分a [0] list(map(int, input().split())) a[n 1:]三、差…

Android从屏幕刷新到View的绘制(二)之Choreographer、Vsync与屏幕刷新

0.相关分享&#xff1a; Android从屏幕刷新到View的绘制&#xff08;一&#xff09;之 Window、WindowManager和WindowManagerService之间的关系 Android从屏幕刷新到View的绘制&#xff08;二&#xff09;之Choreographer、Vsync与屏幕刷新 1. 相关类 Choreographer 编舞者…

MySQL创建表

在创建表时需要提前了解mysql里面的数据类型 常见的数据类型 创建表方式1&#xff1a; 格式&#xff1a; CREATE TABLE [IF NOT EXISTS] 表名( 字段1, 数据类型 [约束条件] [默认值], 字段2, 数据类型 [约束条件] [默认值], 字段3, 数据类型 [约束条件] [默认值], …… [表约束…

英语基础语法学习(B站英语电力公司)

1. 句子结构 五大基本句型&#xff1a; 主谓主谓宾主谓宾宾主谓宾宾补主系表 谓语&#xff1a; 一般来说&#xff0c;谓语是指主语发出的动作。&#xff08;动词&#xff09;但是很多句子是没有动作的&#xff0c;但是还是必须要有谓语。&#xff08;此时需要be动词&#x…