From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-wm0-f41.google.com (mail-wm0-f41.google.com [74.125.82.41]) by kanga.kvack.org (Postfix) with ESMTP id C57176B0253 for ; Mon, 29 Feb 2016 12:53:41 -0500 (EST) Received: by mail-wm0-f41.google.com with SMTP id l68so446238wml.0 for ; Mon, 29 Feb 2016 09:53:41 -0800 (PST) Date: Mon, 29 Feb 2016 18:53:39 +0100 From: Michal Hocko Subject: Re: [PATCH 07/18] mm, proc: make clear_refs killable Message-ID: <20160229175338.GM16930@dhcp22.suse.cz> References: <1456752417-9626-1-git-send-email-mhocko@kernel.org> <1456752417-9626-8-git-send-email-mhocko@kernel.org> <20160229173845.GC3615@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20160229173845.GC3615@redhat.com> Sender: owner-linux-mm@kvack.org List-ID: To: Oleg Nesterov Cc: LKML , Andrew Morton , linux-mm@kvack.org, Alex Deucher , Alex Thorlton , Andrea Arcangeli , Andy Lutomirski , Benjamin LaHaise , Christian =?iso-8859-1?Q?K=F6nig?= , Daniel Vetter , Dave Hansen , David Airlie , Davidlohr Bueso , David Rientjes , "H . Peter Anvin" , Hugh Dickins , Ingo Molnar , Johannes Weiner , "Kirill A . Shutemov" , Konstantin Khlebnikov , linux-arch@vger.kernel.org, Mel Gorman , Peter Zijlstra , Petr Cermak , Thomas Gleixner On Mon 29-02-16 18:38:45, Oleg Nesterov wrote: > On 02/29, Michal Hocko wrote: > > > > --- a/fs/proc/task_mmu.c > > +++ b/fs/proc/task_mmu.c > > @@ -1027,11 +1027,15 @@ static ssize_t clear_refs_write(struct file *file, const char __user *buf, > > }; > > > > if (type == CLEAR_REFS_MM_HIWATER_RSS) { > > + if (down_write_killable(&mm->mmap_sem)) { > > + put_task_struct(task); > > + return -EINTR; > > + } > > + > > /* > > * Writing 5 to /proc/pid/clear_refs resets the peak > > * resident set size to this mm's current rss value. > > */ > > - down_write(&mm->mmap_sem); > > reset_mm_hiwater_rss(mm); > > up_write(&mm->mmap_sem); > > goto out_mm; > > @@ -1043,7 +1047,10 @@ static ssize_t clear_refs_write(struct file *file, const char __user *buf, > > if (!(vma->vm_flags & VM_SOFTDIRTY)) > > continue; > > up_read(&mm->mmap_sem); > > - down_write(&mm->mmap_sem); > > + if (down_write_killable(&mm->mmap_sem)) { > > + put_task_struct(task); > > + return -EINTR; > > + } > > Both lack mmput() afaics. Don't you need "goto out_mm" rather then "return" ? Of course I need! Thanks for catching that. > In this case you do not need put_task_struct(). Why not? Both are after get_proc_task which takes a reference to the task... I will send an updated patch. Thanks! -- Michal Hocko SUSE Labs -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: email@kvack.org