码迷,mamicode.com
首页 > 其他好文 > 详细

[转载]目标 code segment 的访问

时间:2015-01-31 11:50:58      阅读:202      评论:0      收藏:0      [点我收藏+]

标签:

当程序中使用指令 call / jmp,以及通过 int 引发中断例程的执行,这将都是对目标的 code segment 进行访问,当通过权限的检查后程序将会跳转到目标的 code segment 进行执行。

在 code segment 的访问过程中涉及到权限级别的改变,stack 的改变等问题。


访问目标 code segment 的几种情形:

1、call / jmp offset
在段内直接 call / jmp,不改变目标 code segment

2、call / jmp code_selector:offset
直接 call / jmp 目标 code segment

3、call / jmp callgate_selector:offset
使用 call gate 的 call / jmp 形式

4、call / jmp tss_selector:offset
使用 TSS gate 的直接 call / jmp 形式,使用了 TSS 任务切换机制

5、call / jmp taskgate_selector:offset
通过 task gate 使用 TSS 任务切换机制

6、int n
使用 int 指令调用 interrupt / trp 例程,或者 task gate 提供的任务切换机制

7、使用 syscall / sysret、 sysenter / sysexit 指令快速调用系统服务例程

8、ret 或 iret
利用 ret 以及 iret 指令构造另一种访问 code segment 的途径。


以上是程序中主动发起访问目标 code segment 大多数方法,在继续执行之前,processor 会进行一系统的检查,包括相关的权限检查、type 检查、limit 检查等,通过了检查后,加载到 cs:rip 后继续执行。

[转载]目标 code segment 的访问

标签:

原文地址:http://www.cnblogs.com/Acg-Check/p/4263739.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!