ARM中多寄存内存访问概念和栈的种类和应用

news2024/10/2 22:17:41

多寄存器内存访问指令

  • @ 多寄存器内存访问指令
    @ MOV R1,#1
    @ MOV R2,#2
    @ MOV R3,#3
    @ MOV R4,#4
    @ MOV R11,#0x40000020
    @ STM R11,{R1-R4}
    @ 将R1-R4寄存器中的数据存储到内存以R11为起始地址的内存中
    @ LDM R11,{R6-R9}
    @ 将内存中以R11为起始地址的数据读取到R6-R9寄存器中
    @ 当寄存器不连续是使用逗号分隔
    @ STM R11,{R1,R2,R4}
    @ 不管花括号里的顺序如何,存储时永远是低地址存储小编号的寄存器
    @ STM R11,{R3,R1,R4,R2}
    @ 自动索引照样适用多寄存器内存访问指令
    STM R11!,{R1-R4}

多寄存器内存访问指令的寻址方式

  • @ 多寄存器内存访问指令的寻址方式
    @ MOV R1,#1
    @ MOV R2,#2
    @ MOV R3,#3
    @ MOV R4,#4
    @ MOV R11,#0x40000020
    @ 存储完数据在增长地址
    @ STMIA R11!,{R1-R4}
    @ 先增长地址在存储数据
    @ STMIB R11!,{R1-R4}
    @ 先存储玩数据在减少地址
    @ STMDA R11!,{R1-R4}
    @ 先减少地址在存储数据
    @ STMDB R11!,{R1-R4}

栈的种类和应用

  • 栈的概念
    栈的本质就是一段内存,程序运行时用于保存一些临时数据
    如局部变量、函数的参数、返回值、以及程序跳转时需要保护的寄存器
  • 栈的分类
    在这里插入图片描述
  • 空栈和满栈
    根据SP位置来区分,如果空栈的话,先压栈在移动指针,反之如果满栈的话,先移动指针,在压栈
  • 栈的分类
    栈分为空增、空减、满增、满减四种,ARM处理器一般使用满减栈(和之前的STMDB类似,减是往地址小的方向压栈)
  • 代码指令如下:
    @ 栈的种类与使用
    MOV R1,#1
    MOV R2,#2
    MOV R3,#3
    MOV R4,#4
    MOV R11,#0x40000020
    STMDB R11!,{R1-R4}
    LDMIA R11!,{R6-R9}
  • ARM内部一般用字母来表示满增、满减等等
    空增(EA)、空减(ED)、满增(FA)、满减(FD)
  • 汇编代码如下:
    MOV R1,#1
    MOV R2,#2
    MOV R3,#3
    MOV R4,#4
    MOV R11,#0x40000020
    STMFD R11!,{R1-R4}
    LDMFD R11!,{R6-R9}
  • 叶子函数的调用过程举例
    @ 初始化栈指针
    @ MOV SP,#0x40000020
    @MAIN:
    @ MOV R1,#10
    @ MOV R2,#5
    @ BL FUNC
    @ LDMFD SP!,{R1,R2}
    @ ADD R3,R1,R2
    @ B STOP
    @FUNC:
    @压栈保护现场
    @ STMFD SP!,{R1,R2}
    @ MOV R1,#10
    @ MOV R2,#20
    @ SUB R1,R2,R1
    @ MOV PC,LR
  • 非叶子函数的调用过程举例
    @ 初始化栈指针
    MOV SP,#0x40000020
    MAIN:
    MOV R1,#3
    MOV R2,#5
    BL FUNC1
    ADD R3,R1,R2
    B STOP
    FUNC1:
    STMFD SP!,{R1,R2,LR}
    MOV R1,#10
    MOV R2,#20
    BL FUNC2
    SUB R1,R2,R1
    LDMFD SP!,{R1,R2,LR}
    MOV PC,LR
    FUNC2:
    STMFD SP!,{R1,R2}
    MOV R1,#7
    MOV R2,#8
    MUL R3,R1,R2
    LDMFD SP!,{R1,R2}
    MOV PC,LR

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

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

