记录第一个启动代码的诞生

news2024/11/18 11:32:24

        核使用R52,参考汇编模板,一步一步来实现。

        首先是ld文件,这个没啥好说的,主要是关注给vector_table划一块地址、stack地址,如下:

    .text.intvec :
    {
        _vectors_start = .;
        KEEP(*(.text.intvec))
        _vectors_end = .;
    } > BOOTROM

    .irq_stack :
    {
        . = ALIGN(16);
        __IrqStackBase = .;
        /* Place the irq_stack here. */
        KEEP(*(.irq_stack))
        . = irq_stack_size;
        __IrqStackLimit = .;
    } > ATCMx

        注意哦,我特别没有在这里还对齐处理,原因是想在.S里验证对齐的作用。

        现在开始写vector_table。

1.Vector Table

        默认情况下,R52复位后是在EL2(Hyp mode).

        因此首先是要把EL2、1等级下的中断向量表给做出来,例如:EL2_Vector_Tabel

.macro vector_section label
.section .text.intvec, "ax"
.endm

vector_section EL2_VectorTable:
    ldr pc, = el2_reset_entry
    ldr pc, = el2_undefine_entry
    ...
    ldr pc, = el2_irq_entry
	ldr pc, = el2_fiq_entry

.align 5
EL1_VectorTable:
    nop
    ...
    ldr pc, = el1_irq_entry
	ldr pc, = el1_fiq_entry

        注意看,我在table前面加了个宏,这个标签有什么用呢?

        就是将EL2的table放到链接文件指定的section .text.intvec。

        后面我陆续试过,如果EL2table没有这个标签,会直接放到.text段;如果是放在EL2table下面,那么之后的代码会放到.intvec段,所以,这个宏感觉有点像块砖,哪里需要哪里搬。但是我后面又设计了一下,EL2Table放.intvec段,EL1Table放.text,就必须在EL1Table前加.text的放置。除了上述方式,参考#pragma。

        关于EL1的vectorTable定义,我特地没有做el1_reset_entry。因为R52 reset默认进入EL2模式,因此好像不太需要这个entry,直接定义一个el1的处理函数,这里留个口子,看以后是否会遇到reset 进el1的情况。

        此外,对EL1的table做了对齐,.align 5 表示以2^5对齐。

2. Reset_entry

        el2_reset_entry,以word对齐,为啥?我们现在用的32位,因此填充PC肯定是32位。这里没有.word也没关系,编译器会自动处理。

        现在R52进到了el2的reset_entry里,那么首先要做的就是再确认下是不是el2的模式,为啥?因为pc指针指向的只是一个地址,这个地址里可以是el1_vector_table、也可以是el2的。所以要确认,怎么确认?读取cpsr.mode,如果该mode ==hyp,跳转到正式处理hyp的函数里。否则panic。

2.1 hyp_reset_handler

        这里就主要是设置hyp的中断向量表到HVBAR,使能hyp的cache加快启动速度。

        步骤如下:

  1. 设置HVBAR
  2. 使能EL1访问协处理器寄存器的能力
  3. 如有需要、关闭HVC指令(用户模式下非安全态禁用、核处于安全态禁用)
  4. 设置EL1的VBAR
  5. 保存cpsr到SPSR_hyp(返回EL2模式需要用到)
  6. 设置elr_hyp 为 EL1_init (elr(exception linker register))
  7. 使能TCM,使得EL1\2\0均可访问;且配置TCM大小
  8. 根据情况使能或者关闭TCM slave接口
  9. 调用指令eret,进入EL1

2.2 EL1_init

        在EL1_init最先需要做啥?

        毫无疑问如果没有在EL2设置VBAR,那么就要在这里做VBAR。

        第二个事情就是,初始化C运行环境,具体如下:

  1. .bss段清零,防止出现ECC错误
  2. .data段初始化,将rom数据copy至ram
  3. 各种模式的stack初始化,包括svc、abt、und、irq、fiq等

