当前位置: 首页 > article >正文

【ASMbits--常用算术运算指令】

ASMbits--常用算术运算指令

  • 1 基本运算算术指令--最基础
    • 1.1 加法和减法
    • 1.2 移位操作
    • 1.3 乘法
  • 2 practice
    • 2.1 编写invert(int n)
    • 2.2 编写judge_odd(int n)
    • 2.3 计算绝对值abs(int n)
    • 2.4 add(int n1, int n2)函数
    • 2.4 shift寄存器
    • 2.5 sihft ath right
    • 2.6 shift left

在ARMv7汇编中,代码片段:

1: b 1b	//Done

作用是创建一个无限循环,使程序永远停留在当前位置,不在执行后续命令;

语法解释:

  • 1::这是一个局部标签(local label)。在 ARM 汇编中,以数字开头的标签(如 1:)是局部标签,可以通过 b 1b 或 b 1f 引用。
    1b:表示向后查找最近的 1: 标签(Backward)。
    1f:表示向前查找最近的 1: 标签(Forward)。

  • b 1b:这是一个分支指令(Branch),跳转到最近的 1: 标签(向后查找)。由于标签 1: 就在当前行,这条指令会无限循环跳转到自身。

代码 1: b 1b 的作用是让程序在当前位置无限循环,防止后续未定义代码的执行。这是裸机编程或嵌入式系统中常见的“安全终止”方法。
具体在裸机程序(无操作系统)或嵌入式系统中,这种无限循环常用于:

  • 防止程序执行到未定义的内存区域(例如代码结束后未初始化的内存)。
  • 保持程序在完成所有任务后“挂起”(例如在调试时观察结果);

1 基本运算算术指令–最基础

1.1 加法和减法

  • ADD 加法
    语法:ADD{条件}{S} 目标寄存器, 操作数1, 操作数2
    功能:将操作数1和操作数2相加,结果存入目标寄存器。
ADD R0, R1, R2     @ R0 = R1 + R2
ADD R3, R4, #10    @ R3 = R4 + 10
  • SUB减法
    语法:SUB{条件}{S} 目标寄存器, 操作数1, 操作数2
    功能:从操作数1中减去操作数2,结果存入目标寄存器。
SUB R0, R1, R2     @ R0 = R1 - R2
SUB R3, R4, #5      @ R3 = R4 - 5

1.2 移位操作

  • LSL逻辑左移
    语法:LSL{条件}{S} 目标寄存器, 操作数, 移位位数
    功能:将操作数左移指定位数,低位补零。
LSL R0, R1, #4      @ R0 = R1 << 4
  • LSR逻辑右移
    语法:LSR{条件}{S} 目标寄存器, 操作数, 移位位数
    功能:将操作数右移指定位数,高位补零。
LSR R0, R1, #3      @ R0 = R1 >> 3(无符号)
  • ASR(算术右移)
    语法:ASR{条件}{S} 目标寄存器, 操作数, 移位位数
    功能:将操作数右移指定位数,高位补符号位(用于有符号数)
ASR R0, R1, #2      @ R0 = R1 >> 2(保留符号)
  • ROR循环右移
    语法:ROR{条件}{S} 目标寄存器, 操作数, 移位位数
    功能:将操作数循环右移指定位数,移出的位补到高位。
ROR R0, R1, #8      @ R0 = R1 循环右移8位

1.3 乘法

  • MUL无符号乘法
    语法:MUL{条件}{S} 目标寄存器, 操作数1, 操作数2
    功能:操作数1 × 操作数2,结果低32位存入目标寄存器。
MUL R0, R1, R2     @ R0 = (R1 × R2) 的低32位
  • MIL乘加
    语法:MLA{条件}{S} 目标寄存器, 操作数1, 操作数2, 操作数3
    功能:操作数1 × 操作数2 + 操作数3。
MLA R0, R1, R2, R3  @ R0 = (R1 × R2) + R3

