xref: /freebsd/sys/netgraph/bluetooth/l2cap/ng_l2cap_var.h (revision 2ff63af9b88c7413b7d71715b5532625752a248e)
1878ed226SJulian Elischer /*
2878ed226SJulian Elischer  * ng_l2cap_var.h
3c398230bSWarner Losh  */
4c398230bSWarner Losh 
5c398230bSWarner Losh /*-
6*4d846d26SWarner Losh  * SPDX-License-Identifier: BSD-2-Clause
7fe267a55SPedro F. Giffuni  *
8878ed226SJulian Elischer  * Copyright (c) 2001 Maksim Yevmenkin <m_evmenkin@yahoo.com>
9878ed226SJulian Elischer  * All rights reserved.
10878ed226SJulian Elischer  *
11878ed226SJulian Elischer  * Redistribution and use in source and binary forms, with or without
12878ed226SJulian Elischer  * modification, are permitted provided that the following conditions
13878ed226SJulian Elischer  * are met:
14878ed226SJulian Elischer  * 1. Redistributions of source code must retain the above copyright
15878ed226SJulian Elischer  *    notice, this list of conditions and the following disclaimer.
16878ed226SJulian Elischer  * 2. Redistributions in binary form must reproduce the above copyright
17878ed226SJulian Elischer  *    notice, this list of conditions and the following disclaimer in the
18878ed226SJulian Elischer  *    documentation and/or other materials provided with the distribution.
19878ed226SJulian Elischer  *
20878ed226SJulian Elischer  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
21878ed226SJulian Elischer  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22878ed226SJulian Elischer  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23878ed226SJulian Elischer  * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
24878ed226SJulian Elischer  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25878ed226SJulian Elischer  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26878ed226SJulian Elischer  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27878ed226SJulian Elischer  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28878ed226SJulian Elischer  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29878ed226SJulian Elischer  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30878ed226SJulian Elischer  * SUCH DAMAGE.
31878ed226SJulian Elischer  *
32f2bb1caeSJulian Elischer  * $Id: ng_l2cap_var.h,v 1.2 2003/04/28 21:44:59 max Exp $
33878ed226SJulian Elischer  */
34878ed226SJulian Elischer 
35878ed226SJulian Elischer #ifndef _NETGRAPH_L2CAP_VAR_H_
36f21fff6cSMaksim Yevmenkin #define _NETGRAPH_L2CAP_VAR_H_
37878ed226SJulian Elischer 
38878ed226SJulian Elischer /* MALLOC decalation */
39878ed226SJulian Elischer #ifdef NG_SEPARATE_MALLOC
40878ed226SJulian Elischer MALLOC_DECLARE(M_NETGRAPH_L2CAP);
41878ed226SJulian Elischer #else
42878ed226SJulian Elischer #define M_NETGRAPH_L2CAP M_NETGRAPH
43878ed226SJulian Elischer #endif /* NG_SEPARATE_MALLOC */
44878ed226SJulian Elischer 
45878ed226SJulian Elischer /* Debug */
46878ed226SJulian Elischer #define	NG_L2CAP_ALERT	if (l2cap->debug >= NG_L2CAP_ALERT_LEVEL) printf
47878ed226SJulian Elischer #define	NG_L2CAP_ERR	if (l2cap->debug >= NG_L2CAP_ERR_LEVEL)   printf
48878ed226SJulian Elischer #define	NG_L2CAP_WARN	if (l2cap->debug >= NG_L2CAP_WARN_LEVEL)  printf
49878ed226SJulian Elischer #define	NG_L2CAP_INFO	if (l2cap->debug >= NG_L2CAP_INFO_LEVEL)  printf
50878ed226SJulian Elischer 
51878ed226SJulian Elischer /* Wrapper around m_pullup */
52878ed226SJulian Elischer #define NG_L2CAP_M_PULLUP(m, s) \
53878ed226SJulian Elischer 	do { \
54878ed226SJulian Elischer 		if ((m)->m_len < (s)) \
55878ed226SJulian Elischer 			(m) = m_pullup((m), (s)); \
56878ed226SJulian Elischer 		if ((m) == NULL) \
574ae439a3SMaksim Yevmenkin 			NG_L2CAP_ALERT("%s: %s - m_pullup(%zd) failed\n", \
58878ed226SJulian Elischer 				__func__, NG_NODE_NAME(l2cap->node), (s)); \
59878ed226SJulian Elischer 	} while (0)
60878ed226SJulian Elischer 
61878ed226SJulian Elischer /*
62878ed226SJulian Elischer  * L2CAP signaling command ident's are assigned relative to the connection,
63878ed226SJulian Elischer  * because there is only one signaling channel (cid == 0x01) for every
64878ed226SJulian Elischer  * connection. So up to 254 (0xff - 0x01) L2CAP commands can be pending at the
65878ed226SJulian Elischer  * same time for the same connection.
66878ed226SJulian Elischer  */
67878ed226SJulian Elischer 
68878ed226SJulian Elischer #define NG_L2CAP_NULL_IDENT	0x00        /* DO NOT USE THIS IDENT */
69878ed226SJulian Elischer #define NG_L2CAP_FIRST_IDENT	0x01        /* dynamically alloc. (start) */
70878ed226SJulian Elischer #define NG_L2CAP_LAST_IDENT	0xff        /* dynamically alloc. (end) */
71878ed226SJulian Elischer 
72878ed226SJulian Elischer /*
73878ed226SJulian Elischer  * L2CAP (Node private)
74878ed226SJulian Elischer  */
75878ed226SJulian Elischer 
76878ed226SJulian Elischer struct ng_l2cap_con;
77878ed226SJulian Elischer struct ng_l2cap_chan;
78878ed226SJulian Elischer 
79878ed226SJulian Elischer typedef struct ng_l2cap {
80878ed226SJulian Elischer 	node_p				node;         /* node ptr */
81878ed226SJulian Elischer 
82878ed226SJulian Elischer 	ng_l2cap_node_debug_ep		debug;        /* debug level */
83878ed226SJulian Elischer 	ng_l2cap_node_flags_ep		flags;        /* L2CAP node flags */
84f2bb1caeSJulian Elischer 	ng_l2cap_node_auto_discon_ep	discon_timo;  /* auto discon. timeout */
85878ed226SJulian Elischer 
86878ed226SJulian Elischer 	u_int16_t			pkt_size;     /* max. ACL packet size */
87878ed226SJulian Elischer 	u_int16_t			num_pkts;     /* out queue size */
88f2bb1caeSJulian Elischer 	bdaddr_t			bdaddr;       /* unit BDADDR */
89878ed226SJulian Elischer 
90878ed226SJulian Elischer 	hook_p				hci;          /* HCI downstream hook */
91878ed226SJulian Elischer 	hook_p				l2c;          /* L2CAP upstream hook */
92878ed226SJulian Elischer 	hook_p				ctl;          /* control hook */
93878ed226SJulian Elischer 
94878ed226SJulian Elischer 	LIST_HEAD(, ng_l2cap_con)	con_list;     /* ACL connections */
95878ed226SJulian Elischer 
96878ed226SJulian Elischer     	u_int16_t			cid;          /* last allocated CID */
97fbc48c2bSTakanori Watanabe     	u_int16_t			lecid;          /* last allocated CID for LE */
98fbc48c2bSTakanori Watanabe 
99878ed226SJulian Elischer 	LIST_HEAD(, ng_l2cap_chan)	chan_list;    /* L2CAP channels */
100878ed226SJulian Elischer } ng_l2cap_t;
101878ed226SJulian Elischer typedef ng_l2cap_t *			ng_l2cap_p;
102878ed226SJulian Elischer 
103878ed226SJulian Elischer /*
104878ed226SJulian Elischer  * L2CAP connection descriptor
105878ed226SJulian Elischer  */
106878ed226SJulian Elischer 
107878ed226SJulian Elischer struct ng_l2cap_cmd;
108878ed226SJulian Elischer 
109878ed226SJulian Elischer typedef struct ng_l2cap_con {
110878ed226SJulian Elischer 	ng_l2cap_p			 l2cap;      /* pointer to L2CAP */
111878ed226SJulian Elischer 
112878ed226SJulian Elischer 	u_int16_t			 state;      /* ACL connection state */
113f2bb1caeSJulian Elischer 	u_int16_t			 flags;      /* ACL connection flags */
114f2bb1caeSJulian Elischer 
115f2bb1caeSJulian Elischer 	int32_t				 refcnt;     /* reference count */
116878ed226SJulian Elischer 
117878ed226SJulian Elischer 	bdaddr_t			 remote;     /* remote unit address */
118878ed226SJulian Elischer 	u_int16_t			 con_handle; /* ACL connection handle */
119b81d7730SMaksim Yevmenkin 	struct callout			 con_timo;   /* connection timeout */
120878ed226SJulian Elischer 
121878ed226SJulian Elischer 	u_int8_t			 ident;      /* last allocated ident */
122fbc48c2bSTakanori Watanabe 	uint8_t				 linktype;
1233a601a23STakanori Watanabe 	uint8_t				 encryption;
124fbc48c2bSTakanori Watanabe 
125878ed226SJulian Elischer 	TAILQ_HEAD(, ng_l2cap_cmd)	 cmd_list;   /* pending L2CAP cmds */
126878ed226SJulian Elischer 
127878ed226SJulian Elischer 	struct mbuf			*tx_pkt;     /* xmitted L2CAP packet */
128878ed226SJulian Elischer 	int				 pending;    /* num. of pending pkts */
129878ed226SJulian Elischer 
130878ed226SJulian Elischer 	struct mbuf			*rx_pkt;     /* received L2CAP packet */
131878ed226SJulian Elischer 	int				 rx_pkt_len; /* packet len. so far */
132878ed226SJulian Elischer 
133878ed226SJulian Elischer 	LIST_ENTRY(ng_l2cap_con)	 next;       /* link */
134878ed226SJulian Elischer } ng_l2cap_con_t;
135878ed226SJulian Elischer typedef ng_l2cap_con_t *		ng_l2cap_con_p;
136878ed226SJulian Elischer 
137878ed226SJulian Elischer /*
138878ed226SJulian Elischer  * L2CAP channel descriptor
139878ed226SJulian Elischer  */
140878ed226SJulian Elischer 
141878ed226SJulian Elischer typedef struct ng_l2cap_chan {
142878ed226SJulian Elischer 	ng_l2cap_con_p			con;        /* pointer to connection */
143878ed226SJulian Elischer 
144878ed226SJulian Elischer 	u_int16_t			state;      /* channel state */
145878ed226SJulian Elischer 
146878ed226SJulian Elischer 	u_int8_t			cfg_state;  /* configuration state */
147878ed226SJulian Elischer #define NG_L2CAP_CFG_IN			(1 << 0)    /* incoming cfg path done */
148878ed226SJulian Elischer #define NG_L2CAP_CFG_OUT		(1 << 1)    /* outgoing cfg path done */
149878ed226SJulian Elischer #define NG_L2CAP_CFG_BOTH		(NG_L2CAP_CFG_IN|NG_L2CAP_CFG_OUT)
150878ed226SJulian Elischer 
151878ed226SJulian Elischer 	u_int8_t			ident;      /* last L2CAP req. ident */
152878ed226SJulian Elischer 
153878ed226SJulian Elischer 	u_int16_t			psm;        /* channel PSM */
154878ed226SJulian Elischer 	u_int16_t			scid;       /* source channel ID */
155878ed226SJulian Elischer 	u_int16_t			dcid;       /* destination channel ID */
156878ed226SJulian Elischer 
157fbc48c2bSTakanori Watanabe 	uint16_t			idtype;
158878ed226SJulian Elischer 	u_int16_t			imtu;       /* incoming channel MTU */
159878ed226SJulian Elischer 	ng_l2cap_flow_t			iflow;      /* incoming flow control */
160878ed226SJulian Elischer 
161878ed226SJulian Elischer 	u_int16_t			omtu;       /* outgoing channel MTU */
162878ed226SJulian Elischer 	ng_l2cap_flow_t			oflow;      /* outgoing flow control */
163878ed226SJulian Elischer 
164878ed226SJulian Elischer 	u_int16_t			flush_timo; /* flush timeout */
165878ed226SJulian Elischer 	u_int16_t			link_timo;  /* link timeout */
166878ed226SJulian Elischer 
167878ed226SJulian Elischer 	LIST_ENTRY(ng_l2cap_chan)	next;       /* link */
168878ed226SJulian Elischer } ng_l2cap_chan_t;
169878ed226SJulian Elischer typedef ng_l2cap_chan_t *		ng_l2cap_chan_p;
170878ed226SJulian Elischer 
171878ed226SJulian Elischer /*
172878ed226SJulian Elischer  * L2CAP command descriptor
173878ed226SJulian Elischer  */
174878ed226SJulian Elischer 
175878ed226SJulian Elischer typedef struct ng_l2cap_cmd {
176878ed226SJulian Elischer 	ng_l2cap_con_p			 con;       /* L2CAP connection */
177878ed226SJulian Elischer 	ng_l2cap_chan_p			 ch;        /* L2CAP channel */
178878ed226SJulian Elischer 
179878ed226SJulian Elischer 	u_int16_t 			 flags;     /* command flags */
180878ed226SJulian Elischer #define NG_L2CAP_CMD_PENDING		 (1 << 0)   /* command is pending */
181878ed226SJulian Elischer 
182878ed226SJulian Elischer 	u_int8_t 			 code;      /* L2CAP command opcode */
183878ed226SJulian Elischer 	u_int8_t			 ident;     /* L2CAP command ident */
184878ed226SJulian Elischer 	u_int32_t			 token;     /* L2CA message token */
185878ed226SJulian Elischer 
186b81d7730SMaksim Yevmenkin 	struct callout			 timo;      /* RTX/ERTX timeout */
187878ed226SJulian Elischer 
188878ed226SJulian Elischer 	struct mbuf			*aux;       /* optional data */
189878ed226SJulian Elischer 
190878ed226SJulian Elischer 	TAILQ_ENTRY(ng_l2cap_cmd)	 next;      /* link */
191878ed226SJulian Elischer } ng_l2cap_cmd_t;
192878ed226SJulian Elischer typedef ng_l2cap_cmd_t *		ng_l2cap_cmd_p;
193878ed226SJulian Elischer 
194878ed226SJulian Elischer #endif /* ndef _NETGRAPH_L2CAP_VAR_H_ */
195