Windows生物识别框架示例umdf驱动程序:此设备无法启动。 (代码10)

问题描述 投票:1回答:1

我正在尝试运行Windows biometric driver sample,我对驱动程序开发很天真

我更改了inx文件中的硬件ID并重新构建了驱动程序项目,并在Windows 10 Pro版本1803上安装了生成的驱动程序。

我正在使用Fingerprint Morpho Device 1300 E3

驱动程序已成功安装但出现一个错误:

此设备无法启动。 (代码10)指定的请求不是目标设备的有效操作。

我查看了C:\Windows\INF\setupapi.dev.log文件

它显示了下一个警告:

     sig:                     {_VERIFY_FILE_SIGNATURE} 10:13:03.130
     sig:                          Key      = wudfbiousbsample.inf
     sig:                          FilePath = C:\WINDOWS\System32\DriverStore\Temp\{ee9ffca3-751f-0b4e-a7ac-dce2543d995e}\wudfbiousbsample.inf
     sig:                          Catalog  = C:\WINDOWS\System32\DriverStore\Temp\{ee9ffca3-751f-0b4e-a7ac-dce2543d995e}\biometrics.cat
!    sig:                          Verifying file against specific (valid) catalog failed.
!    sig:                          Error 0x800b0109: A certificate chain processed, but terminated in a root certificate which is not trusted by the trust provider.
!!!  dvi:                     Device not started: Device has problem: 0x0a (CM_PROB_FAILED_START), problem status: 0xc0000450.

但是我在本地计算机上的受信任的根证书颁发机构和受信任的发布者上安装了TestCertificate

我还检查了事件查看器:应用程序和服务日志> Microsoft \ Windows \ CodeIntegrity应用程序和服务日志> Microsoft \ Windows \ Biometrics

