1a79b7128SAlfred Perlstein /*- 2a79b7128SAlfred Perlstein * Copyright (c) 2000 Alfred Perlstein <alfred@FreeBSD.org> 3a79b7128SAlfred Perlstein * All rights reserved. 4a79b7128SAlfred Perlstein * 5a79b7128SAlfred Perlstein * Redistribution and use in source and binary forms, with or without 6a79b7128SAlfred Perlstein * modification, are permitted provided that the following conditions 7a79b7128SAlfred Perlstein * are met: 8a79b7128SAlfred Perlstein * 1. Redistributions of source code must retain the above copyright 9a79b7128SAlfred Perlstein * notice, this list of conditions and the following disclaimer. 10a79b7128SAlfred Perlstein * 2. Redistributions in binary form must reproduce the above copyright 11a79b7128SAlfred Perlstein * notice, this list of conditions and the following disclaimer in the 12a79b7128SAlfred Perlstein * documentation and/or other materials provided with the distribution. 13a79b7128SAlfred Perlstein * 14a79b7128SAlfred Perlstein * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15a79b7128SAlfred Perlstein * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16a79b7128SAlfred Perlstein * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17a79b7128SAlfred Perlstein * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18a79b7128SAlfred Perlstein * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19a79b7128SAlfred Perlstein * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20a79b7128SAlfred Perlstein * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21a79b7128SAlfred Perlstein * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22a79b7128SAlfred Perlstein * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23a79b7128SAlfred Perlstein * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24a79b7128SAlfred Perlstein * SUCH DAMAGE. 25a79b7128SAlfred Perlstein */ 26a79b7128SAlfred Perlstein 274b421e2dSMike Silbersack #include <sys/cdefs.h> 284b421e2dSMike Silbersack __FBSDID("$FreeBSD$"); 294b421e2dSMike Silbersack 30a79b7128SAlfred Perlstein #define ACCEPT_FILTER_MOD 31a79b7128SAlfred Perlstein 32a79b7128SAlfred Perlstein #include <sys/param.h> 33a79b7128SAlfred Perlstein #include <sys/kernel.h> 345dba30f1SPoul-Henning Kamp #include <sys/module.h> 35960ed29cSSeigo Tanimura #include <sys/sysctl.h> 36960ed29cSSeigo Tanimura #include <sys/signalvar.h> 37a79b7128SAlfred Perlstein #include <sys/socketvar.h> 38a79b7128SAlfred Perlstein 39a79b7128SAlfred Perlstein /* accept filter that holds a socket until data arrives */ 40a79b7128SAlfred Perlstein 4174fb0ba7SJohn Baldwin static int sohasdata(struct socket *so, void *arg, int waitflag); 42a79b7128SAlfred Perlstein 43a79b7128SAlfred Perlstein static struct accept_filter accf_data_filter = { 44a79b7128SAlfred Perlstein "dataready", 45a79b7128SAlfred Perlstein sohasdata, 46a79b7128SAlfred Perlstein NULL, 47a79b7128SAlfred Perlstein NULL 48a79b7128SAlfred Perlstein }; 49a79b7128SAlfred Perlstein 50a79b7128SAlfred Perlstein static moduledata_t accf_data_mod = { 51a79b7128SAlfred Perlstein "accf_data", 52a79b7128SAlfred Perlstein accept_filt_generic_mod_event, 53a79b7128SAlfred Perlstein &accf_data_filter 54a79b7128SAlfred Perlstein }; 55a79b7128SAlfred Perlstein 56a79b7128SAlfred Perlstein DECLARE_MODULE(accf_data, accf_data_mod, SI_SUB_DRIVERS, SI_ORDER_MIDDLE); 57a79b7128SAlfred Perlstein 5874fb0ba7SJohn Baldwin static int 59a79b7128SAlfred Perlstein sohasdata(struct socket *so, void *arg, int waitflag) 60a79b7128SAlfred Perlstein { 61a79b7128SAlfred Perlstein 624cc20ab1SSeigo Tanimura if (!soreadable(so)) 6374fb0ba7SJohn Baldwin return (SU_OK); 64a79b7128SAlfred Perlstein 6574fb0ba7SJohn Baldwin return (SU_ISCONNECTED); 66a79b7128SAlfred Perlstein } 67