使用库函数API和C代码中嵌入汇编代码两种方式使用同一个系统调用

方法一:使用库函数API在屏幕上显示进程的ID

    先在实验楼中打开XFCE,在目录下输入指令: vi getpid.c;新建并打开getpid.c文件。

    随后再在VI中输入在网上查阅的实现getpid的函数代码后,保存并退出。

    随后再同gcc将该函数代码进行编译。再通过输入指令./getpid即可得出目前进程的ID为:22056.

这种方式是用C语言使用库函数API进行系统调用。

方法二:使用C语言内嵌汇编代码在屏幕上显示进程ID

对于内嵌汇编调用system_call()

    1、系统调用号放入eax中。

    2、系统调用的参数,按照顺序存入相应寄存器中。

    3、返回值使用eax传递值。

     因为中断(包括异常)是从用户态进入内核态的唯一方式,所以在上述代码中使用了中断(“int $s0x80\n\t”这句),然后中断处理程序SAVE_ALL保存现场,随后就进入了内核态

进行下一步的操作。
  • 中断处理
     中断处理是从用户态进入内核态主要的方式,系统调用是一种特殊的中断。

     中断处理的完整过程(由中断信号或者int指令完成): 将cs:eip的值,堆栈段寄存器当前的栈顶(ss:eip)和当前的标志寄存器(eflags)保存到内核堆栈中;同时将当前中断服

务例程的入口加载到cs:eip中,当前堆栈段和eip也加载到CPU中。执行完以上以上步骤之后,当前CPU在执行下一条指令时,就已经开始执行整个中断处理程序的入口了。此时已经

开始操作内核态的堆栈了。

     若完成中断服务之后不发生进程调度,则继续执行指令(RESTORE_ALL和iret),然后返回到原来的状态;

     若发生进程调度,那么当前发生的状态都会暂时的保存在系统中,当下一次发生调度再次回到当前进程时就继续执行指令RESTORE_ALL和iret。

  • 系统调用的工作机制:

      用户态中xyz()函数就是系统调用对应的API;

      这个API中封装了一个系统调用,这个系统调用会触发int 0x80的一个中断;

      0x80这个中断向量就对应着system_call(内核代码的入口起点);

      内核代码中可能会执行到对应的中断服务程序sys_xyz();

      在中断服务程序执行完之后,可能会执行ret指令,此时可能会发生进程调度;

      如果没有发生进程调度,就执行iret,返回到用户态接着执行其他指令。

实验总结:

       即便是最简单的程序,也难免要用到诸如输入、输出以及推出等操作,而要进行这些操作则需要调用操作系统所提供的服务,也就是系统调用。除非程序中只完成加减乘除等数学

算法,否则将很难避免使用系统调用。在Linux平台下有两种方式来采用系统调用:利用封装后的C库或者通过汇编直接调用。

      这次实验,我知道了如何进行系统调用,但是对于代码,我只能选择借鉴,汇编的知识也不太熟练,不过这次实验让我更加熟悉了系统调用的本质和系统调用与中断的关联。中断

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

系统调用的工作机制:

       1、用户态中的xyz()函数就是系统调用所对应的系统API;

       2、在这个API中将系统调用封装好,并在执行时触发int 0x80这个中断。对应内核态的system_call();

       3、system_call()中可能会执行中断服务程序sys_xyz()

