Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933069AbdIRRMu (ORCPT ); Mon, 18 Sep 2017 13:12:50 -0400 Received: from aserp1040.oracle.com ([141.146.126.69]:47514 "EHLO aserp1040.oracle.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932707AbdIRRMs (ORCPT ); Mon, 18 Sep 2017 13:12:48 -0400 Subject: Re: [patch] mremap.2: Add description of old_size == 0 functionality To: Florian Weimer , mtk.manpages@gmail.com Cc: linux-man@vger.kernel.org, linux-kernel@vger.kernel.org, linux-api@vger.kernel.org, Michal Hocko , Andrea Arcangeli , "Kirill A . Shutemov" , Vlastimil Babka , Anshuman Khandual , linux-mm@kvack.org References: <20170915213745.6821-1-mike.kravetz@oracle.com> From: Mike Kravetz Message-ID: Date: Mon, 18 Sep 2017 10:11:44 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.3.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit X-Source-IP: aserv0021.oracle.com [141.146.126.233] Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1841 Lines: 42 On 09/18/2017 06:45 AM, Florian Weimer wrote: > On 09/15/2017 11:53 PM, Mike Kravetz wrote: >> +If the value of \fIold_size\fP is zero, and \fIold_address\fP refers to >> +a private anonymous mapping, then >> +.BR mremap () >> +will create a new mapping of the same pages. \fInew_size\fP >> +will be the size of the new mapping and the location of the new mapping >> +may be specified with \fInew_address\fP, see the description of >> +.B MREMAP_FIXED >> +below. If a new mapping is requested via this method, then the >> +.B MREMAP_MAYMOVE >> +flag must also be specified. This functionality is deprecated, and no >> +new code should be written to use this feature. A better method of >> +obtaining multiple mappings of the same private anonymous memory is via the >> +.BR memfd_create() >> +system call. > > Is there any particular reason to deprecate this? > > In glibc, we cannot use memfd_create and keep the file descriptor around because the application can close descriptors beneath us. > > (We might want to use alias mappings to avoid run-time code generation for PLT-less LD_AUDIT interceptors.) > Hi Florian, When I brought up this mremap 'duplicate mapping' functionality on the mm mail list, most developers were surprised. It seems this functionality exists mostly 'by chance', and it was not really designed. It certainly was never documented. There were suggestions to remove the functionality, which led to my claim that it was being deprecated. However, in hindsight that may have been too strong. I can drop this wording, but would still like to suggest memfd_create as the preferred method of creating duplicate mappings. It would be good if others on Cc: could comment as well. Just curious, does glibc make use of this today? Or, is this just something that you think may be useful. -- Mike Kravetz