linux进程切换

news/2024/4/27 19:07:39/文章来源:https://blog.csdn.net/zhu_superman/article/details/136980132
  1. 内核堆栈:每个进程在内核模式下运行时都有自己的内核堆栈。这个堆栈保存了进程在内核模式下的运行状态,包括函数调用时传递的参数、局部变量和返回地址等。

  2. 用户态与内核态:进程通常在用户态下运行,当执行系统调用或响应中断时进入内核态。在内核态,进程对硬件资源有更高级别的控制。

  3. 返回地址:当系统调用或中断发生时,CPU从用户态切换到内核态并保存返回用户态的地址。当内核完成处理后,通过这个地址返回用户态继续执行原进程。

进程切换的实质操作发生在内核堆栈上。当操作系统决定将CPU从当前进程切换到另一个进程时,它会保存当前进程的内核堆栈信息(即执行“保存上下文”),然后加载新的进程的内核堆栈信息(即执行“恢复上下文”)到CPU。

关键步骤是修改内核堆栈上的返回地址

  • 对于当前正在运行的进程,其在内核堆栈上的信息会被保存,包括即将返回到用户态执行的地址。
  • 当要切换到新的进程时,操作系统会更改内核堆栈上的数据为新进程的堆栈信息,并设置新的返回地址为新进程的用户态地址。

当操作系统做好这些更改后,它将“返回”到新进程的用户态,从新进程保存的那个点继续执行。从用户的角度看,CPU似乎从一个进程“跳”到了另一个。实际上,这个“跳”是通过保存和恢复不同进程的上下文、修改内核堆栈上的数据完成的。这样,一个进程切换到另一个进程的过程就完成了,CPU现在执行新的进程代码。

内核态:

在内核态可以理解为不分进程,进入内核态就不分了。只在内核态返回到用户进程才有意义。

  1. 进程上下文: 在用户态,操作系统为每个运行的程序提供了一个独立的进程上下文,包括虚拟内存空间、文件句柄、安全权限等。每个进程都拥有自己独立的用户态环境,操作系统通过进程间切换(Context Switch)来管理多任务。

  2. 内核态简化: 在内核态,虽然当前可能是响应某个进程的系统调用进入的,但是由于所有进程共享相同的内核空间和内核资源,所以在一些操作中不需要考虑是哪个用户进程在请求服务。

  3. 共享内核资源: 内核态代码直接运行在处理器的最高权限级别,访问的是全局的、不属于特定进程的资源。比如内核的调度器、内存管理单元、I/O处理系统等,都是服务于所有进程的共享资源。

  4. 安全隔离与共享: 即使在内核态有时也需要知道当前操作是由哪个进程触发的(例如管理进程的内核栈、确保访问权限等),但许多低级别的内核操作本身是与发起请求的特定进程无关的,比如硬件中断处理、定时器调度、底层网络数据包处理等。

linux内核如何加载多种不同的可执行文件?

  1. shell 环境下调用execve同时载入命令行参数和环境变量
  2. 库函数触发系统调用陷入内核态
  3. system call 调用sys_execuve -> do_execve -> do_execve_common -> exec_binprm-> load_elf_binary

在系统初始化阶段调用了core_initcall(init_elf_binfmt); 

init_elf_binfmt 中将 elf_format全局变量注册在内核的fmt链表中,所以在 exec_binprm 中会在fmt链表中找到对应模块来解析ELF文件的头部信息。

调用 elf_format变量中的 load_elf_binary 方法,load_elf_binary 中最后调用start_thread 设置新的ip值,等该进程返回用户态时,就转而执行新的代码。

两种加载的方法:

静态库:直接执行可执行程序的入口

动态库:由ld来动态链接这个程序,再把控制权移交给可执行程序的入口

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

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

相关文章

从一次 RPC 请求,探索 MOSN 的工作流程

王程铭(呈铭) 蚂蚁集团技术工程师,Apache Committer 专注 RPC、Service Mesh 和云原生等领域。 本文 7368 字,预计阅读 15 分钟 前言 MOSN(Modular Open Smart Network)是一款主要使用 Go 语言开发的云…

吴恩达深度学习笔记:神经网络的编程基础2.5-2.8

