tss

2023-05-16

1.linux进程切换和TSS结构

http://blog.csdn.net/goodlixueyong/article/details/6018281

  TSS 全称为task state segment,是指在操作系统进程管理的过程中,进程切换时的任务现场信息。   

X86体系从硬件上支持任务间的切换。为此目的,它增设了一个新段:任务状态段(TSS),它和数据段、代码段一样也是一种段,记录了任务的状态信息。

与其它段一样,TSS也有描述它的结构:TSS描述符表,它记录了一个TSS的信息,同时还有一个TR寄存器,它指向当前任务的TSS。任务切换的时候,CPU会将原寄存器的内容写出到相应的TSS,同时将新TSS的内容填到寄存器中,这样就实现了任务的切换。

    TSS在任务切换过程中起着重要作用,通过它实现任务的挂起和恢复。所谓任务切换是指挂起当前正在执行的任务,恢复或启动执行另一个任务。Linux任务切换是通过switch_to这个宏来实现的,它利用长跳指令,当长跳指令的操作数是TSS描述符的时候,就会引起CPU的任务的切换,此时,CPU将所有寄存器的状态保存到当前任务寄存器TR所指向的TSS段中,然后利用长跳指令的操作数(TSS描述符)找到新任务的TSS段,并将其中的内容填写到各个寄存器中,最后,将新任务的TSS选择符更新到TR中。这样系统就开始运行新切换的任务了。由此可见,通过在TSS中保存任务现场各寄存器状态的完整映象,实现了任务的切换。 task_struct中的tss成员就是记录TSS段内容的。当进程被切换前,该进程用tss_struct保存处理器的所有寄存器的当前值。当进程重新执行时,CPU利用tss恢复寄存器状态。

      

2.x86体系下linux中的任务切换与TSS      

tss的作用举例:保存不同特权级别下任务所使用的寄存器,特别重要的是esp,因为比如中断后,涉及特权级切换时(一个任务切换),首先要切换栈,这个栈显然是内核栈,那么如何找到该栈的地址呢,这需要从tss段中得到,这样后续的执行才有所依托(在x86机器上,c语言的函数调用是通过栈实现的)。只要涉及地特权环到高特权环的任务切换,都需要找到高特权环对应的栈,因此需要esp2,esp1,esp0起码三个esp,然而linux只使用esp0。

tss是什么:tss是一个段,段是x86的概念,在保护模式下,段选择符参与寻址,段选择符在段寄存器中,而tss段则在tr寄存器中。

intel的建议:为每一个进程准备一个独立的tss段,进程切换的时候切换tr寄存器使之指向该进程对应的tss段,然后在任务切换时(比如涉及特权级切换的中断)使用该段保留所有的寄存器。

linux的做法:

1.linux没有为每一个进程都准备一个tss段,而是每一个cpu使用一个tss段,tr寄存器保存该段。进程切换时,只更新唯一tss段中的esp0字段到新进程的内核栈。

2.linux的tss段中只使用esp0和iomap等字段,不用它来保存寄存器,在一个用户进程被中断进入ring0的时候,tss中取出esp0,然后切到esp0,其它的寄存器则保存在esp0指示的内核栈上而不保存在tss中。

3.结果,linux中每一个cpu只有一个tss段,tr寄存器永远指向它。符合x86处理器的使用规范,但不遵循intel的建议,这样的后果是开销更小了,因为不必切换tr寄存器了。

linux的实现:

1.定义tss:

struct tss_struct init_tss[NR_CPUS] __cacheline_aligned = { [0 ... NR_CPUS-1] = INIT_TSS };(arch/i386/kernel/init_task.c)

INIT_TSS定义为:

#define INIT_TSS  {                            /

    .esp0        = sizeof(init_stack) + (long)&init_stack,    /

    .ss0        = __KERNEL_DS,                    /

    .esp1        = sizeof(init_tss[0]) + (long)&init_tss[0],    /

    .ss1        = __KERNEL_CS,                    /

    .ldt        = GDT_ENTRY_LDT,                /

    .io_bitmap_base    = INVALID_IO_BITMAP_OFFSET,            /

    .io_bitmap    = { [ 0 ... IO_BITMAP_LONGS] = ~0 },        /

}

2.初始化tss:

struct tss_struct * t = init_tss + cpu;

...

load_esp0(t, thread);

set_tss_desc(cpu,t);

cpu_gdt_table[cpu][GDT_ENTRY_TSS].b &= 0xfffffdff;

load_TR_desc();

相关函数或者宏为:

