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

[qemu+kvm]: smmu stage 2 建立流程

1. qemu倡导 gpa和hpa映射关系在vm建立时不确定在运行时触发缺页异常后建立映射关系lazy binding。2. smmu stage 2要求 gpa和hpa的映射关系在vm建立时确定若在运行时触发缺页会导致dma失败pcie ats 除外两者有冲突那么 qemu 对于smmu stage 2 、mmu stage 2 ept建立到底是怎样的1.smmu stage2建立过程 对于vfio设备有自己专属的MemoryListenerstaticconstMemoryListener vfio_memory_listener{.namevfio,.region_addvfio_listener_region_add,.region_delvfio_listener_region_del,.log_global_startvfio_listener_log_global_start,.log_global_stopvfio_listener_log_global_stop,.log_syncvfio_listener_log_sync,};注册 hw/vfio/common.cmemory_listener_register(container-prereg_listener,address_space_memory);此MemoryListener的address_space_memory和ddr mem 相同所以当ddr mem增加时vfio_listener_region_add会被调用。通过memory_region_get_ram_ptr拿到hva通过section-offset_within_address_space 获得iova 将两个参数传入vfio_dma_mapvfio_dma_map调用ioctl(container-fd, VFIO_IOMMU_MAP_DMA, map)进入内核做映射进入内核vfio_pin_map_dmavfio_iommu_map会做真正的map 工作调用 arm_smmu_ops-map建立 smmu stage 2页表但在此之前已经得到了pfn pfn是通过vfio_pin_pages_remote获取的所以vfio_pin_pages_remote职责是分配物理页建立hva和hpa 的映射关系。staticlongvfio_pin_pages_remote(structvfio_dma*dma,unsignedlongvaddr,longnpage,unsignedlong*pfn_base,unsignedlonglimit,structvfio_batch*batch){retvaddr_get_pfns(mm,vaddr,req_pages,dma-prot,pfn,batch-pages);}在这里插入代码片vaddr_get_pfnsstaticintvaddr_get_pfns(structmm_struct*mm,unsignedlongvaddr,longnpages,intprot,unsignedlong*pfn,structpage**pages){retpin_user_pages_remote(mm,vaddr,npages,flags|FOLL_LONGTERM,pages,NULL);retry:vmavma_lookup(mm,vaddr);if(vmavma-vm_flagsVM_PFNMAP){retfollow_fault_pfn(vma,mm,vaddr,pfn,protIOMMU_WRITE);}比较清晰了通过pin_user_pages_remote 建立 hva到hpa的映射同时follow_fault_pfn是个兜底机制把映射关系放到task_struct-mm下2. mmu stage 2 建立过程因为smmu stage 2已经建立hva和hpa映射关系已经明确了同时gpa 和hva的关系在vm建立初期就明确了hva section_base gpa所以gpa和hpa的关系已经明确 那么mmu 在触发 mmu stage 2 缺页时只需要创建gpa到hpa的页表就行了不需要额外分配hpa。mmu stage2 缺页进入 user_mem_abortstaticintuser_mem_abort(structkvm_vcpu*vcpu,phys_addr_tfault_ipa,structkvm_memory_slot*memslot,unsignedlonghva,bool fault_is_perm){pfn__gfn_to_pfn_memslot(memslot,gfn,false,false,NULL,write_fault,writable,NULL);retkvm_pgtable_stage2_map(pgt,fault_ipa,vma_pagesize,__pfn_to_phys(pfn),prot,memcache,KVM_PGTABLE_WALK_HANDLE_FAULT|KVM_PGTABLE_WALK_SHARED);}__gfn_to_pfn_memslot负责找到gpa 对应的hpa kvm_pgtable_stage2_map负责建立 mmu stage 2 映射__gfn_to_pfn_memslot:kvm_pfn_t__gfn_to_pfn_memslot(conststructkvm_memory_slot*slot,gfn_tgfn,bool atomic,bool interruptible,bool*async,bool write_fault,bool*writable,hva_t*hva){hva_to_pfn(addr,atomic,interruptible,async,write_fault,writable);}hva_to_pfn:kvm_pfn_thva_to_pfn(unsignedlongaddr,bool atomic,bool interruptible..{if(hva_to_pfn_fast(addr,write_fault,writable,pfn))returnpfn;if(atomic)returnKVM_PFN_ERR_FAULT;npageshva_to_pfn_slow(addr,async,write_fault,interruptible,writable,pfn);}hva_to_pfn_fast 快速路径由于建立smmu stage2 时hva和hpa的关系已经明确所以这里走快速路径 hva_to_pfn_slow慢速路径如果guest没有透传设备每当guest访存时都要走慢速路径现场分配pfn。 函数细节有空展开分析。流程、原理已经说清楚了。
http://www.gsyq.cn/news/1337014.html

相关文章:

  • MASA全家桶汉化包终极指南:让Minecraft模组界面说中文的免费解决方案
  • 手把手教你用Docker和Vulhub复现Apache Flink 1.9.1未授权上传漏洞(附MSF实战)
  • 【2026年华为暑期实习(AI)-5月20日-第二题- LLM 多源语料分级清洗预算分配】(题目+思路+JavaC++Python解析+在线测试)
  • Perplexity新闻搜索准确率骤降41.6%?——来自CNCF认证环境工程师的7层环境审计清单
  • Verilog时序逻辑设计:从D触发器到状态机的实战指南
  • 别再花冤枉钱!Stata 18保姆级安装与版本选择指南(附闲鱼购买避坑)
  • 卫星转发器核心用途及实践价值 GNSS卫星转发器 北斗转发器
  • 光伏出口退税取消后首月数据观察(2026年5月)
  • 从‘黑盒’测试到电路设计:互易定理在排查传感器信号异常时的实战应用
  • 跨境服装电商出海增长新范式:集之互动以AI技术,破解合规、本土化、成本三大全球难题
  • 七牛云:批量将标准存储文件转为归档直读存储
  • 考研复习 Day 39 | 密码学--第四章 分组密码(上)
  • 【Redis | 第一篇】Redis常见命令
  • 【Rust + Tauri 2 + TypeScript + Tailwind CSS 4 桌面应用 UI 组件选型深度对比(2026版)】
  • 别再硬套RBAC了!用Filebrowser的‘文件夹规则’搞定多级文件权限(附实战配置)
  • python conda正确安装cuda版本的pytorch
  • 示波器RIGOL与UltraSigma截图的使用
  • C 语言单向链表基础操作详解
  • 2026深度前瞻:制造业生产合规管控,未来有哪些智能化发展方向?
  • B站SEO优化底层逻辑:以用户需求为核心,解锁低成本流量密码
  • AI Agent将如何重构制造业的安全生产隐患识别模式?深度理解与实在Agent闭环实战
  • 从选题到定稿零焦虑?okbiye AI 本科论文写作,把 “熬大夜” 的时间还给你
  • Anthropic《创始人手册:打造AI原生创业公司》Claude(中文精读版)完整38页pdf
  • 你的舵机控制代码可能一直写错了:从PWM占空比公式到SG90/MG996R舵机平滑运动避坑指南
  • 手把手教你用示波器抓CAN总线波形:从SOF到EOF的保姆级解析(附位填充实战)
  • 2026年4月西藏靠谱的体育看台源头厂家推荐,体育看台/雨棚/遮阳棚/推拉蓬/电动推拉棚,体育看台生产厂家怎么选择 - 品牌推荐师
  • STM32G474实战:用CubeIde配置互补PWM驱动电机,这10个坑我帮你踩过了
  • 为什么你的Midjourney时装图总被拒稿?揭秘Pantone TPX数据库未公开调用逻辑及RGB→PMS精准映射公式
  • 轻松实现Zoho系统与轻易云数据集成平台的无缝对接
  • InterSystems IntelliCare 成为首个获得欧盟医疗器械法规认证的 AI 原生EHR系统