From: "Dmitry V. Levin" <ldv@strace.io>
To: Shuah Khan <shuah@kernel.org>, Andrew Morton <akpm@linux-foundation.org>
Cc: Oleg Nesterov <oleg@redhat.com>,
"Maciej W. Rozycki" <macro@orcam.me.uk>,
strace-devel@lists.strace.io, linux-kselftest@vger.kernel.org,
linux-mips@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH v2] selftests/ptrace/get_syscall_info: fix for MIPS n32
Date: Wed, 26 Mar 2025 11:06:43 +0200 [thread overview]
Message-ID: <20250326090643.GA30882@strace.io> (raw)
In-Reply-To: <20250115233747.GA28541@strace.io>
Could somebody pick up this patch, please?
Nothing has changed since v2, so I have nothing new to add.
v2: https://lore.kernel.org/all/20250115233747.GA28541@strace.io/
On Thu, Jan 16, 2025 at 01:37:47AM +0200, Dmitry V. Levin wrote:
> MIPS n32 is one of two ILP32 architectures supported by the kernel
> that have 64-bit syscall arguments (another one is x32).
>
> When this test passed 32-bit arguments to syscall(), they were
> sign-extended in libc, PTRACE_GET_SYSCALL_INFO reported these
> sign-extended 64-bit values, and the test complained about the mismatch.
>
> Fix this by passing arguments of the appropriate type to syscall(),
> which is "unsigned long long" on MIPS n32, and __kernel_ulong_t on other
> architectures.
>
> As a side effect, this also extends the test on all 64-bit architectures
> by choosing constants that don't fit into 32-bit integers.
>
> Signed-off-by: Dmitry V. Levin <ldv@strace.io>
> ---
>
> v2: Fixed MIPS #ifdef.
>
> .../selftests/ptrace/get_syscall_info.c | 53 +++++++++++--------
> 1 file changed, 32 insertions(+), 21 deletions(-)
>
> diff --git a/tools/testing/selftests/ptrace/get_syscall_info.c b/tools/testing/selftests/ptrace/get_syscall_info.c
> index 5bcd1c7b5be6..2970f72d66d3 100644
> --- a/tools/testing/selftests/ptrace/get_syscall_info.c
> +++ b/tools/testing/selftests/ptrace/get_syscall_info.c
> @@ -11,8 +11,19 @@
> #include <err.h>
> #include <signal.h>
> #include <asm/unistd.h>
> +#include <linux/types.h>
> #include "linux/ptrace.h"
>
> +#if defined(_MIPS_SIM) && _MIPS_SIM == _MIPS_SIM_NABI32
> +/*
> + * MIPS N32 is the only architecture where __kernel_ulong_t
> + * does not match the bitness of syscall arguments.
> + */
> +typedef unsigned long long kernel_ulong_t;
> +#else
> +typedef __kernel_ulong_t kernel_ulong_t;
> +#endif
> +
> static int
> kill_tracee(pid_t pid)
> {
> @@ -42,37 +53,37 @@ sys_ptrace(int request, pid_t pid, unsigned long addr, unsigned long data)
>
> TEST(get_syscall_info)
> {
> - static const unsigned long args[][7] = {
> + const kernel_ulong_t args[][7] = {
> /* a sequence of architecture-agnostic syscalls */
> {
> __NR_chdir,
> - (unsigned long) "",
> - 0xbad1fed1,
> - 0xbad2fed2,
> - 0xbad3fed3,
> - 0xbad4fed4,
> - 0xbad5fed5
> + (uintptr_t) "",
> + (kernel_ulong_t) 0xdad1bef1bad1fed1ULL,
> + (kernel_ulong_t) 0xdad2bef2bad2fed2ULL,
> + (kernel_ulong_t) 0xdad3bef3bad3fed3ULL,
> + (kernel_ulong_t) 0xdad4bef4bad4fed4ULL,
> + (kernel_ulong_t) 0xdad5bef5bad5fed5ULL
> },
> {
> __NR_gettid,
> - 0xcaf0bea0,
> - 0xcaf1bea1,
> - 0xcaf2bea2,
> - 0xcaf3bea3,
> - 0xcaf4bea4,
> - 0xcaf5bea5
> + (kernel_ulong_t) 0xdad0bef0caf0bea0ULL,
> + (kernel_ulong_t) 0xdad1bef1caf1bea1ULL,
> + (kernel_ulong_t) 0xdad2bef2caf2bea2ULL,
> + (kernel_ulong_t) 0xdad3bef3caf3bea3ULL,
> + (kernel_ulong_t) 0xdad4bef4caf4bea4ULL,
> + (kernel_ulong_t) 0xdad5bef5caf5bea5ULL
> },
> {
> __NR_exit_group,
> 0,
> - 0xfac1c0d1,
> - 0xfac2c0d2,
> - 0xfac3c0d3,
> - 0xfac4c0d4,
> - 0xfac5c0d5
> + (kernel_ulong_t) 0xdad1bef1fac1c0d1ULL,
> + (kernel_ulong_t) 0xdad2bef2fac2c0d2ULL,
> + (kernel_ulong_t) 0xdad3bef3fac3c0d3ULL,
> + (kernel_ulong_t) 0xdad4bef4fac4c0d4ULL,
> + (kernel_ulong_t) 0xdad5bef5fac5c0d5ULL
> }
> };
> - const unsigned long *exp_args;
> + const kernel_ulong_t *exp_args;
>
> pid_t pid = fork();
>
> @@ -154,7 +165,7 @@ TEST(get_syscall_info)
> }
> ASSERT_LT(0, (rc = sys_ptrace(PTRACE_GET_SYSCALL_INFO,
> pid, size,
> - (unsigned long) &info))) {
> + (uintptr_t) &info))) {
> LOG_KILL_TRACEE("PTRACE_GET_SYSCALL_INFO: %m");
> }
> ASSERT_EQ(expected_none_size, rc) {
> @@ -177,7 +188,7 @@ TEST(get_syscall_info)
> case SIGTRAP | 0x80:
> ASSERT_LT(0, (rc = sys_ptrace(PTRACE_GET_SYSCALL_INFO,
> pid, size,
> - (unsigned long) &info))) {
> + (uintptr_t) &info))) {
> LOG_KILL_TRACEE("PTRACE_GET_SYSCALL_INFO: %m");
> }
> switch (ptrace_stop) {
> --
> ldv
--
ldv
next prev parent reply other threads:[~2025-03-26 9:06 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-01-15 23:37 [PATCH v2] selftests/ptrace/get_syscall_info: fix for MIPS n32 Dmitry V. Levin
2025-03-26 9:06 ` Dmitry V. Levin [this message]
2025-03-28 23:04 ` Shuah Khan
2025-03-29 12:48 ` Dmitry V. Levin
2025-03-29 14:02 ` Maciej W. Rozycki
2025-04-08 23:54 ` Shuah Khan
2025-06-02 11:59 ` Dmitry V. Levin
2025-06-02 22:21 ` Shuah Khan
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250326090643.GA30882@strace.io \
--to=ldv@strace.io \
--cc=akpm@linux-foundation.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-kselftest@vger.kernel.org \
--cc=linux-mips@vger.kernel.org \
--cc=macro@orcam.me.uk \
--cc=oleg@redhat.com \
--cc=shuah@kernel.org \
--cc=strace-devel@lists.strace.io \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).