* [PATCH 0/1] mm: move ->mremap() from file_operations to vm_operations_struct
@ 2015-06-23 18:02 Oleg Nesterov
2015-06-23 18:02 ` [PATCH 1/1] " Oleg Nesterov
` (2 more replies)
0 siblings, 3 replies; 15+ messages in thread
From: Oleg Nesterov @ 2015-06-23 18:02 UTC (permalink / raw)
To: Andy Lutomirski, Andrew Morton
Cc: Al Viro, Benjamin LaHaise, Hugh Dickins, Jeff Moyer,
Kirill Shutemov, Linus Torvalds, linux-kernel, Andy Lutomirski,
Pavel Emelyanov
On 06/22, Andy Lutomirski wrote:
>
> On Mon, Jun 22, 2015 at 5:47 PM, Oleg Nesterov <oleg@redhat.com> wrote:
> >
> > I never understood why ->mremap() lives in file_operations, not in
> > vm_operations_struct. To me vma->vm_file->f_op in move_vma() just
> > looks strange, vma->vm_ops->mremap(new_vma) looks "obviously better".
> >
> > And afaics more useful. CRIU remaps vdso, but this does not update
> > mm->context.vdso. OK, probably this does not matter currently, CRIU
> > can't c/r the compat tasks, and 64-bit apps do not use context.vdso.
> > Afaics. Still, I think we might want to have special_mapping_remap()
> > and we can't do this because ->vm_file == NULL.
>
> I would like this. Then I could clean up and resubmit my patch to
> keep context.vdso up to date.
Cough... where can I find this patch ? ;)
> Oleg, can you let me know what patch, if any, I should be reviewing?
This one, it looks really trivial. And of course I will appreciate it
if you can review the special_mapping_fault() fixes.
The change in move_vma() textually depends on another patch I sent,
[PATCH 1/4] mremap: don't leak new_vma if f_op->mremap() fails
http://marc.info/?l=linux-kernel&m=143475603713622
Oleg.
^ permalink raw reply [flat|nested] 15+ messages in thread
* [PATCH 1/1] mm: move ->mremap() from file_operations to vm_operations_struct
2015-06-23 18:02 [PATCH 0/1] mm: move ->mremap() from file_operations to vm_operations_struct Oleg Nesterov
@ 2015-06-23 18:02 ` Oleg Nesterov
2015-06-23 18:19 ` Kirill A. Shutemov
` (2 more replies)
2015-06-23 20:59 ` [PATCH 0/1] " Andy Lutomirski
2015-06-25 20:45 ` [PATCH v2 1/1] " Oleg Nesterov
2 siblings, 3 replies; 15+ messages in thread
From: Oleg Nesterov @ 2015-06-23 18:02 UTC (permalink / raw)
To: Andy Lutomirski, Andrew Morton
Cc: Al Viro, Benjamin LaHaise, Hugh Dickins, Jeff Moyer,
Kirill Shutemov, Linus Torvalds, linux-kernel, Andy Lutomirski,
Pavel Emelyanov
vma->vm_ops->mremap() looks more natural and clean in move_vma(),
and this way ->mremap() can have more users. Say, vdso.
Signed-off-by: Oleg Nesterov <oleg@redhat.com>
---
fs/aio.c | 25 ++++++++++++++++---------
include/linux/fs.h | 1 -
include/linux/mm.h | 1 +
mm/mremap.c | 4 ++--
4 files changed, 19 insertions(+), 12 deletions(-)
diff --git a/fs/aio.c b/fs/aio.c
index 9bc1335..6fe662a 100644
--- a/fs/aio.c
+++ b/fs/aio.c
@@ -308,15 +308,9 @@ static void aio_free_ring(struct kioctx *ctx)
}
}
-static int aio_ring_mmap(struct file *file, struct vm_area_struct *vma)
-{
- vma->vm_flags |= VM_DONTEXPAND;
- vma->vm_ops = &generic_file_vm_ops;
- return 0;
-}
-
-static int aio_ring_remap(struct file *file, struct vm_area_struct *vma)
+static int aio_ring_remap(struct vm_area_struct *vma)
{
+ struct file *file = vma->vm_file;
struct mm_struct *mm = vma->vm_mm;
struct kioctx_table *table;
int i, res = -EINVAL;
@@ -339,9 +333,22 @@ static int aio_ring_remap(struct file *file, struct vm_area_struct *vma)
return res;
}
+static const struct vm_operations_struct aio_ring_vm_ops = {
+ .mremap = aio_ring_remap,
+ .fault = filemap_fault,
+ .map_pages = filemap_map_pages,
+ .page_mkwrite = filemap_page_mkwrite,
+};
+
+static int aio_ring_mmap(struct file *file, struct vm_area_struct *vma)
+{
+ vma->vm_flags |= VM_DONTEXPAND;
+ vma->vm_ops = &aio_ring_vm_ops;
+ return 0;
+}
+
static const struct file_operations aio_ring_fops = {
.mmap = aio_ring_mmap,
- .mremap = aio_ring_remap,
};
#if IS_ENABLED(CONFIG_MIGRATION)
diff --git a/include/linux/fs.h b/include/linux/fs.h
index 35ec87e..42aac09 100644
--- a/include/linux/fs.h
+++ b/include/linux/fs.h
@@ -1582,7 +1582,6 @@ struct file_operations {
long (*unlocked_ioctl) (struct file *, unsigned int, unsigned long);
long (*compat_ioctl) (struct file *, unsigned int, unsigned long);
int (*mmap) (struct file *, struct vm_area_struct *);
- int (*mremap)(struct file *, struct vm_area_struct *);
int (*open) (struct inode *, struct file *);
int (*flush) (struct file *, fl_owner_t id);
int (*release) (struct inode *, struct file *);
diff --git a/include/linux/mm.h b/include/linux/mm.h
index a0fe3d3..0295b4a 100644
--- a/include/linux/mm.h
+++ b/include/linux/mm.h
@@ -244,6 +244,7 @@ struct vm_fault {
struct vm_operations_struct {
void (*open)(struct vm_area_struct * area);
void (*close)(struct vm_area_struct * area);
+ int (*mremap)(struct vm_area_struct * area);
int (*fault)(struct vm_area_struct *vma, struct vm_fault *vmf);
void (*map_pages)(struct vm_area_struct *vma, struct vm_fault *vmf);
diff --git a/mm/mremap.c b/mm/mremap.c
index ed1b13a..aeba807 100644
--- a/mm/mremap.c
+++ b/mm/mremap.c
@@ -276,8 +276,8 @@ static unsigned long move_vma(struct vm_area_struct *vma,
need_rmap_locks);
if (moved_len < old_len) {
err = -ENOMEM;
- } else if (vma->vm_file && vma->vm_file->f_op->mremap) {
- err = vma->vm_file->f_op->mremap(vma->vm_file, new_vma);
+ } else if (vma->vm_ops && vma->vm_ops->mremap) {
+ err = vma->vm_ops->mremap(new_vma);
}
if (unlikely(err)) {
--
1.5.5.1
^ permalink raw reply related [flat|nested] 15+ messages in thread
* Re: [PATCH 1/1] mm: move ->mremap() from file_operations to vm_operations_struct
2015-06-23 18:02 ` [PATCH 1/1] " Oleg Nesterov
@ 2015-06-23 18:19 ` Kirill A. Shutemov
2015-06-23 18:26 ` Oleg Nesterov
2015-06-23 21:01 ` Andy Lutomirski
2015-06-23 21:11 ` Pavel Emelyanov
2 siblings, 1 reply; 15+ messages in thread
From: Kirill A. Shutemov @ 2015-06-23 18:19 UTC (permalink / raw)
To: Oleg Nesterov
Cc: Andy Lutomirski, Andrew Morton, Al Viro, Benjamin LaHaise,
Hugh Dickins, Jeff Moyer, Kirill Shutemov, Linus Torvalds,
linux-kernel, Andy Lutomirski, Pavel Emelyanov
On Tue, Jun 23, 2015 at 08:02:51PM +0200, Oleg Nesterov wrote:
> vma->vm_ops->mremap() looks more natural and clean in move_vma(),
> and this way ->mremap() can have more users. Say, vdso.
>
> Signed-off-by: Oleg Nesterov <oleg@redhat.com>
> ---
> fs/aio.c | 25 ++++++++++++++++---------
> include/linux/fs.h | 1 -
> include/linux/mm.h | 1 +
> mm/mremap.c | 4 ++--
Please, update Documentation/filesystems/Locking.
> 4 files changed, 19 insertions(+), 12 deletions(-)
>
> diff --git a/fs/aio.c b/fs/aio.c
> index 9bc1335..6fe662a 100644
> --- a/fs/aio.c
> +++ b/fs/aio.c
> @@ -308,15 +308,9 @@ static void aio_free_ring(struct kioctx *ctx)
> }
> }
>
> -static int aio_ring_mmap(struct file *file, struct vm_area_struct *vma)
> -{
> - vma->vm_flags |= VM_DONTEXPAND;
> - vma->vm_ops = &generic_file_vm_ops;
> - return 0;
> -}
> -
> -static int aio_ring_remap(struct file *file, struct vm_area_struct *vma)
> +static int aio_ring_remap(struct vm_area_struct *vma)
I guess aio_ring_mremap() would be a better name.
> {
> + struct file *file = vma->vm_file;
> struct mm_struct *mm = vma->vm_mm;
> struct kioctx_table *table;
> int i, res = -EINVAL;
--
Kirill A. Shutemov
^ permalink raw reply [flat|nested] 15+ messages in thread
* Re: [PATCH 1/1] mm: move ->mremap() from file_operations to vm_operations_struct
2015-06-23 18:19 ` Kirill A. Shutemov
@ 2015-06-23 18:26 ` Oleg Nesterov
2015-06-24 15:49 ` Oleg Nesterov
0 siblings, 1 reply; 15+ messages in thread
From: Oleg Nesterov @ 2015-06-23 18:26 UTC (permalink / raw)
To: Kirill A. Shutemov
Cc: Andy Lutomirski, Andrew Morton, Al Viro, Benjamin LaHaise,
Hugh Dickins, Jeff Moyer, Kirill Shutemov, Linus Torvalds,
linux-kernel, Andy Lutomirski, Pavel Emelyanov
On 06/23, Kirill A. Shutemov wrote:
>
> On Tue, Jun 23, 2015 at 08:02:51PM +0200, Oleg Nesterov wrote:
> > vma->vm_ops->mremap() looks more natural and clean in move_vma(),
> > and this way ->mremap() can have more users. Say, vdso.
> >
> > Signed-off-by: Oleg Nesterov <oleg@redhat.com>
> > ---
> > fs/aio.c | 25 ++++++++++++++++---------
> > include/linux/fs.h | 1 -
> > include/linux/mm.h | 1 +
> > mm/mremap.c | 4 ++--
>
> Please, update Documentation/filesystems/Locking.
OK, thanks, will do.
> > -static int aio_ring_remap(struct file *file, struct vm_area_struct *vma)
> > +static int aio_ring_remap(struct vm_area_struct *vma)
>
> I guess aio_ring_mremap() would be a better name.
Yes, agreed.
OK, I'll wait for other comments then send v2 with these changes.
Oleg.
^ permalink raw reply [flat|nested] 15+ messages in thread
* Re: [PATCH 0/1] mm: move ->mremap() from file_operations to vm_operations_struct
2015-06-23 18:02 [PATCH 0/1] mm: move ->mremap() from file_operations to vm_operations_struct Oleg Nesterov
2015-06-23 18:02 ` [PATCH 1/1] " Oleg Nesterov
@ 2015-06-23 20:59 ` Andy Lutomirski
2015-06-24 13:53 ` Oleg Nesterov
2015-06-25 20:45 ` [PATCH v2 1/1] " Oleg Nesterov
2 siblings, 1 reply; 15+ messages in thread
From: Andy Lutomirski @ 2015-06-23 20:59 UTC (permalink / raw)
To: Oleg Nesterov
Cc: Andrew Morton, Al Viro, Benjamin LaHaise, Hugh Dickins,
Jeff Moyer, Kirill Shutemov, Linus Torvalds, linux-kernel,
Andy Lutomirski, Pavel Emelyanov
On Tue, Jun 23, 2015 at 11:02 AM, Oleg Nesterov <oleg@redhat.com> wrote:
> On 06/22, Andy Lutomirski wrote:
>>
>> On Mon, Jun 22, 2015 at 5:47 PM, Oleg Nesterov <oleg@redhat.com> wrote:
>> >
>> > I never understood why ->mremap() lives in file_operations, not in
>> > vm_operations_struct. To me vma->vm_file->f_op in move_vma() just
>> > looks strange, vma->vm_ops->mremap(new_vma) looks "obviously better".
>> >
>> > And afaics more useful. CRIU remaps vdso, but this does not update
>> > mm->context.vdso. OK, probably this does not matter currently, CRIU
>> > can't c/r the compat tasks, and 64-bit apps do not use context.vdso.
>> > Afaics. Still, I think we might want to have special_mapping_remap()
>> > and we can't do this because ->vm_file == NULL.
>>
>> I would like this. Then I could clean up and resubmit my patch to
>> keep context.vdso up to date.
>
> Cough... where can I find this patch ? ;)
>
https://git.kernel.org/cgit/linux/kernel/git/luto/linux.git/log/?h=vdso/vma_tracking
--Andy
^ permalink raw reply [flat|nested] 15+ messages in thread
* Re: [PATCH 1/1] mm: move ->mremap() from file_operations to vm_operations_struct
2015-06-23 18:02 ` [PATCH 1/1] " Oleg Nesterov
2015-06-23 18:19 ` Kirill A. Shutemov
@ 2015-06-23 21:01 ` Andy Lutomirski
2015-06-23 21:11 ` Pavel Emelyanov
2 siblings, 0 replies; 15+ messages in thread
From: Andy Lutomirski @ 2015-06-23 21:01 UTC (permalink / raw)
To: Oleg Nesterov
Cc: Andrew Morton, Al Viro, Benjamin LaHaise, Hugh Dickins,
Jeff Moyer, Kirill Shutemov, Linus Torvalds, linux-kernel,
Andy Lutomirski, Pavel Emelyanov
On Tue, Jun 23, 2015 at 11:02 AM, Oleg Nesterov <oleg@redhat.com> wrote:
> vma->vm_ops->mremap() looks more natural and clean in move_vma(),
> and this way ->mremap() can have more users. Say, vdso.
>
Looks generally reasonable.
--Andy
^ permalink raw reply [flat|nested] 15+ messages in thread
* Re: [PATCH 1/1] mm: move ->mremap() from file_operations to vm_operations_struct
2015-06-23 18:02 ` [PATCH 1/1] " Oleg Nesterov
2015-06-23 18:19 ` Kirill A. Shutemov
2015-06-23 21:01 ` Andy Lutomirski
@ 2015-06-23 21:11 ` Pavel Emelyanov
2 siblings, 0 replies; 15+ messages in thread
From: Pavel Emelyanov @ 2015-06-23 21:11 UTC (permalink / raw)
To: Oleg Nesterov, Andy Lutomirski, Andrew Morton
Cc: Al Viro, Benjamin LaHaise, Hugh Dickins, Jeff Moyer,
Kirill Shutemov, Linus Torvalds, linux-kernel, Andy Lutomirski
On 06/23/2015 09:02 PM, Oleg Nesterov wrote:
> vma->vm_ops->mremap() looks more natural and clean in move_vma(),
> and this way ->mremap() can have more users. Say, vdso.
>
> Signed-off-by: Oleg Nesterov <oleg@redhat.com>
Looks-good-to: /me :) Thanks!
^ permalink raw reply [flat|nested] 15+ messages in thread
* Re: [PATCH 0/1] mm: move ->mremap() from file_operations to vm_operations_struct
2015-06-23 20:59 ` [PATCH 0/1] " Andy Lutomirski
@ 2015-06-24 13:53 ` Oleg Nesterov
0 siblings, 0 replies; 15+ messages in thread
From: Oleg Nesterov @ 2015-06-24 13:53 UTC (permalink / raw)
To: Andy Lutomirski
Cc: Andrew Morton, Al Viro, Benjamin LaHaise, Hugh Dickins,
Jeff Moyer, Kirill Shutemov, Linus Torvalds, linux-kernel,
Andy Lutomirski, Pavel Emelyanov
On 06/23, Andy Lutomirski wrote:
>
> On Tue, Jun 23, 2015 at 11:02 AM, Oleg Nesterov <oleg@redhat.com> wrote:
> > On 06/22, Andy Lutomirski wrote:
> >>
> >> On Mon, Jun 22, 2015 at 5:47 PM, Oleg Nesterov <oleg@redhat.com> wrote:
> >> >
> >> > I never understood why ->mremap() lives in file_operations, not in
> >> > vm_operations_struct. To me vma->vm_file->f_op in move_vma() just
> >> > looks strange, vma->vm_ops->mremap(new_vma) looks "obviously better".
> >> >
> >> > And afaics more useful. CRIU remaps vdso, but this does not update
> >> > mm->context.vdso. OK, probably this does not matter currently, CRIU
> >> > can't c/r the compat tasks, and 64-bit apps do not use context.vdso.
> >> > Afaics. Still, I think we might want to have special_mapping_remap()
> >> > and we can't do this because ->vm_file == NULL.
> >>
> >> I would like this. Then I could clean up and resubmit my patch to
> >> keep context.vdso up to date.
> >
> > Cough... where can I find this patch ? ;)
> >
>
> https://git.kernel.org/cgit/linux/kernel/git/luto/linux.git/log/?h=vdso/vma_tracking
Aha, thanks. So yes, looks like your "Add a mechanism to track the current
address of a special mapping" can rely on vm_ops->mremap().
Oleg.
^ permalink raw reply [flat|nested] 15+ messages in thread
* Re: [PATCH 1/1] mm: move ->mremap() from file_operations to vm_operations_struct
2015-06-23 18:26 ` Oleg Nesterov
@ 2015-06-24 15:49 ` Oleg Nesterov
2015-06-24 19:23 ` Kirill A. Shutemov
0 siblings, 1 reply; 15+ messages in thread
From: Oleg Nesterov @ 2015-06-24 15:49 UTC (permalink / raw)
To: Kirill A. Shutemov
Cc: Andy Lutomirski, Andrew Morton, Al Viro, Benjamin LaHaise,
Hugh Dickins, Jeff Moyer, Kirill Shutemov, Linus Torvalds,
linux-kernel, Andy Lutomirski, Pavel Emelyanov
On 06/23, Oleg Nesterov wrote:
>
> On 06/23, Kirill A. Shutemov wrote:
> >
> > On Tue, Jun 23, 2015 at 08:02:51PM +0200, Oleg Nesterov wrote:
> > > vma->vm_ops->mremap() looks more natural and clean in move_vma(),
> > > and this way ->mremap() can have more users. Say, vdso.
> > >
> > > Signed-off-by: Oleg Nesterov <oleg@redhat.com>
> > > ---
> > > fs/aio.c | 25 ++++++++++++++++---------
> > > include/linux/fs.h | 1 -
> > > include/linux/mm.h | 1 +
> > > mm/mremap.c | 4 ++--
> >
> > Please, update Documentation/filesystems/Locking.
>
> OK, thanks, will do.
Wait... Documentation/filesystems/Locking doesn't mention
->mremap() at all.
So you actually ask me to add the new documentation? ;)
Oh well... OK, I'll try if you think this is necessary.
I tried to make the minimal change before ->mremap() finds another
user in file_operations. I thinks it needs more arguments, at least
new_addr and new_len, otherwise it is not easy to document it. The
same for f_op->mremap() of course.
Currently this does not matter, the only user is aio.c and
VM_DONTEXPAND means that it is not mergeable, so mremap() always
creates the new vma.
Hmm. Can't we do this change and add the documentation later?
Oleg.
^ permalink raw reply [flat|nested] 15+ messages in thread
* Re: [PATCH 1/1] mm: move ->mremap() from file_operations to vm_operations_struct
2015-06-24 15:49 ` Oleg Nesterov
@ 2015-06-24 19:23 ` Kirill A. Shutemov
2015-06-25 20:43 ` Oleg Nesterov
0 siblings, 1 reply; 15+ messages in thread
From: Kirill A. Shutemov @ 2015-06-24 19:23 UTC (permalink / raw)
To: Oleg Nesterov
Cc: Andy Lutomirski, Andrew Morton, Al Viro, Benjamin LaHaise,
Hugh Dickins, Jeff Moyer, Kirill Shutemov, Linus Torvalds,
linux-kernel, Andy Lutomirski, Pavel Emelyanov
On Wed, Jun 24, 2015 at 05:49:14PM +0200, Oleg Nesterov wrote:
> On 06/23, Oleg Nesterov wrote:
> >
> > On 06/23, Kirill A. Shutemov wrote:
> > >
> > > On Tue, Jun 23, 2015 at 08:02:51PM +0200, Oleg Nesterov wrote:
> > > > vma->vm_ops->mremap() looks more natural and clean in move_vma(),
> > > > and this way ->mremap() can have more users. Say, vdso.
> > > >
> > > > Signed-off-by: Oleg Nesterov <oleg@redhat.com>
> > > > ---
> > > > fs/aio.c | 25 ++++++++++++++++---------
> > > > include/linux/fs.h | 1 -
> > > > include/linux/mm.h | 1 +
> > > > mm/mremap.c | 4 ++--
> > >
> > > Please, update Documentation/filesystems/Locking.
> >
> > OK, thanks, will do.
>
> Wait... Documentation/filesystems/Locking doesn't mention
> ->mremap() at all.
>
> So you actually ask me to add the new documentation? ;)
I tried ;)
> Oh well... OK, I'll try if you think this is necessary.
>
> I tried to make the minimal change before ->mremap() finds another
> user in file_operations. I thinks it needs more arguments, at least
> new_addr and new_len, otherwise it is not easy to document it. The
> same for f_op->mremap() of course.
>
> Currently this does not matter, the only user is aio.c and
> VM_DONTEXPAND means that it is not mergeable, so mremap() always
> creates the new vma.
>
> Hmm. Can't we do this change and add the documentation later?
I'm fine with that.
--
Kirill A. Shutemov
^ permalink raw reply [flat|nested] 15+ messages in thread
* Re: [PATCH 1/1] mm: move ->mremap() from file_operations to vm_operations_struct
2015-06-24 19:23 ` Kirill A. Shutemov
@ 2015-06-25 20:43 ` Oleg Nesterov
0 siblings, 0 replies; 15+ messages in thread
From: Oleg Nesterov @ 2015-06-25 20:43 UTC (permalink / raw)
To: Kirill A. Shutemov
Cc: Andy Lutomirski, Andrew Morton, Al Viro, Benjamin LaHaise,
Hugh Dickins, Jeff Moyer, Kirill Shutemov, Linus Torvalds,
linux-kernel, Andy Lutomirski, Pavel Emelyanov
On 06/24, Kirill A. Shutemov wrote:
>
> On Wed, Jun 24, 2015 at 05:49:14PM +0200, Oleg Nesterov wrote:
> >
> > Wait... Documentation/filesystems/Locking doesn't mention
> > ->mremap() at all.
> >
> > So you actually ask me to add the new documentation? ;)
>
> I tried ;)
Understand ;) but I failed to do this. Serisouly, I simply don't
know what can I add into this (outadted anyway) section except
"called when move_page_tables() targets this vma".
> > I tried to make the minimal change before ->mremap() finds another
> > user in file_operations. I thinks it needs more arguments, at least
> > new_addr and new_len, otherwise it is not easy to document it. The
> > same for f_op->mremap() of course.
> >
> > Currently this does not matter, the only user is aio.c and
> > VM_DONTEXPAND means that it is not mergeable, so mremap() always
> > creates the new vma.
> >
> > Hmm. Can't we do this change and add the documentation later?
>
> I'm fine with that.
OK, so I am sending v2 with the only change: rename aio_ring_remap
to aio_ring_mremap as you suggested.
Oleg.
^ permalink raw reply [flat|nested] 15+ messages in thread
* [PATCH v2 1/1] mm: move ->mremap() from file_operations to vm_operations_struct
2015-06-23 18:02 [PATCH 0/1] mm: move ->mremap() from file_operations to vm_operations_struct Oleg Nesterov
2015-06-23 18:02 ` [PATCH 1/1] " Oleg Nesterov
2015-06-23 20:59 ` [PATCH 0/1] " Andy Lutomirski
@ 2015-06-25 20:45 ` Oleg Nesterov
2015-06-25 22:08 ` Kirill A. Shutemov
2015-06-26 12:21 ` Pavel Emelyanov
2 siblings, 2 replies; 15+ messages in thread
From: Oleg Nesterov @ 2015-06-25 20:45 UTC (permalink / raw)
To: Andy Lutomirski, Andrew Morton
Cc: Al Viro, Benjamin LaHaise, Hugh Dickins, Jeff Moyer,
Kirill Shutemov, Linus Torvalds, linux-kernel, Andy Lutomirski,
Pavel Emelyanov
vma->vm_ops->mremap() looks more natural and clean in move_vma(),
and this way ->mremap() can have more users. Say, vdso.
While at it, s/aio_ring_remap/aio_ring_mremap/.
Signed-off-by: Oleg Nesterov <oleg@redhat.com>
---
fs/aio.c | 25 ++++++++++++++++---------
include/linux/fs.h | 1 -
include/linux/mm.h | 1 +
mm/mremap.c | 4 ++--
4 files changed, 19 insertions(+), 12 deletions(-)
diff --git a/fs/aio.c b/fs/aio.c
index 9bc1335..a632f14 100644
--- a/fs/aio.c
+++ b/fs/aio.c
@@ -308,15 +308,9 @@ static void aio_free_ring(struct kioctx *ctx)
}
}
-static int aio_ring_mmap(struct file *file, struct vm_area_struct *vma)
-{
- vma->vm_flags |= VM_DONTEXPAND;
- vma->vm_ops = &generic_file_vm_ops;
- return 0;
-}
-
-static int aio_ring_remap(struct file *file, struct vm_area_struct *vma)
+static int aio_ring_mremap(struct vm_area_struct *vma)
{
+ struct file *file = vma->vm_file;
struct mm_struct *mm = vma->vm_mm;
struct kioctx_table *table;
int i, res = -EINVAL;
@@ -339,9 +333,22 @@ static int aio_ring_remap(struct file *file, struct vm_area_struct *vma)
return res;
}
+static const struct vm_operations_struct aio_ring_vm_ops = {
+ .mremap = aio_ring_mremap,
+ .fault = filemap_fault,
+ .map_pages = filemap_map_pages,
+ .page_mkwrite = filemap_page_mkwrite,
+};
+
+static int aio_ring_mmap(struct file *file, struct vm_area_struct *vma)
+{
+ vma->vm_flags |= VM_DONTEXPAND;
+ vma->vm_ops = &aio_ring_vm_ops;
+ return 0;
+}
+
static const struct file_operations aio_ring_fops = {
.mmap = aio_ring_mmap,
- .mremap = aio_ring_remap,
};
#if IS_ENABLED(CONFIG_MIGRATION)
diff --git a/include/linux/fs.h b/include/linux/fs.h
index 35ec87e..42aac09 100644
--- a/include/linux/fs.h
+++ b/include/linux/fs.h
@@ -1582,7 +1582,6 @@ struct file_operations {
long (*unlocked_ioctl) (struct file *, unsigned int, unsigned long);
long (*compat_ioctl) (struct file *, unsigned int, unsigned long);
int (*mmap) (struct file *, struct vm_area_struct *);
- int (*mremap)(struct file *, struct vm_area_struct *);
int (*open) (struct inode *, struct file *);
int (*flush) (struct file *, fl_owner_t id);
int (*release) (struct inode *, struct file *);
diff --git a/include/linux/mm.h b/include/linux/mm.h
index a0fe3d3..0295b4a 100644
--- a/include/linux/mm.h
+++ b/include/linux/mm.h
@@ -244,6 +244,7 @@ struct vm_fault {
struct vm_operations_struct {
void (*open)(struct vm_area_struct * area);
void (*close)(struct vm_area_struct * area);
+ int (*mremap)(struct vm_area_struct * area);
int (*fault)(struct vm_area_struct *vma, struct vm_fault *vmf);
void (*map_pages)(struct vm_area_struct *vma, struct vm_fault *vmf);
diff --git a/mm/mremap.c b/mm/mremap.c
index ed1b13a..aeba807 100644
--- a/mm/mremap.c
+++ b/mm/mremap.c
@@ -276,8 +276,8 @@ static unsigned long move_vma(struct vm_area_struct *vma,
need_rmap_locks);
if (moved_len < old_len) {
err = -ENOMEM;
- } else if (vma->vm_file && vma->vm_file->f_op->mremap) {
- err = vma->vm_file->f_op->mremap(vma->vm_file, new_vma);
+ } else if (vma->vm_ops && vma->vm_ops->mremap) {
+ err = vma->vm_ops->mremap(new_vma);
}
if (unlikely(err)) {
--
1.5.5.1
^ permalink raw reply related [flat|nested] 15+ messages in thread
* Re: [PATCH v2 1/1] mm: move ->mremap() from file_operations to vm_operations_struct
2015-06-25 20:45 ` [PATCH v2 1/1] " Oleg Nesterov
@ 2015-06-25 22:08 ` Kirill A. Shutemov
2015-06-25 23:41 ` Oleg Nesterov
2015-06-26 12:21 ` Pavel Emelyanov
1 sibling, 1 reply; 15+ messages in thread
From: Kirill A. Shutemov @ 2015-06-25 22:08 UTC (permalink / raw)
To: Oleg Nesterov
Cc: Andy Lutomirski, Andrew Morton, Al Viro, Benjamin LaHaise,
Hugh Dickins, Jeff Moyer, Kirill Shutemov, Linus Torvalds,
linux-kernel, Andy Lutomirski, Pavel Emelyanov
On Thu, Jun 25, 2015 at 10:45:04PM +0200, Oleg Nesterov wrote:
> vma->vm_ops->mremap() looks more natural and clean in move_vma(),
> and this way ->mremap() can have more users. Say, vdso.
>
> While at it, s/aio_ring_remap/aio_ring_mremap/.
>
> Signed-off-by: Oleg Nesterov <oleg@redhat.com>
> ---
> fs/aio.c | 25 ++++++++++++++++---------
> include/linux/fs.h | 1 -
> include/linux/mm.h | 1 +
> mm/mremap.c | 4 ++--
> 4 files changed, 19 insertions(+), 12 deletions(-)
>
> diff --git a/fs/aio.c b/fs/aio.c
> index 9bc1335..a632f14 100644
> --- a/fs/aio.c
> +++ b/fs/aio.c
> @@ -308,15 +308,9 @@ static void aio_free_ring(struct kioctx *ctx)
> }
> }
>
> -static int aio_ring_mmap(struct file *file, struct vm_area_struct *vma)
> -{
> - vma->vm_flags |= VM_DONTEXPAND;
> - vma->vm_ops = &generic_file_vm_ops;
> - return 0;
> -}
> -
> -static int aio_ring_remap(struct file *file, struct vm_area_struct *vma)
> +static int aio_ring_mremap(struct vm_area_struct *vma)
> {
> + struct file *file = vma->vm_file;
> struct mm_struct *mm = vma->vm_mm;
> struct kioctx_table *table;
> int i, res = -EINVAL;
> @@ -339,9 +333,22 @@ static int aio_ring_remap(struct file *file, struct vm_area_struct *vma)
> return res;
> }
>
> +static const struct vm_operations_struct aio_ring_vm_ops = {
> + .mremap = aio_ring_mremap,
> + .fault = filemap_fault,
> + .map_pages = filemap_map_pages,
> + .page_mkwrite = filemap_page_mkwrite,
> +};
> +
> +static int aio_ring_mmap(struct file *file, struct vm_area_struct *vma)
> +{
> + vma->vm_flags |= VM_DONTEXPAND;
> + vma->vm_ops = &aio_ring_vm_ops;
> + return 0;
> +}
> +
> static const struct file_operations aio_ring_fops = {
> .mmap = aio_ring_mmap,
> - .mremap = aio_ring_remap,
> };
>
> #if IS_ENABLED(CONFIG_MIGRATION)
> diff --git a/include/linux/fs.h b/include/linux/fs.h
> index 35ec87e..42aac09 100644
> --- a/include/linux/fs.h
> +++ b/include/linux/fs.h
> @@ -1582,7 +1582,6 @@ struct file_operations {
> long (*unlocked_ioctl) (struct file *, unsigned int, unsigned long);
> long (*compat_ioctl) (struct file *, unsigned int, unsigned long);
> int (*mmap) (struct file *, struct vm_area_struct *);
> - int (*mremap)(struct file *, struct vm_area_struct *);
> int (*open) (struct inode *, struct file *);
> int (*flush) (struct file *, fl_owner_t id);
> int (*release) (struct inode *, struct file *);
> diff --git a/include/linux/mm.h b/include/linux/mm.h
> index a0fe3d3..0295b4a 100644
> --- a/include/linux/mm.h
> +++ b/include/linux/mm.h
> @@ -244,6 +244,7 @@ struct vm_fault {
> struct vm_operations_struct {
> void (*open)(struct vm_area_struct * area);
> void (*close)(struct vm_area_struct * area);
> + int (*mremap)(struct vm_area_struct * area);
> int (*fault)(struct vm_area_struct *vma, struct vm_fault *vmf);
> void (*map_pages)(struct vm_area_struct *vma, struct vm_fault *vmf);
>
> diff --git a/mm/mremap.c b/mm/mremap.c
> index ed1b13a..aeba807 100644
> --- a/mm/mremap.c
> +++ b/mm/mremap.c
> @@ -276,8 +276,8 @@ static unsigned long move_vma(struct vm_area_struct *vma,
> need_rmap_locks);
> if (moved_len < old_len) {
> err = -ENOMEM;
> - } else if (vma->vm_file && vma->vm_file->f_op->mremap) {
> - err = vma->vm_file->f_op->mremap(vma->vm_file, new_vma);
> + } else if (vma->vm_ops && vma->vm_ops->mremap) {
> + err = vma->vm_ops->mremap(new_vma);
> }
>
> if (unlikely(err)) {
I'm not sure what is target tree for the patch. Last hunk is not going to
apply on Linus' tree or -next. Hm?
Otherwise, looks good.
Acked-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
--
Kirill A. Shutemov
^ permalink raw reply [flat|nested] 15+ messages in thread
* Re: [PATCH v2 1/1] mm: move ->mremap() from file_operations to vm_operations_struct
2015-06-25 22:08 ` Kirill A. Shutemov
@ 2015-06-25 23:41 ` Oleg Nesterov
0 siblings, 0 replies; 15+ messages in thread
From: Oleg Nesterov @ 2015-06-25 23:41 UTC (permalink / raw)
To: Kirill A. Shutemov
Cc: Andy Lutomirski, Andrew Morton, Al Viro, Benjamin LaHaise,
Hugh Dickins, Jeff Moyer, Kirill Shutemov, Linus Torvalds,
linux-kernel, Andy Lutomirski, Pavel Emelyanov
On 06/26, Kirill A. Shutemov wrote:
>
> > --- a/mm/mremap.c
> > +++ b/mm/mremap.c
> > @@ -276,8 +276,8 @@ static unsigned long move_vma(struct vm_area_struct *vma,
> > need_rmap_locks);
> > if (moved_len < old_len) {
> > err = -ENOMEM;
> > - } else if (vma->vm_file && vma->vm_file->f_op->mremap) {
> > - err = vma->vm_file->f_op->mremap(vma->vm_file, new_vma);
> > + } else if (vma->vm_ops && vma->vm_ops->mremap) {
> > + err = vma->vm_ops->mremap(new_vma);
> > }
> >
> > if (unlikely(err)) {
>
> I'm not sure what is target tree for the patch.
I hope akpm can take this patch into -mm,
> Last hunk is not going to
> apply on Linus' tree or -next. Hm?
Yes, this depends on another fix I sent to Andrew (and you ;), as 0/1
explains the change in move_vma() textually depends on another patch I sent,
[PATCH 1/4] mremap: don't leak new_vma if f_op->mremap() fails
http://marc.info/?l=linux-kernel&m=143475603713622
> Otherwise, looks good.
>
> Acked-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
Thanks!
Oleg.
^ permalink raw reply [flat|nested] 15+ messages in thread
* Re: [PATCH v2 1/1] mm: move ->mremap() from file_operations to vm_operations_struct
2015-06-25 20:45 ` [PATCH v2 1/1] " Oleg Nesterov
2015-06-25 22:08 ` Kirill A. Shutemov
@ 2015-06-26 12:21 ` Pavel Emelyanov
1 sibling, 0 replies; 15+ messages in thread
From: Pavel Emelyanov @ 2015-06-26 12:21 UTC (permalink / raw)
To: Oleg Nesterov, Andy Lutomirski, Andrew Morton
Cc: Al Viro, Benjamin LaHaise, Hugh Dickins, Jeff Moyer,
Kirill Shutemov, Linus Torvalds, linux-kernel, Andy Lutomirski
On 06/25/2015 11:45 PM, Oleg Nesterov wrote:
> vma->vm_ops->mremap() looks more natural and clean in move_vma(),
> and this way ->mremap() can have more users. Say, vdso.
>
> While at it, s/aio_ring_remap/aio_ring_mremap/.
>
> Signed-off-by: Oleg Nesterov <oleg@redhat.com>
Acked-by: Pavel Emelyanov <xemul@parallels.com>
^ permalink raw reply [flat|nested] 15+ messages in thread
end of thread, other threads:[~2015-06-26 12:21 UTC | newest]
Thread overview: 15+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-06-23 18:02 [PATCH 0/1] mm: move ->mremap() from file_operations to vm_operations_struct Oleg Nesterov
2015-06-23 18:02 ` [PATCH 1/1] " Oleg Nesterov
2015-06-23 18:19 ` Kirill A. Shutemov
2015-06-23 18:26 ` Oleg Nesterov
2015-06-24 15:49 ` Oleg Nesterov
2015-06-24 19:23 ` Kirill A. Shutemov
2015-06-25 20:43 ` Oleg Nesterov
2015-06-23 21:01 ` Andy Lutomirski
2015-06-23 21:11 ` Pavel Emelyanov
2015-06-23 20:59 ` [PATCH 0/1] " Andy Lutomirski
2015-06-24 13:53 ` Oleg Nesterov
2015-06-25 20:45 ` [PATCH v2 1/1] " Oleg Nesterov
2015-06-25 22:08 ` Kirill A. Shutemov
2015-06-25 23:41 ` Oleg Nesterov
2015-06-26 12:21 ` Pavel Emelyanov
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).