目录 第一门课:神经网络和深度学习 (Neural Networks and Deep Learning)第二周:神经网络的编程基础 (Basics of Neural Network programming)2.5 导数(Derivatives)2.6 更多的导数例子(More Derivative Examples&…

Node.js学习(一)

版权声明 本文章由B站上的黑马课程整理所得,仅供个人学习交流使用。如涉及侵权问题,请立即与本人联系,本人将积极配合删除相关内容。感谢理解和支持,本人致力于维护原创作品的权益,共同营造一个尊重知识产权的良好环境…

【二叉树】Leetcode 543. 二叉树的直径【简单】

二叉树的直径 给你一棵二叉树的根节点,返回该树的 直径 。 二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点 root 。 两节点之间路径的 长度 由它们之间边数表示。 示例1: 输入:root [1,2…

C语言实现顺序表(增,删,改,查)

目录 一.概念: 1.静态顺序表:使用定长数组存储元素。 2.动态顺序表:使用动态开辟的数组存储。 二.顺序表的实现: 1.顺序表增加元素 1.检查顺序表 2.头插 3.尾插 2.顺序表删除元素 1.头删 2.尾删 3.指定位置删 3.顺序表查找元素 …

使用Qt生成图片

Qt之生成png/jpg/bmp格式图片_qt生成图片-CSDN博客 (1)使用QPainter 示例关键代码: QImage image(QSize(this->width(),this->height()),QImage::Format_ARGB32);image.fill("white");QPainter *painter new QPainter(&image);painter->…

深入浅出:探索Hadoop生态系统的核心组件与技术架构

目录 前言 HDFS Yarn Hive HBase Spark及Spark Streaming 书本与课程推荐 关于作者: 推荐理由: 作者直播推荐: 前言 进入大数据阶段就意味着 进入NoSQL阶段,更多的是面向OLAP场景,即数据仓库、BI应用等。 …

TCPView下载安装使用教程(图文教程)超详细

「作者简介」:CSDN top100、阿里云博客专家、华为云享专家、网络安全领域优质创作者 「推荐专栏」:更多干货,请关注专栏《网络安全自学教程》 TCPView是微软提供的一款「查看网络连接」和进程的工具,常用来查看电脑上的TCP/UDP连接…

【Leetcode】2580. 统计将重叠区间合并成组的方案数

文章目录 题目思路代码复杂度分析时间复杂度空间复杂度 结果总结 题目 题目链接🔗 给你一个二维整数数组 ranges ,其中 ranges[i] [starti, endi] 表示 starti 到 endi 之间(包括二者)的所有整数都包含在第 i 个区间中。 你需要…

MappedByteBuffer VS FileChannel:从内核层面对比两者的性能差异

本文基于 Linux 内核 5.4 版本进行讨论 自上篇文章《从 Linux 内核角度探秘 JDK MappedByteBuffer》 发布之后,很多读者朋友私信我说,文章的信息量太大了,其中很多章节介绍的内容都是大家非常想要了解,并且是频繁被搜索的内容&…

ubuntu 中安装docker

1 资源地址 进入ubuntu官网下载Ubuntu23.04的版本的镜像 2 安装ubuntu 这里选择再Vmware上安装Ubuntu23.04.6 创建一个虚拟机,下一步下一步 注意虚拟机配置网络桥接,CD/DVD选择本地的镜像地址 开启此虚拟机,下一步下一步等待镜像安装。 3…

Git bash获取ssh key

目录 1、获取密钥 2、查看密钥 3、在vs中向GitHub推送代码 4、重新向GitHub推送修改过的代码 1、获取密钥 指令:ssh-keygen -t rsa -C "邮箱地址" 连续按三次回车,直到出现类似以下界面: 2、查看密钥 路径:C:\U…

银行监管报送系统介绍(十一):金融基础数据报送系统

为了全面落实和实现国务院办公厅下发《关于全面推进金融业综合统计工作的意见》中的综合统计工作的总体目标,中国人民银行调查统计司于2020年6月12日下发了《关于建立金融基础数据统计制度的通知(试行)》。 2020金融基础数据采集报送 报送时…

Kubernetes概念:服务、负载均衡和联网:2. Gateway API

Gateway API 官方文档:https://kubernetes.io/zh-cn/docs/concepts/services-networking/gateway/ Gateway API 通过使用可扩展的、角色导向的、 协议感知的配置机制来提供网络服务。它是一个附加组件, 包含可提供动态基础设施配置和高级流量路由的 API…

9.windows ubuntu 子系统,centrifuge:微生物物种分类。

上次我们用了karken2和bracken进行了物种分类,这次我们使用centrifuge. Centrifuge 是一种用于快速和准确进行微生物分类和物种鉴定的软件。其主要功能包括: 快速分类和物种鉴定: Centrifuge 可以对高通量测序数据(如 metagenomic 或 RNA-Se…

[NLP] 初窥000001

NL(natural language)–自然语言 人类的语言–中文,英语,法语 NLP(Natural Language Processing)–自认语言处理 计算机处理人类语言的技术,它包含翻译、智能问答、文本分类、情感分析等常见应用。 CV(Computational Vision) 感知NLP 认知…

【Java程序设计】【C00388】基于(JavaWeb)Springboot的校园竞赛管理系统(有论文)

Springboot的校园竞赛管理系统(有论文) 项目简介项目获取开发环境项目技术运行截图 博主介绍:java高级开发,从事互联网行业六年,已经做了六年的毕业设计程序开发,开发过上千套毕业设计程序,博客…

2024/3/27打卡更小的数(十四届蓝桥杯)——区间DP

目录 题目 思路 代码 题目 思路 题目说求数组某个区间中的数进行翻转,由于区间选择多,首先想到DP问题。 第一版想到的方法(错误的),当进行状态计算的时候,无法判定区间是否翻转后满足要求,…

js改变图片曝光度(高亮度)

方法一: 原理: 使用canvas进行滤镜操作,通过改变图片数据每个像素点的RGB值来提高图片亮度。 缺点 当前项目使用的是svg,而不是canvas 调整出来的效果不是很好,图片不是高亮,而是有些发白 效果 代码 …

阿里云ECS选型推荐配置

本文介绍构建Kubernetes集群时该如何选择ECS类型以及选型的注意事项。 集群规格规划 目前在创建Kubernetes集群时,存在着使用很多小规格ECS的现象,这样做有以下弊端: 网络问题:小规格Worker ECS的网络资源受限。 容量问题&…