Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
c23663ac
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
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看板
提交
c23663ac
编写于
3月 10, 2016
作者:
M
Mark Brown
浏览文件
操作
浏览文件
下载
差异文件
Merge remote-tracking branch 'spi/fix/imx' into spi-linus
上级
f6cede5b
ba4a3550
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
2 addition
and
15 deletion
+2
-15
drivers/spi/spi-imx.c
drivers/spi/spi-imx.c
+2
-15
未找到文件。
drivers/spi/spi-imx.c
浏览文件 @
c23663ac
...
...
@@ -204,8 +204,8 @@ static bool spi_imx_can_dma(struct spi_master *master, struct spi_device *spi,
{
struct
spi_imx_data
*
spi_imx
=
spi_master_get_devdata
(
master
);
if
(
spi_imx
->
dma_is_inited
&&
transfer
->
len
>
spi_imx
->
wml
*
sizeof
(
u32
)
)
if
(
spi_imx
->
dma_is_inited
&&
transfer
->
len
>=
spi_imx
->
wml
&&
(
transfer
->
len
%
spi_imx
->
wml
)
==
0
)
return
true
;
return
false
;
}
...
...
@@ -919,8 +919,6 @@ static int spi_imx_dma_transfer(struct spi_imx_data *spi_imx,
struct
dma_async_tx_descriptor
*
desc_tx
=
NULL
,
*
desc_rx
=
NULL
;
int
ret
;
unsigned
long
timeout
;
u32
dma
;
int
left
;
struct
spi_master
*
master
=
spi_imx
->
bitbang
.
master
;
struct
sg_table
*
tx
=
&
transfer
->
tx_sg
,
*
rx
=
&
transfer
->
rx_sg
;
...
...
@@ -954,13 +952,6 @@ static int spi_imx_dma_transfer(struct spi_imx_data *spi_imx,
/* Trigger the cspi module. */
spi_imx
->
dma_finished
=
0
;
dma
=
readl
(
spi_imx
->
base
+
MX51_ECSPI_DMA
);
dma
=
dma
&
(
~
MX51_ECSPI_DMA_RXT_WML_MASK
);
/* Change RX_DMA_LENGTH trigger dma fetch tail data */
left
=
transfer
->
len
%
spi_imx
->
wml
;
if
(
left
)
writel
(
dma
|
(
left
<<
MX51_ECSPI_DMA_RXT_WML_OFFSET
),
spi_imx
->
base
+
MX51_ECSPI_DMA
);
/*
* Set these order to avoid potential RX overflow. The overflow may
* happen if we enable SPI HW before starting RX DMA due to rescheduling
...
...
@@ -992,10 +983,6 @@ static int spi_imx_dma_transfer(struct spi_imx_data *spi_imx,
spi_imx
->
devtype_data
->
reset
(
spi_imx
);
dmaengine_terminate_all
(
master
->
dma_rx
);
}
dma
&=
~
MX51_ECSPI_DMA_RXT_WML_MASK
;
writel
(
dma
|
spi_imx
->
wml
<<
MX51_ECSPI_DMA_RXT_WML_OFFSET
,
spi_imx
->
base
+
MX51_ECSPI_DMA
);
}
spi_imx
->
dma_finished
=
1
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录