X64 汇编
生成依赖项->生成自定义 勾选汇编选项
新建ASM文件
.code
addl proc
add rcx,rdx
mov rax,rcx
ret
addl endp
end
项目类型选择汇编
在头文件中导出
EXTERN_C ULONG64 addl(ULONG64 x, ULONG64 y);
然后就可以正常调用了,不能直接内联
X64内存
X64跟X86的寄存器上区别在于,X64新增了4个八位寄存器,8个64位寄存器跟8个128位寄存器(多用于浮点计算或多媒体)。字节方面新增了tbyte代表10字节。
X86中一个地址只有4字节,而64位中一个地址则有8字节,其中48位有效,而微软只使用了其中的44位。
0x00000000_00000000 到 0x00007FFF_FFFFFFFF 为用户地址
0x00008000_00000000 到 0xFFFF7FFF_FFFFFFFF 为空闲地址
0xFFFF8000_00000000 到 0xFFFFFFFF_FFFFFFFF 为内核地址
X64跟X86在内存寻址的方式上也存在区别,X86下全局变量就是单纯的一个地址,X64中全局变量的地址是RIP再加上偏移,类似这样计算。