2 practice

2.1 编写invert(int n)

Write a function that returns the bitwise inversion of its parameter.
int invert (int n);

.global _start
_start:mov r0, #1bl invert1: b 1b    // Done.global invert
invert:MVN r0,r0  // MVN把R0里面的数取反然后再进行存储BX lr	//return caller

2.2 编写judge_odd(int n)

算法:最低位是0还是1,若是1则odd为1,若是为0,则odd为0;如何获得最低位呢,直接使用n & 1;
Steps:

  1. 将r0与1进行AND操作,结果存在某个寄存器,比如r0本身。
  2. 然后比较这个结果是否为0,如果不为0,则返回1,否则返回0。
.global _start
_start:mov r0, #1bl odd1: b 1b    // Done.global odd
odd:AND r0,r0,#1BX lr

2.3 计算绝对值abs(int n)

算法:进制补码中,负数的符号位是1,正数或零是0。所以,如果我能得到符号位的掩码,可能可以用异或和减法来计算绝对值。比如,对于n,如果符号位是0,那么绝对值是n本身;如果符号位是1,绝对值是~n + 1。或者用另一种方法:将n与符号位的掩码异或,然后减去掩码。这可能更高效。
步骤:

  1. 将n算术右移31位,得到mask(0或-1)。
  2. 异或n和mask,得到n ^ mask。
  3. 减去mask,即(n ^ mask) - mask。因为mask是0或-1,当mask是-1时,减法相当于加1。
.global _start
_start:mov r0, #10bl abs1: b 1b    // Done.global abs
abs:ASR r1, r0, #31	// r1 = n>>31 to generate maskEOR r0, r0, r1		// r0 = n ^ maskSUB r0, r0, r1		// r0 = r0 - maskBX lr

2.4 add(int n1, int n2)函数

即第一个参数传递给R0,第二个参数传递给R1;

.global _start
_start:mov r0, #1  // First function parameter is always passed through r0.mov r1, #1  // Second function parameter is always passed through r1.bl add      // Return value is always in r0.1: b 1b     // Done.global add
add:ADD R0,R0,R1BX LR

2.4 shift寄存器

即将该参数移位到24位,低8位;

.global _start
_start:ldr r0, =0x12345678bl shiftb _start        // End of testing code// Convert one U32 sample to U8 format
shift:LSR r0,r0,#24	//将输入参数 r0 右移24位,保留高8位到低8位BX lr

2.5 sihft ath right

// A test case to test your function with.global _start
_start:ldr r0, =0x40000bl shiftb _start        // End of testing code// Return 1/4 amplitude for a S32 sample
shift:ASR r0,r0,#2	//算数右移BX lr

2.6 shift left

// A test case to test your function with.global _start
_start:ldr r0, =0x1234bl shiftb _start        // End of testing code// Convert one S16 to S32 format
shift:LSL R0,R0,#16	// left shift 16BX lr

以上是ARMv7汇编语言的常见算术指令运算;

相关文章:

【ASMbits--常用算术运算指令】

ASMbits--常用算术运算指令 1 基本运算算术指令--最基础1.1 加法和减法1.2 移位操作1.3 乘法 2 practice2.1 编写invert(int n)2.2 编写judge_odd(int n)2.3 计算绝对值abs(int n)2.4 add(int n1, int n2)函数2.4 shift寄存器2.5 sihft ath right2.6 shift left 在ARMv7汇编中&…...

计算机基础:二进制基础12,十进制数转换为十六进制

专栏导航 本节文章分别属于《Win32 学习笔记》和《MFC 学习笔记》两个专栏&#xff0c;故划分为两个专栏导航。读者可以自行选择前往哪个专栏。 &#xff08;一&#xff09;WIn32 专栏导航 上一篇&#xff1a;计算机基础&#xff1a;二进制基础11&#xff0c;十六进制的位基…...

SpringCloud系列教程(十四):Sentinel持久化

