window 显示驱动开发-配置内存段类型
视频内存管理器(VidMm)和显示硬件仅支持某些类型的内存段。 因此,内核模式显示微型端口驱动程序(KMD)只能配置这些类型的段。
KMD 可以配置内存空间段和光圈空间段,其中不同:
- 内存空间段由保存分配位的介质组成。
- 光圈空间段是虚拟地址空间。
分配内存空间段中的范围时,会分配实际内存。 分配光圈空间段中的范围时,虚拟地址空间将重定向到独立于视频内存池或系统内存分配的物理页面。
KMD 可以配置以下类型的内存段:
- 线性内存空间段
- 线性光圈空间段
- AGP 类型光圈空间段
1. 内存空间段(Memory Space Segments)
特点
- 直接分配物理内存:分配此类段中的资源时,VidMm 会直接分配 实际的视频内存(VRAM)或系统内存。
- 介质绑定:内存的物理介质(如显存芯片)与段绑定,分配即占用实际资源。
- 适用场景:需要高性能、低延迟的资源(如渲染目标、纹理)。
子类型
(1) 线性内存空间段(Linear Memory Space Segment)
连续物理地址:内存以线性方式排列,适合需要连续内存的操作(如 DMA 传输)。
典型用途:
- 帧缓冲区(Frame Buffer)
- 深度/模板缓冲区
示例配置(DXGK_SEGMENTDESCRIPTOR):
{.Flags = DXGK_SEGMENT_FLAGS_VIDEO_MEMORY | DXGK_SEGMENT_FLAGS_LINEAR,.SegmentId = 1, // 显存段.BaseAddress = 0x80000000, // GPU 物理地址.Size = 0x40000000, // 1GB
}
2. 光圈空间段(Aperture Space Segments)
特点
虚拟地址重定向:分配此类段中的资源时,VidMm 仅分配 虚拟地址范围,实际物理内存可能来自其他池(如系统内存)。
动态映射:物理内存可按需映射到虚拟地址(类似 CPU 页表)。
适用场景:
- CPU 频繁访问的资源(如动态顶点缓冲区)
- 需要灵活内存管理的场景
子类型
(1) 线性光圈空间段(Linear Aperture Space Segment)
虚拟地址连续:虚拟地址线性连续,但物理内存可能不连续(通过页表映射)。
典型用途:)
- 共享系统内存资源
- 分页池(Pageable Memory
示例配置:
{.Flags = DXGK_SEGMENT_FLAGS_SYSTEM_MEMORY | DXGK_SEGMENT_FLAGS_LINEAR,.SegmentId = 2, // 系统内存光圈.BaseAddress = 0x00000000, // CPU 物理地址.Size = 0x20000000, // 512MB
}
(2) AGP 类型光圈空间段(AGP-style Aperture Space Segment)
- 历史兼容性:模拟传统 AGP(加速图形端口)行为,支持 非一致性内存访问(NUMA)。
- 物理内存分散:允许物理内存分散在多个位置(如部分在显存、部分在系统内存)。
- 现代替代方案:在 PCIe 时代较少使用,部分驱动为兼容性保留。
示例配置
{.Flags = DXGK_SEGMENT_FLAGS_SYSTEM_MEMORY | DXGK_SEGMENT_FLAGS_AGP,.SegmentId = 3,.BaseAddress = 0xC0000000, // 虚拟地址基址.Size = 0x10000000, // 256MB
}
3. 关键区别对比
特性 | 内存空间段 | 光圈空间段 |
---|---|---|
物理内存分配 | ✅ 立即分配 | ❌ 仅分配虚拟地址 |
地址连续性 | 必须连续(线性段) | 可非连续(支持分页) |
性能 | 高(直接访问显存) | 较低(需地址转换) |
CPU 访问 | 通常不可见(除非标记为共享) | 可直接访问(系统内存段) |
典型用途 | 纹理、渲染目标 | 动态缓冲区、共享资源 |
4. 驱动开发注意事项
(1) 段类型选择
- 优先使用内存空间段:对性能敏感的资源(如渲染目标)应分配在显存段。
- 光圈段的灵活性:需频繁 CPU 写入的资源(如动态顶点数据)适合系统内存光圈段。
(2) 混合段配置
多段共存:KMD 可同时配置显存段和系统内存光圈段,例如:
DXGK_SEGMENTDESCRIPTOR Segments[] = {{ /* 显存段 */ },{ /* 系统内存光圈段 */ },{ /* AGP 段(可选) */ }
};
(3) 硬件限制
GPU 架构依赖:某些 GPU 可能不支持 AGP 段(需查阅硬件手册)。
地址对齐:线性段需满足硬件对齐要求(如 4KB 或 64KB)。
5. 典型问题排查
问题 | 可能原因 | 解决方案 |
---|---|---|
分配失败(STATUS_GRAPHICS_INSUFFICIENT_DMA_BUFFER) | 线性段空间不足 | 增加段大小或优化资源布局。 |
CPU 访问性能差 | 误用显存段存储 CPU 频繁写数据 | 改用系统内存光圈段。 |
GPU 访问违例 | AGP 段物理内存未正确映射 | 检查 DxgkDdiBuildPagingBuffer 实现。 |
6. 总结
- 内存空间段:直接管理物理内存(显存/系统内存),适合高性能需求。
- 光圈空间段:虚拟地址映射,灵活支持动态资源和 CPU 访问。
- KMD 配置规则:
- 必须根据硬件能力选择段类型。
- 显存段优先用于 GPU 高频访问资源。
通过合理配置段类型,驱动程序可以平衡性能与灵活性,满足复杂图形应用的需求。
相关文章:
window 显示驱动开发-配置内存段类型
视频内存管理器(VidMm)和显示硬件仅支持某些类型的内存段。 因此,内核模式显示微型端口驱动程序(KMD)只能配置这些类型的段。 KMD 可以配置内存空间段和光圈空间段,其中不同: 内存空间段由保存…...

Modbus RTU 详解 + FreeMODBUS移植(附项目源码)
文章目录 前言一、Modbus RTU1.1 通信方式1.2 模式特点1.3 数据模型1.4 常用功能码说明1.5 异常响应码1.6 通信帧格式1.6.1 示例一:读取保持寄存器(功能码 0x03)1.6.2 示例二:写单个线圈(功能码 0x05)1.6.3…...

对称加密算法(AES、ChaCha20和SM4)Python实现——密码学基础(Python出现No module named “Crypto” 解决方案)
文章目录 一、对称加密算法基础1.1 对称加密算法的基本原理1.2 对称加密的主要工作模式 二、AES加密算法详解2.1 AES基本介绍2.2 AES加密过程2.3 Python中实现AES加密Python出现No module named “Crypto” 解决方案 2.4 AES的安全考量 三、ChaCha20加密算法3.1 ChaCha20基本介…...
JWT原理及工作流程详解
JSON Web Token(JWT)是一种开放标准(RFC 7519),用于在各方之间安全传输信息。其核心原理是通过结构化、签名或加密的JSON对象实现无状态身份验证和授权。以下是JWT的工作原理和关键组成部分: 1. JWT结构 J…...

【软件设计师:存储】16.计算机存储系统
一、主存储器 存储器是计算机系统中的记忆设备,用来存放程序和数据。 计算机中全部信息,包括输入的原始数据、计算机程序、中间运 行结果和最终运行结果都保存在存储器中。 存储器分为: 寄存器Cache(高速缓冲存储器)主存储器辅存储器一、存储器的存取方式 二、存储器的性…...
【Part 2安卓原生360°VR播放器开发实战】第三节|实现VR视频播放与时间轴同步控制
《VR 360全景视频开发》专栏 将带你深入探索从全景视频制作到Unity眼镜端应用开发的全流程技术。专栏内容涵盖安卓原生VR播放器开发、Unity VR视频渲染与手势交互、360全景视频制作与优化,以及高分辨率视频性能优化等实战技巧。 📝 希望通过这个专栏&am…...

WebRTC通信原理与流程
1、服务器与协议相关 1.1 STUN服务器 图1.1.1 STUN服务器在通信中的位置图 1.1.1 STUN服务简介 STUN(Session Traversal Utilities for NAT,NAT会话穿越应用程序)是一种网络协议,它允许位于NAT(或多重 NAT)…...

Java版ERP管理系统源码(springboot+VUE+Uniapp)
ERP系统是企业资源计划(Enterprise Resource Planning)系统的缩写,它是一种集成的软件解决方案,用于协调和管理企业内各种关键业务流程和功能,如财务、供应链、生产、人力资源等。它的目标是帮助企业实现资源的高效利用…...

Redis总结(六)redis持久化
本文将简单介绍redis持久化的两种方式 redis提供了两种不同级别的持久化方式: RDB持久化方式能够在指定的时间间隔能对你的数据进行快照存储.AOF持久化方式记录每次对服务器写的操作,当服务器重启的时候会重新执行这些命令来恢复原始的数据,AOF命令以redis协议追加保…...
使用FastAPI微服务在AWS EKS中构建上下文增强型AI问答系统
系统概述 本文介绍如何使用FastAPI在AWS Elastic Kubernetes Service (EKS)上构建一个由多个微服务组成的AI问答系统。该系统能够接收用户输入的提示(prompt),通过调用其他微服务从AWS ElastiCache on Redis和Amazon DynamoDB获取相关上下文,然后利用AW…...

PMIC电源管理模块的PCB设计
目录 PMU模块简介 PMU的PCB设计 PMU模块简介 PMIC(电源管理集成电路)是现代电子设备的核心模块,负责高效协调多路电源的转换、分配与监控。它通过集成DC-DC降压/升压、LDO线性稳压、电池充电管理、功耗状态切换等功能,替代传统分…...
正大视角下的结构交易节奏:如何借助数据捕捉关键转折
正大视角下的结构交易节奏:如何借助数据捕捉关键转折 在日常的交易结构研究中,节奏与分型常常被误解为“预测工具”,实则更应作为状态识别的参考。正大团队在模型演化过程中提出了“节奏-结构对齐”的分析方式,通过数据驱动来判断…...

华为云Flexus+DeepSeek征文|DeepSeek-V3商用服务开通教程
目录 DeepSeek-V3/R1商用服务开通使用感受 DeepSeek-V3/R1商用服务开通 1、首先需要访问ModelArts Studio_MaaS_大模型即服务_华为云 2、在网站右上角登陆自己的华为云账号,如果没有华为云账号的话,则需要自己先注册一个。 3、接着点击ModelArts Stu…...
STM32F103RC中ADC1和ADC2通道复用
以下是STM32F103RC中ADC1和ADC2通道复用的示意图及文字说明,帮助直观理解这种共享关系: ADC1/ADC2引脚复用示意图 GPIO引脚 ADC1通道 ADC2通道 ┌─────────┐ ┌─────────┐ ┌─────────┐ │ PA0 ├─…...

Qt—鼠标移动事件的趣味小程序:会移动的按钮
1.项目目标 本次根据Qt的鼠标移动事件实现一个趣味小程序:当鼠标移动到按钮时,按钮就会随机出现在置,以至于根本点击不到按钮。 2.项目步骤 首先现在ui界面设计控件(也可以用代码的方式创建,就不多说了) 第一个按钮不需…...

鞋样设计软件
Sxy 64鞋样设计软件是一款专业级鞋类设计工具 专为鞋业设计师与制鞋企业开发 该软件提供全面的鞋样设计功能 包括二维开版 三维建模 放码排料等核心模块 支持从草图构思到成品输出的完整设计流程 内置丰富的鞋型数据库与部件库 可快速生成各种鞋款模板 软件采用智能放码技术 精…...

LeRobot 项目部署运行逻辑(六)——visualize_dataset_html.py/visualize_dataset.py
可视化脚本包括了两个方法:远程下载 huggingface 上的数据集和使用本地数据集 脚本主要使用两个: 目前来说,ACT 采集训练用的是统一时间长度的数据集,此外,这两个脚本最大的问题在于不能裁剪,这也是比较好…...

Windows Server 2025开启GPU分区(GPU-P)部署DoraCloud云桌面
本文描述在ShareStation工作站虚拟化方案的部署过程。 将服务器上部署 Windows Server、DoraCloud,并创建带有vGPU的虚拟桌面。 GPU分区技术介绍 GPU-P(GPU Partitioning) 是微软在 Windows 虚拟化平台(如 Hyper-V)中…...

TCP套接字通信核心要点
TCP套接字通信核心要点 通信模型架构 客户端-服务端模型 CS架构:客户端发起请求,服务端响应和处理请求双向通道:建立连接后实现全双工通信 服务端搭建流程 核心步骤 创建套接字 int server socket(AF_INET, SOCK_STREAM, 0); 参数说明&am…...

【C】初阶数据结构15 -- 计数排序与稳定性分析
本文主要讲解七大排序算法之外的另一种排序算法 -- 计数排序 目录 1 计数排序 1) 算法思想 2) 代码 3) 时间复杂度与空间复杂度分析 (1) 时间复杂度 (2) 空间复杂度 4) 计…...

