linux-0.11内核 任务的堆栈切换

本文详细介绍了在用户态与内核态之间如何进行堆栈切换的过程,包括了用户态堆栈指针(ss和esp)与内核态堆栈指针(ss0和esp0)的具体作用及它们在任务状态段TSS中的位置。当CPU从用户态切换到内核态时,它会保存当前的用户态堆栈指针,并压入内核态堆栈中,同时也会保存标志寄存器eflags的内容和返回地址。

http://blog.163.com/di_yang@yeah/blog/static/86118492201212534924900/

一直缠绕的两个问题:怎样标识的内核栈与用户栈?如何在内核态堆栈与用户态堆栈之间切换? 

用户态堆栈指针:ss和esp;

内核态堆栈指针:ss0和esp0;

二者均位于任务的tss结构中。这里的任务是指除任务0和1之外的普通任务。

CPU进行用户态堆栈到内核态堆栈的切换操作时,CPU会从当前任务的任务状态段TSS中取得新堆栈的段选择符和偏移值,即从TSS的ss0和esp0字段中获取,在定位了新堆栈(内核态堆栈)之后,CPU就会首先把原用户态堆栈指针ss和esp压入内核态堆栈,随后把标志寄存器eflags内容和返回位置cs、eip压入内核态堆栈。

任务调用系统调用时就会进入内核并执行内核中的中断服务代码,此时内核代码就会使用该任务的内核态堆栈进行上述操作。而在执行iret退出内核程序返回到用户程序时,将恢复用户态的堆栈和eflags。

任务的tss结构:

转载于:https://www.cnblogs.com/wanghj-dz/p/3985400.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值