* [PATCH RFC v5 0/5] MPC512x DMA slave s/g support, OF DMA lookup @ 2013-11-01 7:19 Alexander Popov [not found] ` <1383290374-17484-1-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 0 siblings, 1 reply; 16+ messages in thread From: Alexander Popov @ 2013-11-01 7:19 UTC (permalink / raw) To: Gerhard Sittig, Dan Williams, Vinod Koul, Lars-Peter Clausen, Arnd Bergmann, Anatolij Gustschin, Alexander Popov, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ, devicetree-u79uwXL29TY76Z2rM5mHXA 03.10.2013 18:00, Alexander Popov <a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>: > v2013/7/14 Gerhard Sittig <gsi-ynQEQJNshbs@public.gmane.org>: >> this series >> - introduces slave s/g support (that's support for DMA transfers which >> involve peripherals in contrast to mem-to-mem transfers) >> - adds device tree based lookup support for DMA channels >> - combines floating patches and related feedback which already covered >> several aspects of what the suggested LPB driver needs, to demonstrate >> how integration might be done >> - carries Q&D SD card support to enable another DMA client during test, >> while this patch needs to get dropped upon pickup >> Changes in v2: >> - re-order mpc8308 related code paths for improved readability, no >> change in behaviour, introduction of symbolic channel names here >> already >> - squash 'execute() start condition' and 'terminate all' into the >> introduction of 'slave s/g prep' and 'device control' support; refuse >> s/g lists with more than one item since slave support is operational >> yet proper s/g support is missing (can get addressed later) >> - always start transfers from software on MPC8308 as there are no >> external request lines for peripheral flow control >> - drop dt-bindings header file and symbolic channel names in OF nodes Changes in v3 and v4: > Part 1/5: > - use #define instead of enum since individual channels don't require > special handling. > Part 2/5: > - add a flag "will_access_peripheral" to DMA transfer descriptor > according recommendations of Gerhard Sittig. > This flag is set in mpc_dma_prep_memcpy() and mpc_dma_prep_slave_sg() > and is evaluated in mpc_dma_execute() to choose a type of start for > the transfer. > - prevent descriptors of transfers which involve peripherals from > being chained together; > each of such transfers needs hardware initiated start. > - add locking while working with struct mpc_dma_chan > according recommendations of Lars-Peter Clausen. > - remove default nbytes value. Client kernel modules must set > src_maxburst and dst_maxburst fields of struct dma_slave_config (dmaengine.h). Changes in v5: Part 2/5:: - add and improve comments; - improve the code moving transfer descriptors from 'queued' to 'active' list in mpc_dma_execute(); - allow mpc_dma_prep_slave_sg() to run with non-empty 'active' list; - take 'mdesc' back to 'free' list in case of error in mpc_dma_prep_slave_sg(); - improve checks of the transfer parameters; - provide the default value for 'maxburst' in mpc_dma_device_control(). Last changes are tested on MPC5125 - with SCLPC driver (transfers between dev and mem work fine); - with dmatest module (all 64 DMA channels can perform mem-to-mem transfers which are chained correctly now). >> known issues: >> - it's yet to get confirmed whether MPC8308 can use slave support or >> whether the DMA controller's driver shall actively reject it, the >> information that's available so far suggests that peripheral transfers >> to IP bus attached I/O is useful and shall not get blocked right away - adding support for transfers which don't increment the RAM address or do increment the peripheral "port's" address is easy with this implementation; but which options of the common API should be used for specifying such transfers? Alexander Popov (2): dma: mpc512x: reorder mpc8308 specific instructions dma: mpc512x: add support for peripheral transfers Gerhard Sittig (2): dma: mpc512x: register for device tree channel lookup HACK mmc: mxcmmc: enable clocks for the MPC512x Lars-Peter Clausen (1): dma: of: Add common xlate function for matching by channel id .../devicetree/bindings/dma/mpc512x-dma.txt | 55 ++++ arch/powerpc/boot/dts/mpc5121.dtsi | 1 + drivers/dma/mpc512x_dma.c | 295 +++++++++++++++++++-- drivers/dma/of-dma.c | 47 ++++ drivers/mmc/host/mxcmmc.c | 41 ++- include/linux/of_dma.h | 4 + 6 files changed, 404 insertions(+), 39 deletions(-) create mode 100644 Documentation/devicetree/bindings/dma/mpc512x-dma.txt -- 1.7.11.3 -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 16+ messages in thread
[parent not found: <1383290374-17484-1-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>]
* [PATCH RFC v5 1/5] dma: mpc512x: reorder mpc8308 specific instructions [not found] ` <1383290374-17484-1-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> @ 2013-11-01 7:19 ` Alexander Popov [not found] ` <1383290374-17484-2-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2013-11-01 7:19 ` [PATCH RFC v5 2/5] dma: mpc512x: add support for peripheral transfers Alexander Popov ` (3 subsequent siblings) 4 siblings, 1 reply; 16+ messages in thread From: Alexander Popov @ 2013-11-01 7:19 UTC (permalink / raw) To: Gerhard Sittig, Dan Williams, Vinod Koul, Lars-Peter Clausen, Arnd Bergmann, Anatolij Gustschin, Alexander Popov, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ, devicetree-u79uwXL29TY76Z2rM5mHXA Concentrate the specific code for MPC8308 in the 'if' branch and handle MPC512x in the 'else' branch. This modification only reorders instructions but doesn't change behaviour. Signed-off-by: Alexander Popov <a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> --- drivers/dma/mpc512x_dma.c | 42 +++++++++++++++++++++++++----------------- 1 file changed, 25 insertions(+), 17 deletions(-) diff --git a/drivers/dma/mpc512x_dma.c b/drivers/dma/mpc512x_dma.c index 2fe4353..f41639f 100644 --- a/drivers/dma/mpc512x_dma.c +++ b/drivers/dma/mpc512x_dma.c @@ -50,9 +50,17 @@ #define MPC_DMA_DESCRIPTORS 64 /* Macro definitions */ -#define MPC_DMA_CHANNELS 64 #define MPC_DMA_TCD_OFFSET 0x1000 +/* + * Maximum channel counts for individual hardware variants + * and the maximum channel count over all supported controllers, + * used for data structure size + */ +#define MPC8308_DMACHAN_MAX 16 +#define MPC512x_DMACHAN_MAX 64 +#define MPC_DMA_CHANNELS 64 + /* Arbitration mode of group and channel */ #define MPC_DMA_DMACR_EDCG (1 << 31) #define MPC_DMA_DMACR_ERGA (1 << 3) @@ -708,10 +716,10 @@ static int mpc_dma_probe(struct platform_device *op) dma = &mdma->dma; dma->dev = dev; - if (!mdma->is_mpc8308) - dma->chancnt = MPC_DMA_CHANNELS; + if (mdma->is_mpc8308) + dma->chancnt = MPC8308_DMACHAN_MAX; else - dma->chancnt = 16; /* MPC8308 DMA has only 16 channels */ + dma->chancnt = MPC512x_DMACHAN_MAX; dma->device_alloc_chan_resources = mpc_dma_alloc_chan_resources; dma->device_free_chan_resources = mpc_dma_free_chan_resources; dma->device_issue_pending = mpc_dma_issue_pending; @@ -745,7 +753,19 @@ static int mpc_dma_probe(struct platform_device *op) * - Round-robin group arbitration, * - Round-robin channel arbitration. */ - if (!mdma->is_mpc8308) { + if (mdma->is_mpc8308) { + /* MPC8308 has 16 channels and lacks some registers */ + out_be32(&mdma->regs->dmacr, MPC_DMA_DMACR_ERCA); + + /* enable snooping */ + out_be32(&mdma->regs->dmagpor, MPC_DMA_DMAGPOR_SNOOP_ENABLE); + /* Disable error interrupts */ + out_be32(&mdma->regs->dmaeeil, 0); + + /* Clear interrupts status */ + out_be32(&mdma->regs->dmaintl, 0xFFFF); + out_be32(&mdma->regs->dmaerrl, 0xFFFF); + } else { out_be32(&mdma->regs->dmacr, MPC_DMA_DMACR_EDCG | MPC_DMA_DMACR_ERGA | MPC_DMA_DMACR_ERCA); @@ -766,18 +786,6 @@ static int mpc_dma_probe(struct platform_device *op) /* Route interrupts to IPIC */ out_be32(&mdma->regs->dmaihsa, 0); out_be32(&mdma->regs->dmailsa, 0); - } else { - /* MPC8308 has 16 channels and lacks some registers */ - out_be32(&mdma->regs->dmacr, MPC_DMA_DMACR_ERCA); - - /* enable snooping */ - out_be32(&mdma->regs->dmagpor, MPC_DMA_DMAGPOR_SNOOP_ENABLE); - /* Disable error interrupts */ - out_be32(&mdma->regs->dmaeeil, 0); - - /* Clear interrupts status */ - out_be32(&mdma->regs->dmaintl, 0xFFFF); - out_be32(&mdma->regs->dmaerrl, 0xFFFF); } /* Register DMA engine */ -- 1.7.11.3 -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply related [flat|nested] 16+ messages in thread
[parent not found: <1383290374-17484-2-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>]
* Re: [PATCH RFC v5 1/5] dma: mpc512x: reorder mpc8308 specific instructions [not found] ` <1383290374-17484-2-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> @ 2013-11-01 10:04 ` Anatolij Gustschin 0 siblings, 0 replies; 16+ messages in thread From: Anatolij Gustschin @ 2013-11-01 10:04 UTC (permalink / raw) To: Alexander Popov Cc: Gerhard Sittig, Dan Williams, Vinod Koul, Lars-Peter Clausen, Arnd Bergmann, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ, devicetree-u79uwXL29TY76Z2rM5mHXA On Fri, 1 Nov 2013 11:19:30 +0400 Alexander Popov <a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> wrote: > Concentrate the specific code for MPC8308 in the 'if' branch > and handle MPC512x in the 'else' branch. > This modification only reorders instructions but doesn't change behaviour. > > Signed-off-by: Alexander Popov <a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> > --- > drivers/dma/mpc512x_dma.c | 42 +++++++++++++++++++++++++----------------- > 1 file changed, 25 insertions(+), 17 deletions(-) Acked-by: Anatolij Gustschin <agust-ynQEQJNshbs@public.gmane.org> > > diff --git a/drivers/dma/mpc512x_dma.c b/drivers/dma/mpc512x_dma.c > index 2fe4353..f41639f 100644 > --- a/drivers/dma/mpc512x_dma.c > +++ b/drivers/dma/mpc512x_dma.c > @@ -50,9 +50,17 @@ > #define MPC_DMA_DESCRIPTORS 64 > > /* Macro definitions */ > -#define MPC_DMA_CHANNELS 64 > #define MPC_DMA_TCD_OFFSET 0x1000 > > +/* > + * Maximum channel counts for individual hardware variants > + * and the maximum channel count over all supported controllers, > + * used for data structure size > + */ > +#define MPC8308_DMACHAN_MAX 16 > +#define MPC512x_DMACHAN_MAX 64 > +#define MPC_DMA_CHANNELS 64 > + > /* Arbitration mode of group and channel */ > #define MPC_DMA_DMACR_EDCG (1 << 31) > #define MPC_DMA_DMACR_ERGA (1 << 3) > @@ -708,10 +716,10 @@ static int mpc_dma_probe(struct platform_device *op) > > dma = &mdma->dma; > dma->dev = dev; > - if (!mdma->is_mpc8308) > - dma->chancnt = MPC_DMA_CHANNELS; > + if (mdma->is_mpc8308) > + dma->chancnt = MPC8308_DMACHAN_MAX; > else > - dma->chancnt = 16; /* MPC8308 DMA has only 16 channels */ > + dma->chancnt = MPC512x_DMACHAN_MAX; > dma->device_alloc_chan_resources = mpc_dma_alloc_chan_resources; > dma->device_free_chan_resources = mpc_dma_free_chan_resources; > dma->device_issue_pending = mpc_dma_issue_pending; > @@ -745,7 +753,19 @@ static int mpc_dma_probe(struct platform_device *op) > * - Round-robin group arbitration, > * - Round-robin channel arbitration. > */ > - if (!mdma->is_mpc8308) { > + if (mdma->is_mpc8308) { > + /* MPC8308 has 16 channels and lacks some registers */ > + out_be32(&mdma->regs->dmacr, MPC_DMA_DMACR_ERCA); > + > + /* enable snooping */ > + out_be32(&mdma->regs->dmagpor, MPC_DMA_DMAGPOR_SNOOP_ENABLE); > + /* Disable error interrupts */ > + out_be32(&mdma->regs->dmaeeil, 0); > + > + /* Clear interrupts status */ > + out_be32(&mdma->regs->dmaintl, 0xFFFF); > + out_be32(&mdma->regs->dmaerrl, 0xFFFF); > + } else { > out_be32(&mdma->regs->dmacr, MPC_DMA_DMACR_EDCG | > MPC_DMA_DMACR_ERGA | MPC_DMA_DMACR_ERCA); > > @@ -766,18 +786,6 @@ static int mpc_dma_probe(struct platform_device *op) > /* Route interrupts to IPIC */ > out_be32(&mdma->regs->dmaihsa, 0); > out_be32(&mdma->regs->dmailsa, 0); > - } else { > - /* MPC8308 has 16 channels and lacks some registers */ > - out_be32(&mdma->regs->dmacr, MPC_DMA_DMACR_ERCA); > - > - /* enable snooping */ > - out_be32(&mdma->regs->dmagpor, MPC_DMA_DMAGPOR_SNOOP_ENABLE); > - /* Disable error interrupts */ > - out_be32(&mdma->regs->dmaeeil, 0); > - > - /* Clear interrupts status */ > - out_be32(&mdma->regs->dmaintl, 0xFFFF); > - out_be32(&mdma->regs->dmaerrl, 0xFFFF); > } > > /* Register DMA engine */ -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 16+ messages in thread
* [PATCH RFC v5 2/5] dma: mpc512x: add support for peripheral transfers [not found] ` <1383290374-17484-1-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2013-11-01 7:19 ` [PATCH RFC v5 1/5] dma: mpc512x: reorder mpc8308 specific instructions Alexander Popov @ 2013-11-01 7:19 ` Alexander Popov [not found] ` <1383290374-17484-3-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2013-11-01 7:19 ` [PATCH RFC v5 3/5] dma: of: Add common xlate function for matching by channel id Alexander Popov ` (2 subsequent siblings) 4 siblings, 1 reply; 16+ messages in thread From: Alexander Popov @ 2013-11-01 7:19 UTC (permalink / raw) To: Gerhard Sittig, Dan Williams, Vinod Koul, Lars-Peter Clausen, Arnd Bergmann, Anatolij Gustschin, Alexander Popov, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ, devicetree-u79uwXL29TY76Z2rM5mHXA Introduce support for slave s/g transfer preparation and the associated device control callback in the MPC512x DMA controller driver, which adds support for data transfers between memory and peripheral I/O to the previously supported mem-to-mem transfers. Signed-off-by: Alexander Popov <a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> --- drivers/dma/mpc512x_dma.c | 232 +++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 227 insertions(+), 5 deletions(-) diff --git a/drivers/dma/mpc512x_dma.c b/drivers/dma/mpc512x_dma.c index f41639f..d2ec42d 100644 --- a/drivers/dma/mpc512x_dma.c +++ b/drivers/dma/mpc512x_dma.c @@ -2,6 +2,7 @@ * Copyright (C) Freescale Semicondutor, Inc. 2007, 2008. * Copyright (C) Semihalf 2009 * Copyright (C) Ilya Yanok, Emcraft Systems 2010 + * Copyright (C) Alexander Popov, Promcontroller 2013 * * Written by Piotr Ziecik <kosmo-nYOzD4b6Jr9Wk0Htik3J/w@public.gmane.org>. Hardware description * (defines, structures and comments) was taken from MPC5121 DMA driver @@ -29,8 +30,15 @@ */ /* - * This is initial version of MPC5121 DMA driver. Only memory to memory - * transfers are supported (tested using dmatest module). + * This version of MPC5121 DMA driver supports + * memory to memory data transfers (tested using dmatest module) and + * data transfers between memory and peripheral I/O memory + * by means of slave s/g with these limitations: + * - chunked transfers (transfers with more than one part) are refused + * as long as proper support for scatter/gather is missing; + * - transfers on MPC8308 always start from software as this SoC appears + * not to have external request lines for peripheral flow control; + * - minimal memory <-> I/O memory transfer size is 4 bytes. */ #include <linux/module.h> @@ -187,6 +195,7 @@ struct mpc_dma_desc { dma_addr_t tcd_paddr; int error; struct list_head node; + int will_access_peripheral; }; struct mpc_dma_chan { @@ -199,6 +208,10 @@ struct mpc_dma_chan { struct mpc_dma_tcd *tcd; dma_addr_t tcd_paddr; + /* Settings for access to peripheral FIFO */ + dma_addr_t per_paddr; /* FIFO address */ + u32 tcd_nunits; + /* Lock for this structure */ spinlock_t lock; }; @@ -249,8 +262,21 @@ static void mpc_dma_execute(struct mpc_dma_chan *mchan) struct mpc_dma_desc *mdesc; int cid = mchan->chan.chan_id; - /* Move all queued descriptors to active list */ - list_splice_tail_init(&mchan->queued, &mchan->active); + while (!list_empty(&mchan->queued)) { + mdesc = list_first_entry(&mchan->queued, + struct mpc_dma_desc, node); + + /* Grab either several mem-to-mem transfer descriptors + * or one peripheral transfer descriptor, + * don't mix mem-to-mem and peripheral transfer descriptors + * within the same 'active' list. */ + if (mdesc->will_access_peripheral) { + if (list_empty(&mchan->active)) + list_move_tail(&mdesc->node, &mchan->active); + break; + } else + list_move_tail(&mdesc->node, &mchan->active); + } /* Chain descriptors into one transaction */ list_for_each_entry(mdesc, &mchan->active, node) { @@ -264,6 +290,8 @@ static void mpc_dma_execute(struct mpc_dma_chan *mchan) prev->tcd->dlast_sga = mdesc->tcd_paddr; prev->tcd->e_sg = 1; + + /* software initiated start for chained transfers */ mdesc->tcd->start = 1; prev = mdesc; @@ -276,7 +304,17 @@ static void mpc_dma_execute(struct mpc_dma_chan *mchan) if (first != prev) mdma->tcd[cid].e_sg = 1; - out_8(&mdma->regs->dmassrt, cid); + + if (mdma->is_mpc8308) { + /* MPC8308, no request lines, software initiated start */ + out_8(&mdma->regs->dmassrt, cid); + } else if (first->will_access_peripheral) { + /* peripherals involved, start by external request signal */ + out_8(&mdma->regs->dmaserq, cid); + } else { + /* memory to memory transfer, software initiated start */ + out_8(&mdma->regs->dmassrt, cid); + } } /* Handle interrupt on one half of DMA controller (32 channels) */ @@ -594,6 +632,7 @@ mpc_dma_prep_memcpy(struct dma_chan *chan, dma_addr_t dst, dma_addr_t src, } mdesc->error = 0; + mdesc->will_access_peripheral = 0; tcd = mdesc->tcd; /* Prepare Transfer Control Descriptor for this transaction */ @@ -641,6 +680,186 @@ mpc_dma_prep_memcpy(struct dma_chan *chan, dma_addr_t dst, dma_addr_t src, return &mdesc->desc; } +static struct dma_async_tx_descriptor *mpc_dma_prep_slave_sg( + struct dma_chan *chan, struct scatterlist *sgl, + unsigned int sg_len, enum dma_transfer_direction direction, + unsigned long flags, void *context) +{ + struct mpc_dma *mdma = dma_chan_to_mpc_dma(chan); + struct mpc_dma_chan *mchan = dma_chan_to_mpc_dma_chan(chan); + struct mpc_dma_desc *mdesc = NULL; + dma_addr_t per_paddr; + u32 tcd_nunits; + struct mpc_dma_tcd *tcd; + unsigned long iflags; + struct scatterlist *sg; + size_t len; + int iter, i; + + /* currently there is no proper support for scatter/gather */ + if (sg_len != 1) + return NULL; + + for_each_sg(sgl, sg, sg_len, i) { + spin_lock_irqsave(&mchan->lock, iflags); + + mdesc = list_first_entry(&mchan->free, struct mpc_dma_desc, + node); + if (!mdesc) { + spin_unlock_irqrestore(&mchan->lock, iflags); + /* try to free completed descriptors */ + mpc_dma_process_completed(mdma); + return NULL; + } + + list_del(&mdesc->node); + + per_paddr = mchan->per_paddr; + tcd_nunits = mchan->tcd_nunits; + + spin_unlock_irqrestore(&mchan->lock, iflags); + + if (per_paddr == 0 || tcd_nunits == 0) + goto err_prep; + + mdesc->error = 0; + mdesc->will_access_peripheral = 1; + tcd = mdesc->tcd; + + /* Prepare Transfer Control Descriptor for this transaction */ + + memset(tcd, 0, sizeof(struct mpc_dma_tcd)); + + if (!IS_ALIGNED(sg_dma_address(sg), 4)) + goto err_prep; + + if (direction == DMA_DEV_TO_MEM) { + tcd->saddr = per_paddr; + tcd->daddr = sg_dma_address(sg); + tcd->soff = 0; + tcd->doff = 4; + } else if (direction == DMA_MEM_TO_DEV) { + tcd->saddr = sg_dma_address(sg); + tcd->daddr = per_paddr; + tcd->soff = 4; + tcd->doff = 0; + } else + goto err_prep; + + tcd->ssize = MPC_DMA_TSIZE_4; + tcd->dsize = MPC_DMA_TSIZE_4; + + len = sg_dma_len(sg); + tcd->nbytes = tcd_nunits * 4; + if (!IS_ALIGNED(len, tcd->nbytes)) + goto err_prep; + + iter = len / tcd->nbytes; + if (iter >= 1 << 15) { + /* len is too big */ + goto err_prep; + } else { + /* citer_linkch contains the high bits of iter */ + tcd->biter = iter & 0x1ff; + tcd->biter_linkch = iter >> 9; + tcd->citer = tcd->biter; + tcd->citer_linkch = tcd->biter_linkch; + } + + tcd->e_sg = 0; + tcd->d_req = 1; + + /* Place descriptor in prepared list */ + spin_lock_irqsave(&mchan->lock, iflags); + list_add_tail(&mdesc->node, &mchan->prepared); + spin_unlock_irqrestore(&mchan->lock, iflags); + } + + return &mdesc->desc; + + err_prep: + /* Put the descriptor back */ + spin_lock_irqsave(&mchan->lock, iflags); + list_add_tail(&mdesc->node, &mchan->free); + spin_unlock_irqrestore(&mchan->lock, iflags); + + return NULL; +} + +static int mpc_dma_device_control(struct dma_chan *chan, enum dma_ctrl_cmd cmd, + unsigned long arg) +{ + struct mpc_dma_chan *mchan; + struct mpc_dma *mdma; + struct dma_slave_config *cfg; + unsigned long flags; + + mchan = dma_chan_to_mpc_dma_chan(chan); + switch (cmd) { + case DMA_TERMINATE_ALL: + /* disable channel requests */ + mdma = dma_chan_to_mpc_dma(chan); + + spin_lock_irqsave(&mchan->lock, flags); + + out_8(&mdma->regs->dmacerq, chan->chan_id); + list_splice_tail_init(&mchan->prepared, &mchan->free); + list_splice_tail_init(&mchan->queued, &mchan->free); + list_splice_tail_init(&mchan->active, &mchan->free); + + spin_unlock_irqrestore(&mchan->lock, flags); + + return 0; + case DMA_SLAVE_CONFIG: + /* Constraints: + * - only transfers between a peripheral device and + * memory are supported; + * - minimal transfer size is 4 bytes and consequently + * source and destination addresses must be 4-byte aligned and + * transfer size must be aligned on (4 * maxburst) boundary; + * - RAM address is being incremented by minimal transfer size + * during the transfer; + * - peripheral port's address is constant during the transfer. + */ + + cfg = (void *)arg; + + if (cfg->direction != DMA_DEV_TO_MEM && + cfg->direction != DMA_MEM_TO_DEV) + return -EINVAL; + + if (cfg->src_addr_width != DMA_SLAVE_BUSWIDTH_4_BYTES && + cfg->dst_addr_width != DMA_SLAVE_BUSWIDTH_4_BYTES) + return -EINVAL; + + spin_lock_irqsave(&mchan->lock, flags); + + if (cfg->direction == DMA_DEV_TO_MEM) { + mchan->per_paddr = cfg->src_addr; + mchan->tcd_nunits = cfg->src_maxburst; + } else { + mchan->per_paddr = cfg->dst_addr; + mchan->tcd_nunits = cfg->dst_maxburst; + } + + if (!IS_ALIGNED(mchan->per_paddr, 4)) { + spin_unlock_irqrestore(&mchan->lock, flags); + return -EINVAL; + } + + if (mchan->tcd_nunits == 0) + mchan->tcd_nunits = 64; /* apply default */ + + spin_unlock_irqrestore(&mchan->lock, flags); + + return 0; + default: + return -ENOSYS; + } + + return -EINVAL; +} + static int mpc_dma_probe(struct platform_device *op) { struct device_node *dn = op->dev.of_node; @@ -725,9 +944,12 @@ static int mpc_dma_probe(struct platform_device *op) dma->device_issue_pending = mpc_dma_issue_pending; dma->device_tx_status = mpc_dma_tx_status; dma->device_prep_dma_memcpy = mpc_dma_prep_memcpy; + dma->device_prep_slave_sg = mpc_dma_prep_slave_sg; + dma->device_control = mpc_dma_device_control; INIT_LIST_HEAD(&dma->channels); dma_cap_set(DMA_MEMCPY, dma->cap_mask); + dma_cap_set(DMA_SLAVE, dma->cap_mask); for (i = 0; i < dma->chancnt; i++) { mchan = &mdma->channels[i]; -- 1.7.11.3 -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply related [flat|nested] 16+ messages in thread
[parent not found: <1383290374-17484-3-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>]
* Re: [PATCH RFC v5 2/5] dma: mpc512x: add support for peripheral transfers [not found] ` <1383290374-17484-3-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> @ 2013-11-11 20:10 ` Gerhard Sittig [not found] ` <20131111201024.GR17929-kDjWylLy9wD0K7fsECOQyeGNnDKD8DIp@public.gmane.org> 0 siblings, 1 reply; 16+ messages in thread From: Gerhard Sittig @ 2013-11-11 20:10 UTC (permalink / raw) To: Alexander Popov Cc: Dan Williams, Vinod Koul, Lars-Peter Clausen, Arnd Bergmann, Anatolij Gustschin, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ, devicetree-u79uwXL29TY76Z2rM5mHXA On Fri, Nov 01, 2013 at 11:19 +0400, Alexander Popov wrote: > > Introduce support for slave s/g transfer preparation and the associated > device control callback in the MPC512x DMA controller driver, which adds > support for data transfers between memory and peripheral I/O to the > previously supported mem-to-mem transfers. Alexander, there is outstanding review feedback for a previous version of the series that you haven't addressed yet. Can you please either look into those issues, or state that it's OK to leave them and why this is so? It would be nice to get a response to the feedback that you are given. It may be appropriate not to obey to the feedback, but at least it should get considered. Have you noticed the recent introduction of the dmaengine@vger ML? Make sure to include it upon the next submission. virtually yours Gerhard Sittig -- DENX Software Engineering GmbH, MD: Wolfgang Denk & Detlev Zundel HRB 165235 Munich, Office: Kirchenstr. 5, D-82194 Groebenzell, Germany Phone: +49-8142-66989-0 Fax: +49-8142-66989-80 Email: office-ynQEQJNshbs@public.gmane.org -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 16+ messages in thread
[parent not found: <20131111201024.GR17929-kDjWylLy9wD0K7fsECOQyeGNnDKD8DIp@public.gmane.org>]
* Re: [PATCH RFC v5 2/5] dma: mpc512x: add support for peripheral transfers [not found] ` <20131111201024.GR17929-kDjWylLy9wD0K7fsECOQyeGNnDKD8DIp@public.gmane.org> @ 2013-11-12 12:23 ` Alexander Popov [not found] ` <CAF0T0X5mCEiS88YGGjSS6oGU5RaQ=2PEQFL533OjpQzmc398rA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> 0 siblings, 1 reply; 16+ messages in thread From: Alexander Popov @ 2013-11-12 12:23 UTC (permalink / raw) To: Gerhard Sittig, Dan Williams, Vinod Koul, Lars-Peter Clausen, Arnd Bergmann, Anatolij Gustschin, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ, devicetree-u79uwXL29TY76Z2rM5mHXA, Alexander Popov Hello, Gerhard! 2013/11/12 Gerhard Sittig <gsi-ynQEQJNshbs@public.gmane.org>: > Alexander, there is outstanding review feedback for a previous > version of the series that you haven't addressed yet. Can you > please either look into those issues, or state that it's OK to > leave them and why this is so? Excuse me for misunderstanding, Gerhard. I have thoroughly worked on your feedback to RFCv4 and agreed to your points. So I've just wrote RFCv5. And all the improvements and known issues based on your feedback are listed in the cover letter [PATCH RFC v5 0/5]. > It would be nice to get a > response to the feedback that you are given. It may be > appropriate not to obey to the feedback, but at least it should > get considered. Yes, I see. My implicit response by RFCv5 was not efficient, sorry. Now should I write a detailed answer in the thread with your feedback for improving readability of the discussion? > Have you noticed the recent introduction of the dmaengine@vger > ML? No, I didn't. >Make sure to include it upon the next submission. Ok, I will. Thanks. Best regards, Alexander. -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 16+ messages in thread
[parent not found: <CAF0T0X5mCEiS88YGGjSS6oGU5RaQ=2PEQFL533OjpQzmc398rA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>]
* Re: [PATCH RFC v5 2/5] dma: mpc512x: add support for peripheral transfers [not found] ` <CAF0T0X5mCEiS88YGGjSS6oGU5RaQ=2PEQFL533OjpQzmc398rA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> @ 2013-11-14 20:58 ` Gerhard Sittig [not found] ` <20131114205810.GH17929-kDjWylLy9wD0K7fsECOQyeGNnDKD8DIp@public.gmane.org> 0 siblings, 1 reply; 16+ messages in thread From: Gerhard Sittig @ 2013-11-14 20:58 UTC (permalink / raw) To: Alexander Popov Cc: Dan Williams, Vinod Koul, Lars-Peter Clausen, Arnd Bergmann, Anatolij Gustschin, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ, devicetree-u79uwXL29TY76Z2rM5mHXA On Tue, Nov 12, 2013 at 16:23 +0400, Alexander Popov wrote: > > 2013/11/12 Gerhard Sittig <gsi-ynQEQJNshbs@public.gmane.org>: > > > > It would be nice to get a response to the feedback that you > > are given. It may be appropriate not to obey to the > > feedback, but at least it should get considered. > > Yes, I see. My implicit response by RFCv5 was not efficient, > sorry. Now should I write a detailed answer in the thread with > your feedback for improving readability of the discussion? Don't you have a checklist of which feedback you got and which of it you did address and which you didn't? Reviewers don't usually do the tracking for those who do the submissions. I think that you may list "pending issues" or "non-issues" either with new submissions or at the previous version's feedback, whatever is more appropriate. Maybe "pending" is useful with the new announcement, while "won't, need not" is better kept with the reviews. As for the not yet addressed feedback: From the top of my head I can think of the execute comment which contradicts the code (which suggests that at least one of them is wrong), and the data type mismatch in the config routine (where code just happens to work by coincidence). And in bypassing I noticed that your recent submission has coding style issues (braces, indentation), which should no longer happen after several iterations as you should know how to prepare and check the next version. Again: It may be OK to not follow the advice (especially if you get multiple responses of differrent direction, or when you are more familiar with the subject than an observer). But you should state when you don't agree and why. Without feedback, reviewers may see several submissions which suffer from the same issues, and expect more to show up and thus feel that their feedback is getting ignored. Which quickly becomes tiring. virtually yours Gerhard Sittig -- DENX Software Engineering GmbH, MD: Wolfgang Denk & Detlev Zundel HRB 165235 Munich, Office: Kirchenstr. 5, D-82194 Groebenzell, Germany Phone: +49-8142-66989-0 Fax: +49-8142-66989-80 Email: office-ynQEQJNshbs@public.gmane.org -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 16+ messages in thread
[parent not found: <20131114205810.GH17929-kDjWylLy9wD0K7fsECOQyeGNnDKD8DIp@public.gmane.org>]
* Re: [PATCH RFC v5 2/5] dma: mpc512x: add support for peripheral transfers [not found] ` <20131114205810.GH17929-kDjWylLy9wD0K7fsECOQyeGNnDKD8DIp@public.gmane.org> @ 2013-11-20 6:49 ` Alexander Popov 0 siblings, 0 replies; 16+ messages in thread From: Alexander Popov @ 2013-11-20 6:49 UTC (permalink / raw) To: Gerhard Sittig, Dan Williams, Vinod Koul, Lars-Peter Clausen, Arnd Bergmann, Anatolij Gustschin, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ, devicetree-u79uwXL29TY76Z2rM5mHXA, Alexander Popov 2013/11/15 Gerhard Sittig <gsi-ynQEQJNshbs@public.gmane.org>: > As for the not yet addressed feedback: From the top of my head I > can think of the execute comment which contradicts the code > (which suggests that at least one of them is wrong), and the data > type mismatch in the config routine (where code just happens to > work by coincidence). And in bypassing I noticed that your > recent submission has coding style issues (braces, indentation), > which should no longer happen after several iterations as you > should know how to prepare and check the next version. I'll doublecheck this and return with improved code. > Without feedback, reviewers > may see several submissions which suffer from the same issues, > and expect more to show up and thus feel that their feedback is > getting ignored. Which quickly becomes tiring. Thanks for your patience and comprehensive replies. Best regards, Alexander. -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 16+ messages in thread
* [PATCH RFC v5 3/5] dma: of: Add common xlate function for matching by channel id [not found] ` <1383290374-17484-1-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2013-11-01 7:19 ` [PATCH RFC v5 1/5] dma: mpc512x: reorder mpc8308 specific instructions Alexander Popov 2013-11-01 7:19 ` [PATCH RFC v5 2/5] dma: mpc512x: add support for peripheral transfers Alexander Popov @ 2013-11-01 7:19 ` Alexander Popov [not found] ` <1383290374-17484-4-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2013-11-01 7:19 ` [PATCH RFC v5 4/5] dma: mpc512x: register for device tree channel lookup Alexander Popov 2013-11-01 7:19 ` [PATCH RFC v5 5/5] HACK mmc: mxcmmc: enable clocks for the MPC512x Alexander Popov 4 siblings, 1 reply; 16+ messages in thread From: Alexander Popov @ 2013-11-01 7:19 UTC (permalink / raw) To: Gerhard Sittig, Dan Williams, Vinod Koul, Lars-Peter Clausen, Arnd Bergmann, Anatolij Gustschin, Alexander Popov, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ, devicetree-u79uwXL29TY76Z2rM5mHXA From: Lars-Peter Clausen <lars-Qo5EllUWu/uELgA04lAiVw@public.gmane.org> This patch adds a new common OF dma xlate callback function which will match a channel by it's id. The binding expects one integer argument which it will use to lookup the channel by the id. Unlike of_dma_simple_xlate this function is able to handle a system with multiple DMA controllers. When registering the of dma provider with of_dma_controller_register a pointer to the dma_device struct which is associated with the dt node needs to passed as the data parameter. The filter function will use this pointer to match only channels which belong to the specified DMA controller. Signed-off-by: Lars-Peter Clausen <lars-Qo5EllUWu/uELgA04lAiVw@public.gmane.org> Signed-off-by: Gerhard Sittig <gsi-ynQEQJNshbs@public.gmane.org> --- drivers/dma/of-dma.c | 47 +++++++++++++++++++++++++++++++++++++++++++++++ include/linux/of_dma.h | 4 ++++ 2 files changed, 51 insertions(+) diff --git a/drivers/dma/of-dma.c b/drivers/dma/of-dma.c index 0b88dd3..aa9c425 100644 --- a/drivers/dma/of-dma.c +++ b/drivers/dma/of-dma.c @@ -215,3 +215,50 @@ struct dma_chan *of_dma_simple_xlate(struct of_phandle_args *dma_spec, &dma_spec->args[0]); } EXPORT_SYMBOL_GPL(of_dma_simple_xlate); + +struct of_dma_filter_by_chan_id_args { + struct dma_device *dev; + unsigned int chan_id; +}; + +static bool of_dma_filter_by_chan_id(struct dma_chan *chan, void *params) +{ + struct of_dma_filter_by_chan_id_args *args = params; + + return chan->device == args->dev && chan->chan_id == args->chan_id; +} + +/** + * of_dma_xlate_by_chan_id - Translate dt property to DMA channel by channel id + * @dma_spec: pointer to DMA specifier as found in the device tree + * @of_dma: pointer to DMA controller data + * + * This function can be used as the of xlate callback for DMA driver which wants + * to match the channel based on the channel id. When using this xlate function + * the #dma-cells propety of the DMA controller dt node needs to be set to 1. + * The data parameter of of_dma_controller_register must be a pointer to the + * dma_device struct the function should match upon. + * + * Returns pointer to appropriate dma channel on success or NULL on error. + */ +struct dma_chan *of_dma_xlate_by_chan_id(struct of_phandle_args *dma_spec, + struct of_dma *ofdma) +{ + struct of_dma_filter_by_chan_id_args args; + dma_cap_mask_t cap; + + args.dev = ofdma->of_dma_data; + if (!args.dev) + return NULL; + + if (dma_spec->args_count != 1) + return NULL; + + dma_cap_zero(cap); + dma_cap_set(DMA_SLAVE, cap); + + args.chan_id = dma_spec->args[0]; + + return dma_request_channel(cap, of_dma_filter_by_chan_id, &args); +} +EXPORT_SYMBOL_GPL(of_dma_xlate_by_chan_id); diff --git a/include/linux/of_dma.h b/include/linux/of_dma.h index ae36298..56bc026 100644 --- a/include/linux/of_dma.h +++ b/include/linux/of_dma.h @@ -41,6 +41,8 @@ extern struct dma_chan *of_dma_request_slave_channel(struct device_node *np, const char *name); extern struct dma_chan *of_dma_simple_xlate(struct of_phandle_args *dma_spec, struct of_dma *ofdma); +extern struct dma_chan *of_dma_xlate_by_chan_id(struct of_phandle_args *dma_spec, + struct of_dma *ofdma); #else static inline int of_dma_controller_register(struct device_node *np, struct dma_chan *(*of_dma_xlate) @@ -66,6 +68,8 @@ static inline struct dma_chan *of_dma_simple_xlate(struct of_phandle_args *dma_s return NULL; } +#define of_dma_xlate_by_chan_id NULL + #endif #endif /* __LINUX_OF_DMA_H */ -- 1.7.11.3 -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply related [flat|nested] 16+ messages in thread
[parent not found: <1383290374-17484-4-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>]
* Re: [PATCH RFC v5 3/5] dma: of: Add common xlate function for matching by channel id [not found] ` <1383290374-17484-4-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> @ 2013-11-01 7:52 ` Arnd Bergmann [not found] ` <201311010852.05709.arnd-r2nGTMty4D4@public.gmane.org> 0 siblings, 1 reply; 16+ messages in thread From: Arnd Bergmann @ 2013-11-01 7:52 UTC (permalink / raw) To: Alexander Popov Cc: Gerhard Sittig, Dan Williams, Vinod Koul, Lars-Peter Clausen, Anatolij Gustschin, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ, devicetree-u79uwXL29TY76Z2rM5mHXA On Friday 01 November 2013, Alexander Popov wrote: > + * of_dma_xlate_by_chan_id - Translate dt property to DMA channel by channel id > + * @dma_spec: pointer to DMA specifier as found in the device tree > + * @of_dma: pointer to DMA controller data > + * > + * This function can be used as the of xlate callback for DMA driver which wants > + * to match the channel based on the channel id. When using this xlate function > + * the #dma-cells propety of the DMA controller dt node needs to be set to 1. > + * The data parameter of of_dma_controller_register must be a pointer to the > + * dma_device struct the function should match upon. > + * > + * Returns pointer to appropriate dma channel on success or NULL on error. > + */ > +struct dma_chan *of_dma_xlate_by_chan_id(struct of_phandle_args *dma_spec, > + struct of_dma *ofdma) > +{ > + struct of_dma_filter_by_chan_id_args args; > + dma_cap_mask_t cap; > + > + args.dev = ofdma->of_dma_data; > + if (!args.dev) > + return NULL; > + > + if (dma_spec->args_count != 1) > + return NULL; > + > + dma_cap_zero(cap); > + dma_cap_set(DMA_SLAVE, cap); > + > + args.chan_id = dma_spec->args[0]; > + > + return dma_request_channel(cap, of_dma_filter_by_chan_id, &args); > +} > +EXPORT_SYMBOL_GPL(of_dma_xlate_by_chan_id); This seems rather clumsy, now that we have added the dma_get_slave_channel interface. Can you try using that instead of dma_request_channel() now? -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 16+ messages in thread
[parent not found: <201311010852.05709.arnd-r2nGTMty4D4@public.gmane.org>]
* Re: [PATCH RFC v5 3/5] dma: of: Add common xlate function for matching by channel id [not found] ` <201311010852.05709.arnd-r2nGTMty4D4@public.gmane.org> @ 2013-11-07 11:33 ` Alexander Popov 0 siblings, 0 replies; 16+ messages in thread From: Alexander Popov @ 2013-11-07 11:33 UTC (permalink / raw) To: Arnd Bergmann Cc: Gerhard Sittig, Dan Williams, Vinod Koul, Lars-Peter Clausen, Anatolij Gustschin, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ, devicetree-u79uwXL29TY76Z2rM5mHXA, Alexander Popov 2013/11/1 Arnd Bergmann <arnd-r2nGTMty4D4@public.gmane.org>: > On Friday 01 November 2013, Alexander Popov wrote: >> + * of_dma_xlate_by_chan_id - Translate dt property to DMA channel by channel id >> + * @dma_spec: pointer to DMA specifier as found in the device tree >> + * @of_dma: pointer to DMA controller data > > This seems rather clumsy, now that we have added the dma_get_slave_channel interface. > Can you try using that instead of dma_request_channel() now? > Thanks, Arnd. I'll return with the fixed version. Best regards, Alexander. -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 16+ messages in thread
* [PATCH RFC v5 4/5] dma: mpc512x: register for device tree channel lookup [not found] ` <1383290374-17484-1-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> ` (2 preceding siblings ...) 2013-11-01 7:19 ` [PATCH RFC v5 3/5] dma: of: Add common xlate function for matching by channel id Alexander Popov @ 2013-11-01 7:19 ` Alexander Popov [not found] ` <1383290374-17484-5-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2013-11-01 7:19 ` [PATCH RFC v5 5/5] HACK mmc: mxcmmc: enable clocks for the MPC512x Alexander Popov 4 siblings, 1 reply; 16+ messages in thread From: Alexander Popov @ 2013-11-01 7:19 UTC (permalink / raw) To: Gerhard Sittig, Dan Williams, Vinod Koul, Lars-Peter Clausen, Arnd Bergmann, Anatolij Gustschin, Alexander Popov, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ, devicetree-u79uwXL29TY76Z2rM5mHXA From: Gerhard Sittig <gsi-ynQEQJNshbs@public.gmane.org> register the controller for device tree based lookup of DMA channels (non-fatal for backwards compatibility with older device trees), provide the '#dma-cells' property in the shared mpc5121.dtsi file, and introduce a bindings document for the MPC512x DMA controller Signed-off-by: Gerhard Sittig <gsi-ynQEQJNshbs@public.gmane.org> --- .../devicetree/bindings/dma/mpc512x-dma.txt | 55 ++++++++++++++++++++++ arch/powerpc/boot/dts/mpc5121.dtsi | 1 + drivers/dma/mpc512x_dma.c | 21 +++++++-- 3 files changed, 74 insertions(+), 3 deletions(-) create mode 100644 Documentation/devicetree/bindings/dma/mpc512x-dma.txt diff --git a/Documentation/devicetree/bindings/dma/mpc512x-dma.txt b/Documentation/devicetree/bindings/dma/mpc512x-dma.txt new file mode 100644 index 0000000..a4867d5 --- /dev/null +++ b/Documentation/devicetree/bindings/dma/mpc512x-dma.txt @@ -0,0 +1,55 @@ +* Freescale MPC512x DMA Controller + +The DMA controller in the Freescale MPC512x SoC can move blocks of +memory contents between memory and peripherals or memory to memory. + +Refer to the "Generic DMA Controller and DMA request bindings" description +in the dma.txt file for a more detailled discussion of the binding. The +MPC512x DMA engine binding follows the common scheme, but doesn't provide +support for the optional channels and requests counters (those values are +derived from the detected hardware features) and has a fixed client +specifier length of 1 integer cell (the value is the DMA channel, since +the DMA controller uses a fixed assignment of request lines per channel). + + +DMA controller node properties: + +Required properties: +- compatible: should be "fsl,mpc5121-dma" +- reg: address and size of the DMA controller's register set +- interrupts: interrupt spec for the DMA controller + +Optional properties: +- #dma-cells: must be <1>, describes the number of integer cells + needed to specify the 'dmas' property in client nodes, + strongly recommended since common client helper code + uses this property + +Example: + + dma0: dma@14000 { + compatible = "fsl,mpc5121-dma"; + reg = <0x14000 0x1800>; + interrupts = <65 0x8>; + #dma-cells = <1>; + }; + + +Client node properties: + +Required properties: +- dmas: list of DMA specifiers, consisting each of a handle + for the DMA controller and integer cells to specify + the channel used within the DMA controller +- dma-names: list of identifier strings for the DMA specifiers, + client device driver code uses these strings to + have DMA channels looked up at the controller + +Example: + + sdhc@1500 { + compatible = "fsl,mpc5121-sdhc"; + /* ... */ + dmas = <&dma0 30>; + dma-names = "rx-tx"; + }; diff --git a/arch/powerpc/boot/dts/mpc5121.dtsi b/arch/powerpc/boot/dts/mpc5121.dtsi index bd14c00..eb0058f 100644 --- a/arch/powerpc/boot/dts/mpc5121.dtsi +++ b/arch/powerpc/boot/dts/mpc5121.dtsi @@ -390,6 +390,7 @@ compatible = "fsl,mpc5121-dma"; reg = <0x14000 0x1800>; interrupts = <65 0x8>; + #dma-cells = <1>; }; }; diff --git a/drivers/dma/mpc512x_dma.c b/drivers/dma/mpc512x_dma.c index d2ec42d..9929cdc 100644 --- a/drivers/dma/mpc512x_dma.c +++ b/drivers/dma/mpc512x_dma.c @@ -48,6 +48,7 @@ #include <linux/io.h> #include <linux/slab.h> #include <linux/of_device.h> +#include <linux/of_dma.h> #include <linux/of_platform.h> #include <linux/random.h> @@ -1013,11 +1014,23 @@ static int mpc_dma_probe(struct platform_device *op) /* Register DMA engine */ dev_set_drvdata(dev, mdma); retval = dma_async_device_register(dma); - if (retval) { - devm_free_irq(dev, mdma->irq, mdma); - irq_dispose_mapping(mdma->irq); + if (retval) + goto out_irq; + + /* register with OF helpers for DMA lookups (nonfatal) */ + if (dev->of_node) { + retval = of_dma_controller_register(dev->of_node, + of_dma_xlate_by_chan_id, + mdma); + if (retval) + dev_warn(dev, "could not register for OF lookup\n"); } + return 0; + +out_irq: + devm_free_irq(dev, mdma->irq, mdma); + irq_dispose_mapping(mdma->irq); return retval; } @@ -1026,6 +1039,8 @@ static int mpc_dma_remove(struct platform_device *op) struct device *dev = &op->dev; struct mpc_dma *mdma = dev_get_drvdata(dev); + if (dev->of_node) + of_dma_controller_free(dev->of_node); dma_async_device_unregister(&mdma->dma); devm_free_irq(dev, mdma->irq, mdma); irq_dispose_mapping(mdma->irq); -- 1.7.11.3 -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply related [flat|nested] 16+ messages in thread
[parent not found: <1383290374-17484-5-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>]
* Re: [PATCH RFC v5 4/5] dma: mpc512x: register for device tree channel lookup [not found] ` <1383290374-17484-5-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> @ 2013-11-18 12:09 ` Mark Rutland [not found] ` <20131118120957.GH30853-NuALmloUBlrZROr8t4l/smS4ubULX0JqMm0uRHvK7Nw@public.gmane.org> 0 siblings, 1 reply; 16+ messages in thread From: Mark Rutland @ 2013-11-18 12:09 UTC (permalink / raw) To: Alexander Popov Cc: Gerhard Sittig, Dan Williams, Vinod Koul, Lars-Peter Clausen, Arnd Bergmann, Anatolij Gustschin, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org, devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org On Fri, Nov 01, 2013 at 07:19:33AM +0000, Alexander Popov wrote: > From: Gerhard Sittig <gsi-ynQEQJNshbs@public.gmane.org> > > register the controller for device tree based lookup of DMA channels > (non-fatal for backwards compatibility with older device trees), provide > the '#dma-cells' property in the shared mpc5121.dtsi file, and introduce > a bindings document for the MPC512x DMA controller > > Signed-off-by: Gerhard Sittig <gsi-ynQEQJNshbs@public.gmane.org> > --- > .../devicetree/bindings/dma/mpc512x-dma.txt | 55 ++++++++++++++++++++++ > arch/powerpc/boot/dts/mpc5121.dtsi | 1 + > drivers/dma/mpc512x_dma.c | 21 +++++++-- > 3 files changed, 74 insertions(+), 3 deletions(-) > create mode 100644 Documentation/devicetree/bindings/dma/mpc512x-dma.txt > > diff --git a/Documentation/devicetree/bindings/dma/mpc512x-dma.txt b/Documentation/devicetree/bindings/dma/mpc512x-dma.txt > new file mode 100644 > index 0000000..a4867d5 > --- /dev/null > +++ b/Documentation/devicetree/bindings/dma/mpc512x-dma.txt > @@ -0,0 +1,55 @@ > +* Freescale MPC512x DMA Controller > + > +The DMA controller in the Freescale MPC512x SoC can move blocks of > +memory contents between memory and peripherals or memory to memory. > + > +Refer to the "Generic DMA Controller and DMA request bindings" description > +in the dma.txt file for a more detailled discussion of the binding. The > +MPC512x DMA engine binding follows the common scheme, but doesn't provide > +support for the optional channels and requests counters (those values are > +derived from the detected hardware features) and has a fixed client > +specifier length of 1 integer cell (the value is the DMA channel, since > +the DMA controller uses a fixed assignment of request lines per channel). The fact that #dma-cells must be <1> isn't a difference from the standard binding, and needs not be described here. The meaning of the value should be in your description of #dma-cells below. I'm not sure it's worth mentioning optional channels / request counters. If anything, it would be better to update dma.txt to move the "Optional properties" to something like "Suggested properties"... > + > + > +DMA controller node properties: > + > +Required properties: > +- compatible: should be "fsl,mpc5121-dma" > +- reg: address and size of the DMA controller's register set > +- interrupts: interrupt spec for the DMA controller > + > +Optional properties: > +- #dma-cells: must be <1>, describes the number of integer cells > + needed to specify the 'dmas' property in client nodes, > + strongly recommended since common client helper code > + uses this property Rather than redundantly describing what the standard property means, it would be better to describe what the cell actually means (i.e. which value maps to which DMA channel in hardware, how many their are, etc). > + > +Example: > + > + dma0: dma@14000 { > + compatible = "fsl,mpc5121-dma"; > + reg = <0x14000 0x1800>; > + interrupts = <65 0x8>; > + #dma-cells = <1>; > + }; > + > + > +Client node properties: > + > +Required properties: > +- dmas: list of DMA specifiers, consisting each of a handle > + for the DMA controller and integer cells to specify > + the channel used within the DMA controller > +- dma-names: list of identifier strings for the DMA specifiers, > + client device driver code uses these strings to > + have DMA channels looked up at the controller > + I don't think its necessary or helpful to describe the client binding here, it's in dma.txt Thanks, Mark. -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 16+ messages in thread
[parent not found: <20131118120957.GH30853-NuALmloUBlrZROr8t4l/smS4ubULX0JqMm0uRHvK7Nw@public.gmane.org>]
* Re: [PATCH RFC v5 4/5] dma: mpc512x: register for device tree channel lookup [not found] ` <20131118120957.GH30853-NuALmloUBlrZROr8t4l/smS4ubULX0JqMm0uRHvK7Nw@public.gmane.org> @ 2013-11-18 14:31 ` Arnd Bergmann [not found] ` <201311181531.54818.arnd-r2nGTMty4D4@public.gmane.org> 0 siblings, 1 reply; 16+ messages in thread From: Arnd Bergmann @ 2013-11-18 14:31 UTC (permalink / raw) To: Mark Rutland Cc: Alexander Popov, Gerhard Sittig, Dan Williams, Vinod Koul, Lars-Peter Clausen, Anatolij Gustschin, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org, devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org On Monday 18 November 2013, Mark Rutland wrote: > > +++ b/Documentation/devicetree/bindings/dma/mpc512x-dma.txt > > @@ -0,0 +1,55 @@ > > +* Freescale MPC512x DMA Controller > > + > > +The DMA controller in the Freescale MPC512x SoC can move blocks of > > +memory contents between memory and peripherals or memory to memory. > > + > > +Refer to the "Generic DMA Controller and DMA request bindings" description > > +in the dma.txt file for a more detailled discussion of the binding. The > > +MPC512x DMA engine binding follows the common scheme, but doesn't provide > > +support for the optional channels and requests counters (those values are > > +derived from the detected hardware features) and has a fixed client > > +specifier length of 1 integer cell (the value is the DMA channel, since > > +the DMA controller uses a fixed assignment of request lines per channel). > > The fact that #dma-cells must be <1> isn't a difference from the > standard binding, and needs not be described here. The meaning of the > value should be in your description of #dma-cells below. I think the value it has to be in there, and I have in the past asked other people to add this. Note that in the generic binding, it says that it must be "at least 1". You can have controllers that require a larger number, or that can use 1 or 2 alternatively, depending on how the device is wired up, e.g. when a dma controller has two master ports you would need a second cell to specify the port number, but only if more than one port is actually connected to a slave. > I'm not sure it's worth mentioning optional channels / request counters. > If anything, it would be better to update dma.txt to move the "Optional > properties" to something like "Suggested properties"... These are less clearly defined. In the generic binding, it's mostly a matter of "if you need to pass this information, use these properties". The individual binding can then make them mandatory if needed. Arnd -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 16+ messages in thread
[parent not found: <201311181531.54818.arnd-r2nGTMty4D4@public.gmane.org>]
* Re: [PATCH RFC v5 4/5] dma: mpc512x: register for device tree channel lookup [not found] ` <201311181531.54818.arnd-r2nGTMty4D4@public.gmane.org> @ 2013-11-18 15:23 ` Mark Rutland 0 siblings, 0 replies; 16+ messages in thread From: Mark Rutland @ 2013-11-18 15:23 UTC (permalink / raw) To: Arnd Bergmann Cc: Alexander Popov, Gerhard Sittig, Dan Williams, Vinod Koul, Lars-Peter Clausen, Anatolij Gustschin, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org, devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org On Mon, Nov 18, 2013 at 02:31:54PM +0000, Arnd Bergmann wrote: > On Monday 18 November 2013, Mark Rutland wrote: > > > +++ b/Documentation/devicetree/bindings/dma/mpc512x-dma.txt > > > @@ -0,0 +1,55 @@ > > > +* Freescale MPC512x DMA Controller > > > + > > > +The DMA controller in the Freescale MPC512x SoC can move blocks of > > > +memory contents between memory and peripherals or memory to memory. > > > + > > > +Refer to the "Generic DMA Controller and DMA request bindings" description > > > +in the dma.txt file for a more detailled discussion of the binding. The > > > +MPC512x DMA engine binding follows the common scheme, but doesn't provide > > > +support for the optional channels and requests counters (those values are > > > +derived from the detected hardware features) and has a fixed client > > > +specifier length of 1 integer cell (the value is the DMA channel, since > > > +the DMA controller uses a fixed assignment of request lines per channel). > > > > The fact that #dma-cells must be <1> isn't a difference from the > > standard binding, and needs not be described here. The meaning of the > > value should be in your description of #dma-cells below. > > I think the value it has to be in there, and I have in the past asked other > people to add this. Note that in the generic binding, it says that it must > be "at least 1". You can have controllers that require a larger number, or > that can use 1 or 2 alternatively, depending on how the device is wired > up, e.g. when a dma controller has two master ports you would need a > second cell to specify the port number, but only if more than one port > is actually connected to a slave. The number of cells required should be described. My points were that it should be described at the property description rather than in the introduction, and that the fact that a specific value was required was not a difference from the bindings as the paragraph implied. > > > I'm not sure it's worth mentioning optional channels / request counters. > > If anything, it would be better to update dma.txt to move the "Optional > > properties" to something like "Suggested properties"... > > These are less clearly defined. In the generic binding, it's mostly a matter > of "if you need to pass this information, use these properties". The individual > binding can then make them mandatory if needed. Agreed. I'd prefer that bindings described the suggested properties they used, rather than those they don't. Thanks, Mark. -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 16+ messages in thread
* [PATCH RFC v5 5/5] HACK mmc: mxcmmc: enable clocks for the MPC512x [not found] ` <1383290374-17484-1-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> ` (3 preceding siblings ...) 2013-11-01 7:19 ` [PATCH RFC v5 4/5] dma: mpc512x: register for device tree channel lookup Alexander Popov @ 2013-11-01 7:19 ` Alexander Popov 4 siblings, 0 replies; 16+ messages in thread From: Alexander Popov @ 2013-11-01 7:19 UTC (permalink / raw) To: Gerhard Sittig, Dan Williams, Vinod Koul, Lars-Peter Clausen, Arnd Bergmann, Anatolij Gustschin, Alexander Popov, linuxppc-dev-uLR06cmDAlY/bJ5BZ2RsiQ, devicetree-u79uwXL29TY76Z2rM5mHXA From: Gerhard Sittig <gsi-ynQEQJNshbs@public.gmane.org> Q&D HACK to enable SD card support without correct COMMON_CLK support, best viewed with 'git diff -w -b', NOT acceptable for mainline (NAKed) Signed-off-by: Gerhard Sittig <gsi-ynQEQJNshbs@public.gmane.org> --- drivers/mmc/host/mxcmmc.c | 41 +++++++++++++++++++++++++++-------------- 1 file changed, 27 insertions(+), 14 deletions(-) diff --git a/drivers/mmc/host/mxcmmc.c b/drivers/mmc/host/mxcmmc.c index c174c6a..ae13bc9 100644 --- a/drivers/mmc/host/mxcmmc.c +++ b/drivers/mmc/host/mxcmmc.c @@ -1123,20 +1123,29 @@ static int mxcmci_probe(struct platform_device *pdev) host->res = r; host->irq = irq; - host->clk_ipg = devm_clk_get(&pdev->dev, "ipg"); - if (IS_ERR(host->clk_ipg)) { - ret = PTR_ERR(host->clk_ipg); - goto out_iounmap; - } + if (!is_mpc512x_mmc(host)) { + host->clk_ipg = devm_clk_get(&pdev->dev, "ipg"); + if (IS_ERR(host->clk_ipg)) { + ret = PTR_ERR(host->clk_ipg); + goto out_iounmap; + } - host->clk_per = devm_clk_get(&pdev->dev, "per"); - if (IS_ERR(host->clk_per)) { - ret = PTR_ERR(host->clk_per); - goto out_iounmap; + host->clk_per = devm_clk_get(&pdev->dev, "per"); + if (IS_ERR(host->clk_per)) { + ret = PTR_ERR(host->clk_per); + goto out_iounmap; + } + } else { + host->clk_per = devm_clk_get(&pdev->dev, "sdhc_clk"); + if (IS_ERR(host->clk_per)) { + ret = PTR_ERR(host->clk_per); + goto out_iounmap; + } } clk_prepare_enable(host->clk_per); - clk_prepare_enable(host->clk_ipg); + if (host->clk_ipg) + clk_prepare_enable(host->clk_ipg); mxcmci_softreset(host); @@ -1206,7 +1215,8 @@ out_free_dma: dma_release_channel(host->dma); out_clk_put: clk_disable_unprepare(host->clk_per); - clk_disable_unprepare(host->clk_ipg); + if (host->clk_ipg) + clk_disable_unprepare(host->clk_ipg); out_iounmap: iounmap(host->base); out_free: @@ -1236,7 +1246,8 @@ static int mxcmci_remove(struct platform_device *pdev) dma_release_channel(host->dma); clk_disable_unprepare(host->clk_per); - clk_disable_unprepare(host->clk_ipg); + if (host->clk_ipg) + clk_disable_unprepare(host->clk_ipg); release_mem_region(host->res->start, resource_size(host->res)); @@ -1255,7 +1266,8 @@ static int mxcmci_suspend(struct device *dev) if (mmc) ret = mmc_suspend_host(mmc); clk_disable_unprepare(host->clk_per); - clk_disable_unprepare(host->clk_ipg); + if (host->clk_ipg) + clk_disable_unprepare(host->clk_ipg); return ret; } @@ -1267,7 +1279,8 @@ static int mxcmci_resume(struct device *dev) int ret = 0; clk_prepare_enable(host->clk_per); - clk_prepare_enable(host->clk_ipg); + if (host->clk_ipg) + clk_prepare_enable(host->clk_ipg); if (mmc) ret = mmc_resume_host(mmc); -- 1.7.11.3 -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply related [flat|nested] 16+ messages in thread
end of thread, other threads:[~2013-11-20 6:49 UTC | newest] Thread overview: 16+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2013-11-01 7:19 [PATCH RFC v5 0/5] MPC512x DMA slave s/g support, OF DMA lookup Alexander Popov [not found] ` <1383290374-17484-1-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2013-11-01 7:19 ` [PATCH RFC v5 1/5] dma: mpc512x: reorder mpc8308 specific instructions Alexander Popov [not found] ` <1383290374-17484-2-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2013-11-01 10:04 ` Anatolij Gustschin 2013-11-01 7:19 ` [PATCH RFC v5 2/5] dma: mpc512x: add support for peripheral transfers Alexander Popov [not found] ` <1383290374-17484-3-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2013-11-11 20:10 ` Gerhard Sittig [not found] ` <20131111201024.GR17929-kDjWylLy9wD0K7fsECOQyeGNnDKD8DIp@public.gmane.org> 2013-11-12 12:23 ` Alexander Popov [not found] ` <CAF0T0X5mCEiS88YGGjSS6oGU5RaQ=2PEQFL533OjpQzmc398rA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> 2013-11-14 20:58 ` Gerhard Sittig [not found] ` <20131114205810.GH17929-kDjWylLy9wD0K7fsECOQyeGNnDKD8DIp@public.gmane.org> 2013-11-20 6:49 ` Alexander Popov 2013-11-01 7:19 ` [PATCH RFC v5 3/5] dma: of: Add common xlate function for matching by channel id Alexander Popov [not found] ` <1383290374-17484-4-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2013-11-01 7:52 ` Arnd Bergmann [not found] ` <201311010852.05709.arnd-r2nGTMty4D4@public.gmane.org> 2013-11-07 11:33 ` Alexander Popov 2013-11-01 7:19 ` [PATCH RFC v5 4/5] dma: mpc512x: register for device tree channel lookup Alexander Popov [not found] ` <1383290374-17484-5-git-send-email-a13xp0p0v88-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org> 2013-11-18 12:09 ` Mark Rutland [not found] ` <20131118120957.GH30853-NuALmloUBlrZROr8t4l/smS4ubULX0JqMm0uRHvK7Nw@public.gmane.org> 2013-11-18 14:31 ` Arnd Bergmann [not found] ` <201311181531.54818.arnd-r2nGTMty4D4@public.gmane.org> 2013-11-18 15:23 ` Mark Rutland 2013-11-01 7:19 ` [PATCH RFC v5 5/5] HACK mmc: mxcmmc: enable clocks for the MPC512x Alexander Popov
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).