xref: /freebsd/usr.sbin/bluetooth/btpand/btpand.h (revision 2a63c3be)
17718ced0SMaksim Yevmenkin /*	$NetBSD: btpand.h,v 1.1 2008/08/17 13:20:57 plunky Exp $	*/
27718ced0SMaksim Yevmenkin 
37718ced0SMaksim Yevmenkin /*-
4b61a5730SWarner Losh  * SPDX-License-Identifier: BSD-2-Clause
51de7b4b8SPedro F. Giffuni  *
67718ced0SMaksim Yevmenkin  * Copyright (c) 2008 Iain Hibbert
77718ced0SMaksim Yevmenkin  * All rights reserved.
87718ced0SMaksim Yevmenkin  *
97718ced0SMaksim Yevmenkin  * Redistribution and use in source and binary forms, with or without
107718ced0SMaksim Yevmenkin  * modification, are permitted provided that the following conditions
117718ced0SMaksim Yevmenkin  * are met:
127718ced0SMaksim Yevmenkin  * 1. Redistributions of source code must retain the above copyright
137718ced0SMaksim Yevmenkin  *    notice, this list of conditions and the following disclaimer.
147718ced0SMaksim Yevmenkin  * 2. Redistributions in binary form must reproduce the above copyright
157718ced0SMaksim Yevmenkin  *    notice, this list of conditions and the following disclaimer in the
167718ced0SMaksim Yevmenkin  *    documentation and/or other materials provided with the distribution.
177718ced0SMaksim Yevmenkin  *
187718ced0SMaksim Yevmenkin  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
197718ced0SMaksim Yevmenkin  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
207718ced0SMaksim Yevmenkin  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
217718ced0SMaksim Yevmenkin  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
227718ced0SMaksim Yevmenkin  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
237718ced0SMaksim Yevmenkin  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
247718ced0SMaksim Yevmenkin  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
257718ced0SMaksim Yevmenkin  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
267718ced0SMaksim Yevmenkin  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
277718ced0SMaksim Yevmenkin  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
287718ced0SMaksim Yevmenkin  */
297718ced0SMaksim Yevmenkin 
307718ced0SMaksim Yevmenkin 
317718ced0SMaksim Yevmenkin #include <sys/types.h>
327718ced0SMaksim Yevmenkin #include <sys/queue.h>
337718ced0SMaksim Yevmenkin #include <sys/socket.h>
347718ced0SMaksim Yevmenkin 
357718ced0SMaksim Yevmenkin #include <net/if.h>
367718ced0SMaksim Yevmenkin #include <net/ethernet.h>
377718ced0SMaksim Yevmenkin 
387718ced0SMaksim Yevmenkin #include <assert.h>
397718ced0SMaksim Yevmenkin #include <bluetooth.h>
407718ced0SMaksim Yevmenkin #include <stdbool.h>
417718ced0SMaksim Yevmenkin #include <stdlib.h>
427718ced0SMaksim Yevmenkin #include <string.h>
437718ced0SMaksim Yevmenkin #include <syslog.h>
447718ced0SMaksim Yevmenkin 
457718ced0SMaksim Yevmenkin #include "event.h"
467718ced0SMaksim Yevmenkin 
477718ced0SMaksim Yevmenkin #ifndef __arraycount
487718ced0SMaksim Yevmenkin #define __arraycount(__x)	(int)(sizeof((__x)) / sizeof((__x)[0]))
497718ced0SMaksim Yevmenkin #endif
507718ced0SMaksim Yevmenkin 
517718ced0SMaksim Yevmenkin #ifndef	L2CAP_PSM_INVALID
527718ced0SMaksim Yevmenkin #define	L2CAP_PSM_INVALID(psm)	(((psm) & 0x0101) != 0x0001)
537718ced0SMaksim Yevmenkin #endif
547718ced0SMaksim Yevmenkin 
55905033dcSMaksim Yevmenkin #ifndef	L2CAP_PSM_BNEP
56905033dcSMaksim Yevmenkin #define	L2CAP_PSM_BNEP	15
57905033dcSMaksim Yevmenkin #endif
58905033dcSMaksim Yevmenkin 
597718ced0SMaksim Yevmenkin typedef struct channel	channel_t;
607718ced0SMaksim Yevmenkin typedef struct pfilter	pfilter_t;
617718ced0SMaksim Yevmenkin typedef struct mfilter	mfilter_t;
627718ced0SMaksim Yevmenkin typedef struct packet	packet_t;
637718ced0SMaksim Yevmenkin typedef struct pkthdr	pkthdr_t;
647718ced0SMaksim Yevmenkin typedef struct pktlist	pktlist_t;
657718ced0SMaksim Yevmenkin typedef struct exthdr	exthdr_t;
667718ced0SMaksim Yevmenkin typedef struct extlist	extlist_t;
677718ced0SMaksim Yevmenkin 
687718ced0SMaksim Yevmenkin LIST_HEAD(chlist, channel);
697718ced0SMaksim Yevmenkin STAILQ_HEAD(extlist, exthdr);
707718ced0SMaksim Yevmenkin STAILQ_HEAD(pktlist, pkthdr);
717718ced0SMaksim Yevmenkin 
727718ced0SMaksim Yevmenkin enum channel_state {
737718ced0SMaksim Yevmenkin 	CHANNEL_CLOSED,
747718ced0SMaksim Yevmenkin 	CHANNEL_WAIT_CONNECT_REQ,
757718ced0SMaksim Yevmenkin 	CHANNEL_WAIT_CONNECT_RSP,
767718ced0SMaksim Yevmenkin 	CHANNEL_OPEN,
777718ced0SMaksim Yevmenkin };
787718ced0SMaksim Yevmenkin 
797718ced0SMaksim Yevmenkin #define CHANNEL_MAXQLEN		128
807718ced0SMaksim Yevmenkin 
817718ced0SMaksim Yevmenkin /* BNEP or tap channel */
827718ced0SMaksim Yevmenkin struct channel {
837718ced0SMaksim Yevmenkin 	enum channel_state	state;
847718ced0SMaksim Yevmenkin 	bool			oactive;
857718ced0SMaksim Yevmenkin 
867718ced0SMaksim Yevmenkin 	uint8_t			laddr[ETHER_ADDR_LEN];
877718ced0SMaksim Yevmenkin 	uint8_t			raddr[ETHER_ADDR_LEN];
887718ced0SMaksim Yevmenkin 	size_t			mru;
897718ced0SMaksim Yevmenkin 	size_t			mtu;
907718ced0SMaksim Yevmenkin 
917718ced0SMaksim Yevmenkin 	int			npfilter;
927718ced0SMaksim Yevmenkin 	pfilter_t *		pfilter;
937718ced0SMaksim Yevmenkin 
947718ced0SMaksim Yevmenkin 	int			nmfilter;
957718ced0SMaksim Yevmenkin 	mfilter_t *		mfilter;
967718ced0SMaksim Yevmenkin 
977718ced0SMaksim Yevmenkin 	pktlist_t		pktlist;
987718ced0SMaksim Yevmenkin 	int			qlen;
997718ced0SMaksim Yevmenkin 
1007718ced0SMaksim Yevmenkin 	int			fd;
1017718ced0SMaksim Yevmenkin 	struct event		rd_ev;
1027718ced0SMaksim Yevmenkin 	struct event		wr_ev;
1037718ced0SMaksim Yevmenkin 	uint8_t *		sendbuf;
1047718ced0SMaksim Yevmenkin 
1057718ced0SMaksim Yevmenkin 	bool			(*send)(channel_t *, packet_t *);
1067718ced0SMaksim Yevmenkin 	bool			(*recv)(packet_t *);
1077718ced0SMaksim Yevmenkin 
1087718ced0SMaksim Yevmenkin 	int			tick;
1097718ced0SMaksim Yevmenkin 
1107718ced0SMaksim Yevmenkin 	struct pidfh		*pfh;
1117718ced0SMaksim Yevmenkin 
1127718ced0SMaksim Yevmenkin 	int			refcnt;
1137718ced0SMaksim Yevmenkin 	LIST_ENTRY(channel)	next;
1147718ced0SMaksim Yevmenkin };
1157718ced0SMaksim Yevmenkin 
1167718ced0SMaksim Yevmenkin /* network protocol type filter */
1177718ced0SMaksim Yevmenkin struct pfilter {
1187718ced0SMaksim Yevmenkin 	uint16_t	start;
1197718ced0SMaksim Yevmenkin 	uint16_t	end;
1207718ced0SMaksim Yevmenkin };
1217718ced0SMaksim Yevmenkin 
1227718ced0SMaksim Yevmenkin /* multicast address filter */
1237718ced0SMaksim Yevmenkin struct mfilter {
1247718ced0SMaksim Yevmenkin 	uint8_t		start[ETHER_ADDR_LEN];
1257718ced0SMaksim Yevmenkin 	uint8_t		end[ETHER_ADDR_LEN];
1267718ced0SMaksim Yevmenkin };
1277718ced0SMaksim Yevmenkin 
1287718ced0SMaksim Yevmenkin /* packet data buffer */
1297718ced0SMaksim Yevmenkin struct packet {
1307718ced0SMaksim Yevmenkin 	channel_t *		chan;	/* source channel */
1317718ced0SMaksim Yevmenkin 	uint8_t *		dst;	/* dest address */
1327718ced0SMaksim Yevmenkin 	uint8_t *		src;	/* source address */
1337718ced0SMaksim Yevmenkin 	uint8_t *		type;	/* protocol type */
1347718ced0SMaksim Yevmenkin 	uint8_t *		ptr;	/* data pointer */
1357718ced0SMaksim Yevmenkin 	size_t			len;	/* data length */
1367718ced0SMaksim Yevmenkin 	int			refcnt;	/* reference count */
1377718ced0SMaksim Yevmenkin 	extlist_t		extlist;/* extension headers */
1387718ced0SMaksim Yevmenkin 	uint8_t			buf[0];	/* data starts here */
1397718ced0SMaksim Yevmenkin };
1407718ced0SMaksim Yevmenkin 
1417718ced0SMaksim Yevmenkin /* extension header */
1427718ced0SMaksim Yevmenkin struct exthdr {
1437718ced0SMaksim Yevmenkin 	STAILQ_ENTRY(exthdr)	next;
1447718ced0SMaksim Yevmenkin 	uint8_t *		ptr;
1457718ced0SMaksim Yevmenkin 	uint8_t			len;
1467718ced0SMaksim Yevmenkin };
1477718ced0SMaksim Yevmenkin 
1487718ced0SMaksim Yevmenkin /* packet header */
1497718ced0SMaksim Yevmenkin struct pkthdr {
1507718ced0SMaksim Yevmenkin 	STAILQ_ENTRY(pkthdr)	next;
1517718ced0SMaksim Yevmenkin 	packet_t *		data;
1527718ced0SMaksim Yevmenkin };
1537718ced0SMaksim Yevmenkin 
1547718ced0SMaksim Yevmenkin /* global variables */
1557718ced0SMaksim Yevmenkin extern const char *	control_path;
1567718ced0SMaksim Yevmenkin extern const char *	service_name;
1577718ced0SMaksim Yevmenkin extern const char *	interface_name;
1587718ced0SMaksim Yevmenkin extern bdaddr_t		local_bdaddr;
1597718ced0SMaksim Yevmenkin extern bdaddr_t		remote_bdaddr;
1607718ced0SMaksim Yevmenkin extern uint16_t		l2cap_psm;
1617718ced0SMaksim Yevmenkin extern int		l2cap_mode;
1627718ced0SMaksim Yevmenkin extern uint16_t		service_class;
1637718ced0SMaksim Yevmenkin extern int		server_limit;
1647718ced0SMaksim Yevmenkin 
1657718ced0SMaksim Yevmenkin /*
1667718ced0SMaksim Yevmenkin  * Bluetooth addresses are stored the other way around than
1677718ced0SMaksim Yevmenkin  * Ethernet addresses even though they are of the same family
1687718ced0SMaksim Yevmenkin  */
1697718ced0SMaksim Yevmenkin static inline void
b2eaddr(void * dst,bdaddr_t * src)1707718ced0SMaksim Yevmenkin b2eaddr(void *dst, bdaddr_t *src)
1717718ced0SMaksim Yevmenkin {
1727718ced0SMaksim Yevmenkin 	uint8_t *d = dst;
1737718ced0SMaksim Yevmenkin 	int i;
1747718ced0SMaksim Yevmenkin 
1757718ced0SMaksim Yevmenkin 	for (i = 0; i < ETHER_ADDR_LEN; i++)
1767718ced0SMaksim Yevmenkin 		d[i] = src->b[ETHER_ADDR_LEN - i - 1];
1777718ced0SMaksim Yevmenkin }
1787718ced0SMaksim Yevmenkin 
1797718ced0SMaksim Yevmenkin #define log_err(fmt, args...)		syslog(LOG_ERR, fmt , ##args)
1807718ced0SMaksim Yevmenkin #define log_info(fmt, args...)		syslog(LOG_INFO, fmt , ##args)
1817718ced0SMaksim Yevmenkin #define log_notice(fmt, args...)	syslog(LOG_NOTICE, fmt , ##args)
1827718ced0SMaksim Yevmenkin #define log_debug(fmt, args...)		syslog(LOG_DEBUG, "%s: " fmt, __func__ , ##args)
1837718ced0SMaksim Yevmenkin 
1847718ced0SMaksim Yevmenkin /* bnep.c */
1857718ced0SMaksim Yevmenkin bool		bnep_send(channel_t *, packet_t *);
1867718ced0SMaksim Yevmenkin bool		bnep_recv(packet_t *);
1877fcdc815SDimitry Andric void		bnep_send_control(channel_t *, unsigned, ...);
1887718ced0SMaksim Yevmenkin 
1897718ced0SMaksim Yevmenkin /* channel.c */
1907718ced0SMaksim Yevmenkin void		channel_init(void);
1917718ced0SMaksim Yevmenkin channel_t *	channel_alloc(void);
1927718ced0SMaksim Yevmenkin bool		channel_open(channel_t *, int);
1937718ced0SMaksim Yevmenkin void		channel_close(channel_t *);
1947718ced0SMaksim Yevmenkin void		channel_free(channel_t *);
1957718ced0SMaksim Yevmenkin void		channel_timeout(channel_t *, int);
1967718ced0SMaksim Yevmenkin void		channel_put(channel_t *, packet_t *);
1977718ced0SMaksim Yevmenkin 
1987718ced0SMaksim Yevmenkin /* client.c */
1997718ced0SMaksim Yevmenkin void		client_init(void);
2007718ced0SMaksim Yevmenkin 
2017718ced0SMaksim Yevmenkin /* packet.c */
2027718ced0SMaksim Yevmenkin packet_t *	packet_alloc(channel_t *);
2037718ced0SMaksim Yevmenkin void		packet_free(packet_t *);
2047718ced0SMaksim Yevmenkin void		packet_adj(packet_t *, size_t);
2057718ced0SMaksim Yevmenkin pkthdr_t *	pkthdr_alloc(packet_t *);
2067718ced0SMaksim Yevmenkin void		pkthdr_free(pkthdr_t *);
2077718ced0SMaksim Yevmenkin 
2087718ced0SMaksim Yevmenkin /* server.c */
2097718ced0SMaksim Yevmenkin void		server_init(void);
2107718ced0SMaksim Yevmenkin void		server_update(int);
2117718ced0SMaksim Yevmenkin 
2127718ced0SMaksim Yevmenkin /* tap.c */
2137718ced0SMaksim Yevmenkin void		tap_init(void);
214