[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <lsq.1589984009.929198316@decadent.org.uk>
Date: Wed, 20 May 2020 15:14:56 +0100
From: Ben Hutchings <ben@...adent.org.uk>
To: linux-kernel@...r.kernel.org, stable@...r.kernel.org
CC: akpm@...ux-foundation.org, Denis Kirjanov <kda@...ux-powerpc.org>,
"Jens Axboe" <axboe@...nel.dk>,
"Jerome Glisse" <jglisse@...hat.com>,
"Aneesh Kumar K.V" <aneesh.kumar@...ux.ibm.com>,
"John Hubbard" <jhubbard@...dia.com>,
"Linus Torvalds" <torvalds@...ux-foundation.org>,
"Jan Kara" <jack@...e.cz>,
"Dan Williams" <dan.j.williams@...el.com>,
"Jason Gunthorpe" <jgg@...pe.ca>,
"Hans Verkuil" <hverkuil-cisco@...all.nl>,
"Christoph Hellwig" <hch@....de>,
"Leon Romanovsky" <leonro@...lanox.com>,
"Alex Williamson" <alex.williamson@...hat.com>,
"Daniel Vetter" <daniel.vetter@...ll.ch>,
"Jonathan Corbet" <corbet@....net>,
"Jason Gunthorpe" <jgg@...lanox.com>,
"Björn Töpel"
<bjorn.topel@...el.com>, "Ira Weiny" <ira.weiny@...el.com>,
"Mike Rapoport" <rppt@...ux.ibm.com>,
"Mauro Carvalho Chehab" <mchehab@...nel.org>,
"Kirill A. Shutemov" <kirill@...temov.name>
Subject: [PATCH 3.16 88/99] media/v4l2-core: set pages dirty upon
releasing DMA buffers
3.16.84-rc1 review patch. If anyone has any objections, please let me know.
------------------
From: John Hubbard <jhubbard@...dia.com>
commit 3c7470b6f68434acae459482ab920d1e3fabd1c7 upstream.
After DMA is complete, and the device and CPU caches are synchronized,
it's still required to mark the CPU pages as dirty, if the data was
coming from the device. However, this driver was just issuing a bare
put_page() call, without any set_page_dirty*() call.
Fix the problem, by calling set_page_dirty_lock() if the CPU pages were
potentially receiving data from the device.
Link: http://lkml.kernel.org/r/20200107224558.2362728-11-jhubbard@nvidia.com
Signed-off-by: John Hubbard <jhubbard@...dia.com>
Reviewed-by: Christoph Hellwig <hch@....de>
Acked-by: Hans Verkuil <hverkuil-cisco@...all.nl>
Cc: Mauro Carvalho Chehab <mchehab@...nel.org>
Cc: Alex Williamson <alex.williamson@...hat.com>
Cc: Aneesh Kumar K.V <aneesh.kumar@...ux.ibm.com>
Cc: Björn Töpel <bjorn.topel@...el.com>
Cc: Daniel Vetter <daniel.vetter@...ll.ch>
Cc: Dan Williams <dan.j.williams@...el.com>
Cc: Ira Weiny <ira.weiny@...el.com>
Cc: Jan Kara <jack@...e.cz>
Cc: Jason Gunthorpe <jgg@...lanox.com>
Cc: Jason Gunthorpe <jgg@...pe.ca>
Cc: Jens Axboe <axboe@...nel.dk>
Cc: Jerome Glisse <jglisse@...hat.com>
Cc: Jonathan Corbet <corbet@....net>
Cc: Kirill A. Shutemov <kirill@...temov.name>
Cc: Leon Romanovsky <leonro@...lanox.com>
Cc: Mike Rapoport <rppt@...ux.ibm.com>
Signed-off-by: Andrew Morton <akpm@...ux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@...ux-foundation.org>
[bwh: Backported to 3.16: adjust context]
Signed-off-by: Ben Hutchings <ben@...adent.org.uk>
---
drivers/media/v4l2-core/videobuf-dma-sg.c | 5 ++++-
1 file changed, 4 insertions(+), 1 deletion(-)
--- a/drivers/media/v4l2-core/videobuf-dma-sg.c
+++ b/drivers/media/v4l2-core/videobuf-dma-sg.c
@@ -316,8 +316,11 @@ int videobuf_dma_free(struct videobuf_dm
BUG_ON(dma->sglen);
if (dma->pages) {
- for (i = 0; i < dma->nr_pages; i++)
+ for (i = 0; i < dma->nr_pages; i++) {
+ if (dma->direction == DMA_FROM_DEVICE)
+ set_page_dirty_lock(dma->pages[i]);
page_cache_release(dma->pages[i]);
+ }
kfree(dma->pages);
dma->pages = NULL;
}
Powered by blists - more mailing lists