linux内核堆栈切换问题

问题描述

linux内核堆栈切换问题
假设每个进程有自己的页目录和页表。。用户进程运行时如果发生了中断。就会从特权级
3切换到特权级0。cpu此时自动从tss里面获取到esp0ss0,并将cseipeflags自动压入栈,
但此时的页目录还未切换,虽然已经进入内核栈空间,但此时经过页映射,物理地址还在
进程空间,linux是怎样实现当中断发生时,不破坏进程空间里面的值来切换到内核栈的?
注意,我说的不是0.xx的内核。。。整个CPU只用到了一个tss.

解决方案

我知道答案了。linux把地址分为内核空间和用户空间内核空间是3G以上,用户可用空间是3G以下,所以用户和内核空间是不会重合的,每个进程共享内核
空间,所以无论切不切换cr3都无所谓了。

时间: 2024-09-17 04:00:41

linux内核堆栈切换问题的相关文章

Linux内核堆栈使用方法 进程0和进程1【转】

转自:http://blog.csdn.net/yihaolovem/article/details/37119971 目录(?)[-] 8 Linux 系统中堆栈的使用方法 81  初始化阶段 82  任务的堆栈 83  任务内核态堆栈与用户态堆栈之间的切换 今天和一个朋友聊天,朋友说在编写驱动时遇到一个怪异的问题.他在内核中使用了一个深度函数调用(多层嵌套的函数),但没有实现预定的效果,但如果把嵌套去掉,函数就没问题了.当时我也没有多想,就回答可能是编译器的问题.回来后头脑中又浮现出这个问题

如何修补和保护Linux内核堆栈冲突漏洞CVE-2017-1000364

在 Linux 内核中发现了一个名为 "Stack Clash" 的严重安全问题,攻击者能够利用它来破坏内存数据并执行任意代码.攻击者可以利用这个及另一个漏洞来执行任意代码并获得管理帐户(root)权限. 在 Linux 中该如何解决这个问题? the-stack-clash-on-linux-openbsd-netbsd-freebsd-solaris Qualys 研究实验室在 GNU C Library(CVE-2017-1000366)的动态链接器中发现了许多问题,它们通过与

linux内核学习之四:进程切换简述【转】

转自:http://www.cnblogs.com/xiongyuanxiong/p/3531884.html 在讲述专业知识前,先讲讲我学习linux内核使用的入门书籍:<深入理解linux内核>第三版(英文原版叫<Understanding the Linux Kernel>),不过这本书不一定对每个人都适合,大家可以根据自己的情况选择适合的入门书籍.看了前面几章,感觉这本书的语言极其精练,没有一句多余的,必须慢慢读.可能我以前习惯了粗略浏览的阅读方式,读这本书时经常看着看着就

linux内核学习之四:进程切换简述

 进程是现代操作系统的核心概念之一,用于分配系统(CPU,内存)资源的使用.了解linux进程及进程切换的知识,首先要理解进程与程序的区别,进程是执行流,是动态概念:程序是数据与指令序列的集合,是静态概念.进程作为动态的执行流,可以用execv系统调用自由选择一个程序(只要有权限)来执行的,理解这一点很重要.在阅读本书的第三章<进程>中,有两个地方比较难于理解的.   1 switch_to宏的last参数      书中讨论switch_to宏(第110页)时,提到,该宏有3个参数:prev

linux信号机制 - 用户堆栈和内核堆栈的变化【转】

转自:http://itindex.net/detail/16418-linux-%E4%BF%A1%E5%8F%B7-%E5%A0%86%E6%A0%88 此文只简单分析发送信号给用户程序后,用户堆栈和内核堆栈的变化.没有分析实时信号,当然整个过程基本一致.很多参考了<情景分析>,所以有些代码和现在的内核可能不同,比如RESTORE_ALL,但大体的机制是类似的. 1. 一个信号小例子 hex@Gentoo ~/signal $ cat sigint.c #include <stdio

《奔跑吧Linux内核》之处理器体系结构

本文摘自人民邮电出版社异步社区<奔跑吧Linux内核> 第1章 处理器体系结构 京东购书:https://item.jd.com/12152745.html 试读地址:http://www.epubit.com.cn/book/details/4835本章思考题 1.请简述精简指令集RISC和复杂指令集CISC的区别. 2.请简述数值0x12345678在大小端字节序处理器的存储器中的存储方式. 3.请简述在你所熟悉的处理器(比如双核Cortex-A9)中一条存储读写指令的执行全过程. 4.请

十天学Linux内核之第一天---内核探索工具类

原文:十天学Linux内核之第一天---内核探索工具类 寒假闲下来了,可以尽情的做自己喜欢的事情,专心待在实验室里燥起来了,因为大二的时候接触过Linux,只是关于内核方面确实是不好懂,所以十天的时间里还是希望能够补充一下Linux内核相关知识,接下来继续待在实验室里想总结一下Linux内核编程,十天肯定完全掌握不了Linux内核,这里我也只是把自己认为不是很好懂并且很重要的难点疑点写出来,和大家一起分享,希望大家改正互相学习. Linux的具体概述这里就不多说了,今天主要讲的是Linux内核中

Linux内核中断和异常分析(上)

中断,通常被定义为一个事件.打个比方,你烧热水,水沸腾了,这时候你要去关掉烧热水的电磁炉,然后再去办之前手中停不下来的事情.那么热水沸腾就是打断你正常工作的一个信号机制.当然,还有其它的情况,我们以后再做分析.       中断也就是这样产生的,中断分为同步中断还有异步中断.       同步中断在Intel的手册中被称为异常,而异步中断被称作中断.打个比方在ARM处理器的异常种类就有不少,有未定义指令异常,软中断异常,快中断异常等等.异常是由程序错误产生的,或者是内核必须处理的异常条件产生的.

Linux内核剖析 之 进程简介

1.概念    1.1  什么是进程?     进程是程序执行的一个实例,可以看作充分描述程序已经执行到何种程度的数据结构的汇集.     从内核观点看,进程的目的就是担当分配系统资源(CPU时间,内存等)的实体.     我们熟悉的fork()库函数,它有两种用法:     (1).一个父进程希望复制自己,使父子进程执行不同的代码段,常用于网络服务程序.     (2).一个进程要执行一个不同的程序,fork()后立即exec(),如shell. 1.2  什么是线程?     有时候,一个进