4626|4

69

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

nt式usb过滤驱动,无法拦截到write操作.Windows xp [复制链接]

主要代码:
Windows xp
extern "C" NTSTATUS DriverEntry(IN PDRIVER_OBJECT    DriverObject,
                                IN PUNICODE_STRING    RegistryPath
                                )
{
    NTSTATUS    status;
    DriverObject->DriverUnload = DriverUnload;

    for(ULONG i = 0; i < IRP_MJ_MAXIMUM_FUNCTION; i++)
    {
        DriverObject->MajorFunction = DispatchGeneral;
    }
    DriverObject->MajorFunction[IRP_MJ_WRITE]    = DispatchWrite;
    DriverObject->MajorFunction[IRP_MJ_SCSI]    = DispatchWrite;  // 加了这句后仍然不能过滤掉写入
    DriverObject->MajorFunction[IRP_MJ_POWER]    = OnPower;
    DriverObject->MajorFunction[IRP_MJ_PNP]        = OnPnp;

                    // attach到usb驱动上
    status = AttachUsbDriver(DriverObject);

    return status;
}

// 打算用这个来处理写入请求.结果不工作.
NTSTATUS DispatchWrite(IN PDEVICE_OBJECT    DeviceObject,
                       IN PIRP                Irp)
{
    KdPrint(("Write!\n"));
    return STATUS_ACCESS_DENIED;
}


// 这个是attach到上层驱动,用device tree看了下,能正常工作.
NTSTATUS AttachUsbDriver(IN PDRIVER_OBJECT    DriverObject)
{
    NTSTATUS        status;
    UNICODE_STRING    ustrName;
    PDRIVER_OBJECT    usbDriver;
    PDEVICE_OBJECT    usbDevice;
    PDEVICE_OBJECT    pfltDevice;
    PDEVICE_OBJECT    pLowerDevice;
    PDEVICE_EXTENSION    pdx;

    RtlInitUnicodeString(&ustrName, L"\\Driver\\USBSTOR");
   
    status = ObReferenceObjectByName(&ustrName, OBJ_CASE_INSENSITIVE,
                                        NULL, 0, IoDriverObjectType,
                                        KernelMode, NULL, (PVOID*)&usbDriver);
    if(!NT_SUCCESS(status))
    {
        KdPrint(("Couldn't get usb driver\n"));
        return status;
    }

    usbDevice = usbDriver->DeviceObject;
    // 遍历usb设备对象.
    while(NULL != usbDevice)
    {
        status = IoCreateDevice(DriverObject, sizeof(DEVICE_EXTENSION), NULL,
                                usbDevice->DeviceType, usbDevice->Characteristics,
                                FALSE, &pfltDevice);

        if(!NT_SUCCESS(status))
        {
            ObDereferenceObject(usbDriver);
            KdPrint(("Create fltdevice failed!\n"));
            return status;
        }
        // 附加到上层驱动.
        pLowerDevice = IoAttachDeviceToDeviceStack(pfltDevice, usbDevice);
        if(NULL == pLowerDevice)
        {
            ObDereferenceObject(usbDriver);
            KdPrint(("attach usb device error!\n"));
            IoDeleteDevice(pfltDevice);
            pfltDevice = NULL;
            return STATUS_UNSUCCESSFUL;
        }
        pdx = (PDEVICE_EXTENSION)(pfltDevice->DeviceExtension);
        InitDevExt(pdx, pLowerDevice, pfltDevice, usbDevice);         // 这个函数将有用的信息放到device_extension结构中了.
                                          // 设置属性跟标志位
        pfltDevice->DeviceType        = pLowerDevice->DeviceType;
        pfltDevice->Characteristics    = pLowerDevice->Characteristics;
        pfltDevice->StackSize        = pLowerDevice->StackSize + 1;
        pfltDevice->Flags            |= pLowerDevice->Flags & (DO_BUFFERED_IO | DO_DIRECT_IO | DO_POWER_PAGABLE);
        pfltDevice->Flags            = pfltDevice->Flags & (~DO_DEVICE_INITIALIZING);

        // 移动到下个设备
        usbDevice = usbDevice->NextDevice;
    }
   
    ObDereferenceObject(usbDriver);
    KdPrint(("Attach OK!\n"));
    return STATUS_SUCCESS;
}

网上也搜了下,结果没什么收获,
看了下ms的例子,是用wdm写的.attach到低层的驱动.
能过滤到pnp例程.却不能过滤读写?
是不是attach到上层驱动就不可以过滤还是???
搞了一整天,快吐血了.......

最新回复

剛好也在學習 關注一下  详情 回复 发表于 2010-6-7 13:50
点赞 关注

回复
举报

96

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
搞了两天,快崩溃了...
谁有例子,传个上来,感激涕零...
 
 

回复

71

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
自己顶
 
 
 

回复

59

帖子

0

TA的资源

一粒金砂(初级)

4
 
没人回啊...晕死..
 
 
 

回复

84

帖子

0

TA的资源

一粒金砂(初级)

5
 
剛好也在學習
關注一下
 
 
 

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

查找数据手册?

EEWorld Datasheet 技术支持

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

 
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
快速回复 返回顶部 返回列表