CSAPP:异常控制流

Posted Runnyu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CSAPP:异常控制流相关的知识,希望对你有一定的参考价值。

在一般的情况下,处理器处理的指令序列是相邻的(顺序执行)。

异常控制流提供了指令的跳转,它一部分是由硬件实现的,一部分是由操作系统实现的。

 

 

异常处理

在系统启动时,操作系统分配和初始化一张称为异常表的跳转表:

 

 

触发异常时将从跳转表中找到并执行相应的异常处理程序的代码(所谓的内核态代码?):

 

 

 

系统调用

每个系统调用都属于异常,当调用C库中的系统调用函数时将触发异常。

IA32系统中,系统调用是通过一条称为int 0x80(异常号)的陷阱指令来提供的。

所有Linux的系统调用都是通过寄存器来传递的。

下面是一个系统调用的例子

int main()
{
    write(1, "hello, world\\n", 13);
    exit(0);      
}

相应的汇编代码

main:
    movl $4, %eax       系统调用号
    movl $1, %ebx       文件描述符
    movl $string, %ecx "hello, world\\n"
    movl $len, %edx     长度
    int $0x80
    ...

以上是关于CSAPP:异常控制流的主要内容,如果未能解决你的问题,请参考以下文章

CSAPP读书笔记--第八章 异常控制流

csapp:第八章 异常控制流ECF

CSAPP异常控制流 | 异常表 | 异常类别 | 同步异常 | 异步异常

CSAPP:第八章 异常控制流2

CSAPP第八章

关于异常控制流和系统级 I/O:进程