cregit-Linux how code gets into the kernel

Release 4.11 drivers/dma/virt-dma.c

Directory: drivers/dma
/*
 * Virtual DMA channel support for DMAengine
 *
 * Copyright (C) 2012 Russell King
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 */
#include <linux/device.h>
#include <linux/dmaengine.h>
#include <linux/module.h>
#include <linux/spinlock.h>

#include "virt-dma.h"


static struct virt_dma_desc *to_virt_desc(struct dma_async_tx_descriptor *tx) { return container_of(tx, struct virt_dma_desc, tx); }

Contributors

PersonTokensPropCommitsCommitProp
Russell King24100.00%1100.00%
Total24100.00%1100.00%


dma_cookie_t vchan_tx_submit(struct dma_async_tx_descriptor *tx) { struct virt_dma_chan *vc = to_virt_chan(tx->chan); struct virt_dma_desc *vd = to_virt_desc(tx); unsigned long flags; dma_cookie_t cookie; spin_lock_irqsave(&vc->lock, flags); cookie = dma_cookie_assign(tx); list_move_tail(&vd->node, &vc->desc_submitted); spin_unlock_irqrestore(&vc->lock, flags); dev_dbg(vc->chan.device->dev, "vchan %p: txd %p[%x]: submitted\n", vc, vd, cookie); return cookie; }

Contributors

PersonTokensPropCommitsCommitProp
Russell King10099.01%150.00%
Robert Jarzmik10.99%150.00%
Total101100.00%2100.00%

EXPORT_SYMBOL_GPL(vchan_tx_submit); /** * vchan_tx_desc_free - free a reusable descriptor * @tx: the transfer * * This function frees a previously allocated reusable descriptor. The only * other way is to clear the DMA_CTRL_REUSE flag and submit one last time the * transfer. * * Returns 0 upon success */
int vchan_tx_desc_free(struct dma_async_tx_descriptor *tx) { struct virt_dma_chan *vc = to_virt_chan(tx->chan); struct virt_dma_desc *vd = to_virt_desc(tx); unsigned long flags; spin_lock_irqsave(&vc->lock, flags); list_del(&vd->node); spin_unlock_irqrestore(&vc->lock, flags); dev_dbg(vc->chan.device->dev, "vchan %p: txd %p[%x]: freeing\n", vc, vd, vd->tx.cookie); vc->desc_free(vd); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Robert Jarzmik97100.00%1100.00%
Total97100.00%1100.00%

EXPORT_SYMBOL_GPL(vchan_tx_desc_free);
struct virt_dma_desc *vchan_find_desc(struct virt_dma_chan *vc, dma_cookie_t cookie) { struct virt_dma_desc *vd; list_for_each_entry(vd, &vc->desc_issued, node) if (vd->tx.cookie == cookie) return vd; return NULL; }

Contributors

PersonTokensPropCommitsCommitProp
Russell King44100.00%1100.00%
Total44100.00%1100.00%

EXPORT_SYMBOL_GPL(vchan_find_desc); /* * This tasklet handles the completion of a DMA descriptor by * calling its callback and freeing it. */
static void vchan_complete(unsigned long arg) { struct virt_dma_chan *vc = (struct virt_dma_chan *)arg; struct virt_dma_desc *vd; struct dmaengine_desc_callback cb; LIST_HEAD(head); spin_lock_irq(&vc->lock); list_splice_tail_init(&vc->desc_completed, &head); vd = vc->cyclic; if (vd) { vc->cyclic = NULL; dmaengine_desc_get_callback(&vd->tx, &cb); } else { memset(&cb, 0, sizeof(cb)); } spin_unlock_irq(&vc->lock); dmaengine_desc_callback_invoke(&cb, NULL); while (!list_empty(&head)) { vd = list_first_entry(&head, struct virt_dma_desc, node); dmaengine_desc_get_callback(&vd->tx, &cb); list_del(&vd->node); if (dmaengine_desc_test_reuse(&vd->tx)) list_add(&vd->node, &vc->desc_allocated); else vc->desc_free(vd); dmaengine_desc_callback_invoke(&cb, NULL); } }

Contributors

PersonTokensPropCommitsCommitProp
Russell King13367.17%250.00%
Dave Jiang4120.71%125.00%
Robert Jarzmik2412.12%125.00%
Total198100.00%4100.00%


void vchan_dma_desc_free_list(struct virt_dma_chan *vc, struct list_head *head) { while (!list_empty(head)) { struct virt_dma_desc *vd = list_first_entry(head, struct virt_dma_desc, node); if (dmaengine_desc_test_reuse(&vd->tx)) { list_move_tail(&vd->node, &vc->desc_allocated); } else { dev_dbg(vc->chan.device->dev, "txd %p: freeing\n", vd); list_del(&vd->node); vc->desc_free(vd); } } }

Contributors

PersonTokensPropCommitsCommitProp
Russell King6970.41%150.00%
Robert Jarzmik2929.59%150.00%
Total98100.00%2100.00%

EXPORT_SYMBOL_GPL(vchan_dma_desc_free_list);
void vchan_init(struct virt_dma_chan *vc, struct dma_device *dmadev) { dma_cookie_init(&vc->chan); spin_lock_init(&vc->lock); INIT_LIST_HEAD(&vc->desc_allocated); INIT_LIST_HEAD(&vc->desc_submitted); INIT_LIST_HEAD(&vc->desc_issued); INIT_LIST_HEAD(&vc->desc_completed); tasklet_init(&vc->task, vchan_complete, (unsigned long)vc); vc->chan.device = dmadev; list_add_tail(&vc->chan.device_node, &dmadev->channels); }

Contributors

PersonTokensPropCommitsCommitProp
Russell King9492.16%150.00%
Robert Jarzmik87.84%150.00%
Total102100.00%2100.00%

EXPORT_SYMBOL_GPL(vchan_init); MODULE_AUTHOR("Russell King"); MODULE_LICENSE("GPL");

Overall Contributors

PersonTokensPropCommitsCommitProp
Russell King51171.27%360.00%
Robert Jarzmik16523.01%120.00%
Dave Jiang415.72%120.00%
Total717100.00%5100.00%
Directory: drivers/dma
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.