[嵌入式系统-38]:龙芯1B 开发学习套件 -8-启动过程详解

2024-03-10 09:44

本文主要是介绍[嵌入式系统-38]:龙芯1B 开发学习套件 -8-启动过程详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一、启动程序的入口

二、初始化硬件浮点单元fpu

三、全局指针

四、设置系统栈

五、设置内存

六、设置Cache

七、配置协处理器

八、初始化TLB


一、启动程序的入口

  1. FRAME(_start, sp, 0, ra):这一行是一个汇编宏,用于创建一个函数框架_start 函数的入口地址sp 是栈指针,0 表示没有保存寄存器的空间,ra 是返回地址寄存器。

  2. .set noreorder:这个指令告诉汇编器不要重新排序指令。

  3. #if (__mips_hard_float):这是一个条件编译指令,检查是否启用了硬件浮点运算

  4. li v0, SR_CU1:将 SR_CU1 的值加载到寄存器 v0 中。

  5. mtc0 v0, C0_SR:将寄存器 v0 的值写入 CP0 寄存器 C0_SR 中。

  6. #else

  7. mtc0    zero, C0_SR                     /* clr IntMsks/ kernel/disabled mode */    

  8. #endif

  9. nop:空操作指令。

  10. li v0, CAUSE_DC:将 CAUSE_DC 的值加载到寄存器 v0 中。

  11. mtc0 v0, C0_CAUSE:将寄存器 v0 的值写入 CP0 寄存器 C0_CAUSE 中。

  12. nop:空操作指令。

  13. lui v0, 0xFFFF:将 0xFFFF 的高 16 位加载到寄存器 v0 中。

  14. mtc0 v0, C0_COMPARE:将寄存器 v0 的值写入 CP0 寄存器 C0_COMPARE 中。

  15. nop:空操作指令。

这段代码主要是针对 MIPS 架构的初始化设置。根据是否启用了硬件浮点运算,设置相应的寄存器值,清除软件中断和定时器中断

二、初始化硬件浮点单元fpu

  1. #if (__mips_hard_float):这是一个条件编译指令,检查是否启用了硬件浮点运算。

  2. li t3, 0xAAAA5555:将常数 0xAAAA5555 加载到寄存器 t3 中。

  3. mtc1 t3, fp0:将寄存器 t3 的值写入浮点寄存器 fp0 中。

  4. mtc1 zero, fp1:将寄存器 zero 的值(0)写入浮点寄存器 fp1 中。

  5. mfc1 t0, fp0:将浮点寄存器 fp0 的值读取到通用寄存器 t0 中。

  6. mfc1 t1, fp1:将浮点寄存器 fp1 的值读取到通用寄存器 t1 中。

  7. nop:空操作指令。

  8. bne t0, t3, 1f:如果寄存器 t0 的值不等于 t3,则跳转到标签 1f 处执行。

  9. nop:空操作指令。

  10. bne t1, zero, 1f:如果寄存器 t1 的值不等于 0,则跳转到标签 1f 处执行。

  11. nop:空操作指令。

  12. ctc1 zero, fcr31:将寄存器 zero 的值写入浮点控制寄存器 fcr31 中,即清除浮点控制状态寄存器。

  13. j 2f:无条件跳转到标签 2f 处执行。

  14. nop:空操作指令。

  15. li v0, 0x0:将常数 0x0 加载到寄存器 v0 中。

  16. mtc0 v0, C0_SR:将寄存器 v0 的值写入 CP0 寄存器 C0_SR 中,即重置状态寄存器。

  17. nop:空操作指令。

  18. 2::标签 2,用于跳转。

  19. #endif:结束条件编译指令块。

这段代码主要用于检查是否存在浮点处理器(FPU),如果存在,则清除浮点控制状态寄存器,并重置状态寄存器。

