3067|2

67

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

U盘过滤驱动如何获取设备描述符? [复制链接]

    我想做一个U盘过滤驱动,先读取U盘的设备描述符,然后根据设备描述符中的某项禁用U盘,承蒙大家的帮助,禁用已实现。现在就是想要获取U盘的设备描述符。由于也是刚刚接触过滤驱动,在网上也没搜到相关资料,想在这里向大家请教几个问题:
    我的过滤驱动挂载在{36FC9E60-C465-11CF-8056-444553540000}下。
    1.在过滤驱动里获取U盘的设备描述符,在哪个例程里获取?是截获IRP_MJ_QUERY_INFORMATION这个IRP吗?
    2.如果是在IRP_MJ_QUERY_INFORMATION的派遣函数里获取,如何获取?我觉得应该是得到IRP_MJ_QUERY_INFORMATION发送出去后的返回值,如何得到这个返回值呢?
    3.需要构造USB请求包吗?如果需要构造的话,感觉就像是一个功能驱动而不是过滤驱动了?


最新回复

自己搞定了。 想向大家请教另一个问题: 如何修改U盘的设备描述符, 比如修改设备描述符里的iSerialNumber  详情 回复 发表于 2009-9-17 17:16
点赞 关注

回复
举报

80

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
我参考U盘驱动的代码,想构造一个URB,但是没有获取到设备描述符。
代码如下,大家给看看是什么错误

typedef struct tagDEVICE_EXTENSION {

        PDEVICE_OBJECT DeviceObject;                        // device object this extension belongs to

        PDEVICE_OBJECT LowerDeviceObject;                // next lower driver in same stack

        PDEVICE_OBJECT Pdo;                                                // the PDO

        IO_REMOVE_LOCK RemoveLock;

        } DEVICE_EXTENSION, *PDEVICE_EXTENSION;



NTSTATUS
ReadandSelectDescriptors( IN PDEVICE_OBJECT DeviceObject )
{
        KdPrint(("ReadandSelectDescriptors begin\n"));

    PURB                   urb;
    ULONG                  siz;
    NTSTATUS               ntStatus;
    PUSB_DEVICE_DESCRIPTOR deviceDescriptor;
   
    urb = NULL;
    deviceDescriptor = NULL;
       
    //Read the device descriptor       
    urb = (PURB)ExAllocatePool(NonPagedPool,  sizeof(struct _URB_CONTROL_DESCRIPTOR_REQUEST));       
    if(urb)
        {               
        siz = sizeof(USB_DEVICE_DESCRIPTOR);
        deviceDescriptor = (PUSB_DEVICE_DESCRIPTOR)ExAllocatePool(NonPagedPool, siz);               
        if(deviceDescriptor) //注意看一下
                {                       
            UsbBuildGetDescriptorRequest(
                                urb,
                                (USHORT) sizeof(struct _URB_CONTROL_DESCRIPTOR_REQUEST),
                                USB_DEVICE_DESCRIPTOR_TYPE,
                                0,
                                0,
                                deviceDescriptor,
                                NULL,
                                siz,
                                NULL);
                       
            ntStatus = CallUSBD(DeviceObject, urb);               
            if(NT_SUCCESS(ntStatus))
                        {
                ASSERT(deviceDescriptor->bNumConfigurations);
                //ntStatus = ConfigureDevice(DeviceObject);
                                KdPrint(("get deviceDescriptor success!"));
            }                       
            ExFreePool(urb);               
            ExFreePool(deviceDescriptor);
        }
        else
                {
                        ExFreePool(urb);
            ntStatus = STATUS_INSUFFICIENT_RESOURCES;
        }
    }
    else
        {       
        ntStatus = STATUS_INSUFFICIENT_RESOURCES;
    }
    return ntStatus;
}

NTSTATUS
CallUSBD(
                 IN PDEVICE_OBJECT DeviceObject,
                 IN PURB           Urb
                 )
{
    PIRP               irp;
    KEVENT             event;
    NTSTATUS           ntStatus;
    IO_STATUS_BLOCK    ioStatus;
    PIO_STACK_LOCATION nextStack;
    PDEVICE_EXTENSION  pdx;
       
    irp = NULL;
    pdx = (PDEVICE_EXTENSION)DeviceObject->DeviceExtension;
   
    //KeInitializeEvent(&event, NotificationEvent, FALSE);
       
    irp = IoBuildDeviceIoControlRequest(IOCTL_INTERNAL_USB_SUBMIT_URB,
                pdx->LowerDeviceObject,
                NULL,
                0,
                NULL,
                0,
                TRUE,
                &event,
                &ioStatus);
       
    if(!irp)
        {               
        KdPrint(("IoBuildDeviceIoControlRequest failed\n"));
        return STATUS_INSUFFICIENT_RESOURCES;
    }
       
    nextStack = IoGetNextIrpStackLocation(irp);
    ASSERT(nextStack != NULL);
    nextStack->Parameters.Others.Argument1 = Urb;

//         IoSetCompletionRoutine(irp, (PIO_COMPLETION_ROUTINE) GetDescriptorCompletionRoutine,
//                         (PVOID) pdx, TRUE, TRUE, TRUE);

    ntStatus = IoCallDriver(pdx->LowerDeviceObject, irp);       
    if(ntStatus == STATUS_PENDING)
        {               
        //KeWaitForSingleObject(&event, Executive, KernelMode, FALSE, NULL);               
        ntStatus = ioStatus.Status;
    }
    return ntStatus;
}
 
 

回复

75

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
自己搞定了。

想向大家请教另一个问题:
如何修改U盘的设备描述符,
比如修改设备描述符里的iSerialNumber
 
 
 

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

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

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

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

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

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

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