17718ced0SMaksim Yevmenkin /* $NetBSD: btpand.h,v 1.1 2008/08/17 13:20:57 plunky Exp $ */
27718ced0SMaksim Yevmenkin
37718ced0SMaksim Yevmenkin /*-
4*b61a5730SWarner 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