16(%esp)真的违反直觉[esp+16]吗?是不是更合乎逻辑:
eax = 5
mov eax, 5
Run Code Online (Sandbox Code Playgroud)
at at&t是:
mov 5, eax
5 = a (? wait what ?)
Run Code Online (Sandbox Code Playgroud)
注意:我不是想乱跑.我只是不明白他们所做的设计选择,我试图了解他们为什么做了他们所做的.
想象一下你10年前写的这篇文章(在英特尔MPX和bnd0.. bnd3注册表甚至在路线图上之前):
section .data
; define some globals which are part of an ABI so you can't just rename them
global bnd0 ; MPX bound register name conflict
bnd0: dd 123
global k0 ; AVX512 mask register name conflict
k0: dq 12345
Run Code Online (Sandbox Code Playgroud)
如何使用当前版本的NASM进行组装? 即NASM(或YASM)是否与支持新注册名称的新版本具有向前兼容性?
显然,在单个文件或项目中搜索/替换很容易解决.但理论上,您可以将全局变量名称作为库ABI的一部分,您可以从NASM导出或需要导入到NASM中extern ymm0.(必须声明外部符号,因此无法识别的寄存器名称永远不会汇编为符号引用.)
NASM语法已经不适合作为平台上C编译器输出的格式,这些平台不会为符号名称添加前缀_或执行其他类型的名称修改(例如Linux ELF).你无法编译全局int eax = 1;. 这就是AT&T语法%eax用于寄存器名称的原因.对该答案的评论中的讨论是启发这个问题的原因.请注意,GAS不需要声明外部符号; 无法识别的名称被视为符号(即使在.intel_syntax noprefix使用类似于MASM的语法的模式中).
相关:MASM如何处理新扩展的前向源兼容性?
你能以某种方式禁用MPX支持吗?
YASM支持一个CPU指令,允许您禁用对某些助记符的支持,但即使禁用AVX支持也不允许您将其ymm0用作符号名称.(YASM …
x86-64汇编中操作数的顺序是什么?:指令目标,源或:指令源,目标
我有三本书和两种不同的方法!
x86标准是否包含助记符,还是仅定义操作码?
如果它不包含它们,那么不同的汇编程序是否有另一个标准?
在我的C++/C项目中,我想将堆栈指针设置为等于基指针 ...直观地,我会使用这样的东西:
asm volatile(
"movl %%ebp %%esp"
);
Run Code Online (Sandbox Code Playgroud)
但是,当我执行此操作时,我收到此错误消息:
Error: bad register name `%%ebp %%esp'
Run Code Online (Sandbox Code Playgroud)
我使用gcc/g ++版本4.9.1编译器.
我不知道我是否需要设置特定的g ++或gcc标志...应该有一种方法来操作esp和ebp寄存器,但我只是不知道正确的方法来做到这一点.
有谁知道如何在c ++中操纵这两个寄存器?也许我应该使用hexed OP代码?