默认会自动探测 WDK 所在环境,当然也可以指定 WDK sdk 环境目录:
```sh
$ xmake f --wdk="G:\Program Files\Windows Kits\10" -c
$ xmake
```
更多详情可以参考:[#159](https://github.com/xmake-io/xmake/issues/159)
相关完整工程 example 见:[WDK examples](https://github.com/xmake-io/xmake/tree/master/tests/projects/windows/driver)
## umdf 驱动程序{#umdf}
## kmdf 驱动程序 {#kmdf}
## wdm 驱动程序 {#wdm}
## 生成驱动包 {#package}
可以通过以下命令生成.cab驱动包:
```sh
$ xmake [p|package]
$ xmake [p|package] -o outputdir
```
输出的目录结构如下:
```
- drivers
- sampledsm
- debug/x86/sampledsm.cab
- release/x64/sampledsm.cab
- debug/x86/sampledsm.cab
- release/x64/sampledsm.cab
```
## 驱动签名 {#driver-sign}
默认编译禁用签名,可以通过 `set_values("wdk.sign.mode", ...)` 设置签名模式来启用签名。
### 测试签名 {#test-sign}
测试签名一般本机调试时候用,可以使用 xmake 自带的 test 证书来进行签名,例如:
```lua
target("msdsm")
add_rules("wdk.driver", "wdk.env.wdm")
set_values("wdk.sign.mode", "test")
set_values("wdk.sign.digest_algorithm", "sha256")
```
不过这种情况下,需要用户手动在管理员模式下,执行一遍:`$xmake l utils.wdk.testcert install`,来生成和注册test证书到本机环境。
这个只需要执行一次就行了,后续就可以正常编译和签名了。
当然也可以使用本机已有的有效证书去签名。
从sha1来选择合适的证书进行签名:
```lua
target("msdsm")
add_rules("wdk.driver", "wdk.env.wdm")
set_values("wdk.sign.mode", "test")
set_values("wdk.sign.thumbprint", "032122545DCAA6167B1ADBE5F7FDF07AE2234AAA")
set_values("wdk.sign.digest_algorithm", "sha256")
```
从store/company来选择合适的证书进行签名:
```lua
target("msdsm")
add_rules("wdk.driver", "wdk.env.wdm")
set_values("wdk.sign.mode", "test")
set_values("wdk.sign.store", "PrivateCertStore")
set_values("wdk.sign.company", "tboox.org(test)")
set_values("wdk.sign.digest_algorithm", "sha256")
```
### 正式签名 {#sign}
通过指定对应的正式签名证书文件进行签名:
```lua
target("msdsm")
add_rules("wdk.driver", "wdk.env.wdm")
set_values("wdk.sign.mode", "release")
set_values("wdk.sign.company", "xxxx")
set_values("wdk.sign.certfile", path.join(os.projectdir(), "xxxx.cer"))
set_values("wdk.sign.digest_algorithm", "sha256")
```
## 生成低版本驱动 {#low-version-driver}
如果想在wdk10环境编译生成 win7, win8 等低版本系统支持的驱动,可以通过设置 `wdk.env.winver` 来切换系统版本:
```lua
set_values("wdk.env.winver", "win10")
set_values("wdk.env.winver", "win10_rs3")
set_values("wdk.env.winver", "win81")
set_values("wdk.env.winver", "win8")
set_values("wdk.env.winver", "win7")
set_values("wdk.env.winver", "win7_sp1")
set_values("wdk.env.winver", "win7_sp2")
set_values("wdk.env.winver", "win7_sp3")
```
我们也可以手动指定编译的目标程序支持的windows版本:
```sh
$ xmake f --wdk_winver=[win10_rs3|win8|win7|win7_sp1]
$ xmake
```