diff options
author | Ludovic Desroches <ludovic.desroches@microchip.com> | 2018-08-20 10:54:45 +0200 |
---|---|---|
committer | Ulf Hansson <ulf.hansson@linaro.org> | 2018-08-21 16:06:17 +0200 |
commit | 17e96d8516e31c3cb52cb8e2ee79d1d2e6948c11 (patch) | |
tree | bc60f2baf18d3cf723fa0df1353bcd6cdec94c1f /drivers/mmc/host/android-goldfish.c | |
parent | mmc: atmel-mci: fix bad logic of sg_copy_{from,to}_buffer conversion (diff) | |
download | linux-17e96d8516e31c3cb52cb8e2ee79d1d2e6948c11.tar.xz linux-17e96d8516e31c3cb52cb8e2ee79d1d2e6948c11.zip |
mmc: android-goldfish: fix bad logic of sg_copy_{from,to}_buffer conversion
The conversion to sg_copy_{from,to}_buffer has been done in the wrong
way. sg_copy_to_buffer is a copy from an SG list to a linear buffer so
it can't replace memcpy(dest, host->virt_base, data->sg->length) where
dest is the virtual address of the SG. Same for sg_copy_from_buffer
but in the opposite way.
Signed-off-by: Ludovic Desroches <ludovic.desroches@microchip.com>
Suggested-by: Douglas Gilbert <dgilbert@interlog.com>
Fixes: 53d7e098ba08 ("mmc: android-goldfish: use sg_copy_{from,to}_buffer")
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
Diffstat (limited to 'drivers/mmc/host/android-goldfish.c')
-rw-r--r-- | drivers/mmc/host/android-goldfish.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/mmc/host/android-goldfish.c b/drivers/mmc/host/android-goldfish.c index 294de177632c..61e4e2a213c9 100644 --- a/drivers/mmc/host/android-goldfish.c +++ b/drivers/mmc/host/android-goldfish.c @@ -217,7 +217,7 @@ static void goldfish_mmc_xfer_done(struct goldfish_mmc_host *host, * We don't really have DMA, so we need * to copy from our platform driver buffer */ - sg_copy_to_buffer(data->sg, 1, host->virt_base, + sg_copy_from_buffer(data->sg, 1, host->virt_base, data->sg->length); } host->data->bytes_xfered += data->sg->length; @@ -393,7 +393,7 @@ static void goldfish_mmc_prepare_data(struct goldfish_mmc_host *host, * We don't really have DMA, so we need to copy to our * platform driver buffer */ - sg_copy_from_buffer(data->sg, 1, host->virt_base, + sg_copy_to_buffer(data->sg, 1, host->virt_base, data->sg->length); } } |