Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
5039104f
cloud-kernel
项目概览
openanolis
/
cloud-kernel
接近 2 年 前同步成功
通知
169
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看板
提交
5039104f
编写于
1月 31, 2018
作者:
V
Vinod Koul
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'topic/rcar' into for-linus
上级
2cb1800c
73a47bd0
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
43 addition
and
1 deletion
+43
-1
drivers/dma/sh/rcar-dmac.c
drivers/dma/sh/rcar-dmac.c
+43
-1
未找到文件。
drivers/dma/sh/rcar-dmac.c
浏览文件 @
5039104f
...
@@ -10,6 +10,7 @@
...
@@ -10,6 +10,7 @@
* published by the Free Software Foundation.
* published by the Free Software Foundation.
*/
*/
#include <linux/delay.h>
#include <linux/dma-mapping.h>
#include <linux/dma-mapping.h>
#include <linux/dmaengine.h>
#include <linux/dmaengine.h>
#include <linux/interrupt.h>
#include <linux/interrupt.h>
...
@@ -741,6 +742,41 @@ static int rcar_dmac_fill_hwdesc(struct rcar_dmac_chan *chan,
...
@@ -741,6 +742,41 @@ static int rcar_dmac_fill_hwdesc(struct rcar_dmac_chan *chan,
/* -----------------------------------------------------------------------------
/* -----------------------------------------------------------------------------
* Stop and reset
* Stop and reset
*/
*/
static
void
rcar_dmac_chcr_de_barrier
(
struct
rcar_dmac_chan
*
chan
)
{
u32
chcr
;
unsigned
int
i
;
/*
* Ensure that the setting of the DE bit is actually 0 after
* clearing it.
*/
for
(
i
=
0
;
i
<
1024
;
i
++
)
{
chcr
=
rcar_dmac_chan_read
(
chan
,
RCAR_DMACHCR
);
if
(
!
(
chcr
&
RCAR_DMACHCR_DE
))
return
;
udelay
(
1
);
}
dev_err
(
chan
->
chan
.
device
->
dev
,
"CHCR DE check error
\n
"
);
}
static
void
rcar_dmac_sync_tcr
(
struct
rcar_dmac_chan
*
chan
)
{
u32
chcr
=
rcar_dmac_chan_read
(
chan
,
RCAR_DMACHCR
);
if
(
!
(
chcr
&
RCAR_DMACHCR_DE
))
return
;
/* set DE=0 and flush remaining data */
rcar_dmac_chan_write
(
chan
,
RCAR_DMACHCR
,
(
chcr
&
~
RCAR_DMACHCR_DE
));
/* make sure all remaining data was flushed */
rcar_dmac_chcr_de_barrier
(
chan
);
/* back DE */
rcar_dmac_chan_write
(
chan
,
RCAR_DMACHCR
,
chcr
);
}
static
void
rcar_dmac_chan_halt
(
struct
rcar_dmac_chan
*
chan
)
static
void
rcar_dmac_chan_halt
(
struct
rcar_dmac_chan
*
chan
)
{
{
...
@@ -749,6 +785,7 @@ static void rcar_dmac_chan_halt(struct rcar_dmac_chan *chan)
...
@@ -749,6 +785,7 @@ static void rcar_dmac_chan_halt(struct rcar_dmac_chan *chan)
chcr
&=
~
(
RCAR_DMACHCR_DSE
|
RCAR_DMACHCR_DSIE
|
RCAR_DMACHCR_IE
|
chcr
&=
~
(
RCAR_DMACHCR_DSE
|
RCAR_DMACHCR_DSIE
|
RCAR_DMACHCR_IE
|
RCAR_DMACHCR_TE
|
RCAR_DMACHCR_DE
);
RCAR_DMACHCR_TE
|
RCAR_DMACHCR_DE
);
rcar_dmac_chan_write
(
chan
,
RCAR_DMACHCR
,
chcr
);
rcar_dmac_chan_write
(
chan
,
RCAR_DMACHCR
,
chcr
);
rcar_dmac_chcr_de_barrier
(
chan
);
}
}
static
void
rcar_dmac_chan_reinit
(
struct
rcar_dmac_chan
*
chan
)
static
void
rcar_dmac_chan_reinit
(
struct
rcar_dmac_chan
*
chan
)
...
@@ -1309,8 +1346,11 @@ static unsigned int rcar_dmac_chan_get_residue(struct rcar_dmac_chan *chan,
...
@@ -1309,8 +1346,11 @@ static unsigned int rcar_dmac_chan_get_residue(struct rcar_dmac_chan *chan,
residue
+=
chunk
->
size
;
residue
+=
chunk
->
size
;
}
}
if
(
desc
->
direction
==
DMA_DEV_TO_MEM
)
rcar_dmac_sync_tcr
(
chan
);
/* Add the residue for the current chunk. */
/* Add the residue for the current chunk. */
residue
+=
rcar_dmac_chan_read
(
chan
,
RCAR_DMATCR
)
<<
desc
->
xfer_shift
;
residue
+=
rcar_dmac_chan_read
(
chan
,
RCAR_DMATCR
B
)
<<
desc
->
xfer_shift
;
return
residue
;
return
residue
;
}
}
...
@@ -1481,6 +1521,8 @@ static irqreturn_t rcar_dmac_isr_channel(int irq, void *dev)
...
@@ -1481,6 +1521,8 @@ static irqreturn_t rcar_dmac_isr_channel(int irq, void *dev)
if
(
chcr
&
RCAR_DMACHCR_TE
)
if
(
chcr
&
RCAR_DMACHCR_TE
)
mask
|=
RCAR_DMACHCR_DE
;
mask
|=
RCAR_DMACHCR_DE
;
rcar_dmac_chan_write
(
chan
,
RCAR_DMACHCR
,
chcr
&
~
mask
);
rcar_dmac_chan_write
(
chan
,
RCAR_DMACHCR
,
chcr
&
~
mask
);
if
(
mask
&
RCAR_DMACHCR_DE
)
rcar_dmac_chcr_de_barrier
(
chan
);
if
(
chcr
&
RCAR_DMACHCR_DSE
)
if
(
chcr
&
RCAR_DMACHCR_DSE
)
ret
|=
rcar_dmac_isr_desc_stage_end
(
chan
);
ret
|=
rcar_dmac_isr_desc_stage_end
(
chan
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录