热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

LINUX中断上下文为什么不能访问用户空间

如题:编写LINUX中断上下文函数时注意的几点:1.不能向用户空间发送或接受数据2.不能使用可能引起阻塞的函数3.不能使用可能引起调度的函数2,3很好理解,但1为什么
如题:
编写LINUX 中断上下文函数时注意的几点:

1.不能向用户空间发送或接受数据
2.不能使用可能引起阻塞的函数
3.不能使用可能引起调度的函数


2,3很好理解,但1为什么不能向用户空间发送和接收数据呢,访问不是通过CR3寄存器 找到 目录项,再根据虚拟地址借助页表项最后找到物理地址访问吗,为什么不可以呢

4 个解决方案

#1


处于中断上下文时,跟任何进程是没有关系的,因为没有进程概念,所以也就没有进程那种虚拟地址映射表,如果你这时候让中断程序去访问用户空间的地址,它去访问哪个进程的用户空间地址?如果你说是当前进程的用户空间,那么中断可能在任何进程运行时发生,那么中断代码就没法写得适用于所有进程。
基于很多考虑,中断中干脆就禁止访问用户空间了。

#2


引用 1 楼 xinzha 的回复:
处于中断上下文时,跟任何进程是没有关系的,因为没有进程概念,所以也就没有进程那种虚拟地址映射表,如果你这时候让中断程序去访问用户空间的地址,它去访问哪个进程的用户空间地址?如果你说是当前进程的用户空间,那么中断可能在任何进程运行时发生,那么中断代码就没法写得适用于所有进程。
基于很多考虑,中断中干脆就禁止访问用户空间了。

你后面说的我很赞同,前面说的我有点困惑,被中断的进程,进程虚拟地址映射表应该实际存在的把,是不是有些虚拟地址还未分配实际物理地址,中断中访问这些地址空间导致缺页异常,中断中的缺页异常可能得不到运行,可能导致系统问题?我这样理解不知道对不对,还望大师指点

#3


进程虚拟地址映射表是存在的,但是中断运行在中断上下文,而不是进程上下文,在中断上下文中只有物理地址逻辑地址这些整个系统公用的东西才有意义(也就是说中断代码可以看到这些映射表,而进程私有的东西,中断是不会去看的),而用户空间地址是进程私有的,中断服务代码中如果真的去访问进程私有空间,那么同样的中断代码在不同的时刻会有不可预测的行为和结果,因为中断可能发生在任何进程运行的时间点。
确实虚拟地址映射表中会有某些虚地址没有分配物理内存的情况,但是跟这个问题没有关联。而且可以验证的是,如果在isr中访问非法地址肯定会挂掉。即使你在用户空间访问一个不存在于映射表的地址,也一样会出错,只是系统没有挂掉而已。

#4


引用 3 楼 xinzha 的回复:
进程虚拟地址映射表是存在的,但是中断运行在中断上下文,而不是进程上下文,在中断上下文中只有物理地址逻辑地址这些整个系统公用的东西才有意义(也就是说中断代码可以看到这些映射表,而进程私有的东西,中断是不会去看的),而用户空间地址是进程私有的,中断服务代码中如果真的去访问进程私有空间,那么同样的中断代码在不同的时刻会有不可预测的行为和结果,因为中断可能发生在任何进程运行的时间点。
确实虚拟地址映射表中会有某些虚地址没有分配物理内存的情况,但是跟这个问题没有关联。而且可以验证的是,如果在isr中访问非法地址肯定会挂掉。即使你在用户空间访问一个不存在于映射表的地址,也一样会出错,只是系统没有挂掉而已。

非常感谢你精彩无私的回答,受益良多!

推荐阅读
  • 优化联通光猫DNS服务器设置
    本文详细介绍了如何为联通光猫配置DNS服务器地址,以提高网络解析效率和访问体验。通过智能线路解析功能,域名解析可以根据访问者的IP来源和类型进行差异化处理,从而实现更优的网络性能。 ... [详细]
  • 本文详细分析了JSP(JavaServer Pages)技术的主要优点和缺点,帮助开发者更好地理解其适用场景及潜在挑战。JSP作为一种服务器端技术,广泛应用于Web开发中。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文详细介绍了如何在BackTrack 5中配置和启动SSH服务,确保其正常运行,并通过Windows系统成功连接。涵盖了必要的密钥生成步骤及常见问题解决方法。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 掌握Linux:基础命令入门
    本章节深入浅出地介绍了Linux系统中的基本命令操作,帮助读者快速上手并理解其核心功能。 ... [详细]
  • 解决Linux系统中pygraphviz安装问题
    本文探讨了在Linux环境下安装pygraphviz时遇到的常见问题,并提供了详细的解决方案和最佳实践。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 在哈佛大学商学院举行的Cyberposium大会上,专家们深入探讨了开源软件的崛起及其对企业市场的影响。会议指出,开源软件不仅为企业提供了新的增长机会,还促进了软件质量的提升和创新。 ... [详细]
  • CMake跨平台开发实践
    本文介绍如何使用CMake支持不同平台的代码编译。通过一个简单的示例,我们将展示如何编写CMakeLists.txt以适应Linux和Windows平台,并实现跨平台的函数调用。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
author-avatar
开心小笨笨猪
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有