* [LTP] [PATCH v4 1/3] syscalls/mq_timedreceive: convert to new API
@ 2017-03-08 14:21 Petr Vorel
2017-03-08 14:21 ` [LTP] [PATCH v4 2/3] lib: SAFE_MQ_OPEN() macro Petr Vorel
` (2 more replies)
0 siblings, 3 replies; 7+ messages in thread
From: Petr Vorel @ 2017-03-08 14:21 UTC (permalink / raw)
To: ltp
Signed-off-by: Petr Vorel <pvorel@suse.cz>
---
.../syscalls/mq_timedreceive/mq_timedreceive01.c | 688 ++++++++-------------
1 file changed, 256 insertions(+), 432 deletions(-)
diff --git a/testcases/kernel/syscalls/mq_timedreceive/mq_timedreceive01.c b/testcases/kernel/syscalls/mq_timedreceive/mq_timedreceive01.c
index d3d49773d..ab46bc6b0 100644
--- a/testcases/kernel/syscalls/mq_timedreceive/mq_timedreceive01.c
+++ b/testcases/kernel/syscalls/mq_timedreceive/mq_timedreceive01.c
@@ -1,478 +1,302 @@
-/******************************************************************************/
-/* Copyright (c) Crackerjack Project., 2007-2008 ,Hitachi, Ltd */
-/* Author(s): Takahiro Yasui <takahiro.yasui.mp@hitachi.com>, */
-/* Yumiko Sugita <yumiko.sugita.yf@hitachi.com>, */
-/* Satoshi Fujiwara <sa-fuji@sdl.hitachi.co.jp> */
-/* */
-/* This program is free software; you can redistribute it and/or modify */
-/* it under the terms of the GNU General Public License as published by */
-/* the Free Software Foundation; either version 2 of the License, or */
-/* (at your option) any later version. */
-/* */
-/* This program is distributed in the hope that it will be useful, */
-/* but WITHOUT ANY WARRANTY; without even the implied warranty of */
-/* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See */
-/* the GNU General Public License for more details. */
-/* */
-/* You should have received a copy of the GNU General Public License */
-/* along with this program; if not, write to the Free Software */
-/* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */
-/* */
-/******************************************************************************/
-/******************************************************************************/
-/* */
-/* File: mq_timedreceive01.c */
-/* */
-/* Description: This tests the mq_timedreceive() syscall */
-/* */
-/* */
-/* */
-/* */
-/* */
-/* */
-/* Usage: <for command-line> */
-/* mq_timedreceive01 [-c n] [-e][-i n] [-I x] [-p x] [-t] */
-/* where, -c n : Run n copies concurrently. */
-/* -e : Turn on errno logging. */
-/* -i n : Execute test n times. */
-/* -I x : Execute test for x seconds. */
-/* -P x : Pause for x seconds between iterations. */
-/* -t : Turn on syscall timing. */
-/* */
-/* Total Tests: 1 */
-/* */
-/* Test Name: mq_timedreceive01 */
-/* History: Porting from Crackerjack to LTP is done by */
-/* Manas Kumar Nayak maknayak@in.ibm.com> */
-/******************************************************************************/
-#define _XOPEN_SOURCE 600
-#include <sys/syscall.h>
-#include <sys/types.h>
-#include <sys/stat.h>
-#include <sys/wait.h>
-#include <getopt.h>
-#include <libgen.h>
-#include <stdlib.h>
+/*
+ * Copyright (c) Crackerjack Project., 2007-2008 ,Hitachi, Ltd
+ * Author(s): Takahiro Yasui <takahiro.yasui.mp@hitachi.com>,
+ * Yumiko Sugita <yumiko.sugita.yf@hitachi.com>,
+ * Satoshi Fujiwara <sa-fuji@sdl.hitachi.co.jp>
+ * Copyright (c) 2016-2017 Linux Test Project
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of
+ * the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it would be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write the Free Software Foundation,
+ * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
#include <errno.h>
-#include <stdio.h>
-#include <unistd.h>
-#include <string.h>
-#include <mqueue.h>
-#include <time.h>
-#include <signal.h>
#include <limits.h>
+#include <mqueue.h>
-#include "../utils/include_j_h.h"
-#include "../utils/common_j_h.c"
+#include "tst_sig_proc.h"
+#include "tst_test.h"
-#include "test.h"
-#include "linux_syscall_numbers.h"
+static struct sigaction act;
+static pid_t pid;
+static int fd, fd_root;
-char *TCID = "mq_timedreceive01";
-int testno;
-int TST_TOTAL = 1;
-struct sigaction act;
+struct test_case {
+ int len;
+ unsigned prio;
+ struct timespec rq;
+ int fd;
+ int invalid_msg;
+ int send;
+ int ret;
+ int err;
+ void (*setup)(void);
+ void (*cleanup)(void);
+};
-/*
- * sighandler()
- */
-void sighandler(int sig)
+#define MAX_MSGSIZE 8192
+
+#define QUEUE_NAME "/test_mqueue"
+
+static void create_queue(void);
+static void create_queue_nonblock(void);
+static void create_queue_sig(void);
+static void open_fd(void);
+static void unlink_queue(void);
+
+static struct test_case tcase[] = {
+ {
+ .setup = create_queue,
+ .send = 1,
+ .len = 0,
+ .ret = 0,
+ .err = 0,
+ },
+ {
+ .setup = create_queue,
+ .send = 1,
+ .len = 1,
+ .ret = 0,
+ .err = 0,
+ },
+ {
+ .setup = create_queue,
+ .send = 1,
+ .len = MAX_MSGSIZE,
+ .ret = 0,
+ .err = 0,
+ },
+ {
+ .setup = create_queue,
+ .send = 1,
+ .len = 1,
+ .prio = 32767, /* max priority */
+ .ret = 0,
+ .err = 0,
+ },
+ {
+ .setup = create_queue,
+ .invalid_msg = 1,
+ .send = 1,
+ .len = 0,
+ .ret = -1,
+ .err = EMSGSIZE,
+ },
+ {
+ .len = 0,
+ .fd = -1,
+ .ret = -1,
+ .err = EBADF,
+ },
+ {
+ .len = 0,
+ .fd = INT_MAX - 1,
+ .ret = -1,
+ .err = EBADF,
+ },
+ {
+ .len = 0,
+ .ret = -1,
+ .err = EBADF,
+ .setup = open_fd,
+ },
+ {
+ .len = 16,
+ .ret = -1,
+ .err = EAGAIN,
+ .setup = create_queue_nonblock,
+ .cleanup = unlink_queue,
+ },
+ {
+ .len = 16,
+ .rq = (struct timespec) {.tv_sec = -1, .tv_nsec = 0},
+ .ret = -1,
+ .err = EINVAL,
+ .setup = create_queue,
+ .cleanup = unlink_queue,
+ },
+ {
+ .len = 16,
+ .rq = (struct timespec) {.tv_sec = 0, .tv_nsec = -1},
+ .ret = -1,
+ .err = EINVAL,
+ .setup = create_queue,
+ .cleanup = unlink_queue,
+ },
+ {
+ .len = 16,
+ .rq = (struct timespec) {.tv_sec = 0, .tv_nsec = 1000000000},
+ .ret = -1,
+ .err = EINVAL,
+ .setup = create_queue,
+ .cleanup = unlink_queue,
+ },
+ {
+ .len = 16,
+ .rq = (struct timespec) {.tv_sec = 0, .tv_nsec = 999999999},
+ .ret = -1,
+ .err = ETIMEDOUT,
+ .setup = create_queue,
+ .cleanup = unlink_queue,
+ },
+ {
+ .len = 16,
+ .rq = (struct timespec) {.tv_sec = 3, .tv_nsec = 0},
+ .ret = -1,
+ .err = EINTR,
+ .setup = create_queue_sig,
+ .cleanup = unlink_queue,
+ },
+};
+
+static void sighandler(int sig LTP_ATTRIBUTE_UNUSED)
{
- if (sig == SIGINT)
- return;
+}
- return;
+static void setup(void)
+{
+ act.sa_handler = sighandler;
+ sigaction(SIGINT, &act, NULL);
+
+ fd_root = SAFE_OPEN("/", O_RDONLY);
}
-/* Extern Global Functions */
-/******************************************************************************/
-/* */
-/* Function: cleanup */
-/* */
-/* Description: Performs all one time clean up for this test on successful */
-/* completion, premature exit or failure. Closes all temporary */
-/* files, removes all temporary directories exits the test with */
-/* appropriate return code by calling tst_exit() function. */
-/* */
-/* Input: None. */
-/* */
-/* Output: None. */
-/* */
-/* Return: On failure - Exits calling tst_exit(). Non '0' return code. */
-/* On success - Exits calling tst_exit(). With '0' return code. */
-/* */
-/******************************************************************************/
-void cleanup(void)
+static void cleanup(void)
{
+ if (fd > 0)
+ SAFE_CLOSE(fd);
+}
- tst_rmdir();
+static void create_queue(void)
+{
+ fd = mq_open(QUEUE_NAME, O_CREAT | O_EXCL | O_RDWR, S_IRWXU, NULL);
+ if (fd == -1)
+ tst_brk(TBROK | TERRNO, "mq_open(" QUEUE_NAME ") failed");
+}
+static void create_queue_nonblock(void)
+{
+ fd = mq_open(QUEUE_NAME, O_CREAT | O_EXCL | O_RDWR | O_NONBLOCK, S_IRWXU,
+ NULL);
+ if (fd == -1)
+ tst_brk(TBROK | TERRNO, "mq_open(" QUEUE_NAME ") failed");
}
-/* Local Functions */
-/******************************************************************************/
-/* */
-/* Function: setup */
-/* */
-/* Description: Performs all one time setup for this test. This function is */
-/* typically used to capture signals, create temporary dirs */
-/* and temporary files that may be used in the course of this */
-/* test. */
-/* */
-/* Input: None. */
-/* */
-/* Output: None. */
-/* */
-/* Return: On failure - Exits by calling cleanup(). */
-/* On success - returns 0. */
-/* */
-/******************************************************************************/
-void setup(void)
+static void create_queue_sig(void)
{
- /* Capture signals if any */
- act.sa_handler = sighandler;
- sigfillset(&act.sa_mask);
- sigaction(SIGINT, &act, NULL);
- /* Create temporary directories */
- TEST_PAUSE;
- tst_tmpdir();
+ create_queue();
+ pid = create_sig_proc(SIGINT, 40, 200000);
}
-/*
- * Macros
- */
-#define SYSCALL_NAME "mq_timedreceive"
-
-enum test_type {
- NORMAL,
- FD_NONE,
- FD_NOT_EXIST,
- FD_FILE,
- INVALID_MSG_LEN,
- EMPTY_QUEUE,
- SEND_SIGINT,
-};
+static void open_fd(void)
+{
+ fd = fd_root;
+}
-/*
- * Data Structure
- */
-struct test_case {
- int ttype;
- int non_block;
- int len;
- unsigned prio;
- time_t sec;
- long nsec;
- int ret;
- int err;
-};
+static void send_msg(int fd, int len, int prio)
+{
+ char smsg[MAX_MSGSIZE];
+ int i;
-#define MAX_MSG 10
-#define MAX_MSGSIZE 8192
+ for (i = 0; i < len; i++)
+ smsg[i] = i;
-/* Test cases
- *
- * test status of errors on man page
- *
- * EAGAIN v (would block)
- * EBADF v (not a valid descriptor)
- * EINTR v (interrupted by a signal)
- * EINVAL v (invalid timeout value)
- * ETIMEDOUT v (not block and timeout occured)
- * EMSGSIZE v ('msg_len' is less than the message size of the queue)
- * EBADMSG can't check because this error never occur
- */
-static struct test_case tcase[] = {
- { // case00
- .ttype = NORMAL,
- .len = 0, // also success when size equals zero
- .ret = 0,
- .err = 0,
- },
- { // case01
- .ttype = NORMAL,
- .len = 1,
- .ret = 0,
- .err = 0,
- },
- { // case02
- .ttype = NORMAL,
- .len = MAX_MSGSIZE,
- .ret = 0,
- .err = 0,
- },
- { // case03
- .ttype = NORMAL,
- .len = 1,
- .prio = 32767, // max priority
- .ret = 0,
- .err = 0,
- },
- { // case04
- .ttype = INVALID_MSG_LEN,
- .len = 0,
- .ret = -1,
- .err = EMSGSIZE,
- },
- { // case05
- .ttype = FD_NONE,
- .len = 0,
- .ret = -1,
- .err = EBADF,
- },
- { // case06
- .ttype = FD_NOT_EXIST,
- .len = 0,
- .ret = -1,
- .err = EBADF,
- },
- { // case07
- .ttype = FD_FILE,
- .len = 0,
- .ret = -1,
- .err = EBADF,
- },
- { // case08
- .ttype = EMPTY_QUEUE,
- .non_block = 1,
- .len = 16,
- .ret = -1,
- .err = EAGAIN,
- },
- { // case09
- .ttype = EMPTY_QUEUE,
- .len = 16,
- .sec = -1,
- .nsec = 0,
- .ret = -1,
- .err = EINVAL,
- },
- { // case10
- .ttype = EMPTY_QUEUE,
- .len = 16,
- .sec = 0,
- .nsec = -1,
- .ret = -1,
- .err = EINVAL,
- },
- { // case11
- .ttype = EMPTY_QUEUE,
- .len = 16,
- .sec = 0,
- .nsec = 1000000000,
- .ret = -1,
- .err = EINVAL,
- },
- { // case12
- .ttype = EMPTY_QUEUE,
- .len = 16,
- .sec = 0,
- .nsec = 999999999,
- .ret = -1,
- .err = ETIMEDOUT,
- },
- { // case13
- .ttype = SEND_SIGINT,
- .len = 16,
- .sec = 3,
- .nsec = 0,
- .ret = -1,
- .err = EINTR,
- },
-};
+ if (mq_timedsend(fd, smsg, len, prio,
+ &((struct timespec){0})) < 0)
+ tst_brk(TBROK | TERRNO, "mq_timedsend failed");
+}
-#define MEM_LENGTH (4 * 1024 * 1024)
-/*
- * do_test()
- *
- * Input : TestCase Data
- * Return : RESULT_OK(0), RESULT_NG(1)
- *
- */
+static void unlink_queue(void)
+{
+ if (fd > 0)
+ SAFE_CLOSE(fd);
+
+ mq_unlink(QUEUE_NAME);
+}
-static int do_test(struct test_case *tc)
+static void do_test(unsigned int i)
{
- int sys_ret;
- int sys_errno;
- int result = RESULT_OK;
- int oflag;
- int i, rc, cmp_ok = 1, fd = -1;
- char smsg[MAX_MSGSIZE], rmsg[MAX_MSGSIZE];
- struct timespec ts = { 0, 0 };
- pid_t pid = 0;
+ struct test_case *tc = &tcase[i];
+
+ char rmsg[MAX_MSGSIZE];
unsigned prio;
size_t msg_len;
+ fd = -1;
+ pid = 0;
+
/*
* When test ended with SIGTERM etc, mq descriptor is left remains.
* So we delete it first.
*/
- TEST(mq_unlink(QUEUE_NAME));
-
- switch (tc->ttype) {
- case FD_NOT_EXIST:
- fd = INT_MAX - 1;
- /* fallthrough */
- case FD_NONE:
- break;
- case FD_FILE:
- TEST(fd = open("/", O_RDONLY));
- if (TEST_RETURN < 0) {
- tst_resm(TFAIL | TTERRNO, "can't open \"/\".");
- result = 1;
- goto EXIT;
- }
- break;
- default:
- /*
- * Open message queue
- */
- oflag = O_CREAT | O_EXCL | O_RDWR;
- if (tc->non_block)
- oflag |= O_NONBLOCK;
-
- TEST(fd = mq_open(QUEUE_NAME, oflag, S_IRWXU, NULL));
- if (TEST_RETURN < 0) {
- tst_resm(TFAIL | TTERRNO, "mq_open failed");
- result = 1;
- goto EXIT;
- }
+ mq_unlink(QUEUE_NAME);
- if (tc->ttype == SEND_SIGINT) {
- pid = create_sig_proc(200000, SIGINT, UINT_MAX);
- if (pid < 0) {
- result = 1;
- goto EXIT;
- }
- }
- break;
- }
+ if (tc->fd)
+ fd = tc->fd;
- /*
- * Prepare send message
- */
- for (i = 0; i < tc->len; i++)
- smsg[i] = i;
+ if (tc->setup)
+ tc->setup();
- /*
- * Send message
- */
- switch (tc->ttype) {
- case EMPTY_QUEUE:
- case SEND_SIGINT:
- case FD_NONE:
- case FD_NOT_EXIST:
- case FD_FILE:
- break;
- default:
- TEST(rc = mq_timedsend(fd, smsg, tc->len, tc->prio, &ts));
- if (TEST_RETURN < 0) {
- tst_resm(TFAIL | TTERRNO, "mq_timedsend failed");
- result = 1;
- goto EXIT;
- }
- break;
- }
+ if (tc->send)
+ send_msg(fd, tc->len, tc->prio);
- /*
- * Set the message length and timeout value
- */
msg_len = MAX_MSGSIZE;
- if (tc->ttype == INVALID_MSG_LEN)
+ if (tc->invalid_msg)
msg_len -= 1;
- ts.tv_sec = tc->sec;
- ts.tv_nsec = tc->nsec;
- if (tc->sec >= 0 || tc->nsec != 0)
- ts.tv_sec += time(NULL);
- /*
- * Execute system call
- */
- errno = 0;
- TEST(sys_ret = mq_timedreceive(fd, rmsg, msg_len, &prio, &ts));
- sys_errno = errno;
- if (sys_ret < 0)
- goto TEST_END;
+ if (tc->rq.tv_sec >= 0 || tc->rq.tv_nsec != 0)
+ tc->rq.tv_sec += time(NULL);
- /*
- * Compare received message
- */
- if (sys_ret != tc->len || tc->prio != prio)
- cmp_ok = 0;
- else {
- for (i = 0; i < tc->len; i++)
- if (rmsg[i] != smsg[i]) {
- cmp_ok = 0;
- break;
- }
- }
+ /* test */
+ TEST(mq_timedreceive(fd, rmsg, msg_len, &prio, &tc->rq));
-TEST_END:
- /*
- * Check results
- */
- result |= (sys_errno != tc->err) || !cmp_ok;
- PRINT_RESULT_CMP(0, tc->ret == 0 ? tc->len : tc->ret, tc->err, sys_ret,
- sys_errno, cmp_ok);
-
-EXIT:
- if (fd >= 0) {
- TEST(close(fd));
- TEST(mq_unlink(QUEUE_NAME));
- }
- if (pid > 0) {
- int st;
- TEST(kill(pid, SIGTERM));
- TEST(wait(&st));
+ /* cleanup */
+ if (tc->cleanup)
+ tc->cleanup();
+
+ if (pid) {
+ SAFE_KILL(pid, SIGTERM);
+ SAFE_WAIT(NULL);
}
- return result;
-}
-/*
- * main()
- */
+ /* result */
+ if (TEST_RETURN != -1) {
+ if (TEST_RETURN != tc->len) {
+ tst_res(TFAIL | TTERRNO, "mq_timedreceive wrong msg_len returned %ld, expected %d",
+ TEST_RETURN, tc->len);
+ return;
+ }
-int main(int ac, char **av)
-{
- int result = RESULT_OK;
- int i;
- int lc;
-
- tst_parse_opts(ac, av, NULL, NULL);
-
- setup();
-
- for (lc = 0; TEST_LOOPING(lc); ++lc) {
- tst_count = 0;
- for (testno = 0; testno < TST_TOTAL; ++testno) {
-
- /*
- * Execute test
- */
- for (i = 0; i < (int)ARRAY_SIZE(tcase); i++) {
- int ret;
- tst_resm(TINFO, "(case%02d) START", i);
- ret = do_test(&tcase[i]);
- tst_resm(TINFO, "(case%02d) END => %s",
- i, (ret == 0) ? "OK" : "NG");
- result |= ret;
- }
-
- /*
- * Check results
- */
- switch (result) {
- case RESULT_OK:
- tst_resm(TPASS,
- "mq_timedreceive call succeeded");
- break;
-
- default:
- tst_brkm(TFAIL | TTERRNO, cleanup,
- "mq_timedreceive failed");
- }
+ if (tc->prio != prio) {
+ tst_res(TFAIL | TTERRNO, "mq_timedreceive wrong prio returned %d, expected %d",
+ prio, tc->prio);
+ return;
}
}
- cleanup();
- tst_exit();
+
+ if (TEST_ERRNO != tc->err || (tc->ret < 0 && TEST_RETURN != tc->ret)
+ || (tc->ret >= 0 && TEST_RETURN < 0))
+ tst_res(TFAIL | TTERRNO, "%d returned: %ld, expected: %d, expected errno: %s (%d)",
+ i, TEST_RETURN, tc->ret, tst_strerrno(tc->err), tc->err);
+ else
+ tst_res(TPASS | TTERRNO, "%d returned: %ld", i, TEST_RETURN);
}
+
+static struct tst_test test = {
+ .tid = "mq_timedreceive01",
+ .tcnt = ARRAY_SIZE(tcase),
+ .test = do_test,
+ .setup = setup,
+ .cleanup = cleanup,
+ .forks_child = 1,
+};
--
2.12.0
^ permalink raw reply related [flat|nested] 7+ messages in thread* [LTP] [PATCH v4 2/3] lib: SAFE_MQ_OPEN() macro
2017-03-08 14:21 [LTP] [PATCH v4 1/3] syscalls/mq_timedreceive: convert to new API Petr Vorel
@ 2017-03-08 14:21 ` Petr Vorel
2017-03-10 14:50 ` Cyril Hrubis
2017-03-08 14:21 ` [LTP] [PATCH v4 3/3] syscalls: use " Petr Vorel
2017-03-10 14:46 ` [LTP] [PATCH v4 1/3] syscalls/mq_timedreceive: convert to new API Cyril Hrubis
2 siblings, 1 reply; 7+ messages in thread
From: Petr Vorel @ 2017-03-08 14:21 UTC (permalink / raw)
To: ltp
Signed-off-by: Petr Vorel <pvorel@suse.cz>
---
include/tst_safe_posix_ipc.h | 33 +++++++++++++++++++++++++++++++++
lib/tst_safe_posix_ipc.c | 41 +++++++++++++++++++++++++++++++++++++++++
2 files changed, 74 insertions(+)
create mode 100644 include/tst_safe_posix_ipc.h
create mode 100644 lib/tst_safe_posix_ipc.c
diff --git a/include/tst_safe_posix_ipc.h b/include/tst_safe_posix_ipc.h
new file mode 100644
index 000000000..3802e2783
--- /dev/null
+++ b/include/tst_safe_posix_ipc.h
@@ -0,0 +1,33 @@
+/*
+ * Copyright (C) 2017 Petr Vorel pvorel@suse.cz
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of version 2 of the GNU General Public License as
+ * published by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it would be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+ *
+ * Further, this software is distributed without any warranty that it is
+ * free of the rightful claim of any third person regarding infringement
+ * or the like. Any license provided herein, whether implied or
+ * otherwise, applies only to this software file. Patent licenses, if
+ * any, provided herein do not apply to combinations of this program with
+ * other software, or any other product whatsoever.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ */
+
+#ifndef TST_SAFE_POSIX_IPC_H__
+#define TST_SAFE_POSIX_IPC_H__
+
+#define SAFE_MQ_OPEN(pathname, oflags, ...) \
+ safe_mq_open(__FILE__, __LINE__, (pathname), (oflags), ##__VA_ARGS__)
+
+int safe_mq_open(const char *file, const int lineno, const char *pathname,
+ int oflags, ...);
+
+#endif /* TST_SAFE_POSIX_IPC_H__ */
diff --git a/lib/tst_safe_posix_ipc.c b/lib/tst_safe_posix_ipc.c
new file mode 100644
index 000000000..5f9fda6ae
--- /dev/null
+++ b/lib/tst_safe_posix_ipc.c
@@ -0,0 +1,41 @@
+#include <mqueue.h>
+#include <stdarg.h>
+
+#define TST_NO_DEFAULT_MAIN
+#include "tst_test.h"
+#include "tst_safe_posix_ipc.h"
+
+int safe_mq_open(const char *file, const int lineno, const char *pathname,
+ int oflags, ...)
+{
+ va_list ap;
+ int rval;
+ mode_t mode;
+ struct mq_attr *attr;
+
+ mode = 0;
+ attr = NULL;
+
+ va_start(ap, oflags);
+
+ /* Android's NDK's mode_t is smaller than an int, which results in
+ * SIGILL here when passing the mode_t type.
+ */
+#ifndef ANDROID
+ mode = va_arg(ap, mode_t);
+#else
+ mode = va_arg(ap, int);
+#endif
+
+ attr = va_arg(ap, struct mq_attr *);
+
+ va_end(ap);
+
+ rval = mq_open(pathname, oflags, mode, attr);
+ if (rval == -1) {
+ tst_brk(TBROK | TERRNO, "%s:%d: mq_open(%s,%d,0%o,%p) failed",
+ file, lineno, pathname, oflags, mode, attr);
+ }
+
+ return rval;
+}
--
2.12.0
^ permalink raw reply related [flat|nested] 7+ messages in thread* [LTP] [PATCH v4 3/3] syscalls: use SAFE_MQ_OPEN() macro
2017-03-08 14:21 [LTP] [PATCH v4 1/3] syscalls/mq_timedreceive: convert to new API Petr Vorel
2017-03-08 14:21 ` [LTP] [PATCH v4 2/3] lib: SAFE_MQ_OPEN() macro Petr Vorel
@ 2017-03-08 14:21 ` Petr Vorel
2017-03-10 14:46 ` [LTP] [PATCH v4 1/3] syscalls/mq_timedreceive: convert to new API Cyril Hrubis
2 siblings, 0 replies; 7+ messages in thread
From: Petr Vorel @ 2017-03-08 14:21 UTC (permalink / raw)
To: ltp
Signed-off-by: Petr Vorel <pvorel@suse.cz>
---
testcases/kernel/syscalls/mq_notify/mq_notify01.c | 7 ++-----
testcases/kernel/syscalls/mq_open/mq_open01.c | 9 +++------
testcases/kernel/syscalls/mq_timedreceive/mq_timedreceive01.c | 11 ++++-------
testcases/kernel/syscalls/mq_unlink/mq_unlink01.c | 7 ++-----
4 files changed, 11 insertions(+), 23 deletions(-)
diff --git a/testcases/kernel/syscalls/mq_notify/mq_notify01.c b/testcases/kernel/syscalls/mq_notify/mq_notify01.c
index 68fabffcf..99ec2edcc 100644
--- a/testcases/kernel/syscalls/mq_notify/mq_notify01.c
+++ b/testcases/kernel/syscalls/mq_notify/mq_notify01.c
@@ -28,6 +28,7 @@
#include <fcntl.h>
#include "tst_test.h"
+#include "tst_safe_posix_ipc.h"
#define MAX_MSGSIZE 8192
#define MSG_SIZE 16
@@ -162,11 +163,7 @@ static void do_test(unsigned int i)
}
break;
default:
- fd = mq_open(QUEUE_NAME, O_CREAT | O_EXCL | O_RDWR, S_IRWXU, NULL);
- if (fd < 0) {
- tst_res(TBROK | TERRNO, "mq_open failed");
- goto CLEANUP;
- }
+ fd = SAFE_MQ_OPEN(QUEUE_NAME, O_CREAT | O_EXCL | O_RDWR, S_IRWXU, NULL);
}
ev.sigev_notify = tc->notify;
diff --git a/testcases/kernel/syscalls/mq_open/mq_open01.c b/testcases/kernel/syscalls/mq_open/mq_open01.c
index 6324d921d..c2955d861 100644
--- a/testcases/kernel/syscalls/mq_open/mq_open01.c
+++ b/testcases/kernel/syscalls/mq_open/mq_open01.c
@@ -25,6 +25,7 @@
#include <pwd.h>
#include "tst_safe_file_ops.h"
+#include "tst_safe_posix_ipc.h"
#include "tst_test.h"
#define QUEUE_NAME "/test_mqueue"
@@ -155,9 +156,7 @@ static struct test_case tcase[] = {
static void create_queue(void)
{
- fd2 = mq_open(QUEUE_NAME, O_CREAT | O_EXCL | O_RDWR, S_IRWXU, NULL);
- if (fd2 == -1)
- tst_brk(TBROK | TERRNO, "mq_open(" QUEUE_NAME ") failed");
+ fd2 = SAFE_MQ_OPEN(QUEUE_NAME, O_CREAT | O_EXCL | O_RDWR, S_IRWXU, NULL);
SAFE_SETEUID(pw->pw_uid);
}
@@ -209,9 +208,7 @@ static void setup(void)
pw = SAFE_GETPWNAM("nobody");
SAFE_GETRLIMIT(RLIMIT_NOFILE, &rlim);
- fd3 = mq_open(QUEUE_INIT, O_CREAT | O_EXCL | O_RDWR, S_IRWXU, NULL);
- if (fd3 == -1)
- tst_brk(TBROK | TERRNO, "mq_open(%s) failed", QUEUE_INIT);
+ fd3 = SAFE_MQ_OPEN(QUEUE_INIT, O_CREAT | O_EXCL | O_RDWR, S_IRWXU, NULL);
}
static void cleanup(void)
diff --git a/testcases/kernel/syscalls/mq_timedreceive/mq_timedreceive01.c b/testcases/kernel/syscalls/mq_timedreceive/mq_timedreceive01.c
index ab46bc6b0..c1ffd0eb1 100644
--- a/testcases/kernel/syscalls/mq_timedreceive/mq_timedreceive01.c
+++ b/testcases/kernel/syscalls/mq_timedreceive/mq_timedreceive01.c
@@ -25,6 +25,7 @@
#include <mqueue.h>
#include "tst_sig_proc.h"
+#include "tst_safe_posix_ipc.h"
#include "tst_test.h"
static struct sigaction act;
@@ -179,17 +180,13 @@ static void cleanup(void)
static void create_queue(void)
{
- fd = mq_open(QUEUE_NAME, O_CREAT | O_EXCL | O_RDWR, S_IRWXU, NULL);
- if (fd == -1)
- tst_brk(TBROK | TERRNO, "mq_open(" QUEUE_NAME ") failed");
+ fd = SAFE_MQ_OPEN(QUEUE_NAME, O_CREAT | O_EXCL | O_RDWR, S_IRWXU, NULL);
}
static void create_queue_nonblock(void)
{
- fd = mq_open(QUEUE_NAME, O_CREAT | O_EXCL | O_RDWR | O_NONBLOCK, S_IRWXU,
- NULL);
- if (fd == -1)
- tst_brk(TBROK | TERRNO, "mq_open(" QUEUE_NAME ") failed");
+ fd = SAFE_MQ_OPEN(QUEUE_NAME, O_CREAT | O_EXCL | O_RDWR | O_NONBLOCK,
+ S_IRWXU, NULL);
}
static void create_queue_sig(void)
diff --git a/testcases/kernel/syscalls/mq_unlink/mq_unlink01.c b/testcases/kernel/syscalls/mq_unlink/mq_unlink01.c
index 9e0a2a7e3..03ce3f8a0 100644
--- a/testcases/kernel/syscalls/mq_unlink/mq_unlink01.c
+++ b/testcases/kernel/syscalls/mq_unlink/mq_unlink01.c
@@ -25,6 +25,7 @@
#include <mqueue.h>
#include "tst_test.h"
+#include "tst_safe_posix_ipc.h"
#define QUEUE_NAME "/test_mqueue"
@@ -94,11 +95,7 @@ static void do_test(unsigned int i)
mq_unlink(QUEUE_NAME);
/* prepare */
- fd = mq_open(QUEUE_NAME, O_CREAT | O_EXCL | O_RDWR, S_IRWXU, NULL);
- if (fd == -1) {
- tst_res(TBROK | TERRNO, "mq_open failed");
- goto EXIT;
- }
+ fd = SAFE_MQ_OPEN(QUEUE_NAME, O_CREAT | O_EXCL | O_RDWR, S_IRWXU, NULL);
if (tc->as_nobody && seteuid(pw->pw_uid)) {
tst_res(TBROK | TERRNO, "seteuid failed");
--
2.12.0
^ permalink raw reply related [flat|nested] 7+ messages in thread* [LTP] [PATCH v4 1/3] syscalls/mq_timedreceive: convert to new API
2017-03-08 14:21 [LTP] [PATCH v4 1/3] syscalls/mq_timedreceive: convert to new API Petr Vorel
2017-03-08 14:21 ` [LTP] [PATCH v4 2/3] lib: SAFE_MQ_OPEN() macro Petr Vorel
2017-03-08 14:21 ` [LTP] [PATCH v4 3/3] syscalls: use " Petr Vorel
@ 2017-03-10 14:46 ` Cyril Hrubis
2017-03-10 15:08 ` Petr Vorel
2 siblings, 1 reply; 7+ messages in thread
From: Cyril Hrubis @ 2017-03-10 14:46 UTC (permalink / raw)
To: ltp
Hi!
Pushed with following diff, thanks.
(90% of the changes fixes the -i looping argument as we have to close
file descriptors, initialize timeouts correctly on each iteration, etc.)
diff --git a/testcases/kernel/syscalls/mq_timedreceive/mq_timedreceive01.c b/testcases/kernel/syscalls/mq_timedreceive/mq_timedreceive01.c
index ab46bc6..cd2282d 100644
--- a/testcases/kernel/syscalls/mq_timedreceive/mq_timedreceive01.c
+++ b/testcases/kernel/syscalls/mq_timedreceive/mq_timedreceive01.c
@@ -30,11 +30,13 @@
static struct sigaction act;
static pid_t pid;
static int fd, fd_root;
+static struct timespec timeout_ts;
+static struct timespec eintr_ts;
struct test_case {
int len;
unsigned prio;
- struct timespec rq;
+ struct timespec *rq;
int fd;
int invalid_msg;
int send;
@@ -51,12 +53,15 @@ struct test_case {
static void create_queue(void);
static void create_queue_nonblock(void);
static void create_queue_sig(void);
+static void create_queue_timeout(void);
static void open_fd(void);
static void unlink_queue(void);
+static void unlink_queue_sig(void);
-static struct test_case tcase[] = {
+static const struct test_case tcase[] = {
{
.setup = create_queue,
+ .cleanup = unlink_queue,
.send = 1,
.len = 0,
.ret = 0,
@@ -64,6 +69,7 @@ static struct test_case tcase[] = {
},
{
.setup = create_queue,
+ .cleanup = unlink_queue,
.send = 1,
.len = 1,
.ret = 0,
@@ -71,6 +77,7 @@ static struct test_case tcase[] = {
},
{
.setup = create_queue,
+ .cleanup = unlink_queue,
.send = 1,
.len = MAX_MSGSIZE,
.ret = 0,
@@ -78,6 +85,7 @@ static struct test_case tcase[] = {
},
{
.setup = create_queue,
+ .cleanup = unlink_queue,
.send = 1,
.len = 1,
.prio = 32767, /* max priority */
@@ -86,6 +94,7 @@ static struct test_case tcase[] = {
},
{
.setup = create_queue,
+ .cleanup = unlink_queue,
.invalid_msg = 1,
.send = 1,
.len = 0,
@@ -119,7 +128,7 @@ static struct test_case tcase[] = {
},
{
.len = 16,
- .rq = (struct timespec) {.tv_sec = -1, .tv_nsec = 0},
+ .rq = &(struct timespec) {.tv_sec = -1, .tv_nsec = 0},
.ret = -1,
.err = EINVAL,
.setup = create_queue,
@@ -127,7 +136,7 @@ static struct test_case tcase[] = {
},
{
.len = 16,
- .rq = (struct timespec) {.tv_sec = 0, .tv_nsec = -1},
+ .rq = &(struct timespec) {.tv_sec = 0, .tv_nsec = -1},
.ret = -1,
.err = EINVAL,
.setup = create_queue,
@@ -135,7 +144,7 @@ static struct test_case tcase[] = {
},
{
.len = 16,
- .rq = (struct timespec) {.tv_sec = 0, .tv_nsec = 1000000000},
+ .rq = &(struct timespec) {.tv_sec = 0, .tv_nsec = 1000000000},
.ret = -1,
.err = EINVAL,
.setup = create_queue,
@@ -143,19 +152,19 @@ static struct test_case tcase[] = {
},
{
.len = 16,
- .rq = (struct timespec) {.tv_sec = 0, .tv_nsec = 999999999},
.ret = -1,
+ .rq = &timeout_ts,
.err = ETIMEDOUT,
- .setup = create_queue,
+ .setup = create_queue_timeout,
.cleanup = unlink_queue,
},
{
.len = 16,
- .rq = (struct timespec) {.tv_sec = 3, .tv_nsec = 0},
+ .rq = &eintr_ts,
.ret = -1,
.err = EINTR,
.setup = create_queue_sig,
- .cleanup = unlink_queue,
+ .cleanup = unlink_queue_sig,
},
};
@@ -175,6 +184,9 @@ static void cleanup(void)
{
if (fd > 0)
SAFE_CLOSE(fd);
+
+ if (fd_root > 0)
+ SAFE_CLOSE(fd_root);
}
static void create_queue(void)
@@ -194,10 +206,23 @@ static void create_queue_nonblock(void)
static void create_queue_sig(void)
{
+ clock_gettime(CLOCK_REALTIME, &eintr_ts);
+ eintr_ts.tv_sec += 3;
+
create_queue();
pid = create_sig_proc(SIGINT, 40, 200000);
}
+static void create_queue_timeout(void)
+{
+ clock_gettime(CLOCK_REALTIME, &timeout_ts);
+ timeout_ts.tv_nsec += 50000000;
+ timeout_ts.tv_sec += timeout_ts.tv_nsec / 1000000000;
+ timeout_ts.tv_nsec %= 1000000000;
+
+ create_queue();
+}
+
static void open_fd(void)
{
fd = fd_root;
@@ -224,16 +249,20 @@ static void unlink_queue(void)
mq_unlink(QUEUE_NAME);
}
-static void do_test(unsigned int i)
+static void unlink_queue_sig(void)
{
- struct test_case *tc = &tcase[i];
+ SAFE_KILL(pid, SIGTERM);
+ SAFE_WAIT(NULL);
+
+ unlink_queue();
+}
+static void do_test(unsigned int i)
+{
+ const struct test_case *tc = &tcase[i];
char rmsg[MAX_MSGSIZE];
unsigned prio;
- size_t msg_len;
-
- fd = -1;
- pid = 0;
+ size_t msg_len = MAX_MSGSIZE;
/*
* When test ended with SIGTERM etc, mq descriptor is left remains.
@@ -250,46 +279,39 @@ static void do_test(unsigned int i)
if (tc->send)
send_msg(fd, tc->len, tc->prio);
- msg_len = MAX_MSGSIZE;
if (tc->invalid_msg)
msg_len -= 1;
- if (tc->rq.tv_sec >= 0 || tc->rq.tv_nsec != 0)
- tc->rq.tv_sec += time(NULL);
+ TEST(mq_timedreceive(fd, rmsg, msg_len, &prio, tc->rq));
- /* test */
- TEST(mq_timedreceive(fd, rmsg, msg_len, &prio, &tc->rq));
-
- /* cleanup */
if (tc->cleanup)
tc->cleanup();
- if (pid) {
- SAFE_KILL(pid, SIGTERM);
- SAFE_WAIT(NULL);
+ if (TEST_RETURN < 0) {
+ if (TEST_ERRNO != tc->err) {
+ tst_res(TFAIL | TTERRNO,
+ "mq_timedreceive failed unexpectedly, expected %s",
+ tst_strerrno(tc->err));
+ } else {
+ tst_res(TPASS | TTERRNO, "mq_timedreceive failed expectedly");
+ }
+ return;
}
- /* result */
- if (TEST_RETURN != -1) {
- if (TEST_RETURN != tc->len) {
- tst_res(TFAIL | TTERRNO, "mq_timedreceive wrong msg_len returned %ld, expected %d",
- TEST_RETURN, tc->len);
- return;
- }
- if (tc->prio != prio) {
- tst_res(TFAIL | TTERRNO, "mq_timedreceive wrong prio returned %d, expected %d",
- prio, tc->prio);
- return;
- }
+ if (TEST_RETURN != tc->len) {
+ tst_res(TFAIL | TTERRNO, "mq_timedreceive wrong msg_len returned %ld, expected %d",
+ TEST_RETURN, tc->len);
+ return;
+ }
+
+ if (tc->prio != prio) {
+ tst_res(TFAIL | TTERRNO, "mq_timedreceive wrong prio returned %d, expected %d",
+ prio, tc->prio);
+ return;
}
- if (TEST_ERRNO != tc->err || (tc->ret < 0 && TEST_RETURN != tc->ret)
- || (tc->ret >= 0 && TEST_RETURN < 0))
- tst_res(TFAIL | TTERRNO, "%d returned: %ld, expected: %d, expected errno: %s (%d)",
- i, TEST_RETURN, tc->ret, tst_strerrno(tc->err), tc->err);
- else
- tst_res(TPASS | TTERRNO, "%d returned: %ld", i, TEST_RETURN);
+ tst_res(TPASS, "mq_timedreceive returned %ld prio %u", TEST_RETURN, prio);
}
static struct tst_test test = {
--
Cyril Hrubis
chrubis@suse.cz
^ permalink raw reply related [flat|nested] 7+ messages in thread* [LTP] [PATCH v4 1/3] syscalls/mq_timedreceive: convert to new API
2017-03-10 14:46 ` [LTP] [PATCH v4 1/3] syscalls/mq_timedreceive: convert to new API Cyril Hrubis
@ 2017-03-10 15:08 ` Petr Vorel
2017-03-10 15:09 ` Cyril Hrubis
0 siblings, 1 reply; 7+ messages in thread
From: Petr Vorel @ 2017-03-10 15:08 UTC (permalink / raw)
To: ltp
Hi!
> Pushed with following diff, thanks.
Oh, so many fixes needed, I'm sorry.
> (90% of the changes fixes the -i looping argument as we have to close
> file descriptors, initialize timeouts correctly on each iteration, etc.)
Good tip for testing, thanks!
Kind regards,
Petr
^ permalink raw reply [flat|nested] 7+ messages in thread
* [LTP] [PATCH v4 1/3] syscalls/mq_timedreceive: convert to new API
2017-03-10 15:08 ` Petr Vorel
@ 2017-03-10 15:09 ` Cyril Hrubis
0 siblings, 0 replies; 7+ messages in thread
From: Cyril Hrubis @ 2017-03-10 15:09 UTC (permalink / raw)
To: ltp
Hi!
> > (90% of the changes fixes the -i looping argument as we have to close
> > file descriptors, initialize timeouts correctly on each iteration, etc.)
> Good tip for testing, thanks!
I usually run the test with -i at least 100 which tends to catch various
problems...
--
Cyril Hrubis
chrubis@suse.cz
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2017-03-10 15:09 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-03-08 14:21 [LTP] [PATCH v4 1/3] syscalls/mq_timedreceive: convert to new API Petr Vorel
2017-03-08 14:21 ` [LTP] [PATCH v4 2/3] lib: SAFE_MQ_OPEN() macro Petr Vorel
2017-03-10 14:50 ` Cyril Hrubis
2017-03-08 14:21 ` [LTP] [PATCH v4 3/3] syscalls: use " Petr Vorel
2017-03-10 14:46 ` [LTP] [PATCH v4 1/3] syscalls/mq_timedreceive: convert to new API Cyril Hrubis
2017-03-10 15:08 ` Petr Vorel
2017-03-10 15:09 ` Cyril Hrubis
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox