Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp4871013pxb; Tue, 25 Jan 2022 22:37:01 -0800 (PST) X-Google-Smtp-Source: ABdhPJxvmfdTFLJg8S8jdZXr5vNhMhKxTbMnrIWRMGxpHgP5AVEZs0InypyhAJpKUzHQW+MJ9mVH X-Received: by 2002:a17:903:31d5:b0:14b:53b7:cbd3 with SMTP id v21-20020a17090331d500b0014b53b7cbd3mr11743134ple.29.1643179021641; Tue, 25 Jan 2022 22:37:01 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643179021; cv=none; d=google.com; s=arc-20160816; b=Vo+9CHng9HXxBvcJT4EWa73SbMdDHJH3VvlJ4hpxXVHPKwVjem0MEo5TbDXJu8zSX3 yTXaLA1Dy8yzuK7EdW8r7OpHlcFOjrO8u9ggoNbEeif4nmVgMPUi3Ejr5GlINR/pPsXp HZsWkLOzu0y/wm3gMZMF/8qQ/0s8/7XpiS0ZvK88oQLbRxFOnOEmw0va/t68lwPk+62G LmnS4/PjRNixZiSKZvlVUrQn/YhvvLnUpPgBMbOy8MRx3H2r6qD6FE4mGv3KBKG2xNb9 2ed/3Kt+zHuD+qFZeuS3HEcfpPi2OBPxxV4BFwa0+m6m2mXZXtXFNxYE5NIIn/0Ns0Jj r7WQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=bt8DG4kv/HiKHmCxuEq4ti3BrhnQMbSnttO4/8+9Xs4=; b=k8j+9cI37u1CD+2VlkRvFrDjpjp/rYu4dumXyaB1wx++IbSFCUwSUTiH6INn65P4G8 7iJPUwbAU8A4UZiUyHlx5XUeGtppkWUkuSBvTRbg9QadaRNSgYlZ4QquVimDZtnE+qxz Tw/0mXEWyXqxtVKTI7woCdTdk8JM2BxxhgB7fjh9r9y5mrQIT8GMZlEJNYolZOrJu12o OazTK0+kO1gkTpOlwSRQl0o/DmKhmtnBb9zNXeVIJxtz7NYdtykGsQOvdWWoS/RSGrBQ uQLvUt382RvPjj/BTQaPHOejGjjz7zelGAJpIGsPcqUNVePRbTmaKBjLoCINcgCG9YOB i2cA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b=sl1vLhCy; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id q21si17543738plr.217.2022.01.25.22.36.49; Tue, 25 Jan 2022 22:37:01 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b=sl1vLhCy; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233381AbiAYTAW (ORCPT + 99 others); Tue, 25 Jan 2022 14:00:22 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44040 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232885AbiAYTAN (ORCPT ); Tue, 25 Jan 2022 14:00:13 -0500 Received: from casper.infradead.org (casper.infradead.org [IPv6:2001:8b0:10b:1236::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E5899C06173E for ; Tue, 25 Jan 2022 11:00:12 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=casper.20170209; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=bt8DG4kv/HiKHmCxuEq4ti3BrhnQMbSnttO4/8+9Xs4=; b=sl1vLhCyZd3T8KmPTjKxZcrVsT yHbYNZfD0SvdklJb+XFTy6+SRgqlug+6n3hTafjWom8+t6HNsM/kinSWuwgRZCUGLx7tIXmxgA+dU vCS89F3ztYMaw23a4R+qztj+agAyg0rwnXi1SOlME1Uu2GQA1EKzIQhX9cg3e22vquRlV3ICyETMj 9kV9sCClzEc7Y+vM9ym4CDlTO49jmrIVLe6IwTczO8MrQLT/+dYnmi7pF9mGBTRCiA3IqfrJ0lWAI SwpoxqO/d8GcivW55uKjW00PHVJ83rpOncMgm1/HcBGxHsoNe+P5b79TCmqADb1hL4bY20Cuiu5+p OJsyB/XA==; Received: from willy by casper.infradead.org with local (Exim 4.94.2 #2 (Red Hat Linux)) id 1nCR2k-003GLD-An; Tue, 25 Jan 2022 18:59:50 +0000 Date: Tue, 25 Jan 2022 18:59:50 +0000 From: Matthew Wilcox To: "Kirill A. Shutemov" Cc: Khalid Aziz , akpm@linux-foundation.org, longpeng2@huawei.com, arnd@arndb.de, dave.hansen@linux.intel.com, david@redhat.com, rppt@kernel.org, surenb@google.com, linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: Re: [RFC PATCH 0/6] Add support for shared PTEs across processes Message-ID: References: <20220125114212.ks2qtncaahi6foan@box.shutemov.name> <20220125135917.ezi6itozrchsdcxg@box.shutemov.name> <20220125185705.wf7p2l77vggipfry@box.shutemov.name> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20220125185705.wf7p2l77vggipfry@box.shutemov.name> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jan 25, 2022 at 09:57:05PM +0300, Kirill A. Shutemov wrote: > On Tue, Jan 25, 2022 at 02:09:47PM +0000, Matthew Wilcox wrote: > > > I think zero-API approach (plus madvise() hints to tweak it) is worth > > > considering. > > > > I think the zero-API approach actually misses out on a lot of > > possibilities that the mshare() approach offers. For example, mshare() > > allows you to mmap() many small files in the shared region -- you > > can't do that with zeroAPI. > > Do you consider a use-case for many small files to be common? I would > think that the main consumer of the feature to be mmap of huge files. > And in this case zero enabling burden on userspace side sounds like a > sweet deal. mmap() of huge files is certainly the Oracle use-case. With occasional funny business like mprotect() of a single page in the middle of a 1GB hugepage. The approach of designating ranges of a process's address space as sharable with other processes felt like the cleaner & frankly more interesting approach that opens up use-cases other than "hurr, durr, we are Oracle, we like big files, kernel get out of way now, transactions to perform".