#define load_TR_desc() __asm__ __volatile__("ltr %%ax"::"a" (GDT_ENTRY_TSS*8))

static inline void __set_tss_desc(unsigned int cpu, unsigned int entry, void *addr)

{

    _set_tssldt_desc(&cpu_gdt_table[cpu][entry], (int)addr,

        offsetof(struct tss_struct, __cacheline_filler) - 1, 0x89);

}

 

#define set_tss_desc(cpu,addr) __set_tss_desc(cpu, GDT_ENTRY_TSS, addr)

经过上述的初始化,tr永远指向唯一的tss段,然而tss段中的esp0以及iomap却是不断随着进程切换而变化的。

3.进程切换时切换全局唯一tss段中的esp0以及iomap即可:

在__switch_to中:

struct tss_struct *tss = init_tss + cpu;

...

load_esp0(tss, next);

从而改变了tss的esp0。

此时如果进程在用户态被中断,机器切到ring0,从tr中取出唯一的tss段,找到它的esp0,将堆栈切过去即可,然后把所有的其它寄存器都保存在tss当前的esp0指示的内核也就是ring0的堆栈上。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

tss 的相关文章

  • publisher与subscriber话题的消息类型md5sum不一致问题

    ERROR 1604235557 591296096 Client range vision fusion 01 wants topic detection vision objects to have datatype md5sum au
  • Ubuntu18.04下px4+MAVROSM+QGC地面站安装教程及避坑指南

    下面安装建立在已经安装好了ROS的基础 xff0c 未安装ROS的请先按照下面教程安装ROSROS 安装教程 目录 一 安装px4 toolchain 二 编译PX4固件 三 mavros and mavlink 安装 四 修改gazebo
  • Linux实用工具/软件

    一 录屏 Kazam 参考 xff1a Linux截图和屏幕视频录制软件Kazam 简书 二 播放器 VLC 推荐理由 xff1a 跨平台播放器 xff0c 支持H264等高清算法压缩格式 h264压缩比是200 1 xff0c 一般的第三
  • Ubuntu 安装boost

    boost是扩展的C 43 43 标准库 查看电脑默认安装的boost版本 xff1a dpkg S usr include boost version hpp 很多程序需要boost xff0c 但是版本可能不是ubuntu系统默认安装的
  • linux+python自动备份数据库

    linux 43 python自动备份数据库 1 在linux上安装mysqldump xff1a yum y install holland mysqldump noarch 2 编写python脚本 xff1a usr bin pyth
  • python基于Tkinter实现学生信息管理系统

    一 功能点介绍 xff08 毕设设计 xff09 1 添加学生成绩 xff1a 管理员可以在系统中添加学生的成绩信息 xff0c 包括学生姓名 学号 课程名称 成绩等 2 删除学生成绩 xff1a 管理员可以根据学生的学号或者姓名删除学生的
  • 感想京东

    xfeff xfeff 现在网上购物已经是家常便饭 xff0c 大多数人们都已接受了网购这种方式 xff0c 而能够给人们提供网购的网站也很多 xff0c 而我从好几年前就开始在京东网购物了 xff0c 因此京东商城的每一次发展 xff0c
  • 2014年度总结

    时光转眼即逝 xff0c 从还是懵懵懂懂的孩子一下子变成了已步入社会的工作者 回首2014年 xff0c 有欢乐 xff0c 有泪水 xff0c 有付出 xff0c 有收获等等 xff01 想起2014的自己还是一个刚步入工作岗位才半年 x
  • 将tensorflow训练好的模型移植到android

    将tensorflow训练好的模型移植到android上 说明 本文将描述如何将一个训练好的模型植入到android设备上 xff0c 并且在android设备上输入待处理数据 xff0c 通过模型 xff0c 获取输出数据 通过一个例子
  • FreeRTOS 启动第一个线程的步骤

    FreeRTOS 启动第一个线程的步骤 从main函数开始 初始化完成之后 通过SVC指令的中断函数来 初始化成需要的寄存器值 才能正常运行线程 1 启动第一个线程函数prvStartFirstTask 调用prvStartFirstTas
  • C#委托与事件的本质区别

    C 委托与事件的本质区别 从定义上说 xff0c 委托被编译器编译成一个类 xff0c 所以它可以像类一样在任何地方定义 xff0c 而事件被编译成一个委托类型的私有字段和两个公有add 和 remove 方法 xff08 有点类似于属性的
  • 文章千古事、得失寸心知

    文章千古事 得失寸心知 这些年 xff0c 读过的技术经典图书 成晓旭 xff1a 欢迎转载 行千里路 读万卷书 xff1b 历数十项目 编百万代码 十来年风雨IT路 xff0c 上百本沉寂专业书 佛说 xff1a 一花一世界 一叶一菩提
  • PX4+QGC+jmavsim软件在环仿真

    一 环境修改 参考官方手册jMAVSim 仿真模拟 PX4 Developer Guide xff0c 以上环境基于上一篇内容 xff0c 未完成ROS 43 jmavsim 43 QGC环境搭建的请移步Ubuntu18 04下px4 43
  • Delphi之东进模拟语音卡(D160A)可复用源码

    Delphi之东进模拟语音卡 D160A 可复用源码 作者 xff1a 成晓旭 Blog xff1a http blog csdn net cxxsoft 声明 xff1a 欢迎转载 xff0c 请保证文章的完整性 设计简介 xff1a 1
  • 《上海滩》命运的真实

    上海滩 命运的真实 小时候 xff0c 家里没电视 xff0c 像80年周润华版 上海滩 这样的经典 xff0c 通常也会很难一集不漏地看全 当然 xff0c 那个时候也看不懂那个冯程程的漂亮 许文强的帅气 xff0c 更看不懂冯敬尧的强横
  • 中国房价不可能下降的19个理由

    中国房价不可能下降的19 个理由 2014 年01月26日 根据 腾讯房产 资料整理 在 腾讯房产 频道看到的 xff0c 所谓专家解释说的房价不可能下降有N 个无以辩驳理由 虽然少数内容缺乏数据依据 xff0c 但总体来看 xff0c 分
  • 如果生命就是一次马航之旅

    岁月长河中 xff0c 生命只不过是一粒尘埃 xff0c 渺小而短暂 xff1a 正如一场马航之旅 xff0c 从起点到终点 xff0c 正常飞行6小时后一定能抵达目的地 xff1b 当波音777平稳抵达目的地后 xff0c 无论你多么留念
  • 秀一段《易语言》的源代码

    公开 类 启动类 lt gt 公开 静态 启动 猜数字 猜 61 创建 猜数字 猜 猜 类 猜数字 整数 内定数字 61 66 TODO 随机选择一个数 公开 猜 循环 猜数字 61 61 假 逻辑 猜数字 控制台 输出行 34 请猜1 1
  • 腾讯QQ音乐业务产品规划

    腾讯QQ音乐业务产品规划

