From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933903AbbI2Im7 (ORCPT ); Tue, 29 Sep 2015 04:42:59 -0400 Received: from mail-wi0-f173.google.com ([209.85.212.173]:38832 "EHLO mail-wi0-f173.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933839AbbI2Imm (ORCPT ); Tue, 29 Sep 2015 04:42:42 -0400 Date: Tue, 29 Sep 2015 10:42:38 +0200 From: Ingo Molnar To: Oleg Nesterov Cc: Linus Torvalds , Linux Kernel Mailing List , linux-mm , Andy Lutomirski , Andrew Morton , Denys Vlasenko , Brian Gerst , Peter Zijlstra , Borislav Petkov , "H. Peter Anvin" , Waiman Long , Thomas Gleixner Subject: Re: [PATCH 02/11] x86/mm/hotplug: Remove pgd_list use from the memory hotplug code Message-ID: <20150929084238.GA332@gmail.com> References: <1442903021-3893-1-git-send-email-mingo@kernel.org> <1442903021-3893-3-git-send-email-mingo@kernel.org> <20150923114453.GA8480@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20150923114453.GA8480@redhat.com> User-Agent: Mutt/1.5.23 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org * Oleg Nesterov wrote: > On 09/22, Linus Torvalds wrote: > > > > However, this now becomes a pattern for the series, and that just makes me think > > > > "Why is this not a 'for_each_mm()' pattern helper?" > > And we already have other users. And note that oom_kill_process() does _not_ > follow this pattern and that is why it is buggy. > > So this is funny, but I was thinking about almost the same, something like > > struct task_struct *next_task_with_mm(struct task_struct *p) > { > struct task_struct *t; > > p = p->group_leader; > while ((p = next_task(p)) != &init_task) { > if (p->flags & PF_KTHREAD) > continue; > > t = find_lock_task_mm(p); > if (t) > return t; > } > > return NULL; > } > > #define for_each_task_lock_mm(p) > for (p = &init_task; (p = next_task_with_mm(p)); task_unlock(p)) > > > So that you can do > > for_each_task_lock_mm(p) { > do_something_with(p->mm); > > if (some_condition()) { > // UNFORTUNATELY you can't just do "break" > task_unlock(p); > break; > } > } > > do you think it makes sense? Sure, I'm inclined to use the above code from you. > In fact it can't be simpler, we can move task_unlock() into next_task_with_mm(), > it can check ->mm != NULL or p != init_task. s/can't/can ? But even with that I'm not sure I can parse your suggestion. Got some (pseudo) code perhaps? Thanks, Ingo