L45 【哈工大_操作系统】操作系统接口 系统调用实现

L4 操作系统接口

本节比较简单,故与第五节课程笔记一起发布。本节主要是研究 上层应用 是怎么穿过边界进入 操作系统。

  • 接口:操作系统提供的重要函数/指令( system call ),用来连接硬件,所以OS接口就是系统调用
  • POSIX(Portable Operating System Interface of UNIX, 可移植操作系统接口):IEEE制定的OS接口标准

L5 系统调用实现

本节课程是重点,强调了系统调用的底层实现逻辑,主要涵盖三个问题:

1、用户系统调用 为什么 不应该进入内核?
2、怎么样 做到不让用户进入内核?
3、系统调用想进去内核应该 怎么办

1、用户系统调用为什么不应该进入内核?

  • 为了系统的隐私性,不能随意的 jmpmov 来获取内存中的数据。
  1. 内核(Kernel):内核是操作系统的核心部分,它负责管理系统的各种资源(如CPU、内存、设备等),提供服务给用户程序,实现了操作系统的基本功能,比如进程管理、内存管理、文件系统、设备驱动程序等。内核通常是操作系统的一个独立模块,负责运行在最高特权级别,控制整个系统的运行。
  2. 内存(Memory):内存是计算机系统中用于存储数据和程序的一种硬件设备。它是用来存放程序和数据的临时存储区域,供 CPU 进行读写操作。操作系统通过内存管理的功能来管理计算机系统中的内存资源,包括分配、释放、保护和共享内存等操作。

2、怎么做到不让用户进入内核?

  • 硬件电路将内核程序和用户程序隔离,防止随意 jmp

在这里插入图片描述

  • DPL(目标段特权级),CPL(当前段特权级),特权级数字越小等级越高。只有当 DPL≤CPL(由硬件来检查),当前段才可以访问目标段。

特权级: 核心态 = 0 OS服务 = 1/2 用户态 = 3

  • 系统初始化 head.s 执行时,建立 GDT 表象时就初始化了各态的特权级别

3、系统调用想进去内核应该通过什么手段?

  • 硬件提供了主动进入内核的方法:中断指令 int

在这里插入图片描述

  • open 展开实际包含了中断 int 指令,来实现调用内核

4、用户程序包含 int 指令的代码

在这里插入图片描述

  • 只能通过 int 0x80 进入OS内核

在这里插入图片描述

  • write 指令的系统调用,通过 宏 来展开
  • _asm_volatile(内嵌汇编),输出 =aeax。先将 NR_##name 置给 eax。代入即把 write 置给 eax核心:将系统调用号置给 eax,然后调用 int 0x80
// 定义(上面这一页 PPT 是定义)
// weite 指令的调用(再上一页 PPT 是调用)
syscal13(int, write, int, fd, char const *buf, off_t, count)
/*  把 write 置给 eax (实际是一个系统调用号 _NR_write)
	把 fd 置给 bax, *buf 置给 cax, count 置给 dax      */

5、操作系统写中断处理

  • IDT 表中取出中断处理函数

在这里插入图片描述

  • 实现了 DPL = 3CPL = 0, 用户程序就可以进入内核了

6、操作系统根据编号执行相应代码

在这里插入图片描述

  • write 的系统调用对应的地址,乘4 是因为每次函数位置占32位 -> 4个字节。

在这里插入图片描述

  • 通过 int 0x80 指令(CPL = 3, DPL = 3),才能穿过接口到达系统

在这里插入图片描述
至此,本节课程已介绍完毕。

再次强调一下本系列文章的定位:希望通过这一系列文章,可以帮助大家巩固与学习李治军老师课程上的重点内容。同时,也为大家后续知识点遗忘提供了查阅的渠道,而无需去视频中寻找知识,故本系列文章图片均保留了课堂笔记。希望对大家有所帮助!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/544017.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Res2Net网络

Res2Net网络 摘要Abstract1. Res2Net网络1.1 文献摘要1.2 背景1.3 创新点1.4 网络结构1.5 实验1.5.1 在ImageNet数据集上进行实验1.5.2 在CIFAR数据集上进行实验 2. Res2Net代码实现3. 总结 摘要 Res2Net是一种神经网络架构,旨在改善类似ResNet的网络在计算机视觉任…

vscode开发 vue3+ts 的 uni-app 微信小程序项目

创建uni-app项目: # 创建用ts开发的uni-app npx degit dcloudio/uni-preset-vue#vite-ts 项目名称 # 创建用js开发的uni-app npx degit dcloudio/uni-preset-vue#vite 项目名称VS Code 配置 为什么选择 VS Code ? HbuilderX 对 TS 类型支持暂不完善VS…

unity记一下如何播放动画

我使用的版本是2022.3.14fc 展开你的模型树,是会出现这个三角形的东西的 然后在资源面板创建一个animation controller 进去之后,把三角形拖进去,就会出现一个动画,然后点击他 在左侧给他创建这么个状态名字,类型…

AskManyAI:一个GPT、Claude、Gemini、Kimi等顶级AI的决斗场

一直以来很多人问我能不能有个稳定,不折腾的全球AI大模型测试网站,既能够保证真实靠谱,又能够保证稳定、快速,不要老动不动就挂了、出错或者漫长的响应。 直到笔者遇到了AskManyAI,直接就惊艳住了! 话不多…

第17天:信息打点-语言框架开发组件FastJsonShiroLog4jSpringBoot等

