[LTP] [PATCH v3] mseal02: Handle multiple errnos for 32-bit compat mode
Wei Gao
wegao@suse.com
Mon Mar 23 07:08:29 CET 2026
In 32-bit compat mode, the overflow_size (calculated using a 32-bit ULONG_MAX)
does not cause a 64-bit integer wrap-around when added to the start address.
Consequently, the kernel see valid range that points to unmapped space, returning
ENOMEM instead of the expected EINVAL.
Signed-off-by: Wei Gao <wegao@suse.com>
---
v2->v3: Add compat_err replace hardcoding index similar with dcf0c145d9
("setxattr02: Adapt test for kernel 7.1.0+ socket xattr support").
testcases/kernel/syscalls/mseal/mseal02.c | 16 +++++++++-------
1 file changed, 9 insertions(+), 7 deletions(-)
diff --git a/testcases/kernel/syscalls/mseal/mseal02.c b/testcases/kernel/syscalls/mseal/mseal02.c
index e11d7dbf4..5874e108a 100644
--- a/testcases/kernel/syscalls/mseal/mseal02.c
+++ b/testcases/kernel/syscalls/mseal/mseal02.c
@@ -29,20 +29,22 @@ static struct tcase {
size_t *len;
unsigned long flags;
int exp_err;
+ int compat_err;
} tcases[] = {
- {&start_addr, &page_size, ULONG_MAX, EINVAL},
- {&unaligned_start_addr, &page_size, 0, EINVAL},
- {&start_addr, &overflow_size, 0, EINVAL},
- {&unallocated_start_addr, &twopages_size, 0, ENOMEM},
- {&unallocated_end_addr, &twopages_size, 0, ENOMEM},
- {&start_addr, &fourpages_size, 0, ENOMEM},
+ {.addr = &start_addr, .len = &page_size, .flags = ULONG_MAX, .exp_err = EINVAL},
+ {.addr = &unaligned_start_addr, .len = &page_size, .flags = 0, .exp_err = EINVAL},
+ {.addr = &start_addr, .len = &overflow_size, .flags = 0, .exp_err = EINVAL, .compat_err = ENOMEM},
+ {.addr = &unallocated_start_addr, .len = &twopages_size, .flags = 0, .exp_err = ENOMEM},
+ {.addr = &unallocated_end_addr, .len = &twopages_size, .flags = 0, .exp_err = ENOMEM},
+ {.addr = &start_addr, .len = &fourpages_size, .flags = 0, .exp_err = ENOMEM},
};
static void run(unsigned int n)
{
struct tcase *tc = &tcases[n];
+ int exp_err = tc->compat_err && tst_is_compat_mode() ? tc->compat_err : tc->exp_err;
- TST_EXP_FAIL(tst_syscall(__NR_mseal, *tc->addr, *tc->len, tc->flags), tc->exp_err,
+ TST_EXP_FAIL(tst_syscall(__NR_mseal, *tc->addr, *tc->len, tc->flags), exp_err,
"mseal(%p, %lu, %lu)", *tc->addr, *tc->len, tc->flags);
}
--
2.52.0
More information about the ltp
mailing list