2017-03-28 38 views
0

我们有许多客户使用的硬件设备。我们支持Windows 7-10操作系统。使用此设备,包含驱动程序和软件。该设备是在中国内置的,他们最终使用了一个Cypress USB驱动程序。 .inf文件可以在下面找到。然后中国公司在.inf文件中添加了一些自己设备的参考文件,这些文件通过结合其软件神奇地使其工作。为需要的.inf文件驱动程序创建HCK和HLK测试?

我的背景不是C++或任何硬件相关的开发。现在,我们有客户在驱动程序安装并插入时收到代码52错误。

Windows无法验证此文件的数字签名。最近的硬件或软件更改可能安装了签名不正确或损坏的文件,或者可能是未知来源的恶意软件。

所以经过大量的谷歌搜索之后,似乎这家中国公司并没有跟上司机的最新标准。较新的设备启用了安全引导,可以阻止未正确签名的驱动程序。

现在我想知道的几件事情:

  • 将让我的司机,虽然需要的各种HCK/HLK/WLK测试?我的驱动程序只是一个.inf文件,.sys文件和一个生成的.cat文件。
  • 会生成一个.cab文件与makecab是否足够?
  • 我的驱动程序实际上是内核模式驱动程序还是用户模式驱动程序?
  • 这当然会被测试:但是用EV证书签署文件cat是否已经解决了这个问题?

虽然HCK和HLK测试似乎对于简单的.inf文件有很多工作。虽然准则非常明确,但我不完全确定在我的方案中是否有特定的事情我不需要做。

.inf文件代码:

; Installation INF for the Cypress Generic USB Driver for Windows 2000 
; Processor support for x86 based platforms. 
; 
; (c) Copyright 2011 Cypress Semiconductor Corporation 
; 

[Version] 
Signature="$WINDOWS NT$" 
Class=USB 
ClassGUID={36FC9E60-C465-11CF-8056-444553540000} 
provider=%CYUSB_Provider% 
CatalogFile=CYUSB.cat 
DriverVer=10/17/2011,3.4.7.000 

[SourceDisksNames] 
1=%CYUSB_Install%,,, 

[SourceDisksFiles] 
CYUSB.sys = 1 

[DestinationDirs] 
CYUSB.Files.Ext = 10,System32\Drivers 

[ControlFlags] 
ExcludeFromSelect = * 

[Manufacturer] 
%CYUSB_Provider%=Device,NT,NTx86,NTamd64 

;for all platforms 
[Device] 
;%VID_XXXX&PID_XXXX.DeviceDesc%=CyUsb, USB\VID_XXXX&PID_XXXX 


;for windows 2000 non intel platforms 
[Device.NT] 
;%VID_XXXX&PID_XXXX.DeviceDesc%=CyUsb, USB\VID_XXXX&PID_XXXX 


;for x86 platforms 
[Device.NTx86] 
;%VID_XXXX&PID_XXXX.DeviceDesc%=CyUsb, USB\VID_XXXX&PID_XXXX 


;for x64 platforms 
[Device.NTamd64] 
;%VID_XXXX&PID_XXXX.DeviceDesc%=CyUsb, USB\VID_XXXX&PID_XXXX 


[CYUSB] 
CopyFiles=CYUSB.Files.Ext 
AddReg=CyUsb.AddReg 

[CYUSB.HW] 
AddReg=CYUSB.AddReg.Guid 

[CYUSB.Services] 
Addservice = CYUSB,2,CYUSB.AddService 

[CYUSB.NT] 
CopyFiles=CYUSB.Files.Ext 
AddReg=CyUsb.AddReg 

[CYUSB.NT.HW] 
AddReg=CYUSB.AddReg.Guid 

[CYUSB.NT.Services] 
Addservice = CYUSB,2,CYUSB.AddService 


[CYUSB.NTx86] 
CopyFiles=CYUSB.Files.Ext 
AddReg=CyUsb.AddReg 

[CYUSB.NTx86.HW] 
AddReg=CYUSB.AddReg.Guid 

[CYUSB.NTx86.Services] 
Addservice = CYUSB,2,CYUSB.AddService 

[CYUSB.NTamd64] 
CopyFiles=CYUSB.Files.Ext 
AddReg=CyUsb.AddReg 

[CYUSB.NTamd64.HW] 
AddReg=CYUSB.AddReg.Guid 

[CYUSB.NTamd64.Services] 
Addservice = CYUSB,2,CYUSB.AddService 


[CYUSB.AddReg] 
; Deprecating - do not use in new apps to identify a CYUSB driver 
HKR,,DevLoader,,*ntkern 
HKR,,NTMPDriver,,CYUSB.sys 
; You may optionally include a check for DriverBase in your application to check for a CYUSB driver 
HKR,,DriverBase,,CYUSB.sys 
HKR,"Parameters","MaximumTransferSize",0x10001,4096 
HKR,"Parameters","DebugLevel",0x10001,2 
HKR,,FriendlyName,,%CYUSB_Description% 

[CYUSB.AddService] 
DisplayName = %CYUSB_Description% 
ServiceType = 1     ; SERVICE_KERNEL_DRIVER 
StartType  = 3     ; SERVICE_DEMAND_START 
ErrorControl = 1     ; SERVICE_ERROR_NORMAL 
ServiceBinary = %10%\System32\Drivers\CYUSB.sys 
AddReg   = CYUSB.AddReg 
LoadOrderGroup = Base 

[CYUSB.Files.Ext] 
CYUSB.sys 

[CYUSB.AddReg.Guid] 
HKR,,DriverGUID,,%CYUSB.GUID% 

[Strings] 
CYUSB_Provider = "Cypress" 
CYUSB_Company  = "Cypress Semiconductor Corporation" 
CYUSB_Description = "Cypress Generic USB Driver" 
CYUSB_DisplayName = "Cypress USB Generic" 
CYUSB_Install  = "Cypress CYUSB Driver Installation Disk" 
VID_XXXX&PID_XXXX.DeviceDesc="Cypress USB Generic Driver (3.4.7.000)" 
CYUSB.GUID="{AE18AA60-7F6A-11d4-97DD-00010229B959}" 
CYUSB_Unused  = "." 

回答

0

微软不断增加的障碍,你可能要签在他们dev portal now and you need a EV cert.注册。在执行安全启动时,干净安装和升级之间也有区别!

我建议你读/加入OSR mailing list,它具有multiplethreadsdealingwith的Windows 10 & SHA2签署的斗争。

Their blog也可能有用。

+0

嗨,谢谢你的回复。我已经注册了一个EV证书,我将能够进行HCK测试,所以线程和文章并不真正相关。我只是想知道HCK/HLK/WLK测试是否可以用.inf文件完成。请参阅我提到的其他问题。 – CularBytes