From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751098AbcBHJAw (ORCPT ); Mon, 8 Feb 2016 04:00:52 -0500 Received: from mx2.parallels.com ([199.115.105.18]:52169 "EHLO mx2.parallels.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750972AbcBHJAv (ORCPT ); Mon, 8 Feb 2016 04:00:51 -0500 Date: Mon, 8 Feb 2016 12:00:34 +0300 From: Vladimir Davydov To: Dmitry Safonov CC: , , , <0x7f454c46@gmail.com>, Christoph Lameter , Pekka Enberg , David Rientjes , Joonsoo Kim Subject: Re: [PATCH] mm: slab: free kmem_cache_node after destroy sysfs file Message-ID: <20160208090034.GA30053@esperanza> References: <1454692612-14856-1-git-send-email-dsafonov@virtuozzo.com> <20160207191006.GC19151@esperanza> <56B85663.9030406@virtuozzo.com> MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Disposition: inline In-Reply-To: <56B85663.9030406@virtuozzo.com> X-ClientProxiedBy: US-EXCH.sw.swsoft.com (10.255.249.47) To US-EXCH.sw.swsoft.com (10.255.249.47) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Feb 08, 2016 at 11:48:35AM +0300, Dmitry Safonov wrote: ... > >> /* > >> * Attempt to free all partial slabs on a node. > >>- * This is called from kmem_cache_close(). We must be the last thread > >>+ * This is called from __kmem_cache_shutdown(). We must be the last thread > >> * using the cache and therefore we do not need to lock anymore. > >Well, that's not true as we've found out - sysfs might still access the > >cache in parallel. And alloc_calls_show -> list_locations does walk over > >the kmem_cache_node->partial list, which we prune on shutdown. > > > >I guess we should reintroduce locking for free_partial() in the scope of > >this patch, partially reverting 69cb8e6b7c298. > I think, we can omit locking for !SLAB_SUPPORTS_SYSFS and reintroduce > for sysfs case. Will do I really don't think there's any point in cluttering the code with ifdefs here - we'd better just enable locking in any case. It won't hurt performance, because it's a very-very slow path anyway. Besides, SYSFS is on by default on most builds. FWIW SLAB does not omit locking on shutdown, although it doesn't support sysfs. Thanks, Vladimir