随机推荐

  • 谁是你生命中的贵人

    谁是你生命中的贵人 谨以此文献给我一生至爱 作者 xff1a 成晓旭 版权保留 转载请保持文章完整性 最近很奇怪的发现 xff0c 生命中的人和事 xff0c 常常不是均匀而规律地分布在人生的时间轴上 xff0c 或许很长时间都平淡无奇 x
  • 服务器处理能力,你估算正确过吗?

    服务器处理能力 xff0c 你估算正确过吗 xff1f 作者 xff1a 成晓旭 1 引题 但凡写过技术方案的都知道 xff0c 在技术方案最终落实到工程实施部署时 xff0c 必须编制出当前解决方案需要部署的IT设备及环境 xff0c 包
  • 电信运营商云计算体系架构分析

    电信运营商云计算体系架构分析 作者 xff1a 成晓旭 xff08 版权保留 欢迎转载 xff09 第三篇 xff1a 体系架构分析 电信运营商云计算发展分析之一 xff1a 战略定位分析 xff0c 可供参考 电信运营商云计算发展分析之二
  • 企业ERP系统开发总结及建议

    企业ERP系统开发总结及建议 作者 xff1a 成晓旭 对于像我们这种规模的大型公司 xff0c 自己建设 实施和维护满足公司特定管理要求的管理信息系统 xff0c 是目前部分大型公司建设企业ERP 的常见思路 比如 xff1a XXXX
  • DataGridView解决使用BindingList时属性改变界面不更新问题

    目录 问题 解决方法一 解决方法二 问题 在使用BindingList作为DataGridView的数据源时 xff0c 当BindingList lt gt 有增加或者删除的时候DataGridView会自动刷新 xff0c 但是当Bin
  • 给软件工程师的自学建议

    给软件工程师的自学建议 与现在大学生的情况类似 xff0c 学校学的专业知识总是与实际工作中需要的知识相差甚远 或许进入我们这个行业就注定要一辈子不离书本 不离学习了 由于软硬件技术的推陈出新 xff0c 学校教的C Basic Pasca
  • 电信运营商移动互联网发展分析

    电信运营商移动互联网发展分析 移动互联网是通信业发展的大趋势 xff0c 随着3G 和WiMAX 等高速无线接入技术的飞速发展 xff0c 移动互联网不仅继承固定互联网的很多技术 xff0c 并且在商务 娱乐以及移动性等方面拓展用户需求 自
  • 47天21家面试,半年空挡期觉得整个人生都被毁了

    近日 xff0c 有网友在某社交论坛将自己这段时间的面试经历发表出来 xff0c 根据发帖人自己提供的信息 xff0c 主要面试的地点都在北京 xff0c 上海等地 微软和亚马逊刚面试完一面 xff0c 都是以算法为主 xff0c 其中 x
  • 嵌入式软件工程师面试题及答案

    题目一 上个星期 xff0c 去深圳一家搞ARM开发的公司面试 xff0c HR叫我做了一份卷子 xff0c 里面都是C编程 xff0c 心中暗喜 xff0c 因为这些题基本上都在程序员面试宝典里见过 后来回到学校 xff0c 在网上搜索
  • 中断和查询方式区别

    中断方式 xff1a 是事件触发的 xff0c 换訖只要有事件产生都会进入中断 組取得最优运行 xff0c 因此响应更快 xff0c 及时 查询方式 xff1a 就是在主函数里面不停循环 xff0c 查询端C 状态 xff0c 明显其弊端在
  • 怎么用美图秀秀制作证件照

    1 第一步 xff1a 制作各种背景 在美图秀秀软件中点击选择 新建 按钮 xff0c 打开新建功能菜单选项 弹出的页面中我们点击选择 新建画布 xff0c 然后选项设置选择使用 白色画布 或者 蓝色画布 xff0c 依照一寸 xff1a
  • C++应用程序路径获取及操作

    xfeff xfeff 想要访问执行程序 exe 路径下的文件 xff0c 有以下几个步骤 xff1a 1 先通过函数GetModuleFileName获取执行程序的绝对路径 TCHAR szPath MAX PATH 61 0 GetMo
  • c++成员函数后面加一个冒号的含义

    目录 1 变量初始化方式 1 1 赋值运算符赋值 1 2 括号赋值 1 3 冒号初始化 1 4 使用情况 1 变量初始化方式 1 1 赋值运算符赋值 int a 61 10 char b 61 39 r 39 1 2 括号赋值 int a
  • 相机标定与内外参

    目录 1 相机标定 1 1外参 1 2内参 2 参考资料 1 相机标定 在图像测量过程以及机器视觉应用中 xff0c 为确定空间物体表面某点的三维几何位置与其在图像中对应点之间的相互关系 xff0c 必须建立相机成像的几何模型 xff0c
  • 开启代理服务器解决跨域问题

    我在学习尚硅谷Ajax课程时候 xff0c 第一次遇到跨域的问题 Access to XMLHttpRequest at http localhost 5000 students from origin http localhost 808
  • 阿里云CentOS环境之docker安装,启动,加速器,docker-compose(十四)

    阿里云CentOS环境之docker安装 xff0c 启动 xff0c 加速器 十四 文章目录 阿里云CentOS环境之docker安装 xff0c 启动 xff0c 加速器 十四 介绍前提条件centos下安装1 卸载 xff08 可选
  • SQL Server JDBC Driver配置方法(图文讲解)

    一 下载驱动程序 下载地址 http download microsoft com download 8 B D 8BDABAE2 B6EA 41D4 B903 7916EF3690EF sqljdbc 1 2 2323 101 enu e
  • 孤立森林(Isolation Forest)算法剖析

    之后会持续更新算法剖析系列 xff0c 力图用最生动的例子演示每一个算法的原理 xff0c 不稀里糊涂做一个调包侠 欢迎持续关注 xff0c 指正不足 孤立森林 xff08 Isolation Forest xff09 算法是西瓜书作者周志
  • 如何使用VOFA+?一款好用的上位机软件(VOFA+的三种数据传输协议)——以PID调参为例

    这里写目录标题 起因一 VOFA 43 支持的三种数据传输协议RawData协议格式1 使用方法2 示例3 测试 firewater协议格式1 使用方法2 数据格式3 示例4 测试 justfloat协议格式1 使用方法2 数据格式3 示例
  • tss

    1 linux进程切换和TSS结构 http blog csdn net goodlixueyong article details 6018281 TSS 全称为task state segment xff0c 是指在操作系统进程管理的过