当前位置: 首页 > news >正文

window 显示驱动开发-处理 E_INVALIDARG 返回值

通常,用户模式显示驱动程序不能通过返回E_INVALIDARG来使任何函数失败。 但是,如果用户模式显示驱动程序由于驱动程序中的编程错误或操作系统 () 中运行的恶意代码而调用 Microsoft Direct3D 运行时提供的函数 之一时收到E_INVALIDARG返回值,则驱动程序必须在运行时调用其中一个驱动程序函数后,将E_INVALIDARG返回到 Direct3D 运行时。 否则,用户模式显示驱动程序绝不应将E_INVALIDARG返回到 Direct3D 运行时。

1. 核心规则

  • 禁止主动返回 E_INVALIDARG

用户模式驱动(UMD)不得在任何函数中主动返回 E_INVALIDARG,即使参数明显无效(如 NULL 指针、越界值)。

例外:仅当 Direct3D 运行时本身返回 E_INVALIDARG 时,UMD 可传递此错误。

  • 必须传递运行时返回的 E_INVALIDARG

如果 UMD 调用运行时提供的回调函数(如 pfnAllocateCb)时收到 E_INVALIDARG,必须将错误 原样返回 给运行时。

2. 适用场景与示例

(1) 合法传递 E_INVALIDARG 的场景

HRESULT APIENTRY CreateResource(D3D10DDI_HDEVICE hDevice,CONST D3D10DDIARG_CREATERESOURCE* pArgs
) {// 调用运行时提供的函数HRESULT hr = pDeviceFuncs->pfnAllocateCb(hDevice, &allocInfo);if (hr == E_INVALIDARG) {return hr; // 必须传递运行时的E_INVALIDARG}// 其他错误处理...
}

(2) 禁止返回 E_INVALIDARG 的场景

HRESULT APIENTRY SetVertexShader(D3D10DDI_HDEVICE hDevice,D3D10DDI_HSHADER hShader
) {if (hShader == NULL) {// 错误!即使参数无效,也不能返回E_INVALIDARGreturn S_OK; // 应静默处理或返回其他错误(如E_FAIL)}
}

3. 设计原理

  • 安全性优先:防止恶意代码利用驱动返回的 E_INVALIDARG 探测系统漏洞。
  • 稳定性保障:避免应用因参数检查不严而崩溃。
  • 调试友好性:强制驱动内部处理无效参数,而非依赖运行时拦截。

4. 异常情况处理

若驱动因自身逻辑错误或恶意代码触发 E_INVALIDARG:

  • 记录错误日志:通过 ETW 或调试输出标记异常。
  • 安全降级:返回 E_FAIL 或 S_OK(视场景而定)。
  • 断言调试:在 Debug 版本中触发断言(如 ASSERT(FALSE))。

示例:

HRESULT HandleMaliciousCall() {if (IsMaliciousInput()) {DebugPrint("警告:检测到恶意参数");return E_FAIL; // 避免返回E_INVALIDARG}return S_OK;
}

5. WHCK 认证要求

测试项验证目标测试方法
Device.Graphics.UMD.InvalidArgHandling驱动是否违规返回 E_INVALIDARG注入无效参数调用所有 DDI 函数。
Device.Graphics.UMD.ErrorPropagation运行时返回的 E_INVALIDARG 是否正确传递。模拟运行时返回 E_INVALIDARG

6. 开发者注意事项

  • 参数验证:即使不返回 E_INVALIDARG,仍需验证参数安全性(如指针解引用前检查 NULL)。
  • 错误替代方案:使用 E_FAIL、E_OUTOFMEMORY 或 E_NOTIMPL 替代 E_INVALIDARG。
  • 测试覆盖:使用 WEX 工具测试非法参数场景。

7. 总结

绝对禁止:UMD 主动返回 E_INVALIDARG(除非传递运行时的错误)。

安全实践:对无效参数静默处理或返回非特异性错误。

认证关键:违反此规则将导致 WHCK 测试失败。

相关文章:

  • Vert.x学习笔记-什么是Context
  • Django数据库连接报错 django.db.utils.NotSupportedError: MySQL 8 or later is required
  • 系统思考:心智模式与业务创新
  • 增程与插混技术战略
  • node-DeepResearch开源ai程序用于深入调查查询,继续搜索、阅读网页、推理,直到找到答案
  • VMware安装Ubuntu实战分享大纲
  • 类和对象(中1)
  • 在 Linux 中让 ​​Gunicorn​​ 在后台运行(作为守护进程),有几种常用方法:
  • 论文笔记:Towards Explainable Traffic Flow Prediction with Large Language Models
  • Python爬虫实战:抓取百度15天天气预报数据
  • [神经网络]使用olivettiface数据集进行训练并优化,观察对比loss结果
  • Android 插件化
  • More SQL(Focus Subqueries、Join)
  • python完成批量复制Excel文件并根据另一个Excel文件中的名称重命名
  • 高效合并 Excel 表格实用工具
  • c++第三天(对象与构造函数)
  • MySQL 数据迁移Postgresql(openGuass) 之 pg_chameleon
  • 【Python办公】Excel简易透视办公小工具
  • EasyExcel使用导出模版后设置 CellStyle失效问题解决
  • C++ 异步编程与网络编程:工具、协议的层次与协同
  • 江西专业南昌网站建设/花都网站建设公司
  • 怎么区分模板网站/百度sem运营
  • wordpress+centos6/福州百度seo代理
  • 做网站要备案/网络营销方案
  • 天气预报网站怎么做/深圳优化怎么做搜索
  • 苏州网站推广电话/谷歌浏览器手机版免费官方下载