NtCreateFile获得的设备句柄为什么指向文件对象

NtCreateFile打开设备时,返回的句柄实际上是FILE_OBJECT,而非DEVICE_OBJECT。在查找设备对象并调用其ParseProcedure(IopParseDevice)后,会创建FILE_OBJECT,其DeviceObject字段指向实际的DEVICE_OBJECT。因此,句柄最终指向的是文件对象。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


通过NtCreateFile打开设备,获得的句柄实际上指向的是一个文件对象(FILE_OBJECT),而不是设备对象(DEVICE_OBJECT).


设备对象类型的创建过程如下,是有存在ParseProcedure的

RtlInitUnicodeString( &nameString, L"Device" );
    objectTypeInitializer.DefaultNonPagedPoolCharge = sizeof( DEVICE_OBJECT );
    objectTypeInitializer.ParseProcedure = IopParseDevice;
    objectTypeInitializer.CaseInsensitive = TRUE;
    objectTypeInitializer.DeleteProcedure = IopDeleteDevice;
    objectTypeInitializer.SecurityProcedure = IopGetSetSecurityObject;
    objectTypeInitializer.QueryNameProcedure = (OB_QUERYNAME_METHOD)NULL;
    if (!NT_SUCCESS( ObCreateObjectType( &nameString,
                                      &objectTypeInitializer,
                                      (PSECURITY_DESCRIPTOR) NULL,
                                      &IoDeviceObjectType ))) {
        return FALSE;
    }


NtCreateFile打开设备主要通过ObpLookupObjectName来找到设备对象,当找到设备对象时:


 if (ParseProcedure && (!InsertObject || (ParseProcedure == ObpParseSymbolicLink))) {

                。。。。。。。。

                。。。。。。。。

                。。。。。。。。

                Status = (*ParseProcedure)( Object,
                                            (PVOID)ObjectType,
                                            AccessState,
                                            AccessCheckMode,
                                            Attributes,
                                            ObjectName,
                                            &RemainingName,
                                            ParseContext,
                                            SecurityQos,
                                            &Object );

                。。。。。。。。

                。。。。。。。。

                。。。。。。。。

}


因此当找到设备对象时,调用设备对象的ParseProcedure:IopParseDevice。

在IopParseDevice中,对非删除和查询炒作创建文件对象(FILE_OBJECT),文件对象的DeviceObject成员指向实际设备对象,并返回文件对象


 status = ObCreateObject( KernelMode,
                                 IoFileObjectType,
                                 &objectAttributes,
                                 AccessMode,
                                 (PVOID) NULL,
                                 fileObjectSize,
                                 0,
                                 0,
                                 (PVOID *) &fileObject );


fileObject->DeviceObject = parseDeviceObject;


*Object = fileObject;


故最终NtCreateFile获得的设备句柄指向文件对象








评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值