winusb设备驱动程序应用程序未被执行

时间:2014-07-01 19:44:02

标签: visual-studio-2013 usb device-driver winusb

我正在开发WinUSB应用程序,它使用通用USB设备通过中断端点进行基本读取。设备驱动程序安装正常。但是当设备连接时,应用程序t_main函数根本没有被触发。它仅在visual studio调试器中触发并正常工作。

我在这里缺少什么? Winusbtrace检测到设备并记录WinUSB_InitControlPipe和WinUSB_DOEntry的进入和退出。 Windows / inf / * .log中的日志没有帮助,因为它们只记录安装。我可以参考的任何其他日志?

我真的很感激任何投入。提前致谢。 下面是我的INF文件,我在Win 7 x64上使用visual studio 2013

;
; Test.inf
;
; Installs WinUsb
;

[Version]
Signature = "$Windows NT$"
Class     = USBDevice
ClassGUID = {88BAE032-5A81-49f0-BC3D-A4FF138216D6}
Provider = %ManufacturerName%
CatalogFile=Test.cat

; ========== Manufacturer/Models sections ===========

[Manufacturer]
%ManufacturerName% = Standard,NT$ARCH$

[Standard.NT$ARCH$]
%DeviceName% =USB_Install, USB\VID_0457&PID_0500

; ========== Class definition ===========

[ClassInstall32]
AddReg = ClassInstall_AddReg

[ClassInstall_AddReg]
HKR,,,,%ClassName%
HKR,,NoInstallClass,,1
HKR,,IconPath,%REG_MULTI_SZ%,"%systemroot%\system32\setupapi.dll,-20"
HKR,,LowerLogoVersion,,5.2

; =================== Installation ===================

[USB_Install]
Include=winusb.inf
Needs=WINUSB.NT

[USB_Install.Services]
Include=winusb.inf
AddService=WinUsb,0x00000002,WinUsb_ServiceInstall

[WinUsb_ServiceInstall]
DisplayName     = %WinUsb_SvcDesc%
ServiceType     = 1
StartType       = 3
ErrorControl    = 1
ServiceBinary   = %12%\WinUSB.sys

[USB_Install.HW]
AddReg=Dev_AddReg

[Dev_AddReg]
; By default, USBDevice class uses iProduct descriptor to name the device in
; Device Manager on Windows 8 and higher.
; Uncomment for this device to use %DeviceName% on Windows 8 and higher:
;HKR,,FriendlyName,,%DeviceName%
HKR,,DeviceInterfaceGUIDs,0x10000,"{2753294b-5128-4a42-be6a-d7818234ea9c}"

[USB_Install.Wdf]
KmdfService=WINUSB, WinUsb_Install

[WinUsb_Install]
KmdfLibraryVersion=1.9

[USB_Install.CoInstallers]
AddReg=CoInstallers_AddReg
CopyFiles=CoInstallers_CopyFiles

[CoInstallers_AddReg]
HKR,,CoInstallers32,0x00010000,"WdfCoInstaller$KMDFCOINSTALLERVERSION$.dll,WdfCoInstaller"

[CoInstallers_CopyFiles]
WdfCoInstaller$KMDFCOINSTALLERVERSION$.dll

[DestinationDirs]
CoInstallers_CopyFiles=11

; ================= Source Media Section =====================

[SourceDisksNames]
1 = %DiskName%

[SourceDisksFiles]
WdfCoInstaller$KMDFCOINSTALLERVERSION$.dll=1

; =================== Strings ===================

[Strings]
ManufacturerName="Test"
ClassName="Universal Serial Bus devices"
DiskName="Device Installation Disk"
WinUsb_SvcDesc="WinUSB Driver"
DeviceName="Test Device"
REG_MULTI_SZ = 0x00010000

1 个答案:

答案 0 :(得分:1)

winusb应用程序不是驱动程序。你必须告诉它何时运行。如果您尝试在插入设备时运行应用程序,则可以尝试将应用程序绑定到此帖子中描述的连接事件:https://superuser.com/questions/219401/starting-scheduled-task-by-detecting-connection-of-usb-drive