Commit f55c98f7 authored by Russell King's avatar Russell King Committed by Ulf Hansson

mmc: sdhci: factor out common DMA cleanup in sdhci_finish_data()

sdhci_finish_data() has two paths which result in identical DMA cleanup.
One is when SDHCI_USE_ADMA is clear, and the other is just before when
SDHCI_USE_ADMA is set, and is performed within sdhci_adma_table_post().

Simplify the code by removing the 'else' and eliminating the duplicate
inside sdhci_adma_table_post().
Signed-off-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
Signed-off-by: default avatarAdrian Hunter <adrian.hunter@intel.com>
Tested-by: default avatarGregory CLEMENT <gregory.clement@free-electrons.com>
Signed-off-by: default avatarUlf Hansson <ulf.hansson@linaro.org>
parent 47fa9613
...@@ -552,19 +552,12 @@ static int sdhci_adma_table_pre(struct sdhci_host *host, ...@@ -552,19 +552,12 @@ static int sdhci_adma_table_pre(struct sdhci_host *host,
static void sdhci_adma_table_post(struct sdhci_host *host, static void sdhci_adma_table_post(struct sdhci_host *host,
struct mmc_data *data) struct mmc_data *data)
{ {
int direction;
struct scatterlist *sg; struct scatterlist *sg;
int i, size; int i, size;
void *align; void *align;
char *buffer; char *buffer;
unsigned long flags; unsigned long flags;
if (data->flags & MMC_DATA_READ)
direction = DMA_FROM_DEVICE;
else
direction = DMA_TO_DEVICE;
if (data->flags & MMC_DATA_READ) { if (data->flags & MMC_DATA_READ) {
bool has_unaligned = false; bool has_unaligned = false;
...@@ -577,7 +570,7 @@ static void sdhci_adma_table_post(struct sdhci_host *host, ...@@ -577,7 +570,7 @@ static void sdhci_adma_table_post(struct sdhci_host *host,
if (has_unaligned) { if (has_unaligned) {
dma_sync_sg_for_cpu(mmc_dev(host->mmc), data->sg, dma_sync_sg_for_cpu(mmc_dev(host->mmc), data->sg,
data->sg_len, direction); data->sg_len, DMA_FROM_DEVICE);
align = host->align_buffer; align = host->align_buffer;
...@@ -595,12 +588,6 @@ static void sdhci_adma_table_post(struct sdhci_host *host, ...@@ -595,12 +588,6 @@ static void sdhci_adma_table_post(struct sdhci_host *host,
} }
} }
} }
if (data->host_cookie == COOKIE_MAPPED) {
dma_unmap_sg(mmc_dev(host->mmc), data->sg,
data->sg_len, direction);
data->host_cookie = COOKIE_UNMAPPED;
}
} }
static u8 sdhci_calc_timeout(struct sdhci_host *host, struct mmc_command *cmd) static u8 sdhci_calc_timeout(struct sdhci_host *host, struct mmc_command *cmd)
...@@ -920,14 +907,12 @@ static void sdhci_finish_data(struct sdhci_host *host) ...@@ -920,14 +907,12 @@ static void sdhci_finish_data(struct sdhci_host *host)
if (host->flags & SDHCI_REQ_USE_DMA) { if (host->flags & SDHCI_REQ_USE_DMA) {
if (host->flags & SDHCI_USE_ADMA) if (host->flags & SDHCI_USE_ADMA)
sdhci_adma_table_post(host, data); sdhci_adma_table_post(host, data);
else {
if (data->host_cookie == COOKIE_MAPPED) { if (data->host_cookie == COOKIE_MAPPED) {
dma_unmap_sg(mmc_dev(host->mmc), dma_unmap_sg(mmc_dev(host->mmc), data->sg, data->sg_len,
data->sg, data->sg_len, (data->flags & MMC_DATA_READ) ?
(data->flags & MMC_DATA_READ) ? DMA_FROM_DEVICE : DMA_TO_DEVICE);
DMA_FROM_DEVICE : DMA_TO_DEVICE); data->host_cookie = COOKIE_UNMAPPED;
data->host_cookie = COOKIE_UNMAPPED;
}
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment