Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753031AbcLJKgn (ORCPT ); Sat, 10 Dec 2016 05:36:43 -0500 Received: from mail.efficios.com ([167.114.142.141]:59519 "EHLO mail.efficios.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752641AbcLJKgl (ORCPT ); Sat, 10 Dec 2016 05:36:41 -0500 Date: Sat, 10 Dec 2016 10:38:26 +0000 (UTC) From: Mathieu Desnoyers To: Joel Fernandes Cc: linux-kernel , Huang Ying , Ingo Molnar , Will Deacon , "Paul E. McKenney" Message-ID: <1745919097.35200.1481366306119.JavaMail.zimbra@efficios.com> In-Reply-To: <1481343196-24931-1-git-send-email-joelaf@google.com> References: <1481343196-24931-1-git-send-email-joelaf@google.com> Subject: Re: [PATCH] llist: Clarify comments about when locking is needed MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit X-Originating-IP: [167.114.142.141] X-Mailer: Zimbra 8.7.1_GA_1670 (ZimbraWebClient - FF45 (Linux)/8.7.1_GA_1670) Thread-Topic: llist: Clarify comments about when locking is needed Thread-Index: 2uOmgf6OR3rpArj4DBn3G6gQJrWuSw== Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3810 Lines: 91 ----- On Dec 10, 2016, at 5:13 AM, Joel Fernandes joelaf@google.com wrote: > llist.h comments are a bit confusing about when locking is needed versus when > it isn't. Clarify these comments a bit more and be a bit more descriptive about > why locking is needed for llist_del_first. Could rephrase the last sentence as: Clarify these comments by being more descriptive about why locking is needed for llist_del_first. > > Cc: Huang Ying > Cc: Ingo Molnar > Cc: Will Deacon > Cc: Paul McKenney > Cc: Mathieu Desnoyers > Signed-off-by: Joel Fernandes > --- > include/linux/llist.h | 37 +++++++++++++++++++++---------------- > 1 file changed, 21 insertions(+), 16 deletions(-) > > diff --git a/include/linux/llist.h b/include/linux/llist.h > index fd4ca0b..31822bb 100644 > --- a/include/linux/llist.h > +++ b/include/linux/llist.h > @@ -3,28 +3,33 @@ > /* > * Lock-less NULL terminated single linked list > * > - * If there are multiple producers and multiple consumers, llist_add > - * can be used in producers and llist_del_all can be used in > - * consumers. They can work simultaneously without lock. But > - * llist_del_first can not be used here. Because llist_del_first > - * depends on list->first->next does not changed if list->first is not > - * changed during its operation, but llist_del_first, llist_add, > - * llist_add (or llist_del_all, llist_add, llist_add) sequence in > - * another consumer may violate that. > - * > - * If there are multiple producers and one consumer, llist_add can be > - * used in producers and llist_del_all or llist_del_first can be used > - * in the consumer. > - * > - * This can be summarized as follow: > + * Cases where locking is not needed: > + * If there are multiple producers and multiple consumers, llist_add can be > + * used in producers and llist_del_all can be used in consumers simultaneously > + * without locking. Also a single consumer can use llist_del_first while > multiple > + * producers simultaneously use llist_add, without any locking. > + * > + * Cases where locking is needed: > + * If we have multiple consumers with llist_del_first used in one consumer, and > + * llist_del_first or llist_del_all used in other consumers, then a lock is > + * needed. This is because llist_del_first depends on list->first->next not > + * changing, but without lock protection, there's no way to be sure about that > + * if a preemption happens in the middle of the delete operation and on being > + * preempted back, the list->first is the same as before causing the cmpxchg in > + * llist_del_first to succeed. For example, while a llist_del_first operation > + * is in progress in one consumer, then - a llist_del_first, llist_add, Is the "-" expected in this sentence ? Other than that, Acked-by: Mathieu Desnoyers > + * llist_add (or llist_del_all, llist_add, llist_add) sequence in another > + * consumer may cause violations. > + * > + * This can be summarized as follows: > * > * | add | del_first | del_all > * add | - | - | - > * del_first | | L | L > * del_all | | | - > * > - * Where "-" stands for no lock is needed, while "L" stands for lock > - * is needed. > + * Where, a particular row's operation can happen concurrently with a column's > + * operation, with "-" being no lock needed, while "L" being lock is needed. > * > * The list entries deleted via llist_del_all can be traversed with > * traversing function such as llist_for_each etc. But the list > -- > 2.8.0.rc3.226.g39d4020 -- Mathieu Desnoyers EfficiOS Inc. http://www.efficios.com