From patchwork Sat Jul 8 01:11:32 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Charlie Jenkins X-Patchwork-Id: 13305512 Return-Path: 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 99517C00528 for ; Sat, 8 Jul 2023 01:12:18 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 388986B0072; Fri, 7 Jul 2023 21:12:18 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 3389F8D0002; Fri, 7 Jul 2023 21:12:18 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 1D9508D0001; Fri, 7 Jul 2023 21:12:18 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0013.hostedemail.com [216.40.44.13]) by kanga.kvack.org (Postfix) with ESMTP id F2FC06B0072 for ; Fri, 7 Jul 2023 21:12:17 -0400 (EDT) Received: from smtpin14.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay08.hostedemail.com (Postfix) with ESMTP id AF3F4140169 for ; Sat, 8 Jul 2023 01:12:17 +0000 (UTC) X-FDA: 80986668714.14.5080185 Received: from mail-oo1-f50.google.com (mail-oo1-f50.google.com [209.85.161.50]) by imf28.hostedemail.com (Postfix) with ESMTP id D70FDC000D for ; Sat, 8 Jul 2023 01:12:15 +0000 (UTC) Authentication-Results: imf28.hostedemail.com; dkim=pass header.d=rivosinc-com.20221208.gappssmtp.com header.s=20221208 header.b=3xtx3kLk; dmarc=none; spf=pass (imf28.hostedemail.com: domain of charlie@rivosinc.com designates 209.85.161.50 as permitted sender) smtp.mailfrom=charlie@rivosinc.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1688778735; 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=1lKe6yHyZy9K3PFiy7uwsh090/tMqL+ZOHLxwbJUQNU=; b=MGObZs2+IKxlrTlCiBfeFpCgqKOTRkqFatmNB8qpe3sWfSIGNAbWfGnGPPvyu/DauSTfjV VyePLl6Ah177O5qvdo8du8PPX4LF2q4wAACWVC0V7jQiHLfNmCUjQjdT46Ysw/54cKIBbe MHnts8v5dlosCUbetRHcI175cN0OG2o= ARC-Authentication-Results: i=1; imf28.hostedemail.com; dkim=pass header.d=rivosinc-com.20221208.gappssmtp.com header.s=20221208 header.b=3xtx3kLk; dmarc=none; spf=pass (imf28.hostedemail.com: domain of charlie@rivosinc.com designates 209.85.161.50 as permitted sender) smtp.mailfrom=charlie@rivosinc.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1688778735; a=rsa-sha256; cv=none; b=jeaRS/lWloDKkIAgKtMlpNqo8KVXoie+9/vbB7Uon8TWCvyy0f3ewXMsGTCScrTBtr07M+ IHk9EKC1Xob4RssXhAJ4PqxokWim7Cxmrpg2UH706/tkUvcUeRy1yaZSPC5KGkgKCHBfbx JhWKlUs9vdhTLbKXF1nYlvc5drFsFDY= Received: by mail-oo1-f50.google.com with SMTP id 006d021491bc7-56584266c41so1830024eaf.2 for ; Fri, 07 Jul 2023 18:12:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=rivosinc-com.20221208.gappssmtp.com; s=20221208; t=1688778735; x=1691370735; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=1lKe6yHyZy9K3PFiy7uwsh090/tMqL+ZOHLxwbJUQNU=; b=3xtx3kLk27Pt5nQRjo2gIABwLUOicjlR50GeIy3PIPo3T7ivLSyd0Mn3gjEwJzZM0r 0dM6f2JeTRuxED/dJNaqCELwLP/w1FTo+GLHgNP34xh7mKbJ64eikyBDPxbg/DJfJvhx Y+cVCTchX1Y+56HFaSRczQptsqV3qq+Kgpfme7g5v27i80wMH/Qmbw0AYfYv2t1nCjW6 uX/hFmbnWEGjyG+JKsxI/H0ErMxzzsryWUexcdUBjZwftfcYW2BCK7xlKqyuh3609j9J t8ostOouYIat8RZ6iWw8hSRqtnElpqSCQeRwT1TOVrpbUFlUkDBnyRauYk/bLjMvJq4c jJjQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1688778735; x=1691370735; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=1lKe6yHyZy9K3PFiy7uwsh090/tMqL+ZOHLxwbJUQNU=; b=BeenGLzh/RzIxcwvYsBOyTuMwf9qLO6CUrtKTzm4TUz53H0Jm+NTBZeb4YijrWOF96 3u/VLnZElKCo5eGXBzqWIeuTShxXRN/qS15F16tKWpB2Br/0I4PwinWajkeJ0dGNDUc7 /lTWTvtYyneqZZ5zvqINvi3D4ca1wZFkAU07RX6XJfVLyllRVDTa/c1Z8ll/P3/5ASjf QqFuSSEIhKIlpyHRkSt0P0WzQzyE9aS4UgzVFsAcJxhiH1Gl3LIroUCt04cmMTN+7ic9 pzne6fm/iN6BTTbFFoAWX0KpOWNrzf2mP42Qt70d5L2zXnQ+sNSCy/IK2Gc8DgSP63YQ oKvw== X-Gm-Message-State: ABy/qLZn48w8A3JSJpOmA8dNcPKXtexe7iWuQf/o7Z0F3hdH/jNyPW/2 E6FksCvW43/bEUaOXh9r+S9Cxg== X-Google-Smtp-Source: APBJJlGg5nRKgYW+XdI1rMP/hwn173NFRuMlzbFPemjPeQPEYTIF5WuXBIKOFywdw6/fbn7CMjMf9Q== X-Received: by 2002:a05:6358:e48b:b0:135:24ed:5108 with SMTP id by11-20020a056358e48b00b0013524ed5108mr8839615rwb.10.1688778734803; Fri, 07 Jul 2023 18:12:14 -0700 (PDT) Received: from charlie.ba.rivosinc.com ([66.220.2.162]) by smtp.gmail.com with ESMTPSA id x24-20020a170902b41800b001b87d3e845bsm3830654plr.149.2023.07.07.18.12.13 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 07 Jul 2023 18:12:14 -0700 (PDT) From: Charlie Jenkins To: linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org Cc: charlie@rivosinc.com, conor@kernel.org, paul.walmsley@sifive.com, palmer@rivosinc.com, aou@eecs.berkeley.edu, anup@brainfault.org, konstantin@linuxfoundation.org, linux-doc@vger.kernel.org, linux-kselftest@vger.kernel.org, linux-mm@kvack.org, mick@ics.forth.gr, jrtc27@jrtc27.com, rdunlap@infradead.org Subject: [PATCH v4 1/4] RISC-V: mm: Restrict address space for sv39,sv48,sv57 Date: Fri, 7 Jul 2023 18:11:32 -0700 Message-ID: <20230708011156.2697409-2-charlie@rivosinc.com> X-Mailer: git-send-email 2.41.0 In-Reply-To: <20230708011156.2697409-1-charlie@rivosinc.com> References: <20230708011156.2697409-1-charlie@rivosinc.com> MIME-Version: 1.0 X-Rspamd-Queue-Id: D70FDC000D X-Rspam-User: X-Rspamd-Server: rspam05 X-Stat-Signature: 4rynmmu5an8mzstxsa9jxmo14ima6hpg X-HE-Tag: 1688778735-301241 X-HE-Meta: U2FsdGVkX19+eQf1Uhh13KJTqgnGUejd1aAfY2+ZW9pc8F2+04WEACBvaoIPYI5EyZQ+PLeqYAdo2LPGppCJR0czZsL7kF4ZV5NWENu4YJcYNfRctfKaBVXSoo7Flwnrs3V5b9tPkBGtgoFTQ88fiM7Y7cF6Fgg6WavDSxNtgwj09agnsbiAiufXBiWlishI3lowSZChpUQfGxxALgVESJ3skqCtmqhNQ376fMURcvtDHn2dOBqKi9KctQ2+wj6hggcqhFSAw6iAWf/RSYxDdZjS8C6Icyf3U6n/fgCGw5kNBzRq3SWKhqZ4NjhH1OOkrXRIzftYpBEuWvbo7CKZAQB+xl34XemzJdZZ4Qus/2UhTgSBup8YPLo3GP6XbSBvXYPdFnxv6cVfRTe3FKyZnuAvn5nJ9c0Z6Ji6uQI34aXjeqWNUY/alFNFqmjENSPXJMO7UPKZmcbT1wdyawS3E2CBdsQwMoz38mhgI9gSaxiamwSqU1ZBpwNkSXRo/d8UeFgB/7Mr8mLGaN67ZQ+8Ck0qmya7Ux+WdqtuHZf0RrvqoxTyQFTLU7lMD7GKXiMrzYgP6n15AP3WgjgqMNpXtufM/6PtcZAT9O4gFg7uZbAKHEqdmK5gssfQO8EeUYfcfpYX01VSMmt2flNS2IEV3900vIXSbRlh8aiix0z7DRUw3AZ0zFpVsc0pnvkFw/cy8+Pruu/RY8M+CUVOtBTc4VQ0UNR2scrdR7XS17CHgs0CAfOIKCOseSJwV0McQbXDtOlZnnqtORBMjPrt9KiwqSjpwuQfxgBIPlEZK5fyFbxE9v9W857nEUmw+POYZK6NZZMfreTSXgJV/832CDPVQgfhG7GY5vxtDbWtvQEKnO/Exb4Li80ReFhMQL8tbhVtxRmMu8e/f9bztwQugh0/w4sdoziB5PDs8F1mIdFRvZgQI8dcD+PzpPHk7ZoDCTE/UuUU6HLaEZM9Glsrn7Q sJ1BtDom 5eyZN/Nedq3CQvAQkgUdgI6hWq+enFrr6LxEzRmccQjwDsgz0MX+DYkJ7EH1+f2HIFlpj0bqXEDK+gljQ7qRRpPjR4k9DESKbjwIpYrfsApbu/+o9lc8XY6/S7bfb6o74QjoiE8SrzQvHXG6bngW+xNf6eRItcTca+obH+aQ/szAKvUgOy/cOrFkI2dy1XZxQ5m1rCrAmBRuuzlwVuUEboY9F1mgTHpD/3fqnV5pidMrqhALz11cHZTVDYKKuFimbCqMVaz2Y8vXetz203TeVuK/OsgnR3WpvkvY2lXmyJU08Ybnc6rfgj9JIiq3XEttUFjkUFr8Kjj6tucgpIl+ULKsEZUeBCaA6JcPxwD+Ma7bSL58ZAw/cjATRrcW2cjhAduzNVBIZcOjMl3nf1v3h+gZcdRaQFZAAUAHH13auTvA8Iz4ckTudG5hTmuqZynqUcwp8 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: Make sv48 the default address space for mmap as some applications currently depend on this assumption. A hint address passed to mmap will cause the largest address space that fits entirely into the hint to be used. If the hint is less than or equal to 1<<38, an sv39 address will be used. An exception is that if the hint address is 0, then a sv48 address will be used. After an address space is completely full, the next smallest address space will be used. Signed-off-by: Charlie Jenkins --- arch/riscv/include/asm/elf.h | 2 +- arch/riscv/include/asm/pgtable.h | 13 ++++++++- arch/riscv/include/asm/processor.h | 43 +++++++++++++++++++++++++----- 3 files changed, 49 insertions(+), 9 deletions(-) diff --git a/arch/riscv/include/asm/elf.h b/arch/riscv/include/asm/elf.h index c24280774caf..5d3368d5585c 100644 --- a/arch/riscv/include/asm/elf.h +++ b/arch/riscv/include/asm/elf.h @@ -49,7 +49,7 @@ extern bool compat_elf_check_arch(Elf32_Ehdr *hdr); * the loader. We need to make sure that it is out of the way of the program * that it will "exec", and that there is sufficient room for the brk. */ -#define ELF_ET_DYN_BASE ((TASK_SIZE / 3) * 2) +#define ELF_ET_DYN_BASE ((DEFAULT_MAP_WINDOW / 3) * 2) #ifdef CONFIG_64BIT #ifdef CONFIG_COMPAT diff --git a/arch/riscv/include/asm/pgtable.h b/arch/riscv/include/asm/pgtable.h index 75970ee2bda2..a8090ebea705 100644 --- a/arch/riscv/include/asm/pgtable.h +++ b/arch/riscv/include/asm/pgtable.h @@ -57,18 +57,29 @@ #define MODULES_END (PFN_ALIGN((unsigned long)&_start)) #endif + /* * Roughly size the vmemmap space to be large enough to fit enough * struct pages to map half the virtual address space. Then * position vmemmap directly below the VMALLOC region. */ #ifdef CONFIG_64BIT +#define VA_BITS_SV39 39 +#define VA_BITS_SV48 48 +#define VA_BITS_SV57 57 + +#define VA_USER_SV39 (UL(1) << (VA_BITS_SV39 - 1)) +#define VA_USER_SV48 (UL(1) << (VA_BITS_SV48 - 1)) +#define VA_USER_SV57 (UL(1) << (VA_BITS_SV57 - 1)) + #define VA_BITS (pgtable_l5_enabled ? \ - 57 : (pgtable_l4_enabled ? 48 : 39)) + VA_BITS_SV57 : (pgtable_l4_enabled ? VA_BITS_SV48 : VA_BITS_SV39)) #else #define VA_BITS 32 #endif +#define MMAP_VA_BITS ((VA_BITS >= VA_BITS_SV48) ? VA_BITS_SV48 : VA_BITS) + #define VMEMMAP_SHIFT \ (VA_BITS - PAGE_SHIFT - 1 + STRUCT_PAGE_MAX_SHIFT) #define VMEMMAP_SIZE BIT(VMEMMAP_SHIFT) diff --git a/arch/riscv/include/asm/processor.h b/arch/riscv/include/asm/processor.h index c950a8d9edef..63715c071e1b 100644 --- a/arch/riscv/include/asm/processor.h +++ b/arch/riscv/include/asm/processor.h @@ -13,20 +13,49 @@ #include -/* - * This decides where the kernel will search for a free chunk of vm - * space during mmap's. - */ -#define TASK_UNMAPPED_BASE PAGE_ALIGN(TASK_SIZE / 3) - -#define STACK_TOP TASK_SIZE #ifdef CONFIG_64BIT +#define DEFAULT_MAP_WINDOW (UL(1) << (MMAP_VA_BITS - 1)) #define STACK_TOP_MAX TASK_SIZE_64 + +#define arch_get_mmap_end(addr, len, flags) \ +({ \ + unsigned long mmap_end; \ + if ((addr) >= VA_USER_SV57) \ + mmap_end = STACK_TOP_MAX; \ + else if ((((addr) >= VA_USER_SV48)) && (VA_BITS >= VA_BITS_SV48)) \ + mmap_end = VA_USER_SV48; \ + else \ + mmap_end = VA_USER_SV39; \ + mmap_end; \ +}) + +#define arch_get_mmap_base(addr, base) \ +({ \ + unsigned long mmap_base; \ + if ((addr >= VA_USER_SV57) && (VA_BITS >= VA_BITS_SV57)) \ + mmap_base = base + (VA_USER_SV57 - DEFAULT_MAP_WINDOW); \ + else if ((((addr) >= VA_USER_SV48)) && (VA_BITS >= VA_BITS_SV48)) \ + mmap_base = base + (VA_USER_SV48 - DEFAULT_MAP_WINDOW); \ + else \ + mmap_base = base + (VA_USER_SV39 - DEFAULT_MAP_WINDOW); \ + mmap_base; \ +}) + #else +#define DEFAULT_MAP_WINDOW TASK_SIZE #define STACK_TOP_MAX TASK_SIZE #endif #define STACK_ALIGN 16 + +#define STACK_TOP DEFAULT_MAP_WINDOW + +/* + * This decides where the kernel will search for a free chunk of vm + * space during mmap's. + */ +#define TASK_UNMAPPED_BASE PAGE_ALIGN(DEFAULT_MAP_WINDOW / 3) + #ifndef __ASSEMBLY__ struct task_struct; From patchwork Sat Jul 8 01:11:33 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Charlie Jenkins X-Patchwork-Id: 13305513 Return-Path: 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 BA5FBC001E0 for ; Sat, 8 Jul 2023 01:12:20 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 3FD9D6B0074; Fri, 7 Jul 2023 21:12:20 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 3897E8D0002; Fri, 7 Jul 2023 21:12:20 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 1DAB18D0001; Fri, 7 Jul 2023 21:12:20 -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 E78C56B0074 for ; Fri, 7 Jul 2023 21:12:19 -0400 (EDT) Received: from smtpin04.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay08.hostedemail.com (Postfix) with ESMTP id 8D4CE140163 for ; Sat, 8 Jul 2023 01:12:19 +0000 (UTC) X-FDA: 80986668798.04.18E01B1 Received: from mail-oo1-f48.google.com (mail-oo1-f48.google.com [209.85.161.48]) by imf26.hostedemail.com (Postfix) with ESMTP id B636D140013 for ; Sat, 8 Jul 2023 01:12:17 +0000 (UTC) Authentication-Results: imf26.hostedemail.com; dkim=pass header.d=rivosinc-com.20221208.gappssmtp.com header.s=20221208 header.b=HDgqAprx; spf=pass (imf26.hostedemail.com: domain of charlie@rivosinc.com designates 209.85.161.48 as permitted sender) smtp.mailfrom=charlie@rivosinc.com; dmarc=none ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1688778737; a=rsa-sha256; cv=none; b=Ln8gP11vvWVGsX8Sj/OLdTR4F7A0zpgFuRdWGyDCUkzUJhMtnLW4ZIoHWJ5QSMBcR7FuIl ZGmcykzn7w9IrlhXZqREg5xzHjrYtJb1YzjabVMB/AYVMdt8EJlqn1/7HpLmjMwEB9rNCW WfpxxMZYwaMzkDyBQJTtYGtS+SGqbgY= ARC-Authentication-Results: i=1; imf26.hostedemail.com; dkim=pass header.d=rivosinc-com.20221208.gappssmtp.com header.s=20221208 header.b=HDgqAprx; spf=pass (imf26.hostedemail.com: domain of charlie@rivosinc.com designates 209.85.161.48 as permitted sender) smtp.mailfrom=charlie@rivosinc.com; dmarc=none ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1688778737; 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=fFZ0EGHA/E167mwLb87wWH3iE0UjDp5JHbGLXoRkRqA=; b=GB3LvzKzs6+63j4D37dBwQ3xNvju5PRJUvoi6deHYGkV/gMG3U0h0LJCVeM6KvYai8C84t 01IV1noL3iDEh6/Np1Qhf8ekAtdD97Xzl6RaARCeMSNa8/PAxJWmODnlM8EsdNcJevSxMx e1JLGYHBlhBLhBNJwoH6uVmeWICaxss= Received: by mail-oo1-f48.google.com with SMTP id 006d021491bc7-5634808e16eso1873151eaf.2 for ; Fri, 07 Jul 2023 18:12:17 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=rivosinc-com.20221208.gappssmtp.com; s=20221208; t=1688778737; x=1691370737; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=fFZ0EGHA/E167mwLb87wWH3iE0UjDp5JHbGLXoRkRqA=; b=HDgqAprxKYm8kUAilt9ykmDFPdqSL5jzWa9ZQIg86N24hikrK7bFrh8lq9sOZNwcPJ GBQg/fc1ly4OcubeE4NEsYMV+rwcoEbtoO4YkEArdhelBYw40CmWE9tT0YBWLSZLRbZM gD5cyaZQ0gIgEIDaE0ITuDdSsIIq0Ee2cthIO0/netNj0Z7HlXRR6YyK2iGgI7N2H431 +ol/lZUst/dsO+/YYsrxFeJcj0Oq2FtOA4KrjdCgQs4R+RbL1D4MdTXNhdB8Airt2xTu 3hbyfC3E+ioskekFf0KRq4JRnYlVpHJVFc/tcZlogM0HGJuNlsfqFWcB4erEtn7CaCbA oRjg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1688778737; x=1691370737; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=fFZ0EGHA/E167mwLb87wWH3iE0UjDp5JHbGLXoRkRqA=; b=PiSzTZNtGEjti/sakjdcrfegU+/EF73EVwJKMvkhVYAmrjigtQ01KKstnIClm6CSrc YSMaE+lDD6ey+NX/cA4yCFivSXphq+csCaBkNb+3bnHOzAcNw+4nJC9MD7Pe5KqAUJNz WIt3kunGglV+EMGb6rMHTXc+luoz4s6KpDdt/b/JnFiIDzpKgbMfGIXIIJP5sXS8le0l tQOO8aRkB9UeIsi4ZuzYDouzp06paKTVoz8LnbNuc2mG3QSC+nfg3VCN1N8IFPF9d+HA 7TB6Mm3Zq4+j52Ag2z4XQsi+W84Zda87wjwq3/ynJvEmaOAe9OKiPZk2G5+rMe0TOFXB XMDA== X-Gm-Message-State: ABy/qLaVrCNQkddKv7SitzCK7528G3SNygM5rWBu7wKbeg7KBev5kOqu pH7hDqJFVrMoTcBqYHvyWUmD7w== X-Google-Smtp-Source: APBJJlEFdNEztRYAagPRAz9QaNM7HMXGie5hZWVWxVe2fWa+vBsugeNU+m5ep6BeVbUuhpVIZAjDVw== X-Received: by 2002:a05:6358:2905:b0:134:ec26:b53 with SMTP id y5-20020a056358290500b00134ec260b53mr8012421rwb.16.1688778736790; Fri, 07 Jul 2023 18:12:16 -0700 (PDT) Received: from charlie.ba.rivosinc.com ([66.220.2.162]) by smtp.gmail.com with ESMTPSA id x24-20020a170902b41800b001b87d3e845bsm3830654plr.149.2023.07.07.18.12.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 07 Jul 2023 18:12:16 -0700 (PDT) From: Charlie Jenkins To: linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org Cc: charlie@rivosinc.com, conor@kernel.org, paul.walmsley@sifive.com, palmer@rivosinc.com, aou@eecs.berkeley.edu, anup@brainfault.org, konstantin@linuxfoundation.org, linux-doc@vger.kernel.org, linux-kselftest@vger.kernel.org, linux-mm@kvack.org, mick@ics.forth.gr, jrtc27@jrtc27.com, rdunlap@infradead.org Subject: [PATCH v4 2/4] RISC-V: mm: Add tests for RISC-V mm Date: Fri, 7 Jul 2023 18:11:33 -0700 Message-ID: <20230708011156.2697409-3-charlie@rivosinc.com> X-Mailer: git-send-email 2.41.0 In-Reply-To: <20230708011156.2697409-1-charlie@rivosinc.com> References: <20230708011156.2697409-1-charlie@rivosinc.com> MIME-Version: 1.0 X-Rspamd-Server: rspam08 X-Rspamd-Queue-Id: B636D140013 X-Stat-Signature: bwgjghizopcrize9gn9w1efb9pfh93i7 X-Rspam-User: X-HE-Tag: 1688778737-937369 X-HE-Meta: U2FsdGVkX18+xq9WbR72sUArFkrTgF7/LcTAkfNEtamZFleq2Dj9mA9Yjnqi3OgxzqowGQHNYXvEYXFXGxymOX/abGpQciRPNs0wRxMPyNMurZLxrAwBVkW/FYi/Yk0itjZqVqeDnaNeSMiH4RLMAxbWNxOUEVh/R3dQH8pm8vFqLpyB1jP6IYd10n20gD7PrSM51eDtja+xZpzaW3N3OhwA2UxL3hIMRW9JISbwGtsVdAtNUBXntU8nJAEFAm+rakIVe6bn6hitP7GR2ea3SZRRcG7UZURw3lfp9zbfWaSm9V+PIqdVN1Oz6P+WoTFknbZnXTX0HvAQqyTIpCkKMMu7Vqib9gNUEfQuXcrISdlRvsVdt7wyDbke5ft48Q6zsVUsBW13u7uO9+ZeBKI6lL5tS0fod/f9oCmf3AHZywugFHajqFPZAcntRyAB+qTxpdZ1Vn4A8t9ZGUH0KVxhNYT5QiJA051sHVG7pR3kn8DH+guLgOJ1Tw6ZDuE7aQNVHQcZXLkHCeJC6FNsnc37AE7/Mf1shLSNdSNUoN5MHtaDHSJW7Cdoc1IKFUEGlVvhDRI2TPml8YwR53Dn1SykOzV/uEfUCMp194Yi2GiZq+tRrgnKPZ4HlZ6ONArSDKt1V+U6rTXdaEzOWExo8IJnYemKbrMeqLjYsSrQ44TPvK4OKBzaYO4mj7cA3zQrzKE/0osXzkXpkwCCR5NX9iYjrhtWlvbNb+zga0aFibAVfG4aVGY7TeDeP0K5Fn1yt3/jSO+qEGBAsBTl3ScR6oMn96Ek/2srrPMNEUQaCEHF/M0xVrpPYuqXvkmakHLJW1CDSG28EyhFE6UpDApeA+WotRarPOTMLYmarbGMj+a3bbCirjgYj9kWTcEo+heowAXwmWmb38ja0Aj3dRvdqE1XHvQHg4fZ4bwy/qn8YcaDc3M+fIHvxBVc+v7aQzBQ0Kroq8+Z/mjW4vj7krqjd/I H1qgJtZm FmN2swZuTP1G8Z3xvfvQTRqcNifiu+hPDGm9melarloMX1VeVZl57OpL8EV/URgu0u45tl3O90YX51bY9XG0ps+x70e/1x9lrfVee77dpdutGP45jh+0CrpORfb33QgT3kwstWhoQYMhym1c4+4b2cvu1Q4PmOKGnM2GQdqm9FHHFsStlP5yUDDGehu9DwBjTeJyCADqRpaHiMGPJKb+n3azBXP3b2ckGGlpAdu472cVZYdKyMpBQlACLiMJuf8vTZ2kWYollUL/vRgvFOlZKn/SbIwBo5jiUeq5vt0WHWDcYuU+UBI8Zh9DMNIr4GGWxhB9HmXVND+b4uPON3ogwjHEnFcF+sN3PGQhQctHg7BF5ERvVRiDYehcQcZD1PKOtIbcRDeWOaq91ivNF52Z2RoWn1lsR7W5JJQQ1XlD7h1T5LdBC+3ID2PkKsWXyPDr4e56H X-Bogosity: Ham, tests=bogofilter, spamicity=0.000565, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: Add tests that enforce mmap hint address behavior. mmap should default to sv48. mmap will provide an address at the highest address space that can fit into the hint address, unless the hint address is less than sv39 and not 0, then it will return a sv39 address. In addition, ensure that rlimit changes do not cause mmap to fail. Signed-off-by: Charlie Jenkins --- tools/testing/selftests/riscv/Makefile | 2 +- tools/testing/selftests/riscv/mm/.gitignore | 1 + tools/testing/selftests/riscv/mm/Makefile | 21 +++ .../selftests/riscv/mm/testcases/mmap.c | 133 ++++++++++++++++++ 4 files changed, 156 insertions(+), 1 deletion(-) create mode 100644 tools/testing/selftests/riscv/mm/.gitignore create mode 100644 tools/testing/selftests/riscv/mm/Makefile create mode 100644 tools/testing/selftests/riscv/mm/testcases/mmap.c diff --git a/tools/testing/selftests/riscv/Makefile b/tools/testing/selftests/riscv/Makefile index 9dd629cc86aa..1b79da90396e 100644 --- a/tools/testing/selftests/riscv/Makefile +++ b/tools/testing/selftests/riscv/Makefile @@ -5,7 +5,7 @@ ARCH ?= $(shell uname -m 2>/dev/null || echo not) ifneq (,$(filter $(ARCH),riscv)) -RISCV_SUBTARGETS ?= hwprobe vector +RISCV_SUBTARGETS ?= hwprobe vector mm else RISCV_SUBTARGETS := endif diff --git a/tools/testing/selftests/riscv/mm/.gitignore b/tools/testing/selftests/riscv/mm/.gitignore new file mode 100644 index 000000000000..9a6f303edcd3 --- /dev/null +++ b/tools/testing/selftests/riscv/mm/.gitignore @@ -0,0 +1 @@ +mmap diff --git a/tools/testing/selftests/riscv/mm/Makefile b/tools/testing/selftests/riscv/mm/Makefile new file mode 100644 index 000000000000..cf68e63e7495 --- /dev/null +++ b/tools/testing/selftests/riscv/mm/Makefile @@ -0,0 +1,21 @@ +# SPDX-License-Identifier: GPL-2.0 +# Originally tools/testing/selftests/arm64/signal + +# Additional include paths needed by kselftest.h and local headers +CFLAGS += -D_GNU_SOURCE -std=gnu99 -I. + +SRCS := $(filter-out testcases/testcases.c,$(wildcard testcases/*.c)) +PROGS := $(patsubst %.c,%,$(SRCS)) + +# Generated binaries to be installed by top KSFT script +TEST_GEN_PROGS := $(notdir $(PROGS)) + +# Get Kernel headers installed and use them. + +# Including KSFT lib.mk here will also mangle the TEST_GEN_PROGS list +# to account for any OUTPUT target-dirs optionally provided by +# the toplevel makefile +include ../../lib.mk + +$(TEST_GEN_PROGS): $(PROGS) + cp $(PROGS) $(OUTPUT)/ diff --git a/tools/testing/selftests/riscv/mm/testcases/mmap.c b/tools/testing/selftests/riscv/mm/testcases/mmap.c new file mode 100644 index 000000000000..d8e751f7b8c9 --- /dev/null +++ b/tools/testing/selftests/riscv/mm/testcases/mmap.c @@ -0,0 +1,133 @@ +// SPDX-License-Identifier: GPL-2.0-only +#include +#include +#include + +#include "../../kselftest_harness.h" +struct addresses { + int *no_hint; + int *on_37_addr; + int *on_38_addr; + int *on_46_addr; + int *on_47_addr; + int *on_55_addr; + int *on_56_addr; +}; + +void do_mmaps(struct addresses *mmap_addresses) +{ + // Place all of the hint addresses on the boundaries of mmap + // sv39, sv48, sv57 + // User addresses end at 1<<38, 1<<47, 1<<56 respectively + void *on_37_bits = (void *)(1UL << 37); + void *on_38_bits = (void *)(1UL << 38); + void *on_46_bits = (void *)(1UL << 46); + void *on_47_bits = (void *)(1UL << 47); + void *on_55_bits = (void *)(1UL << 55); + void *on_56_bits = (void *)(1UL << 56); + + int prot = PROT_READ | PROT_WRITE; + int flags = MAP_PRIVATE | MAP_ANONYMOUS; + + mmap_addresses->no_hint = + mmap(NULL, 5 * sizeof(int), prot, flags, 0, 0); + mmap_addresses->on_37_addr = + mmap(on_37_bits, 5 * sizeof(int), prot, flags, 0, 0); + mmap_addresses->on_38_addr = + mmap(on_38_bits, 5 * sizeof(int), prot, flags, 0, 0); + mmap_addresses->on_46_addr = + mmap(on_46_bits, 5 * sizeof(int), prot, flags, 0, 0); + mmap_addresses->on_47_addr = + mmap(on_47_bits, 5 * sizeof(int), prot, flags, 0, 0); + mmap_addresses->on_55_addr = + mmap(on_55_bits, 5 * sizeof(int), prot, flags, 0, 0); + mmap_addresses->on_56_addr = + mmap(on_56_bits, 5 * sizeof(int), prot, flags, 0, 0); +} + +TEST(default_rlimit) +{ +// Only works on 64 bit +#if __riscv_xlen == 64 + struct addresses mmap_addresses; + + do_mmaps(&mmap_addresses); + + EXPECT_NE(mmap_addresses.no_hint, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_37_addr, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_38_addr, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_46_addr, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_47_addr, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_55_addr, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_56_addr, MAP_FAILED); + + EXPECT_LT((unsigned long)mmap_addresses.no_hint, 1UL << 47); + EXPECT_LT((unsigned long)mmap_addresses.on_37_addr, 1UL << 38); + EXPECT_LT((unsigned long)mmap_addresses.on_38_addr, 1UL << 38); + EXPECT_LT((unsigned long)mmap_addresses.on_46_addr, 1UL << 38); + EXPECT_LT((unsigned long)mmap_addresses.on_47_addr, 1UL << 47); + EXPECT_LT((unsigned long)mmap_addresses.on_55_addr, 1UL << 47); + EXPECT_LT((unsigned long)mmap_addresses.on_56_addr, 1UL << 56); +#endif +} + +TEST(zero_rlimit) +{ +// Only works on 64 bit +#if __riscv_xlen == 64 + struct addresses mmap_addresses; + struct rlimit rlim_new = { .rlim_cur = 0, .rlim_max = RLIM_INFINITY }; + + setrlimit(RLIMIT_STACK, &rlim_new); + + do_mmaps(&mmap_addresses); + + EXPECT_NE(mmap_addresses.no_hint, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_37_addr, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_38_addr, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_46_addr, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_47_addr, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_55_addr, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_56_addr, MAP_FAILED); + + EXPECT_LT((unsigned long)mmap_addresses.no_hint, 1UL << 47); + EXPECT_LT((unsigned long)mmap_addresses.on_37_addr, 1UL << 38); + EXPECT_LT((unsigned long)mmap_addresses.on_38_addr, 1UL << 38); + EXPECT_LT((unsigned long)mmap_addresses.on_46_addr, 1UL << 38); + EXPECT_LT((unsigned long)mmap_addresses.on_47_addr, 1UL << 47); + EXPECT_LT((unsigned long)mmap_addresses.on_55_addr, 1UL << 47); + EXPECT_LT((unsigned long)mmap_addresses.on_56_addr, 1UL << 56); +#endif +} + +TEST(infinite_rlimit) +{ +// Only works on 64 bit +#if __riscv_xlen == 64 + struct addresses mmap_addresses; + struct rlimit rlim_new = { .rlim_cur = RLIM_INFINITY, + .rlim_max = RLIM_INFINITY }; + + setrlimit(RLIMIT_STACK, &rlim_new); + + do_mmaps(&mmap_addresses); + + EXPECT_NE(mmap_addresses.no_hint, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_37_addr, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_38_addr, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_46_addr, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_47_addr, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_55_addr, MAP_FAILED); + EXPECT_NE(mmap_addresses.on_56_addr, MAP_FAILED); + + EXPECT_LT((unsigned long)mmap_addresses.no_hint, 1UL << 47); + EXPECT_LT((unsigned long)mmap_addresses.on_37_addr, 1UL << 38); + EXPECT_LT((unsigned long)mmap_addresses.on_38_addr, 1UL << 38); + EXPECT_LT((unsigned long)mmap_addresses.on_46_addr, 1UL << 38); + EXPECT_LT((unsigned long)mmap_addresses.on_47_addr, 1UL << 47); + EXPECT_LT((unsigned long)mmap_addresses.on_55_addr, 1UL << 47); + EXPECT_LT((unsigned long)mmap_addresses.on_56_addr, 1UL << 56); +#endif +} + +TEST_HARNESS_MAIN From patchwork Sat Jul 8 01:11:34 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Charlie Jenkins X-Patchwork-Id: 13305514 Return-Path: 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 40683C00528 for ; Sat, 8 Jul 2023 01:12:24 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id A3F068D0001; Fri, 7 Jul 2023 21:12:23 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 9EF8E6B0078; Fri, 7 Jul 2023 21:12:23 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 868E98D0001; Fri, 7 Jul 2023 21:12:23 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0015.hostedemail.com [216.40.44.15]) by kanga.kvack.org (Postfix) with ESMTP id 64E046B0075 for ; Fri, 7 Jul 2023 21:12:23 -0400 (EDT) Received: from smtpin24.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay07.hostedemail.com (Postfix) with ESMTP id 2768B160170 for ; Sat, 8 Jul 2023 01:12:23 +0000 (UTC) X-FDA: 80986668966.24.E41F537 Received: from mail-pl1-f180.google.com (mail-pl1-f180.google.com [209.85.214.180]) by imf27.hostedemail.com (Postfix) with ESMTP id 45B3340004 for ; Sat, 8 Jul 2023 01:12:20 +0000 (UTC) Authentication-Results: imf27.hostedemail.com; dkim=pass header.d=rivosinc-com.20221208.gappssmtp.com header.s=20221208 header.b=HGN3ju79; spf=pass (imf27.hostedemail.com: domain of charlie@rivosinc.com designates 209.85.214.180 as permitted sender) smtp.mailfrom=charlie@rivosinc.com; dmarc=none ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1688778740; a=rsa-sha256; cv=none; b=lB5lQjVDgZZncV3PDETg9ueammdGg54W6S9pI3zOFTCRAKP4j+5vG9WS4lrpPVeYjdM+fp iMS0nkf6MRQao9ekrsW4afNeDw9DjxhyrlmCrkl2IEANuHLanrFdJU20rDm3aRcHZLZ+FH ymGDld4y8rLrWCd2uYcJmYwB9e1Wfp8= ARC-Authentication-Results: i=1; imf27.hostedemail.com; dkim=pass header.d=rivosinc-com.20221208.gappssmtp.com header.s=20221208 header.b=HGN3ju79; spf=pass (imf27.hostedemail.com: domain of charlie@rivosinc.com designates 209.85.214.180 as permitted sender) smtp.mailfrom=charlie@rivosinc.com; dmarc=none ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1688778740; 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-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=VGYD7N8wGDu1tDg8VZbK81LUzFuUntAfMahEoaG4sqc=; b=T2GAObkTU1fpOLOGTVStqFyVsNEuQZfyv4ZMfQ3gkBa9ymz8HYyoDPFuK+XixBPq4eRjec xB0amaZIyHPlomueHxSRnTCeBVGeOTvJTKlmNvrgnpiOSYk9hf8k6Fsf8AwyCK/j6Ew/Gx 6bQxtNbnaidZV1VmQVCHtJcLwfRPXLM= Received: by mail-pl1-f180.google.com with SMTP id d9443c01a7336-1b8ad8383faso17038095ad.0 for ; Fri, 07 Jul 2023 18:12:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=rivosinc-com.20221208.gappssmtp.com; s=20221208; t=1688778739; x=1691370739; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=VGYD7N8wGDu1tDg8VZbK81LUzFuUntAfMahEoaG4sqc=; b=HGN3ju79/NcRtAH1rWTzt1SF66qlIOEIPW+h8YCZSLaemLUac5sLeNcc06JOpcpXYS Cj+44tx2Z+rwnRiNelURAceDB/qdaKXjyGvhTuZuZecJIPAZ93DUuWf9RMS8856fmHx8 Umn9pcJZq+zDFbW3kfivmOjwAuguRCJGOID7fJdAs9Nbn12i9eOGzLQ76DGuAdP1h2/F EC/pD0QZPhElZ7NCVIs4iLArjS3xtiJrVYm/2wZeUdSifvbekOHDtDtmS8cMIhwN9VIH 81Hbh7TQSzo/OJgjK4nyg7wVpciIrnm85nU2hbGdj1OHDOVQwJk4nRSRz6OyiZoPcTy9 ci6Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1688778739; x=1691370739; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=VGYD7N8wGDu1tDg8VZbK81LUzFuUntAfMahEoaG4sqc=; b=dlO9jw/4In9B++7GbRQGHvu13jhSG63Pr3KS1WeYBumfuExbKmrKeDna+ZX5JmHH7J lX5eNpICSxJka+zdDQaIdHp9jCt2fguOMaixznWA8nt9lbkqSy78iX36+zRKOwzIOUES hkJV+VZFoo3GRd7cxarbUBK+/1WRmKBwTaLGjjn/96fXS0SzOa66H/1fmeKslorQmmYL GCV0sT1f3Q5EPfjAJhahOJk4yoq0BQgGx1Kd8Aq5Cl0Toxu574BjsevfywdXYgzeWB4d tGjbUOW8I7NsBD7J1xHE2QCuVZbcqrcV0b5+Dt8O+/dvOiWursB0s39m4Yr5TBECGNJ5 DwqQ== X-Gm-Message-State: ABy/qLYaXpZD199sPwjx6wj+/LLHZbIR6gAUT1wqDjOSr8lXuVOjiiix deySnu81hbtEOG9dMFNoll955g== X-Google-Smtp-Source: APBJJlHkZ1VNL0aalCS0nI4K5MUssbBtfN29EiaKPdj3R58vKoRX7bIN9ly2ZZTe32HyTdXxVRe5ag== X-Received: by 2002:a17:902:c951:b0:1b8:3e15:46a1 with SMTP id i17-20020a170902c95100b001b83e1546a1mr8516813pla.67.1688778738940; Fri, 07 Jul 2023 18:12:18 -0700 (PDT) Received: from charlie.ba.rivosinc.com ([66.220.2.162]) by smtp.gmail.com with ESMTPSA id x24-20020a170902b41800b001b87d3e845bsm3830654plr.149.2023.07.07.18.12.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 07 Jul 2023 18:12:18 -0700 (PDT) From: Charlie Jenkins To: linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org Cc: charlie@rivosinc.com, conor@kernel.org, paul.walmsley@sifive.com, palmer@rivosinc.com, aou@eecs.berkeley.edu, anup@brainfault.org, konstantin@linuxfoundation.org, linux-doc@vger.kernel.org, linux-kselftest@vger.kernel.org, linux-mm@kvack.org, mick@ics.forth.gr, jrtc27@jrtc27.com, rdunlap@infradead.org Subject: [PATCH v4 3/4] RISC-V: mm: Update pgtable comment documentation Date: Fri, 7 Jul 2023 18:11:34 -0700 Message-ID: <20230708011156.2697409-4-charlie@rivosinc.com> X-Mailer: git-send-email 2.41.0 In-Reply-To: <20230708011156.2697409-1-charlie@rivosinc.com> References: <20230708011156.2697409-1-charlie@rivosinc.com> MIME-Version: 1.0 X-Rspamd-Server: rspam08 X-Rspamd-Queue-Id: 45B3340004 X-Stat-Signature: fafkxi9upuk6uwxq8c545rywf5twjpsr X-Rspam-User: X-HE-Tag: 1688778740-189808 X-HE-Meta: U2FsdGVkX1+v0yn7cWTbGp4lXq8jT+llmAvMhhop14+aJ8vqHdxjKHYA3lNRR/1O6ZAOAwapdjBPYkuvf/WIJRemNa5DSgo3L1LYhroqfejUNkSZ0eanaG9BSYvA7//Zqi7pKUyU+BztzqejOP+tgjf6Gxg1nJWI7AyNGwL9ykSWRO4yu6lgsBBMQ7LH+W3sNNDnXRq/pyZiuYsZxXwKmb6xKu1rVdugO2w87ge9VLhB10+erbl8rDQTp+qc9VEveVJOnvu99lDW28/0LINZGP5FxrW+AdPTwiLpEnVYuKVPGLdGpoV3vPBzmiZ6biD4gnygjU3DHP6BU2eVqdYgiDwYdw5ze4E7ChWP5mrFlEF/baNsBBpyqEBXZmq/bXerZcZqlAv40b35/pJL7wxiO0iY4+MIDrCvmYdcLLDiLO5tyCYFOJHsSZ0c8cU/4+7r5IcbW7CGJ7XGAKHXWd8JpG4o0wC0ZN2j6tD5TsLu36p7EZonllXY6XoJq5WBthLdG5GijlrP8+HUt/fOq5ioGOG+DkqNIYTPmnVCupOmrWlTpRgagzFrYt5n27vSF1ULnntF3StTNztBrrbwBqi9aQM567WKDVru1OEfDNUTiE3ps2d4MYLsjVNj81YJwovV4uefnUYU79cmbiz2FQ6hjPwEL8QNLH7zBKpiLJuH0GiERc6gPikGyFRu624GTBW1L5wFVxjQMMlkIn4Cg4PiyuCwjNVhRpJ7zk8ENlmwGv7gRQiWzFFqSZ9PUwZgyrWBwxh40tyHepeimjY/bCsROxEdHJbSA2K//aEfYM4lxkMYkVz/yw0W7G4aPndawd0HX5Hj2Uw4JK6/Vo9feGfCx3qKpxZTXMp7sojydDgz8mgqcoYh9SylyH7WbKEbCVf+CWb39ibhiJ5i9cHBRLi9c70rqiNTjgEvXvlHLEEMVwDdxMSIHYkQygXO6l7oBq8T6MMvfs6nziXuI1MGhU3 EkAnzvzM f/Kv22MH7qHDk8/B+aun7jf0fORu6iaie/+xPFhNi8fVgCnCI38L/zbxijlnctAX/ac0YyhIPbzz/w2wIYi4IVK9f4jYGCkS2umfuu60lID0fd3YhDiWGohLF6gLPzqCdyozLFqOqiHFkGmXf7rS6iVDMbypyr/neEzNFDn5K5/sh2Kj+XRi/jGnnYDQL0s0p9Gc8/7wvsdjV0VHZ9u+PniU6juA6YahzJXj9kCVCWiF5AcMNPD8QxP17CL1FuXtbsbn5Cg3uOXi1RDbvCgHwSL2Xl77DFK7dpq9+cRRKGs5AsLZz3f/LkY8jKMM5CZ7dNU+O+GbroXLpyMoZnpYH2orkmKbWn4b9Z0XSdfykyLCyxrkcTAot+G7bI8npQtIqtqNyRZcq/uTH97HZCzCHKsxdlCy1eaMLvOSi6EY+i9izpxY+PkePUzMj4x1bHPUBXRH01LeOHb2MPPU= X-Bogosity: Ham, tests=bogofilter, spamicity=0.092547, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: sv57 is supported in the kernel so pgtable.h should reflect that. Signed-off-by: Charlie Jenkins --- arch/riscv/include/asm/pgtable.h | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/arch/riscv/include/asm/pgtable.h b/arch/riscv/include/asm/pgtable.h index a8090ebea705..e6bbe8c0e583 100644 --- a/arch/riscv/include/asm/pgtable.h +++ b/arch/riscv/include/asm/pgtable.h @@ -841,14 +841,16 @@ static inline pte_t pte_swp_clear_exclusive(pte_t pte) * Task size is 0x4000000000 for RV64 or 0x9fc00000 for RV32. * Note that PGDIR_SIZE must evenly divide TASK_SIZE. * Task size is: - * - 0x9fc00000 (~2.5GB) for RV32. - * - 0x4000000000 ( 256GB) for RV64 using SV39 mmu - * - 0x800000000000 ( 128TB) for RV64 using SV48 mmu + * - 0x9fc00000 (~2.5GB) for RV32. + * - 0x4000000000 ( 256GB) for RV64 using SV39 mmu + * - 0x800000000000 ( 128TB) for RV64 using SV48 mmu + * - 0x100000000000000 ( 64PB) for RV64 using SV57 mmu * * Note that PGDIR_SIZE must evenly divide TASK_SIZE since "RISC-V * Instruction Set Manual Volume II: Privileged Architecture" states that * "load and store effective addresses, which are 64bits, must have bits * 63–48 all equal to bit 47, or else a page-fault exception will occur." + * Similarly for SV57, bits 63–57 must be equal to bit 56. */ #ifdef CONFIG_64BIT #define TASK_SIZE_64 (PGDIR_SIZE * PTRS_PER_PGD / 2) From patchwork Sat Jul 8 01:11:35 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Charlie Jenkins X-Patchwork-Id: 13305515 Return-Path: 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 D73C0C001B0 for ; Sat, 8 Jul 2023 01:12:25 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 780B18D0002; Fri, 7 Jul 2023 21:12:25 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 731966B0078; Fri, 7 Jul 2023 21:12:25 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 584D88D0002; Fri, 7 Jul 2023 21:12:25 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0016.hostedemail.com [216.40.44.16]) by kanga.kvack.org (Postfix) with ESMTP id 3246A6B0075 for ; Fri, 7 Jul 2023 21:12:25 -0400 (EDT) Received: from smtpin12.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay04.hostedemail.com (Postfix) with ESMTP id E57771A0182 for ; Sat, 8 Jul 2023 01:12:24 +0000 (UTC) X-FDA: 80986669008.12.5429F39 Received: from mail-oo1-f50.google.com (mail-oo1-f50.google.com [209.85.161.50]) by imf27.hostedemail.com (Postfix) with ESMTP id 1F9B94000C for ; Sat, 8 Jul 2023 01:12:22 +0000 (UTC) Authentication-Results: imf27.hostedemail.com; dkim=pass header.d=rivosinc-com.20221208.gappssmtp.com header.s=20221208 header.b=YFsN5teo; dmarc=none; spf=pass (imf27.hostedemail.com: domain of charlie@rivosinc.com designates 209.85.161.50 as permitted sender) smtp.mailfrom=charlie@rivosinc.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1688778743; 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=HbN8vPNRnpC2rsql2yMQGj4/q3r+GbD6Fgm8kHqgv+g=; b=BGPiRZt/3oh1RKJqyFivGxq8VuHVURzQQ9Zx0wkFMU8t5Wy3KPmbkdAdcc/4Zus9X54z0M Bt7pLML76h+9Dypk7ErzczHh4USp0a14d9L75wFNgvNmUsnewjgT5Vjcr0Tz5dxS019aUy QLCavDhWwCvVYU5F3r+z/jMDRSErdgk= ARC-Authentication-Results: i=1; imf27.hostedemail.com; dkim=pass header.d=rivosinc-com.20221208.gappssmtp.com header.s=20221208 header.b=YFsN5teo; dmarc=none; spf=pass (imf27.hostedemail.com: domain of charlie@rivosinc.com designates 209.85.161.50 as permitted sender) smtp.mailfrom=charlie@rivosinc.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1688778743; a=rsa-sha256; cv=none; b=Wu+V8eGKsFVdBx+Ahbw8TbmQ1e4WY3jQ25qvcayikj0v6AMqMwpnsHvhgHc3ZGD5YcW68I UTT/f9F6eozdxDlFNLejPUc50aXGYX5TMTC/t6fU366zAJKhC6KYvuCBW8CdKjVlZC0uOA 2HtTYtjSRF7hVlxq23KasU+s+w8D/yY= Received: by mail-oo1-f50.google.com with SMTP id 006d021491bc7-563439ea4a2so1834044eaf.0 for ; Fri, 07 Jul 2023 18:12:22 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=rivosinc-com.20221208.gappssmtp.com; s=20221208; t=1688778742; x=1691370742; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=HbN8vPNRnpC2rsql2yMQGj4/q3r+GbD6Fgm8kHqgv+g=; b=YFsN5teo2Xz7zOmpo4/u8q+vpC9gfozaUxki8nVKZv9U3t07rRrfE2F4D/Mpc5IR6Y g2mhkupBGRVRoam4tBIlKDHh9QI3CglQEfd+e5rWKmh2SSW1KWTgyeQZWx33sFhEiL/R zgEzQmy2w6g0b6bkpsyL0pXxNONEUqIbqM5EyF7yTZ4nd+QmM5x5KgzeZtipCgrkcwup nNVAWTBHg56PkxtsUwaVwvwNubSbZIkurOLzlb3ihhEr/nv+HyjB0A54Sr6SdIfOKJ3r u1doM0X8jjfji3no8jcXuswWv7vTaFA/xQIWTftyN61BawJxTM4bORzaV5IG40o6TLK3 Hpeg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1688778742; x=1691370742; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=HbN8vPNRnpC2rsql2yMQGj4/q3r+GbD6Fgm8kHqgv+g=; b=G30pxfRvQ1k2/md5kwUDW+Ea7pzwfP2qX5jRTlz0Mo5ZDg3gpL0PiZrlq96lUQcduV k2901Cq7gSLUVqQm03atykJX11u+DjGixNC7DYOzdacqCIhUtW31WRBykR4wUMwpArfM IiYYONyoQBtn5W45TyAam3SNMOP3gqYjvcKXYQrHyJOq87UWANwToJKlN9zNunxWSp7m RZG4ddloIjUOBw12tyGokjxTeQiK5hSlrnXtbksPWFYM2OilS5rUTvnLwXn1rPIdDOF7 IVxRWU1jb69HlYALIphdi39Baw3gmnojMpArLjmDGAXW3OhtNwljoM3iRyxzfzIp6uuA JVaQ== X-Gm-Message-State: ABy/qLZ9WMOSqmw2RJ38n28A439LPliehKccPIvOSSepIJnivwnChhDE UbnVVhRCtVD3KJ2T10etFxWlgA== X-Google-Smtp-Source: APBJJlGdindojK5i23bHPXGUqY/0vPqfcqx7SQxTQvxyGmC/pEljPyl1GkowwHsZX51mLjvN1LEySQ== X-Received: by 2002:a05:6358:2925:b0:125:a552:4389 with SMTP id y37-20020a056358292500b00125a5524389mr7496248rwb.22.1688778742292; Fri, 07 Jul 2023 18:12:22 -0700 (PDT) Received: from charlie.ba.rivosinc.com ([66.220.2.162]) by smtp.gmail.com with ESMTPSA id x24-20020a170902b41800b001b87d3e845bsm3830654plr.149.2023.07.07.18.12.21 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 07 Jul 2023 18:12:21 -0700 (PDT) From: Charlie Jenkins To: linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org Cc: charlie@rivosinc.com, conor@kernel.org, paul.walmsley@sifive.com, palmer@rivosinc.com, aou@eecs.berkeley.edu, anup@brainfault.org, konstantin@linuxfoundation.org, linux-doc@vger.kernel.org, linux-kselftest@vger.kernel.org, linux-mm@kvack.org, mick@ics.forth.gr, jrtc27@jrtc27.com, rdunlap@infradead.org Subject: [PATCH v4 4/4] RISC-V: mm: Document mmap changes Date: Fri, 7 Jul 2023 18:11:35 -0700 Message-ID: <20230708011156.2697409-5-charlie@rivosinc.com> X-Mailer: git-send-email 2.41.0 In-Reply-To: <20230708011156.2697409-1-charlie@rivosinc.com> References: <20230708011156.2697409-1-charlie@rivosinc.com> MIME-Version: 1.0 X-Rspam-User: X-Rspamd-Server: rspam12 X-Rspamd-Queue-Id: 1F9B94000C X-Stat-Signature: qczu41kxtadd7eohhu84thmb3z4is78k X-HE-Tag: 1688778742-52999 X-HE-Meta: U2FsdGVkX196o0KSnqofxMP1v8QX0uSAmvurbvq9pWgFYXRr0zKV/mWBQ3bga82eWcTORSrbFohLL1AUWsgXqQuIbae826wglbDfwv4hMtmcFsrU0EPjUIqUvcvo15xKVp0uQd86ofRufaM4jJUbObjQJ47dY6+nY5lLNg91o5ZDBOUVuP3nD+/4jUGkHpVq7qYxF+fz4rf8Mu0FnN/57360Ome7xOat9Sz16sRvaYIE/oVlvsaIeMIfJVaHkBmn5ji8CF6LdJg1wdRyw65aJea16W6ZpbHxQj+voCOK9EC/nLyD2fbN5aISo5mDc8obnkwdoQJ3CqnB5eFQPnKTiBQnyrFW3VI+Y+TZs+5GkiK0i/js6k3k7eoA7TY3jsBU7SJQ3oMrCvpSvPJcJvH90PVywtFueFtSascGzn/3ey3oroU7eZSR1OjitXIHjdrxzlKRJUjEFtIYThzcO51V9kSSHExenaYmeaGkvYUHlX8KHeqHpnrGu939/nHaBwN45rxUAO6Mb3wgIyGKoxjnckDQTfcBiZ3V1ZELHuVSVK4GcLYx3EA6FadTVgofY72orPEv1hPClmEodJTCKMAyphC14yT+FqYyVqFfuXBwrMMafukXbxGPPobJuZVPMF8vIX0B7gzlbGuF6NtNzuhqSEYh9bRChUosTBBk5+rc9NPJ01ktlE5Ji9gMFxkLTqeAvxYqqsW+smRZ5Ezy+hZken79pq+PvuEkl0jAAB7jgkNIoOvDFdGmTfx2JNxu8Y8Uadw/nXfGDkonpxT/85+gyfevs+d5u9XlQRyT1jzrwxpyZwkafzRgw8Gr/9K6nljZkx0KadDfRGL/QuQ8BSYdSj5ttiVnfi3FfazHZbkOTOD4ijBA9RIDkJ5qjFRNCJ7/uSJIWxz7gwp/P2psetkHzcPTuGxL/NiNtnGUzc8K9W2EFReNF8MnzH05ou/LEVbtwBCmoKUIe97zJTDL/jj T4cuJCGv LEI4XFT7IMvDEWY1JYdRegusWxzJ2EYvcVCVzqwdpTz/QLFtGtZz9OFqcK6je130tA5v8BMhGKqVgHGAHdO9dl/J/EfV3fLTiN4kbA0tLvfpBqoNFuWBvOIcfpyCgSiOJN4oY9leznEkJLKZ3NkOQcVHtcRyHQ/NKiY9QJZR+x5Xta+/oRMlkGua6FEPbq8MwXcvJToaVsi+7XoSo9zOqAyhnOiqH7YeUFQNGJ4UT5I+NGtCfhoJEbvo7zsQNG9FZwLAwvjIWSy/eu2/nB4hpgRQvnOg4q7TYtvqfSiYkl5hP9s6d+PictqATvtC4L7UeN551uWWfR6kayuxETZxqlTeoNqrS1B79DvyX+Ff5mDeadM+yoNtDABnBlcR35voVhOD/40d3aBgOYVVP0uvCI7k2NaWzLpbq/HrhOViT4UNKY6RfPXT3JFsRfz2LJiglMRzt X-Bogosity: Ham, tests=bogofilter, spamicity=0.000753, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: The behavior of mmap is modified with this patch series, so explain the changes to the mmap hint address behavior. Signed-off-by: Charlie Jenkins --- Documentation/riscv/vm-layout.rst | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/Documentation/riscv/vm-layout.rst b/Documentation/riscv/vm-layout.rst index 5462c84f4723..8141addbf888 100644 --- a/Documentation/riscv/vm-layout.rst +++ b/Documentation/riscv/vm-layout.rst @@ -133,3 +133,25 @@ RISC-V Linux Kernel SV57 ffffffff00000000 | -4 GB | ffffffff7fffffff | 2 GB | modules, BPF ffffffff80000000 | -2 GB | ffffffffffffffff | 2 GB | kernel __________________|____________|__________________|_________|____________________________________________________________ + + +Userspace VAs +-------------------- +To maintain compatibility with software that relies on the VA space with a +maximum of 48 bits the kernel will, by default, return virtual addresses to +userspace from a 48-bit range (sv48). This default behavior is achieved by +passing 0 into the hint address parameter of mmap. On CPUs with an address space +smaller than sv48, the CPU maximum supported address space will be the default. + +Software can "opt-in" to receiving VAs from other VA space by providing +a hint address to mmap. A call to mmap is guaranteed to return an address +that will not override the unset left-aligned bits in the hint address, +unless there is no space left in the address space. If there is no space +available in the requested address space, an address in the next smallest +available address space will be returned. + +For example, in order to obtain 48-bit VA space, a hint address greater than +:code:`1 << 38` must be provided. Note that this is 38 due to sv39 userspace +ending at :code:`1 << 38` and the addresses beyond this are reserved for the +kernel. Similarly, to obtain 57-bit VA space addresses, a hint address greater +than or equal to :code:`1 << 47` must be provided.