All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] mmc: new API for data write using scatter gather DMA
@ 2014-11-26 11:07 ` Avinash Patil
  0 siblings, 0 replies; 11+ messages in thread
From: Avinash Patil @ 2014-11-26 11:07 UTC (permalink / raw)
  To: ulf.hansson
  Cc: linux-mmc, linux-wireless, akarwar, cluo, yangyang, huxm, patila,
	bin9zha0, Bing Zhao

From: Bing Zhao <bzhao@marvell.com>

This patch adds new API to handle scatter gather aggregation.

Signed-off-by: Bing Zhao <bzhao@marvell.com>
Signed-off-by: Avinash Patil <patila@marvell.com>
Signed-off-by: Xinming Hu <huxm@marvell.com>
Signed-off-by: Cathy Luo <cluo@marvell.com>
---
 drivers/mmc/core/sdio_ops.c   | 65 +++++++++++++++++++++++++++++++++++++++++++
 include/linux/mmc/sdio_func.h |  5 ++++
 2 files changed, 70 insertions(+)

diff --git a/drivers/mmc/core/sdio_ops.c b/drivers/mmc/core/sdio_ops.c
index 62508b4..4c5e362 100644
--- a/drivers/mmc/core/sdio_ops.c
+++ b/drivers/mmc/core/sdio_ops.c
@@ -15,6 +15,7 @@
 #include <linux/mmc/card.h>
 #include <linux/mmc/mmc.h>
 #include <linux/mmc/sdio.h>
+#include <linux/export.h>
 
 #include "core.h"
 #include "sdio_ops.h"
@@ -204,6 +205,70 @@ int mmc_io_rw_extended(struct mmc_card *card, int write, unsigned fn,
 	return 0;
 }
 
+int mmc_io_rw_extended_sg(struct mmc_card *card, int write, unsigned fn,
+			  unsigned addr, int incr_addr,
+			  struct sg_table *sgt, unsigned blksz)
+{
+	struct mmc_request mrq = {NULL};
+	struct mmc_command cmd = {0};
+	struct mmc_data data = {0};
+	struct scatterlist *sg_ptr;
+	unsigned blocks = 0;
+	int i;
+
+	BUG_ON(!card || !card->host);
+	BUG_ON(fn > 7);
+	BUG_ON(!blksz);
+	for_each_sg(sgt->sgl, sg_ptr, sgt->nents, i) {
+		WARN_ON(sg_ptr->length > card->host->max_seg_size);
+		blocks += DIV_ROUND_UP(sg_ptr->length, blksz);
+	}
+
+	/* sanity check */
+	if (addr & ~0x1FFFF)
+		return -EINVAL;
+
+	mrq.cmd = &cmd;
+	mrq.data = &data;
+
+	cmd.opcode = SD_IO_RW_EXTENDED;
+	cmd.arg = write ? 0x80000000 : 0x00000000;
+	cmd.arg |= fn << 28;
+	cmd.arg |= incr_addr ? 0x04000000 : 0x00000000;
+	cmd.arg |= addr << 9;
+	cmd.arg |= 0x08000000 | blocks;
+	cmd.flags = MMC_RSP_SPI_R5 | MMC_RSP_R5 | MMC_CMD_ADTC;
+
+	data.blksz = blksz;
+	data.blocks = blocks;
+	data.flags = write ? MMC_DATA_WRITE : MMC_DATA_READ;
+
+	data.sg = sgt->sgl;
+	data.sg_len = sgt->nents;
+
+	mmc_set_data_timeout(&data, card);
+	mmc_wait_for_req(card->host, &mrq);
+
+	if (cmd.error)
+		return cmd.error;
+	if (data.error)
+		return data.error;
+
+	if (mmc_host_is_spi(card->host)) {
+		/* host driver already reported errors */
+	} else {
+		if (cmd.resp[0] & R5_ERROR)
+			return -EIO;
+		if (cmd.resp[0] & R5_FUNCTION_NUMBER)
+			return -EINVAL;
+		if (cmd.resp[0] & R5_OUT_OF_RANGE)
+			return -ERANGE;
+	}
+
+	return 0;
+}
+EXPORT_SYMBOL_GPL(mmc_io_rw_extended_sg);
+
 int sdio_reset(struct mmc_host *host)
 {
 	int ret;
diff --git a/include/linux/mmc/sdio_func.h b/include/linux/mmc/sdio_func.h
index 50f0bc9..927ea8f 100644
--- a/include/linux/mmc/sdio_func.h
+++ b/include/linux/mmc/sdio_func.h
@@ -14,6 +14,7 @@
 
 #include <linux/device.h>
 #include <linux/mod_devicetable.h>
+#include <linux/scatterlist.h>
 
 #include <linux/mmc/pm.h>
 
@@ -153,6 +154,10 @@ extern int sdio_memcpy_toio(struct sdio_func *func, unsigned int addr,
 extern int sdio_writesb(struct sdio_func *func, unsigned int addr,
 	void *src, int count);
 
+int mmc_io_rw_extended_sg(struct mmc_card *card, int write, unsigned fn,
+			  unsigned addr, int incr_addr,
+			  struct sg_table *sgt, unsigned blksz);
+
 extern unsigned char sdio_f0_readb(struct sdio_func *func,
 	unsigned int addr, int *err_ret);
 extern void sdio_f0_writeb(struct sdio_func *func, unsigned char b,
-- 
1.8.1.4


^ permalink raw reply related	[flat|nested] 11+ messages in thread

end of thread, other threads:[~2015-09-22  7:20 UTC | newest]

Thread overview: 11+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-11-26 11:07 [PATCH] mmc: new API for data write using scatter gather DMA Avinash Patil
2014-11-26 11:07 ` Avinash Patil
2014-11-26 13:43 ` Ulf Hansson
     [not found]   ` <CAPDyKFr-iaPWKWWgk-5_XcJm9sag=y=uZjfJvo-DQiJFM8BVLw-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2014-11-26 18:10     ` Arend van Spriel
2014-11-26 18:10       ` Arend van Spriel
     [not found]       ` <CAEhWJFmxxFyh5oF33NiTQn70RhoP_z-vkRBEdVb-XcMfDDnHfg@mail.gmail.com>
     [not found]         ` <e5ce420ddc0f4ceca8cac83f5350ded3@SC-EXCH04.marvell.com>
2015-09-22  7:20           ` Amitkumar Karwar
2015-09-22  7:20             ` Amitkumar Karwar
2014-12-02  9:25     ` Avinash Patil
2014-12-02  9:25       ` Avinash Patil
2014-12-05  9:24       ` Avinash Patil
2014-12-05 10:16         ` Ulf Hansson

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.