Linux内核设计第四周

——扒开系统调用三层皮

一、知识点总结

(一)、系统调用基础知识

1、用户态和内核态

内核态:在高级别的状态下,代码可以执行特权指令,访问任意的物理地址; 
用户态:在相应的低级别执行状态下,代码的掌控范围会受到限制。

区分: 
CPU每条指令的读取都是通过cs:eip,cs寄存器最低两位表明了当前代码的特权级。内核态下可访问所有地址空间。

  • 0xc0000000(逻辑地址)以上的空间只能在内核态下访问
  • 0x00000000 ~ 0xbfffffff 内核态和用户态均可访问

2、Intel x86 CPU有四种不同的执行级别0——3,Linux只是用了其中的0和3来表示内核态和用户态。

3、中断处理是是从用户态进入内核态的主要方式。系统调用只是一种特殊的中断。

4、用户态进入内核态需保存寄存器上下文:

  • 用户态寄存器上下文保存
  • 恢复内核态相应的寄存器值到CPU中

5、中断/int指令会在堆栈上保存一些寄存器的值。

  • 如:用户态栈顶地址、当时的状态字、当时的cs:eip的值。

6、中断发生后的第一件事就是保存现场,结束前最后一件事是恢复现场。

  • 保护现场就是进入中断程序 保存需要用到的寄存器的数据。
  • 恢复现场就是推出中断程序 恢复保存寄存器的数据。

7、中断处理的完整过程

interrupt(ex:int 0x80)-save

  • 保存了cs:eip、ss:esp、eflags到内核堆栈中
  • 加载了cs:eip、ss:esp到CPU中

SAVE_ALL

  • 完成中断服务,发生进程调度

RESTORE_ALL 
iret-pop cs:eip/ss:esp/eflags from kernel stack

(二)、系统调用概述

1、系统调用:操作系统为用户态进程与硬件设备进行交互提供了一组接口

2、系统调用的意义:

  • 把用户从底层的硬件编程中解放出来
  • 极大的提高了系统的安全性
  • 使用户程序具有可移植性

3、API:应用编程接口

4、操作系统提供的API和系统调用的关系

  • API:应用程序编程接口,是一个函数定义。
  • 系统调用:通过软中断向内核发出一个明确的请求。

5、Lib库定义的一些API引用了封装例程——唯一的目的是发布系统调用

  • 一般每个系统调用对应一个封装例程
  • 库再用这些封装例程定义出给用户的API。

特点:

  • API与系统调用不是一一对应的
  • API可以直接提供用户态服务(如:数学函数)
  • 一个单独的API可能调用几个系统调用
  • 不同的API可能调用了同一个系统调用

返回值:

  • 大部分封装例程返回一个整数,其值的含义依赖于相应的系统调用
  • -1表示内核不能满足进程请求
  • Libc中定义errno变量,包含特定出错码

6、系统调用三层皮

  • API
  • 中断向量
  • 中断服务程序

7、系统调用的参数传递: 
(1)寄存器传递参数具有如下限制:

  • 每个参数的长度不能超过寄存器的长度,即32位
  • 在系统调用号(eax)之外,参数的个数不能超过6个(ebx, ecx,edx,esi,edi,ebp)
  • 超过6个怎么办?把某一个寄存器作为一个指针,指向某一块内存。

(2)参数的种类

系统调用也需要输入输出参数 - 实际的值 - 用户态进程地址空间的变量的地址 - 甚至是包含指向用户态函数的指针的数据结构的地址

二、实验过程

我选择了调用39号系统调用mkdir,调用了系统函数sys_mkdir()

(一)直接进行系统调用的源代码如下图:

执行结果如下图:

(二)使用嵌入式汇编进行系统调用的源代码如下图:

执行结果如下图:

三、分析汇编代码调用系统调用的工作过程(参数的传递的方式)

如上的图片所示: mkdir系统调用

  • (1)需要传递两个参数,第一个是要新建文件夹的路径,第二个是新建文件夹的权限。
  • (2)有一个返回值,表示是否创建成功

我们在使用汇编代码调用系统函数sys_mkdir()时,需要利用寄存器传递参数,这里我选择,ebx、ecx寄存器传递两个参数、用eax寄存器传递返回值,只需要将输入的参数赋值给相应的寄存器即可,通过int指令,进入系统调用。

四、总结

阐明自己对“系统调用的工作机制”的理解。

  • (1)系统调用,就是用户提供系统调用号和相关函数参数,就可以执行相应的功能。
  • (2)而具体怎么实现是内核态在执行,用户是不需要考虑相关的堆栈变化,这样用户就可以轻松调用系统函数。

宋宸宁+ 原创作品转载请注明出处 + 《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000

