From mboxrd@z Thu Jan 1 00:00:00 1970 From: Huang Ying Subject: RE: [RFC 1/2] lib, Make gen_pool memory allocator lockless Date: Thu, 10 Feb 2011 16:32:35 +0800 Message-ID: <1297326755.32714.0.camel@yhuang-dev> References: <1297236451-11331-1-git-send-email-ying.huang@intel.com> <1297236451-11331-2-git-send-email-ying.huang@intel.com> <987664A83D2D224EAE907B061CE93D53019D18D43A@orsmsx505.amr.corp.intel.com> Mime-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit Return-path: Received: from mga02.intel.com ([134.134.136.20]:20271 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750991Ab1BJIcv (ORCPT ); Thu, 10 Feb 2011 03:32:51 -0500 In-Reply-To: <987664A83D2D224EAE907B061CE93D53019D18D43A@orsmsx505.amr.corp.intel.com> Sender: linux-acpi-owner@vger.kernel.org List-Id: linux-acpi@vger.kernel.org To: "Luck, Tony" Cc: Len Brown , "linux-kernel@vger.kernel.org" , Andi Kleen , "linux-acpi@vger.kernel.org" , Peter Zijlstra , Andrew Morton , Ingo Molnar On Thu, 2011-02-10 at 03:03 +0800, Luck, Tony wrote: > +static int set_bits_ll(unsigned long *addr, unsigned long mask_to_set) > +{ > + unsigned long val, nval; > + > + nval = *addr; > + do { > + val = nval; > + if (val & mask_to_set) > + return -EBUSY; > + } while ((nval = cmpxchg(addr, val, val | mask_to_set)) != val); > + > + return 0; > +} > > Spin loops like this should have a call to cpu_relax(), shouldn't they? Thanks! Sounds reasonable to me. Will change it. Best Regards, Huang Ying