From patchwork Tue Mar 25 12:16:15 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Guo Ren X-Patchwork-Id: 14028875 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 D1CA2C36005 for ; Tue, 25 Mar 2025 12:24:58 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id B5DBE280027; Tue, 25 Mar 2025 08:24:57 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id B12B228000C; Tue, 25 Mar 2025 08:24:57 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 9154D280027; Tue, 25 Mar 2025 08:24:57 -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 6A01428000C for ; Tue, 25 Mar 2025 08:24:57 -0400 (EDT) Received: from smtpin20.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay08.hostedemail.com (Postfix) with ESMTP id A99F8140156 for ; Tue, 25 Mar 2025 12:24:57 +0000 (UTC) X-FDA: 83259992634.20.B47270F Received: from sea.source.kernel.org (sea.source.kernel.org [172.234.252.31]) by imf14.hostedemail.com (Postfix) with ESMTP id E8B7F10000C for ; Tue, 25 Mar 2025 12:24:55 +0000 (UTC) Authentication-Results: imf14.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=NBdZnQ6w; dmarc=pass (policy=quarantine) header.from=kernel.org; spf=pass (imf14.hostedemail.com: domain of guoren@kernel.org designates 172.234.252.31 as permitted sender) smtp.mailfrom=guoren@kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1742905496; 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=xTUFOBOXx71BsLHiNJckym+XV3lyYvRwI4lWirZpMFQ=; b=qWNTAhFwb+UuMIRGxlbWI4Ro0Ea6gamJjo9v8jv5AwOu//1/7tNCGFP2CosiNFPdXVyvKy r9xpMFSrV8nHelWUmQBpjGZN1pZwYePvZR0ea8w7dXQsebDhzVh+Cq07jxncDNI+6rxj+2 R4hq63t5LK6QWWmu1ZLc+68sR3AC+QY= ARC-Authentication-Results: i=1; imf14.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=NBdZnQ6w; dmarc=pass (policy=quarantine) header.from=kernel.org; spf=pass (imf14.hostedemail.com: domain of guoren@kernel.org designates 172.234.252.31 as permitted sender) smtp.mailfrom=guoren@kernel.org ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1742905496; a=rsa-sha256; cv=none; b=t5ip1IAsfBG5VlEkV9NeEzFZnhfpyv4vmbanBM3asjP0tetxgFpc31FG2RKVSUQz3BRV4A dRivmJVITXBn323FPrnbpUSiTsiWqtD7rveIDdcz1ITzv74xv1WpqLcgEG0LXcDT+7NpVo y78y4HroYiIsQfggVgDDIpum61CYPw0= Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by sea.source.kernel.org (Postfix) with ESMTP id 7FFC340C51; Tue, 25 Mar 2025 12:24:54 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 3BE93C4CEE4; Tue, 25 Mar 2025 12:24:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1742905494; bh=JwtECzOHq6ymjHklbfhF05tHrVz/dVoFwQnBuog4LCc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=NBdZnQ6wGqSC6QfVLwGWKEPwB7OJ2JptqWNe6hKJxvNlO7hfByhpmxMvHthIUgk61 dNUcCE7m/h28WuqOcXJmgPZQk3Hy8cSc4aiS4wgdEwf37RF7fMts6mVPBiUNrWNCWt oWzAZgLDhGX29uKl8dWvRO9Mm1JoxE4/TpLaaQgKCG0EvxU9De7+6S+NM9bXKazZUh iiJaT6DEIOs44LKfjd1QeKJBQDjIo3VxGUUBkRirfVvYipwwzvO9PksRO3PoHIeu8G 685HBjMd/zqHvy1H0+rm2OtgsMHs8OXxw2D6U5NNsckTsb6/vNidB7w2u683wCRv8q kinJAJyufOtuA== From: guoren@kernel.org To: arnd@arndb.de, gregkh@linuxfoundation.org, torvalds@linux-foundation.org, paul.walmsley@sifive.com, palmer@dabbelt.com, anup@brainfault.org, atishp@atishpatra.org, oleg@redhat.com, kees@kernel.org, tglx@linutronix.de, will@kernel.org, mark.rutland@arm.com, brauner@kernel.org, akpm@linux-foundation.org, rostedt@goodmis.org, edumazet@google.com, unicorn_wang@outlook.com, inochiama@outlook.com, gaohan@iscas.ac.cn, shihua@iscas.ac.cn, jiawei@iscas.ac.cn, wuwei2016@iscas.ac.cn, drew@pdp7.com, prabhakar.mahadev-lad.rj@bp.renesas.com, ctsai390@andestech.com, wefu@redhat.com, kuba@kernel.org, pabeni@redhat.com, josef@toxicpanda.com, dsterba@suse.com, mingo@redhat.com, peterz@infradead.org, boqun.feng@gmail.com, guoren@kernel.org, xiao.w.wang@intel.com, qingfang.deng@siflower.com.cn, leobras@redhat.com, jszhang@kernel.org, conor.dooley@microchip.com, samuel.holland@sifive.com, yongxuan.wang@sifive.com, luxu.kernel@bytedance.com, david@redhat.com, ruanjinjie@huawei.com, cuiyunhui@bytedance.com, wangkefeng.wang@huawei.com, qiaozhe@iscas.ac.cn Cc: ardb@kernel.org, ast@kernel.org, linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org, kvm@vger.kernel.org, kvm-riscv@lists.infradead.org, linux-mm@kvack.org, linux-crypto@vger.kernel.org, bpf@vger.kernel.org, linux-input@vger.kernel.org, linux-perf-users@vger.kernel.org, linux-serial@vger.kernel.org, linux-fsdevel@vger.kernel.org, linux-arch@vger.kernel.org, maple-tree@lists.infradead.org, linux-trace-kernel@vger.kernel.org, netdev@vger.kernel.org, linux-atm-general@lists.sourceforge.net, linux-btrfs@vger.kernel.org, netfilter-devel@vger.kernel.org, coreteam@netfilter.org, linux-nfs@vger.kernel.org, linux-sctp@vger.kernel.org, linux-usb@vger.kernel.org, linux-media@vger.kernel.org Subject: [RFC PATCH V3 34/43] rv64ilp32_abi: mm: Adapt vm_flags_t struct Date: Tue, 25 Mar 2025 08:16:15 -0400 Message-Id: <20250325121624.523258-35-guoren@kernel.org> X-Mailer: git-send-email 2.40.1 In-Reply-To: <20250325121624.523258-1-guoren@kernel.org> References: <20250325121624.523258-1-guoren@kernel.org> MIME-Version: 1.0 X-Rspamd-Server: rspam01 X-Stat-Signature: cft3k7jionz4sbqzgk33b48btek9rpuo X-Rspam-User: X-Rspamd-Queue-Id: E8B7F10000C X-HE-Tag: 1742905495-938006 X-HE-Meta: U2FsdGVkX18sPfAQ3AyzW4GN9JJYK5E0gbVPQBIj3QA8Em4UOb8MpKPP8QxsxE6rdn+EpVHUZFpzMf7Qj7RBpCbMVxAWf8H4ZAvBkaUSGDSk4tLszjZJa/2Jr5s5MGyszugf6qOFH1ZAjTGSRL4fxE9alGmB8m/UiN7t8kA4Ijpxyn8nCnFIl3MKXqJLpu6cLtlNbm4+L9FJaNJETxRflBn2NPOEImPTOeNQ74n4f7Aps20cchkDvhruXLlS1I/JNKK9DhQo+AmVmESy51y9bHnVK47iNjDLsclE0+Clp23RvZurNf8D8ixrH+9y9bgaYlcta2oEGBXJLYguHgr4PtS3RHindEg8RZp/yxooibuGH63z1LbHfapGVPcr7tIoE5au84XJ3iNatmRf0UF1jVAl1/sQ5DYMR1cmgGF9ldo8yn2BoXRN77Gjz3AL9UAhxPTX7LAjKjwuwwnG69yZmtVOw+kOwukeO73lIUUcdyL9CGkEBMHDo3kgypxywYtuVAJHg1TWGhnhXD0S04rCkesEOLY7xzFG0CZLs8Lu/vgZiimMXhL3GkEOldLxhSeS0R9CIvJLKf23HM7IkPAVa5EKJG96QE9FjMtEmyGyryN8Ep8s3Zp5Nkf7u2WYrIzlbhNkZEuTFHERXFaXompYg0vr7UxIOxVMC33CrGknsZKbRgqlajFkf2J1zY1MrpREMcjEGDHlhNLerJJkMyKNqPMPuV3kFBb/R1tdii0PjudIbkZ6fF5+QY2QjjuXoG0zxVboxiajQ2GkzjvH/drvLFQajDHIb53RElwEwlh7DMjCszxkmrACLLg1/wZJGtFqyue6YTsjcAs8Dxq8N9DIHngpOeXbmhaRxWiV0d5wmuptk1iCVFgPs6h6Hl8d1oS0/Z2z3Uw7tUUkiR90YXOM4psvG2aUZkQeielZUjrjAuYhyoWmqSq4fQUFtffNRp6SQVyo1mmtdohxkNFtHwa a/BTzFih ROFkdqzuLxerw8A5qhpEIIwawzfBP9mLxZUACy1KdGZlcju7Md52B9xNZiONsLrqT9fhlj8juC/FxqjNXk2hTMxm14daq1U2+IaooNm+Pdj5j8aJ9xO68V8Gwm4hiBdti5lISGKuU3zeoGouQeDexOkW/CF6ujpW5ZtskzlLwxHRdJaXTfkataLfTint16n9cgelgKkAyLNaMiDG0YlgOhwi6tgGIVOD7se+dmuAKj9yIvA93YxIEzpDlFmQBVSYMd+N2Ec1P3okHJlDtZN7piyPUL2LO3OD/3k1O23iuaFNIhslOq/FIcCGH+i3wIluKluWoQ2lzgA8X+1y28gAjDYpR4A3/cuWlLMkT 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: List-Subscribe: List-Unsubscribe: From: "Guo Ren (Alibaba DAMO Academy)" RV64ILP32 ABI linux kernel is based on CONFIG_64BIT, so uses unsigned long long as vm_flags struct type. Signed-off-by: Guo Ren (Alibaba DAMO Academy) --- fs/proc/task_mmu.c | 9 +++++++-- include/linux/mm.h | 10 +++++++--- include/linux/mm_types.h | 4 ++++ mm/debug.c | 4 ++++ mm/memory.c | 4 ++++ 5 files changed, 26 insertions(+), 5 deletions(-) diff --git a/fs/proc/task_mmu.c b/fs/proc/task_mmu.c index f02cd362309a..6c4eaba794da 100644 --- a/fs/proc/task_mmu.c +++ b/fs/proc/task_mmu.c @@ -905,6 +905,11 @@ static int smaps_pte_range(pmd_t *pmd, unsigned long addr, unsigned long end, return 0; } +#ifdef CONFIG_64BIT +#define MNEMONICS_SZ 64 +#else +#define MNEMONICS_SZ 32 +#endif static void show_smap_vma_flags(struct seq_file *m, struct vm_area_struct *vma) { /* @@ -917,11 +922,11 @@ static void show_smap_vma_flags(struct seq_file *m, struct vm_area_struct *vma) * -Werror=unterminated-string-initialization warning * with GCC 15 */ - static const char mnemonics[BITS_PER_LONG][3] = { + static const char mnemonics[MNEMONICS_SZ][3] = { /* * In case if we meet a flag we don't know about. */ - [0 ... (BITS_PER_LONG-1)] = "??", + [0 ... (MNEMONICS_SZ-1)] = "??", [ilog2(VM_READ)] = "rd", [ilog2(VM_WRITE)] = "wr", diff --git a/include/linux/mm.h b/include/linux/mm.h index 454fb8ca724c..d9735cd7efe9 100644 --- a/include/linux/mm.h +++ b/include/linux/mm.h @@ -412,7 +412,11 @@ extern unsigned int kobjsize(const void *objp); #ifdef CONFIG_HAVE_ARCH_USERFAULTFD_MINOR # define VM_UFFD_MINOR_BIT 38 +#ifdef CONFIG_64BIT +# define VM_UFFD_MINOR BIT_ULL(VM_UFFD_MINOR_BIT) /* UFFD minor faults */ +#else # define VM_UFFD_MINOR BIT(VM_UFFD_MINOR_BIT) /* UFFD minor faults */ +#endif #else /* !CONFIG_HAVE_ARCH_USERFAULTFD_MINOR */ # define VM_UFFD_MINOR VM_NONE #endif /* CONFIG_HAVE_ARCH_USERFAULTFD_MINOR */ @@ -426,14 +430,14 @@ extern unsigned int kobjsize(const void *objp); */ #ifdef CONFIG_64BIT #define VM_ALLOW_ANY_UNCACHED_BIT 39 -#define VM_ALLOW_ANY_UNCACHED BIT(VM_ALLOW_ANY_UNCACHED_BIT) +#define VM_ALLOW_ANY_UNCACHED BIT_ULL(VM_ALLOW_ANY_UNCACHED_BIT) #else #define VM_ALLOW_ANY_UNCACHED VM_NONE #endif #ifdef CONFIG_64BIT #define VM_DROPPABLE_BIT 40 -#define VM_DROPPABLE BIT(VM_DROPPABLE_BIT) +#define VM_DROPPABLE BIT_ULL(VM_DROPPABLE_BIT) #elif defined(CONFIG_PPC32) #define VM_DROPPABLE VM_ARCH_1 #else @@ -442,7 +446,7 @@ extern unsigned int kobjsize(const void *objp); #ifdef CONFIG_64BIT /* VM is sealed, in vm_flags */ -#define VM_SEALED _BITUL(63) +#define VM_SEALED _BITULL(63) #endif /* Bits set in the VMA until the stack is in its final location */ diff --git a/include/linux/mm_types.h b/include/linux/mm_types.h index 0d436b0217fd..900665c5eca8 100644 --- a/include/linux/mm_types.h +++ b/include/linux/mm_types.h @@ -571,7 +571,11 @@ static inline void *folio_get_private(struct folio *folio) return folio->private; } +#ifdef CONFIG_64BIT +typedef unsigned long long vm_flags_t; +#else typedef unsigned long vm_flags_t; +#endif /* * A region containing a mapping of a non-memory backed file under NOMMU diff --git a/mm/debug.c b/mm/debug.c index 8d2acf432385..0fcb85e6efea 100644 --- a/mm/debug.c +++ b/mm/debug.c @@ -181,7 +181,11 @@ void dump_vma(const struct vm_area_struct *vma) pr_emerg("vma %px start %px end %px mm %px\n" "prot %lx anon_vma %px vm_ops %px\n" "pgoff %lx file %px private_data %px\n" +#ifdef CONFIG_64BIT + "flags: %#llx(%pGv)\n", +#else "flags: %#lx(%pGv)\n", +#endif vma, (void *)vma->vm_start, (void *)vma->vm_end, vma->vm_mm, (unsigned long)pgprot_val(vma->vm_page_prot), vma->anon_vma, vma->vm_ops, vma->vm_pgoff, diff --git a/mm/memory.c b/mm/memory.c index 539c0f7c6d54..3c4a9663c094 100644 --- a/mm/memory.c +++ b/mm/memory.c @@ -533,7 +533,11 @@ static void print_bad_pte(struct vm_area_struct *vma, unsigned long addr, (long long)pte_val(pte), (long long)pmd_val(*pmd)); if (page) dump_page(page, "bad pte"); +#ifdef CONFIG_64BIT + pr_alert("addr:%px vm_flags:%08llx anon_vma:%px mapping:%px index:%lx\n", +#else pr_alert("addr:%px vm_flags:%08lx anon_vma:%px mapping:%px index:%lx\n", +#endif (void *)addr, vma->vm_flags, vma->anon_vma, mapping, index); pr_alert("file:%pD fault:%ps mmap:%ps read_folio:%ps\n", vma->vm_file,