- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何为 Risc-V(汇编语言)编写 NOT 操作?如果没有 NOT 指令,你如何实现同样的事情?
最佳答案
与 MIPS 和其他一些架构一样,RISC V 不为许多事情提供专用指令,包括二元运算,因为这些运算可以使用它们的三运算数格式,通常使用 x0
作为第三个操作数,但有时常量 1
或 -1
作为第三个操作数。
为方便起见,汇编器将接受这些一元运算(及其他)的伪指令。以下是常见 RISC V 伪指令及其替代指令的列表。
要完成更复杂或未列出的事情,请使用数学和逻辑,并根据需要使用尽可能多的指令。
li rd, immediate | Myriad sequences | Load immediate
mv rd, rs | addi rd, rs, 0 | Copy register
not rd, rs | xori rd, rs, -1 | One’s complement
neg rd, rs | sub rd, x0, rs | Two’s complement
negw rd, rs | subw rd, x0, rs | Two’s complement word
sext.w rd, rs | addiw rd, rs, 0 | Sign extend word
seqz rd, rs | sltiu rd, rs, 1 | Set if = zero
snez rd, rs | sltu rd, x0, rs | Set if ̸= zero
sltz rd, rs | slt rd, rs, x0 | Set if < zero
sgtz rd, rs | slt rd, x0, rs | Set if > zero
beqz rs, offset | beq rs, x0, offset | Branch if = zero
bnez rs, offset | bne rs, x0, offset | Branch if ̸= zero
blez rs, offset | bge x0, rs, offset | Branch if ≤ zero
bgez rs, offset | bge rs, x0, offset | Branch if ≥ zero
bltz rs, offset | blt rs, x0, offset | Branch if < zero
bgtz rs, offset | blt x0, rs, offset | Branch if > zero
bgt rs, rt, offset | blt rt, rs, offset | Branch if >
ble rs, rt, offset | bge rt, rs, offset | Branch if ≤
bgtu rs, rt, offset | bltu rt, rs, offset | Branch if >, unsigned
bleu rs, rt, offset | bgeu rt, rs, offset | Branch if ≤, unsigned
j offset | jal x0, offset | Jump
jal offset | jal x1, offset | Jump and link
jr rs | jalr x0, 0(rs) | Jump register
jalr rs | jalr x1, 0(rs) | Jump and link register
ret | jalr x0, 0(x1) | Return from subroutine
call aa | auipc x1, aa[31 : 12] + aa[11] | Call far-away subroutine
| jalr x1, aa[11:0](x1) | (two instructions)
tail aa | auipc x6, aa[31 : 12] + aa[11] | Tail call far-away subroutine
| jalr x0, aa[11:0](x6) | (also two instructions)
顺便说一句,有一款名为 LC-3 的教育处理器。它只有三种算术/逻辑运算:ADD
、AND
、NOT
。然而,学生应该编写执行乘法、除法、模数、XOR
、OR
等的代码。!乘法和除法/模数是通过循环完成的; XOR
和 OR
是使用逻辑序列完成的——我们知道所有的 bool 运算都可以只使用 NAND 门,所以(只有)AND
& NOT
很原始但足够了。
我最喜欢的处理器上的 XOR
序列来自这个公式:
(A AND NOT B) + (NOT A AND B)
此处 +
的字面意思是 ADD
,它可以替代 OR
,因为两个操作数永远不会同时为 1同时,所以不会发生从一位位置到另一位位置的进位,在这种情况下,ADD
和 OR
是等价的。
关于assembly - 如何为 Risc-V(汇编语言)编写 NOT 操作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65006052/
我不确定 cbw命令实际上可以。我有一段代码: mov ax,0FF0h cbw idiv ah cbw后ax的值如何变化? 最佳答案 cbw指令将一个字节符号扩展为一个字。在这种情况下,它将采用
MIPS 架构中的.s 和.asm 有什么区别? 最佳答案 .s 和.asm 之间没有天生的区别 如果你愿意,你可以用 .s 命名文本文件,用 .asm 命名十六进制文件,但这只是为了让它们保持正直。
我正在业余时间学习汇编语言,以成为更好的开发人员。 我在概念层面上理解基于堆栈的机器和基于寄存器的机器之间的区别,但我想知道基于堆栈的机器实际上是如何实现的。如果是虚拟机,例如JVM 或 .NET,在
几周后我开始上大学(软件工程学位),并且知道我将在第一年学习的一个模块是“建筑基础”或类似的东西;基本上它是在学习“汇编”中的编程。 我想做一些背景学习,所以我为此做好了准备(我在其他一些单元上做了同
我是汇编语言的新手。我目前正在经历这个 Assembly Guide .我对 LEA 指令有疑问。我对LEA指令的理解是LEA用source operand的有效地址加载destination ope
x86 汇编中是否有模运算符或指令之类的东西? 最佳答案 如果您的模数/除数是一个已知常数,并且您关心性能,请参阅 this和 this .对于直到运行时才知道的循环不变值,乘法逆甚至是可能的,例如见
我是汇编语言的新手。我目前正在经历这个 Assembly Guide .我对 LEA 指令有疑问。我对LEA指令的理解是LEA用source operand的有效地址加载destination ope
我相信这对大多数人来说非常简单,但我对 x86 汇编语言不是很熟悉。我只是想自学。 我在 window 里。在我读到的任何地方,我都被告知要使用 INT 21返回操作系统。这退出了程序,但我收到一条错
我正在尝试输入一个字符串,然后查看该字符串中的最后一个值是否为 EOL 字符。我想我会使用读入的字符串的长度,然后将它添加到缓冲区的地址以找到最后一个元素。这似乎不起作用。 编辑:很抱歉我没有包含更多
; This program checks for even or odd parities inside of an array. Displays 1 if even or 0 if odd. I
我一直在努力掌握 x86 汇编语言,并且想知道是否有一个与 movl $1, %eax 等效的快速简短的语言。就在那时,我认为列出该语言中经常使用的习语可能是个好主意。 这可能包括首选使用 xorl
有人知道如何在 ARMv6 汇编语言中开始注释(例如“#”、“;”、“/”、“/*”)吗? 最佳答案 应该是“;”根据我在 wikipedia article: 上找到的一些示例代码 loop
; This program checks for even or odd parities inside of an array. Displays 1 if even or 0 if odd. I
我是一名利用业余时间学习汇编语言的大学生。我注意到虽然有像 add 和 mul 这样的指令,但算术运算符经常在指令中使用。例如: mov eax,[ebx+ecx] 它等价于以下吗? add ebx,
我真的是学习汇编语言的新手,并且刚刚开始研究汇编语言,所以我想知道也许有些人可以帮助我解决一个问题。我有一个作业,告诉我将汇编语言指令与C代码进行比较,并告诉我哪些C代码与汇编指令等效。所以这是组装说
假设我有以下代码: C++ 代码和内联汇编代码如下: 方程式: X=40+5 Y=3*12 ---> X=45 Y=36 测试 if x < y - print x+y else print x-y
我正在编写一个程序,其中的要求如下: 有一个名为 Name 的字符串变量,该变量设置为您的全名,包括空格。 只清除 AL 寄存器,不清除 EAX 寄存器的其余部分。 遍历 Name 变量中的每个字符。
我有一个任务,描述如下: - Reads printable characters (20h-7Fh) from the keyboard without echoing - Uppercase le
我正在查看 switch 语句的汇编语言代码。 我了解代码的工作原理以及情况。我的问题是如何决定案例名称? 下面是汇编语言代码,下面是我的解释。我基本上只需要使用跳转表并填写案例名称。 1 8
我是汇编语言新手,我想到了这个问题:构建代码、宏或过程哪个是更好的解决方案?虽然宏中包含的代码只是复制到所需的部分,并且允许执行代码而无需昂贵的跳转,但它确实添加了必须在程序执行时加载的额外指令。此外
我是一名优秀的程序员,十分优秀!