linux - execve shellcode linux段错误

标签 linux assembly nasm

我试图运行这个 shellcode 但它抛出我:“Segmentation fault”错误 shellcode如下:

shellcode.asm:

global _start
_start:

jmp short ca
doit:
pop ebx
xor eax, eax
cdq
mov byte [ebx+7], al
mov long [ebx+8], ebx
mov long [ebx+12], eax
lea ecx, [ebx+8]
mov byte al, 0x0b

int 0x80
ca:
call doit
db '/bin/sh'

我编译它:'nasm -f elf shellcode.asm' 并将其链接为:'ld -m elf_i386 -s -o shellcode shellcode.o

我认为错误是当我使用 mov [ebx+x], al/eax/ebx 因为当我从代码中删除它时,你不会出错

谢谢

最佳答案

您的问题是 .text 部分默认情况下不可写。最简单的做法是将您的代码放入标记为可写的新自定义部分。在您的 asm 文件顶部添加此行:

section .shellcode  progbits alloc exec write align=16

您还可以将 -N 开关传递给链接器。

或者,您可以重写 shellcode,以便它使用堆栈来创建参数。

关于linux - execve shellcode linux段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21850056/

相关文章:

linux - 如何链接C语言库?

linux - 计划磁盘扫描

linux - git -H 做什么?

linux - 纸牌屋 - 有多现实?

gcc - %ebp 和 %esp 的 gcc 内联汇编中的字母是什么?

assembly - MinGW 32 "undefined reference to ` 退出进程@ 4'"

linux - Cron 没有为用户运行

c++ - if else 比 if + default 快吗?

macos - 在 OSX 中安装 GNU 汇编器

windows - 如何将 .asm 文件汇编并链接到 Win32 可执行文件?