相关文章

一劳永逸的方法解决:LNK1168无法打开 xxx.exe 进行写入 报错问题

这种错误的产生原因: 运行程序退出不是按正常流退出,是按窗口右上角的 “X” 来关闭程序,但是后台的xxx.exe控制台程序还在运行;修改程序的代码后再运行,就会报LNK1168的错误; 报错示例: 解决方…

第十七章垃圾回收器

第十七章垃圾回收器 文章目录 第十七章垃圾回收器1. GC分类与性能指标1.1 垃圾回收器概述1.2 垃圾回收器分类1.3 评估GC的性能指标吞吐量暂停时间吞吐量VS暂停时间 2. 不同的垃圾回收器概述七种经典垃圾回收器七种经典收集器与垃圾分代之间的关系垃圾收集器的组合关系如何查看默…

详细讲解Xilinx DDR3 的MIG IP生成步骤及参数含义

前几篇文章讲解了SDRAM到DDR3各自的变化,本文讲解如何使用DDR3,在Altera的Cyclone IV开发板上一般会使用SDRAM作为存储数据的芯片,而Xilinx的S6和7000系列一般使用DDR3作为存储数据的芯片。 从SDRAM芯片内部结构分析其原理,从内部…

【大模型系列】图文对齐(CLIP/TinyCLIP/GLIP)

