Thread (11 messages) 11 messages, 5 authors, 2021-04-01

Re: [PATCH] userfaultfd: Write protect when virtual memory range has no page table entry

From: Bui Quang Minh <hidden>
Date: 2021-03-23 02:48:58
Also in: lkml

On Mon, Mar 22, 2021 at 03:00:37PM +0200, Mike Rapoport wrote:
On Mon, Mar 22, 2021 at 11:14:37AM +0100, Michal Hocko wrote:
quoted
Le'ts Andrea and Mike

On Fri 19-03-21 22:24:28, Bui Quang Minh wrote:
quoted
userfaultfd_writeprotect() use change_protection() to clear write bit in
page table entries (pte/pmd). So, later write to this virtual address
range causes a page fault, which is then handled by userspace program.
However, change_protection() has no effect when there is no page table
entries associated with that virtual memory range (a newly mapped memory
range). As a result, later access to that memory range causes allocating a
page table entry with write bit still set (due to VM_WRITE flag in
vma->vm_flags).

Add checks for VM_UFFD_WP in vma->vm_flags when allocating new page table
entry in missing page table entry page fault path.
From the above it is not really clear whether this is a usability
problem or a bug of the interface.
I'd say it's usability/documentation clarity issue. 
Userspace can register an area with

	UFFDIO_REGISTER_MODE_MISSING | UFFDIO_REGISTER_MODE_WP

and then it will be notified either when page table has no entry for a
virtual address or when there is a write to a write protected address.
Yes, you are right. I saw a patch from Peter to linux-man and saw that

	"When there is only UFFDIO_REGISTER_MODE_WP registered, the userspace
	will not receive any message when a missing page is written"

It's my mistake that I didn't look at the documentation carefully when playing
around.

Thanks,
Quang Minh.
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help