Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751766Ab0KXCxU (ORCPT ); Tue, 23 Nov 2010 21:53:20 -0500 Received: from mail-qy0-f174.google.com ([209.85.216.174]:63158 "EHLO mail-qy0-f174.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751083Ab0KXCxS (ORCPT ); Tue, 23 Nov 2010 21:53:18 -0500 DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :cc:content-type; b=AIudco0MhgIwUrh70KWrdF+2q5XyMF+d75gZq8VLI8aCmLwZXJznoMG/M+SD87UNb/ e5A7u5rcRkQwGJxxWj4UZv6ksho9ZKxc/4hHxrdbRCquF64ZPuiFB5p1xpcip2WdiR0d KoJwe1EQmxWQwK0awNN4x4eh+fJhX8CLhYQK0= MIME-Version: 1.0 In-Reply-To: <4CEC2BE7.4060205@tilera.com> References: <1289489007.17691.1310.camel@edumazet-laptop> <4CDF1945.8090101@tilera.com> <201011151425.oAFEPU3W005682@farm-0010.internal.tilera.com> <4CEA71AD.5010606@tilera.com> <4CEC2BE7.4060205@tilera.com> Date: Wed, 24 Nov 2010 10:53:17 +0800 Message-ID: Subject: Re: [PATCH] arch/tile: fix rwlock so would-be write lockers don't block new readers From: Cypher Wu To: Chris Metcalf Cc: linux-kernel@vger.kernel.org, =?ISO-8859-1?Q?Am=E9rico_Wang?= , Eric Dumazet , netdev Content-Type: text/plain; charset=ISO-8859-1 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1441 Lines: 35 2010/11/24 Chris Metcalf : > On 11/22/2010 8:36 PM, Cypher Wu wrote: >> Say, if core A try to write_lock() rwlock and current_ticket_ is 0 and >> it write next_ticket_ to 1, when it processing the lock, core B try to >> write_lock() again and write next_ticket_ to 2, then when A >> write_unlock() it seen that (current_ticket_+1) is not equal to >> next_ticket_, so it increment current_ticket_, and core B get the >> lock. If core A try write_lock again before core B write_unlock, it >> will increment next_ticket_ to 3. And so on. >> This may rarely happened, I've tested it yesterday for several hours >> it goes very well under pressure. > > This should be OK when it happens (other than starving out the readers, but > that was the decision made by doing a ticket lock in the first place). > Even if we wrap around 255 back to zero on the tickets, the ticket queue > will work correctly. The key is not to need more than 256 concurrent write > lock waiters, which we don't. > > -- > Chris Metcalf, Tilera Corp. > http://www.tilera.com > > If we count on that, should we make 'my_ticket_ = (val >> WR_NEXT_SHIFT) & WR_MASK;'? -- Cyberman Wu http://www.meganovo.com -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/