我尝试使用wdfverifier.exe following some videos from msdn进行调试,但进程未启动,因此无法调试:(

我确认Visual Studio没有签署EngineAdapter.dll插件文件,所以我禁用了驱动程序签名,并按照this paper手动执行。但我得到相同的错误代码10 :(

我还想知道错误代码10是否是预期的行为,因为没有实现EngineAdapter.dll的代码。

更新:我正在测试Windows 10 Pro版本1709虚拟机VMWare,我收到其他错误:

此设备无法正常工作,因为Windows无法加载此设备所需的驱动程序。 (代码31)

!!!  dvi:                     Device not started: Device has problem: 0x1f (CM_PROB_FAILED_ADD), problem status: 0xc0000001.

同样的警告:

     sig:           {_VERIFY_FILE_SIGNATURE} 17:19:01.646
     sig:                Key      = wudfbiousbsample.inf
     sig:                FilePath = C:\Windows\System32\DriverStore\Temp\{85323f79-3f5f-f84c-a52b-639b6ae57db1}\wudfbiousbsample.inf
     sig:                Catalog  = C:\Windows\System32\DriverStore\Temp\{85323f79-3f5f-f84c-a52b-639b6ae57db1}\biometrics.cat
!    sig:                Verifying file against specific (valid) catalog failed.
!    sig:                Error 0x800b0109: A certificate chain processed, but terminated in a root certificate which is not trusted by the trust provider.
     sig:           {_VERIFY_FILE_SIGNATURE exit(0x800b0109)} 17:19:01.661
     sig:           {_VERIFY_FILE_SIGNATURE} 17:19:01.676
     sig:                Key      = wudfbiousbsample.inf
     sig:                FilePath = C:\Windows\System32\DriverStore\Temp\{85323f79-3f5f-f84c-a52b-639b6ae57db1}\wudfbiousbsample.inf
     sig:                Catalog  = C:\Windows\System32\DriverStore\Temp\{85323f79-3f5f-f84c-a52b-639b6ae57db1}\biometrics.cat
     sig:                Success: File is signed in Authenticode(tm) catalog.
     sig:                Error 0xe0000241: The INF was signed with an Authenticode(tm) catalog from a trusted publisher.
     sig:           {_VERIFY_FILE_SIGNATURE exit(0xe0000241)} 17:19:01.708
     sto:      {DRIVERSTORE IMPORT VALIDATE: exit(0x00000000)} 17:19:01.739

完整的日志文件在这里setupapi.dev.log

我认为驱动程序没有加载,因为有关证书或错误的警告可能在其他地方。

如果有人可以给我一个小建议继续。我现在卡住了:(

非常感谢。

c++ wdk umdf wbf wbdi
1个回答
0
投票

一切都是在我能够安装我的生物识别驱动程序时开始的,但它显示了“黄色感叹号”和一般信息“此设备无法启动。(代码10)”

生物识别示例项目不包括如何使用Visual Studio正确签署EngineAdapter.dll的示例我发现this resource (page 33-34)其中显示如何在项目属性上签署EngineAdapter构建事件 - >构建后事件:

Command Line: signtool sign /v /ac "Path_to_cross_certificate_DigiCert Assured ID Root CA.crt" /tr http://timestamp.digicert.com /td sha256 /fd sha256 /f "path_to_my_certificate_file.pfx" /p mypassword "$(Platform)\$(ConfigurationName)\EngineAdapter.dll"
Use In Build: Yes

接下来This first video tutorial显示了使用WDK wdfverifier.exe中的工具调试umdf驱动程序的示例。我无法将调试器附加到我的驱动程序进程,因为该进程不存在。但是我可以在进程崩溃之前在启动时进行调试。

要使用wdfverifier.exe进行调试,我执行了以下步骤:

设置选项卡:选中“请求时自动启动用户模式调试器”选项,在输入“主机进程将等待”中指定15秒

首选项选项卡:选中“使用WinDbg”,然后

在设备管理器上禁用/启用我的设备

WinDbg启动,我可以检查我的驱动程序模块是否加载了下一个命令:

lm m *bio*
//the module is not loaded, use g commant to continue
g
//again see if the module was loaded
lm m *bio*
//module shows up, great!

现在我可以设置断点但在此之前我必须指定WinDbg其中是符号文件(* .pdb)和驱动程序的源代码以及下一个命令(如果构建包项目,路径可能不同,我是使用EngineAdapter项目引用构建WudfBioUsbSample:

.symfix
.srcpath+ C:\Users\myuser\Documents\Windows-driver-samples\biometrics\driver    
.sympath+ C:\Users\myuser\Documents\Windows-driver-samples\biometrics\driver\x64\Debug

.reload /f

接下来我可以设置一个断点:

//x command is used to search if the method exist
x WudfBioUsbSample!CBiometricDriver::*
x WudfBioUsbSample!CBiometricDevice::*
x WudfBioUsbSample!CBiometricDevice::OnGetAttributes
//examples of breakpoints
bp WudfBioUsbSample!CBiometricDriver::OnDeviceAdd
bp WudfBioUsbSample!CBiometricDevice::OnGetAttributes
bp WudfBioUsbSample!CBiometricDevice::CreateUsbIoTargets

CreateUsbIoTargets方法是错误显示的位置。 JinzhuXing在this github issue修正了这些错误

修复驱动程序代码并调试后,CreateUsbIoTargets方法运行正常

仍然向我展示了黄色感叹号,但这次错误发生在EngineAdapter.dll中。 EventViewer中显示下一个错误:应用程序和服务日志> Microsoft \ Windows \ Biometrics

模块的“引擎适配器”初始化例程失败,错误:0x80004001

EngineAdapter项目方法返回E_NOTIMPL我只是将其更改为返回S_OK而不是所有方法。生物识别单元成功创建。

此外,还使用Visual Studio调试Engine插件。以下是我遵循的步骤:

使用wdfverifier.exe将WinDbg附加到我的umdf驱动程序的进程并设置一个断点到OnGetAttributes方法(当我启动/重新启动Windows生物识别服务时调用此方法)此断点将使服务在调用EngineAdapter之前等待插件代码。

x WudfBioUsbSample!CBiometricDevice::OnGetAttributes
bp WudfBioUsbSample!CBiometricDevice::OnGetAttributes
g

重新启动或启动Windows生物识别服务(任务管理器 - >服务选项卡上的WbioSrvc)

复制进程ID(PID)

以管理员身份运行Visual Studio,打开WBDIsample项目

使用菜单调试 - >附加到进程...

输入以下值:

Connection Type: Windows User Mode Debugger
Connection Target: Localhost

Check "Show processes from all users" 

Filter by Process ID 
Select the process and Click Attach button.

在WbioQueryEngineInterface,EngineAdapterAttach,EngineAdapterDetach上设置断点sample implementation is on msdn

在WinDbg上运行命令g(Go)

g

在此之后,您可以在Visual Studio上调试插件的代码。

剩下的就是实现生物识别驱动程序的代码和设备的必要插件

© www.soinside.com 2019 - 2024. All rights reserved.