获取中断描述符表IDT的信息
<pre name="code" class="cpp">//GetIDT.h文件
#ifndef _WIN32_WINNT // Allow use of features specific to Windows XP or later.
#define _WIN32_WINNT 0x0501 // Change this to the appropriate value to target other versions of Windows.
#endif
#ifdef __cplusplus
extern "C"
{
#endif
#include <ntddk.h>
#include <ntddstor.h>
#include <mountdev.h>
#include <ntddvol.h>
#ifdef __cplusplus
}
#endif
//***************************************************************************************************************
//GetIDT.cpp文件
#include "GetIDT.h"
//#include <stdio.h>
//IDT表的最大项数为256
#define MAX_IDT_ENTRIES 0XFF
#define MAKELONG(a, b)\
((unsigned long) (((unsigned short) (a)) | ((unsigned long) ((unsigned short) (b))) << 16))
//SIDT返回的数据格式
typedef struct
{
unsigned short IDTLimit; //IDT表项的个数
unsigned short LowIDTBase; //地址低16位
unsigned short HiIDTBase; //地址高16位
}IDTINFO, *PIDTINFO;
#pragma pack(1)
typedef struct
{
unsigned short LowOffset; //地址低16位
unsigned short Selector; //段选择字
unsigned char unused_lo; //保留
unsigned char segment_type:4; //中断门类型
unsigned char system_segment_flag:1; //为0是中断门
unsigned char DPL:2; //特权级
unsigned char P:1; //现在是否是使用中断
unsigned short HiOffset; //地址高16位
}IDTENTRY, *PIDTENTRY;
#pragma pack()
//卸载例程
void GetIDTUnload(IN PDRIVER_OBJECT DriverObject);
//创建和关闭例程
NTSTATUS GetIDTCreateClose(IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp);
//默认处理例程
NTSTATUS GetIDTDefaultHandler(IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp);
//获取IDT表的例程函数
NTSTATUS Fun_GetIDT();
#ifdef __cplusplus
//驱动入口函数
extern "C" NTSTATUS DriverEntry(IN PDRIVER_OBJECT DriverObject, IN PUNICODE_STRING RegistryPath);
#endif
NTSTATUS DriverEntry(IN PDRIVER_OBJECT DriverObject, IN PUNICODE_STRING RegistryPath)
{
//设备名称
UNICODE_STRING DeviceName;
//设备连接符
UNICODE_STRING Win32Device;
//设备对象
PDEVICE_OBJECT DeviceObject = NULL;
NTSTATUS status;
unsigned i;
//DeviceName-设备对象名称
RtlInitUnicodeString(&DeviceName,L"\\Device\\GetIDT0");
//Win32Device-连接符
RtlInitUnicodeString(&Win32Device,L"\\DosDevices\\GetIDT0");
for (i = 0; i <= IRP_MJ_MAXIMUM_FUNCTION; i++)
{
//设置默认的处理例程函数
DriverObject->MajorFunction[i] = GetIDTDefaultHandler;
}
//设置创建处理例程函数
DriverObject->MajorFunction[IRP_MJ_CREATE] = GetIDTCreateClose;
//设置关闭处理例程函数
DriverObject->MajorFunction[IRP_MJ_CLOSE] = GetIDTCreateClose;
//设置卸载处理例程函数
DriverObject->DriverUnload = GetIDTUnload;
//创建设备对象
status = IoCreateDevice(DriverObject,
0,
&DeviceName,
FILE_DEVICE_UNKNOWN, //设备类型
0,
FALSE,
&DeviceObject);
if (!NT_SUCCESS(status))
return status;
if (!DeviceObject)
return STATUS_UNEXPECTED_IO_ERROR;
//设置缓冲区通信方式
DeviceObject->Flags |= DO_DIRECT_IO;
//设置字对齐
DeviceObject->AlignmentRequirement = FILE_WORD_ALIGNMENT;
//创建连接符
status = IoCreateSymbolicLink(&Win32Device, &DeviceName);
//设备初始化完成
DeviceObject->Flags &= ~DO_DEVICE_INITIALIZING;
//获取IDT表
Fun_GetIDT();
return STATUS_SUCCESS;
}
//获取IDT表的例程函数
NTSTATUS Fun_GetIDT()
{
IDTINFO idtInfo;
PIDTENTRY pIdtEntry;
//获取IDT表的基地址
__asm sidt idtInfo
pIdtEntry = (PIDTENTRY)MAKELONG(idtInfo.LowIDTBase, idtInfo.HiIDTBase);
for (unsigned long i = 0; i < MAX_IDT_ENTRIES; i++)
{
//char szBuffer[255];
PIDTENTRY pTmpIdtEntry = &pIdtEntry[i];
//获取IDT表的每项的地址
unsigned long lgAddr = MAKELONG(pTmpIdtEntry->LowOffset, pTmpIdtEntry->HiOffset);
//_snprintf(szBuffer, 253, "中断号:%d,地址:%08X\r\n", i, lgAddr);
//显示
KdPrint(("中断号:%04d,地址:%08X\r\n", i, lgAddr));
}
return STATUS_SUCCESS;
}
//卸载例程
void GetIDTUnload(IN PDRIVER_OBJECT DriverObject)
{
UNICODE_STRING Win32Device;
RtlInitUnicodeString(&Win32Device,L"\\DosDevices\\GetIDT0");
IoDeleteSymbolicLink(&Win32Device);
IoDeleteDevice(DriverObject->DeviceObject);
}
//创建关闭例程
NTSTATUS GetIDTCreateClose(IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp)
{
Irp->IoStatus.Status = STATUS_SUCCESS;
Irp->IoStatus.Information = 0;
IoCompleteRequest(Irp, IO_NO_INCREMENT);
return STATUS_SUCCESS;
}
//默认处理例程
NTSTATUS GetIDTDefaultHandler(IN PDEVICE_OBJECT DeviceObject, IN PIRP Irp)
{
Irp->IoStatus.Status = STATUS_NOT_SUPPORTED;
Irp->IoStatus.Information = 0;
IoCompleteRequest(Irp, IO_NO_INCREMENT);
return Irp->IoStatus.Status;
}
获取中断描述符表IDT的信息的更多相关文章
- Bran的内核开发教程(bkerndev)-07 中断描述符表(IDT)
中断描述符表(IDT) 中断描述符表(IDT)用于告诉处理器调用哪个中断服务程序(ISR)来处理异常或汇编中的"int"指令.每当设备完成请求并需要服务事, 中断请求也会调用I ...
- 中断描述符表 IDT
保护模式下三个重要的系统表——GDT.LDT和IDT 这里主要是解释中断描述符表 中断描述符表IDT将每个异常或中断向量分别与它们的处理过程联系起来.与GDT和LDT表类似,IDT也是由8字节长描述符 ...
- 中断描述符表(Interrupt Descriptor Table,IDT)
中断描述符表(Interrupt Descriptor Table,IDT)将每个异常或中断向量分别与它们的处理过程联系起来.与GDT和LDT表类似,IDT也是由8字节长描述符组成的一个数组. #pr ...
- IDT系列:(一)初探IDT,Interrupt Descriptor Table,中断描述符表
原文: IDT系列:(一)初探IDT,Interrupt Descriptor Table,中断描述符表 IDT,Interrupt Descriptor Table,中断描述符表是CPU用来处理中 ...
- LGDT/LIDT-加载全局/中断描述符表寄存器
将源操作数中的值加载到全局描述符表寄存器 (GDTR) 或中断描述符表寄存器 (IDTR).源操作数指定 6 字节内存位置,它包含全局描述符表 (GDT) 或中断描述符表 (IDT) 的基址(线性地址 ...
- Linux中断技术、门描述符、IDT(中断描述符表)、异常控制技术总结归类
相关学习资料 <深入理解计算机系统(原书第2版)>.pdf http://zh.wikipedia.org/zh/%E4%B8%AD%E6%96%B7 独辟蹊径品内核:Linux内核源代码 ...
- 中断——中断描述符表的定义和初始化(二) (基于3.16-rc4)
上篇博文对中断描述符表(IDT)中异常和非屏蔽中断部分的初始化做了说明,这篇文章将分析外部中断部分的初始化. 在上篇博文中,可以看到,内核在setup_once汇编片段中,对中断和异常部分做了初步的初 ...
- 中断——中断描述符表的定义和初始化(一) (基于3.16-rc4)
1.中断描述符表的定义(arch/x86/kernel/traps.c) gate_desc debug_idt_table[NR_VECTORS] __page_aligned_bss; 定义的描述 ...
- 【译】x86程序员手册32-9.4 中断描述符表
9.4 Interrupt Descriptor Table 中断描述符表 The interrupt descriptor table (IDT) associates each interrupt ...
随机推荐
- 剑指 Offer 09. 用两个栈实现队列 +java中栈和队列的使用
剑指 Offer 09. 用两个栈实现队列 题目链接 class CQueue { private Stack<Integer> sta1; private Stack<Intege ...
- VirtualBOX 虚拟机 FreeBSD配置
pkg装virtualbox-ose-additions, 再将 Section "Device"Identifier "Card0"Driver " ...
- LNMP配置——PHP安装
一.下载 #cd /usr/local/src //软件包都放在这里方便管理 #wget http://cn2.php.net/distributions/php-5.6.30.tar.gz 二.解压 ...
- Spring如何解决循环依赖
一.什么是循环依赖 多个bean之间相互依赖,形成了一个闭环. 比如:A依赖于B.B依赖于c.c依赖于A 通常来说,如果问spring容器内部如何解决循环依赖, 一定是指默认的单例Bean中,属性互相 ...
- CodeMonkey少儿编程第7章 函数
目标 了解函数是什么 掌握如何定义一个函数 函数是什么 本章我们学习一个新的概念----函数. 你可以简单的将函数看作为一个黑匣子,给它输入参数后,它将会按照一定的规则,执行相应的指令或输出数据. 让 ...
- Nginx配置静态文件服务从入门到精通
作者:三十三重天 博客:http://www.zhouhuibo.club 通过学习和分享的过程,将自己工作中的问题和技术总结输出,希望菜鸟和老鸟都能通过自己的文章收获新的知识,并付诸实施. 引言 使 ...
- SpringMVC请求映射handler源码解读
请求映射源码 首先看一张请求完整流转图(这里感谢博客园上这位大神的图,博客地址我忘记了): 前台发送给后台的访问请求是如何找到对应的控制器映射并执行后续的后台操作呢,其核心为DispatcherSer ...
- P1423_小玉在游泳(JAVA语言)
题目描述 小玉开心的在游泳,可是她很快难过的发现,自己的力气不够,游泳好累哦. 已知小玉第一步能游2米,可是随着越来越累,力气越来越小, 她接下来的每一步都只能游出上一步距离的98%. 现在小玉想知道 ...
- 前瞻|Amundsen的数据血缘功能
目前,Amundsen并不支持表级别和列级别的数据血缘功能,也没有办法展示数据的来龙去脉. 作为Amundsen一项非常核心的功能,Lineage功能早已经提上日程,并进入设计与研发阶段.本位将展示此 ...
- Spring Boot 轻量替代框架 Solon 1.3.18 发布
Solon 是一个微型的Java开发框架.项目从2018年启动以来,参考过大量前人作品:历时两年,4000多次的commit:内核保持0.1m的身材,超高的跑分,良好的使用体验.支持:RPC.REST ...