diff options
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_.patch | 80 |
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 + |