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