Linux内核设计第四周——扒开系统调用三层皮的更多相关文章

  1. 20135327郭皓--Linux内核分析第四周 扒开系统调用的三层皮(上)

    Linux内核分析第四周 扒开系统调用的三层皮(上) 郭皓 原创作品转载请注明出处 <Linux内核分析>MOOC课程 http://mooc.study.163.com/course/U ...

  2. LINUX内核分析第四周——扒开系统调用的三层皮

    LINUX内核分析第四周--扒开系统调用的三层皮 李雪琦 + 原创作品转载请注明出处 + <Linux内核分析>MOOC课程http://mooc.study.163.com/course ...

  3. linux内核分析 第四周 扒开系统调用的三层皮(上)

    一.用户态.内核态和中断处理过程 系统调用是用户通过库函数方式:库函数帮我们把系统调用封装起来. 内核态:高级别执行,可以使用特权指令,访问任意的物理地址. 用户态:低级别执行,代码范围受到限制. C ...

  4. Linux内核设计第五周——扒开系统调用三层皮(下)

    Linux内核设计第五周 ——扒开系统调用三层皮(下) 一.知识点总结 1.给MenuOS增加新的命令的步骤 更新menu代码到最新版 test.c中main函数里,增加MenuConfig() 增加 ...

  5. Linux内核设计第四周学习总结 使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用

    陈巧然原创作品 转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 实验目的: 使用库函数A ...

  6. Linux内核分析 笔记五 扒开系统调用的三层皮(下) ——by王玥

    (一)给MenuOs增加time和time-asm命令 更新menu代码到最新版 在main函数中增加MenuConfig 增加对应的Ttime和TimeAsm函数 make rootfs (二)使用 ...

  7. linux内核设计与实现--进程调度 系统调用

    进程可以分为I/O消耗型和处理器消耗型. I/O消耗型指,进程的大部分时间用来提交I/O请求或者等待I/O请求. 处理器耗费型进程把时间大多用在执行代码上. linux采用了两种不同的优先级范围: 第 ...

  8. LINUX内核分析第四周学习总结——扒开系统调用的“三层皮”

    LINUX内核分析第四周学习总结--扒开系统调用的"三层皮" 标签(空格分隔): 20135321余佳源 余佳源 原创作品转载请注明出处 <Linux内核分析>MOOC ...

  9. Linux内核分析第四周学习总结:扒开系统调用的三层皮(上)

    韩玉琪 + 原创作品转载请注明出处 + <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 一.用户态.内核 ...

随机推荐

  1. BZOJ4157 : 星际瘟疫

    首先剔除所有从$R$不可到达的点,然后用Lengauer-Tarjan算法建立出以$R$为起点的Dominator Tree. 那么对于每个询问,求出那些点的父亲的LCA,那么答案就是LCA到根路径上 ...

  2. Spring AOP报错处理 Can not set field to $Proxy 在spring中使用事物或AOP遇到的错误

    [转] 解决方法: http://forum.springsource.org/showthread.php?85016-IllegalArgumentException-with-Applicati ...

  3. 洛谷 P1433 吃奶酪 Label:dfs && 剪枝Ex

    题目描述 房间里放着n块奶酪.一只小老鼠要把它们都吃掉,问至少要跑多少距离?老鼠一开始在(0,0)点处. 输入输出格式 输入格式: 第一行一个数n (n<=15) 接下来每行2个实数,表示第i块 ...

  4. jQuery的事件委托实例分析

    事件委托主要是利用事件冒泡现象来实现的,对于事件委托的精准的掌握,可以有利于提高代码的执行效率.先看一段代码实例: <!DOCTYPE html> <html> <hea ...

  5. wamp环境下安装memcached最好的详解教程^.^:(只需要3个步骤 )

    win8.1 wampserver2.5 -Apache-2.4.9-Mysql-5.6.17-php5.5.12-64b 可以参考一下部分讲解有图,我就是看4-5个讲解,结合有一篇的截图最终才搞定的 ...

  6. CF 22B. Bargaining Table

    水题.好久没有写过优化搜索题了. #include <cstdio> #include <cstring> #include <iostream> #include ...

  7. Android -- 通知栏的使用

    1. 效果图

  8. BZOJ1443: [JSOI2009]游戏Game

    如果没有不能走的格子的话,和BZOJ2463一样,直接判断是否能二分图匹配 现在有了一些不能走的格子 黑白染色后求出最大匹配 如果是完备匹配,则无论如何后手都能转移到1*2的另一端,故先手必输 否则的 ...

  9. iOS定时器

    主要使用的是NSTimer的scheduledTimerWithTimeInterval方法来每1秒执行一次timeFireMethod函数,timeFireMethod进行倒计时的一些操作,完成时把 ...

  10. 前端自动化工具 -- grunt 使用简介

    grunt作为一个前端构建工具,有资源压缩,代码检查,文件合并等功能. 下面就简单了解grunt的使用. 一.环境配置 grunt是基于nodejs的,所以需要一个 nodejs 环境,未了解的可以  ...