关于masm不能直接call imm的问题!

简介:

    很多人困惑为啥masm不能直接写call 立即数地址的汇编指令,如果你那样

写铁定报错的。但是查看intel指令手册这种指令编码方式是合法正确的。那么

只有推测是masm对此作了限制。

    解决的办法有很多,做一个间接调用 call [eax],或者call far xxx,或者直接

写byte码。

    其他的办法是在gcc内联汇编里写(VC的内联貌似还是不行):

__asm__ __volatile__("call 0x400000");

    但是这种写法会导致目标地址发生变化,要修正地址,即先算出修正增值:

addx,然后调用:

__asm__ __volatile__("call 0x400000+addx");

    最后完美的做法是用nasm,里面可以直接写:

    call 0x400000


相关文章
|
C语言 Android开发 Windows
解决windows下eclipse创建project时没有include导致出现“unresolved inclusion: <stdio.h>”错误的方法
解决windows下eclipse创建project时没有include导致出现“unresolved inclusion: <stdio.h>”错误的方法
解决windows下eclipse创建project时没有include导致出现“unresolved inclusion: <stdio.h>”错误的方法
用IAR打开STM8时,出现“Unable to create configuration 'Debug' using tool chain ‘STM8’
用IAR打开STM8时,出现“Unable to create configuration 'Debug' using tool chain ‘STM8’
450 0
|
3月前
bpf_func_id是如何产生的?
bpf_func_id是如何产生的?
|
小程序
小程序 define is not defined
小程序 define is not defined
160 0
|
7月前
|
程序员
深入理解汇编:平栈、CALL和RET指令详解
深入理解汇编:平栈、CALL和RET指令详解
138 1
|
前端开发 rax Shell
[PWN][高级篇]ROP-ret2libc-32/64位实例 (共四个)(上)
[PWN][高级篇]ROP-ret2libc-32/64位实例 (共四个)
829 0
[PWN][高级篇]ROP-ret2libc-32/64位实例 (共四个)(上)
|
Ubuntu C语言
【ubuntu】2.c:(.text+0xd2): undefined reference to `pthread_create‘ collect2: error: ld returned
【ubuntu】2.c:(.text+0xd2): undefined reference to `pthread_create‘ collect2: error: ld returned
148 0
用#define宏实现Add函数
用#define宏实现Add函数
108 0
解决办法:error LNK2005: "void * __cdecl operator new(unsigned int)" 已经在 LIBCMTD.lib(new.obj) 中定义
解决办法:error LNK2005: "void * __cdecl operator new(unsigned int)" 已经在 LIBCMTD.lib(new.obj) 中定义
284 0
|
NoSQL Shell
[PWN][高级篇]ROP-ret2libc-32/64位实例 (共四个)(下)
[PWN][高级篇]ROP-ret2libc-32/64位实例 (共四个)
289 0
[PWN][高级篇]ROP-ret2libc-32/64位实例 (共四个)(下)