From: Dan Williams Subject: Re: [PATCH 01/18] mm: introduce MAP_SHARED_VALIDATE, a mechanism to safely define new mmap flags Date: Wed, 22 Nov 2017 08:52:37 -0800 Message-ID: References: <20171101153648.30166-1-jack@suse.cz> <20171101153648.30166-2-jack@suse.cz> <638b3b80-5cb9-97c2-5055-fef3a1ec25b9@suse.cz> Mime-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Cc: Jan Kara , Ross Zwisler , Christoph Hellwig , linux-fsdevel , "linux-nvdimm@lists.01.org" , Linux MM , Linux API , linux-ext4 , linux-xfs , "Darrick J . Wong" , Arnd Bergmann , Andy Lutomirski , Andrew Morton , Michal Hocko , Matthew Wilcox , Kees Cook , Florian Weimer , John Hubbard , "Kirill A. Shutemov" To: Vlastimil Babka Return-path: In-Reply-To: <638b3b80-5cb9-97c2-5055-fef3a1ec25b9@suse.cz> Sender: owner-linux-mm@kvack.org List-Id: linux-ext4.vger.kernel.org On Wed, Nov 22, 2017 at 4:02 AM, Vlastimil Babka wrote: > On 11/01/2017 04:36 PM, Jan Kara wrote: >> From: Dan Williams >> >> The mmap(2) syscall suffers from the ABI anti-pattern of not validating >> unknown flags. However, proposals like MAP_SYNC need a mechanism to >> define new behavior that is known to fail on older kernels without the >> support. Define a new MAP_SHARED_VALIDATE flag pattern that is >> guaranteed to fail on all legacy mmap implementations. > > So I'm trying to make sense of this together with Michal's attempt for > MAP_FIXED_SAFE [1] where he has to introduce a completely new flag > instead of flag modifier exactly for the reason of not validating > unknown flags. And my conclusion is that because MAP_SHARED_VALIDATE > implies MAP_SHARED and excludes MAP_PRIVATE, MAP_FIXED_SAFE as a > modifier cannot build on top of this. Wouldn't thus it be really better > long-term to introduce mmap3 at this point? ... We have room to define MAP_PRIVATE_VALIDATE in MAP_TYPE on every arch except parisc. Can we steal an extra bit for MAP_TYPE from somewhere else on parisc? -- 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