【发布时间】:2010-11-24 11:57:37
【问题描述】:
你好,所以。
我有一些代码尝试使用 gcc 进行编译,但我的尝试遭到了挫败。谁能更精通这个主题,也许我缺少一些东西。
我正在 Linux Kitchen 2.6.28-15-generic #49-Ubuntu SMP Tue Aug 18 19:25:34 UTC 2009 x86_64 GNU/Linux 上编译此代码。
int
main(void)
{
__asm__(
"xorq %rdx,%rdx"
"movq $0x68732f6e69622fff, %rdx"
"shr $0x8, %rbx"
"push %rbx"
"movq %rsp,%rdi"
"xorq %rax,%rax"
"pushq %rax"
"pushq %rdi"
"movq %rsp,%rsi"
"mov $0x3b, %al"
"syscall"
"pushq $0x1"
"pop %rdi"
"pushq $0x3c"
"pop %rax"
"syscall"
);
return 0;
}
返回的错误是:
$ gcc -o shellcode shellcode.c
shellcode.c: Assembler messages:
shellcode.c:4: Error: bad register name `%rdxmovq $0x68732f6e69622fff'
谢谢大家。
【问题讨论】:
-
你也可以内联你的程序集(如果它对你来说更容易的话)。见stackoverflow.com/questions/3139772/check-if-carry-flag-is-set/…。
标签: gcc assembly x86 x86-64 inline-assembly