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