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

Linux内存从0到1学习笔记(8.16 SMMU详解)---更新中

写在前面

前面博客已经了解过。SMMU是IOMMU在ARM架构上的实现。主要为了解决虚拟化环境中,GuestOS无法直接将连续的物理地址分配给硬件的问题。对于Hypervisor/GuestOS的虚拟化系统来说,所有的VM都运行在Hypervisor上,每一个VM独立运行一个OS(GuestOS),Hypervisor完成硬件的共享,隔离和切换。那么由于虚拟化系统中,GuestOS看到的内存并非实际的物理内存,因此需要SMMU对DMA设备发出的请求进行翻译,以确保正确的数据传输。所以SMMU实际上就是一个为外设提供的MMU子系统,它主要的作用就是对虚拟地址的管理,映射和翻译,以确保DMA设备能够在虚拟化环境中正常工作。

再来说说DMA?

DMA(Direct Memory Access),即直接内存存取,是一种外部设备与系统内存直接交换数据的接口技术。它允许外设将数据批量传输到内存,然后再发送一个中断通知CPU去处理,这个过程并不经过CPU,从而降低了算力负载。但是,DMA需要连续的物理内存来进行数据传输,应为它不能像CPU一样通过MMU来操作虚拟地址。我们可以把它理解为使外设和内存之间的桥梁(硬件),这样外设可以绕过CPU直接通过DMA将批量数据传输到内存。

一,QSMMU

本文基于QCOM平台的SoC进行拆解。在QCOM平台下,SMMU作为一个子系统负责将虚拟地址转换为物理地址并检查访问权限。SMMU在SoC中执行两个主要功能:内存碎片整理(使用虚拟内存)和访问控制。

http://www.lryc.cn/news/372436.html

相关文章:

  • 标准盒模型和怪异盒模型的区别
  • 【第8章】如何利用ControlNet生成“可控画面”?(配置要求/一键安装/快速上手/生成第一张图)ComfyUI基础入门教程
  • [qt] qt程序打包以及docker镜像打包
  • 电脑屏幕监控软件有哪些?2025年监控软件排行榜
  • 音视频主要概念
  • AIGC全面介绍
  • vscode中模糊搜索和替换
  • 人工智能入门学习教程分享
  • Django序列化器详解:普通序列化器与模型序列化器的选择与运用
  • Commons-io工具包与Hutool工具包
  • ROS中Twist消息类型
  • Pixi.js学习 (四)鼠标跟随、元素组合与图片位控
  • Golang | Leetcode Golang题解之第139题单词拆分
  • 简单聊一下Oracle,MySQL,postgresql三种锁表的机制,行锁和表锁
  • Python的网络请求
  • [Shell编程学习路线]——探讨Shell中变量的作用范围(export)
  • AlertManager解析:构建高效告警系统
  • 打造专属 Switch 模拟游戏机
  • 如何使用Python中的type()函数和isinstance()函数
  • 【LeetCode刷题】前缀和解决问题:560.和为k的子数组
  • DTU在城市智慧供热上的应用:引领供热行业的智能化革新
  • LeetCode | 58.最后一个单词的长度
  • 202479读书笔记|《你是人间的四月天》——谁又能参透这幻化的轮回, 谁又大胆的爱过这伟大的变幻?
  • 近期docker镜像加速器被封杀,需要的请看此内容 点赞加关注
  • 开源大模型的新星:ChatGPT-Next-Web 项目解析与推荐
  • 【区块链】记账的千年演化:从泥板到区块链
  • MySQL的索引类型,以及各自的作用
  • 数组中的map方法
  • 使用Python生成并上传文档
  • LAMP部署及应用