17718ced0SMaksim Yevmenkin /* $NetBSD: btpand.h,v 1.1 2008/08/17 13:20:57 plunky Exp $ */ 27718ced0SMaksim Yevmenkin 37718ced0SMaksim Yevmenkin /*- 4*1de7b4b8SPedro F. Giffuni * SPDX-License-Identifier: BSD-2-Clause-NetBSD 5*1de7b4b8SPedro 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 /* $FreeBSD$ */ 317718ced0SMaksim Yevmenkin 327718ced0SMaksim Yevmenkin #include <sys/types.h> 337718ced0SMaksim Yevmenkin #include <sys/queue.h> 347718ced0SMaksim Yevmenkin #include <sys/socket.h> 357718ced0SMaksim Yevmenkin 367718ced0SMaksim Yevmenkin #include <net/if.h> 377718ced0SMaksim Yevmenkin #include <net/ethernet.h> 387718ced0SMaksim Yevmenkin 397718ced0SMaksim Yevmenkin #include <assert.h> 407718ced0SMaksim Yevmenkin #include <bluetooth.h> 417718ced0SMaksim Yevmenkin #include <stdbool.h> 427718ced0SMaksim Yevmenkin #include <stdlib.h> 437718ced0SMaksim Yevmenkin #include <string.h> 447718ced0SMaksim Yevmenkin #include <syslog.h> 457718ced0SMaksim Yevmenkin 467718ced0SMaksim Yevmenkin #include "event.h" 477718ced0SMaksim Yevmenkin 487718ced0SMaksim Yevmenkin #ifndef __arraycount 497718ced0SMaksim Yevmenkin #define __arraycount(__x) (int)(sizeof((__x)) / sizeof((__x)[0])) 507718ced0SMaksim Yevmenkin #endif 517718ced0SMaksim Yevmenkin 527718ced0SMaksim Yevmenkin #ifndef L2CAP_PSM_INVALID 537718ced0SMaksim Yevmenkin #define L2CAP_PSM_INVALID(psm) (((psm) & 0x0101) != 0x0001) 547718ced0SMaksim Yevmenkin #endif 557718ced0SMaksim Yevmenkin 56905033dcSMaksim Yevmenkin #ifndef L2CAP_PSM_BNEP 57905033dcSMaksim Yevmenkin #define L2CAP_PSM_BNEP 15 58905033dcSMaksim Yevmenkin #endif 59905033dcSMaksim Yevmenkin 607718ced0SMaksim Yevmenkin typedef struct channel channel_t; 617718ced0SMaksim Yevmenkin typedef struct pfilter pfilter_t; 627718ced0SMaksim Yevmenkin typedef struct mfilter mfilter_t; 637718ced0SMaksim Yevmenkin typedef struct packet packet_t; 647718ced0SMaksim Yevmenkin typedef struct pkthdr pkthdr_t; 657718ced0SMaksim Yevmenkin typedef struct pktlist pktlist_t; 667718ced0SMaksim Yevmenkin typedef struct exthdr exthdr_t; 677718ced0SMaksim Yevmenkin typedef struct extlist extlist_t; 687718ced0SMaksim Yevmenkin 697718ced0SMaksim Yevmenkin LIST_HEAD(chlist, channel); 707718ced0SMaksim Yevmenkin STAILQ_HEAD(extlist, exthdr); 717718ced0SMaksim Yevmenkin STAILQ_HEAD(pktlist, pkthdr); 727718ced0SMaksim Yevmenkin 737718ced0SMaksim Yevmenkin enum channel_state { 747718ced0SMaksim Yevmenkin CHANNEL_CLOSED, 757718ced0SMaksim Yevmenkin CHANNEL_WAIT_CONNECT_REQ, 767718ced0SMaksim Yevmenkin CHANNEL_WAIT_CONNECT_RSP, 777718ced0SMaksim Yevmenkin CHANNEL_OPEN, 787718ced0SMaksim Yevmenkin }; 797718ced0SMaksim Yevmenkin 807718ced0SMaksim Yevmenkin #define CHANNEL_MAXQLEN 128 817718ced0SMaksim Yevmenkin 827718ced0SMaksim Yevmenkin /* BNEP or tap channel */ 837718ced0SMaksim Yevmenkin struct channel { 847718ced0SMaksim Yevmenkin enum channel_state state; 857718ced0SMaksim Yevmenkin bool oactive; 867718ced0SMaksim Yevmenkin 877718ced0SMaksim Yevmenkin uint8_t laddr[ETHER_ADDR_LEN]; 887718ced0SMaksim Yevmenkin uint8_t raddr[ETHER_ADDR_LEN]; 897718ced0SMaksim Yevmenkin size_t mru; 907718ced0SMaksim Yevmenkin size_t mtu; 917718ced0SMaksim Yevmenkin 927718ced0SMaksim Yevmenkin int npfilter; 937718ced0SMaksim Yevmenkin pfilter_t * pfilter; 947718ced0SMaksim Yevmenkin 957718ced0SMaksim Yevmenkin int nmfilter; 967718ced0SMaksim Yevmenkin mfilter_t * mfilter; 977718ced0SMaksim Yevmenkin 987718ced0SMaksim Yevmenkin pktlist_t pktlist; 997718ced0SMaksim Yevmenkin int qlen; 1007718ced0SMaksim Yevmenkin 1017718ced0SMaksim Yevmenkin int fd; 1027718ced0SMaksim Yevmenkin struct event rd_ev; 1037718ced0SMaksim Yevmenkin struct event wr_ev; 1047718ced0SMaksim Yevmenkin uint8_t * sendbuf; 1057718ced0SMaksim Yevmenkin 1067718ced0SMaksim Yevmenkin bool (*send)(channel_t *, packet_t *); 1077718ced0SMaksim Yevmenkin bool (*recv)(packet_t *); 1087718ced0SMaksim Yevmenkin 1097718ced0SMaksim Yevmenkin int tick; 1107718ced0SMaksim Yevmenkin 1117718ced0SMaksim Yevmenkin struct pidfh *pfh; 1127718ced0SMaksim Yevmenkin 1137718ced0SMaksim Yevmenkin int refcnt; 1147718ced0SMaksim Yevmenkin LIST_ENTRY(channel) next; 1157718ced0SMaksim Yevmenkin }; 1167718ced0SMaksim Yevmenkin 1177718ced0SMaksim Yevmenkin /* network protocol type filter */ 1187718ced0SMaksim Yevmenkin struct pfilter { 1197718ced0SMaksim Yevmenkin uint16_t start; 1207718ced0SMaksim Yevmenkin uint16_t end; 1217718ced0SMaksim Yevmenkin }; 1227718ced0SMaksim Yevmenkin 1237718ced0SMaksim Yevmenkin /* multicast address filter */ 1247718ced0SMaksim Yevmenkin struct mfilter { 1257718ced0SMaksim Yevmenkin uint8_t start[ETHER_ADDR_LEN]; 1267718ced0SMaksim Yevmenkin uint8_t end[ETHER_ADDR_LEN]; 1277718ced0SMaksim Yevmenkin }; 1287718ced0SMaksim Yevmenkin 1297718ced0SMaksim Yevmenkin /* packet data buffer */ 1307718ced0SMaksim Yevmenkin struct packet { 1317718ced0SMaksim Yevmenkin channel_t * chan; /* source channel */ 1327718ced0SMaksim Yevmenkin uint8_t * dst; /* dest address */ 1337718ced0SMaksim Yevmenkin uint8_t * src; /* source address */ 1347718ced0SMaksim Yevmenkin uint8_t * type; /* protocol type */ 1357718ced0SMaksim Yevmenkin uint8_t * ptr; /* data pointer */ 1367718ced0SMaksim Yevmenkin size_t len; /* data length */ 1377718ced0SMaksim Yevmenkin int refcnt; /* reference count */ 1387718ced0SMaksim Yevmenkin extlist_t extlist;/* extension headers */ 1397718ced0SMaksim Yevmenkin uint8_t buf[0]; /* data starts here */ 1407718ced0SMaksim Yevmenkin }; 1417718ced0SMaksim Yevmenkin 1427718ced0SMaksim Yevmenkin /* extension header */ 1437718ced0SMaksim Yevmenkin struct exthdr { 1447718ced0SMaksim Yevmenkin STAILQ_ENTRY(exthdr) next; 1457718ced0SMaksim Yevmenkin uint8_t * ptr; 1467718ced0SMaksim Yevmenkin uint8_t len; 1477718ced0SMaksim Yevmenkin }; 1487718ced0SMaksim Yevmenkin 1497718ced0SMaksim Yevmenkin /* packet header */ 1507718ced0SMaksim Yevmenkin struct pkthdr { 1517718ced0SMaksim Yevmenkin STAILQ_ENTRY(pkthdr) next; 1527718ced0SMaksim Yevmenkin packet_t * data; 1537718ced0SMaksim Yevmenkin }; 1547718ced0SMaksim Yevmenkin 1557718ced0SMaksim Yevmenkin /* global variables */ 1567718ced0SMaksim Yevmenkin extern const char * control_path; 1577718ced0SMaksim Yevmenkin extern const char * service_name; 1587718ced0SMaksim Yevmenkin extern const char * interface_name; 1597718ced0SMaksim Yevmenkin extern bdaddr_t local_bdaddr; 1607718ced0SMaksim Yevmenkin extern bdaddr_t remote_bdaddr; 1617718ced0SMaksim Yevmenkin extern uint16_t l2cap_psm; 1627718ced0SMaksim Yevmenkin extern int l2cap_mode; 1637718ced0SMaksim Yevmenkin extern uint16_t service_class; 1647718ced0SMaksim Yevmenkin extern int server_limit; 1657718ced0SMaksim Yevmenkin 1667718ced0SMaksim Yevmenkin /* 1677718ced0SMaksim Yevmenkin * Bluetooth addresses are stored the other way around than 1687718ced0SMaksim Yevmenkin * Ethernet addresses even though they are of the same family 1697718ced0SMaksim Yevmenkin */ 1707718ced0SMaksim Yevmenkin static inline void 1717718ced0SMaksim Yevmenkin b2eaddr(void *dst, bdaddr_t *src) 1727718ced0SMaksim Yevmenkin { 1737718ced0SMaksim Yevmenkin uint8_t *d = dst; 1747718ced0SMaksim Yevmenkin int i; 1757718ced0SMaksim Yevmenkin 1767718ced0SMaksim Yevmenkin for (i = 0; i < ETHER_ADDR_LEN; i++) 1777718ced0SMaksim Yevmenkin d[i] = src->b[ETHER_ADDR_LEN - i - 1]; 1787718ced0SMaksim Yevmenkin } 1797718ced0SMaksim Yevmenkin 1807718ced0SMaksim Yevmenkin #define log_err(fmt, args...) syslog(LOG_ERR, fmt , ##args) 1817718ced0SMaksim Yevmenkin #define log_info(fmt, args...) syslog(LOG_INFO, fmt , ##args) 1827718ced0SMaksim Yevmenkin #define log_notice(fmt, args...) syslog(LOG_NOTICE, fmt , ##args) 1837718ced0SMaksim Yevmenkin #define log_debug(fmt, args...) syslog(LOG_DEBUG, "%s: " fmt, __func__ , ##args) 1847718ced0SMaksim Yevmenkin 1857718ced0SMaksim Yevmenkin /* bnep.c */ 1867718ced0SMaksim Yevmenkin bool bnep_send(channel_t *, packet_t *); 1877718ced0SMaksim Yevmenkin bool bnep_recv(packet_t *); 1887fcdc815SDimitry Andric void bnep_send_control(channel_t *, unsigned, ...); 1897718ced0SMaksim Yevmenkin 1907718ced0SMaksim Yevmenkin /* channel.c */ 1917718ced0SMaksim Yevmenkin void channel_init(void); 1927718ced0SMaksim Yevmenkin channel_t * channel_alloc(void); 1937718ced0SMaksim Yevmenkin bool channel_open(channel_t *, int); 1947718ced0SMaksim Yevmenkin void channel_close(channel_t *); 1957718ced0SMaksim Yevmenkin void channel_free(channel_t *); 1967718ced0SMaksim Yevmenkin void channel_timeout(channel_t *, int); 1977718ced0SMaksim Yevmenkin void channel_put(channel_t *, packet_t *); 1987718ced0SMaksim Yevmenkin 1997718ced0SMaksim Yevmenkin /* client.c */ 2007718ced0SMaksim Yevmenkin void client_init(void); 2017718ced0SMaksim Yevmenkin 2027718ced0SMaksim Yevmenkin /* packet.c */ 2037718ced0SMaksim Yevmenkin packet_t * packet_alloc(channel_t *); 2047718ced0SMaksim Yevmenkin void packet_free(packet_t *); 2057718ced0SMaksim Yevmenkin void packet_adj(packet_t *, size_t); 2067718ced0SMaksim Yevmenkin pkthdr_t * pkthdr_alloc(packet_t *); 2077718ced0SMaksim Yevmenkin void pkthdr_free(pkthdr_t *); 2087718ced0SMaksim Yevmenkin 2097718ced0SMaksim Yevmenkin /* server.c */ 2107718ced0SMaksim Yevmenkin void server_init(void); 2117718ced0SMaksim Yevmenkin void server_update(int); 2127718ced0SMaksim Yevmenkin 2137718ced0SMaksim Yevmenkin /* tap.c */ 2147718ced0SMaksim Yevmenkin void tap_init(void); 215