aboutsummaryrefslogtreecommitdiffstats
path: root/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71-e3000/0102-mmc-sdhci-add-adma_table_cnt-member-to-struct-sdhci_.patch
diff options
context:
space:
mode:
Diffstat (limited to 'meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71-e3000/0102-mmc-sdhci-add-adma_table_cnt-member-to-struct-sdhci_.patch')
-rw-r--r--meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71-e3000/0102-mmc-sdhci-add-adma_table_cnt-member-to-struct-sdhci_.patch80
1 files changed, 80 insertions, 0 deletions
diff --git a/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71-e3000/0102-mmc-sdhci-add-adma_table_cnt-member-to-struct-sdhci_.patch b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71-e3000/0102-mmc-sdhci-add-adma_table_cnt-member-to-struct-sdhci_.patch
new file mode 100644
index 00000000..7679f318
--- /dev/null
+++ b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71-e3000/0102-mmc-sdhci-add-adma_table_cnt-member-to-struct-sdhci_.patch
@@ -0,0 +1,80 @@
+From 1d2f6e2bf771658f2865a0931aa71ce4a861a8b2 Mon Sep 17 00:00:00 2001
+From: Sudheesh Mavila <sudheesh.mavila@amd.com>
+Date: Wed, 16 Jan 2019 11:23:47 +0530
+Subject: [PATCH 102/131] mmc: sdhci: add adma_table_cnt member to struct
+ sdhci_host
+
+This patch adds adma_table_cnt member to struct sdhci_host to give more
+flexibility to drivers to control the ADMA table count.
+
+Default value of adma_table_cnt is set to (SDHCI_MAX_SEGS * 2 + 1).
+
+Signed-off-by: Jisheng Zhang <Jisheng.Zhang@synaptics.com>
+Acked-by: Adrian Hunter <adrian.hunter@intel.com>
+Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
+
+Signed-off-by: Sudheesh Mavila <sudheesh.mavila@amd.com>
+---
+ drivers/mmc/host/sdhci.c | 17 +++++++++--------
+ drivers/mmc/host/sdhci.h | 3 +++
+ 2 files changed, 12 insertions(+), 8 deletions(-)
+ mode change 100644 => 100755 drivers/mmc/host/sdhci.h
+
+diff --git a/drivers/mmc/host/sdhci.c b/drivers/mmc/host/sdhci.c
+index 0819b85..075253f 100644
+--- a/drivers/mmc/host/sdhci.c
++++ b/drivers/mmc/host/sdhci.c
+@@ -3223,6 +3223,13 @@ struct sdhci_host *sdhci_alloc_host(struct device *dev,
+
+ host->sdma_boundary = SDHCI_DEFAULT_BOUNDARY_ARG;
+
++ /*
++ * The DMA table descriptor count is calculated as the maximum
++ * number of segments times 2, to allow for an alignment
++ * descriptor for each segment, plus 1 for a nop end descriptor.
++ */
++ host->adma_table_cnt = SDHCI_MAX_SEGS * 2 + 1;
++
+ return host;
+ }
+
+@@ -3468,18 +3475,12 @@ int sdhci_setup_host(struct sdhci_host *host)
+ dma_addr_t dma;
+ void *buf;
+
+- /*
+- * The DMA descriptor table size is calculated as the maximum
+- * number of segments times 2, to allow for an alignment
+- * descriptor for each segment, plus 1 for a nop end descriptor,
+- * all multipled by the descriptor size.
+- */
+ if (host->flags & SDHCI_USE_64_BIT_DMA) {
+- host->adma_table_sz = (SDHCI_MAX_SEGS * 2 + 1) *
++ host->adma_table_sz = host->adma_table_cnt *
+ SDHCI_ADMA2_64_DESC_SZ;
+ host->desc_sz = SDHCI_ADMA2_64_DESC_SZ;
+ } else {
+- host->adma_table_sz = (SDHCI_MAX_SEGS * 2 + 1) *
++ host->adma_table_sz = host->adma_table_cnt *
+ SDHCI_ADMA2_32_DESC_SZ;
+ host->desc_sz = SDHCI_ADMA2_32_DESC_SZ;
+ }
+diff --git a/drivers/mmc/host/sdhci.h b/drivers/mmc/host/sdhci.h
+old mode 100644
+new mode 100755
+index e093037..17193f4
+--- a/drivers/mmc/host/sdhci.h
++++ b/drivers/mmc/host/sdhci.h
+@@ -550,6 +550,9 @@ struct sdhci_host {
+ /* Host SDMA buffer boundary. */
+ u32 sdma_boundary;
+
++ /* Host ADMA table count */
++ u32 adma_table_cnt;
++
+ unsigned long private[0] ____cacheline_aligned;
+ };
+
+--
+2.7.4
+