/* $OpenBSD: bt_proto.c,v 1.5 2008/11/22 04:42:58 uwe Exp $ */ /* * Copyright (c) 2004 Alexander Yurchenko * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ #include #include #include #include #include #include #include #include #include #include #include struct domain btdomain; void bt_init(void); struct protosw btsw[] = { { SOCK_RAW, &btdomain, BTPROTO_HCI, PR_ATOMIC | PR_ADDR, NULL/*input*/, NULL/*output*/, NULL/*ctlinput*/, hci_ctloutput, hci_usrreq, NULL/*init*/, NULL/*fasttimo*/, NULL/*slowtimo*/, NULL/*drain*/, NULL/*sysctl*/ }, { SOCK_SEQPACKET, &btdomain, BTPROTO_SCO, PR_ATOMIC | PR_CONNREQUIRED, NULL/*input*/, NULL/*output*/, NULL/*ctlinput*/, sco_ctloutput, sco_usrreq, NULL/*init*/, NULL/*fasttimo*/, NULL/*slowtimo*/, NULL/*drain*/, NULL/*sysctl*/ }, { SOCK_SEQPACKET, &btdomain, BTPROTO_L2CAP, PR_ATOMIC | PR_CONNREQUIRED, NULL/*input*/, NULL/*output*/, NULL/*ctlinput*/, l2cap_ctloutput, l2cap_usrreq, l2cap_init, NULL/*fasttimo*/, NULL/*slowtimo*/, NULL/*drain*/, NULL/*sysctl*/ }, { SOCK_STREAM, &btdomain, BTPROTO_RFCOMM, PR_CONNREQUIRED | PR_WANTRCVD, NULL/*input*/, NULL/*output*/, NULL/*ctlinput*/, rfcomm_ctloutput, rfcomm_usrreq, rfcomm_init, NULL/*fasttimo*/, NULL/*slowtimo*/, NULL/*drain*/, NULL/*sysctl*/ } }; struct domain btdomain = { AF_BLUETOOTH, "bluetooth", bt_init, NULL/*externalize*/, NULL/*dispose*/, btsw, &btsw[sizeof(btsw) / sizeof(btsw[0])], NULL, NULL/*rtattach*/, 32, sizeof(struct sockaddr_bt), NULL/*ifattach*/, NULL/*ifdetach*/ }; struct mutex bt_lock; void bt_init(void) { /* * In accordance with mutex(9), since hci_intr() uses the * lock, we associate the subsystem lock with IPL_SOFTNET. * For unknown reasons, in NetBSD the interrupt level is * IPL_NONE. */ mtx_init(&bt_lock, IPL_SOFTNET); }