mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-02 16:44:10 +08:00
iio: buffer-dmaengine: adjust bytes_used
with residue info
A transfer may fall shorter than the bytes in the block. This information is available in the residue from the DMA engine, so we can compute actual `bytes_used` with that by subtracting the residue. Signed-off-by: Alexandru Ardelean <alexandru.ardelean@analog.com> Signed-off-by: Lars-Peter Clausen <lars@metafoo.de> Link: https://lore.kernel.org/r/20200826052011.13348-1-lars@metafoo.de Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
This commit is contained in:
parent
e7b61fc4ca
commit
65e02d0b50
@ -45,7 +45,8 @@ static struct dmaengine_buffer *iio_buffer_to_dmaengine_buffer(
|
||||
return container_of(buffer, struct dmaengine_buffer, queue.buffer);
|
||||
}
|
||||
|
||||
static void iio_dmaengine_buffer_block_done(void *data)
|
||||
static void iio_dmaengine_buffer_block_done(void *data,
|
||||
const struct dmaengine_result *result)
|
||||
{
|
||||
struct iio_dma_buffer_block *block = data;
|
||||
unsigned long flags;
|
||||
@ -53,6 +54,7 @@ static void iio_dmaengine_buffer_block_done(void *data)
|
||||
spin_lock_irqsave(&block->queue->list_lock, flags);
|
||||
list_del(&block->head);
|
||||
spin_unlock_irqrestore(&block->queue->list_lock, flags);
|
||||
block->bytes_used -= result->residue;
|
||||
iio_dma_buffer_block_done(block);
|
||||
}
|
||||
|
||||
@ -74,7 +76,7 @@ static int iio_dmaengine_buffer_submit_block(struct iio_dma_buffer_queue *queue,
|
||||
if (!desc)
|
||||
return -ENOMEM;
|
||||
|
||||
desc->callback = iio_dmaengine_buffer_block_done;
|
||||
desc->callback_result = iio_dmaengine_buffer_block_done;
|
||||
desc->callback_param = block;
|
||||
|
||||
cookie = dmaengine_submit(desc);
|
||||
|
Loading…
Reference in New Issue
Block a user