4 * Copyright (c) 2002, 2008 The NetBSD Foundation, Inc.
7 * This code is derived from software contributed to The NetBSD Foundation
8 * by Luke Mewburn and Jaromir Dolecek.
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
19 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 * POSSIBILITY OF SUCH DAMAGE.
32 #include <sys/cdefs.h>
33 __COPYRIGHT("@(#) Copyright (c) 2008\
34 The NetBSD Foundation, inc. All rights reserved.");
37 #include <sys/event.h>
48 #include "../../../h_macros.h"
51 h_check(bool check_master
)
55 struct kevent event
[1];
57 int amaster
, aslave
, acurrent
;
65 RL(openpty(&amaster
, &aslave
, slavetty
, NULL
, NULL
));
67 (void)printf("tty: openpty master %d slave %d tty '%s'\n",
68 amaster
, aslave
, slavetty
);
69 acurrent
= check_master
? amaster
: aslave
;
75 (void)printf("tty: child writing 'f00\\n'\n");
76 (void)write(check_master
? aslave
: amaster
, "f00\n", 4);
81 /* switch ONLCR off, to not get confused by newline translation */
82 RL(tcgetattr(acurrent
, &tio
));
83 tio
.c_oflag
&= ~ONLCR
;
84 RL(tcsetattr(acurrent
, TCSADRAIN
, &tio
));
88 (void)printf("tty: polling ...\n");
89 RL(poll(&pfd
, 1, INFTIM
));
90 (void)printf("tty: returned from poll - %d\n", pfd
.revents
);
94 if (ioctl(acurrent
, TIOCPKT
, &fl
) < 0)
100 EV_SET(&event
[0], acurrent
, EVFILT_READ
, EV_ADD
|EV_ENABLE
, 0, 0, 0);
101 RL(kevent(kq
, event
, 1, NULL
, 0, NULL
));
103 RL(n
= kevent(kq
, NULL
, 0, event
, 1, NULL
));
105 (void)printf("kevent num %d filt %d flags: %#x, fflags: %#x, "
106 "data: %" PRId64
"\n", n
, event
[0].filter
, event
[0].flags
,
107 event
[0].fflags
, event
[0].data
);
109 ATF_REQUIRE_EQ(event
[0].filter
, EVFILT_READ
);
111 RL(n
= read(acurrent
, buffer
, 128));
112 (void)printf("tty: read '%.*s' (n=%d)\n", n
, buffer
, n
);
114 (void)waitpid(child
, &status
, 0);
115 (void)printf("tty: successful end\n");
119 ATF_TC_HEAD(master
, tc
)
121 atf_tc_set_md_var(tc
, "descr", "Checks EVFILT_READ for master tty");
123 ATF_TC_BODY(master
, tc
)
129 ATF_TC_HEAD(slave
, tc
)
131 atf_tc_set_md_var(tc
, "descr", "Checks EVFILT_READ for slave tty");
133 ATF_TC_BODY(slave
, tc
)
140 ATF_TP_ADD_TC(tp
, master
);
141 ATF_TP_ADD_TC(tp
, slave
);
143 return atf_no_error();