From mboxrd@z Thu Jan 1 00:00:00 1970 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 picard.linux.it (picard.linux.it [213.254.12.146]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id DF917F9937D for ; Thu, 23 Apr 2026 12:03:43 +0000 (UTC) Received: from picard.linux.it (localhost [IPv6:::1]) by picard.linux.it (Postfix) with ESMTP id 72F163E2DC3 for ; Thu, 23 Apr 2026 14:03:42 +0200 (CEST) Received: from in-5.smtp.seeweb.it (in-5.smtp.seeweb.it [IPv6:2001:4b78:1:20::5]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (secp384r1)) (No client certificate requested) by picard.linux.it (Postfix) with ESMTPS id 8A13E3E538D for ; Thu, 23 Apr 2026 14:03:07 +0200 (CEST) Received: from smtp-out1.suse.de (smtp-out1.suse.de [IPv6:2a07:de40:b251:101:10:150:64:1]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by in-5.smtp.seeweb.it (Postfix) with ESMTPS id EA1FD600788 for ; Thu, 23 Apr 2026 14:03:06 +0200 (CEST) Received: from imap1.dmz-prg2.suse.org (unknown [10.150.64.97]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) by smtp-out1.suse.de (Postfix) with ESMTPS id BC3A86A86E for ; Thu, 23 Apr 2026 12:03:01 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.cz; s=susede2_rsa; t=1776945785; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc: mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=+33xLtgjceZle6BuFK6Wc9+nwoVm8aLpS/VHYdfRM60=; b=QdFmgUDOn6pqgTOqyDyFzWJ/h50ncoj6HesgIbuLSM5U4eQiKhr2BF4elzqUeqrE9N9FCR clp+Sc04ffpxTMeQ070DtFyG9S2AYIX7kcrZh5EKD3v+8pGYz9BJ9ggmoJyDwGxifDIWfu Dj3Ebp5bQQIXDEl145YImQJuGPkEcUw= DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=suse.cz; s=susede2_ed25519; t=1776945785; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc: mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=+33xLtgjceZle6BuFK6Wc9+nwoVm8aLpS/VHYdfRM60=; b=SDdpDelXWEJXezFwMNR5QVMbszW0OE4HFkbuy7a9c9TEdhT1lVXmrhLe/QHpVPWu1wNwHq Jlb3AfBs3t58UeBg== Authentication-Results: smtp-out1.suse.de; none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.cz; s=susede2_rsa; t=1776945781; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc: mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=+33xLtgjceZle6BuFK6Wc9+nwoVm8aLpS/VHYdfRM60=; b=qJ0JvKssCnENfbuYB8fm+PivzkihBnwtB7bG2ukxbo4jU5/x1F9itI+WuRTYPgNV4sqshx JFM8X5GL560AqQqOuO2SZM+CxNj7KEUVej05ENu0nvJnNuu0OsaJBZSY6O5C4V9q2A7nr4 Z0ft0fk+fB6cAPCnCSu80PkyjWwhwhE= DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=suse.cz; s=susede2_ed25519; t=1776945781; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc: mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=+33xLtgjceZle6BuFK6Wc9+nwoVm8aLpS/VHYdfRM60=; b=5z0aXRAwhrmI+anuumDV8/ZLx2yfdDWQJnuWv6O+qizTB3jMQ2toekgOqT0ZuBbEZHnX8S WZzA8qi6x1Ok/PCA== Received: from imap1.dmz-prg2.suse.org (localhost [127.0.0.1]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) by imap1.dmz-prg2.suse.org (Postfix) with ESMTPS id ADE01593B0 for ; Thu, 23 Apr 2026 12:03:01 +0000 (UTC) Received: from dovecot-director2.suse.de ([2a07:de40:b281:106:10:150:64:167]) by imap1.dmz-prg2.suse.org with ESMTPSA id l8ylKXUK6mm1UQAAD6G6ig (envelope-from ) for ; Thu, 23 Apr 2026 12:03:01 +0000 From: Cyril Hrubis To: ltp@lists.linux.it Date: Thu, 23 Apr 2026 14:03:03 +0200 Message-ID: <20260423120309.18049-3-chrubis@suse.cz> X-Mailer: git-send-email 2.52.0 In-Reply-To: <20260423120309.18049-1-chrubis@suse.cz> References: <20260423120309.18049-1-chrubis@suse.cz> MIME-Version: 1.0 X-Spamd-Result: default: False [-2.80 / 50.00]; BAYES_HAM(-3.00)[100.00%]; NEURAL_HAM_LONG(-1.00)[-1.000]; MID_CONTAINS_FROM(1.00)[]; R_MISSING_CHARSET(0.50)[]; NEURAL_HAM_SHORT(-0.20)[-0.995]; MIME_GOOD(-0.10)[text/plain]; FUZZY_RATELIMITED(0.00)[rspamd.com]; RCVD_VIA_SMTP_AUTH(0.00)[]; RCPT_COUNT_ONE(0.00)[1]; ARC_NA(0.00)[]; DKIM_SIGNED(0.00)[suse.cz:s=susede2_rsa,suse.cz:s=susede2_ed25519]; DBL_BLOCKED_OPENRESOLVER(0.00)[suse.cz:mid,suse.cz:email]; FROM_EQ_ENVFROM(0.00)[]; FROM_HAS_DN(0.00)[]; MIME_TRACE(0.00)[0:+]; RCVD_COUNT_TWO(0.00)[2]; TO_MATCH_ENVRCPT_ALL(0.00)[]; TO_DN_NONE(0.00)[]; PREVIOUSLY_DELIVERED(0.00)[ltp@lists.linux.it]; RCVD_TLS_ALL(0.00)[] X-Virus-Scanned: clamav-milter 1.0.9 at in-5.smtp.seeweb.it X-Virus-Status: Clean Subject: [LTP] [PATCH v2 2/8] syscalls: Add epoll_wait08 X-BeenThere: ltp@lists.linux.it X-Mailman-Version: 2.1.29 Precedence: list List-Id: Linux Test Project List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Errors-To: ltp-bounces+ltp=archiver.kernel.org@lists.linux.it Sender: "ltp" Tests that epoll_wait() can be interrupted by a signal and returns EINTR. Signed-off-by: Cyril Hrubis --- runtest/syscalls | 3 + .../kernel/syscalls/epoll_wait/.gitignore | 1 + .../kernel/syscalls/epoll_wait/epoll_wait08.c | 69 +++++++++++++++++++ 3 files changed, 73 insertions(+) create mode 100644 testcases/kernel/syscalls/epoll_wait/epoll_wait08.c diff --git a/runtest/syscalls b/runtest/syscalls index d890c5516..99cdd1db8 100644 --- a/runtest/syscalls +++ b/runtest/syscalls @@ -187,6 +187,7 @@ epoll_ctl02 epoll_ctl02 epoll_ctl03 epoll_ctl03 epoll_ctl04 epoll_ctl04 epoll_ctl05 epoll_ctl05 + epoll_wait01 epoll_wait01 epoll_wait02 epoll_wait02 epoll_wait03 epoll_wait03 @@ -194,6 +195,8 @@ epoll_wait04 epoll_wait04 epoll_wait05 epoll_wait05 epoll_wait06 epoll_wait06 epoll_wait07 epoll_wait07 +epoll_wait08 epoll_wait08 + epoll_pwait01 epoll_pwait01 epoll_pwait02 epoll_pwait02 epoll_pwait03 epoll_pwait03 diff --git a/testcases/kernel/syscalls/epoll_wait/.gitignore b/testcases/kernel/syscalls/epoll_wait/.gitignore index 66ac18ae2..f3b208950 100644 --- a/testcases/kernel/syscalls/epoll_wait/.gitignore +++ b/testcases/kernel/syscalls/epoll_wait/.gitignore @@ -5,3 +5,4 @@ epoll_wait04 epoll_wait05 epoll_wait06 epoll_wait07 +epoll_wait08 diff --git a/testcases/kernel/syscalls/epoll_wait/epoll_wait08.c b/testcases/kernel/syscalls/epoll_wait/epoll_wait08.c new file mode 100644 index 000000000..9d10984ef --- /dev/null +++ b/testcases/kernel/syscalls/epoll_wait/epoll_wait08.c @@ -0,0 +1,69 @@ +// SPDX-License-Identifier: GPL-2.0-or-later +/* + * Copyright (c) Linux Test Project, 2026 + */ + +/*\ + * Verify that epoll_wait fails with EINTR when a signal arrives while waiting + * for events. + * + * [Algorithm] + * + * - Create an epoll instance and register a socket fd for EPOLLIN. + * - Fork a child that waits for the parent to enter epoll_wait, then sends + * SIGUSR1 to interrupt it. + * - Verify that epoll_wait returns -1 with errno set to EINTR. + */ + +#include +#include + +#include "tst_test.h" +#include "tst_epoll.h" + +static int efd = -1; + +static void sighandler(int sig LTP_ATTRIBUTE_UNUSED) +{ +} + +static void setup(void) +{ + static struct sigaction sa = { + .sa_handler = sighandler, + }; + + SAFE_SIGEMPTYSET(&sa.sa_mask); + SAFE_SIGACTION(SIGUSR1, &sa, NULL); + + efd = SAFE_EPOLL_CREATE1(0); +} + +static void run(void) +{ + pid_t pid = SAFE_FORK(); + + if (!pid) { + struct epoll_event ev; + + TST_EXP_FAIL(epoll_wait(efd, &ev, 1, -1), EINTR, + "epoll_wait() interrupted by signal"); + exit(0); + } + + TST_PROCESS_STATE_WAIT(pid, 'S', 0); + SAFE_KILL(pid, SIGUSR1); +} + +static void cleanup(void) +{ + if (efd != -1) + SAFE_CLOSE(efd); +} + +static struct tst_test test = { + .test_all = run, + .setup = setup, + .cleanup = cleanup, + .forks_child = 1, +}; -- 2.52.0 -- Mailing list info: https://lists.linux.it/listinfo/ltp