Sentinel之前已经搭建和应用成功了&#xff0c;但是它有一个很大的缺点就是官方没有提供持久化的方案&#xff0c;从项目源码上看感觉这款工具也没有完成的太好&#xff0c;所以需要我们去对它进行二次开发。要补充的功能大概如下&#xff1a; 1、将Sentinel接入nacos中&#…...

Slider,InputField,Scroll View,Scrollbar及Layout组件

Slider组件 Fill Rect:填充滑动条选中区域的背景图部分 Handle Rect:滑动条的球 Direction:滑动条的滑动方向 Min Value:起始位置的数值&#xff08;浮点数&#xff09; Max Value:结束位置的数值&#xff08;浮点数&#xff09; Whole Numbers:必须为整数&#xff08;布尔…...

ollama注册自定义模型(GGUF格式)

文章目录 ollama注册自定义模型&#xff08;GGUF格式&#xff09;下载模型注册模型(GGUF格式) ollama注册自定义模型&#xff08;GGUF格式&#xff09; 需要全程开启ollama nohup ollama serve > ollama.log 2>&1 &需要注意&#xff0c;尽管手动下载的GGUF格式模…...

【算法】 区间合并(附蓝桥杯真题) python

步骤 1.先将所有区间按左端点排序 2.从前往后扫一遍&#xff0c;维护当前正在合并的区间[st, ed] 3.依次检查每个区间[l, r]&#xff0c; 若 l > ed,将[st, ed]加入 ans , 更新st l,ed r 若 l < ed &#xff0c;更新ed max(ed, r) 时间复杂度 O(nlogn) 模板 https:/…...

关于重构分析查询界面的思考(未完)

业务系统里&#xff0c;查询界面很常见&#xff0c;数据分析场景需求普遍而迫切&#xff0c;而新的技术也在不断出现&#xff0c;很有必要重构分析查询界面。 查询筛选 为了尽可能从数据中发现&#xff0c;需要尽可能地将查询条件添加进来&#xff0c;可这样&#xff0c;查询…...

机器人技能列表

一、机器人制作基础入门 &#xff08;一&#xff09;机器人概述 1.机器人的定义与分类 2.机器人的发展历程与现状 3.机器人在各领域的应用案例 &#xff08;二&#xff09;必备工具与材料 4.常用电子工具介绍&#xff08;万用表、电烙铁等&#xff09; 5.机械加工工具&…...

五大基础算法——分治算法

分治算法 是一种通过将问题分解为多个规模较小的子问题&#xff0c;递归解决子问题&#xff0c;然后将子问题的解合并为原问题解的算法思想。它通常包含三个步骤&#xff1a;分解&#xff08;Divide&#xff09;、解决&#xff08;Conquer&#xff09; 和 合并&#xff08;Comb…...

HarmonyOS NEXT 声明式UI语法学习笔记-创建自定义组件

基础语法概述 ArkTS的基本组成 装饰器&#xff1a;用于装饰类、结构、方法以及变量&#xff0c;并赋予其特殊含义。如上图都是装饰器&#xff0c;Component表示自定义组件&#xff0c;Entry表示表示自定义组件的入口组件&#xff0c;State表示组件中的状态变量&#xff0c;当状…...

补充二分LIS

B3637 最长上升子序列 题目描述 这是一个简单的动规板子题。 给出一个由 n ( n ≤ 5000 ) n(n\le 5000) n(n≤5000) 个不超过 1 0 6 10^6 106 的正整数组成的序列。请输出这个序列的最长上升子序列的长度。 最长上升子序列是指&#xff0c;从原序列中按顺序取出一些数字排…...

用户模块——握手验证

1. 引言 在现代 Web 应用中&#xff0c;WebSocket 以其全双工通信、低延迟、减少 HTTP 开销等优势&#xff0c;被广泛应用于即时通讯、在线游戏、实时数据推送等场景。然而&#xff0c;在涉及用户认证时&#xff0c;WebSocket 存在一个常见问题——每次刷新页面都会重新建立 We…...