三、全局指针

  1. la gp, _gp:将全局指针 _gp 的地址加载到全局指针寄存器 gp 中,用于初始化全局指针寄存器。

  2. la v0, _fbss:将未初始化数据段(bss段)的起始地址 _fbss 加载到通用寄存器 v0 中。

  3. la v1, _end:将未初始化数据段的结束地址 _end 加载到通用寄存器 v1 中。

  4. 3::标签 3,用于循环中的跳转。

  5. sw zero, 0(v0):将寄存器 zero 的值(0)存储到地址为 v0 的内存位置,即清零未初始化数据段中的一个字。

  6. bltu v0, v1, 3b:如果 v0 的值小于 v1 的值,则跳转到标签 3 处执行。这是一个无符号数比较分支指令,用于在清零未初始化数据段的过程中循环处理直到结束。

  7. add v0, 4:将寄存器 v0 的值加上4,即增加一个字的大小,用于指向下一个未初始化数据段的地址。

这段代码的主要作用是初始化全局指针寄存器,并清零未初始化数据段(bss段)的内容,确保其在使用之前被正确初始化。

四、设置系统栈

  1. la t0, _stack_end: 将系统栈的结束地址 _stack_end 加载到临时寄存器 t0 中。

  2. sub t0, t0, (4 * 4): 从系统栈的结束地址减去4个字(即16个字节)。这可能是为了留出一些空间用于栈帧或其他用途。“XXX overhead” 注释可能表示这个操作有一定的额外开销。

  3. move sp, t0: 将临时寄存器 t0 中的值移动到栈指针寄存器 sp 中,从而设置系统栈。

  4. la a0, _RamSize: 将 RAM 的大小 _RamSize 加载到寄存器 a0 中。

五、设置内存

  1. jal set_memory_size: 调用函数 set_memory_size,这可能是设置内存大小的函数。

  2. nop: 空操作指令,用于填充延时槽或优化。

六、设置Cache

  1. jal config_cache: 调用函数 config_cache,用于确定 D & I caches 的大小。

  2. nop: 空操作指令。

  3. la a0, memory_cfg_struct: 将内存配置结构体 memory_cfg_struct 的地址加载到寄存器 a0 中。

  4. jal get_memory_conf: 调用函数 get_memory_conf,可能用于填充内存配置结构体。

  5. nop: 空操作指令。

  6. jal flush_cache: 调用函数 flush_cache,用于初始化缓存。

  7. nop: 空操作指令。

七、配置协处理器

  1. mfc0 v0, C0_CONFIG, 0: 从协处理器0的配置寄存器中(特权级0)读取数据,将其存储到通用寄存器 v0 中。

  2. and v0, v0, ~CFG0_K0: 将 v0 的值与 CFG0_K0 的按位取反值进行按位与操作,可能是为了清除特定位的设置。

  3. or v0, v0, CFG_C_CACHABLE: 将 CFG_C_CACHABLE 的值与 v0 进行按位或操作,可能是为了设置缓存为可缓存的模式。

  4. mtc0 v0, C0_CONFIG, 0: 将寄存器 v0 的值写入到协处理器0的配置寄存器中(特权级0)。

  5. nop: 空操作指令。

这段代码的主要作用是设置系统栈、内存大小、缓存配置等,并进行一些与内存和缓存相关的初始化操作。

八、初始化TLB

/* Clear Translation Lookaside Buffer (TLB)
 */
    jal     init_tlb                        /* clear the tlb */
    nop

/* End of CPU initialization, ready to start kernel
 */
    move    a0, zero                        /* Set argc passed to main */
    jal     bsp_start                        //C语言启动代码,不返回,
    nop

/* Kernel has been shutdown, jump to the "exit" routine
 */
    jal     _sys_exit
    move    a0, v0                          # pass through the exit code

1:
    beq     zero, zero, 1b
    nop

    .set    reorder
ENDFRAME(_start)

这篇关于[嵌入式系统-38]:龙芯1B 开发学习套件 -8-启动过程详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

作业提交过程之HDFSMapReduce

作业提交全过程详解 (1)作业提交 第1步:Client调用job.waitForCompletion方法,向整个集群提交MapReduce作业。 第2步:Client向RM申请一个作业id。 第3步:RM给Client返回该job资源的提交路径和作业id。 第4步:Client提交jar包、切片信息和配置文件到指定的资源提交路径。 第5步:Client提交完资源后,向RM申请运行MrAp