1878ed226SJulian Elischer /* 2878ed226SJulian Elischer * ng_btsocket_l2cap.h 3c398230bSWarner Losh */ 4c398230bSWarner Losh 5c398230bSWarner Losh /*- 6878ed226SJulian Elischer * Copyright (c) 2001-2002 Maksim Yevmenkin <m_evmenkin@yahoo.com> 7878ed226SJulian Elischer * All rights reserved. 8878ed226SJulian Elischer * 9878ed226SJulian Elischer * Redistribution and use in source and binary forms, with or without 10878ed226SJulian Elischer * modification, are permitted provided that the following conditions 11878ed226SJulian Elischer * are met: 12878ed226SJulian Elischer * 1. Redistributions of source code must retain the above copyright 13878ed226SJulian Elischer * notice, this list of conditions and the following disclaimer. 14878ed226SJulian Elischer * 2. Redistributions in binary form must reproduce the above copyright 15878ed226SJulian Elischer * notice, this list of conditions and the following disclaimer in the 16878ed226SJulian Elischer * documentation and/or other materials provided with the distribution. 17878ed226SJulian Elischer * 18878ed226SJulian Elischer * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 19878ed226SJulian Elischer * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 20878ed226SJulian Elischer * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 21878ed226SJulian Elischer * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 22878ed226SJulian Elischer * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 23878ed226SJulian Elischer * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 24878ed226SJulian Elischer * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 25878ed226SJulian Elischer * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 26878ed226SJulian Elischer * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 27878ed226SJulian Elischer * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 28878ed226SJulian Elischer * SUCH DAMAGE. 29878ed226SJulian Elischer * 30f2bb1caeSJulian Elischer * $Id: ng_btsocket_l2cap.h,v 1.4 2003/03/25 23:53:33 max Exp $ 31878ed226SJulian Elischer * $FreeBSD$ 32878ed226SJulian Elischer */ 33878ed226SJulian Elischer 34878ed226SJulian Elischer #ifndef _NETGRAPH_BTSOCKET_L2CAP_H_ 35f21fff6cSMaksim Yevmenkin #define _NETGRAPH_BTSOCKET_L2CAP_H_ 36878ed226SJulian Elischer 37878ed226SJulian Elischer /* 38878ed226SJulian Elischer * L2CAP routing entry 39878ed226SJulian Elischer */ 40878ed226SJulian Elischer 41878ed226SJulian Elischer struct ng_hook; 42878ed226SJulian Elischer struct ng_message; 43878ed226SJulian Elischer 44878ed226SJulian Elischer struct ng_btsocket_l2cap_rtentry { 45878ed226SJulian Elischer bdaddr_t src; /* source BD_ADDR */ 46878ed226SJulian Elischer struct ng_hook *hook; /* downstream hook */ 47f2bb1caeSJulian Elischer LIST_ENTRY(ng_btsocket_l2cap_rtentry) next; /* link to next */ 48878ed226SJulian Elischer }; 49878ed226SJulian Elischer typedef struct ng_btsocket_l2cap_rtentry ng_btsocket_l2cap_rtentry_t; 50878ed226SJulian Elischer typedef struct ng_btsocket_l2cap_rtentry * ng_btsocket_l2cap_rtentry_p; 51878ed226SJulian Elischer 52878ed226SJulian Elischer /***************************************************************************** 53878ed226SJulian Elischer ***************************************************************************** 54878ed226SJulian Elischer ** SOCK_RAW L2CAP sockets ** 55878ed226SJulian Elischer ***************************************************************************** 56878ed226SJulian Elischer *****************************************************************************/ 57878ed226SJulian Elischer 58878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_RAW_SENDSPACE NG_L2CAP_MTU_DEFAULT 59878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_RAW_RECVSPACE NG_L2CAP_MTU_DEFAULT 60878ed226SJulian Elischer 61878ed226SJulian Elischer /* 62878ed226SJulian Elischer * Bluetooth raw L2CAP socket PCB 63878ed226SJulian Elischer */ 64878ed226SJulian Elischer 65878ed226SJulian Elischer struct ng_btsocket_l2cap_raw_pcb { 66878ed226SJulian Elischer struct socket *so; /* socket */ 67878ed226SJulian Elischer 68f2bb1caeSJulian Elischer u_int32_t flags; /* flags */ 69f2bb1caeSJulian Elischer #define NG_BTSOCKET_L2CAP_RAW_PRIVILEGED (1 << 0) 70f2bb1caeSJulian Elischer 71878ed226SJulian Elischer bdaddr_t src; /* source address */ 72f2bb1caeSJulian Elischer bdaddr_t dst; /* dest address */ 73fbc48c2bSTakanori Watanabe uint8_t srctype;/*source addr type*/ 74fbc48c2bSTakanori Watanabe uint8_t dsttype;/*source addr type*/ 75878ed226SJulian Elischer ng_btsocket_l2cap_rtentry_p rt; /* routing info */ 76878ed226SJulian Elischer 77878ed226SJulian Elischer u_int32_t token; /* message token */ 78878ed226SJulian Elischer struct ng_mesg *msg; /* message */ 79878ed226SJulian Elischer 80f2bb1caeSJulian Elischer struct mtx pcb_mtx; /* pcb mutex */ 81f2bb1caeSJulian Elischer 82878ed226SJulian Elischer LIST_ENTRY(ng_btsocket_l2cap_raw_pcb) next; /* link to next PCB */ 83878ed226SJulian Elischer }; 84878ed226SJulian Elischer typedef struct ng_btsocket_l2cap_raw_pcb ng_btsocket_l2cap_raw_pcb_t; 85878ed226SJulian Elischer typedef struct ng_btsocket_l2cap_raw_pcb * ng_btsocket_l2cap_raw_pcb_p; 86878ed226SJulian Elischer 87878ed226SJulian Elischer #define so2l2cap_raw_pcb(so) \ 88878ed226SJulian Elischer ((struct ng_btsocket_l2cap_raw_pcb *)((so)->so_pcb)) 89878ed226SJulian Elischer 90878ed226SJulian Elischer /* 91878ed226SJulian Elischer * Bluetooth raw L2CAP socket methods 92878ed226SJulian Elischer */ 93878ed226SJulian Elischer 94878ed226SJulian Elischer #ifdef _KERNEL 95878ed226SJulian Elischer 96878ed226SJulian Elischer void ng_btsocket_l2cap_raw_init (void); 97ac45e92fSRobert Watson void ng_btsocket_l2cap_raw_abort (struct socket *); 98a152f8a3SRobert Watson void ng_btsocket_l2cap_raw_close (struct socket *); 99878ed226SJulian Elischer int ng_btsocket_l2cap_raw_attach (struct socket *, int, struct thread *); 100878ed226SJulian Elischer int ng_btsocket_l2cap_raw_bind (struct socket *, struct sockaddr *, 101878ed226SJulian Elischer struct thread *); 102878ed226SJulian Elischer int ng_btsocket_l2cap_raw_connect (struct socket *, struct sockaddr *, 103878ed226SJulian Elischer struct thread *); 104878ed226SJulian Elischer int ng_btsocket_l2cap_raw_control (struct socket *, u_long, caddr_t, 105878ed226SJulian Elischer struct ifnet *, struct thread *); 106bc725eafSRobert Watson void ng_btsocket_l2cap_raw_detach (struct socket *); 107878ed226SJulian Elischer int ng_btsocket_l2cap_raw_disconnect (struct socket *); 108878ed226SJulian Elischer int ng_btsocket_l2cap_raw_peeraddr (struct socket *, struct sockaddr **); 109878ed226SJulian Elischer int ng_btsocket_l2cap_raw_send (struct socket *, int, struct mbuf *, 110878ed226SJulian Elischer struct sockaddr *, struct mbuf *, 111878ed226SJulian Elischer struct thread *); 112878ed226SJulian Elischer int ng_btsocket_l2cap_raw_sockaddr (struct socket *, struct sockaddr **); 113878ed226SJulian Elischer 114878ed226SJulian Elischer #endif /* _KERNEL */ 115878ed226SJulian Elischer 116878ed226SJulian Elischer /***************************************************************************** 117878ed226SJulian Elischer ***************************************************************************** 118878ed226SJulian Elischer ** SOCK_SEQPACKET L2CAP sockets ** 119878ed226SJulian Elischer ***************************************************************************** 120878ed226SJulian Elischer *****************************************************************************/ 121878ed226SJulian Elischer 122878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_SENDSPACE NG_L2CAP_MTU_DEFAULT /* (64 * 1024) */ 123878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_RECVSPACE (64 * 1024) 124878ed226SJulian Elischer 125878ed226SJulian Elischer /* 126878ed226SJulian Elischer * Bluetooth L2CAP socket PCB 127878ed226SJulian Elischer */ 128878ed226SJulian Elischer 129878ed226SJulian Elischer struct ng_btsocket_l2cap_pcb { 130878ed226SJulian Elischer struct socket *so; /* Pointer to socket */ 131878ed226SJulian Elischer 132878ed226SJulian Elischer bdaddr_t src; /* Source address */ 133878ed226SJulian Elischer bdaddr_t dst; /* Destination address */ 134fbc48c2bSTakanori Watanabe uint8_t srctype; /*source addr type*/ 135fbc48c2bSTakanori Watanabe uint8_t dsttype; /*source addr type*/ 136878ed226SJulian Elischer 137878ed226SJulian Elischer u_int16_t psm; /* PSM */ 138878ed226SJulian Elischer u_int16_t cid; /* Local channel ID */ 139*3a601a23STakanori Watanabe uint8_t idtype; 140878ed226SJulian Elischer u_int16_t flags; /* socket flags */ 141878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_CLIENT (1 << 0) /* socket is client */ 142878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_TIMO (1 << 1) /* timeout pending */ 143878ed226SJulian Elischer 144878ed226SJulian Elischer u_int8_t state; /* socket state */ 145878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_CLOSED 0 /* socket closed */ 146878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_CONNECTING 1 /* wait for connect */ 147878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_CONFIGURING 2 /* wait for config */ 148878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_OPEN 3 /* socket open */ 149878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_DISCONNECTING 4 /* wait for disconnect */ 150*3a601a23STakanori Watanabe #define NG_BTSOCKET_L2CAP_W4_ENC_CHANGE 5 151878ed226SJulian Elischer 152878ed226SJulian Elischer u_int8_t cfg_state; /* config state */ 153878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_CFG_IN (1 << 0) /* incoming path done */ 154878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_CFG_OUT (1 << 1) /* outgoing path done */ 155878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_CFG_BOTH \ 156878ed226SJulian Elischer (NG_BTSOCKET_L2CAP_CFG_IN | NG_BTSOCKET_L2CAP_CFG_OUT) 157878ed226SJulian Elischer 158878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_CFG_IN_SENT (1 << 2) /* L2CAP ConfigReq sent */ 159878ed226SJulian Elischer #define NG_BTSOCKET_L2CAP_CFG_OUT_SENT (1 << 3) /* ---/--- */ 160*3a601a23STakanori Watanabe uint8_t encryption; 161878ed226SJulian Elischer u_int16_t imtu; /* Incoming MTU */ 162878ed226SJulian Elischer ng_l2cap_flow_t iflow; /* Input flow spec */ 163878ed226SJulian Elischer 164878ed226SJulian Elischer u_int16_t omtu; /* Outgoing MTU */ 165878ed226SJulian Elischer ng_l2cap_flow_t oflow; /* Outgoing flow spec */ 166878ed226SJulian Elischer 167878ed226SJulian Elischer u_int16_t flush_timo; /* flush timeout */ 168878ed226SJulian Elischer u_int16_t link_timo; /* link timeout */ 169878ed226SJulian Elischer 1703d1592efSJohn Baldwin struct callout timo; /* timeout */ 171878ed226SJulian Elischer 172878ed226SJulian Elischer u_int32_t token; /* message token */ 173878ed226SJulian Elischer ng_btsocket_l2cap_rtentry_p rt; /* routing info */ 174878ed226SJulian Elischer 175878ed226SJulian Elischer struct mtx pcb_mtx; /* pcb mutex */ 176*3a601a23STakanori Watanabe uint16_t need_encrypt; /*encryption needed*/ 177878ed226SJulian Elischer 178878ed226SJulian Elischer LIST_ENTRY(ng_btsocket_l2cap_pcb) next; /* link to next PCB */ 179878ed226SJulian Elischer }; 180878ed226SJulian Elischer typedef struct ng_btsocket_l2cap_pcb ng_btsocket_l2cap_pcb_t; 181878ed226SJulian Elischer typedef struct ng_btsocket_l2cap_pcb * ng_btsocket_l2cap_pcb_p; 182878ed226SJulian Elischer 183878ed226SJulian Elischer #define so2l2cap_pcb(so) \ 184878ed226SJulian Elischer ((struct ng_btsocket_l2cap_pcb *)((so)->so_pcb)) 185878ed226SJulian Elischer 186878ed226SJulian Elischer /* 187878ed226SJulian Elischer * Bluetooth L2CAP socket methods 188878ed226SJulian Elischer */ 189878ed226SJulian Elischer 190878ed226SJulian Elischer #ifdef _KERNEL 191878ed226SJulian Elischer 192878ed226SJulian Elischer void ng_btsocket_l2cap_init (void); 193ac45e92fSRobert Watson void ng_btsocket_l2cap_abort (struct socket *); 194a152f8a3SRobert Watson void ng_btsocket_l2cap_close (struct socket *); 195878ed226SJulian Elischer int ng_btsocket_l2cap_accept (struct socket *, struct sockaddr **); 196878ed226SJulian Elischer int ng_btsocket_l2cap_attach (struct socket *, int, struct thread *); 197878ed226SJulian Elischer int ng_btsocket_l2cap_bind (struct socket *, struct sockaddr *, 198878ed226SJulian Elischer struct thread *); 199878ed226SJulian Elischer int ng_btsocket_l2cap_connect (struct socket *, struct sockaddr *, 200878ed226SJulian Elischer struct thread *); 201878ed226SJulian Elischer int ng_btsocket_l2cap_control (struct socket *, u_long, caddr_t, 202878ed226SJulian Elischer struct ifnet *, struct thread *); 203878ed226SJulian Elischer int ng_btsocket_l2cap_ctloutput (struct socket *, struct sockopt *); 204bc725eafSRobert Watson void ng_btsocket_l2cap_detach (struct socket *); 205878ed226SJulian Elischer int ng_btsocket_l2cap_disconnect (struct socket *); 206d374e81eSRobert Watson int ng_btsocket_l2cap_listen (struct socket *, int, struct thread *); 207878ed226SJulian Elischer int ng_btsocket_l2cap_peeraddr (struct socket *, struct sockaddr **); 208878ed226SJulian Elischer int ng_btsocket_l2cap_send (struct socket *, int, struct mbuf *, 209878ed226SJulian Elischer struct sockaddr *, struct mbuf *, 210878ed226SJulian Elischer struct thread *); 211878ed226SJulian Elischer int ng_btsocket_l2cap_sockaddr (struct socket *, struct sockaddr **); 212878ed226SJulian Elischer 213878ed226SJulian Elischer #endif /* _KERNEL */ 214878ed226SJulian Elischer 215878ed226SJulian Elischer #endif /* _NETGRAPH_BTSOCKET_L2CAP_H_ */ 216878ed226SJulian Elischer 217