文章目录 1 CLIP(ICML2021,OpenAI)1.1 预训练阶段1.2 推理阶段1.3 CLIP的下游应用1.3.1 ViLD:zero-shot目标检测(2022, Google)1.3.2 图像检索Image Retrival1.3.3 HairCLIP:图像编辑Image Editing(2022,中科大) 2 TinyCLIP(2023,…

【AI视野·今日Robot 机器人论文速览 第八十三期】Wed, 6 Mar 2024

AI视野今日CS.Robotics 机器人学论文速览 Wed, 6 Mar 2024 Totally 30 papers 👉上期速览✈更多精彩请移步主页 Interesting: 📚SpaceHopper,外星探索多功能三足机器人 (from Robotic Systems Lab, ETH Zurich) Daily Robotics Papers A Safety-Criti…

RAG综述 《Retrieval-Augmented Generation for Large Language Models: A Survey》笔记

文章目录 概述RAG 的定义RAG的框架Naive RAGAdvanced RAGpre-retrieval processRetrievalpost-retrieval process Modular RAG RetrievalEnhancing Semantic Representationschunk 优化 微调向量模型Aligning Queries and DocumentsAligning Retriever and LLM GenerationAugme…

【工具使用-VScode】VScode如何设置空格和tab键显示

一,简介 在提交代码的时候,行末尾的tab和空格不符合规范,但是如果在vscode中不显示tab和空格的话,不能及时的查看到并改正,导致提交代码之后还需要再次进行修改,效率比较低。 代码编辑界面如图所示&#…

1+x中级题目练习复盘(一)

1、MOD(m,n) 返回m除以n的余数 2、物理备份可以分为冷备份和热备份。冷备份又称脱机备份,是指在关闭数据库后进行的备份;而热备份也称为联机备份,是在数据库运行的同时进行备份,但热备份存在着难以维护等风险。 3、删除表使用…

Elastic Stack--05--聚合、映射mapping

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 1.聚合(aggregations)基本概念桶(bucket)度量(metrics) 案例 11. 接下来按price字段进行分组:2. 若想对所…

8核16G服务器支持多少人?2024年腾讯云8核16G18M轻量服务器

腾讯云8核16G轻量服务器CPU性能如何?18M带宽支持多少人在线?轻量应用服务器具有100%CPU性能,18M带宽下载速度2304KB/秒,折合2.25M/s,系统盘为270GB SSD盘,月流量3500GB,折合每天116.6GB流量&…

Qdrant 向量数据库的部署以及如何在 .NET 中使用 TLS 安全访问

本文介绍如何使用 Docker 部署 Qdrant 向量数据库,以及其相关的安全配置,并演示如何使用 .NET 通过 TLS 安全访问 Qdrant 向量数据库。 文章目录 1. 背景2. Qdrant 向量数据库的部署2.1 Qdrant 向量数据库的安全配置2.2 使用 Docker 部署安全的 Qdrant 向…

vulnstack1--红队靶机(第一部分)

环境搭建 Windows7x64 Windows server8(域控) Windows server3 注意密码是hongrisec2019,需要测试是否连通 Kali配置 Eth1是桥接的ip 流程 主机发现 目标应该是193 端口扫描 服务扫描 漏洞扫描 看一下web Win7的系统 目录爆破 web利用 …

【开源】SpringBoot框架开发教学资源共享平台

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 课程档案模块2.3 课程资源模块2.4 课程作业模块2.5 课程评价模块 三、系统设计3.1 用例设计3.2 类图设计3.3 数据库设计3.3.1 课程档案表3.3.2 课程资源表3.3.3 课程作业表3.3.4 课程评价表 四、系统展…

gensim 实现 TF-IDF;textRank 关键词提取

目录 TF-IDF 提取关键词 介绍 代码 textRAnk 提取关键词 这里只写了两种简单的提取方法,不需要理解上下文,如果需要基于一些语义提取关键词用 LDA:TF-IDF,textRank,LSI_LDA 关键词提取-CSDN博客 TF-IDF 提取关键词…

JavaEE进阶(15)Spring原理:Bean的作用域、Bean的生命周期、Spring Boot自动配置(加载Bean、SpringBoot原理分析)

接上次博客:JavaEE进阶(14)Linux基本使用和程序部署(博客系统部署)-CSDN博客 目录 关于Bean的作用域 概念 Bean的作用域 Bean的生命周期 源码阅读 Spring Boot自动配置 Spring 加载Bean 问题描述 原因分析 …

【stm32】hal库学习笔记--定时器输出PWM波

【stm32】hal库学习笔记–定时器输出PWM波 PWM波原理 输出比较 输入捕获 驱动函数 定时器驱动函数 PWM波驱动函数 定时器基本不使用DMA方式 定时器中断处理通用函数 HAL_TIM_IRQHandler实验一:输出固定占空比PWM波 时钟树配置 PF9 改为tim14CH1 tim14配置 开启tim14全局中…

基础GamePlay知识-矩形碰撞检测

主要介绍AABB碰撞检测下,矩形该如何和矩形进行碰撞检测/和圆形进行碰撞检测。 直接看图,主要是比较两个矩形的边界线的前后关系。 效果 分析什么时候重合 分析什么时候不重合 完整代码 矩形身上挂载 public class Rectangle : MonoBehaviour {public …

MES数据采集设备

在智能制造日益盛行的今天,MES(制造执行系统)作为连接计划与生产现场的关键环节,其重要性不言而喻。而MES数据采集设备则是MES系统的核心组件,负责实时、准确地获取生产现场的各种数据,为企业的生产决策提供…

内存卡损坏打不开:数据恢复全攻略

在我们的日常生活中,内存卡作为一种常见的存储设备,广泛应用于手机、相机、平板电脑等电子设备中。然而,有时我们会遇到内存卡损坏打不开的问题,导致重要的照片、视频或文件无法读取。面对这种情况,我们该如何应对呢&a…

mac电脑总卡蓝屏是怎么回事,苹果电脑老卡蓝屏怎么办

电脑老卡蓝屏是比较常见的电脑故障之一,导致这一问题的出现很可能是电脑本身的硬件,或电脑上的驱动安装错误,没法运行,当然也不排除其他的一些因素。虽说电脑蓝屏是电脑几乎都会出现的小毛病,不足以致命,但…