IRP在内存中的结构

以下内容来自win7 64位系统

nt!_IRP

+0x000 Type             : Int2B

+0x002 Size             : Uint2B

+0x008 MdlAddress       : Ptr64 _MDL

+0x010 Flags            : Uint4B

+0x018 AssociatedIrp    :

+0x020 ThreadListEntry  : _LIST_ENTRY

+0x030 IoStatus         : _IO_STATUS_BLOCK

+0x040 RequestorMode    : Char

+0x041 PendingReturned  : UChar

+0x042 StackCount       : Char

+0x043 CurrentLocation  : Char

+0x044 Cancel           : UChar

+0x045 CancelIrql       : UChar

+0x046 ApcEnvironment   : Char

+0x047 AllocationFlags  : UChar

+0x048 UserIosb         : Ptr64 _IO_STATUS_BLOCK

+0x050 UserEvent        : Ptr64 _KEVENT

+0x058 Overlay          :

+0x068 CancelRoutine    : Ptr64     void

+0x070 UserBuffer       : Ptr64 Void

+0x078 Tail             :

+0x000 CSHORT Type 保留

+0x002 USHORT Size 保留

+0x008 PMDL MdlAddress MDL用户缓冲区的指针,如果是直接IO请求,则使用这个字段.如果驱动程序不使用直接IO,则该指针为空.IRP请求应该是下面这3中请求:

如果是IRP_MJ_READ,则此为空缓冲或驱动程序填写

如果是IRP_MJ_WRITE,则此缓冲区包含设备或驱动程序的数据

如果是IRP_MJ_DEVICE_CONTROL或IRP_MJ_INTERNAL_DEVICE_CONTROL请求,则根据 IOCTL 指定METHOD_IN_DIRECT或者METHOD_OUT_DIRECT来确定MDL是是包含数据还是空缓冲区.

+0x010 ULONG Flags

文件系统驱动使用这个字段,这个字段是只读字段.说明请求的类型

+0x018 union AssociatedIrp 共用体

AssociatedIrp.MasterIrp 指向IRP中的主IRP的指针,由最上层驱动程序调用IoMakeAssociatedIrp创建.

AssociatedIrp.SystemBuffer 指向系统空间缓冲区的指针,如果驱动程序使用缓冲IO,则缓冲区的目的由IRP主要功能代码决定,功能代码如下:

IRP_MJ_READ

缓冲器从设备或驱动程序接收数据。 缓冲区的长度由驱动程序的IO_STACK_LOCATION结构中的Parameters.Read.Length指定。

IRP_MJ_WRITE

缓冲区提供设备或驱动程序的数据。 缓冲区的长度由驱动程序IO_STACK_LOCATION结构中的Parameters.Write.Length指定。

IRP_MJ_DEVICE_CONTROL 或 IRP_MJ_INTERNAL_DEVICE_CONTROL

缓冲区表示提供给DeviceIoControl和IoBuildDeviceIoControlRequest的输入和输出缓冲区。 输出数据覆盖输入数据。

对于输入,缓冲区的长度由驱动程序的IO_STACK_LOCATION结构中的Parameters.DeviceIoControl.InputBufferLength指定。

对于输出,缓冲区的长度由驱动程序的IO_STACK_LOCATION结构中的Parameters.DeviceIoControl.OutputBufferLength指定。

如果驱动程序使用直接IO,则缓冲区的目的由IRP主要功能代码决定:

IRP_MJ_READ

NULL.

IRP_MJ_WRITE

NULL.

IRP_MJ_DEVICE_CONTROL 或 IRP_MJ_INTERNAL_DEVICE_CONTROL

表示提供给DeviceIoControl和IoBuildDeviceIoControlRequest的输入缓冲区。

缓冲区的长度由驱动程序的IO_STACK_LOCATION结构中的Parameters.DeviceIoControl.InputBufferLength指定。

+0x020 LIST_ENTRY ThreadListEntry 保留

+0x030 IO_STATUS_BLOCK IoStatus

包含IO_STATUS_BLOCK结构,驱动程序在调用IoCompleteRequest之前存储状态和信息。

+0x040 KPROCESSOR_MODE RequestorMode

