1 1.2 christos /* $NetBSD: t_pipe.c,v 1.2 2017/01/13 21:30:41 christos Exp $ */ 2 1.1 jmmv 3 1.1 jmmv /*- 4 1.1 jmmv * Copyright (c) 2002 The NetBSD Foundation, Inc. 5 1.1 jmmv * All rights reserved. 6 1.1 jmmv * 7 1.1 jmmv * This code is derived from software contributed to The NetBSD Foundation 8 1.1 jmmv * by Luke Mewburn and Jaromir Dolecek. 9 1.1 jmmv * 10 1.1 jmmv * Redistribution and use in source and binary forms, with or without 11 1.1 jmmv * modification, are permitted provided that the following conditions 12 1.1 jmmv * are met: 13 1.1 jmmv * 1. Redistributions of source code must retain the above copyright 14 1.1 jmmv * notice, this list of conditions and the following disclaimer. 15 1.1 jmmv * 2. Redistributions in binary form must reproduce the above copyright 16 1.1 jmmv * notice, this list of conditions and the following disclaimer in the 17 1.1 jmmv * documentation and/or other materials provided with the distribution. 18 1.1 jmmv * 19 1.1 jmmv * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 20 1.1 jmmv * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 21 1.1 jmmv * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22 1.1 jmmv * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 23 1.1 jmmv * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24 1.1 jmmv * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25 1.1 jmmv * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26 1.1 jmmv * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27 1.1 jmmv * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28 1.1 jmmv * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29 1.1 jmmv * POSSIBILITY OF SUCH DAMAGE. 30 1.1 jmmv */ 31 1.1 jmmv 32 1.1 jmmv #include <sys/cdefs.h> 33 1.1 jmmv __COPYRIGHT("@(#) Copyright (c) 2008\ 34 1.1 jmmv The NetBSD Foundation, inc. All rights reserved."); 35 1.2 christos __RCSID("$NetBSD: t_pipe.c,v 1.2 2017/01/13 21:30:41 christos Exp $"); 36 1.1 jmmv 37 1.1 jmmv #include <sys/event.h> 38 1.1 jmmv #include <sys/wait.h> 39 1.1 jmmv 40 1.1 jmmv #include <fcntl.h> 41 1.1 jmmv #include <stdio.h> 42 1.1 jmmv #include <stdlib.h> 43 1.1 jmmv #include <unistd.h> 44 1.1 jmmv 45 1.1 jmmv #include <atf-c.h> 46 1.1 jmmv 47 1.2 christos #include "h_macros.h" 48 1.1 jmmv 49 1.1 jmmv ATF_TC(pipe1); 50 1.1 jmmv ATF_TC_HEAD(pipe1, tc) 51 1.1 jmmv { 52 1.1 jmmv atf_tc_set_md_var(tc, "descr", 53 1.1 jmmv "Checks EVFILT_WRITE for pipes. This test used to trigger " 54 1.1 jmmv "problem fixed in rev. 1.5.2.7 of sys/kern/sys_pipe.c"); 55 1.1 jmmv } 56 1.1 jmmv ATF_TC_BODY(pipe1, tc) 57 1.1 jmmv { 58 1.1 jmmv struct kevent event[1]; 59 1.1 jmmv int fds[2]; 60 1.1 jmmv int kq, n; 61 1.1 jmmv 62 1.1 jmmv RL(pipe(fds)); 63 1.1 jmmv RL(kq = kqueue()); 64 1.1 jmmv RL(close(fds[0])); 65 1.1 jmmv 66 1.1 jmmv EV_SET(&event[0], fds[1], EVFILT_WRITE, EV_ADD|EV_ENABLE, 0, 0, 0); 67 1.1 jmmv ATF_REQUIRE_EQ_MSG((n = kevent(kq, event, 1, NULL, 0, NULL)), 68 1.1 jmmv -1, "got: %d", n); 69 1.1 jmmv ATF_REQUIRE_EQ_MSG(errno, EBADF, "got: %s", strerror(errno)); 70 1.1 jmmv } 71 1.1 jmmv 72 1.1 jmmv ATF_TC(pipe2); 73 1.1 jmmv ATF_TC_HEAD(pipe2, tc) 74 1.1 jmmv { 75 1.1 jmmv atf_tc_set_md_var(tc, "descr", 76 1.1 jmmv "Checks EVFILT_WRITE for pipes. This test used to trigger problem " 77 1.1 jmmv "fixed in rev. 1.5.2.9 of sys/kern/sys_pipe.c"); 78 1.1 jmmv } 79 1.1 jmmv ATF_TC_BODY(pipe2, tc) 80 1.1 jmmv { 81 1.1 jmmv struct kevent event[1]; 82 1.1 jmmv char buffer[128]; 83 1.1 jmmv int fds[2]; 84 1.1 jmmv int kq, n; 85 1.1 jmmv int status; 86 1.1 jmmv pid_t child; 87 1.1 jmmv 88 1.1 jmmv RL(pipe(fds)); 89 1.1 jmmv RL(kq = kqueue()); 90 1.1 jmmv 91 1.1 jmmv EV_SET(&event[0], fds[1], EVFILT_WRITE, EV_ADD|EV_ENABLE, 0, 0, 0); 92 1.1 jmmv RL(kevent(kq, event, 1, NULL, 0, NULL)); 93 1.1 jmmv 94 1.1 jmmv /* spawn child reader */ 95 1.1 jmmv RL(child = fork()); 96 1.1 jmmv if (child == 0) { 97 1.1 jmmv int sz = read(fds[0], buffer, 128); 98 1.1 jmmv if (sz > 0) 99 1.1 jmmv (void)printf("pipe: child read '%.*s'\n", sz, buffer); 100 1.1 jmmv exit(sz <= 0); 101 1.1 jmmv } 102 1.1 jmmv 103 1.1 jmmv RL(n = kevent(kq, NULL, 0, event, 1, NULL)); 104 1.1 jmmv 105 1.1 jmmv (void)printf("kevent num %d flags: %#x, fflags: %#x, data: " 106 1.1 jmmv "%" PRId64 "\n", n, event[0].flags, event[0].fflags, event[0].data); 107 1.1 jmmv 108 1.1 jmmv RL(n = write(fds[1], "foo", 3)); 109 1.1 jmmv RL(close(fds[1])); 110 1.1 jmmv 111 1.1 jmmv (void)waitpid(child, &status, 0); 112 1.1 jmmv } 113 1.1 jmmv 114 1.1 jmmv ATF_TC(pipe3); 115 1.1 jmmv ATF_TC_HEAD(pipe3, tc) 116 1.1 jmmv { 117 1.1 jmmv atf_tc_set_md_var(tc, "descr", 118 1.1 jmmv "Checks EVFILT_WRITE for pipes. This test used to trigger problem " 119 1.1 jmmv "fixed in rev. 1.5.2.10 of sys/kern/sys_pipe.c"); 120 1.1 jmmv } 121 1.1 jmmv ATF_TC_BODY(pipe3, tc) 122 1.1 jmmv { 123 1.1 jmmv struct kevent event[1]; 124 1.1 jmmv int fds[2]; 125 1.1 jmmv int kq; 126 1.1 jmmv 127 1.1 jmmv RL(pipe(fds)); 128 1.1 jmmv RL(kq = kqueue()); 129 1.1 jmmv 130 1.1 jmmv EV_SET(&event[0], fds[1], EVFILT_WRITE, EV_ADD|EV_ENABLE, 0, 0, 0); 131 1.1 jmmv RL(kevent(kq, event, 1, NULL, 0, NULL)); 132 1.1 jmmv 133 1.1 jmmv /* close 'read' end first, then 'write' */ 134 1.1 jmmv 135 1.1 jmmv RL(close(fds[0])); 136 1.1 jmmv RL(close(fds[1])); 137 1.1 jmmv } 138 1.1 jmmv 139 1.1 jmmv 140 1.1 jmmv ATF_TP_ADD_TCS(tp) 141 1.1 jmmv { 142 1.1 jmmv ATF_TP_ADD_TC(tp, pipe1); 143 1.1 jmmv ATF_TP_ADD_TC(tp, pipe2); 144 1.1 jmmv ATF_TP_ADD_TC(tp, pipe3); 145 1.1 jmmv 146 1.1 jmmv return atf_no_error(); 147 1.1 jmmv } 148