From: Souptick Joarder Date: Sun, 12 Jul 2020 03:39:54 +0000 (+0530) Subject: xen/privcmd: Mark pages as dirty X-Git-Tag: v5.10.7~1694^2~33 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=a0c34d225183fd4aca61dccb50e5783fa2f26db1;p=platform%2Fkernel%2Flinux-rpi.git xen/privcmd: Mark pages as dirty pages need to be marked as dirty before unpinned it in unlock_pages() which was oversight. This is fixed now. Signed-off-by: Souptick Joarder Suggested-by: John Hubbard Reviewed-by: Juergen Gross Reviewed-by: Paul Durrant Cc: John Hubbard Cc: Boris Ostrovsky Cc: Paul Durrant Link: https://lore.kernel.org/r/1594525195-28345-3-git-send-email-jrdr.linux@gmail.com Signed-off-by: Juergen Gross --- diff --git a/drivers/xen/privcmd.c b/drivers/xen/privcmd.c index a9b2baa..aa8ca58 100644 --- a/drivers/xen/privcmd.c +++ b/drivers/xen/privcmd.c @@ -612,8 +612,11 @@ static void unlock_pages(struct page *pages[], unsigned int nr_pages) { unsigned int i; - for (i = 0; i < nr_pages; i++) + for (i = 0; i < nr_pages; i++) { + if (!PageDirty(pages[i])) + set_page_dirty_lock(pages[i]); put_page(pages[i]); + } } static long privcmd_ioctl_dm_op(struct file *file, void __user *udata)