5968|4

76

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

ZwQuerySystemInformation(SystemHandleInformation,NULL,0,&nSize);为什么调用失败?第一个解决的,就 [复制链接]

    ULONG nSize;
    ULONG pBuffer;
    NTSTATUS status;
        DbgPrint("GetHandleList\n");
       
        //pBuffer =(ULONG)ExAllocatePool(PagedPool,0x1000);
    status = ZwQuerySystemInformation(SystemHandleInformation,NULL,0,&nSize);   
    if(NT_SUCCESS( status ))
        {        
                pBuffer =(ULONG)ExAllocatePool(NonPagedPool,nSize);
        status = ZwQuerySystemInformation(SystemHandleInformation,(PVOID)pBuffer,nSize,NULL);
                if ( !NT_SUCCESS( status ) )
                {
                        ExFreePool( pBuffer );
                    return STATUS_UNSUCCESSFUL;
                }
                else
                        return pBuffer;
    }
    else
                return 0;

最新回复

原来是我的判断错了! 以下是正确的代码:     ULONG nSize;     ULONG pBuffer;     NTSTATUS status;         DbgPrint("GetHandleList\n");             pBuffer =(ULONG)ExAllocatePool(PagedPool,0x1000);     status = ZwQuerySystemInformation(SystemHandleInformation,(PVOID)pBuffer,0x1000,&nSize);     ExFreePool((PVOID)pBuffer);        if(STATUS_INFO_LENGTH_MISMATCH == status)     {         pBuffer =(ULONG)ExAllocatePool(NonPagedPool,nSize);         ZwQuerySystemInformation(SystemHandleInformation,(PVOID)pBuffer,nSize,NULL);         return pBuffer;     }     else         return 0;  详情 回复 发表于 2008-12-7 00:30
点赞 关注

回复
举报

76

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
ZwQuerySystemInformation的第2、3参数给0时肯定会返回失败的,(因为缓冲区空间不足),第4参数返回所需的空间大小。此时你判断if(NT_SUCCESS( status ))就不对了。
 
 

回复

68

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
怎么这样调用也是失败的?

   ULONG nSize;
    ULONG pBuffer;
    NTSTATUS status;
        DbgPrint("GetHandleList\n");
       
    pBuffer =(ULONG)ExAllocatePool(PagedPool,0x1000);
    status = ZwQuerySystemInformation(SystemHandleInformation,(PVOID)pBuffer,0x1000,&nSize);
    ExFreePool((PVOID)pBuffer);   
    if(NT_SUCCESS( status ))
        {        
                pBuffer =(ULONG)ExAllocatePool(NonPagedPool,nSize);
        status = ZwQuerySystemInformation(SystemHandleInformation,(PVOID)pBuffer,nSize,NULL);
                if ( !NT_SUCCESS( status ) )
                {
                        ExFreePool( pBuffer );
                    return STATUS_UNSUCCESSFUL;
                }
                else
                        return pBuffer;
    }
    else
                return 0;
 
 
 

回复

77

帖子

0

TA的资源

一粒金砂(初级)

4
 
当给出的缓冲区不足时,会返回失败,第4参数返回所需的大小;当给出的缓冲区足够时,返回成功,此时第4参数的值是没有参考价值的。
顺便提一下,调用函数失败时,看一下返回值是多少,根据返回值来分析错误原因。
 
 
 

回复

82

帖子

0

TA的资源

一粒金砂(初级)

5
 
原来是我的判断错了!
以下是正确的代码:
    ULONG nSize;
    ULONG pBuffer;
    NTSTATUS status;
        DbgPrint("GetHandleList\n");
       
    pBuffer =(ULONG)ExAllocatePool(PagedPool,0x1000);
    status = ZwQuerySystemInformation(SystemHandleInformation,(PVOID)pBuffer,0x1000,&nSize);
    ExFreePool((PVOID)pBuffer);   
    if(STATUS_INFO_LENGTH_MISMATCH == status)
    {
        pBuffer =(ULONG)ExAllocatePool(NonPagedPool,nSize);
        ZwQuerySystemInformation(SystemHandleInformation,(PVOID)pBuffer,nSize,NULL);
        return pBuffer;
    }
    else
        return 0;
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/6 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表