aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLee Jones <lee.jones@linaro.org>2013-05-03 10:32:03 -0400
committerLinus Walleij <linus.walleij@linaro.org>2013-05-23 15:12:47 -0400
commitdb72da92103e3023e6a4fdfe65183b21bfe5d883 (patch)
tree19663173711535124862a6833481633d875d3377
parent4bd04e2ed415754a38118399328bc2c494f68632 (diff)
dmaengine: ste_dma40: Calculate number of logical channels from physical ones
This change will cost ~25KB of memory, but it's worth the trade-off, as it removes a great deal of overhead. It means that instead of only allocating memory for the logical channels in use, it does so for all available ones, which is 32 per physical channel. However, this now means we can remove some platform data and we don't have to worry about adding vendor specific variables to Device Tree. Acked-by: Vinod Koul <vnod.koul@intel.com> Signed-off-by: Lee Jones <lee.jones@linaro.org> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
-rw-r--r--arch/arm/mach-ux500/devices-db8500.c1
-rw-r--r--drivers/dma/ste_dma40.c16
-rw-r--r--include/linux/platform_data/dma-ste-dma40.h2
3 files changed, 6 insertions, 13 deletions
diff --git a/arch/arm/mach-ux500/devices-db8500.c b/arch/arm/mach-ux500/devices-db8500.c
index 7989c564e47a..130f3d9917e7 100644
--- a/arch/arm/mach-ux500/devices-db8500.c
+++ b/arch/arm/mach-ux500/devices-db8500.c
@@ -121,7 +121,6 @@ static const dma_addr_t dma40_rx_map[DB8500_DMA_NR_DEV] = {
121}; 121};
122 122
123static struct stedma40_platform_data dma40_plat_data = { 123static struct stedma40_platform_data dma40_plat_data = {
124 .dev_len = DB8500_DMA_NR_DEV,
125 .dev_rx = dma40_rx_map, 124 .dev_rx = dma40_rx_map,
126 .dev_tx = dma40_tx_map, 125 .dev_tx = dma40_tx_map,
127 .disabled_channels = {-1}, 126 .disabled_channels = {-1},
diff --git a/drivers/dma/ste_dma40.c b/drivers/dma/ste_dma40.c
index 367ef15a3cd8..f25c9ccf28e8 100644
--- a/drivers/dma/ste_dma40.c
+++ b/drivers/dma/ste_dma40.c
@@ -45,6 +45,9 @@
45#define D40_LCLA_LINK_PER_EVENT_GRP 128 45#define D40_LCLA_LINK_PER_EVENT_GRP 128
46#define D40_LCLA_END D40_LCLA_LINK_PER_EVENT_GRP 46#define D40_LCLA_END D40_LCLA_LINK_PER_EVENT_GRP
47 47
48/* Max number of logical channels per physical channel */
49#define D40_MAX_LOG_CHAN_PER_PHY 32
50
48/* Attempts before giving up to trying to get pages that are aligned */ 51/* Attempts before giving up to trying to get pages that are aligned */
49#define MAX_LCLA_ALLOC_ATTEMPTS 256 52#define MAX_LCLA_ALLOC_ATTEMPTS 256
50 53
@@ -3210,6 +3213,8 @@ static struct d40_base * __init d40_hw_detect_init(struct platform_device *pdev)
3210 else 3213 else
3211 num_phy_chans = 4 * (readl(virtbase + D40_DREG_ICFG) & 0x7) + 4; 3214 num_phy_chans = 4 * (readl(virtbase + D40_DREG_ICFG) & 0x7) + 4;
3212 3215
3216 num_log_chans = num_phy_chans * D40_MAX_LOG_CHAN_PER_PHY;
3217
3213 dev_info(&pdev->dev, "hardware revision: %d @ 0x%x with %d physical channels\n", 3218 dev_info(&pdev->dev, "hardware revision: %d @ 0x%x with %d physical channels\n",
3214 rev, res->start, num_phy_chans); 3219 rev, res->start, num_phy_chans);
3215 3220
@@ -3219,15 +3224,6 @@ static struct d40_base * __init d40_hw_detect_init(struct platform_device *pdev)
3219 goto failure; 3224 goto failure;
3220 } 3225 }
3221 3226
3222 /* Count the number of logical channels in use */
3223 for (i = 0; i < plat_data->dev_len; i++)
3224 if (plat_data->dev_rx[i] != 0)
3225 num_log_chans++;
3226
3227 for (i = 0; i < plat_data->dev_len; i++)
3228 if (plat_data->dev_tx[i] != 0)
3229 num_log_chans++;
3230
3231 base = kzalloc(ALIGN(sizeof(struct d40_base), 4) + 3227 base = kzalloc(ALIGN(sizeof(struct d40_base), 4) +
3232 (num_phy_chans + num_log_chans + ARRAY_SIZE(dma40_memcpy_channels)) * 3228 (num_phy_chans + num_log_chans + ARRAY_SIZE(dma40_memcpy_channels)) *
3233 sizeof(struct d40_chan), GFP_KERNEL); 3229 sizeof(struct d40_chan), GFP_KERNEL);
@@ -3295,7 +3291,7 @@ static struct d40_base * __init d40_hw_detect_init(struct platform_device *pdev)
3295 * The max number of logical channels are event lines for all 3291 * The max number of logical channels are event lines for all
3296 * src devices and dst devices 3292 * src devices and dst devices
3297 */ 3293 */
3298 base->lookup_log_chans = kzalloc(plat_data->dev_len * 2 * 3294 base->lookup_log_chans = kzalloc(num_log_chans *
3299 sizeof(struct d40_chan *), 3295 sizeof(struct d40_chan *),
3300 GFP_KERNEL); 3296 GFP_KERNEL);
3301 if (!base->lookup_log_chans) 3297 if (!base->lookup_log_chans)
diff --git a/include/linux/platform_data/dma-ste-dma40.h b/include/linux/platform_data/dma-ste-dma40.h
index 9e42a67d0cd5..c54af61c9e48 100644
--- a/include/linux/platform_data/dma-ste-dma40.h
+++ b/include/linux/platform_data/dma-ste-dma40.h
@@ -136,7 +136,6 @@ struct stedma40_chan_cfg {
136/** 136/**
137 * struct stedma40_platform_data - Configuration struct for the dma device. 137 * struct stedma40_platform_data - Configuration struct for the dma device.
138 * 138 *
139 * @dev_len: length of dev_tx and dev_rx
140 * @dev_tx: mapping between destination event line and io address 139 * @dev_tx: mapping between destination event line and io address
141 * @dev_rx: mapping between source event line and io address 140 * @dev_rx: mapping between source event line and io address
142 * @disabled_channels: A vector, ending with -1, that marks physical channels 141 * @disabled_channels: A vector, ending with -1, that marks physical channels
@@ -153,7 +152,6 @@ struct stedma40_chan_cfg {
153 * for 'multiple of 4' channels, like 8. 152 * for 'multiple of 4' channels, like 8.
154 */ 153 */
155struct stedma40_platform_data { 154struct stedma40_platform_data {
156 u32 dev_len;
157 const dma_addr_t *dev_tx; 155 const dma_addr_t *dev_tx;
158 const dma_addr_t *dev_rx; 156 const dma_addr_t *dev_rx;
159 int disabled_channels[STEDMA40_MAX_PHYS]; 157 int disabled_channels[STEDMA40_MAX_PHYS];