diff options
author | Russell King <rmk+kernel@arm.linux.org.uk> | 2012-05-26 09:04:29 -0400 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2012-07-01 09:15:59 -0400 |
commit | 01d8dc64e92a0abace41028db5b9ca298458543f (patch) | |
tree | 3a3af4e7d0dc3a069ad70036f82fbdd010cabfa6 | |
parent | a5a488db427ef1ba637163d1a699b170c20d9789 (diff) |
dmaengine: PL08x: convert to use virt-dma structs
Convert PL08x to use the virt-dma structures.
Acked-by: Linus Walleij <linus.walleij@linaro.org>
Tested-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
-rw-r--r-- | drivers/dma/amba-pl08x.c | 57 |
1 files changed, 29 insertions, 28 deletions
diff --git a/drivers/dma/amba-pl08x.c b/drivers/dma/amba-pl08x.c index bbae30ceb8fb..9a0642805b82 100644 --- a/drivers/dma/amba-pl08x.c +++ b/drivers/dma/amba-pl08x.c | |||
@@ -86,6 +86,7 @@ | |||
86 | #include <asm/hardware/pl080.h> | 86 | #include <asm/hardware/pl080.h> |
87 | 87 | ||
88 | #include "dmaengine.h" | 88 | #include "dmaengine.h" |
89 | #include "virt-dma.h" | ||
89 | 90 | ||
90 | #define DRIVER_NAME "pl08xdmac" | 91 | #define DRIVER_NAME "pl08xdmac" |
91 | 92 | ||
@@ -165,7 +166,7 @@ struct pl08x_sg { | |||
165 | 166 | ||
166 | /** | 167 | /** |
167 | * struct pl08x_txd - wrapper for struct dma_async_tx_descriptor | 168 | * struct pl08x_txd - wrapper for struct dma_async_tx_descriptor |
168 | * @tx: async tx descriptor | 169 | * @vd: virtual DMA descriptor |
169 | * @node: node for txd list for channels | 170 | * @node: node for txd list for channels |
170 | * @dsg_list: list of children sg's | 171 | * @dsg_list: list of children sg's |
171 | * @llis_bus: DMA memory address (physical) start for the LLIs | 172 | * @llis_bus: DMA memory address (physical) start for the LLIs |
@@ -174,7 +175,7 @@ struct pl08x_sg { | |||
174 | * @ccfg: config reg values for current txd | 175 | * @ccfg: config reg values for current txd |
175 | */ | 176 | */ |
176 | struct pl08x_txd { | 177 | struct pl08x_txd { |
177 | struct dma_async_tx_descriptor tx; | 178 | struct virt_dma_desc vd; |
178 | struct list_head node; | 179 | struct list_head node; |
179 | struct list_head dsg_list; | 180 | struct list_head dsg_list; |
180 | dma_addr_t llis_bus; | 181 | dma_addr_t llis_bus; |
@@ -208,7 +209,7 @@ enum pl08x_dma_chan_state { | |||
208 | 209 | ||
209 | /** | 210 | /** |
210 | * struct pl08x_dma_chan - this structure wraps a DMA ENGINE channel | 211 | * struct pl08x_dma_chan - this structure wraps a DMA ENGINE channel |
211 | * @chan: wrappped abstract channel | 212 | * @vc: wrappped virtual channel |
212 | * @phychan: the physical channel utilized by this channel, if there is one | 213 | * @phychan: the physical channel utilized by this channel, if there is one |
213 | * @tasklet: tasklet scheduled by the IRQ to handle actual work etc | 214 | * @tasklet: tasklet scheduled by the IRQ to handle actual work etc |
214 | * @name: name of channel | 215 | * @name: name of channel |
@@ -226,7 +227,7 @@ enum pl08x_dma_chan_state { | |||
226 | * @mux_use: count of descriptors using this DMA request signal setting | 227 | * @mux_use: count of descriptors using this DMA request signal setting |
227 | */ | 228 | */ |
228 | struct pl08x_dma_chan { | 229 | struct pl08x_dma_chan { |
229 | struct dma_chan chan; | 230 | struct virt_dma_chan vc; |
230 | struct pl08x_phy_chan *phychan; | 231 | struct pl08x_phy_chan *phychan; |
231 | struct tasklet_struct tasklet; | 232 | struct tasklet_struct tasklet; |
232 | const char *name; | 233 | const char *name; |
@@ -287,12 +288,12 @@ struct pl08x_driver_data { | |||
287 | 288 | ||
288 | static inline struct pl08x_dma_chan *to_pl08x_chan(struct dma_chan *chan) | 289 | static inline struct pl08x_dma_chan *to_pl08x_chan(struct dma_chan *chan) |
289 | { | 290 | { |
290 | return container_of(chan, struct pl08x_dma_chan, chan); | 291 | return container_of(chan, struct pl08x_dma_chan, vc.chan); |
291 | } | 292 | } |
292 | 293 | ||
293 | static inline struct pl08x_txd *to_pl08x_txd(struct dma_async_tx_descriptor *tx) | 294 | static inline struct pl08x_txd *to_pl08x_txd(struct dma_async_tx_descriptor *tx) |
294 | { | 295 | { |
295 | return container_of(tx, struct pl08x_txd, tx); | 296 | return container_of(tx, struct pl08x_txd, vd.tx); |
296 | } | 297 | } |
297 | 298 | ||
298 | /* | 299 | /* |
@@ -648,14 +649,14 @@ static void pl08x_phy_free(struct pl08x_dma_chan *plchan) | |||
648 | next = NULL; | 649 | next = NULL; |
649 | 650 | ||
650 | /* Find a waiting virtual channel for the next transfer. */ | 651 | /* Find a waiting virtual channel for the next transfer. */ |
651 | list_for_each_entry(p, &pl08x->memcpy.channels, chan.device_node) | 652 | list_for_each_entry(p, &pl08x->memcpy.channels, vc.chan.device_node) |
652 | if (p->state == PL08X_CHAN_WAITING) { | 653 | if (p->state == PL08X_CHAN_WAITING) { |
653 | next = p; | 654 | next = p; |
654 | break; | 655 | break; |
655 | } | 656 | } |
656 | 657 | ||
657 | if (!next) { | 658 | if (!next) { |
658 | list_for_each_entry(p, &pl08x->slave.channels, chan.device_node) | 659 | list_for_each_entry(p, &pl08x->slave.channels, vc.chan.device_node) |
659 | if (p->state == PL08X_CHAN_WAITING) { | 660 | if (p->state == PL08X_CHAN_WAITING) { |
660 | next = p; | 661 | next = p; |
661 | break; | 662 | break; |
@@ -1351,9 +1352,9 @@ static struct pl08x_txd *pl08x_get_txd(struct pl08x_dma_chan *plchan, | |||
1351 | struct pl08x_txd *txd = kzalloc(sizeof(*txd), GFP_NOWAIT); | 1352 | struct pl08x_txd *txd = kzalloc(sizeof(*txd), GFP_NOWAIT); |
1352 | 1353 | ||
1353 | if (txd) { | 1354 | if (txd) { |
1354 | dma_async_tx_descriptor_init(&txd->tx, &plchan->chan); | 1355 | dma_async_tx_descriptor_init(&txd->vd.tx, &plchan->vc.chan); |
1355 | txd->tx.flags = flags; | 1356 | txd->vd.tx.flags = flags; |
1356 | txd->tx.tx_submit = pl08x_tx_submit; | 1357 | txd->vd.tx.tx_submit = pl08x_tx_submit; |
1357 | INIT_LIST_HEAD(&txd->node); | 1358 | INIT_LIST_HEAD(&txd->node); |
1358 | INIT_LIST_HEAD(&txd->dsg_list); | 1359 | INIT_LIST_HEAD(&txd->dsg_list); |
1359 | 1360 | ||
@@ -1413,7 +1414,7 @@ static struct dma_async_tx_descriptor *pl08x_prep_dma_memcpy( | |||
1413 | if (ret) | 1414 | if (ret) |
1414 | return NULL; | 1415 | return NULL; |
1415 | 1416 | ||
1416 | return &txd->tx; | 1417 | return &txd->vd.tx; |
1417 | } | 1418 | } |
1418 | 1419 | ||
1419 | static struct dma_async_tx_descriptor *pl08x_prep_slave_sg( | 1420 | static struct dma_async_tx_descriptor *pl08x_prep_slave_sg( |
@@ -1529,7 +1530,7 @@ static struct dma_async_tx_descriptor *pl08x_prep_slave_sg( | |||
1529 | if (ret) | 1530 | if (ret) |
1530 | return NULL; | 1531 | return NULL; |
1531 | 1532 | ||
1532 | return &txd->tx; | 1533 | return &txd->vd.tx; |
1533 | } | 1534 | } |
1534 | 1535 | ||
1535 | static int pl08x_control(struct dma_chan *chan, enum dma_ctrl_cmd cmd, | 1536 | static int pl08x_control(struct dma_chan *chan, enum dma_ctrl_cmd cmd, |
@@ -1630,11 +1631,11 @@ static void pl08x_ensure_on(struct pl08x_driver_data *pl08x) | |||
1630 | 1631 | ||
1631 | static void pl08x_unmap_buffers(struct pl08x_txd *txd) | 1632 | static void pl08x_unmap_buffers(struct pl08x_txd *txd) |
1632 | { | 1633 | { |
1633 | struct device *dev = txd->tx.chan->device->dev; | 1634 | struct device *dev = txd->vd.tx.chan->device->dev; |
1634 | struct pl08x_sg *dsg; | 1635 | struct pl08x_sg *dsg; |
1635 | 1636 | ||
1636 | if (!(txd->tx.flags & DMA_COMPL_SKIP_SRC_UNMAP)) { | 1637 | if (!(txd->vd.tx.flags & DMA_COMPL_SKIP_SRC_UNMAP)) { |
1637 | if (txd->tx.flags & DMA_COMPL_SRC_UNMAP_SINGLE) | 1638 | if (txd->vd.tx.flags & DMA_COMPL_SRC_UNMAP_SINGLE) |
1638 | list_for_each_entry(dsg, &txd->dsg_list, node) | 1639 | list_for_each_entry(dsg, &txd->dsg_list, node) |
1639 | dma_unmap_single(dev, dsg->src_addr, dsg->len, | 1640 | dma_unmap_single(dev, dsg->src_addr, dsg->len, |
1640 | DMA_TO_DEVICE); | 1641 | DMA_TO_DEVICE); |
@@ -1644,8 +1645,8 @@ static void pl08x_unmap_buffers(struct pl08x_txd *txd) | |||
1644 | DMA_TO_DEVICE); | 1645 | DMA_TO_DEVICE); |
1645 | } | 1646 | } |
1646 | } | 1647 | } |
1647 | if (!(txd->tx.flags & DMA_COMPL_SKIP_DEST_UNMAP)) { | 1648 | if (!(txd->vd.tx.flags & DMA_COMPL_SKIP_DEST_UNMAP)) { |
1648 | if (txd->tx.flags & DMA_COMPL_DEST_UNMAP_SINGLE) | 1649 | if (txd->vd.tx.flags & DMA_COMPL_DEST_UNMAP_SINGLE) |
1649 | list_for_each_entry(dsg, &txd->dsg_list, node) | 1650 | list_for_each_entry(dsg, &txd->dsg_list, node) |
1650 | dma_unmap_single(dev, dsg->dst_addr, dsg->len, | 1651 | dma_unmap_single(dev, dsg->dst_addr, dsg->len, |
1651 | DMA_FROM_DEVICE); | 1652 | DMA_FROM_DEVICE); |
@@ -1670,8 +1671,8 @@ static void pl08x_tasklet(unsigned long data) | |||
1670 | while (!list_empty(&head)) { | 1671 | while (!list_empty(&head)) { |
1671 | struct pl08x_txd *txd = list_first_entry(&head, | 1672 | struct pl08x_txd *txd = list_first_entry(&head, |
1672 | struct pl08x_txd, node); | 1673 | struct pl08x_txd, node); |
1673 | dma_async_tx_callback callback = txd->tx.callback; | 1674 | dma_async_tx_callback callback = txd->vd.tx.callback; |
1674 | void *callback_param = txd->tx.callback_param; | 1675 | void *callback_param = txd->vd.tx.callback_param; |
1675 | 1676 | ||
1676 | list_del(&txd->node); | 1677 | list_del(&txd->node); |
1677 | 1678 | ||
@@ -1732,7 +1733,7 @@ static irqreturn_t pl08x_irq(int irq, void *dev) | |||
1732 | * reservation. | 1733 | * reservation. |
1733 | */ | 1734 | */ |
1734 | pl08x_release_mux(plchan); | 1735 | pl08x_release_mux(plchan); |
1735 | dma_cookie_complete(&tx->tx); | 1736 | dma_cookie_complete(&tx->vd.tx); |
1736 | list_add_tail(&tx->node, &plchan->done_list); | 1737 | list_add_tail(&tx->node, &plchan->done_list); |
1737 | 1738 | ||
1738 | /* | 1739 | /* |
@@ -1807,8 +1808,8 @@ static int pl08x_dma_init_virtual_channels(struct pl08x_driver_data *pl08x, | |||
1807 | "initialize virtual channel \"%s\"\n", | 1808 | "initialize virtual channel \"%s\"\n", |
1808 | chan->name); | 1809 | chan->name); |
1809 | 1810 | ||
1810 | chan->chan.device = dmadev; | 1811 | chan->vc.chan.device = dmadev; |
1811 | dma_cookie_init(&chan->chan); | 1812 | dma_cookie_init(&chan->vc.chan); |
1812 | 1813 | ||
1813 | spin_lock_init(&chan->lock); | 1814 | spin_lock_init(&chan->lock); |
1814 | INIT_LIST_HEAD(&chan->pend_list); | 1815 | INIT_LIST_HEAD(&chan->pend_list); |
@@ -1817,7 +1818,7 @@ static int pl08x_dma_init_virtual_channels(struct pl08x_driver_data *pl08x, | |||
1817 | tasklet_init(&chan->tasklet, pl08x_tasklet, | 1818 | tasklet_init(&chan->tasklet, pl08x_tasklet, |
1818 | (unsigned long) chan); | 1819 | (unsigned long) chan); |
1819 | 1820 | ||
1820 | list_add_tail(&chan->chan.device_node, &dmadev->channels); | 1821 | list_add_tail(&chan->vc.chan.device_node, &dmadev->channels); |
1821 | } | 1822 | } |
1822 | dev_info(&pl08x->adev->dev, "initialized %d virtual %s channels\n", | 1823 | dev_info(&pl08x->adev->dev, "initialized %d virtual %s channels\n", |
1823 | i, slave ? "slave" : "memcpy"); | 1824 | i, slave ? "slave" : "memcpy"); |
@@ -1830,8 +1831,8 @@ static void pl08x_free_virtual_channels(struct dma_device *dmadev) | |||
1830 | struct pl08x_dma_chan *next; | 1831 | struct pl08x_dma_chan *next; |
1831 | 1832 | ||
1832 | list_for_each_entry_safe(chan, | 1833 | list_for_each_entry_safe(chan, |
1833 | next, &dmadev->channels, chan.device_node) { | 1834 | next, &dmadev->channels, vc.chan.device_node) { |
1834 | list_del(&chan->chan.device_node); | 1835 | list_del(&chan->vc.chan.device_node); |
1835 | kfree(chan); | 1836 | kfree(chan); |
1836 | } | 1837 | } |
1837 | } | 1838 | } |
@@ -1884,7 +1885,7 @@ static int pl08x_debugfs_show(struct seq_file *s, void *data) | |||
1884 | seq_printf(s, "\nPL08x virtual memcpy channels:\n"); | 1885 | seq_printf(s, "\nPL08x virtual memcpy channels:\n"); |
1885 | seq_printf(s, "CHANNEL:\tSTATE:\n"); | 1886 | seq_printf(s, "CHANNEL:\tSTATE:\n"); |
1886 | seq_printf(s, "--------\t------\n"); | 1887 | seq_printf(s, "--------\t------\n"); |
1887 | list_for_each_entry(chan, &pl08x->memcpy.channels, chan.device_node) { | 1888 | list_for_each_entry(chan, &pl08x->memcpy.channels, vc.chan.device_node) { |
1888 | seq_printf(s, "%s\t\t%s\n", chan->name, | 1889 | seq_printf(s, "%s\t\t%s\n", chan->name, |
1889 | pl08x_state_str(chan->state)); | 1890 | pl08x_state_str(chan->state)); |
1890 | } | 1891 | } |
@@ -1892,7 +1893,7 @@ static int pl08x_debugfs_show(struct seq_file *s, void *data) | |||
1892 | seq_printf(s, "\nPL08x virtual slave channels:\n"); | 1893 | seq_printf(s, "\nPL08x virtual slave channels:\n"); |
1893 | seq_printf(s, "CHANNEL:\tSTATE:\n"); | 1894 | seq_printf(s, "CHANNEL:\tSTATE:\n"); |
1894 | seq_printf(s, "--------\t------\n"); | 1895 | seq_printf(s, "--------\t------\n"); |
1895 | list_for_each_entry(chan, &pl08x->slave.channels, chan.device_node) { | 1896 | list_for_each_entry(chan, &pl08x->slave.channels, vc.chan.device_node) { |
1896 | seq_printf(s, "%s\t\t%s\n", chan->name, | 1897 | seq_printf(s, "%s\t\t%s\n", chan->name, |
1897 | pl08x_state_str(chan->state)); | 1898 | pl08x_state_str(chan->state)); |
1898 | } | 1899 | } |