aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/dma/amba-pl08x.c
diff options
context:
space:
mode:
authorRussell King - ARM Linux <linux@arm.linux.org.uk>2011-01-03 17:39:13 -0500
committerDan Williams <dan.j.williams@intel.com>2011-01-04 22:16:12 -0500
commit19524d77ec34faf58d313ba34fb755ef6e159216 (patch)
tree63b24d5a82de3ee5fd8e07a311eb8d573cd21f76 /drivers/dma/amba-pl08x.c
parentc885bee4f10323a1ff3f19e1aa2aa6f4e7f89dd8 (diff)
ARM: PL08x: avoid duplicating registers in txd and phychan structures
As we now have all the code accessing the phychan {csrc,cdst,clli,cctl, ccfg} members in one function, there's no point storing the data into the struct. Get rid of the struct members. Re-order the register dump in the dev_dbg() to reflect the order we write the registers to the DMA device. The txd {csrc,cdst,clli,cctl} values are duplicates of the lli[0] values, so there's no point duplicating these either. Program the DMAC registers directly from the lli[0] values. Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk> Acked-by: Linus Walleij <linus.walleij@stericsson.com> Signed-off-by: Dan Williams <dan.j.williams@intel.com>
Diffstat (limited to 'drivers/dma/amba-pl08x.c')
-rw-r--r--drivers/dma/amba-pl08x.c57
1 files changed, 19 insertions, 38 deletions
diff --git a/drivers/dma/amba-pl08x.c b/drivers/dma/amba-pl08x.c
index c025a4b4bae4..a1a18bde6b7f 100644
--- a/drivers/dma/amba-pl08x.c
+++ b/drivers/dma/amba-pl08x.c
@@ -193,33 +193,25 @@ static void pl08x_start_txd(struct pl08x_dma_chan *plchan,
193{ 193{
194 struct pl08x_driver_data *pl08x = plchan->host; 194 struct pl08x_driver_data *pl08x = plchan->host;
195 struct pl08x_phy_chan *phychan = plchan->phychan; 195 struct pl08x_phy_chan *phychan = plchan->phychan;
196 u32 val; 196 struct pl08x_lli *lli = &txd->llis_va[0];
197 u32 val, ccfg;
197 198
198 plchan->at = txd; 199 plchan->at = txd;
199 200
200 /* Copy the basic control register calculated at transfer config */
201 phychan->csrc = txd->csrc;
202 phychan->cdst = txd->cdst;
203 phychan->clli = txd->clli;
204 phychan->cctl = txd->cctl;
205
206 /* Assign the signal to the proper control registers */ 201 /* Assign the signal to the proper control registers */
207 phychan->ccfg = plchan->cd->ccfg; 202 ccfg = plchan->cd->ccfg;
208 phychan->ccfg &= ~PL080_CONFIG_SRC_SEL_MASK; 203 ccfg &= ~(PL080_CONFIG_SRC_SEL_MASK | PL080_CONFIG_DST_SEL_MASK);
209 phychan->ccfg &= ~PL080_CONFIG_DST_SEL_MASK; 204
210 /* If it wasn't set from AMBA, ignore it */ 205 /* If it wasn't set from AMBA, ignore it */
211 if (txd->direction == DMA_TO_DEVICE) 206 if (txd->direction == DMA_TO_DEVICE)
212 /* Select signal as destination */ 207 /* Select signal as destination */
213 phychan->ccfg |= 208 ccfg |= phychan->signal << PL080_CONFIG_DST_SEL_SHIFT;
214 (phychan->signal << PL080_CONFIG_DST_SEL_SHIFT);
215 else if (txd->direction == DMA_FROM_DEVICE) 209 else if (txd->direction == DMA_FROM_DEVICE)
216 /* Select signal as source */ 210 /* Select signal as source */
217 phychan->ccfg |= 211 ccfg |= phychan->signal << PL080_CONFIG_SRC_SEL_SHIFT;
218 (phychan->signal << PL080_CONFIG_SRC_SEL_SHIFT); 212
219 /* Always enable error interrupts */ 213 /* Always enable error and terminal interrupts */
220 phychan->ccfg |= PL080_CONFIG_ERR_IRQ_MASK; 214 ccfg |= PL080_CONFIG_ERR_IRQ_MASK | PL080_CONFIG_TC_IRQ_MASK;
221 /* Always enable terminal interrupts */
222 phychan->ccfg |= PL080_CONFIG_TC_IRQ_MASK;
223 215
224 /* Wait for channel inactive */ 216 /* Wait for channel inactive */
225 while (pl08x_phy_channel_busy(phychan)) 217 while (pl08x_phy_channel_busy(phychan))
@@ -227,19 +219,15 @@ static void pl08x_start_txd(struct pl08x_dma_chan *plchan,
227 219
228 dev_vdbg(&pl08x->adev->dev, 220 dev_vdbg(&pl08x->adev->dev,
229 "WRITE channel %d: csrc=0x%08x, cdst=0x%08x, " 221 "WRITE channel %d: csrc=0x%08x, cdst=0x%08x, "
230 "cctl=0x%08x, clli=0x%08x, ccfg=0x%08x\n", 222 "clli=0x%08x, cctl=0x%08x, ccfg=0x%08x\n",
231 phychan->id, 223 phychan->id, lli->src, lli->dst, lli->lli, lli->cctl,
232 phychan->csrc, 224 ccfg);
233 phychan->cdst, 225
234 phychan->cctl, 226 writel(lli->src, phychan->base + PL080_CH_SRC_ADDR);
235 phychan->clli, 227 writel(lli->dst, phychan->base + PL080_CH_DST_ADDR);
236 phychan->ccfg); 228 writel(lli->lli, phychan->base + PL080_CH_LLI);
237 229 writel(lli->cctl, phychan->base + PL080_CH_CONTROL);
238 writel(phychan->csrc, phychan->base + PL080_CH_SRC_ADDR); 230 writel(ccfg, phychan->base + PL080_CH_CONFIG);
239 writel(phychan->cdst, phychan->base + PL080_CH_DST_ADDR);
240 writel(phychan->clli, phychan->base + PL080_CH_LLI);
241 writel(phychan->cctl, phychan->base + PL080_CH_CONTROL);
242 writel(phychan->ccfg, phychan->base + PL080_CH_CONFIG);
243 231
244 /* Enable the DMA channel */ 232 /* Enable the DMA channel */
245 /* Do not access config register until channel shows as disabled */ 233 /* Do not access config register until channel shows as disabled */
@@ -920,13 +908,6 @@ static int pl08x_fill_llis_for_desc(struct pl08x_driver_data *pl08x,
920 */ 908 */
921 llis_va[num_llis - 1].cctl |= PL080_CONTROL_TC_IRQ_EN; 909 llis_va[num_llis - 1].cctl |= PL080_CONTROL_TC_IRQ_EN;
922 910
923 /* Now store the channel register values */
924 txd->csrc = llis_va[0].src;
925 txd->cdst = llis_va[0].dst;
926 txd->clli = llis_va[0].lli;
927 txd->cctl = llis_va[0].cctl;
928 /* ccfg will be set at physical channel allocation time */
929
930#ifdef VERBOSE_DEBUG 911#ifdef VERBOSE_DEBUG
931 { 912 {
932 int i; 913 int i;