97.HarmonyOS NEXT跑马灯组件教程:基础概念与架构设计

温馨提示&#xff1a;本篇博客的详细代码已发布到 git : https://gitcode.com/nutpi/HarmonyosNext 可以下载运行哦&#xff01; HarmonyOS NEXT跑马灯组件教程&#xff1a;基础概念与架构设计 1. 跑马灯组件概述 跑马灯&#xff08;Marquee&#xff09;是一种常见的UI组件&a…...

81.HarmonyOS NEXT 状态管理与响应式编程:@Observed深度解析

温馨提示&#xff1a;本篇博客的详细代码已发布到 git : https://gitcode.com/nutpi/HarmonyosNext 可以下载运行哦&#xff01; HarmonyOS NEXT 状态管理与响应式编程&#xff1a;Observed深度解析 文章目录 HarmonyOS NEXT 状态管理与响应式编程&#xff1a;Observed深度解析…...

【Agent】OpenManus-Agent架构详细分析

各组件详细设计见&#xff1a; BaseAgent&#xff1a;BaseAgentReActAgent&#xff1a;ReActAgentToolCallAgent&#xff1a;ToolCallAgent具体Agent实现&#xff1a;具体AgentMemory数据结构&#xff1a;Memory 1. 智能体层次结构 OpenManus 采用了一个多层次的智能体继承结…...

股指期货有卖不出去的时候吗?

在股指期货的交易世界里&#xff0c;很多人都有这样的疑问&#xff1a;股指期货会不会有卖不出去的时候呢&#xff1f;答案是会的&#xff0c;下面咱们就来详细唠唠为啥会出现这种情况。 市场极端行情下难以卖出 1.跌停限制&#xff1a;股指期货和股票一样&#xff0c;也有涨…...

前端Html5 Canvas面试题及参考答案

目录 Canvas 元素的默认尺寸是多少?如何正确设置其宽高以避免图像拉伸? 如何获取 Canvas 的 2D 上下文对象?3D 上下文支持哪些技术? canvas.width 与 canvas.style.width 的区别是什么? Canvas 支持的图像格式有哪些?如何将 Canvas 转换为 Base64 图片? Canvas 中如…...

【ES6】03-Set + Map

本文介绍两种集合 set map 的操作和方法。 目录 1. Set 1.1 set基本使用 1.2 add 1.3 delete 1.4 has 1.5 size 1.6 set转换为数组 1.7 拓展运算符 1.8 for...of 1.9 forEach 1.10 set给数组去重 2. Map 2.1 创建map集合 2.2 set添加元素 2.3 delete删除元素 …...

Java缓存String(字符串常量池)、Integer (-128 到 127 )

对问题的解释 1. “字符串常量池存储的是string对象的直接引用&#xff0c;而不是直接存放的对象&#xff0c;是一张string table” 的含义 这句话可以从以下几个方面理解&#xff1a; (1) 字符串常量池的存储内容 直接引用&#xff1a;字符串常量池中存储的是指向实际 Stri…...

消息队列的特性与使用场景:Kafka、ActiveMQ、RabbitMQ与RocketMQ的深度剖析

在分布式系统和微服务架构中&#xff0c;消息队列是实现服务间通信和解耦的核心组件。Kafka、ActiveMQ、RabbitMQ和RocketMQ是当前最受欢迎的消息队列解决方案&#xff0c;它们各自具有独特的特性和适用场景。本文将从特性和使用场景两个维度进行对比分析&#xff0c;帮助读者更…...

开发、科研、日常办公工具汇总(自用,持续更新)

主要记录汇总一下自己平常会用到的网站工具&#xff0c;方便查阅。 update&#xff1a;2025/2/11&#xff08;开发网站补一下&#xff09; update&#xff1a;2025/2/21&#xff08;补充一些AI工具&#xff0c;刚好在做AI视频相关工作&#xff09; update&#xff1a;2025/3/7&…...

