首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >execve fault代码linux分段错误

execve fault代码linux分段错误
EN

Stack Overflow用户
提问于 2014-02-18 09:56:55
回答 1查看 1.2K关注 0票数 4

我试图运行这个外壳代码,但是它抛出了:“分段错误”错误外壳代码如下所示:

shellcode.asm:

代码语言:javascript
复制
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 code.o

我认为错误是当我使用mov ebx+x,al/eax/ebx,因为当我从代码中删除它时,没有错误

谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-02-18 12:04:24

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

代码语言:javascript
复制
section .shellcode  progbits alloc exec write align=16

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

或者,您可以重写外壳代码,以便它使用堆栈创建参数。

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21850056

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档