From patchwork Tue Mar 25 12:16:20 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Guo Ren X-Patchwork-Id: 14028880 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 795FAC35FFC for ; Tue, 25 Mar 2025 12:26:16 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 59FCD28002D; Tue, 25 Mar 2025 08:26:15 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 54DEC28002C; Tue, 25 Mar 2025 08:26:15 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 3A1B428002D; Tue, 25 Mar 2025 08:26:15 -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 1563428002C for ; Tue, 25 Mar 2025 08:26:15 -0400 (EDT) Received: from smtpin14.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay08.hostedemail.com (Postfix) with ESMTP id 6365D14010F for ; Tue, 25 Mar 2025 12:26:15 +0000 (UTC) X-FDA: 83259995910.14.9253C7D Received: from sea.source.kernel.org (sea.source.kernel.org [172.234.252.31]) by imf17.hostedemail.com (Postfix) with ESMTP id 802FC4000B for ; Tue, 25 Mar 2025 12:26:13 +0000 (UTC) Authentication-Results: imf17.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=dXHVR37B; spf=pass (imf17.hostedemail.com: domain of guoren@kernel.org designates 172.234.252.31 as permitted sender) smtp.mailfrom=guoren@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1742905573; 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=aDa2F2M0tO1sjvajZlGmkdDKna5y4ezZhfE7dxC5APg=; b=wJO5LSkBsTdT66ssKPTGINlPC22WCB+XfhVvGG56pXDLaOTxtKECm5lmfyxzwn2MywAwBQ AGdYBN+3xFPUhdiIrSHcpYYQTfeDddtDOVmhPJk4ioSuHPxjVLW+9hpIQ/Pk6WLiNhuzul zoFHvsQ7PMQKWP2TLNQcvPTtNI81iUg= ARC-Authentication-Results: i=1; imf17.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=dXHVR37B; spf=pass (imf17.hostedemail.com: domain of guoren@kernel.org designates 172.234.252.31 as permitted sender) smtp.mailfrom=guoren@kernel.org; dmarc=pass (policy=quarantine) header.from=kernel.org ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1742905573; a=rsa-sha256; cv=none; b=Iu61udc/aMJnuYXQuLp8HFHzLjgT2ddzF03f/GqBIWiY52QmcdhrkVoXmWxItQ9lTPDPu8 jYyDj6hriRiW6ZuXf8ADrOa83M9BRPccypqnCrJvzinMcYQqEYjAhYAz6OQm+a0X+rwAYK 7YIZ/0CGDmuJQqilGp5OhjAr3odOwIQ= Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by sea.source.kernel.org (Postfix) with ESMTP id 194D643C55; Tue, 25 Mar 2025 12:26:12 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id CA822C4CEE9; Tue, 25 Mar 2025 12:25:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1742905572; bh=yrVg1aQo8nvzx1orbzCiGBpDINXbK2p/bzc74O/ZG7Y=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=dXHVR37BYjtnP226wRmqGD/+5q9LGrYaanpzXXOav8r/BHJV5tQivSCfdRSIzthse 8trpo5JD1iz/5OecDTcnupCBJBQX33vaw/hAbD4qk4LeJVqvqHHpw9NHBT1ZFlMkn0 uCFXCw3w+yxAMYAhQHMWBx2FPCBEyeY1A19l2GvG5jVXNeDCNpsZ+dZy8FBqDa7uo/ Zsma4xcYZbwnzagW4sOr51uBOwZp+LjobLSp/6HGruAVKHWCA8RItDHKa1cnmepcuH KTSRJuNlahXURYcKWJr2ZhoKXLWH1u/JzJrtINfTgSwDQFMRVa5eB4TERwwIW5IXtr Utc6YiuHqvQsA== 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 39/43] rv64ilp32_abi: sysinfo: Adapt sysinfo structure to lp64 uapi Date: Tue, 25 Mar 2025 08:16:20 -0400 Message-Id: <20250325121624.523258-40-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-Queue-Id: 802FC4000B X-Rspam-User: X-Rspamd-Server: rspam02 X-Stat-Signature: jirby68swprduofshs4kpyzrpjj591zd X-HE-Tag: 1742905573-175505 X-HE-Meta: U2FsdGVkX1+ZD35avq+Mj4vb7kcfOJoczXLizJaqq3GofplNWGbsOWGk4/0xFT1ljKPKkaq69L8Xz0v/e2BpmqMwMhNV7VKRF7lDRz6F9FaD1Jm4+DLXHFz4jQIEbyKsu8FhRYcGVH2hPkO0e/1UAjVL6sDGaFSqY1uJJqQaN8Mh82kY8dwTsSK+KjUSkPH+R/3XwEdz0L1pAVzFTndMFX3qVcqDLnEoKeIK7425EzhseA5fOBumiza1U164mKVU8OX30cY/GzSYnm0ofxS/cZRdoRBwEJk4p5h0UoPKWp7ybyQSUMcroQjqM3yqNrWYjewPqWAvUSDY/qBe3cHCDTp8EgQ0KILC/+RJ7KgEdT5GCT9tg3RDNV683zrJVxskpJfQoIvzeUG+kjjD9td1egWXhs151gg8QakHm3Kg+ZjTIM2rsOI/Oom+FhHtgL+sLXKbq4BHbAnHE4slzcSL8LcdcBLTAG0JJJB3h/HXb9vgJvd/4H3MGWeNvBeExemf7Gs/mOPXwTt9scre9BvOiRAGXHv1lz0KDZNrIR53sHC/I0DKWdCydJPNdU0dYTtGWnZR7IE0Gt9x6VxnzrTKjdO3dhvTrX5SRBVMaoghZ/+H7yjZsAlfeO175uFM0WGByrXWQOrcLCURPAfwiwyteZhqkZ1rNZxenPff7uMmocZIMMpYU1KbSYWJ1ejeekXwyDyfXKYxcE6DmAhNnvylGboq8vxUJnfftSuErtiJLwMlGFLP4xIOzjK0+3ufbJ02+8QN+x2sRF5c0C6tTfdekcQpmHsNCqFAOXLe42KrwMOKC3ytcPl1e1KZeNYe+/nLhu5MNZwRZ086QscLkivI4VGDNGuGBB+MCmknjKWj+ynQikc7hrDrPGlW0utEpObhmKUuM2LxOkTJnenSBqT625aabeqsXkjiyYVpvlA6pwNF8eABN6+VvmU/FOeyCQ+C/W9sAUJGjUjxsQ3bZiB eGqd/PiL +DLqpXv4apjbDrZmcBwBdmlT6W9zX8eyVJBgtRV1rEgmIxxB2O2DJHVVNLmT2JprSqR6WESOsXDVEJ9oFCKOq1KR0fH2kaIEWGpx3gZzmAsKEtc2Qy1jydzSzUnJj88HdAbua0AWf5PtnyVf+LoBhh+rZJTVEPsx8qysYWvZMyh38mEFpZSrtBv2wmQiT5FF2n7O6VI1/iOQ50r5Gg3Vi8Z70BcLuzV8mKdAOfUxjGB1Cb1ph8PKP2gvpraEpXS3LKJI/bOQ9RxSSlxwkC/46WvwIi20qmEuY50GzkLKQv33MgniEqEF0QK6qINTYvWzA6tlSX2HbqxxNRrUzIcNzD4vES93WBgLDEy8x 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)" The RISC-V 64ilp32 ABI leverages LP64 uapi and accommodates LP64 ABI userspace directly, necessitating updates to the sysinfo struct's unsigned long and array types with u64. Signed-off-by: Guo Ren (Alibaba DAMO Academy) --- fs/proc/loadavg.c | 10 +++++++--- include/linux/sched/loadavg.h | 4 ++++ include/uapi/linux/sysinfo.h | 20 ++++++++++++++++++++ kernel/sched/loadavg.c | 4 ++++ 4 files changed, 35 insertions(+), 3 deletions(-) diff --git a/fs/proc/loadavg.c b/fs/proc/loadavg.c index 817981e57223..643e06de3446 100644 --- a/fs/proc/loadavg.c +++ b/fs/proc/loadavg.c @@ -13,14 +13,18 @@ static int loadavg_proc_show(struct seq_file *m, void *v) { +#if defined(CONFIG_64BIT) && (BITS_PER_LONG == 32) + unsigned long long avnrun[3]; +#else unsigned long avnrun[3]; +#endif get_avenrun(avnrun, FIXED_1/200, 0); seq_printf(m, "%lu.%02lu %lu.%02lu %lu.%02lu %u/%d %d\n", - LOAD_INT(avnrun[0]), LOAD_FRAC(avnrun[0]), - LOAD_INT(avnrun[1]), LOAD_FRAC(avnrun[1]), - LOAD_INT(avnrun[2]), LOAD_FRAC(avnrun[2]), + LOAD_INT((ulong)avnrun[0]), LOAD_FRAC((ulong)avnrun[0]), + LOAD_INT((ulong)avnrun[1]), LOAD_FRAC((ulong)avnrun[1]), + LOAD_INT((ulong)avnrun[2]), LOAD_FRAC((ulong)avnrun[2]), nr_running(), nr_threads, idr_get_cursor(&task_active_pid_ns(current)->idr) - 1); return 0; diff --git a/include/linux/sched/loadavg.h b/include/linux/sched/loadavg.h index 83ec54b65e79..8f2d6a827ee9 100644 --- a/include/linux/sched/loadavg.h +++ b/include/linux/sched/loadavg.h @@ -13,7 +13,11 @@ * 11 bit fractions. */ extern unsigned long avenrun[]; /* Load averages */ +#if defined(CONFIG_64BIT) && (BITS_PER_LONG == 32) +extern void get_avenrun(unsigned long long *loads, unsigned long offset, int shift); +#else extern void get_avenrun(unsigned long *loads, unsigned long offset, int shift); +#endif #define FSHIFT 11 /* nr of bits of precision */ #define FIXED_1 (1< #define SI_LOAD_SHIFT 16 + +#if (__riscv_xlen == 64) && (__BITS_PER_LONG == 32) +struct sysinfo { + __s64 uptime; /* Seconds since boot */ + __u64 loads[3]; /* 1, 5, and 15 minute load averages */ + __u64 totalram; /* Total usable main memory size */ + __u64 freeram; /* Available memory size */ + __u64 sharedram; /* Amount of shared memory */ + __u64 bufferram; /* Memory used by buffers */ + __u64 totalswap; /* Total swap space size */ + __u64 freeswap; /* swap space still available */ + __u16 procs; /* Number of current processes */ + __u16 pad; /* Explicit padding for m68k */ + __u64 totalhigh; /* Total high memory size */ + __u64 freehigh; /* Available high memory size */ + __u32 mem_unit; /* Memory unit size in bytes */ + char _f[20-2*sizeof(__u64)-sizeof(__u32)]; /* Padding: libc5 uses this.. */ +}; +#else struct sysinfo { __kernel_long_t uptime; /* Seconds since boot */ __kernel_ulong_t loads[3]; /* 1, 5, and 15 minute load averages */ @@ -21,5 +40,6 @@ struct sysinfo { __u32 mem_unit; /* Memory unit size in bytes */ char _f[20-2*sizeof(__kernel_ulong_t)-sizeof(__u32)]; /* Padding: libc5 uses this.. */ }; +#endif #endif /* _LINUX_SYSINFO_H */ diff --git a/kernel/sched/loadavg.c b/kernel/sched/loadavg.c index c48900b856a2..f1f5abc64dea 100644 --- a/kernel/sched/loadavg.c +++ b/kernel/sched/loadavg.c @@ -68,7 +68,11 @@ EXPORT_SYMBOL(avenrun); /* should be removed */ * * These values are estimates at best, so no need for locking. */ +#if defined(CONFIG_64BIT) && (BITS_PER_LONG == 32) +void get_avenrun(unsigned long long *loads, unsigned long offset, int shift) +#else void get_avenrun(unsigned long *loads, unsigned long offset, int shift) +#endif { loads[0] = (avenrun[0] + offset) << shift; loads[1] = (avenrun[1] + offset) << shift;