解决VueI18n使用浏览器插件翻译后,切换国际化失效的问题

问题复现 在使用Vue-i18n对页面进行国际化的时候&#xff0c;使用浏览器翻译插件&#xff08;如腾讯翻译&#xff09;后&#xff0c;切换国际化语言&#xff0c;随后当我们关闭浏览器翻译插件后&#xff0c;再次切换国际化语言&#xff0c;原来被翻译的文字无法正确切换 出现…...

HTML5 drag API实现列表拖拽排序

拖拽API&#xff08;Drag and Drop API&#xff09;是HTML5提供的一组功能&#xff0c;使得在网页上实现拖放操作变得更加简单和强大。这个API允许开发者为网页元素添加拖拽功能&#xff0c;用户可以通过鼠标将元素拖动并放置到指定的目标区域。 事件类型 dragstart&#xff1…...

改变一生的思维模型【11】升维

升维思维模型&#xff1a;突破认知局限的破局法则 一、定义与核心逻辑 升维思维是通过增加分析维度&#xff0c;将问题投射到更高认知层次寻找解决方案的思考方式。其本质是跳出原有竞争维度&#xff0c;在更广阔的空间重构游戏规则。核心逻辑在于&#xff1a;当低维战场陷入…...

【动手学深度学习】#2线性神经网络

主要参考学习资料&#xff1a; 《动手学深度学习》阿斯顿张 等 著 【动手学深度学习 PyTorch版】哔哩哔哩跟李牧学AI 目录 2.1 线性回归2.1.1 线性回归的基本元素线性模型损失函数解析解随机梯度下降 2.1.3 最大似然估计 2.2 线性回归从零开始实现2.2.1 生成数据集2.2.2 读取数…...

计算机网络——NAT

一、什么是NAT&#xff1f; NAT&#xff08;Network Address Translation&#xff0c;网络地址转换&#xff09; 是一种将 私有IP地址 与 公有IP地址 相互映射的技术&#xff0c;主要用于解决IPv4地址不足的问题。它像一名“翻译官”&#xff0c;在数据包经过路由器或防火墙时…...

Stable Deffusion--常见模型插件详解

1.Checkpoint大模型 Checkpoint 是生成图像的基础模型&#xff0c;决定了整体画风如动漫、写实、机甲等。它是必选项&#xff0c;所有图像生成必须基于一个主模型。文件体积较大通常 1.5GB 以上&#xff0c;格式为 .ckpt 或 .safetensors。 存放位置为&#xff1a;\models\Sta…...

防重复提交详解:从前端Vue到后端Java的全面解决方案

防重复提交详解&#xff1a;从前端Vue到后端Java的全面解决方案 一、重复提交问题概述 在Web应用开发中&#xff0c;表单重复提交是一个常见问题&#xff0c;可能导致&#xff1a; 数据库中出现重复记录重复执行业务逻辑&#xff08;如多次扣款&#xff09;系统资源浪费用户…...

同一子网通信

添加交换机后的通信流程 1. 同一子网内&#xff08;使用交换机&#xff09; 判断是否在同一子网&#xff1a; 主机A通过子网掩码判断主机B的IP地址是否属于同一子网。若在同一子网&#xff0c;主机A需要通过ARP获取主机B的MAC地址。 ARP请求&#xff08;广播&#xff09;&…...

快速迭代:利用 nodemon 和其他工具实现 Express.js 热更新

在开发 Express.js 应用时&#xff0c;热更新&#xff08;Hot Reloading&#xff09;可以显著提升开发效率&#xff0c;因为它允许你在修改代码后立即看到效果&#xff0c;而无需手动重启服务器。以下是几种实现热更新的方法和工具&#xff0c;帮助你在开发过程中更高效地工作。…...