第五章 系统调用的三层机制(下)

1.给MenuOS增加命令

进入Linuxkernel目录下,强制删除当前menu目录,再重新克隆一个新版本的menu

进入menu,运行make roofts脚本就可以自动编译并且自动生成根文件系统,还可以运行MenuOS系统。

输入help命令可以发现,当前支持的命令比之前多了。增加了两个命令:time,功能是显示系统时间,还有一个是time_asm,功能是使用汇编的方式来显示时间。

下面来增加一个hello的命令,输出“hello 你的学号”。

打开test.c文件:

给MenuOS增加新的命令只需要使用MenuConfig命令即可。在main()函数中增加一行代码。增加对应的函数如下:

使用make roofts自动编译,输入help命令可以发现,比之前多了一个hello命令。

2.使用gdb跟踪系统调用内核函数sys_time

启动内核

再打开一个窗口,水平分割,启动gdb,把内核加载进来建立连接

连接到target remote 1234

在 start_kernel 处设置断点,在gdb中按c会在设置断点的 start_kernel 处停下来,使用list可以查看这段代码。

用b sys_time设置一个断点,启动MenuOS后执行time命令,程序会停到 sys_time 这个函数的位置,time命令执行到一半卡在那里。

gdb调试可以看到Breakpoint在 linux-3.18.6/kernel/time/time.c 中的这个文件,因为是使用宏定义,所以无法直接看到 sys_time。
使用list命令列出的sys_time对应的代码如下:

单步执行,会进入get_seconds() 中所在的 linux-3.18.6/kernel/time/timekeeping.c 文件。

使用finish命令把这个函数全部执行完。

再单步执行,一直到 return i,获得的就是当前系统时间time的数值。

再设置一个断点system_call,继续执行,会发现time函数返回了。

但是在 MenuOS 中执行 time-asm 命令时候,还是停在了原先设定的 sys_time 这个位置,在 system_call 这个位置它并不能停下来。

因为 system_call 不是一个普通的函数,它是一段特殊的汇编代码,只能调试系统调用的内核函数和其他内核函数的处理过程,但gdb不能跟踪 entry_32.s 这个汇编代码。

遇到的问题

问题原因:没有克隆新版本的menu。

解决办法:用git clone克隆一个新版本的menu,就会增加新的命令time和time-asm。

3.系统调用在内核代码中的处理过程

system_call流程示意图:

从系统调用处理过程的入口开始,就也可以看到SAVE_ALL保存现场,然后找到syscall_call和sys_call_table。之后restore_all和最后的TNTERRUPT_RETURN(iret)用于恢复现场并且返回系统调用到用户态结束。这个过程可能会执行 syscall_exit_work,需要跳转到 work_pending ,里面有work_notifysig 处理信号,还有 work_resched 是需要重新调度的,这里是进程调度的时机点 call schedule ,调度完之后就会跳转到 restore_all ,恢复现场返回系统调用到用户态。

2019-2020-1 20199324《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. 获取ExtJS中开启Form.fileUpload时,返回的信息

    当Form,开启fileUpload后,不能按默认的方式得到action.result,开启fileUpload与否,返回的action.result的内容是不一样的 未开启fileUpload时,返 ...

  2. DRF项目之解决浏览器同源策略问题

    DRF项目,是一个前后端分离的Web框架. 本项目中,我们前端采用的是VUE框架. 前后端分离的情况就会出现一个问题,前端的Ajax请求无法请求到后端API(接口). 那么,为什么会出现这种问题呢? ...

  3. Python快速安装库的靠谱办法

    我们如果使用python,并且使用pip安装一些库 会经常遇到pip在线安装速度慢 !   慢也就算了,安装经常会由于timeout等原因中断 所以有没有什么在线安装库并且速度较快的办法么? 其实是有 ...

  4. centos系统将shell脚本改成systemctl启动的形式

    说明: CentOS 7的服务systemctl脚本存放在:/usr/lib/systemd/,有系统(system)和用户(user)之分,像需要开机不登陆就能运行的程序,就将程序存在系统服务里,即 ...

  5. 3.GIT常用命令

    往仓库里面添加文件 将新的文件放到暂存区 git add 文件名(多个文件用空格分隔) git commit -m '说明内容' git commit --amend 此修改一般用于未push之前修改 ...

  6. 分享-QQ/微信/微博(环境搭建)

    QQ环境搭建

  7. 04-for循环的各个语句及list列表学习

    目录 04-for循环的各个语句及list列表学习 1. for循环 2. range()函数 3. 循环语句中的break.continue.pass 4. list列表 5. 列表生成式 6. 实 ...

  8. JavaScript—飞机大战

    今天来写个游戏,飞机大战 1,布局 2,思路 1,动态创建自己的飞机 让它在规定的区域,跟着鼠标运动. 2,在自己飞机的上方,间隔1s生成子弹.子弹往上移动 当top:0 子弹消失 3,每隔1s 产生 ...

  9. 插曲 强大的神器 vmware

    电脑到了  这连天给电脑配环境变量  真的想死  发现用 虚拟机 直接跑别人配置好的镜像文件   多快好省超级开心 比较毒瘤的  clion  不仅要配置c++ 环境  还要走cmake  等一堆东西 ...

  10. Python笔记_第四篇_高阶编程_正则表达式_2.正则表达式入门

    1. 匹配单个字符和数字: . --->> 匹配除换行符以外的任意字符.[0123456789] --->> []字符集合,表示匹配方括号中所包含的任意一个字符.[Thomas ...