欢迎光临 高端调试
登录
|
注册
|
FAQ
搜索论坛
内核调试
ACPI调试
Linux内核调试
Windows内核调试
调试方法学
调试战役
调试原理
新工具观察
操作系统
Linux
Windows Vista
Windows
驱动开发
Linux驱动
WDF
WDM
总线
PCI Express
PCI/PCI-X
USB
无线通信协议
中央处理器
64位CPU
ARM
IA-32
CPU Info Center
计算机机系统
ACPI标准
系统认证
Desktop
服务器
嵌入式系统
Embedded Linux
嵌入式开发工具
VxWorks
WinCE
嵌入式Windows
特别链接
格蠹调试套件(GDK)
格蠹学院
小朱书店
老雷的微博
《软件调试》
《格蠹汇编》
《软件调试(第二版)》
沪ICP备11027180号-1
Windows内核调试
帖子发起人:
小毛
发起时间:
2009-08-26 21:27 下午
回复:
1
高端调试
»
软件调试
»
Windows内核调试
»
学习完前8章,有几处疑问
搜索论坛
帖子排序:
Oldest to newest
Newest to oldest
2009-08-26, 21:27 下午
小毛
注册: 2009-08-26
发 贴: 3
学习完前8章,有几处疑问
花了几天时间看完前8章,弄懂了以前许多不懂得问题,但有几处疑问:
一是关于段机制的,当我访问某个地址时,比如我用mov eax,[12345678]指令,这里我并没有指定这个地址的段选择子。cpu如何知道这个地址所对应的段选择子呢?有人告诉我是和实模式一样采用ds作为默认段选择子呢?如果这样的话,用户程序访问内核地址时,由于要进行权限的检查,此时ds的值会变化吗?
二是在看到“使用 INT 2E切换到内核模式”时,NtDll中的NtReadFile发出INT 2E中断,cpu通过IDT表找到KiSystemService函数,此时cpu会吧执行权限给内核态程序,张老师写到当用户态切换到内核态时,cpu会进行权限检查,但是如果真是进行权限检查,那么很明显转换前用户态权限低呀,不是不能进入内核模式吗?我觉得对于中断的话,cpu不会进行权限检查吧。
对于这两个问题,还望张老师指教
IP 地址: 已记录
报告
2009-08-26, 22:51 下午
格蠹老雷
注册: 2005-12-19
发 贴: 1,303
Re: 学习完前8章,有几处疑问
Q1, 对的,是用默认的段。以Windows为例,DS段的基地址是0,大小是4GB,是可以指向内核空间的,但是通常会通过页属性来禁止用户态代码访问内核态数据。
0:001> dg 23
P Si Gr Pr Lo
Sel Base Limit Type l ze an es ng Flags
---- -------- -------- ---------- - -- -- -- -- --------
0023 00000000 ffffffff Data RW Ac 3 Bg Pg P Nl 00000cf3
中断和异常描述符中可以定义权限(DPL,参见P275),CPU会做权限检查,像INT 2E这种情况,属于通过检查的情况——检查是做的,只是符合要求,放行罢了。
IP 地址: 已记录
报告
高端调试
»
软件调试
»
Windows内核调试
»
学习完前8章,有几处疑问
请选择
论坛首页
|- 论坛搜索
|- 热门主题
|- 未回复的主题
用户选项
|- 登录
|- 注册
|- 找回密码
软件调试
|- Windows内核调试
|- C/C++本地代码调试
|- .Net程序调试
|- 脚本程序调试
|- Java程序调试
|- Linux内核调试
|- 《程序员》杂志调试专栏
|- WinDbg
|- GDB
|- 远程调试
|- 调试ACPI和BIOS
|- 特殊的调试任务
|- 转储分析
|- GDK7
内核探秘
|- Windows内核
|- Linux内核
系统架构
|- CPU架构
|- PCI/PCI Express架构
程序人生
|- 软件物语
|- 社区活动
|- 名人逸事
联盟论坛
|- 欢迎使用CnForums
没有银弹
|- BUG也精彩
|- 豆腐工程
|- 软件圈里十大怪
Windows Vista
|- 用调试利剑剖析VISTA内幕
|- 老专家如何破解新问题
|- 我的电脑谁说了算?
|- 资源
Office开发
|- Visio
驱动程序开发
|- Windows驱动开发
|- Linux驱动开发
|- Windows CE驱动开发
用户态开发
|- Windows本地代码(native)高级开发
|- Web应用开发
|- WinFX和.Net
|- Office开发
本站建设
|- 高端调试团队
|- 版面布局
|- 活动建议
|- 网站维护
64位计算
|- 64-bit Windows
|- 64-bit CPU
图书
|- 《软件调试》的示例程序
|- 《软件调试》的工具
|- 《软件调试》书友
|- 《软件调试》答疑
|- 《软件调试》勘误和意见
|- 《格蠹汇编》
|- 《软件调试》第二版卷1
|- 《软件调试》第二版卷2
云计算
|- IaaS
|- 云存储
|- 大数据
|- PaaS和SaaS
GPU
|- CUDA
|- OpenCL
|- HSA
|- 游戏开发与调试
(C)2004-2020 ADVDBG.ORG All Rights Reserved.