Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
599c26d3
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
160
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
599c26d3
编写于
5月 14, 2007
作者:
P
Paul Mundt
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
sh64: dma-mapping updates.
Follow the noncoherent changes from sh. Signed-off-by:
N
Paul Mundt
<
lethal@linux-sh.org
>
上级
a226d33a
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
9 addition
and
5 deletion
+9
-5
include/asm-sh64/dma-mapping.h
include/asm-sh64/dma-mapping.h
+9
-5
未找到文件。
include/asm-sh64/dma-mapping.h
浏览文件 @
599c26d3
...
...
@@ -35,6 +35,10 @@ static inline void dma_free_coherent(struct device *dev, size_t size,
consistent_free
(
NULL
,
size
,
vaddr
,
dma_handle
);
}
#define dma_alloc_noncoherent(d, s, h, f) dma_alloc_coherent(d, s, h, f)
#define dma_free_noncoherent(d, s, v, h) dma_free_coherent(d, s, v, h)
#define dma_is_consistent(d, h) (1)
static
inline
void
dma_cache_sync
(
struct
device
*
dev
,
void
*
vaddr
,
size_t
size
,
enum
dma_data_direction
dir
)
{
...
...
@@ -49,7 +53,7 @@ static inline dma_addr_t dma_map_single(struct device *dev,
if
(
dev
->
bus
==
&
pci_bus_type
)
return
virt_to_bus
(
ptr
);
#endif
dma_cache_sync
(
ptr
,
size
,
dir
);
dma_cache_sync
(
dev
,
ptr
,
size
,
dir
);
return
virt_to_bus
(
ptr
);
}
...
...
@@ -63,7 +67,7 @@ static inline int dma_map_sg(struct device *dev, struct scatterlist *sg,
for
(
i
=
0
;
i
<
nents
;
i
++
)
{
#if !defined(CONFIG_PCI) || defined(CONFIG_SH_PCIDMA_NONCOHERENT)
dma_cache_sync
(
page_address
(
sg
[
i
].
page
)
+
sg
[
i
].
offset
,
dma_cache_sync
(
dev
,
page_address
(
sg
[
i
].
page
)
+
sg
[
i
].
offset
,
sg
[
i
].
length
,
dir
);
#endif
sg
[
i
].
dma_address
=
page_to_phys
(
sg
[
i
].
page
)
+
sg
[
i
].
offset
;
...
...
@@ -94,7 +98,7 @@ static inline void dma_sync_single(struct device *dev, dma_addr_t dma_handle,
if
(
dev
->
bus
==
&
pci_bus_type
)
return
;
#endif
dma_cache_sync
(
bus_to_virt
(
dma_handle
),
size
,
dir
);
dma_cache_sync
(
dev
,
bus_to_virt
(
dma_handle
),
size
,
dir
);
}
static
inline
void
dma_sync_single_range
(
struct
device
*
dev
,
...
...
@@ -106,7 +110,7 @@ static inline void dma_sync_single_range(struct device *dev,
if
(
dev
->
bus
==
&
pci_bus_type
)
return
;
#endif
dma_cache_sync
(
bus_to_virt
(
dma_handle
)
+
offset
,
size
,
dir
);
dma_cache_sync
(
dev
,
bus_to_virt
(
dma_handle
)
+
offset
,
size
,
dir
);
}
static
inline
void
dma_sync_sg
(
struct
device
*
dev
,
struct
scatterlist
*
sg
,
...
...
@@ -116,7 +120,7 @@ static inline void dma_sync_sg(struct device *dev, struct scatterlist *sg,
for
(
i
=
0
;
i
<
nelems
;
i
++
)
{
#if !defined(CONFIG_PCI) || defined(CONFIG_SH_PCIDMA_NONCOHERENT)
dma_cache_sync
(
page_address
(
sg
[
i
].
page
)
+
sg
[
i
].
offset
,
dma_cache_sync
(
dev
,
page_address
(
sg
[
i
].
page
)
+
sg
[
i
].
offset
,
sg
[
i
].
length
,
dir
);
#endif
sg
[
i
].
dma_address
=
page_to_phys
(
sg
[
i
].
page
)
+
sg
[
i
].
offset
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录