高性能Python Web 框架--FastAPI 学习「基础 → 进阶 → 生产级」
以下是针对 FastAPI 的保姆级教程,包含核心概念、完整案例和关键注意事项,采用「基础 → 进阶 → 生产级」的三阶段教学法: 一、FastAPI介绍 FastAPI 是一个现代化的、高性能的 Python Web 框架,专门用于构建 APIs(应…...

Qt QML自定义LIstView
QML ListView组合拳做列表,代码不可直接复制使用,需要小改 先上图看效果 样式1 样式2 样式3 原理:操作:技术点:代码片段: 先上图看效果 样式1 三个表格组合成要给,上下滚动时,三个同时滚动&am…...

C++进阶--红黑树的实现
文章目录 红黑树的实现红黑树的概念红黑树的规则红黑树的效率 红黑树的实现红黑树的结构红黑树的插入变色单旋(变色)双旋(变色) 红黑树的查找红黑树的验证 总结:结语 很高兴和大家见面,给生活加点impetus&a…...

WPF之值转换器
文章目录 目录什么是值转换器IValueConverter接口Convert方法ConvertBack方法 创建和使用值转换器定义转换器类在XAML中使用转换器转换器参数(ConverterParameter) 常用转换器实现布尔值转可见性(BoolToVisibilityConverter)数值转…...
黄金、碳排放期货市场API接口文档
StockTV 提供了多种期货市场的数据接口,包括获取K线图表数据、查询特定期货的实时行情等。以下为对接期货市场的详细接口说明。 一、获取K线图表数据 通过调用/futures/kline接口,您可以获取指定期货合约的历史K线数据(例如开盘价、最高价、…...
云上系统CC攻击如何进行检测与防御?
云上系统遭受CC攻击(Challenge Collapsar,一种针对应用层的DDoS攻击)时,检测与防御需结合流量分析、行为识别和技术手段,以下是核心方法: 一、检测方法 异常流量分析 监控请求量突增&#…...

qml中的TextArea使用QSyntaxHighlighter显示高亮语法
效果图,左侧显示行号,右侧用TextArea显示文本内容,并且语法高亮。 2025年5月8号更新 1、多行文本注释 多行文本注释跟普通的高亮规则代码不太一样,代码需要修改,这里以JavaScript举例。 先制定多行文本注释规则&…...
QuecPython+腾讯云:快速连接腾讯云l0T平台
该模块提供腾讯 IoT 平台物联网套件客户端功能,目前的产品节点类型仅支持“设备”,设备认证方式支持“一机一密”和“动态注册认证”。 BC25PA系列不支持该功能。 初始化腾讯 IoT 平台 TXyun TXyun(productID, devicename, devicePsk, ProductSecret)配置腾讯 IoT…...
RocketMQ 深度解析:架构设计与最佳实践
在分布式系统架构日益复杂的今天,消息中间件作为系统间通信的桥梁,扮演着至关重要的角色。RocketMQ 作为阿里开源的高性能分布式消息中间件,凭借其卓越的性能、丰富的功能以及高可用性,在电商、金融、互联网等众多领域得到广泛应用…...

Transformer编码器+SHAP分析,模型可解释创新表达!
目录 效果一览基本介绍程序设计参考资料 效果一览 基本介绍 基本介绍 基于SHAP分析的特征选择和贡献度计算,Matlab2023b代码实现;基于MATLAB的SHAP可解释Transformer编码器回归模型,敏感性分析方法。 详细介绍 引言 在正向渗透(…...