Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
L
linux-davinci
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
linux
linux-davinci
Commits
656217d2
Commit
656217d2
authored
Apr 16, 2009
by
Martin Fuzzey
Committed by
Pierre Ossman
Jun 03, 2009
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mxcmmc: Fix missing return value checking in DMA setup code.
Signed-off-by:
Martin Fuzzey
<
mfuzzey@gmail.com
>
parent
18489fa2
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
26 additions
and
10 deletions
+26
-10
drivers/mmc/host/mxcmmc.c
drivers/mmc/host/mxcmmc.c
+26
-10
No files found.
drivers/mmc/host/mxcmmc.c
View file @
656217d2
...
@@ -162,7 +162,7 @@ static void mxcmci_softreset(struct mxcmci_host *host)
...
@@ -162,7 +162,7 @@ static void mxcmci_softreset(struct mxcmci_host *host)
writew
(
0xff
,
host
->
base
+
MMC_REG_RES_TO
);
writew
(
0xff
,
host
->
base
+
MMC_REG_RES_TO
);
}
}
static
void
mxcmci_setup_data
(
struct
mxcmci_host
*
host
,
struct
mmc_data
*
data
)
static
int
mxcmci_setup_data
(
struct
mxcmci_host
*
host
,
struct
mmc_data
*
data
)
{
{
unsigned
int
nob
=
data
->
blocks
;
unsigned
int
nob
=
data
->
blocks
;
unsigned
int
blksz
=
data
->
blksz
;
unsigned
int
blksz
=
data
->
blksz
;
...
@@ -170,6 +170,7 @@ static void mxcmci_setup_data(struct mxcmci_host *host, struct mmc_data *data)
...
@@ -170,6 +170,7 @@ static void mxcmci_setup_data(struct mxcmci_host *host, struct mmc_data *data)
#ifdef HAS_DMA
#ifdef HAS_DMA
struct
scatterlist
*
sg
;
struct
scatterlist
*
sg
;
int
i
;
int
i
;
int
ret
;
#endif
#endif
if
(
data
->
flags
&
MMC_DATA_STREAM
)
if
(
data
->
flags
&
MMC_DATA_STREAM
)
nob
=
0xffff
;
nob
=
0xffff
;
...
@@ -185,7 +186,7 @@ static void mxcmci_setup_data(struct mxcmci_host *host, struct mmc_data *data)
...
@@ -185,7 +186,7 @@ static void mxcmci_setup_data(struct mxcmci_host *host, struct mmc_data *data)
for_each_sg
(
data
->
sg
,
sg
,
data
->
sg_len
,
i
)
{
for_each_sg
(
data
->
sg
,
sg
,
data
->
sg_len
,
i
)
{
if
(
sg
->
offset
&
3
||
sg
->
length
&
3
)
{
if
(
sg
->
offset
&
3
||
sg
->
length
&
3
)
{
host
->
do_dma
=
0
;
host
->
do_dma
=
0
;
return
;
return
0
;
}
}
}
}
...
@@ -194,23 +195,30 @@ static void mxcmci_setup_data(struct mxcmci_host *host, struct mmc_data *data)
...
@@ -194,23 +195,30 @@ static void mxcmci_setup_data(struct mxcmci_host *host, struct mmc_data *data)
host
->
dma_nents
=
dma_map_sg
(
mmc_dev
(
host
->
mmc
),
data
->
sg
,
host
->
dma_nents
=
dma_map_sg
(
mmc_dev
(
host
->
mmc
),
data
->
sg
,
data
->
sg_len
,
host
->
dma_dir
);
data
->
sg_len
,
host
->
dma_dir
);
imx_dma_setup_sg
(
host
->
dma
,
data
->
sg
,
host
->
dma_nents
,
datasize
,
ret
=
imx_dma_setup_sg
(
host
->
dma
,
data
->
sg
,
host
->
dma_nents
,
host
->
res
->
start
+
MMC_REG_BUFFER_ACCESS
,
datasize
,
DMA_MODE_READ
);
host
->
res
->
start
+
MMC_REG_BUFFER_ACCESS
,
DMA_MODE_READ
);
}
else
{
}
else
{
host
->
dma_dir
=
DMA_TO_DEVICE
;
host
->
dma_dir
=
DMA_TO_DEVICE
;
host
->
dma_nents
=
dma_map_sg
(
mmc_dev
(
host
->
mmc
),
data
->
sg
,
host
->
dma_nents
=
dma_map_sg
(
mmc_dev
(
host
->
mmc
),
data
->
sg
,
data
->
sg_len
,
host
->
dma_dir
);
data
->
sg_len
,
host
->
dma_dir
);
imx_dma_setup_sg
(
host
->
dma
,
data
->
sg
,
host
->
dma_nents
,
datasize
,
ret
=
imx_dma_setup_sg
(
host
->
dma
,
data
->
sg
,
host
->
dma_nents
,
host
->
res
->
start
+
MMC_REG_BUFFER_ACCESS
,
datasize
,
DMA_MODE_WRITE
);
host
->
res
->
start
+
MMC_REG_BUFFER_ACCESS
,
DMA_MODE_WRITE
);
}
}
if
(
ret
)
{
dev_err
(
mmc_dev
(
host
->
mmc
),
"failed to setup DMA : %d
\n
"
,
ret
);
return
ret
;
}
wmb
();
wmb
();
imx_dma_enable
(
host
->
dma
);
imx_dma_enable
(
host
->
dma
);
#endif
/* HAS_DMA */
#endif
/* HAS_DMA */
return
0
;
}
}
static
int
mxcmci_start_cmd
(
struct
mxcmci_host
*
host
,
struct
mmc_command
*
cmd
,
static
int
mxcmci_start_cmd
(
struct
mxcmci_host
*
host
,
struct
mmc_command
*
cmd
,
...
@@ -536,6 +544,7 @@ static void mxcmci_request(struct mmc_host *mmc, struct mmc_request *req)
...
@@ -536,6 +544,7 @@ static void mxcmci_request(struct mmc_host *mmc, struct mmc_request *req)
{
{
struct
mxcmci_host
*
host
=
mmc_priv
(
mmc
);
struct
mxcmci_host
*
host
=
mmc_priv
(
mmc
);
unsigned
int
cmdat
=
host
->
cmdat
;
unsigned
int
cmdat
=
host
->
cmdat
;
int
error
;
WARN_ON
(
host
->
req
!=
NULL
);
WARN_ON
(
host
->
req
!=
NULL
);
...
@@ -545,7 +554,12 @@ static void mxcmci_request(struct mmc_host *mmc, struct mmc_request *req)
...
@@ -545,7 +554,12 @@ static void mxcmci_request(struct mmc_host *mmc, struct mmc_request *req)
host
->
do_dma
=
1
;
host
->
do_dma
=
1
;
#endif
#endif
if
(
req
->
data
)
{
if
(
req
->
data
)
{
mxcmci_setup_data
(
host
,
req
->
data
);
error
=
mxcmci_setup_data
(
host
,
req
->
data
);
if
(
error
)
{
req
->
cmd
->
error
=
error
;
goto
out
;
}
cmdat
|=
CMD_DAT_CONT_DATA_ENABLE
;
cmdat
|=
CMD_DAT_CONT_DATA_ENABLE
;
...
@@ -553,7 +567,9 @@ static void mxcmci_request(struct mmc_host *mmc, struct mmc_request *req)
...
@@ -553,7 +567,9 @@ static void mxcmci_request(struct mmc_host *mmc, struct mmc_request *req)
cmdat
|=
CMD_DAT_CONT_WRITE
;
cmdat
|=
CMD_DAT_CONT_WRITE
;
}
}
if
(
mxcmci_start_cmd
(
host
,
req
->
cmd
,
cmdat
))
error
=
mxcmci_start_cmd
(
host
,
req
->
cmd
,
cmdat
);
out:
if
(
error
)
mxcmci_finish_request
(
host
,
req
);
mxcmci_finish_request
(
host
,
req
);
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment