Received: by 2002:ac0:950c:0:0:0:0:0 with SMTP id f12csp1700732imc; Mon, 11 Mar 2019 21:36:11 -0700 (PDT) X-Google-Smtp-Source: APXvYqw9abGsnM0el6UP36U4fg0RyVf0bsz6Rm3tGgy2Ptlnsf1VruNLQ1H5OHJG7UY212w7Mzeu X-Received: by 2002:aa7:8150:: with SMTP id d16mr36942524pfn.172.1552365371689; Mon, 11 Mar 2019 21:36:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552365371; cv=none; d=google.com; s=arc-20160816; b=e8WETNnz+L5s3Q0Pah8LXqVkRRo+Mpxl9dMV1/Y8gYqX+SbZLO5TeMjE3+ZfCPmxRE 1xezMd1+hwJmd96kijV5DWJpLt61BFaiZIvsl+JpjT3fCcw279UT8GpZ1EdPdLjDMl6n d+g+e5A7+wOM2BlFz3gVe93Yk/9EbgoedzrGu9IxSiRgY8/xu3s591zQZQkIXayF3PVW BLJ7udalCec2GrwZs5e4RKl21fDNEwUmKhKrKpSG/Q6COYuHV1kM2fKkXHnGg7dDZmCL 234aQAE20xr1Diivz3Lr2GkZ7Ib8M9rnvvFDZeulSfiyfuT8Hboqqk6ygyqb4WTX8nkI rRMg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:feedback-id:mime-version:user-agent :references:message-id:in-reply-to:subject:cc:to:from:date :dkim-signature; bh=4mqdNc8jzh5hJ0hdB0WUXyd0kgpmExzkooynOQeDpZQ=; b=n/Uy+66rtuU/wqfN3gFSbbIuu9vjHAJP5srHbQeiZlmtCjOU5yVU4GyZrHG/p0cVch r5dfEytckC+8voz7jCujOj1zgaSLRXLff8GxS9+DFfgOfYmh7TCEu4b1W/feCmIFV/FW GX6AMiIU1DxW201CQJKGDL3eRKtea4MOpS2ZDhywT9f3bGsvr9v4GearBwezf02y/vZs G8rnZFFc4R8kn18ZP1943Ng6h5M2YAPPNi6c3LQMmg2LgInMWI+p32QIo+rHnnDpxIwI w4DtAtMNaUaRSXv6I4nVesGSZ7igWRXFP0ucvKWrxt+ZlHbWVd92BSvx3s3bjG7rRpYN ax2A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@amazonses.com header.s=ug7nbtf4gccmlpwj322ax3p6ow6yfsug header.b=dPZiNMzA; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id k194si6847428pgc.94.2019.03.11.21.35.55; Mon, 11 Mar 2019 21:36:11 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@amazonses.com header.s=ug7nbtf4gccmlpwj322ax3p6ow6yfsug header.b=dPZiNMzA; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726157AbfCLEfQ (ORCPT + 99 others); Tue, 12 Mar 2019 00:35:16 -0400 Received: from a9-46.smtp-out.amazonses.com ([54.240.9.46]:54406 "EHLO a9-46.smtp-out.amazonses.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725792AbfCLEfQ (ORCPT ); Tue, 12 Mar 2019 00:35:16 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/simple; s=ug7nbtf4gccmlpwj322ax3p6ow6yfsug; d=amazonses.com; t=1552365315; h=Date:From:To:cc:Subject:In-Reply-To:Message-ID:References:MIME-Version:Content-Type:Feedback-ID; bh=IbeuS+zdcBFTccbustqiwuLJ9wpMqCNVsFWBtNbKAts=; b=dPZiNMzAgEKy+d5R3GmABBmXu0+p3BIgveTRcb7Y/V7shB2pxnRd55Rqpq7Yz/RQ 7+pnOikBn+Tz2XvX+HJq2s3moWzsIlT6WXoDzB+cHCSn8yPHAMbQ+c+XWdpOzK9LIjj 1sdDXaJUK9OT5kVjMh14wrdnAv2+iM2QHZ5z4Jjw= Date: Tue, 12 Mar 2019 04:35:15 +0000 From: Christopher Lameter X-X-Sender: cl@nuc-kabylake To: Roman Gushchin cc: "Tobin C. Harding" , Andrew Morton , Pekka Enberg , Matthew Wilcox , Tycho Andersen , "linux-mm@kvack.org" , "linux-kernel@vger.kernel.org" Subject: Re: [RFC 02/15] slub: Add isolate() and migrate() methods In-Reply-To: <20190311215106.GA7915@tower.DHCP.thefacebook.com> Message-ID: <01000169702ee357-fe8b85e5-e601-41da-8ba2-25e8b7db52eb-000000@email.amazonses.com> References: <20190308041426.16654-1-tobin@kernel.org> <20190308041426.16654-3-tobin@kernel.org> <20190311215106.GA7915@tower.DHCP.thefacebook.com> User-Agent: Alpine 2.21 (DEB 202 2017-01-01) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII X-SES-Outgoing: 2019.03.12-54.240.9.46 Feedback-ID: 1.us-east-1.fQZZZ0Xtj2+TD7V5apTT/NrT6QKuPgzCT/IC7XYgDKI=:AmazonSES Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 11 Mar 2019, Roman Gushchin wrote: > > --- a/mm/slub.c > > +++ b/mm/slub.c > > @@ -4325,6 +4325,34 @@ int __kmem_cache_create(struct kmem_cache *s, slab_flags_t flags) > > return err; > > } > > > > +void kmem_cache_setup_mobility(struct kmem_cache *s, > > + kmem_cache_isolate_func isolate, > > + kmem_cache_migrate_func migrate) > > +{ > > I wonder if it's better to adapt kmem_cache_create() to take two additional > argument? I suspect mobility is not a dynamic option, so it can be > set on kmem_cache creation. One other idea that prior versions of this patchset used was to change kmem_cache_create() so that the ctor parameter becomes an ops vector. However, in order to reduce the size of the patchset I dropped that. It could be easily moved back to the way it was before. > > + /* > > + * Sadly serialization requirements currently mean that we have > > + * to disable fast cmpxchg based processing. > > + */ > > Can you, please, elaborate a bit more here? cmpxchg based processing does not lock the struct page. SMO requires to ensure that all changes on a slab page can be stopped. The page->lock will accomplish that. I think we could avoid dealing with actually locking the page with some more work.