使用库函数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. 移动Web UI库(H5框架)有哪些,看这里就够了

    前言 今年上半年,项目组在项目开发的过程中建立了一套风格统一,组件丰富完善,命名统一规范的PC端UI库,适用于做大型站点,该UI库也是应用到了整个平台的项目中,在各个项目组中进行推广.因为项目的保密性 ...

  2. 2017 Russian Code Cup (RCC 17), Final Round

    2017 Russian Code Cup (RCC 17), Final Round A Set Theory 思路:原题转换一下就是找一个b数组,使得b数组任意两个数的差值都和a数组任意两个数的差 ...

  3. Python自学:第三章 在列表末尾添加元素与在列表中插入元素

    motorcycles = ['honda', 'yamaha' ,'suzuki'] motorcycles.insert(0, "ducati") print(motorcyc ...

  4. mongo学习笔记---1

    mongo简介 非结构化数据库,数据都是以Bson格式(json的二进制)存储的. 特点:不需要指定表结构,存在一张表里的数据其结构可以完全不同.内部执行引擎为JS解释器, 把文档存储成bson结构, ...

  5. eclipse 对 hadoop1.2.1 hdfs 文件操作

    package com.hdfs; import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io ...

  6. laravel数据库迁移 和 路由防攻击

    命令:php  artisan  migrate 防攻击:

  7. STL标准库-容器-deque 双端队列

    头文件: #include<deque> 常用操作: https://www.cnblogs.com/LearningTheLoad/p/7450948.html

  8. jquery 获取表单的内容以JSON对象形式返回

    添加一个serializeJson方法 <!DOCTYPE html> <html> <head> <meta charset="UTF-8&quo ...

  9. c、c++函数随机

    #inlcude<algorithm> next_permutation函数<全排列函数> #include<stdio.h> #include<algori ...

  10. ln 链接命令 简要说明 软硬链接关系说明

    ln [选项] 目标 -s 创建符号链接(软链接) -f 强制创建链接 -i 覆盖前先询问 -v 显示创建链接过程 ln命令不能对目录创建硬链接,但可以创建软链接,对目录的软链接经常被用到 删除软链接 ...