From mboxrd@z Thu Jan 1 00:00:00 1970 From: Steven Rostedt Subject: Re: [PATCH 6/6] mm: add preempt points into __purge_vmap_area_lazy Date: Tue, 18 Oct 2016 17:01:47 -0400 Message-ID: <20161018170147.232aed1e@gandalf.local.home> References: <1476773771-11470-1-git-send-email-hch@lst.de> <1476773771-11470-7-git-send-email-hch@lst.de> <20161018205648.GB7021@home.goodmis.org> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Cc: akpm@linux-foundation.org, joelaf@google.com, jszhang@marvell.com, chris@chris-wilson.co.uk, joaodias@google.com, linux-mm@kvack.org, linux-rt-users@vger.kernel.org, linux-kernel@vger.kernel.org To: Christoph Hellwig Return-path: Received: from smtprelay0194.hostedemail.com ([216.40.44.194]:34970 "EHLO smtprelay.hostedemail.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S933707AbcJRVBw (ORCPT ); Tue, 18 Oct 2016 17:01:52 -0400 In-Reply-To: <20161018205648.GB7021@home.goodmis.org> Sender: linux-rt-users-owner@vger.kernel.org List-ID: On Tue, 18 Oct 2016 16:56:48 -0400 Steven Rostedt wrote: > Is releasing the lock within a llist_for_each_entry_safe() actually safe? Is > vmap_area_lock the one to protect the valist? > > That is llist_for_each_entry_safe(va, n_va, valist, purg_list) does: > > for (va = llist_entry(valist, typeof(*va), purge_list); > &va->purge_list != NULL && > n_va = llist_entry(va->purge_list.next, typeof(*n_va), > purge_list, true); > pos = n) > > Thus n_va is pointing to the next element to process when we release the > lock. Is it possible for another task to get into this same path and process > the item that n_va is pointing to? Then when the preempted task comes back, > grabs the vmap_area_lock, and then continues the loop with what n_va has, > could that cause problems? That is, the next iteration after releasing the > lock does va = n_va. What happens if n_va no longer exits? > > I don't know this code that well, and perhaps vmap_area_lock is not protecting > the list and this is all fine. > Bah, nevermind. I missed the: valist = llist_del_all(&vmap_purge_list); so yeah, all should be good. Nothing to see here, move along please. -- Steve