指示操作的原始请求者的执行模式,UserMode或KernelMode。

+0x041 BOOLEAN PendingReturned

如果设置为TRUE,说明该请求等待完成。

所有完成函数都应该检查这个标志的值。

如果标志为TRUE,则完成函数不因返回STATUS_MORE_PROCESSING_REQUIRED,应该调用IoMarkIrpPending函数将待处理状态转发到设备堆栈中的上层驱动程序。

+0x042 CHAR StackCount 保留

+0x043 CHAR CurrentLocation 保留

+0x044 BOOLEAN Cancel

如果设置为TRUE,则应该取消该IRP请求

+0x045 KIRQL CancelIrql

包含调用IoAcquireCancelSpinLock(取消自旋锁)时驱动程序正在运行的IRQL

+0x046 CCHAR ApcEnvironment 保留

+0x047 UCHAR AllocationFlags 保留

+0x048 PIO_STATUS_BLOCK UserIosb 保留

+0x050 PKEVENT UserEvent 保留

+0x058 union Overlay 保留

+0x068 __volatile PDRIVER_CANCEL CancelRoutine

包含驱动程序提供的取消函数的入口点,如果IRP被取消,则调用该例程。 NULL表示IRP当前不可取消。

+0x070 PVOID UserBuffer

如果满足以下两个条件,则包含输出缓冲区的地址:

I / O堆栈位置中的主要功能代码是IRP_MJ_DEVICE_CONTROL或IRP_MJ_INTERNAL_DEVICE_CONTROL。

I / O控制代码用METHOD_NEITHER或METHOD_BUFFERED定义。

对于METHOD_BUFFERED,驱动程序应使用Irp-> AssociatedIrp.SystemBuffer指向的缓冲区作为输出缓冲区。 当驱动程序完成请求时,I / O管理器将此缓冲区的内容复制到Irp-> UserBuffer指向的输出缓冲区。 驱动程序不应该直接写入Irp-> UserBuffer指向的缓冲区。

+0x078 union Tail

Tail.Overlay.DeviceQueueEntry

如果IRP在与驱动程序设备对象相关联的设备队列中排队,则此字段将IRP链接在设备队列中。 这些链接只能在驱动程序处理IRP时使用。

Tail.Overlay.DriverContext

如果IRP未在与驱动程序设备对象相关联的设备队列中排队,则该字段可由驱动程序用于存储最多四个指针。 此字段只能在驱动程序拥有IRP时使用。

Tail.Overlay.Thread

指向调用者的线程控制块(TCB)的指针。 对于源自用户模式的请求,I / O管理器始终将此字段设置为指向发出请求的线程的TCB。

Tail.Overlay.ListEntry

如果驱动程序管理其自己的IRP内部队列,它使用此字段将一个IRP链接到下一个IRP。 这些链接只能在驱动程序将IRP保存在队列中或正在处理IRP时使用。

Tail.Overlay.AuxiliaryBuffer 保留

Tail.Overlay.CurrentStackLocation 保留

Tail.Overlay.PacketType 保留

Tail.Overlay.OriginalFileObject 保留

Tail.Apc 保留

Tail.CompletionKey 保留

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,723评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,080评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,604评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,440评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,431评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,499评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,893评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,541评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,751评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,547评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,619评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,320评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,890评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,896评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,137评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,796评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,335评论 2 342

推荐阅读更多精彩内容

  • 技术原理 何为符号链接?符号链接是一个别名,可以指向任意一个有名字的对象. ZwCreateFile 不但可以打开...
    f675b1a02698阅读 590评论 0 0
  • 设备绑定的内核API之一 驱动 --> 生成多个 --> 设备对象 --> 对应 --> 真实的一个设备 wind...
    f675b1a02698阅读 664评论 0 0
  • linux资料总章2.1 1.0写的不好抱歉 但是2.0已经改了很多 但是错误还是无法避免 以后资料会慢慢更新 大...
    数据革命阅读 12,127评论 2 34
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,579评论 18 139
  • Windows内核中把驱动,设备,文件等都称为"对象",在系统启动后,这些对象都在内存中. 一个驱动对象(DRIV...
    f675b1a02698阅读 1,056评论 0 0