unplugged-vendor/external/ltp/testcases/kernel/syscalls/pipe2/pipe2_01.c

187 lines
9.4 KiB
C
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/******************************************************************************/
/* */
/* Copyright (c) Ulrich Drepper <drepper@redhat.com> */
/* Copyright (c) International Business Machines Corp., 2009 */
/* */
/* 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: pipe2_01.c */
/* */
/* Description: This Program tests the new system call introduced in 2.6.27. */
/* Ulrich´s comment as in: */
/* http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commit;h=ed8cae8ba01348bfd83333f4648dd807b04d7f08 */
/* says: */
/* This patch introduces the new syscall pipe2 which is like pipe but it also */
/* takes an additional parameter which takes a flag value. This patch */
/* implements the handling of O_CLOEXEC for the flag. I did not add support */
/* for the new syscall for the architectures which have a special sys_pipe */
/* implementation. I think the maintainers of those archs have the chance to */
/* go with the unified implementation but that's up to them. */
/* */
/* The implementation introduces do_pipe_flags. I did that instead of */
/* changing all callers of do_pipe because some of the callers are written in */
/* assembler. I would probably screw up changing the assembly code. To avoid */
/* breaking code do_pipe is now a small wrapper around do_pipe_flags. Once */
/* all callers are changed over to do_pipe_flags the old do_pipe function can */
/* be removed. */
/* The following test must be adjusted for architectures other than x86 and */
/* x86-64 and in case the syscall numbers changed. */
/* */
/* Usage: <for command-line> */
/* pipe2_01 [-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: pipe2_01 */
/* */
/* Author: Ulrich Drepper <drepper@redhat.com> */
/* */
/* History: Created - Jan 13 2009 - Ulrich Drepper <drepper@redhat.com> */
/* Ported to LTP */
/* - Jan 13 2009 - Subrata <subrata@linux.vnet.ibm.com> */
/******************************************************************************/
#include <fcntl.h>
#include <stdio.h>
#include <unistd.h>
#include <sys/syscall.h>
#include <errno.h>
#include "test.h"
#include "lapi/fcntl.h"
#include "lapi/syscalls.h"
char *TCID = "pipe2_01";
int testno;
int TST_TOTAL = 1;
/* 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)
{
tst_rmdir();
}
/* 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)
{
/* Capture signals if any */
/* Create temporary directories */
TEST_PAUSE;
tst_tmpdir();
}
int main(int argc, char *argv[])
{
int fd[2], i, coe;
int lc;
tst_parse_opts(argc, argv, NULL, NULL);
if ((tst_kvercmp(2, 6, 27)) < 0) {
tst_brkm(TCONF,
NULL,
"This test can only run on kernels that are 2.6.27 and higher");
}
setup();
for (lc = 0; TEST_LOOPING(lc); ++lc) {
tst_count = 0;
for (testno = 0; testno < TST_TOTAL; ++testno) {
if (ltp_syscall(__NR_pipe2, fd, 0) != 0) {
tst_brkm(TFAIL, cleanup, "pipe2(0) failed");
}
for (i = 0; i < 2; ++i) {
coe = fcntl(fd[i], F_GETFD);
if (coe == -1) {
tst_brkm(TBROK, cleanup,
"fcntl failed");
}
if (coe & FD_CLOEXEC) {
tst_brkm(TFAIL,
cleanup, "pipe2(0) set close-on-exit for fd[%d]",
i);
}
}
close(fd[0]);
close(fd[1]);
if (ltp_syscall(__NR_pipe2, fd, O_CLOEXEC) != 0) {
tst_brkm(TFAIL, cleanup,
"pipe2(O_CLOEXEC) failed");
}
for (i = 0; i < 2; ++i) {
coe = fcntl(fd[i], F_GETFD);
if (coe == -1) {
tst_brkm(TBROK, cleanup,
"fcntl failed");
}
if ((coe & FD_CLOEXEC) == 0) {
tst_brkm(TFAIL,
cleanup, "pipe2(O_CLOEXEC) does not set close-on-exit for fd[%d]",
i);
}
}
close(fd[0]);
close(fd[1]);
tst_resm(TPASS, "pipe2(O_CLOEXEC) PASSED");
cleanup();
}
}
tst_exit();
}