《Linux C一站式编程》:不加 int $0x80 导致段错误
在 《Linux C一站式编程》中有这样一个问题:
.section .data
.section .text
.globl _start
_start:
movl $1, %eax # this is the linux kernel command
# number (system call) for exiting
# a program
movl $4, %ebx # this is the status number we will
# return to the operating system.
# Change this around and it will
# return different things to
# echo $?
int $0x80 # this wakes up the kernel to run
# the exit command
在上面的汇编代码中,如果将 int $0x80
这一句去掉,也能够编译链接成功,但是却会导致一个段错误,请问这是为什么?
谢谢大家了~
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
这是一个中断,操作系统(这个 int 80 是在 Linux 下)定死的,现推荐用
SYSENTER
. 那么一个调用最后没有SYSENTER
或者SYSEXIT
,当然会报错啦。它的作用去 Google 把,我就不当搬运工啦,毕竟很长时间没有接触了。
程序从_start入口开始执行,如果去掉int $0x80,当执行完movl $4, %ebx,后就没有调用_exit系统调用结束程序,于是会接着从程序加载内存位置之后取下一条不属于本程序的指令,于是出现段错误