Message ID | 20230613001108.3040476-21-rick.p.edgecombe@intel.com (mailing list archive) |
---|---|
State | New |
Headers | show
Return-Path: <owner-linux-mm@kvack.org> X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 7BE25C88CBA for <linux-mm@archiver.kernel.org>; Tue, 13 Jun 2023 00:12:59 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 18C458E0015; Mon, 12 Jun 2023 20:12:29 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 0C8A18E000B; Mon, 12 Jun 2023 20:12:29 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id DE7498E0015; Mon, 12 Jun 2023 20:12:28 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0014.hostedemail.com [216.40.44.14]) by kanga.kvack.org (Postfix) with ESMTP id BAF868E000B for <linux-mm@kvack.org>; Mon, 12 Jun 2023 20:12:28 -0400 (EDT) Received: from smtpin10.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay08.hostedemail.com (Postfix) with ESMTP id 9325014035B for <linux-mm@kvack.org>; Tue, 13 Jun 2023 00:12:28 +0000 (UTC) X-FDA: 80895797976.10.8807531 Received: from mga03.intel.com (mga03.intel.com [134.134.136.65]) by imf08.hostedemail.com (Postfix) with ESMTP id 62B3C16001F for <linux-mm@kvack.org>; Tue, 13 Jun 2023 00:12:26 +0000 (UTC) Authentication-Results: imf08.hostedemail.com; dkim=pass header.d=intel.com header.s=Intel header.b=QIwfNVHS; dmarc=pass (policy=none) header.from=intel.com; spf=pass (imf08.hostedemail.com: domain of rick.p.edgecombe@intel.com designates 134.134.136.65 as permitted sender) smtp.mailfrom=rick.p.edgecombe@intel.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1686615146; a=rsa-sha256; cv=none; b=wOxJbmPs6Z4bhb8JqhrdUGll2RY4WpxQCl7ZtFaUH4hcBKvtvTv8qdCMgm0pq8ZhUWZpxi qjSbQ1zztbKRpW1nDQmCVNTaXTOk8a5AvmBpZ88WV7R36JU3Ry3A/2jJKQYxVUebuCSu55 UFq8knrIrXJCF6Dkln/rVsWJbPPM0cA= ARC-Authentication-Results: i=1; imf08.hostedemail.com; dkim=pass header.d=intel.com header.s=Intel header.b=QIwfNVHS; dmarc=pass (policy=none) header.from=intel.com; spf=pass (imf08.hostedemail.com: domain of rick.p.edgecombe@intel.com designates 134.134.136.65 as permitted sender) smtp.mailfrom=rick.p.edgecombe@intel.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1686615146; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=eSpfbzj81RJHeXXJwuREGCXBeYOUsrYFIe5C3KzovZA=; b=pkXOhsT8nxlZW3byPQmagOqKWJQwvH5IuyAmbN9SnOhJqwasRGpuPMzjzIJMraI/GfjYgd sfTkFF9Ub9J9ccMfXK8xUqJIMugPWBLKRkh6ZOVMjNrX2XMymQo+zGM0BdDnnyx2FCfhG4 ntt1sh84nO07LYYTMs/NgHMqfcT8TKA= DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1686615146; x=1718151146; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=EOoWyIFrsGRkjg2/O3hP5P9SjQgryxLlQpl2aAV/598=; b=QIwfNVHSnmdVrL/U9bd6je3EgR5A31QT9ua6exiMSxeJFOJnv+XTXOb4 EYNcpsoFqeepxMtWjAsClgGWdPWjH9JQjxTuMsqmfO5pBHtFHM/MOSSfL PwKeq+TFOH1PVTojZUlh96pKXpKkLO7NBaTVh7iAEItsJtl4soI6nf1yC e/6Leo3s+LGZS3rv6RxpsOnQgKvoViDNlfGNi6ezlgCYFL6ttgtSOzcrU Xb+XzHAK31LHLPN6fjdtBnSswVhTlpUuLnZNgIN9PtkuUeraLKvigY/dC UVPAmHaNGTI7zEtXqhkr/YA2jIgo4nhYve03F8aQ2dVbUF8xw5Fs6bMOh w==; X-IronPort-AV: E=McAfee;i="6600,9927,10739"; a="361557128" X-IronPort-AV: E=Sophos;i="6.00,238,1681196400"; d="scan'208";a="361557128" Received: from orsmga004.jf.intel.com ([10.7.209.38]) by orsmga103.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 12 Jun 2023 17:12:25 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10739"; a="835671048" X-IronPort-AV: E=Sophos;i="6.00,238,1681196400"; d="scan'208";a="835671048" Received: from almeisch-mobl1.amr.corp.intel.com (HELO rpedgeco-desk4.amr.corp.intel.com) ([10.209.42.242]) by orsmga004-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 12 Jun 2023 17:12:24 -0700 From: Rick Edgecombe <rick.p.edgecombe@intel.com> To: x86@kernel.org, "H . Peter Anvin" <hpa@zytor.com>, Thomas Gleixner <tglx@linutronix.de>, Ingo Molnar <mingo@redhat.com>, linux-kernel@vger.kernel.org, linux-doc@vger.kernel.org, linux-mm@kvack.org, linux-arch@vger.kernel.org, linux-api@vger.kernel.org, Arnd Bergmann <arnd@arndb.de>, Andy Lutomirski <luto@kernel.org>, Balbir Singh <bsingharora@gmail.com>, Borislav Petkov <bp@alien8.de>, Cyrill Gorcunov <gorcunov@gmail.com>, Dave Hansen <dave.hansen@linux.intel.com>, Eugene Syromiatnikov <esyr@redhat.com>, Florian Weimer <fweimer@redhat.com>, "H . J . Lu" <hjl.tools@gmail.com>, Jann Horn <jannh@google.com>, Jonathan Corbet <corbet@lwn.net>, Kees Cook <keescook@chromium.org>, Mike Kravetz <mike.kravetz@oracle.com>, Nadav Amit <nadav.amit@gmail.com>, Oleg Nesterov <oleg@redhat.com>, Pavel Machek <pavel@ucw.cz>, Peter Zijlstra <peterz@infradead.org>, Randy Dunlap <rdunlap@infradead.org>, Weijiang Yang <weijiang.yang@intel.com>, "Kirill A . Shutemov" <kirill.shutemov@linux.intel.com>, John Allen <john.allen@amd.com>, kcc@google.com, eranian@google.com, rppt@kernel.org, jamorris@linux.microsoft.com, dethoma@microsoft.com, akpm@linux-foundation.org, Andrew.Cooper3@citrix.com, christina.schimpe@intel.com, david@redhat.com, debug@rivosinc.com, szabolcs.nagy@arm.com, torvalds@linux-foundation.org, broonie@kernel.org Cc: rick.p.edgecombe@intel.com, Pengfei Xu <pengfei.xu@intel.com> Subject: [PATCH v9 20/42] x86/mm: Introduce MAP_ABOVE4G Date: Mon, 12 Jun 2023 17:10:46 -0700 Message-Id: <20230613001108.3040476-21-rick.p.edgecombe@intel.com> X-Mailer: git-send-email 2.34.1 In-Reply-To: <20230613001108.3040476-1-rick.p.edgecombe@intel.com> References: <20230613001108.3040476-1-rick.p.edgecombe@intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Rspam-User: X-Rspamd-Server: rspam06 X-Rspamd-Queue-Id: 62B3C16001F X-Stat-Signature: rtde1eb878gg39kuufibu3nyapqn5jb1 X-HE-Tag: 1686615146-607166 X-HE-Meta: U2FsdGVkX1++MOhOb9gDgAcKXvBTHLpI4TSPAb2wG4c3SF9cLJDR/sFgR0iRnamaxyNeN6EbMW9BXI4zooQQgpvepjmYPMo1dWeIXvzWYmL+2ak5fGPWuf0rWP012yclvdHQezILdf9HExQ3gzjG+V8+yal1k7+T9EBerEbTSvg6d0ulVya1qMFVkTSt6X5vPdMMK+7Dw5QvyimdfZM+36rn08ZKut+jLFRRKzxIAvDPJCDsVE+H/NcbVIGEioy/Rs/Ws+jtsrpVfcsO/mFgEgmWd/x4VknaGqkNBtp0lvX951g7cToUyFoDK71hmTydphyq+645AYixsf0BaYdZLulJQz7qpoKOrSK0vJRq4fcecvndYBpuQUgUh/gd4lM/8twdWHt0gnfG30IS+kgd2xJzZT7TGRMOofsHa0Crjj9SWa9luTyWYFPrn6huOh0QT+haEpvfozWJWV1hgf9tokoPk8Y6xMZid1c3HBYj9RPDlCTCaOAuvjDOUz1Y5DWmYm43PasYKV6JoevRGpAnLGa8DpSOvyD6vBtrcnF5R4t80d7KiO4QTDGP0c5ehLuR6mbA1Amer3hmR3+Z1cGuD5ZFXixNhgoQfq1leVocBCDdxJq/tOVzPjyfPetb6x93XqW4MnDfPoUa+dZ7Ay8/UYD+n8M5EUJK1a2NTTXzato3G6ynq3Wk7Xhq2eiT0q/PE7ikigGFW5qKy+zHadEGh3CCSCkUjhW0Mav8xani58059FWFH1ORSbye3XjOO0jL/tBYS0QxI5K9VvZCL5UygWKb5UIjuynazcKVnsJfSsBZ2zAgHRGtG/l1CHhV/3uTkctRY9Nez4JczT4wuSxAbO95kO5jyHJqTbe7Xufy5eXCZ0snm4mihWNd15Y0MgkoZQKwgcL4eTmMP107nUL0Z7qIpY6pQyBPxgHQmhS+TFwx46VyNLLMO+t8/B+2hm09BjlJAdw/d883Oq4FxNE Flo6DVDo gab5wvYY4GsbAhNbu2FVNrKApoREkqq5G0OhvXF20eDX51VEkjlfHQJnYD/SmOmkPBOtB0avT0Ds5MOkF/nngu+X3B7yFOz5xH9prKd23QMZ6NXr8UasaKx+dS39TSqq5Ny8V7B+fIbmtwL9QhKBKb6RbTrjQESeiEBixoPG1qAIvyJpsNI0K1/J2SbvOQYJ6UIGeiNW7zig7e2Z3hTb3rK5voZx3oBBdxNO0jE+Dn/UEmkRG58lyw+SB26tYiYyqJ/+XpdWtX+Jln98Mkf9nJKCnYqKSx1OUojQxwz+AnMdbgnqH9VQRiESyv80m094MHUAteIr8VO9kFBsQMkNn37hvUsKSCDBGi8+AdV0iRuKBQ3o7xgUjvu+nHEC9xHJ7HgsQyW2ACuadc0znSb9MNsEEaWyTztHcUNqczQpf4awc250= X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: <linux-mm.kvack.org> |
Series |
Shadow stacks for userspace
|
expand
|
diff --git a/arch/x86/include/uapi/asm/mman.h b/arch/x86/include/uapi/asm/mman.h index 775dbd3aff73..5a0256e73f1e 100644 --- a/arch/x86/include/uapi/asm/mman.h +++ b/arch/x86/include/uapi/asm/mman.h @@ -3,6 +3,7 @@ #define _ASM_X86_MMAN_H #define MAP_32BIT 0x40 /* only give out 32bit addresses */ +#define MAP_ABOVE4G 0x80 /* only map above 4GB */ #ifdef CONFIG_X86_INTEL_MEMORY_PROTECTION_KEYS #define arch_calc_vm_prot_bits(prot, key) ( \ diff --git a/arch/x86/kernel/sys_x86_64.c b/arch/x86/kernel/sys_x86_64.c index 8cc653ffdccd..c783aeb37dce 100644 --- a/arch/x86/kernel/sys_x86_64.c +++ b/arch/x86/kernel/sys_x86_64.c @@ -193,7 +193,11 @@ arch_get_unmapped_area_topdown(struct file *filp, const unsigned long addr0, info.flags = VM_UNMAPPED_AREA_TOPDOWN; info.length = len; - info.low_limit = PAGE_SIZE; + if (!in_32bit_syscall() && (flags & MAP_ABOVE4G)) + info.low_limit = SZ_4G; + else + info.low_limit = PAGE_SIZE; + info.high_limit = get_mmap_base(0); /* diff --git a/include/linux/mman.h b/include/linux/mman.h index cee1e4b566d8..40d94411d492 100644 --- a/include/linux/mman.h +++ b/include/linux/mman.h @@ -15,6 +15,9 @@ #ifndef MAP_32BIT #define MAP_32BIT 0 #endif +#ifndef MAP_ABOVE4G +#define MAP_ABOVE4G 0 +#endif #ifndef MAP_HUGE_2MB #define MAP_HUGE_2MB 0 #endif @@ -50,6 +53,7 @@ | MAP_STACK \ | MAP_HUGETLB \ | MAP_32BIT \ + | MAP_ABOVE4G \ | MAP_HUGE_2MB \ | MAP_HUGE_1GB)