如下:

    cps  #17                        /* FIQ mode */
    ldr  sp, =__FiqStackLimit
    cps  #18                        /* IRQ mode */
    ldr  sp, =__IrqStackLimit
    cps  #23                        /* Abort mode */
    ldr  sp, =__AbtStackLimit
    cps  #27                        /* Undef mode */
    ldr  sp, =__UndStackLimit
    cps  #31                        /* System mode */
    ldr  sp, =__SysStackLimit
    cps  #19                        /* SVC mode */
    ldr  sp, =__SvcStackLimit
    dsb
    isb

        最后跳转至main

舒服,学到了一些技巧

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

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

相关文章

【谢希尔 计算机网络】第1章 计算机网络概述

目录 1.1.1计算机网络概念,功能,组成,分类 计算机网络的概念 计算机网络的功能 计算机网络的组成 计算机网络的分类 1.1.2标准化工作 1.1.3速率相关的性能指标 速率 带宽 吞吐量 时延 时延带宽积​编辑 往返时延RTT 利用率 1.…

(matplotlib)如何不显示x轴或y轴刻度(ticks)

文章目录 背景plt版本ax子图版本 解决办法plt版本ax子图版本 背景 import numpy as np import matplotlib.pyplot as pltplt版本 x[1,2,3] y[4,5,6] plt.plot(x,y)ax子图版本 x[1,2,3] y[4,5,6] axplt.subplot() ax.plot(x,y)可以发现,正常情况下是有刻度的&…

【多线程】ConcurrentHashMap 详解

ConcurrentHashMap 一. Hashtable二. ConcurrentHashMap三. 相关面试题 HashMap 本身不是线程安全的. 在多线程环境下使用哈希表可以使用: HashtableConcurrentHashMap 一. Hashtable 在关键方法加上了 synchronized 关键字. 这相当于直接针对 Hashtable 对象本身加锁.如果多…

「扫地茅」神话破灭,科沃斯市值缩水超千亿

昔日的“扫地茅”科沃斯神话破灭。 8月26日,“扫地机器人*股”科沃斯(603486.SH)发布2023年上半年业绩报告,业绩增收不增利。 「不二研究」据科沃斯半年报发现:今年上半年,科沃斯营收增速为4.72%,净利下滑至33.40%。…

固定资产管理口号标语怎么写

在现代企业管理中,固定资产的管理是至关重要的一环。它不仅关系到企业的经济效益,也影响到企业的运营效率和稳定性。因此,我们需要一种既富有创意又实用有效的口号来引导我们的固定资产管理工作。 明确一个观点  我们要明确一个观点&#…

众源方略作为一家上市公司,公司实力和发展前景怎么样?

是否能成为上市公司,是衡量一个企业实力的重要参考标准。众源方略教育上市公司实力雄厚,是一家专注教导学员自媒体运营的在线教育培训机构,成立至今已有超过十年的时间。众源方略教育上市公司实力雄厚靠着优秀的师资力量,优质的课…

【Java IO流 - 中秋活动特供】流的分类,API使用,文件操作

博主:_LJaXi 专栏: Java | 从跨平台到跨行业 开发工具:IntelliJ IDEA Community Edition 2022.3.3 Java IO流 中秋特供啦 🥮Java Io 🍔什么是流流的分类文件字节输入流1. 条件循环解决1 (2) 读取特性 2. 数组存储解决 …

优雅地打印堆栈跟踪信息——Backward-cpp

优雅地打印堆栈跟踪信息——Backward-cpp 文章目录 优雅地打印堆栈跟踪信息——Backward-cpp介绍编译Backward-cpp下载源码文件结构安装第三方库编译测试 集成Backward-cpp测试代码 安装backward.hppbackward.cpp 使用方法g直接编译CMakebackward.hpp backward.cpp加入程序编译…

GRACE球谐数据滤波处理(利用matlab实现GRACE月水储量的二维傅里叶变化滤波)

