From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from psmtp.com (na3sys010amx167.postini.com [74.125.245.167]) by kanga.kvack.org (Postfix) with SMTP id 9A2116B0009 for ; Fri, 18 Jan 2013 14:09:53 -0500 (EST) Received: by mail-pb0-f46.google.com with SMTP id wy7so2209079pbc.33 for ; Fri, 18 Jan 2013 11:09:52 -0800 (PST) Subject: Re: [RFC][PATCH v3] slub: Keep page and object in sync in slab_alloc_node() From: Eric Dumazet In-Reply-To: <0000013c4ef61783-2778b0f1-fdc1-421b-9d3e-ccd68d528115-000000@email.amazonses.com> References: <1358446258.23211.32.camel@gandalf.local.home> <1358447864.23211.34.camel@gandalf.local.home> <0000013c4a69a2cf-1a19a6f6-e6a3-4f06-99a4-10fdd4b9aca2-000000@email.amazonses.com> <1358458996.23211.46.camel@gandalf.local.home> <0000013c4a7e7fbf-c51fd42a-2455-4fec-bb37-915035956f05-000000@email.amazonses.com> <1358462763.23211.57.camel@gandalf.local.home> <1358464245.23211.62.camel@gandalf.local.home> <1358464837.23211.66.camel@gandalf.local.home> <1358468598.23211.67.camel@gandalf.local.home> <1358468924.23211.69.camel@gandalf.local.home> <1358521791.7383.11.camel@gandalf.local.home> <0000013c4ef61783-2778b0f1-fdc1-421b-9d3e-ccd68d528115-000000@email.amazonses.com> Content-Type: text/plain; charset="UTF-8" Date: Fri, 18 Jan 2013 11:09:50 -0800 Message-ID: <1358536190.11051.573.camel@edumazet-glaptop> Mime-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: owner-linux-mm@kvack.org List-ID: To: Christoph Lameter Cc: Steven Rostedt , LKML , linux-mm , Andrew Morton , Pekka Enberg , Matt Mackall , Thomas Gleixner , RT , Clark Williams , John Kacur , "Luis Claudio R. Goncalves" On Fri, 2013-01-18 at 18:40 +0000, Christoph Lameter wrote: > The fetching of the tid is the only critical thing here. If the tid is > retrieved from the right cpu then the cmpxchg will fail if any changes > occured to freelist or the page variable. > > The tid can be retrieved without disabling preemption through > this_cpu_read(). Strictly speaking, this_cpu_read() _does_ disable preemption. Of course, on x86, this_cpu_read() uses __this_cpu_read() -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: email@kvack.org