Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
5d450806
K
Kernel
项目概览
openeuler
/
Kernel
大约 1 年 前同步成功
通知
5
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
5d450806
编写于
12月 03, 2008
作者:
J
Joerg Roedel
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
VT-d: adapt domain init and destroy functions for IOMMU API
Signed-off-by:
N
Joerg Roedel
<
joerg.roedel@amd.com
>
上级
19de40a8
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
18 addition
and
17 deletion
+18
-17
drivers/pci/intel-iommu.c
drivers/pci/intel-iommu.c
+18
-15
include/linux/intel-iommu.h
include/linux/intel-iommu.h
+0
-2
未找到文件。
drivers/pci/intel-iommu.c
浏览文件 @
5d450806
...
@@ -34,6 +34,7 @@
...
@@ -34,6 +34,7 @@
#include <linux/mempool.h>
#include <linux/mempool.h>
#include <linux/timer.h>
#include <linux/timer.h>
#include <linux/iova.h>
#include <linux/iova.h>
#include <linux/iommu.h>
#include <linux/intel-iommu.h>
#include <linux/intel-iommu.h>
#include <asm/cacheflush.h>
#include <asm/cacheflush.h>
#include <asm/iommu.h>
#include <asm/iommu.h>
...
@@ -2962,32 +2963,34 @@ static void vm_domain_exit(struct dmar_domain *domain)
...
@@ -2962,32 +2963,34 @@ static void vm_domain_exit(struct dmar_domain *domain)
free_domain_mem
(
domain
);
free_domain_mem
(
domain
);
}
}
st
ruct
dmar_domain
*
intel_iommu_alloc_domain
(
void
)
st
atic
int
intel_iommu_domain_init
(
struct
iommu_domain
*
domain
)
{
{
struct
dmar_domain
*
domain
;
struct
dmar_domain
*
d
mar_d
omain
;
domain
=
iommu_alloc_vm_domain
();
d
mar_d
omain
=
iommu_alloc_vm_domain
();
if
(
!
domain
)
{
if
(
!
d
mar_d
omain
)
{
printk
(
KERN_ERR
printk
(
KERN_ERR
"intel_iommu_domain_
alloc:
domain == NULL
\n
"
);
"intel_iommu_domain_
init: dmar_
domain == NULL
\n
"
);
return
NULL
;
return
-
ENOMEM
;
}
}
if
(
vm_domain_init
(
domain
,
DEFAULT_DOMAIN_ADDRESS_WIDTH
))
{
if
(
vm_domain_init
(
d
mar_d
omain
,
DEFAULT_DOMAIN_ADDRESS_WIDTH
))
{
printk
(
KERN_ERR
printk
(
KERN_ERR
"intel_iommu_domain_
alloc: domain_
init() failed
\n
"
);
"intel_iommu_domain_init() failed
\n
"
);
vm_domain_exit
(
domain
);
vm_domain_exit
(
d
mar_d
omain
);
return
NULL
;
return
-
ENOMEM
;
}
}
domain
->
priv
=
dmar_domain
;
return
domain
;
return
0
;
}
}
EXPORT_SYMBOL_GPL
(
intel_iommu_alloc_domain
);
void
intel_iommu_free_domain
(
struct
dmar
_domain
*
domain
)
static
void
intel_iommu_domain_destroy
(
struct
iommu
_domain
*
domain
)
{
{
vm_domain_exit
(
domain
);
struct
dmar_domain
*
dmar_domain
=
domain
->
priv
;
domain
->
priv
=
NULL
;
vm_domain_exit
(
dmar_domain
);
}
}
EXPORT_SYMBOL_GPL
(
intel_iommu_free_domain
);
int
intel_iommu_attach_device
(
struct
dmar_domain
*
domain
,
int
intel_iommu_attach_device
(
struct
dmar_domain
*
domain
,
struct
pci_dev
*
pdev
)
struct
pci_dev
*
pdev
)
...
...
include/linux/intel-iommu.h
浏览文件 @
5d450806
...
@@ -330,8 +330,6 @@ extern int qi_flush_iotlb(struct intel_iommu *iommu, u16 did, u64 addr,
...
@@ -330,8 +330,6 @@ extern int qi_flush_iotlb(struct intel_iommu *iommu, u16 did, u64 addr,
extern
void
qi_submit_sync
(
struct
qi_desc
*
desc
,
struct
intel_iommu
*
iommu
);
extern
void
qi_submit_sync
(
struct
qi_desc
*
desc
,
struct
intel_iommu
*
iommu
);
struct
dmar_domain
*
intel_iommu_alloc_domain
(
void
);
void
intel_iommu_free_domain
(
struct
dmar_domain
*
domain
);
int
intel_iommu_attach_device
(
struct
dmar_domain
*
domain
,
int
intel_iommu_attach_device
(
struct
dmar_domain
*
domain
,
struct
pci_dev
*
pdev
);
struct
pci_dev
*
pdev
);
void
intel_iommu_detach_device
(
struct
dmar_domain
*
domain
,
void
intel_iommu_detach_device
(
struct
dmar_domain
*
domain
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录