系统调用的三层机制

用户态、内核态和中断

  • 用户态。较低的执行级别,只能访问一部分内存,只能执行一部分指令。
  • 内核态。高级执行级别,可以访问任意物理内存,可以执行特权指令。
  • 中断。系统从用户态进入内核态的主要方式。有硬件中断和软中断。系统调用就是通过软中断进入内核态。

上下文切换

用户态切换到内核态时,就要把用户态寄存器上下文保存起来,同时要把内核态寄存器的值放到当前cpu中。int指令出发中断机制会在堆栈上保存一些寄存器的值,会保存(SAVE_ALL)用户态栈顶的值当时的状态字(flag)当时的CS:EIP的值。同时会将内核态的这些寄存器的值加载到cpu。其中内核态CS:EIP指向中断处理程序的入口,如果是系统调用则指向system_call,当中断结束后执行restore_all和INTERRUPT_RETURN。

API和系统调用

API就是系统调用的库函数,是一个函数定义。系统调用是通过软中断向内核发出了中断请求,int指令的执行就会触发一个中断请求,一个API可能只对应一个系统调用,也可能由多个系统调用实现。

Linux中通过int $0x80来触发系统调用的执行,内核给每个系统调用一个编号,即系统调用号来指明是哪个系统调用,通过EAX寄存器传递。

无参数系统调用

依次通过c语言和内嵌汇编的c语言实现time()函数中封装的系统调用。

time.c

课本上给出的time.c在编译时遇到如下问题:

查看struct tm发现应该是mday:

修改后代码如下:

修改后顺利运行:

内嵌汇编的代码运行顺利:

自选系统调用access

其实没什么大区别,C语言代码及运行结果如图:

内嵌汇编的代码及运行结果如图,比c语言代码有所简化:

带两个参数的系统调用

同样运行顺利,代码如下:

通用库函数syscall

新增的没有被封装好的系统调用可以通过syscall(系统调用号,参数表)实现,实际上比前两种方式舒服很多。

于是我们需要知道系统调用对应的系统调用号,在编译器中通过查看syscall.h中引用的unistd.h文件可以查看系统定义的系统调用号表。

至于为什么unistd.h中的宏定义的变量名和我们使用的不一样,是因为在bits/syscall.h中又进行了一次宏定义:

这样应该更有益于程序的可读性和不同版本的兼容性(兼容性是官方的解释,但我现在对不同版本之间的兼容不报什么希望)。

感想

在查看系统调用号表时,实际上系统中有大量的unistd.h,包括i386、x86_64安装过的mykernel和Linuxkernel以及许多不知道来源的。通常是在/usr/include/asm目录下,但在我的电脑上甚至没有asm这个目录。还好编译器中链接到的文件是在搜索目录中的,所以能比较快的找到需要的头文件。

之前在编程中要用到系统中的命令都是由system(command)实现,现在想来这应该是通过shell的封装来调用的系统函数,效率应该比直接在程序中进行系统调用低不少。

一个小问题

这章之后对Linux系统的层次似乎多了些理解。按照我的理解,内核处于最底层,c语言中的系统调用和shell中的内建命令都是通过调用内核中的函数实现,是对内核中的函数的不同的封装。C语言中syscall()是直接调用内核中的函数,而C语言中的system()函数则是通过调用shell间接的调用内核中的函数,所以命令可以和终端中的写法保持一致,传参也是直接传字符串。希望这么理解是对的,在以后的实践中去检验。

2018-2019-1 20189218《Linux内核原理与分析》第五周作业的更多相关文章

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

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

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

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

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

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

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

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

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

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

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

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

  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. 2018-2019-1 20189221《Linux内核原理与分析》第二周作业

    读书报告 <庖丁解牛Linux内核分析> 第 1 章 计算工作原理 1.1 存储程序计算机工作模型 1.2 x86-32汇编基础 1.3汇编一个简单的C语言程序并分析其汇编指令执行过程 因 ...

随机推荐

  1. 源码解读 zsetAdd

    https://github.com/antirez/redis/blob/6a6471aad5e4f8d6cbab677b918b14cdee416296/src/t_zset.c /* Updat ...

  2. create view in view

    CREATE VIEW view_region2role AS ( SELECT region_set_id, region_set_name, GROUP_CONCAT(id) gc_id, GRO ...

  3. Python性能鸡汤(转)

    英文原文:http://blog.monitis.com/index.php/2012/02/13/python-performance-tips-part-1/ 英文原文:http://blog.m ...

  4. 聊一聊Linux中的工作队列

    2018-01-18 工作队列是Linux内核中把工作延迟执行的一种手段,其目的不同于软中断,软中断是提高CPU的响应,尽可能的缩短关中断的时间:而工作队列主要目的是节省资源,其比较适合很微小的任务, ...

  5. 帝国cms底部代码哪里改?要修改版权和统计代码

    最近接手的几个站是用帝国cms做的,底部代码那边都有一个**设计的链接,还有一些不相关的东西,第一眼看到就想把那些帝国cms底部代码清理掉,这就是让别人建站的烦恼,让他们删除说要收费,坑就一个字,自己 ...

  6. ConcurrentModificationException

    //需求:如何集合中有给定的元素就在集合中在插入一个元素public class ListIteratorDemo2 { public static void main(String[] args) ...

  7. 函数及while实例

    输入1,输出:if 输入2,输出:elif 输入其他数值,输出:else 输入非数字,输出:except def greeting3(name3, lang3=1): if lang3 == 1: r ...

  8. 记两个国外CTF的弱pwn

    两道题都来自CSAW CTF 18.PWN学得不够多,如果哪里错了,欢迎留言交流. 第一个题 get_it checksec检查之后,发现栈保护没开,很可能是栈溢出.IDA打开F5看伪源码. int ...

  9. Keepalived+HAproxy实现高可用负载均衡

    总概:       Keepalived是一个类似于layer3, 4 & 5交换机制的软件,也就是我们平时说的第3层.第4层和第5层交换.Keepalived的作用是检测web服务器的状态, ...

  10. linux mail 发送邮件附件

    在很多场景中我们会使用Shell命令来发送邮件,而且我们还可能在邮件里面添加附件,本文将介绍使用Shell命令发送带附件邮件的几种方式,希望对大家有所帮助. 文章目录 1 使用mail命令 2 使用m ...