[发明专利]用于异构计算的统一内核虚拟地址空间在审
| 申请号: | 202080060590.0 | 申请日: | 2020-07-22 |
| 公开(公告)号: | CN114286987A | 公开(公告)日: | 2022-04-05 |
| 发明(设计)人: | 邝东全;本杰明·坤·潘·陈;威廉·劳埃德·阿特金森 | 申请(专利权)人: | ATI科技无限责任公司 |
| 主分类号: | G06F12/09 | 分类号: | G06F12/09;G06F12/06 |
| 代理公司: | 上海胜康律师事务所 31263 | 代理人: | 樊英如;张静 |
| 地址: | 加拿大*** | 国省代码: | 暂无信息 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 用于 计算 统一 内核 虚拟 地址 空间 | ||
1.一种系统,其包括:
存储器子系统;
具有第一内核地址空间的第一子系统;
具有第二内核地址空间的第二子系统;以及
输入/输出存储器管理单元(IOMMU);
其中所述系统被配置为:
由所述第一子系统在与所述存储器子系统相对应的物理地址空间中的第一物理地址处分配存储器块;
由所述第一子系统创建所述第一内核地址空间中的第一逻辑地址到所述第一物理地址的映射,其中所述第一内核地址空间中的所述第一逻辑地址是与所述第一物理地址的第一偏移量;
由所述IOMMU选择设备地址,所述设备地址是与所述第二内核地址空间中的所述第一逻辑地址的第二偏移量;
创建所述设备地址空间中的所选择设备地址到所述第一物理地址的IOMMU映射;并且
通过所述IOMMU映射,启用所述第一内核地址空间和所述第二内核地址空间两者中的公共共享区域,以供所述第一子系统和所述第二子系统两者使用。
2.如权利要求1所述的系统,其中所述第一子系统被配置为向所述第二子系统传送指向所述存储器块的缓冲区指针,其中所述缓冲区指针在所述第一内核地址空间中指定。
3.如权利要求2所述的系统,其中所述系统还被配置为:
由所述第二子系统在不执行所述缓冲区指针转换的情况下执行引用所述第一内核地址空间中的所述缓冲区指针的存储器访问指令;并且
当由所述第二子系统访问所述存储器块时,通过所述IOMMU映射将所述缓冲区指针转换为所述物理地址空间。
4.如权利要求1所述的系统,其中:
所述第一内核地址空间中的逻辑地址是与所述物理地址空间中的对应地址的第一偏移量;
所述第二内核地址空间中的逻辑地址是与设备地址空间中的对应地址的第二偏移量;并且
所述IOMMU映射创建覆盖,使得所述第二内核地址空间中指向所述存储器块的逻辑地址与所述第一内核地址空间中的逻辑地址相同。
5.如权利要求1所述的系统,其中:
所述第一子系统执行第一操作系统;并且
所述第二子系统执行不同于所述第一操作系统的第二操作系统。
6.如权利要求5所述的系统,其中:
所述第一子系统包括第一存储器管理单元(MMU);并且
所述第二子系统包括不同于所述第一MMU的第二MMU。
7.如权利要求1所述的系统,其中所述公共共享区域映射到所述物理地址空间中的所述存储器块。
8.一种方法,其包括:
由具有第一内核地址空间的第一子系统在物理地址空间中的第一物理地址处分配存储器块;
由所述第一子系统创建所述第一内核地址空间中的第一逻辑地址到所述第一物理地址的映射,其中所述第一内核地址空间中的所述第一逻辑地址是与所述第一物理地址的第一偏移量;
由输入/输出存储器管理单元(IOMMU)选择设备地址,所述设备地址是与第二子系统的第二内核地址空间中的所述第一逻辑地址的第二偏移量;
由所述IOMMU创建所述设备地址空间中的所选择设备地址到所述第一物理地址的IOMMU映射;并且
通过所述IOMMU映射,启用所述第一内核地址空间和所述第二内核地址空间两者中的公共共享区域,以供所述第一子系统和所述第二子系统两者使用。
9.如权利要求8所述的方法,其还包括从所述第一子系统向所述第二子系统传送指向所述存储器块的缓冲区指针,其中所述缓冲区指针在所述第一内核地址空间中指定。
10.如权利要求9所述的方法,其还包括:
由所述第二子系统在不执行所述缓冲区指针转换的情况下执行引用所述第一内核地址空间中的所述缓冲区指针的存储器访问指令;并且
当由所述第二子系统访问所述存储器块时,通过所述IOMMU映射将所述缓冲区指针转换为所述物理地址空间。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于ATI科技无限责任公司,未经ATI科技无限责任公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202080060590.0/1.html,转载请声明来源钻瓜专利网。





