2019-2020-1 20199302《Linux内核原理与分析》第五周作业
一、用户态、内核态和中断
1、一般现代cpu都有几种不用的指令执行级别
2、在高执行级别下,代码可以执行特权指令,访问任意的物理地址,这种CPU执行级别就对应着内核态。
3、在相应的低级别执行状态下,代码的掌控范围会受到限制。只能对应级别允许的范围内活动。
例:intel x86CPU有四种不同的执行级别0-3,Linux只使用了其中的0级和3级分别表示内核态和用户态。
4、为什么需要权限级别的划分?
程序员写的代码可能健壮性不够,使得整个系统崩溃等问题。所以由更专业的程序猿写系统的执行代码,即使用内核态进行操作,保证它的健壮性。
5、对用户态和内核态明显区分的是cs和eip
cs寄存器的最低两位表明了当前代码的特权级。
CPU每条指令的读取都是通过cs:eip这两个寄存器:
其中cs是代码段选择寄存器,eip是偏移量寄存器。
上述判断由硬件完成。
一般来说在Linux中,地址空间是一个显著的标志:0xc0000000以上的地址空间只能在内核态下访问,0x0000000-0xbffffff的地址空间在两种状态下都可以访问。
这里的地址空间是指逻辑地址
6.中断处理是从用户态进入内核态的主要方式,系统调用只是一种特殊的中断。
(1)寄存器上下文:
从用户态切换到内核态时:①必须保存用户态的寄存器上下文②将内核态响应值放入对应的寄存器中
中断/int指令会在堆栈上保存一些寄存器的值,如:用户态栈顶地址、当时的状态字,当时的cs:eip的值。
中断发生后的第一件事就是保存现场保存现场就是进入中断程序,保存需要用到的寄存器的数据,中断发生后最后一件事是恢复现场,恢复现场就是退出中断程序,恢复保存寄存器的数据。
二、系统调用概述
1、操作系统为用户态进程与硬件设备进行交互提供了一组接口-------系统调用
把用户从底层的硬件编程中解放出来
极大提高了系统的安全性
是用户程序具有可移植性
2、应用编程接口(API)和系统调用不同
API只是一个函数定义(可以将一个系统调用封装为一个函数)
系统调用通过软中断向内核发出一个明确的请求
Libc库定义的一些API应用了封装例程(唯一目的就是发布系统调用,程序猿写代码时不需要用汇编指令)
一般每个系统调用对应一个封装例程,库再用这些封装例程定义出给用户的API
不是每一个API都对应一个特定的系统调用。
API可能直接提供用户态的服务。一个单独的API可能调用几个系统调用,不同的API可能调用了同一个系统调用。
3、返回值
大部分封装例程返回一个整数,其值的含义依赖于相应的系统调用。
-1在多数情况下表示内核不能满足进程的请求,Libc中定义的errno变量包含特定的出错码。
4、当用户态进程调用一个系统调用时,CPU切换到内核态并开始执行一个内核函数。
传参内核实现了很多不同的系统调用,进程必须指明需要哪个系统调用,这需要传递一个名为系统调用号的参数,使用eax寄存器传递。
5、系统调用也需要输入输出参数,例如
实际的值。
用户态进程地址空间的变量地址。
甚至是包含指向用户态函数的指针的数据结构地址。
寄存器传参限制:
(1)每个参数的长度不能超过寄存器的长度,即32位。
(2)在系统调用号(eax)之外,参数的个数不能超过6个(ebx,ecx,edx,esi,sdi,ebp)超过6个之后就会把某一个寄存器指向一块内存,可以访问所有内存。
三、使用库函数API获取系统当前时间
在进行本次实验时,遇到了很多问题,首先是编译为32位时,提示错误:
经过查询,是因为虚拟机的机器位数是64位,但是要编译为32位,所以需要使用命令:
sudo apt-get install libc6-dev-i386
但是在执行该条命令时,出现错误:链接不上软件源:
此时,设置DNS
sudo vim /etc/resolv.conf
将文件内容改为:
然后,重启网络服务,并更新apt
sudo apt-get update
然后正常安装
sudo apt-get install libc6-dev-i386
编译之后出现问题:
经过百度,发现,在tm结构体中的关于日的成员变量为tm_mday
改正之后,
2019-2020-1 20199302《Linux内核原理与分析》第五周作业的更多相关文章
- 2019-2020-1 20199329《Linux内核原理与分析》第九周作业
<Linux内核原理与分析>第九周作业 一.本周内容概述: 阐释linux操作系统的整体构架 理解linux系统的一般执行过程和进程调度的时机 理解linux系统的中断和进程上下文切换 二 ...
- 2019-2020-1 20199329《Linux内核原理与分析》第二周作业
<Linux内核原理与分析>第二周作业 一.上周问题总结: 未能及时整理笔记 Linux还需要多用 markdown格式不熟练 发布博客时间超过规定期限 二.本周学习内容: <庖丁解 ...
- 20169212《Linux内核原理与分析》第二周作业
<Linux内核原理与分析>第二周作业 这一周学习了MOOCLinux内核分析的第一讲,计算机是如何工作的?由于本科对相关知识的不熟悉,所以感觉有的知识理解起来了有一定的难度,不过多查查资 ...
- 20169210《Linux内核原理与分析》第二周作业
<Linux内核原理与分析>第二周作业 本周作业分为两部分:第一部分为观看学习视频并完成实验楼实验一:第二部分为看<Linux内核设计与实现>1.2.18章并安装配置内核. 第 ...
- 2018-2019-1 20189221 《Linux内核原理与分析》第九周作业
2018-2019-1 20189221 <Linux内核原理与分析>第九周作业 实验八 理理解进程调度时机跟踪分析进程调度与进程切换的过程 进程调度 进度调度时机: 1.中断处理过程(包 ...
- 2017-2018-1 20179215《Linux内核原理与分析》第二周作业
20179215<Linux内核原理与分析>第二周作业 这一周主要了解了计算机是如何工作的,包括现在存储程序计算机的工作模型.X86汇编指令包括几种内存地址的寻址方式和push.pop.c ...
- 2019-2020-1 20209313《Linux内核原理与分析》第二周作业
2019-2020-1 20209313<Linux内核原理与分析>第二周作业 零.总结 阐明自己对"计算机是如何工作的"理解. 一.myod 步骤 复习c文件处理内容 ...
- 2018-2019-1 20189221《Linux内核原理与分析》第一周作业
Linux内核原理与分析 - 第一周作业 实验1 Linux系统简介 Linux历史 1991 年 10 月,Linus Torvalds想在自己的电脑上运行UNIX,可是 UNIX 的商业版本非常昂 ...
- 《Linux内核原理与分析》第一周作业 20189210
实验一 Linux系统简介 这一节主要学习了Linux的历史,Linux有关的重要人物以及学习Linux的方法,Linux和Windows的区别.其中学到了LInux中的应用程序大都为开源自由的软件, ...
- 2018-2019-1 20189221《Linux内核原理与分析》第二周作业
读书报告 <庖丁解牛Linux内核分析> 第 1 章 计算工作原理 1.1 存储程序计算机工作模型 1.2 x86-32汇编基础 1.3汇编一个简单的C语言程序并分析其汇编指令执行过程 因 ...
随机推荐
- Linux06 文件的打包和压缩(gzip/gunzip、tar、bzip2)
一.gzip/gunzip 这是用于压缩和解压单个文件的工具,且使用方法比较简单 gzip 文件名 gunzip 文件名 二.tar(用的比较多) 不仅可以用于打包文件,还可以将整个目录中的全部文 ...
- Delphi Sysem.JSON 链式写法
链式写法有很多优点:连贯.语意集中.简洁.一气呵成.可读性强.比如要把 3.1415926 中的 59 提取为一个整数:Pi.ToString().Substring(5,2).ToInteger() ...
- Scratch编程:打猎(十)
“ 上节课的内容全部掌握了吗?反复练习了没有,编程最好的学习方法就是练习.练习.再练习.一定要记得多动手.多动脑筋哦~~” 01 — 游戏介绍 这节我们实现一个消灭猎物的射击游戏. 02 — 设计思路 ...
- PXC增量恢复添加节点(IST)
绕开SST通过IST方式添加Node到Percona XtraDB Cluster Gcache存储了所有的 writeset ,因此说这个集合的大小直接决定了允许其他节点宕机后多长时间内可以进行 ...
- 2.NioEventLoop的创建
NioEventLoop的创建 NioEventLoop是netty及其重要的组成部件,它的首要职责就是为注册在它上的channels服务,发现这些channels上发生的新连接.读写等I/O事件,然 ...
- linq 动态排序 order by
项目查询数据库使用的是linq 语法,可是后期需要用到不同字段的排序.各种纠结! 在网上找了各种资料 后面才找到两种方法 using System; using System.Collections. ...
- wpf Log4net的配置和使用
现在项目涉及的是cs客户端,在项目中使用log4net记录本地日志和异常信息,这里项目做完了,想着自己做一个demo,测试记录一下log4Net的配置使用. 第一步.新建一个wpf应用程序,项目右键 ...
- SharePoint中用Power shell命令修改文档的创建时间
第一步:pnp组件连接到SharePointConnect-PnpOnline -url 网站地址 第二步:查出文档库及文档库下所有的文件 Get-PnPListItem -List 文档库名称 第三 ...
- PLSQL登录失败出现空白错误提示框的问题
安装win7后其他软件运行正常,可是数据库用cmd plsplus和plsql软件都连不上,plsql报一个空白提示框 重装n遍oracle客户端,都不行. 最后发现解决方式很简单,在plsql的图标 ...
- BUAA OO 2019 第三单元作业总结
目录 总 JML规格化设计 理论基础 工具链 规格验证 验证代码 代码静态检查 自动生成测试样例 生成结果 错误分析 作业设计 第九次作业 架构 代码实现 第十次作业 架构 代码实现 第十一次作业 架 ...