使用库函数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. CentOS下redis-cli安装

    Step1:安装gcc wget等系统lib yum install -y gcc wget Step2:获取redis稳定版并解压 cd /tmp wget http://download.redi ...

  2. JVM垃圾回收(一)- 什么是垃圾回收

    什么是垃圾回收? 垃圾回收是追踪所有正在被使用的对象,并标注剩余的为garbage.这里我们先从JVM的GC是如何实现的说起. 手动内存管理 在开始介绍垃圾回收之前,我们先复习一下手动内存管理.它是指 ...

  3. django使用小结

    一.静态文件的使用 二.csrf跨站访问安全机制设置 三.MODEL模型使用

  4. VUE环境搭建、创建项目、vue调试工具

    环境搭建 第一步 安装node.js 打开下载链接:   https://nodejs.org/en/download/    这里下载的是node-v6.9.2-x64.msi; 默认式的安装,默认 ...

  5. 活动代码页437--修改windows的系统编码

    1.首先查看系统编码 win+R打开运行,输入cmd回车,打开命令提示符窗口,输入chcp回车,会查询当前系统的活动代码页,它指明了当前系统使用的编码: 或者,打开cmd后,点击cmd窗口左上角图标, ...

  6. 注册一个gitHub

    GitHub 是一个面向开源及私有软件项目的托管平台,因为只支持 Git 作为唯一的版本库格式进行托管,故名 GitHub. GitHub 于 2008 年 4 月 10 日正式上线,除了 Git 代 ...

  7. Python- - -函数目录

    一.函数的定义.调用.返回值.参数. 二.名称空间.作用域.加载顺序.取值顺序. 三.函数的嵌套.作用域链.函数名的应用.闭包. 四.装饰器

  8. 浅谈对象的两个方法:Object.keys() ,Object.assign();

    1 : Object.keys(obj) 返回给定对象的所有可枚举属性的字符串数组 例子1: var arr = [1, 2, 6, 20, 1]; console.log(Object.keys(a ...

  9. Python—字符串的操作

    字符串的操作 变量: 变量只能是 字母,数字或下划线的任意组合,但首个字符不能为数字,且不能有空格 以下关键字不能声明为变量: and ,as, assert, break ,class ,conti ...

  10. 使用CURL进行模拟登录

    在信息采集的时候,要采集的站点可能需要登录,这样使用简单的采集方式(例如file_get_contents)就无法做到了,我们可以利用PHP的CURL扩展库来进行模拟登录,下面给出代码示例: < ...