1*f6217f89SApple OSS Distributions #include <darwintest.h> 2*f6217f89SApple OSS Distributions #include <poll.h> 3*f6217f89SApple OSS Distributions #include <sys/socket.h> 4*f6217f89SApple OSS Distributions #include <unistd.h> 5*f6217f89SApple OSS Distributions 6*f6217f89SApple OSS Distributions T_GLOBAL_META(T_META_RUN_CONCURRENTLY(true)); 7*f6217f89SApple OSS Distributions 8*f6217f89SApple OSS Distributions T_DECL(socket_poll_close_25786011, "Tests an invalid poll call to a socket and then calling close.", T_META_LTEPHASE(LTE_POSTINIT), T_META_TAG_VM_PREFERRED) 9*f6217f89SApple OSS Distributions { 10*f6217f89SApple OSS Distributions int my_socket, ret; 11*f6217f89SApple OSS Distributions 12*f6217f89SApple OSS Distributions my_socket = socket(PF_LOCAL, SOCK_STREAM, 0); 13*f6217f89SApple OSS Distributions T_WITH_ERRNO; T_ASSERT_TRUE(my_socket > 0, "create socket"); 14*f6217f89SApple OSS Distributions 15*f6217f89SApple OSS Distributions /* 16*f6217f89SApple OSS Distributions * Setup a pollfd that we know will return an error when we try 17*f6217f89SApple OSS Distributions * to create a knote for it. We specify a BSD vnode specific event 18*f6217f89SApple OSS Distributions * for a socket. 19*f6217f89SApple OSS Distributions */ 20*f6217f89SApple OSS Distributions struct pollfd my_pollfd = { 21*f6217f89SApple OSS Distributions .fd = my_socket, 22*f6217f89SApple OSS Distributions .events = POLLEXTEND 23*f6217f89SApple OSS Distributions }; 24*f6217f89SApple OSS Distributions 25*f6217f89SApple OSS Distributions /* 26*f6217f89SApple OSS Distributions * Previously the call to kevent_register() in the kernel from this call 27*f6217f89SApple OSS Distributions * would leak an iocount reference on the fileproc, which would cause any 28*f6217f89SApple OSS Distributions * subsequent calls to close() on the associated fd to block indefinitely. 29*f6217f89SApple OSS Distributions */ 30*f6217f89SApple OSS Distributions ret = poll(&my_pollfd, 1, 0); 31*f6217f89SApple OSS Distributions T_WITH_ERRNO; T_ASSERT_TRUE(ret == 1, "poll returned %d", ret); 32*f6217f89SApple OSS Distributions 33*f6217f89SApple OSS Distributions ret = close(my_socket); 34*f6217f89SApple OSS Distributions T_ASSERT_POSIX_ZERO(ret, "close on socket with fd %d\n", my_socket); 35*f6217f89SApple OSS Distributions 36*f6217f89SApple OSS Distributions T_PASS("socket_poll_close_25786011 PASSED"); 37*f6217f89SApple OSS Distributions } 38