aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPer Forlin <per.friden@stericsson.com>2010-10-06 05:05:28 -0400
committerDan Williams <dan.j.williams@intel.com>2010-10-07 17:56:36 -0400
commit661385f9c34e15c2f2c57b80e8cb2c7b910fdbd3 (patch)
treebe7d9196566449473cc0b49138839b6ec2dd66a7
parenta59670a40b4dd497630f9442feb259dde601e469 (diff)
DMAENGINE: Remove stedma40_set_psize and pre_transfer hook in ste_dma40
Remove obsolete pre_transfer hook in stedma40_chan_cfg. The intent of this hook is merely to handle burst size compensation for ux500 variant MMCI. Remove obsolete stedma40_set_psize since it is only called from pre_transfer. DMAEngine device_control replaces the functionality of stedma40_set_psize. Signed-off-by: Per Forlin <per.forlin@stericsson.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
-rw-r--r--arch/arm/plat-nomadik/include/plat/ste_dma40.h24
-rw-r--r--drivers/dma/ste_dma40.c52
2 files changed, 2 insertions, 74 deletions
diff --git a/arch/arm/plat-nomadik/include/plat/ste_dma40.h b/arch/arm/plat-nomadik/include/plat/ste_dma40.h
index 1127af210894..660552d33b3a 100644
--- a/arch/arm/plat-nomadik/include/plat/ste_dma40.h
+++ b/arch/arm/plat-nomadik/include/plat/ste_dma40.h
@@ -1,6 +1,6 @@
1/* 1/*
2 * Copyright (C) ST-Ericsson SA 2007-2010 2 * Copyright (C) ST-Ericsson SA 2007-2010
3 * Author: Per Friden <per.friden@stericsson.com> for ST-Ericsson 3 * Author: Per Forlin <per.forlin@stericsson.com> for ST-Ericsson
4 * Author: Jonas Aaberg <jonas.aberg@stericsson.com> for ST-Ericsson 4 * Author: Jonas Aaberg <jonas.aberg@stericsson.com> for ST-Ericsson
5 * License terms: GNU General Public License (GPL) version 2 5 * License terms: GNU General Public License (GPL) version 2
6 */ 6 */
@@ -123,10 +123,6 @@ struct stedma40_half_channel_info {
123 * @dst_dev_type: Dst device type 123 * @dst_dev_type: Dst device type
124 * @src_info: Parameters for dst half channel 124 * @src_info: Parameters for dst half channel
125 * @dst_info: Parameters for dst half channel 125 * @dst_info: Parameters for dst half channel
126 * @pre_transfer_data: Data to be passed on to the pre_transfer() function.
127 * @pre_transfer: Callback used if needed before preparation of transfer.
128 * Only called if device is set. size of bytes to transfer
129 * (in case of multiple element transfer size is size of the first element).
130 * 126 *
131 * 127 *
132 * This structure has to be filled by the client drivers. 128 * This structure has to be filled by the client drivers.
@@ -140,10 +136,6 @@ struct stedma40_chan_cfg {
140 int dst_dev_type; 136 int dst_dev_type;
141 struct stedma40_half_channel_info src_info; 137 struct stedma40_half_channel_info src_info;
142 struct stedma40_half_channel_info dst_info; 138 struct stedma40_half_channel_info dst_info;
143 void *pre_transfer_data;
144 int (*pre_transfer) (struct dma_chan *chan,
145 void *data,
146 int size);
147}; 139};
148 140
149/** 141/**
@@ -171,20 +163,6 @@ struct stedma40_platform_data {
171}; 163};
172 164
173/** 165/**
174 * setdma40_set_psize() - Used for changing the package size of an
175 * already configured dma channel.
176 *
177 * @chan: dmaengine handle
178 * @src_psize: new package side for src. (STEDMA40_PSIZE*)
179 * @src_psize: new package side for dst. (STEDMA40_PSIZE*)
180 *
181 * returns 0 on ok, otherwise negative error number.
182 */
183int stedma40_set_psize(struct dma_chan *chan,
184 int src_psize,
185 int dst_psize);
186
187/**
188 * stedma40_filter() - Provides stedma40_chan_cfg to the 166 * stedma40_filter() - Provides stedma40_chan_cfg to the
189 * ste_dma40 dma driver via the dmaengine framework. 167 * ste_dma40 dma driver via the dmaengine framework.
190 * does some checking of what's provided. 168 * does some checking of what's provided.
diff --git a/drivers/dma/ste_dma40.c b/drivers/dma/ste_dma40.c
index ad8d6df1b6a8..662d7e35f862 100644
--- a/drivers/dma/ste_dma40.c
+++ b/drivers/dma/ste_dma40.c
@@ -1,6 +1,6 @@
1/* 1/*
2 * Copyright (C) ST-Ericsson SA 2007-2010 2 * Copyright (C) ST-Ericsson SA 2007-2010
3 * Author: Per Friden <per.friden@stericsson.com> for ST-Ericsson 3 * Author: Per Forlin <per.forlin@stericsson.com> for ST-Ericsson
4 * Author: Jonas Aaberg <jonas.aberg@stericsson.com> for ST-Ericsson 4 * Author: Jonas Aaberg <jonas.aberg@stericsson.com> for ST-Ericsson
5 * License terms: GNU General Public License (GPL) version 2 5 * License terms: GNU General Public License (GPL) version 2
6 */ 6 */
@@ -1593,51 +1593,6 @@ static u32 stedma40_residue(struct dma_chan *chan)
1593 return bytes_left; 1593 return bytes_left;
1594} 1594}
1595 1595
1596/* Public DMA functions in addition to the DMA engine framework */
1597
1598int stedma40_set_psize(struct dma_chan *chan,
1599 int src_psize,
1600 int dst_psize)
1601{
1602 struct d40_chan *d40c =
1603 container_of(chan, struct d40_chan, chan);
1604 unsigned long flags;
1605
1606 spin_lock_irqsave(&d40c->lock, flags);
1607
1608 if (d40c->log_num != D40_PHY_CHAN) {
1609 d40c->log_def.lcsp1 &= ~D40_MEM_LCSP1_SCFG_PSIZE_MASK;
1610 d40c->log_def.lcsp3 &= ~D40_MEM_LCSP1_SCFG_PSIZE_MASK;
1611 d40c->log_def.lcsp1 |= src_psize <<
1612 D40_MEM_LCSP1_SCFG_PSIZE_POS;
1613 d40c->log_def.lcsp3 |= dst_psize <<
1614 D40_MEM_LCSP1_SCFG_PSIZE_POS;
1615 goto out;
1616 }
1617
1618 if (src_psize == STEDMA40_PSIZE_PHY_1)
1619 d40c->src_def_cfg &= ~(1 << D40_SREG_CFG_PHY_PEN_POS);
1620 else {
1621 d40c->src_def_cfg |= 1 << D40_SREG_CFG_PHY_PEN_POS;
1622 d40c->src_def_cfg &= ~(STEDMA40_PSIZE_PHY_16 <<
1623 D40_SREG_CFG_PSIZE_POS);
1624 d40c->src_def_cfg |= src_psize << D40_SREG_CFG_PSIZE_POS;
1625 }
1626
1627 if (dst_psize == STEDMA40_PSIZE_PHY_1)
1628 d40c->dst_def_cfg &= ~(1 << D40_SREG_CFG_PHY_PEN_POS);
1629 else {
1630 d40c->dst_def_cfg |= 1 << D40_SREG_CFG_PHY_PEN_POS;
1631 d40c->dst_def_cfg &= ~(STEDMA40_PSIZE_PHY_16 <<
1632 D40_SREG_CFG_PSIZE_POS);
1633 d40c->dst_def_cfg |= dst_psize << D40_SREG_CFG_PSIZE_POS;
1634 }
1635out:
1636 spin_unlock_irqrestore(&d40c->lock, flags);
1637 return 0;
1638}
1639EXPORT_SYMBOL(stedma40_set_psize);
1640
1641struct dma_async_tx_descriptor *stedma40_memcpy_sg(struct dma_chan *chan, 1596struct dma_async_tx_descriptor *stedma40_memcpy_sg(struct dma_chan *chan,
1642 struct scatterlist *sgl_dst, 1597 struct scatterlist *sgl_dst,
1643 struct scatterlist *sgl_src, 1598 struct scatterlist *sgl_src,
@@ -2075,11 +2030,6 @@ static struct dma_async_tx_descriptor *d40_prep_slave_sg(struct dma_chan *chan,
2075 return ERR_PTR(-EINVAL); 2030 return ERR_PTR(-EINVAL);
2076 } 2031 }
2077 2032
2078 if (d40c->dma_cfg.pre_transfer)
2079 d40c->dma_cfg.pre_transfer(chan,
2080 d40c->dma_cfg.pre_transfer_data,
2081 sg_dma_len(sgl));
2082
2083 spin_lock_irqsave(&d40c->lock, flags); 2033 spin_lock_irqsave(&d40c->lock, flags);
2084 d40d = d40_desc_get(d40c); 2034 d40d = d40_desc_get(d40c);
2085 2035