第十七天 本课意义 1.CMS识别到后期漏洞利用和代码审计 2.开发框架识别到后期漏洞利用和代码审计 3.开发组件识别到后期漏洞利用和代码审计 一、CMS指纹识别-不出网程序识别 1.概念 CMS指纹识别一般能识别到的都是以PHP语言开发的网页为主,其他语言开发的网页识…

springboot-tomcat冲突

maven tomcat版本冲突异常 记录一个错误 在项目启动时报错: java.lang.AbstractMethodError: org.apache.tomcat.websocket.server.WsSessionListener.sessionCreated(Ljavax/servlet/http/HttpSessionEvent;)V 引入Session报错。 原因:Springboot默…

数据仓库—维度建模—维度表设计

维度表 维度表(Dimension Table)是数据仓库中描述业务过程中各种维度信息的表,用于提供上下文和描述性信息,以丰富事实数据的分析 维度表是维度建模的灵魂所在,在维度表设计中碰到的问题(比如维度变化、维度层次、维度一致性、维度整合和拆分等)都会直接关系到维度建模…

基于R语言实现的负二项回归模型【理解与实现】-理解负二项回归模型和泊松回归模型之间的区别

前言 我们可以在R语言中使用MASS包中的glm.nb函数来拟合负二项模型,以及使用glm函数来拟合泊松模型。以下是一个详细的过程,包括模拟数据的生成、模型的拟合、结果的比较和解释。 需要的包 if (!require("MASS")) install.packages("M…

【Leetcode每日一题】 分治 - 颜色分类(难度⭐⭐)(57)

1. 题目解析 题目链接:75. 颜色分类 这个问题的理解其实相当简单,只需看一下示例,基本就能明白其含义了。 2.算法原理 算法思路解析 本算法采用三指针法,将数组划分为三个区域,分别用于存放值为0、1和2的元素。通过…

CentOS 7安装Zookeeper

说明:本文介绍如何在CentOS 7操作系统下使用Zookeeper 下载安装 首先,去官网下载所需要安装的版本,我这里下载3.4.9版本; 上传到云服务器上,解压 tar -xvf zookeeper-3.4.9.tar.gz修改配置 进入Zookeeper目录下的co…

3. 安装arrach结构的Mysql

提示:arm的centos上面安装arrach结构的Mysql 文章目录 前言一、查看已经安装过的并卸载mysql二、创建mysql用户组1.设置用户组2. 安装3.设置启动4.查看密码5.修改登录密码6.授权7.修改连接8.设置参数 常见问题排查1. 启动失败查看:2. 用户操作3. 踩坑解决…

【已开源】​基于stm32f103的爬墙小车

​基于stm32f103的遥控器无线控制爬墙小车,实现功能为可平衡在竖直墙面上,并进行移动和转向,具有超声波防撞功能。 直接上: 演示视频如:哔哩哔哩】 https://b23.tv/BzVTymO 项目说明: 在这个项目中&…

Unity 2D让相机跟随角色移动

相机跟随移动 最简单的方式通过插件Cinemachine 在窗口/包管理器选择全部找到Cinemachine,导入。然后在游戏对象/Cinemachine创建2D Camera。此时层级中创建一个2D相机。选中人物拖入检查器Follow。此时相机跟随人物移动。 修改相机视口距离 在检查器中Lens下调正…

linux学习:文件属性

在操作文件的时候,经常需要获取文件的属性,比如类型、权限、大小、所有者等等, 这些信息对于比如文件的传输、管理等是必不可少的,而这些信息 这三个函数的功能完全一样,区别是:stat( )参数是一个文件的名字…

UI设计/交互设计/视觉设计项目汇报/作品集Figma/PPT模板

作为UI设计/交互设计/视觉设计师,创建作品集对于向潜在客户或雇主展示您的技能、创造力和风格至关重要。以下分步指南可帮助您创建令人印象深刻的作品集: 选择您的最佳作品:选择您最强大且最相关的设计项目,将其纳入您的作品集。…

Java应用中文件上传安全性分析与安全实践

✨✨谢谢大家捧场,祝屏幕前的小伙伴们每天都有好运相伴左右,一定要天天开心哦!✨✨ 🎈🎈作者主页: 喔的嘛呀🎈🎈 目录 引言 一. 文件上传的风险 二. 使用合适的框架和库 1. Spr…

CCF区块链论文录用资讯--ICDE 2024

ICDE是CCF A类会议 (数据库/数据挖掘/内容检索) 其2024录用了8篇区块链论文 Database technology for Blockchains I Efficient Partial Order Based Transaction Processing for Permissioned Blockchains (针对许可区块链的高效的基于偏序…

Niobe开发板OpenHarmony内核编程开发——事件标志

本示例将演示如何在Niobe Wifi IoT开发板上使用cmsis 2.0 接口使用事件标志同步线程 EventFlags API分析 osEventFlagsNew() /// Create and Initialize an Event Flags object./// \param[in] attr event flags attributes; NULL: default values./// \return e…

openstack安装dashboard后登录网页显示404错误

1. 2.进入该目录vim /etc/httpd/conf.d/openstack-dashboard.conf 增加这一行 WSGIApplicationGroup %{GLOBAL} 重启httpd后就可以访问了

Devin AI: The World’s First AI Software Engineer

Devin AI是Cognition AI团队推出的一款名为Devin的人工智能软件工程师,它被誉为世界上第一个完全自主的AI软件工程师。Devin AI在2024年3月12日发布,并在SWE-bench编码基准测试中设立了新的技术标杆。 Devin AI具备多项强大的能力,包括学习如…