《Linux内核原理与设计》第五周作业的更多相关文章

  1. 20169212《Linux内核原理与分析》第二周作业

    <Linux内核原理与分析>第二周作业 这一周学习了MOOCLinux内核分析的第一讲,计算机是如何工作的?由于本科对相关知识的不熟悉,所以感觉有的知识理解起来了有一定的难度,不过多查查资 ...

  2. 20169210《Linux内核原理与分析》第二周作业

    <Linux内核原理与分析>第二周作业 本周作业分为两部分:第一部分为观看学习视频并完成实验楼实验一:第二部分为看<Linux内核设计与实现>1.2.18章并安装配置内核. 第 ...

  3. 2018-2019-1 20189221 《Linux内核原理与分析》第九周作业

    2018-2019-1 20189221 <Linux内核原理与分析>第九周作业 实验八 理理解进程调度时机跟踪分析进程调度与进程切换的过程 进程调度 进度调度时机: 1.中断处理过程(包 ...

  4. 2017-2018-1 20179215《Linux内核原理与分析》第二周作业

    20179215<Linux内核原理与分析>第二周作业 这一周主要了解了计算机是如何工作的,包括现在存储程序计算机的工作模型.X86汇编指令包括几种内存地址的寻址方式和push.pop.c ...

  5. 2019-2020-1 20199329《Linux内核原理与分析》第九周作业

    <Linux内核原理与分析>第九周作业 一.本周内容概述: 阐释linux操作系统的整体构架 理解linux系统的一般执行过程和进程调度的时机 理解linux系统的中断和进程上下文切换 二 ...

  6. 2019-2020-1 20199329《Linux内核原理与分析》第二周作业

    <Linux内核原理与分析>第二周作业 一.上周问题总结: 未能及时整理笔记 Linux还需要多用 markdown格式不熟练 发布博客时间超过规定期限 二.本周学习内容: <庖丁解 ...

  7. 2019-2020-1 20209313《Linux内核原理与分析》第二周作业

    2019-2020-1 20209313<Linux内核原理与分析>第二周作业 零.总结 阐明自己对"计算机是如何工作的"理解. 一.myod 步骤 复习c文件处理内容 ...

  8. 2018-2019-1 20189221《Linux内核原理与分析》第一周作业

    Linux内核原理与分析 - 第一周作业 实验1 Linux系统简介 Linux历史 1991 年 10 月,Linus Torvalds想在自己的电脑上运行UNIX,可是 UNIX 的商业版本非常昂 ...

  9. 《Linux内核原理与分析》第一周作业 20189210

    实验一 Linux系统简介 这一节主要学习了Linux的历史,Linux有关的重要人物以及学习Linux的方法,Linux和Windows的区别.其中学到了LInux中的应用程序大都为开源自由的软件, ...

  10. 2020-2021-1 20209307 《Linux内核原理与分析》第九周作业

    这个作业属于哪个课程 <2020-2021-1Linux内核原理与分析)> 这个作业要求在哪里 <2020-2021-1Linux内核原理与分析第九周作业> 这个作业的目标 & ...

随机推荐

  1. 腾讯云CentOS7.4服务器添加swap分区

    自己的腾讯云服务器搭建的zabbix监控中,提示Lack of free swap space 腾讯的官方说明在这: https://cloud.tencent.com/document/produc ...

  2. 3.1 eureka自我保护

    故障现象: Down:是下线(掉线)的意思. 导致原因: 一句话:某时刻某一个微服务不可用了,eureka不会立刻清理,依旧会对该微服务的信息进行保存 什么是自我保护模式? 默认情况下,如果Eurek ...

  3. 微信端修改title

    function setTitle(t) { document.title = t; var i = document.createElement('iframe'); i.src = "i ...

  4. 下载并配置jdk

    ①下载jdk安装到本机,这里是jdk8下载地址,请根据自己机子的环境进行下载 https://www.oracle.com/technetwork/java/javase/downloads/jdk8 ...

  5. String.format(String format, Object... args)方法详解

    很多次见到同事使用这个方法,同时看到https://blog.csdn.net/qq_27298687/article/details/68921934这位仁兄写的非常仔细,我也记录一下,好加深印象. ...

  6. 使用Metasploit渗透攻击windows系统(一)

    攻击机:kaili ip:192.168.80.157 目标机:win7 IP:192.168.80.158 这里用两种方法去创建meterpreter会话: 1)利用kali中的msfvenom生成 ...

  7. spring cloud(一)带你进入分布式

    spring cloud是近年来比较火的热门话题,很多大型公司也渐渐转型使用spring cloud来完善各种开发模式,我认为主要是由spring团队开发由来,致使会有那么多的使用者,在java的领域 ...

  8. jvm内存快照dump文件太大,怎么分析

    1.场景 通常,使用eclipse的mat图形化工具打开dump的时候都会内存溢出. 对于比较小的dump,eclipse可以打开,但一旦dump文件太大,eclipse就有点束手无策. 这时候怎么办 ...

  9. 使用python来访问Hadoop HDFS存储实现文件的操作

    原文:http://rfyiamcool.blog.51cto.com/1030776/1258292 在调试环境下,咱们用hadoop提供的shell接口测试增加删除查看,但是不利于复杂的逻辑编程 ...

  10. less和sass的定义和区别

    less是单独的一种文件,可以理解为css的升级版: sass是一个相对新的编程语言,为web前端开发而生,可以用它来定义一套新的语法规则和函数: 区别: ①   表现方式不同:less基于javas ...