11da177e4SLinus Torvalds /* 21da177e4SLinus Torvalds BlueZ - Bluetooth protocol stack for Linux 31da177e4SLinus Torvalds Copyright (C) 2000-2001 Qualcomm Incorporated 40fe8c8d0SIulia Tanasescu Copyright 2023 NXP 51da177e4SLinus Torvalds 61da177e4SLinus Torvalds Written 2000,2001 by Maxim Krasnyansky <maxk@qualcomm.com> 71da177e4SLinus Torvalds 81da177e4SLinus Torvalds This program is free software; you can redistribute it and/or modify 91da177e4SLinus Torvalds it under the terms of the GNU General Public License version 2 as 101da177e4SLinus Torvalds published by the Free Software Foundation; 111da177e4SLinus Torvalds 121da177e4SLinus Torvalds THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 131da177e4SLinus Torvalds OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 141da177e4SLinus Torvalds FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS. 151da177e4SLinus Torvalds IN NO EVENT SHALL THE COPYRIGHT HOLDER(S) AND AUTHOR(S) BE LIABLE FOR ANY 161da177e4SLinus Torvalds CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES 171da177e4SLinus Torvalds WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 181da177e4SLinus Torvalds ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 191da177e4SLinus Torvalds OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 201da177e4SLinus Torvalds 211da177e4SLinus Torvalds ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PATENTS, 221da177e4SLinus Torvalds COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS, RELATING TO USE OF THIS 231da177e4SLinus Torvalds SOFTWARE IS DISCLAIMED. 241da177e4SLinus Torvalds */ 251da177e4SLinus Torvalds 261da177e4SLinus Torvalds #ifndef __BLUETOOTH_H 271da177e4SLinus Torvalds #define __BLUETOOTH_H 281da177e4SLinus Torvalds 291da177e4SLinus Torvalds #include <linux/poll.h> 301da177e4SLinus Torvalds #include <net/sock.h> 31256a06c8SMasatake YAMATO #include <linux/seq_file.h> 321da177e4SLinus Torvalds 339e8305b3SMarcel Holtmann #define BT_SUBSYS_VERSION 2 344037a774SMarcel Holtmann #define BT_SUBSYS_REVISION 22 35dd31506dSMarcel Holtmann 361da177e4SLinus Torvalds #ifndef AF_BLUETOOTH 371da177e4SLinus Torvalds #define AF_BLUETOOTH 31 381da177e4SLinus Torvalds #define PF_BLUETOOTH AF_BLUETOOTH 391da177e4SLinus Torvalds #endif 401da177e4SLinus Torvalds 41d095c1ebSAndrei Emeltchenko /* Bluetooth versions */ 42d095c1ebSAndrei Emeltchenko #define BLUETOOTH_VER_1_1 1 43d095c1ebSAndrei Emeltchenko #define BLUETOOTH_VER_1_2 2 44d095c1ebSAndrei Emeltchenko #define BLUETOOTH_VER_2_0 3 45cde1a8a9SIsmael Ferreras Morezuelas #define BLUETOOTH_VER_2_1 4 46cde1a8a9SIsmael Ferreras Morezuelas #define BLUETOOTH_VER_4_0 6 47d095c1ebSAndrei Emeltchenko 481da177e4SLinus Torvalds /* Reserv for core and drivers use */ 491da177e4SLinus Torvalds #define BT_SKB_RESERVE 8 501da177e4SLinus Torvalds 511da177e4SLinus Torvalds #define BTPROTO_L2CAP 0 521da177e4SLinus Torvalds #define BTPROTO_HCI 1 531da177e4SLinus Torvalds #define BTPROTO_SCO 2 541da177e4SLinus Torvalds #define BTPROTO_RFCOMM 3 551da177e4SLinus Torvalds #define BTPROTO_BNEP 4 561da177e4SLinus Torvalds #define BTPROTO_CMTP 5 571da177e4SLinus Torvalds #define BTPROTO_HIDP 6 581da177e4SLinus Torvalds #define BTPROTO_AVDTP 7 5926afbd82SLuiz Augusto von Dentz #define BTPROTO_ISO 8 6026afbd82SLuiz Augusto von Dentz #define BTPROTO_LAST BTPROTO_ISO 611da177e4SLinus Torvalds 621da177e4SLinus Torvalds #define SOL_HCI 0 631da177e4SLinus Torvalds #define SOL_L2CAP 6 641da177e4SLinus Torvalds #define SOL_SCO 17 651da177e4SLinus Torvalds #define SOL_RFCOMM 18 661da177e4SLinus Torvalds 678c1b2355SMarcel Holtmann #define BT_SECURITY 4 688c1b2355SMarcel Holtmann struct bt_security { 698c1b2355SMarcel Holtmann __u8 level; 708f360119SVinicius Costa Gomes __u8 key_size; 718c1b2355SMarcel Holtmann }; 728c1b2355SMarcel Holtmann #define BT_SECURITY_SDP 0 738c1b2355SMarcel Holtmann #define BT_SECURITY_LOW 1 748c1b2355SMarcel Holtmann #define BT_SECURITY_MEDIUM 2 758c1b2355SMarcel Holtmann #define BT_SECURITY_HIGH 3 767b5a9241SMarcel Holtmann #define BT_SECURITY_FIPS 4 778c1b2355SMarcel Holtmann 78c4f912e1SMarcel Holtmann #define BT_DEFER_SETUP 7 79c4f912e1SMarcel Holtmann 80e702112fSAndrei Emeltchenko #define BT_FLUSHABLE 8 81e702112fSAndrei Emeltchenko 82e702112fSAndrei Emeltchenko #define BT_FLUSHABLE_OFF 0 83e702112fSAndrei Emeltchenko #define BT_FLUSHABLE_ON 1 84e702112fSAndrei Emeltchenko 8514b12d0bSJaikumar Ganesh #define BT_POWER 9 8614b12d0bSJaikumar Ganesh struct bt_power { 8714b12d0bSJaikumar Ganesh __u8 force_active; 8814b12d0bSJaikumar Ganesh }; 8914b12d0bSJaikumar Ganesh #define BT_POWER_FORCE_ACTIVE_OFF 0 9014b12d0bSJaikumar Ganesh #define BT_POWER_FORCE_ACTIVE_ON 1 9114b12d0bSJaikumar Ganesh 92c14968b0SMat Martineau #define BT_CHANNEL_POLICY 10 93c14968b0SMat Martineau 94c14968b0SMat Martineau /* BR/EDR only (default policy) 95c14968b0SMat Martineau * AMP controllers cannot be used. 96c14968b0SMat Martineau * Channel move requests from the remote device are denied. 97c14968b0SMat Martineau * If the L2CAP channel is currently using AMP, move the channel to BR/EDR. 98c14968b0SMat Martineau */ 99c14968b0SMat Martineau #define BT_CHANNEL_POLICY_BREDR_ONLY 0 100c14968b0SMat Martineau 101c14968b0SMat Martineau /* BR/EDR Preferred 102c14968b0SMat Martineau * Allow use of AMP controllers. 103c14968b0SMat Martineau * If the L2CAP channel is currently on AMP, move it to BR/EDR. 104c14968b0SMat Martineau * Channel move requests from the remote device are allowed. 105c14968b0SMat Martineau */ 106c14968b0SMat Martineau #define BT_CHANNEL_POLICY_BREDR_PREFERRED 1 107c14968b0SMat Martineau 108c14968b0SMat Martineau /* AMP Preferred 109c14968b0SMat Martineau * Allow use of AMP controllers 110c14968b0SMat Martineau * If the L2CAP channel is currently on BR/EDR and AMP controller 111c14968b0SMat Martineau * resources are available, initiate a channel move to AMP. 112c14968b0SMat Martineau * Channel move requests from the remote device are allowed. 113c14968b0SMat Martineau * If the L2CAP socket has not been connected yet, try to create 114c14968b0SMat Martineau * and configure the channel directly on an AMP controller rather 115c14968b0SMat Martineau * than BR/EDR. 116c14968b0SMat Martineau */ 117c14968b0SMat Martineau #define BT_CHANNEL_POLICY_AMP_PREFERRED 2 118c14968b0SMat Martineau 119ad10b1a4SFrédéric Dalleau #define BT_VOICE 11 120ad10b1a4SFrédéric Dalleau struct bt_voice { 121ad10b1a4SFrédéric Dalleau __u16 setting; 122ad10b1a4SFrédéric Dalleau }; 123ad10b1a4SFrédéric Dalleau 124ad10b1a4SFrédéric Dalleau #define BT_VOICE_TRANSPARENT 0x0003 125ad10b1a4SFrédéric Dalleau #define BT_VOICE_CVSD_16BIT 0x0060 126ad10b1a4SFrédéric Dalleau 1271f435424SJohan Hedberg #define BT_SNDMTU 12 1281f435424SJohan Hedberg #define BT_RCVMTU 13 129eab2404bSLuiz Augusto von Dentz #define BT_PHY 14 130eab2404bSLuiz Augusto von Dentz 131eab2404bSLuiz Augusto von Dentz #define BT_PHY_BR_1M_1SLOT 0x00000001 132eab2404bSLuiz Augusto von Dentz #define BT_PHY_BR_1M_3SLOT 0x00000002 133eab2404bSLuiz Augusto von Dentz #define BT_PHY_BR_1M_5SLOT 0x00000004 134eab2404bSLuiz Augusto von Dentz #define BT_PHY_EDR_2M_1SLOT 0x00000008 135eab2404bSLuiz Augusto von Dentz #define BT_PHY_EDR_2M_3SLOT 0x00000010 136eab2404bSLuiz Augusto von Dentz #define BT_PHY_EDR_2M_5SLOT 0x00000020 137eab2404bSLuiz Augusto von Dentz #define BT_PHY_EDR_3M_1SLOT 0x00000040 138eab2404bSLuiz Augusto von Dentz #define BT_PHY_EDR_3M_3SLOT 0x00000080 139eab2404bSLuiz Augusto von Dentz #define BT_PHY_EDR_3M_5SLOT 0x00000100 140eab2404bSLuiz Augusto von Dentz #define BT_PHY_LE_1M_TX 0x00000200 141eab2404bSLuiz Augusto von Dentz #define BT_PHY_LE_1M_RX 0x00000400 142eab2404bSLuiz Augusto von Dentz #define BT_PHY_LE_2M_TX 0x00000800 143eab2404bSLuiz Augusto von Dentz #define BT_PHY_LE_2M_RX 0x00001000 144eab2404bSLuiz Augusto von Dentz #define BT_PHY_LE_CODED_TX 0x00002000 145eab2404bSLuiz Augusto von Dentz #define BT_PHY_LE_CODED_RX 0x00004000 1461f435424SJohan Hedberg 1473ee7b7cdSLuiz Augusto von Dentz #define BT_MODE 15 1483ee7b7cdSLuiz Augusto von Dentz 1493ee7b7cdSLuiz Augusto von Dentz #define BT_MODE_BASIC 0x00 1503ee7b7cdSLuiz Augusto von Dentz #define BT_MODE_ERTM 0x01 1513ee7b7cdSLuiz Augusto von Dentz #define BT_MODE_STREAMING 0x02 1523ee7b7cdSLuiz Augusto von Dentz #define BT_MODE_LE_FLOWCTL 0x03 1533ee7b7cdSLuiz Augusto von Dentz #define BT_MODE_EXT_FLOWCTL 0x04 1543ee7b7cdSLuiz Augusto von Dentz 15500398e1dSAlain Michaud #define BT_PKT_STATUS 16 15600398e1dSAlain Michaud 15700398e1dSAlain Michaud #define BT_SCM_PKT_STATUS 0x03 15800398e1dSAlain Michaud 15926afbd82SLuiz Augusto von Dentz #define BT_ISO_QOS 17 16026afbd82SLuiz Augusto von Dentz 16126afbd82SLuiz Augusto von Dentz #define BT_ISO_QOS_CIG_UNSET 0xff 16226afbd82SLuiz Augusto von Dentz #define BT_ISO_QOS_CIS_UNSET 0xff 16326afbd82SLuiz Augusto von Dentz 164eca0ae4aSLuiz Augusto von Dentz #define BT_ISO_QOS_BIG_UNSET 0xff 165eca0ae4aSLuiz Augusto von Dentz #define BT_ISO_QOS_BIS_UNSET 0xff 166eca0ae4aSLuiz Augusto von Dentz 167c8321645SLuiz Augusto von Dentz #define BT_ISO_SYNC_TIMEOUT 0x07d0 /* 20 secs */ 168c8321645SLuiz Augusto von Dentz 16926afbd82SLuiz Augusto von Dentz struct bt_iso_io_qos { 17026afbd82SLuiz Augusto von Dentz __u32 interval; 17126afbd82SLuiz Augusto von Dentz __u16 latency; 17226afbd82SLuiz Augusto von Dentz __u16 sdu; 17326afbd82SLuiz Augusto von Dentz __u8 phy; 17426afbd82SLuiz Augusto von Dentz __u8 rtn; 17526afbd82SLuiz Augusto von Dentz }; 17626afbd82SLuiz Augusto von Dentz 1770fe8c8d0SIulia Tanasescu struct bt_iso_ucast_qos { 17826afbd82SLuiz Augusto von Dentz __u8 cig; 17926afbd82SLuiz Augusto von Dentz __u8 cis; 18026afbd82SLuiz Augusto von Dentz __u8 sca; 18126afbd82SLuiz Augusto von Dentz __u8 packing; 18226afbd82SLuiz Augusto von Dentz __u8 framing; 18326afbd82SLuiz Augusto von Dentz struct bt_iso_io_qos in; 18426afbd82SLuiz Augusto von Dentz struct bt_iso_io_qos out; 18526afbd82SLuiz Augusto von Dentz }; 18626afbd82SLuiz Augusto von Dentz 1870fe8c8d0SIulia Tanasescu struct bt_iso_bcast_qos { 1880fe8c8d0SIulia Tanasescu __u8 big; 1890fe8c8d0SIulia Tanasescu __u8 bis; 19014f0dcecSLuiz Augusto von Dentz __u8 sync_factor; 1910fe8c8d0SIulia Tanasescu __u8 packing; 1920fe8c8d0SIulia Tanasescu __u8 framing; 1930fe8c8d0SIulia Tanasescu struct bt_iso_io_qos in; 1940fe8c8d0SIulia Tanasescu struct bt_iso_io_qos out; 1950fe8c8d0SIulia Tanasescu __u8 encryption; 1960fe8c8d0SIulia Tanasescu __u8 bcode[16]; 1970fe8c8d0SIulia Tanasescu __u8 options; 1980fe8c8d0SIulia Tanasescu __u16 skip; 1990fe8c8d0SIulia Tanasescu __u16 sync_timeout; 2000fe8c8d0SIulia Tanasescu __u8 sync_cte_type; 2010fe8c8d0SIulia Tanasescu __u8 mse; 2020fe8c8d0SIulia Tanasescu __u16 timeout; 2030fe8c8d0SIulia Tanasescu }; 2040fe8c8d0SIulia Tanasescu 2050fe8c8d0SIulia Tanasescu struct bt_iso_qos { 2060fe8c8d0SIulia Tanasescu union { 2070fe8c8d0SIulia Tanasescu struct bt_iso_ucast_qos ucast; 2080fe8c8d0SIulia Tanasescu struct bt_iso_bcast_qos bcast; 2090fe8c8d0SIulia Tanasescu }; 2100fe8c8d0SIulia Tanasescu }; 2110fe8c8d0SIulia Tanasescu 21226afbd82SLuiz Augusto von Dentz #define BT_ISO_PHY_1M 0x01 21326afbd82SLuiz Augusto von Dentz #define BT_ISO_PHY_2M 0x02 21426afbd82SLuiz Augusto von Dentz #define BT_ISO_PHY_CODED 0x04 21526afbd82SLuiz Augusto von Dentz #define BT_ISO_PHY_ANY (BT_ISO_PHY_1M | BT_ISO_PHY_2M | \ 21626afbd82SLuiz Augusto von Dentz BT_ISO_PHY_CODED) 21726afbd82SLuiz Augusto von Dentz 218248733e8SKiran K #define BT_CODEC 19 219248733e8SKiran K 220248733e8SKiran K struct bt_codec_caps { 221248733e8SKiran K __u8 len; 222248733e8SKiran K __u8 data[]; 223248733e8SKiran K } __packed; 224248733e8SKiran K 225248733e8SKiran K struct bt_codec { 226248733e8SKiran K __u8 id; 227248733e8SKiran K __u16 cid; 228248733e8SKiran K __u16 vid; 229248733e8SKiran K __u8 data_path; 230248733e8SKiran K __u8 num_caps; 231248733e8SKiran K } __packed; 232248733e8SKiran K 233248733e8SKiran K struct bt_codecs { 234248733e8SKiran K __u8 num_codecs; 235248733e8SKiran K struct bt_codec codecs[]; 236248733e8SKiran K } __packed; 237248733e8SKiran K 238f6873401SKiran K #define BT_CODEC_CVSD 0x02 239b2af264aSKiran K #define BT_CODEC_TRANSPARENT 0x03 240904c139aSKiran K #define BT_CODEC_MSBC 0x05 241f6873401SKiran K 242f764a6c2SLuiz Augusto von Dentz #define BT_ISO_BASE 20 243f764a6c2SLuiz Augusto von Dentz 2443ed7003eSJoe Perches __printf(1, 2) 2452b0bf6c8SJoe Perches void bt_info(const char *fmt, ...); 2463ed7003eSJoe Perches __printf(1, 2) 247594b31eaSFrederic Danis void bt_warn(const char *fmt, ...); 248594b31eaSFrederic Danis __printf(1, 2) 2492b0bf6c8SJoe Perches void bt_err(const char *fmt, ...); 250e625e50cSMarcel Holtmann #if IS_ENABLED(CONFIG_BT_FEATURE_DEBUG) 251e625e50cSMarcel Holtmann void bt_dbg_set(bool enable); 252e625e50cSMarcel Holtmann bool bt_dbg_get(void); 253e625e50cSMarcel Holtmann __printf(1, 2) 254e625e50cSMarcel Holtmann void bt_dbg(const char *fmt, ...); 255e625e50cSMarcel Holtmann #endif 256e781b7f7SSzymon Janc __printf(1, 2) 25736278a5dSAlain Michaud void bt_warn_ratelimited(const char *fmt, ...); 25836278a5dSAlain Michaud __printf(1, 2) 259e781b7f7SSzymon Janc void bt_err_ratelimited(const char *fmt, ...); 260e1447d8dSJoe Perches 2613ed7003eSJoe Perches #define BT_INFO(fmt, ...) bt_info(fmt "\n", ##__VA_ARGS__) 262594b31eaSFrederic Danis #define BT_WARN(fmt, ...) bt_warn(fmt "\n", ##__VA_ARGS__) 2633ed7003eSJoe Perches #define BT_ERR(fmt, ...) bt_err(fmt "\n", ##__VA_ARGS__) 264e625e50cSMarcel Holtmann 265e625e50cSMarcel Holtmann #if IS_ENABLED(CONFIG_BT_FEATURE_DEBUG) 266e625e50cSMarcel Holtmann #define BT_DBG(fmt, ...) bt_dbg(fmt "\n", ##__VA_ARGS__) 267e625e50cSMarcel Holtmann #else 2683ed7003eSJoe Perches #define BT_DBG(fmt, ...) pr_debug(fmt "\n", ##__VA_ARGS__) 269e625e50cSMarcel Holtmann #endif 2701da177e4SLinus Torvalds 2719b392e0eSLuiz Augusto von Dentz #define bt_dev_name(hdev) ((hdev) ? (hdev)->name : "null") 2729b392e0eSLuiz Augusto von Dentz 2736f558b70SLoic Poulain #define bt_dev_info(hdev, fmt, ...) \ 2749b392e0eSLuiz Augusto von Dentz BT_INFO("%s: " fmt, bt_dev_name(hdev), ##__VA_ARGS__) 275594b31eaSFrederic Danis #define bt_dev_warn(hdev, fmt, ...) \ 2769b392e0eSLuiz Augusto von Dentz BT_WARN("%s: " fmt, bt_dev_name(hdev), ##__VA_ARGS__) 2776f558b70SLoic Poulain #define bt_dev_err(hdev, fmt, ...) \ 2789b392e0eSLuiz Augusto von Dentz BT_ERR("%s: " fmt, bt_dev_name(hdev), ##__VA_ARGS__) 2796f558b70SLoic Poulain #define bt_dev_dbg(hdev, fmt, ...) \ 2809b392e0eSLuiz Augusto von Dentz BT_DBG("%s: " fmt, bt_dev_name(hdev), ##__VA_ARGS__) 2816f558b70SLoic Poulain 28236278a5dSAlain Michaud #define bt_dev_warn_ratelimited(hdev, fmt, ...) \ 2839b392e0eSLuiz Augusto von Dentz bt_warn_ratelimited("%s: " fmt, bt_dev_name(hdev), ##__VA_ARGS__) 2842064ee33SMarcel Holtmann #define bt_dev_err_ratelimited(hdev, fmt, ...) \ 2859b392e0eSLuiz Augusto von Dentz bt_err_ratelimited("%s: " fmt, bt_dev_name(hdev), ##__VA_ARGS__) 2862064ee33SMarcel Holtmann 2871da177e4SLinus Torvalds /* Connection and socket states */ 2881da177e4SLinus Torvalds enum { 2891da177e4SLinus Torvalds BT_CONNECTED = 1, /* Equal to TCP_ESTABLISHED to make net code happy */ 2901da177e4SLinus Torvalds BT_OPEN, 2911da177e4SLinus Torvalds BT_BOUND, 2921da177e4SLinus Torvalds BT_LISTEN, 2931da177e4SLinus Torvalds BT_CONNECT, 2941da177e4SLinus Torvalds BT_CONNECT2, 2951da177e4SLinus Torvalds BT_CONFIG, 2961da177e4SLinus Torvalds BT_DISCONN, 2971da177e4SLinus Torvalds BT_CLOSED 2981da177e4SLinus Torvalds }; 2991da177e4SLinus Torvalds 30020d1803aSAndrei Emeltchenko /* If unused will be removed by compiler */ 30120d1803aSAndrei Emeltchenko static inline const char *state_to_string(int state) 30220d1803aSAndrei Emeltchenko { 30320d1803aSAndrei Emeltchenko switch (state) { 30420d1803aSAndrei Emeltchenko case BT_CONNECTED: 30520d1803aSAndrei Emeltchenko return "BT_CONNECTED"; 30620d1803aSAndrei Emeltchenko case BT_OPEN: 30720d1803aSAndrei Emeltchenko return "BT_OPEN"; 30820d1803aSAndrei Emeltchenko case BT_BOUND: 30920d1803aSAndrei Emeltchenko return "BT_BOUND"; 31020d1803aSAndrei Emeltchenko case BT_LISTEN: 31120d1803aSAndrei Emeltchenko return "BT_LISTEN"; 31220d1803aSAndrei Emeltchenko case BT_CONNECT: 31320d1803aSAndrei Emeltchenko return "BT_CONNECT"; 31420d1803aSAndrei Emeltchenko case BT_CONNECT2: 31520d1803aSAndrei Emeltchenko return "BT_CONNECT2"; 31620d1803aSAndrei Emeltchenko case BT_CONFIG: 31720d1803aSAndrei Emeltchenko return "BT_CONFIG"; 31820d1803aSAndrei Emeltchenko case BT_DISCONN: 31920d1803aSAndrei Emeltchenko return "BT_DISCONN"; 32020d1803aSAndrei Emeltchenko case BT_CLOSED: 32120d1803aSAndrei Emeltchenko return "BT_CLOSED"; 32220d1803aSAndrei Emeltchenko } 32320d1803aSAndrei Emeltchenko 32420d1803aSAndrei Emeltchenko return "invalid state"; 32520d1803aSAndrei Emeltchenko } 32620d1803aSAndrei Emeltchenko 3271da177e4SLinus Torvalds /* BD Address */ 3281da177e4SLinus Torvalds typedef struct { 3291da177e4SLinus Torvalds __u8 b[6]; 33066c853ccSGustavo F. Padovan } __packed bdaddr_t; 3311da177e4SLinus Torvalds 332591f47f3SAndre Guedes /* BD Address type */ 333591f47f3SAndre Guedes #define BDADDR_BREDR 0x00 334591f47f3SAndre Guedes #define BDADDR_LE_PUBLIC 0x01 335591f47f3SAndre Guedes #define BDADDR_LE_RANDOM 0x02 336591f47f3SAndre Guedes 33721fcf572SPavel Machek static inline bool bdaddr_type_is_valid(u8 type) 338679efe2bSJohan Hedberg { 339679efe2bSJohan Hedberg switch (type) { 340679efe2bSJohan Hedberg case BDADDR_BREDR: 341679efe2bSJohan Hedberg case BDADDR_LE_PUBLIC: 342679efe2bSJohan Hedberg case BDADDR_LE_RANDOM: 343679efe2bSJohan Hedberg return true; 344679efe2bSJohan Hedberg } 345679efe2bSJohan Hedberg 346679efe2bSJohan Hedberg return false; 347679efe2bSJohan Hedberg } 348679efe2bSJohan Hedberg 34921fcf572SPavel Machek static inline bool bdaddr_type_is_le(u8 type) 350679efe2bSJohan Hedberg { 351679efe2bSJohan Hedberg switch (type) { 352679efe2bSJohan Hedberg case BDADDR_LE_PUBLIC: 353679efe2bSJohan Hedberg case BDADDR_LE_RANDOM: 354679efe2bSJohan Hedberg return true; 355679efe2bSJohan Hedberg } 356679efe2bSJohan Hedberg 357679efe2bSJohan Hedberg return false; 358679efe2bSJohan Hedberg } 359679efe2bSJohan Hedberg 3601da177e4SLinus Torvalds #define BDADDR_ANY (&(bdaddr_t) {{0, 0, 0, 0, 0, 0}}) 361a59ac2f7SMarcel Holtmann #define BDADDR_NONE (&(bdaddr_t) {{0xff, 0xff, 0xff, 0xff, 0xff, 0xff}}) 3621da177e4SLinus Torvalds 3631da177e4SLinus Torvalds /* Copy, swap, convert BD Address */ 364f53c20e9SDavid Herrmann static inline int bacmp(const bdaddr_t *ba1, const bdaddr_t *ba2) 3651da177e4SLinus Torvalds { 3661da177e4SLinus Torvalds return memcmp(ba1, ba2, sizeof(bdaddr_t)); 3671da177e4SLinus Torvalds } 368f53c20e9SDavid Herrmann static inline void bacpy(bdaddr_t *dst, const bdaddr_t *src) 3691da177e4SLinus Torvalds { 3701da177e4SLinus Torvalds memcpy(dst, src, sizeof(bdaddr_t)); 3711da177e4SLinus Torvalds } 3721da177e4SLinus Torvalds 37365bce462SLoic Poulain void baswap(bdaddr_t *dst, const bdaddr_t *src); 3741da177e4SLinus Torvalds 3751da177e4SLinus Torvalds /* Common socket structures and functions */ 3761da177e4SLinus Torvalds 3771da177e4SLinus Torvalds #define bt_sk(__sk) ((struct bt_sock *) __sk) 3781da177e4SLinus Torvalds 3791da177e4SLinus Torvalds struct bt_sock { 3801da177e4SLinus Torvalds struct sock sk; 3811da177e4SLinus Torvalds struct list_head accept_q; 3821da177e4SLinus Torvalds struct sock *parent; 383c5daa683SGustavo Padovan unsigned long flags; 384d9763698SMarcel Holtmann void (*skb_msg_name)(struct sk_buff *, void *, int *); 38500398e1dSAlain Michaud void (*skb_put_cmsg)(struct sk_buff *, struct msghdr *, struct sock *); 386c5daa683SGustavo Padovan }; 387c5daa683SGustavo Padovan 388c5daa683SGustavo Padovan enum { 389c5daa683SGustavo Padovan BT_SK_DEFER_SETUP, 390c5daa683SGustavo Padovan BT_SK_SUSPEND, 3913f19ffb2SLuiz Augusto von Dentz BT_SK_PKT_STATUS 3921da177e4SLinus Torvalds }; 3931da177e4SLinus Torvalds 3941da177e4SLinus Torvalds struct bt_sock_list { 3951da177e4SLinus Torvalds struct hlist_head head; 3961da177e4SLinus Torvalds rwlock_t lock; 397256a06c8SMasatake YAMATO #ifdef CONFIG_PROC_FS 398256a06c8SMasatake YAMATO int (* custom_seq_show)(struct seq_file *, void *); 399256a06c8SMasatake YAMATO #endif 4001da177e4SLinus Torvalds }; 4011da177e4SLinus Torvalds 402ec1b4cf7SStephen Hemminger int bt_sock_register(int proto, const struct net_proto_family *ops); 403be9f97f0SDavid Herrmann void bt_sock_unregister(int proto); 4041da177e4SLinus Torvalds void bt_sock_link(struct bt_sock_list *l, struct sock *s); 4051da177e4SLinus Torvalds void bt_sock_unlink(struct bt_sock_list *l, struct sock *s); 4066bfa273eSLuiz Augusto von Dentz struct sock *bt_sock_alloc(struct net *net, struct socket *sock, 4076bfa273eSLuiz Augusto von Dentz struct proto *prot, int proto, gfp_t prio, int kern); 4081b784140SYing Xue int bt_sock_recvmsg(struct socket *sock, struct msghdr *msg, size_t len, 4091b784140SYing Xue int flags); 4101b784140SYing Xue int bt_sock_stream_recvmsg(struct socket *sock, struct msghdr *msg, 4111b784140SYing Xue size_t len, int flags); 412a11e1d43SLinus Torvalds __poll_t bt_sock_poll(struct file *file, struct socket *sock, poll_table *wait); 4133241ad82SMarcel Holtmann int bt_sock_ioctl(struct socket *sock, unsigned int cmd, unsigned long arg); 4141da177e4SLinus Torvalds int bt_sock_wait_state(struct sock *sk, int state, unsigned long timeo); 415da891217SGavin Li int bt_sock_wait_ready(struct sock *sk, unsigned int msg_flags); 4161da177e4SLinus Torvalds 417c4f5627fSMatthias Kaehlcke void bt_accept_enqueue(struct sock *parent, struct sock *sk, bool bh); 4181da177e4SLinus Torvalds void bt_accept_unlink(struct sock *sk); 4191da177e4SLinus Torvalds struct sock *bt_accept_dequeue(struct sock *parent, struct socket *newsock); 4201da177e4SLinus Torvalds 4211da177e4SLinus Torvalds /* Skb helpers */ 42200e3112cSMat Martineau struct l2cap_ctrl { 42321fcf572SPavel Machek u8 sframe:1, 42400e3112cSMat Martineau poll:1, 42500e3112cSMat Martineau final:1, 42600e3112cSMat Martineau fcs:1, 42700e3112cSMat Martineau sar:2, 42800e3112cSMat Martineau super:2; 42921fcf572SPavel Machek 43021fcf572SPavel Machek u16 reqseq; 43121fcf572SPavel Machek u16 txseq; 43221fcf572SPavel Machek u8 retries; 433a4368ff3SJohan Hedberg __le16 psm; 434a4368ff3SJohan Hedberg bdaddr_t bdaddr; 435a4368ff3SJohan Hedberg struct l2cap_chan *chan; 43600e3112cSMat Martineau }; 43700e3112cSMat Martineau 4383119ae95SJohan Hedberg struct hci_dev; 4393119ae95SJohan Hedberg 4401904a853SMarcel Holtmann typedef void (*hci_req_complete_t)(struct hci_dev *hdev, u8 status, u16 opcode); 441e6214487SJohan Hedberg typedef void (*hci_req_complete_skb_t)(struct hci_dev *hdev, u8 status, 442e6214487SJohan Hedberg u16 opcode, struct sk_buff *skb); 4433119ae95SJohan Hedberg 44444d27137SJohan Hedberg #define HCI_REQ_START BIT(0) 44544d27137SJohan Hedberg #define HCI_REQ_SKB BIT(1) 44644d27137SJohan Hedberg 447242c0ebdSMarcel Holtmann struct hci_ctrl { 448cba6b758SLuiz Augusto von Dentz struct sock *sk; 44921fcf572SPavel Machek u16 opcode; 45044d27137SJohan Hedberg u8 req_flags; 451242c0ebdSMarcel Holtmann u8 req_event; 45244d27137SJohan Hedberg union { 453242c0ebdSMarcel Holtmann hci_req_complete_t req_complete; 454242c0ebdSMarcel Holtmann hci_req_complete_skb_t req_complete_skb; 455db6e3e8dSJohan Hedberg }; 45644d27137SJohan Hedberg }; 457db6e3e8dSJohan Hedberg 4588aca46f9SLuiz Augusto von Dentz struct mgmt_ctrl { 4598aca46f9SLuiz Augusto von Dentz struct hci_dev *hdev; 4608aca46f9SLuiz Augusto von Dentz u16 opcode; 4618aca46f9SLuiz Augusto von Dentz }; 4628aca46f9SLuiz Augusto von Dentz 4631da177e4SLinus Torvalds struct bt_skb_cb { 46421fcf572SPavel Machek u8 pkt_type; 46521fcf572SPavel Machek u8 force_active; 46621fcf572SPavel Machek u16 expect; 46721fcf572SPavel Machek u8 incoming:1; 4683f19ffb2SLuiz Augusto von Dentz u8 pkt_status:2; 469db6e3e8dSJohan Hedberg union { 470a4368ff3SJohan Hedberg struct l2cap_ctrl l2cap; 471242c0ebdSMarcel Holtmann struct hci_ctrl hci; 4728aca46f9SLuiz Augusto von Dentz struct mgmt_ctrl mgmt; 47369ae5065SLuiz Augusto von Dentz struct scm_creds creds; 474db6e3e8dSJohan Hedberg }; 4751da177e4SLinus Torvalds }; 4761c2acffbSGustavo F. Padovan #define bt_cb(skb) ((struct bt_skb_cb *)((skb)->cb)) 4771da177e4SLinus Torvalds 478f5c4a42aSMarcel Holtmann #define hci_skb_pkt_type(skb) bt_cb((skb))->pkt_type 4793f19ffb2SLuiz Augusto von Dentz #define hci_skb_pkt_status(skb) bt_cb((skb))->pkt_status 480f5c4a42aSMarcel Holtmann #define hci_skb_expect(skb) bt_cb((skb))->expect 481f5c4a42aSMarcel Holtmann #define hci_skb_opcode(skb) bt_cb((skb))->hci.opcode 48285b56857SLuiz Augusto von Dentz #define hci_skb_event(skb) bt_cb((skb))->hci.req_event 483cba6b758SLuiz Augusto von Dentz #define hci_skb_sk(skb) bt_cb((skb))->hci.sk 484f5c4a42aSMarcel Holtmann 485dd0fc66fSAl Viro static inline struct sk_buff *bt_skb_alloc(unsigned int len, gfp_t how) 4861da177e4SLinus Torvalds { 4871da177e4SLinus Torvalds struct sk_buff *skb; 4881da177e4SLinus Torvalds 489c3c7ea65SGustavo Padovan skb = alloc_skb(len + BT_SKB_RESERVE, how); 4905fcc86bdSJohan Hedberg if (skb) 4911da177e4SLinus Torvalds skb_reserve(skb, BT_SKB_RESERVE); 4921da177e4SLinus Torvalds return skb; 4931da177e4SLinus Torvalds } 4941da177e4SLinus Torvalds 4955a9d0a3fSWaldemar Rymarkiewicz static inline struct sk_buff *bt_skb_send_alloc(struct sock *sk, 4965a9d0a3fSWaldemar Rymarkiewicz unsigned long len, int nb, int *err) 4971da177e4SLinus Torvalds { 4981da177e4SLinus Torvalds struct sk_buff *skb; 4991da177e4SLinus Torvalds 500c3c7ea65SGustavo Padovan skb = sock_alloc_send_skb(sk, len + BT_SKB_RESERVE, nb, err); 5015fcc86bdSJohan Hedberg if (skb) 5021da177e4SLinus Torvalds skb_reserve(skb, BT_SKB_RESERVE); 503e454c844SGustavo F. Padovan 504e454c844SGustavo F. Padovan if (!skb && *err) 505e454c844SGustavo F. Padovan return NULL; 506e454c844SGustavo F. Padovan 507e454c844SGustavo F. Padovan *err = sock_error(sk); 508e454c844SGustavo F. Padovan if (*err) 509e454c844SGustavo F. Padovan goto out; 510e454c844SGustavo F. Padovan 511e454c844SGustavo F. Padovan if (sk->sk_shutdown) { 512e454c844SGustavo F. Padovan *err = -ECONNRESET; 513e454c844SGustavo F. Padovan goto out; 514e454c844SGustavo F. Padovan } 5151da177e4SLinus Torvalds 5161da177e4SLinus Torvalds return skb; 517e454c844SGustavo F. Padovan 518e454c844SGustavo F. Padovan out: 519e454c844SGustavo F. Padovan kfree_skb(skb); 520e454c844SGustavo F. Padovan return NULL; 5211da177e4SLinus Torvalds } 5221da177e4SLinus Torvalds 52338f64f65SLuiz Augusto von Dentz /* Shall not be called with lock_sock held */ 52438f64f65SLuiz Augusto von Dentz static inline struct sk_buff *bt_skb_sendmsg(struct sock *sk, 52538f64f65SLuiz Augusto von Dentz struct msghdr *msg, 52638f64f65SLuiz Augusto von Dentz size_t len, size_t mtu, 52738f64f65SLuiz Augusto von Dentz size_t headroom, size_t tailroom) 52838f64f65SLuiz Augusto von Dentz { 52938f64f65SLuiz Augusto von Dentz struct sk_buff *skb; 53038f64f65SLuiz Augusto von Dentz size_t size = min_t(size_t, len, mtu); 53138f64f65SLuiz Augusto von Dentz int err; 53238f64f65SLuiz Augusto von Dentz 53338f64f65SLuiz Augusto von Dentz skb = bt_skb_send_alloc(sk, size + headroom + tailroom, 53438f64f65SLuiz Augusto von Dentz msg->msg_flags & MSG_DONTWAIT, &err); 53538f64f65SLuiz Augusto von Dentz if (!skb) 53638f64f65SLuiz Augusto von Dentz return ERR_PTR(err); 53738f64f65SLuiz Augusto von Dentz 53838f64f65SLuiz Augusto von Dentz skb_reserve(skb, headroom); 53938f64f65SLuiz Augusto von Dentz skb_tailroom_reserve(skb, mtu, tailroom); 54038f64f65SLuiz Augusto von Dentz 54138f64f65SLuiz Augusto von Dentz if (!copy_from_iter_full(skb_put(skb, size), size, &msg->msg_iter)) { 54238f64f65SLuiz Augusto von Dentz kfree_skb(skb); 54338f64f65SLuiz Augusto von Dentz return ERR_PTR(-EFAULT); 54438f64f65SLuiz Augusto von Dentz } 54538f64f65SLuiz Augusto von Dentz 54638f64f65SLuiz Augusto von Dentz skb->priority = sk->sk_priority; 54738f64f65SLuiz Augusto von Dentz 54838f64f65SLuiz Augusto von Dentz return skb; 54938f64f65SLuiz Augusto von Dentz } 55038f64f65SLuiz Augusto von Dentz 55197e4e802SLuiz Augusto von Dentz /* Similar to bt_skb_sendmsg but can split the msg into multiple fragments 55297e4e802SLuiz Augusto von Dentz * accourding to the MTU. 55397e4e802SLuiz Augusto von Dentz */ 55497e4e802SLuiz Augusto von Dentz static inline struct sk_buff *bt_skb_sendmmsg(struct sock *sk, 55597e4e802SLuiz Augusto von Dentz struct msghdr *msg, 55697e4e802SLuiz Augusto von Dentz size_t len, size_t mtu, 55797e4e802SLuiz Augusto von Dentz size_t headroom, size_t tailroom) 55897e4e802SLuiz Augusto von Dentz { 55997e4e802SLuiz Augusto von Dentz struct sk_buff *skb, **frag; 56097e4e802SLuiz Augusto von Dentz 56197e4e802SLuiz Augusto von Dentz skb = bt_skb_sendmsg(sk, msg, len, mtu, headroom, tailroom); 5626f43f616SDan Carpenter if (IS_ERR(skb)) 56397e4e802SLuiz Augusto von Dentz return skb; 56497e4e802SLuiz Augusto von Dentz 56597e4e802SLuiz Augusto von Dentz len -= skb->len; 56697e4e802SLuiz Augusto von Dentz if (!len) 56797e4e802SLuiz Augusto von Dentz return skb; 56897e4e802SLuiz Augusto von Dentz 56997e4e802SLuiz Augusto von Dentz /* Add remaining data over MTU as continuation fragments */ 57097e4e802SLuiz Augusto von Dentz frag = &skb_shinfo(skb)->frag_list; 57197e4e802SLuiz Augusto von Dentz while (len) { 57297e4e802SLuiz Augusto von Dentz struct sk_buff *tmp; 57397e4e802SLuiz Augusto von Dentz 57497e4e802SLuiz Augusto von Dentz tmp = bt_skb_sendmsg(sk, msg, len, mtu, headroom, tailroom); 575266191aaSLuiz Augusto von Dentz if (IS_ERR(tmp)) { 57629fb6083SLuiz Augusto von Dentz return skb; 57797e4e802SLuiz Augusto von Dentz } 57897e4e802SLuiz Augusto von Dentz 57997e4e802SLuiz Augusto von Dentz len -= tmp->len; 58097e4e802SLuiz Augusto von Dentz 58197e4e802SLuiz Augusto von Dentz *frag = tmp; 58297e4e802SLuiz Augusto von Dentz frag = &(*frag)->next; 58397e4e802SLuiz Augusto von Dentz } 58497e4e802SLuiz Augusto von Dentz 58597e4e802SLuiz Augusto von Dentz return skb; 58697e4e802SLuiz Augusto von Dentz } 58797e4e802SLuiz Augusto von Dentz 588*72473db9SLuiz Augusto von Dentz static inline int bt_copy_from_sockptr(void *dst, size_t dst_size, 589*72473db9SLuiz Augusto von Dentz sockptr_t src, size_t src_size) 590*72473db9SLuiz Augusto von Dentz { 591*72473db9SLuiz Augusto von Dentz if (dst_size > src_size) 592*72473db9SLuiz Augusto von Dentz return -EINVAL; 593*72473db9SLuiz Augusto von Dentz 594*72473db9SLuiz Augusto von Dentz return copy_from_sockptr(dst, src, dst_size); 595*72473db9SLuiz Augusto von Dentz } 596*72473db9SLuiz Augusto von Dentz 59721fcf572SPavel Machek int bt_to_errno(u16 code); 598ca2045e0SLuiz Augusto von Dentz __u8 bt_status(int err); 5991da177e4SLinus Torvalds 6006befc644SMarcel Holtmann void hci_sock_set_flag(struct sock *sk, int nr); 6016befc644SMarcel Holtmann void hci_sock_clear_flag(struct sock *sk, int nr); 602c85be545SMarcel Holtmann int hci_sock_test_flag(struct sock *sk, int nr); 603d0f172b1SJohan Hedberg unsigned short hci_sock_get_channel(struct sock *sk); 60470ecce91SMarcel Holtmann u32 hci_sock_get_cookie(struct sock *sk); 6056befc644SMarcel Holtmann 606e74e58f8SJoe Perches int hci_sock_init(void); 607e74e58f8SJoe Perches void hci_sock_cleanup(void); 6086516455dSMarcel Holtmann 609e74e58f8SJoe Perches int bt_sysfs_init(void); 610e74e58f8SJoe Perches void bt_sysfs_cleanup(void); 6116516455dSMarcel Holtmann 612e74e58f8SJoe Perches int bt_procfs_init(struct net *net, const char *name, 613256a06c8SMasatake YAMATO struct bt_sock_list *sk_list, 614256a06c8SMasatake YAMATO int (*seq_show)(struct seq_file *, void *)); 615e74e58f8SJoe Perches void bt_procfs_cleanup(struct net *net, const char *name); 616256a06c8SMasatake YAMATO 617aef7d97cSMarcel Holtmann extern struct dentry *bt_debugfs; 618be9d1227SMarcel Holtmann 61964274518SGustavo F. Padovan int l2cap_init(void); 62064274518SGustavo F. Padovan void l2cap_exit(void); 62164274518SGustavo F. Padovan 622ff50e8afSArron Wang #if IS_ENABLED(CONFIG_BT_BREDR) 62364274518SGustavo F. Padovan int sco_init(void); 62464274518SGustavo F. Padovan void sco_exit(void); 625ff50e8afSArron Wang #else 626ff50e8afSArron Wang static inline int sco_init(void) 627ff50e8afSArron Wang { 628ff50e8afSArron Wang return 0; 629ff50e8afSArron Wang } 630ff50e8afSArron Wang 631ff50e8afSArron Wang static inline void sco_exit(void) 632ff50e8afSArron Wang { 633ff50e8afSArron Wang } 634ff50e8afSArron Wang #endif 63564274518SGustavo F. Padovan 636ccf74f23SLuiz Augusto von Dentz #if IS_ENABLED(CONFIG_BT_LE) 637ccf74f23SLuiz Augusto von Dentz int iso_init(void); 638ccf74f23SLuiz Augusto von Dentz int iso_exit(void); 639ccf74f23SLuiz Augusto von Dentz bool iso_enabled(void); 640ccf74f23SLuiz Augusto von Dentz #else 641ccf74f23SLuiz Augusto von Dentz static inline int iso_init(void) 642ccf74f23SLuiz Augusto von Dentz { 643ccf74f23SLuiz Augusto von Dentz return 0; 644ccf74f23SLuiz Augusto von Dentz } 645ccf74f23SLuiz Augusto von Dentz 646ccf74f23SLuiz Augusto von Dentz static inline int iso_exit(void) 647ccf74f23SLuiz Augusto von Dentz { 648ccf74f23SLuiz Augusto von Dentz return 0; 649ccf74f23SLuiz Augusto von Dentz } 650ccf74f23SLuiz Augusto von Dentz 651ccf74f23SLuiz Augusto von Dentz static inline bool iso_enabled(void) 652ccf74f23SLuiz Augusto von Dentz { 653ccf74f23SLuiz Augusto von Dentz return false; 654ccf74f23SLuiz Augusto von Dentz } 655ccf74f23SLuiz Augusto von Dentz #endif 656ccf74f23SLuiz Augusto von Dentz 6576d785aa3SJohan Hedberg int mgmt_init(void); 6586d785aa3SJohan Hedberg void mgmt_exit(void); 659b338d917SBrian Gix void mgmt_cleanup(struct sock *sk); 6606d785aa3SJohan Hedberg 661d22015aaSOctavian Purdila void bt_sock_reclassify_lock(struct sock *sk, int proto); 662d22015aaSOctavian Purdila 6631da177e4SLinus Torvalds #endif /* __BLUETOOTH_H */ 664