From: Viresh KUMAR on 15 Jun 2010 01:30 On 6/14/2010 7:09 PM, Linus Walleij wrote: > Hi Viresh, thanks a lot for reviewing this and I'd be *very* happy if > you could give it a spin on > the SPEAr as well! I would be happy too linus, will do it in few weeks, right now we are running short of time. > > 2010/6/14 Viresh KUMAR <viresh.kumar(a)st.com>: >>> diff --git a/drivers/dma/amba-pl08x.c b/drivers/dma/amba-pl08x.c >>> (...) >>> + * (Bursts are irrelevant for mem to mem transfers - there are no burst >>> + * signals) >> >> I agree that there are no request lines from memories but still we can program >> them with burst in order to faster the transfer. This burst feature is >> automatically handled by DMA. > > Actually in the example platform data I set this to the maxburst size > 256 Bytes, however if I read the manual correctly this is simply ignored > when you do mem2mem transfers. > > It will simply AHB master the bus until the transaction is finished. That > is why the manual states: > > "You must program memory-to-memory transfers with a low channel > priority, otherwise: > � other DMA channels cannot access the bus until the > memory-to-memory transfer > has finished > � other AHB masters cannot perform any transaction." Yes i have seen them. One more thing i have found related to mem to mem transfers is: "You must set this value to the burst size of the destination peripheral, or if the destination is memory, to the memory boundary size." >>> +static void pl08x_set_cregs(struct pl08x_driver_data *pl08x, >>> + struct pl08x_phy_chan *ch) >>> +{ >>> + u32 val; >>> + >>> + /* Wait for channel inactive */ >>> + val = readl(ch->base + PL080_CH_CONFIG); >>> + while (val & PL080_CONFIG_ACTIVE) >>> + val = readl(ch->base + PL080_CH_CONFIG); >> >> can we use pl08x_phy_channel_busy() instead of above code? > > Fixed. > >>> + /* >>> + * Do not access config register until channel shows as inactive >>> + */ >>> + val = readl(ch->base + PL080_CH_CONFIG); >>> + while ((val & PL080_CONFIG_ACTIVE) || (val & PL080_CONFIG_ENABLE)) >>> + val = readl(ch->base + PL080_CH_CONFIG); >> >> above 3 fns are always called in order, i.e. pl08x_enable_phy_chan will >> be called after pl08x_set_cregs, so we may not require these checks >> here. Is my understanding correct?? > > The previous check if the channel is active before proceeding, this check also > checks the enable bit, this behaviour comes straight from the manual and is > required to avoid hardware races, so I don't dare to touch it really... > I was talking about the similar check present in pl08x_set_cregs, which will be called before this routine. pl08x_set_cregs has already checked if channel is active or not. so checking active in this routine is not required. >>> + .device_alloc_chan_resources = pl08x_alloc_chan_resources, >>> + .device_free_chan_resources = pl08x_free_chan_resources, >>> + .device_prep_dma_xor = NULL, >>> + .device_prep_dma_memset = NULL, >>> + .device_prep_dma_interrupt = pl08x_prep_dma_interrupt, >>> + .device_tx_status = pl08x_dma_tx_status, >>> + .device_issue_pending = pl08x_issue_pending, >>> + .device_prep_slave_sg = pl08x_prep_slave_sg, >>> + .device_control = pl08x_control, >>> +}; >>> + >> >> One more thing linus, why do we need to create this separation between >> channels. i.e. few are for memcpy and few for slave_sg. Why don't all >> channels support everything and this is resolved at runtime. > > This is done in all in-tree drivers, the reason is (I think) that for example > the dmatest.c test client will look for: > > if (dma_has_cap(DMA_MEMCPY, dma_dev->cap_mask)) { > cnt = dmatest_add_threads(dtc, DMA_MEMCPY); > thread_count += cnt > 0 ? cnt : 0; > > So if you want to partition some channels for device I/O (typically some > which are hard-coded to some devices) and others for memcpy() you create > a slave instance for the former and a memcpy() instance for the latter. > > In this case we multiplex the memcpy and slave transfers on the few > physical channels we have, but I haven't finally decided how to handle this: > perhaps we should always set on physical channel aside for memcpy > so this won't ever fail, and then this special memcpy device entry will help. > > Ideas? Use cases? Hmmm. I am not sure, but i think we can't hard code a channel for some device. All channels should be available with both capabilities. If still there are some conditions (that you might know), where we need to hard code channels for devices, then this should come from plat data in some way. I have few more doubts that i wanted to ask. Are following supported in your driver, we need them in SPEAr: - Configure burst size of source or destination. - Configure DMA Master for src or dest. - Transfer from Peripheral to Peripheral. - Configure Width of src or dest peripheral. - Configure Flow controller of transfer. - Some callback for fixing Request line multiplexing just before initiating transfer. - Multiple sg elements in slave_sg transfer. I think it is not supported. - Control for autoincrement of addresses, both in case of memory and peripherals. viresh. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
From: Viresh KUMAR on 16 Jun 2010 00:10 On 6/16/2010 1:44 AM, Linus WALLEIJ wrote: > [Viresh] > >> On 6/14/2010 7:09 PM, Linus Walleij wrote: >> I have few more doubts that i wanted to ask. Are following supported in >> your >> driver, we need them in SPEAr: >> - Configure burst size of source or destination. > > The PrimeCell extension supports this, do you need that in things > that are not PrimeCells? In that case we need to make them generic. > >> - Configure DMA Master for src or dest. > > Right now I have an algorithm that will (on the PL080, the PL081 > has only one master) try to select AHB1 for the memory and AHB2 PL080 have 2 Masters. > for the device by checking if one address is fixed. If both or > none addresses are fixed it will simply select AHB1 for source > and AHB2 for destination. > > Please elaborate on what algorithm you need for this! In the same way, how other peripheral related data is passed to DMA driver, (like request lines), we can also pass configuration and control information. This will provide us with all features requested by me, as most of the control will be from user only. In SPEAr6xx, Memory is accessible from Master1 only but in SPEAr3xx only from Master 2, similar is the pattern with few peripherals also and so i need control over DMA channel configuration. >> - Configure Flow controller of transfer. > > Currently only done dynamically with DMA as the master for > Mem2mem, mem2per and per2mem. Mastering from the peripherals > is not supported. Do you have advanced features like that? We have JPEG controller, which acts as a flow controller for JPEG to mem transfer. (Synopsys JPEG Controller). > > Anyway it can be passed in from platform data easily. > But platform data will be passed one time only and we will not be able to do it while transferring data at run time. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
|
Pages: 1 Prev: [PATCH] refactor macros Next: drivers:tmp.c Fix warning: variable 'rc' set but not used |