GRACE的全球重力场产品以球谐系数(SHCs)的形式表现出明显的南北条带噪声问题,这种噪声被认为来源于它的极轨道、缺乏横向敏感性以及采样频率引起的混叠效应。 空间滤波器的例子包括各向同性高斯滤波器(Wahr et al.,19…

GDB之保存已经设置的断点(十六)

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长! 优质专栏:Audio工程师进阶系列【原创干货持续更新中……】🚀 人生格言: 人生…

MQTT Paho Android 支持SSL/TLS(亲测有效)

MQTT Paho Android 支持SSL/TLS(亲测有效) 登录时支持ssl的交互 这是调测登录界面设计 代码中对ssl/tls的支持 使用MqttAndroidClient配置mqtt客户端请求时,不加密及加密方式连接存在以下几点差异: url及端口差异 val uri: String if (tlsConnect…

无涯教程-JavaScript - OR函数

描述 如果任何参数为TRUE,则OR函数返回TRUE;如果所有参数为FALSE,则返回FALSE。 语法 OR (logical1, [logical2], ...) 争论 Argument描述Required/Optionallogical1 您要测试的1到255个条件可以是TRUE或FALSE。 您要测试的1到255个条件可以是TRUE或FALSE。 Req…

大数据-玩转数据-oracel字符串分割转化为多列

一、建表 create table split_string_test(id integer primary key,test_string varchar2(500) );二、插入测试数据 insert into split_string_test values(1, 10,11,12,13,14,22); insert into split_string_test values(2, 22,23,24); insert into split_string_test valu…

MySQL5.7修改默认端口

1. 修改配置文件 首先打开MySQL的配置文件 my.ini,我的路径在 C:\ProgramData\MySQL\MySQL Server 5.7 ,如何寻找自己的MySQL配置文件所在位置呢? 1.1 寻找配置文件 首先按下 wins ,搜索 “服务” , 找到MySQL服务…

常驻巨噬细胞诱导的纤维化在胰腺炎性损伤和PDAC中具有不同的作用

介绍一篇2023年8月10日发表在Nature Immunology的文章 标题: Fibrosis induced by resident macrophages has divergent roles in pancreas inflammatory injury and PDAC 影响因子:30.5 DOI:https://doi.org/10.1038/s41590-023-01579-x …

对SPA单页面的理解

SPA单页面应用 SPA(single-page application),翻译过来就是单页应用SPA是一种网络应用程序或网站的模型,它通过动态重写当前页面来与用户交互,这种方法避免了页面之间切换打断用户体验。 在单页应用中,所…

[移动通讯]【Carrier Aggregation-4】【LTE-4】

前言: 推荐两个在线工具 UECapabilityInformation Decoder: https://www.sqimway.com/ue_capa.php FGI Decoder: http://howltestuffworks.blogspot.com/2016/11/lte-feature-group-indicators-decoder.html 参考: 载波聚合(CA)…

webpack-cl明明已经安装了,但是还是会报未安装

解决办法:对当前项目目录进行安装 npm install webpack webpack-cli --save-dev

前端css实现统计圆环

文章目录 效果图 css的原理 左右两边分开制作&#xff0c;左右两边各有两层盒子&#xff0c;外层负责遮挡溢出的部分&#xff0c;里层旋转表示百分比 template部分 // 圆环的代码 <div class"row rel"><div class"left"><div id"lef…

U8用友ERP本地部署异地远程访问:内网端口映射外网方案

文章目录 前言1. 服务器本机安装U8并调试设置2. 用友U8借助cpolar实现企业远程办公2.1 在被控端电脑上&#xff0c;点击开始菜单栏&#xff0c;打开设置——系统2.2 找到远程桌面2.3 启用远程桌面 3. 安装cpolar内网穿透3.1 注册cpolar账号3.2 下载cpolar客户端 4. 获取远程桌面…