Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp5179755ybi; Tue, 28 May 2019 08:48:34 -0700 (PDT) X-Google-Smtp-Source: APXvYqymEBdAaQ2UBWgE7NbvO6fxslokdDj3fUyXdocOmVBpEXaP0p5d7IcodzucsCiXlF7WMA9h X-Received: by 2002:a17:902:b70b:: with SMTP id d11mr22890252pls.84.1559058514633; Tue, 28 May 2019 08:48:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1559058514; cv=none; d=google.com; s=arc-20160816; b=A0TYA2jVoO0wZs/C5jTEXhLLdIeiEJqhHTwLYUz5zFIkXdyNNQuI6kENfimR4ysFuf algrFc0B0FxqUAQcrN3+ULQWuab3T6X1A3C74W3HAuwraqxytl56itSl2MpxHROOzuEl PAd2WV/BeWV/S0u+62gBtP2L+ICLXkCyiI8SXgDSinIt0v7D/fb3xGVI+iSMEMWXYZag cVpZ5/s0Yu1KaK1qnNAvGGYCTCY5XfaYU5tg0Tb39Kqw5I3dZyLN/vzSfvGXADNuzJPj EiN1kMStTef/fDelCNPJ17zHVRN4qxrKVxsNqhpRgnRt/JxjuWQ/gSR5vCRC0A7Uw/f9 IpYw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=i/OyxepcdI4MhZ78D6qBCBDXaKNkVnp8K4/arB4y6mc=; b=KKoYzxpo1gs6JKQIFvO7gRUfXCFwZazAGgCoSRTWje/6jd7Zsg8CjDZbPFNpv/fb2F fipZqxPrWwIokHjTiIPA8pm19ehg+xzEbJnUheu9PYijMXdXOjPScjKAgwOEf7IaGQGg 0AqVw1savq3AziOYlqqPfxLVhZS/BKm58o0/xprtkuehrKjuhgiOPUEX+PKRr1+os9uW pVUkC2+hUKMTHzE0ui/6IMHloBAOj8A3BI17gfixhUwnWB/jYaBnSI7a1mn33+pZKchQ 7590zXMsSWNguUrvYG8LX1pgW2zzqlrRVtRbLwhamRSt+/yn5aay2yXe8eI2oCTAGfKq acgQ== ARC-Authentication-Results: i=1; mx.google.com; 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 m63si22995234pld.421.2019.05.28.08.48.18; Tue, 28 May 2019 08:48:34 -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; 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 S1726830AbfE1PlI (ORCPT + 99 others); Tue, 28 May 2019 11:41:08 -0400 Received: from foss.arm.com ([217.140.101.70]:59592 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726602AbfE1PlH (ORCPT ); Tue, 28 May 2019 11:41:07 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id AE9D7341; Tue, 28 May 2019 08:41:06 -0700 (PDT) Received: from arrakis.emea.arm.com (arrakis.cambridge.arm.com [10.1.196.78]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 027FD3F59C; Tue, 28 May 2019 08:41:00 -0700 (PDT) Date: Tue, 28 May 2019 16:40:58 +0100 From: Catalin Marinas To: Andrew Murray Cc: Andrey Konovalov , Mark Rutland , kvm@vger.kernel.org, Szabolcs Nagy , Will Deacon , dri-devel@lists.freedesktop.org, linux-mm@kvack.org, linux-kselftest@vger.kernel.org, Felix Kuehling , Vincenzo Frascino , Jacob Bramley , Leon Romanovsky , linux-rdma@vger.kernel.org, amd-gfx@lists.freedesktop.org, Dmitry Vyukov , Dave Martin , Evgeniy Stepanov , linux-media@vger.kernel.org, Kevin Brodsky , Kees Cook , Ruben Ayrapetyan , Ramana Radhakrishnan , Alex Williamson , Mauro Carvalho Chehab , linux-arm-kernel@lists.infradead.org, Kostya Serebryany , Greg Kroah-Hartman , Yishai Hadas , linux-kernel@vger.kernel.org, Jens Wiklander , Lee Smith , Alexander Deucher , Andrew Morton , Robin Murphy , Christian Koenig , Luc Van Oostenryck Subject: Re: [PATCH v15 05/17] arms64: untag user pointers passed to memory syscalls Message-ID: <20190528154057.GD32006@arrakis.emea.arm.com> References: <00eb4c63fefc054e2c8d626e8fedfca11d7c2600.1557160186.git.andreyknvl@google.com> <20190527143719.GA59948@MBP.local> <20190528145411.GA709@e119886-lin.cambridge.arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190528145411.GA709@e119886-lin.cambridge.arm.com> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, May 28, 2019 at 03:54:11PM +0100, Andrew Murray wrote: > On Mon, May 27, 2019 at 03:37:20PM +0100, Catalin Marinas wrote: > > On Mon, May 06, 2019 at 06:30:51PM +0200, Andrey Konovalov wrote: > > > This patch is a part of a series that extends arm64 kernel ABI to allow to > > > pass tagged user pointers (with the top byte set to something else other > > > than 0x00) as syscall arguments. > > > > > > This patch allows tagged pointers to be passed to the following memory > > > syscalls: brk, get_mempolicy, madvise, mbind, mincore, mlock, mlock2, > > > mmap, mmap_pgoff, mprotect, mremap, msync, munlock, munmap, > > > remap_file_pages, shmat and shmdt. > > > > > > This is done by untagging pointers passed to these syscalls in the > > > prologues of their handlers. > > > > > > Signed-off-by: Andrey Konovalov > > > > Actually, I don't think any of these wrappers get called (have you > > tested this patch?). Following commit 4378a7d4be30 ("arm64: implement > > syscall wrappers"), I think we have other macro names for overriding the > > sys_* ones. > > What is the value in adding these wrappers? Not much value, initially proposed just to keep the core changes small. I'm fine with moving them back in the generic code (but see below). I think another aspect is how we define the ABI. Is allowing tags to mlock() for example something specific to arm64 or would sparc ADI need the same? In the absence of other architectures defining such ABI, my preference would be to keep the wrappers in the arch code. Assuming sparc won't implement untagged_addr(), we can place the macros back in the generic code but, as per the review here, we need to be more restrictive on where we allow tagged addresses. For example, if mmap() gets a tagged address with MAP_FIXED, is it expected to return the tag? My thoughts on allowing tags (quick look): brk - no get_mempolicy - yes madvise - yes mbind - yes mincore - yes mlock, mlock2, munlock - yes mmap - no (we may change this with MTE but not for TBI) mmap_pgoff - not used on arm64 mprotect - yes mremap - yes for old_address, no for new_address (on par with mmap) msync - yes munmap - probably no (mmap does not return tagged ptrs) remap_file_pages - no (also deprecated syscall) shmat, shmdt - shall we allow tagged addresses on shared memory? The above is only about the TBI ABI while ignoring hardware MTE. For the latter, we may want to change the mmap() to allow pre-colouring on page fault which means that munmap()/mprotect() should also support tagged pointers. Possibly mremap() as well but we need to decide whether it should allow re-colouring the page (probably no, in which case old_address and new_address should have the same tag). For some of these we'll end up with arm64 specific wrappers again, unless sparc ADI adopts exactly the same ABI restrictions. -- Catalin