On Mon, Jan 13, 2025 at 7:27 AM Lorenzo Stoakes <lorenzo.stoakes@xxxxxxxxxx> wrote: > > On Fri, Jan 10, 2025 at 08:25:55PM -0800, Suren Baghdasaryan wrote: > > mmap_init_lock() is used only from mm_init() in fork.c, therefore it does > > not have to reside in the header file. This move lets us avoid including > > additional headers in mmap_lock.h later, when mmap_init_lock() needs to > > initialize rcuwait object. > > > > Signed-off-by: Suren Baghdasaryan <surenb@xxxxxxxxxx> > > Reviewed-by: Vlastimil Babka <vbabka@xxxxxxx> > > Aside from nit below, LGTM: > > Reviewed-by: Lorenzo Stoakes <lorenzo.stoakes@xxxxxxxxxx> > > > --- > > include/linux/mmap_lock.h | 6 ------ > > kernel/fork.c | 6 ++++++ > > 2 files changed, 6 insertions(+), 6 deletions(-) > > > > diff --git a/include/linux/mmap_lock.h b/include/linux/mmap_lock.h > > index 45a21faa3ff6..4706c6769902 100644 > > --- a/include/linux/mmap_lock.h > > +++ b/include/linux/mmap_lock.h > > @@ -122,12 +122,6 @@ static inline bool mmap_lock_speculate_retry(struct mm_struct *mm, unsigned int > > > > #endif /* CONFIG_PER_VMA_LOCK */ > > > > -static inline void mmap_init_lock(struct mm_struct *mm) > > -{ > > - init_rwsem(&mm->mmap_lock); > > - mm_lock_seqcount_init(mm); > > -} > > - > > static inline void mmap_write_lock(struct mm_struct *mm) > > { > > __mmap_lock_trace_start_locking(mm, true); > > diff --git a/kernel/fork.c b/kernel/fork.c > > index f2f9e7b427ad..d4c75428ccaf 100644 > > --- a/kernel/fork.c > > +++ b/kernel/fork.c > > @@ -1219,6 +1219,12 @@ static void mm_init_uprobes_state(struct mm_struct *mm) > > #endif > > } > > > > +static inline void mmap_init_lock(struct mm_struct *mm) > > we don't need inline here, please drop it. Ack. > > > +{ > > + init_rwsem(&mm->mmap_lock); > > + mm_lock_seqcount_init(mm); > > +} > > + > > static struct mm_struct *mm_init(struct mm_struct *mm, struct task_struct *p, > > struct user_namespace *user_ns) > > { > > -- > > 2.47.1.613.gc27f4b7a9f-goog > >