Junichi Katsu / Mbed 2 deprecated BLEControl

Dependencies:   FatFileSystem TB6612FNG2 mbed

Committer:
mbed_Cookbook_SE
Date:
Mon Nov 30 09:32:15 2015 +0000
Revision:
0:de03cbbcd0ff
??

Who changed what in which revision?

UserRevisionLine numberNew contents of line
mbed_Cookbook_SE 0:de03cbbcd0ff 1 /*
mbed_Cookbook_SE 0:de03cbbcd0ff 2 * Copyright (C) 2009-2012 by Matthias Ringwald
mbed_Cookbook_SE 0:de03cbbcd0ff 3 *
mbed_Cookbook_SE 0:de03cbbcd0ff 4 * Redistribution and use in source and binary forms, with or without
mbed_Cookbook_SE 0:de03cbbcd0ff 5 * modification, are permitted provided that the following conditions
mbed_Cookbook_SE 0:de03cbbcd0ff 6 * are met:
mbed_Cookbook_SE 0:de03cbbcd0ff 7 *
mbed_Cookbook_SE 0:de03cbbcd0ff 8 * 1. Redistributions of source code must retain the above copyright
mbed_Cookbook_SE 0:de03cbbcd0ff 9 * notice, this list of conditions and the following disclaimer.
mbed_Cookbook_SE 0:de03cbbcd0ff 10 * 2. Redistributions in binary form must reproduce the above copyright
mbed_Cookbook_SE 0:de03cbbcd0ff 11 * notice, this list of conditions and the following disclaimer in the
mbed_Cookbook_SE 0:de03cbbcd0ff 12 * documentation and/or other materials provided with the distribution.
mbed_Cookbook_SE 0:de03cbbcd0ff 13 * 3. Neither the name of the copyright holders nor the names of
mbed_Cookbook_SE 0:de03cbbcd0ff 14 * contributors may be used to endorse or promote products derived
mbed_Cookbook_SE 0:de03cbbcd0ff 15 * from this software without specific prior written permission.
mbed_Cookbook_SE 0:de03cbbcd0ff 16 * 4. Any redistribution, use, or modification is done solely for
mbed_Cookbook_SE 0:de03cbbcd0ff 17 * personal benefit and not for any commercial purpose or for
mbed_Cookbook_SE 0:de03cbbcd0ff 18 * monetary gain.
mbed_Cookbook_SE 0:de03cbbcd0ff 19 *
mbed_Cookbook_SE 0:de03cbbcd0ff 20 * THIS SOFTWARE IS PROVIDED BY MATTHIAS RINGWALD AND CONTRIBUTORS
mbed_Cookbook_SE 0:de03cbbcd0ff 21 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
mbed_Cookbook_SE 0:de03cbbcd0ff 22 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
mbed_Cookbook_SE 0:de03cbbcd0ff 23 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS
mbed_Cookbook_SE 0:de03cbbcd0ff 24 * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
mbed_Cookbook_SE 0:de03cbbcd0ff 25 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
mbed_Cookbook_SE 0:de03cbbcd0ff 26 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
mbed_Cookbook_SE 0:de03cbbcd0ff 27 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
mbed_Cookbook_SE 0:de03cbbcd0ff 28 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
mbed_Cookbook_SE 0:de03cbbcd0ff 29 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
mbed_Cookbook_SE 0:de03cbbcd0ff 30 * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
mbed_Cookbook_SE 0:de03cbbcd0ff 31 * SUCH DAMAGE.
mbed_Cookbook_SE 0:de03cbbcd0ff 32 *
mbed_Cookbook_SE 0:de03cbbcd0ff 33 * Please inquire about commercial licensing options at btstack@ringwald.ch
mbed_Cookbook_SE 0:de03cbbcd0ff 34 *
mbed_Cookbook_SE 0:de03cbbcd0ff 35 */
mbed_Cookbook_SE 0:de03cbbcd0ff 36
mbed_Cookbook_SE 0:de03cbbcd0ff 37 /*
mbed_Cookbook_SE 0:de03cbbcd0ff 38 * hci_cmds.c
mbed_Cookbook_SE 0:de03cbbcd0ff 39 *
mbed_Cookbook_SE 0:de03cbbcd0ff 40 * Created by Matthias Ringwald on 7/23/09.
mbed_Cookbook_SE 0:de03cbbcd0ff 41 */
mbed_Cookbook_SE 0:de03cbbcd0ff 42
mbed_Cookbook_SE 0:de03cbbcd0ff 43 #include <btstack/hci_cmds.h>
mbed_Cookbook_SE 0:de03cbbcd0ff 44
mbed_Cookbook_SE 0:de03cbbcd0ff 45 #include <string.h>
mbed_Cookbook_SE 0:de03cbbcd0ff 46
mbed_Cookbook_SE 0:de03cbbcd0ff 47 #include <btstack/sdp_util.h>
mbed_Cookbook_SE 0:de03cbbcd0ff 48 #include "config.h"
mbed_Cookbook_SE 0:de03cbbcd0ff 49 #include "hci.h"
mbed_Cookbook_SE 0:de03cbbcd0ff 50
mbed_Cookbook_SE 0:de03cbbcd0ff 51 // calculate combined ogf/ocf value
mbed_Cookbook_SE 0:de03cbbcd0ff 52 #define OPCODE(ogf, ocf) (ocf | ogf << 10)
mbed_Cookbook_SE 0:de03cbbcd0ff 53
mbed_Cookbook_SE 0:de03cbbcd0ff 54 /**
mbed_Cookbook_SE 0:de03cbbcd0ff 55 * construct HCI Command based on template
mbed_Cookbook_SE 0:de03cbbcd0ff 56 *
mbed_Cookbook_SE 0:de03cbbcd0ff 57 * Format:
mbed_Cookbook_SE 0:de03cbbcd0ff 58 * 1,2,3,4: one to four byte value
mbed_Cookbook_SE 0:de03cbbcd0ff 59 * H: HCI connection handle
mbed_Cookbook_SE 0:de03cbbcd0ff 60 * B: Bluetooth Baseband Address (BD_ADDR)
mbed_Cookbook_SE 0:de03cbbcd0ff 61 * E: Extended Inquiry Result
mbed_Cookbook_SE 0:de03cbbcd0ff 62 * N: Name up to 248 chars, \0 terminated
mbed_Cookbook_SE 0:de03cbbcd0ff 63 * P: 16 byte Pairing code
mbed_Cookbook_SE 0:de03cbbcd0ff 64 * S: Service Record (Data Element Sequence)
mbed_Cookbook_SE 0:de03cbbcd0ff 65 */
mbed_Cookbook_SE 0:de03cbbcd0ff 66 uint16_t hci_create_cmd_internal(uint8_t *hci_cmd_buffer, const hci_cmd_t *cmd, va_list argptr){
mbed_Cookbook_SE 0:de03cbbcd0ff 67
mbed_Cookbook_SE 0:de03cbbcd0ff 68 hci_cmd_buffer[0] = cmd->opcode & 0xff;
mbed_Cookbook_SE 0:de03cbbcd0ff 69 hci_cmd_buffer[1] = cmd->opcode >> 8;
mbed_Cookbook_SE 0:de03cbbcd0ff 70 int pos = 3;
mbed_Cookbook_SE 0:de03cbbcd0ff 71
mbed_Cookbook_SE 0:de03cbbcd0ff 72 const char *format = cmd->format;
mbed_Cookbook_SE 0:de03cbbcd0ff 73 uint16_t word;
mbed_Cookbook_SE 0:de03cbbcd0ff 74 uint32_t longword;
mbed_Cookbook_SE 0:de03cbbcd0ff 75 uint8_t * ptr;
mbed_Cookbook_SE 0:de03cbbcd0ff 76 while (*format) {
mbed_Cookbook_SE 0:de03cbbcd0ff 77 switch(*format) {
mbed_Cookbook_SE 0:de03cbbcd0ff 78 case '1': // 8 bit value
mbed_Cookbook_SE 0:de03cbbcd0ff 79 case '2': // 16 bit value
mbed_Cookbook_SE 0:de03cbbcd0ff 80 case 'H': // hci_handle
mbed_Cookbook_SE 0:de03cbbcd0ff 81 word = va_arg(argptr, int); // minimal va_arg is int: 2 bytes on 8+16 bit CPUs
mbed_Cookbook_SE 0:de03cbbcd0ff 82 hci_cmd_buffer[pos++] = word & 0xff;
mbed_Cookbook_SE 0:de03cbbcd0ff 83 if (*format == '2') {
mbed_Cookbook_SE 0:de03cbbcd0ff 84 hci_cmd_buffer[pos++] = word >> 8;
mbed_Cookbook_SE 0:de03cbbcd0ff 85 } else if (*format == 'H') {
mbed_Cookbook_SE 0:de03cbbcd0ff 86 // TODO implement opaque client connection handles
mbed_Cookbook_SE 0:de03cbbcd0ff 87 // pass module handle for now
mbed_Cookbook_SE 0:de03cbbcd0ff 88 hci_cmd_buffer[pos++] = word >> 8;
mbed_Cookbook_SE 0:de03cbbcd0ff 89 }
mbed_Cookbook_SE 0:de03cbbcd0ff 90 break;
mbed_Cookbook_SE 0:de03cbbcd0ff 91 case '3':
mbed_Cookbook_SE 0:de03cbbcd0ff 92 case '4':
mbed_Cookbook_SE 0:de03cbbcd0ff 93 longword = va_arg(argptr, uint32_t);
mbed_Cookbook_SE 0:de03cbbcd0ff 94 // longword = va_arg(argptr, int);
mbed_Cookbook_SE 0:de03cbbcd0ff 95 hci_cmd_buffer[pos++] = longword;
mbed_Cookbook_SE 0:de03cbbcd0ff 96 hci_cmd_buffer[pos++] = longword >> 8;
mbed_Cookbook_SE 0:de03cbbcd0ff 97 hci_cmd_buffer[pos++] = longword >> 16;
mbed_Cookbook_SE 0:de03cbbcd0ff 98 if (*format == '4'){
mbed_Cookbook_SE 0:de03cbbcd0ff 99 hci_cmd_buffer[pos++] = longword >> 24;
mbed_Cookbook_SE 0:de03cbbcd0ff 100 }
mbed_Cookbook_SE 0:de03cbbcd0ff 101 break;
mbed_Cookbook_SE 0:de03cbbcd0ff 102 case 'B': // bt-addr
mbed_Cookbook_SE 0:de03cbbcd0ff 103 ptr = va_arg(argptr, uint8_t *);
mbed_Cookbook_SE 0:de03cbbcd0ff 104 hci_cmd_buffer[pos++] = ptr[5];
mbed_Cookbook_SE 0:de03cbbcd0ff 105 hci_cmd_buffer[pos++] = ptr[4];
mbed_Cookbook_SE 0:de03cbbcd0ff 106 hci_cmd_buffer[pos++] = ptr[3];
mbed_Cookbook_SE 0:de03cbbcd0ff 107 hci_cmd_buffer[pos++] = ptr[2];
mbed_Cookbook_SE 0:de03cbbcd0ff 108 hci_cmd_buffer[pos++] = ptr[1];
mbed_Cookbook_SE 0:de03cbbcd0ff 109 hci_cmd_buffer[pos++] = ptr[0];
mbed_Cookbook_SE 0:de03cbbcd0ff 110 break;
mbed_Cookbook_SE 0:de03cbbcd0ff 111 case 'E': // Extended Inquiry Information 240 octets
mbed_Cookbook_SE 0:de03cbbcd0ff 112 ptr = va_arg(argptr, uint8_t *);
mbed_Cookbook_SE 0:de03cbbcd0ff 113 memcpy(&hci_cmd_buffer[pos], ptr, 240);
mbed_Cookbook_SE 0:de03cbbcd0ff 114 pos += 240;
mbed_Cookbook_SE 0:de03cbbcd0ff 115 break;
mbed_Cookbook_SE 0:de03cbbcd0ff 116 case 'N': { // UTF-8 string, null terminated
mbed_Cookbook_SE 0:de03cbbcd0ff 117 ptr = va_arg(argptr, uint8_t *);
mbed_Cookbook_SE 0:de03cbbcd0ff 118 uint16_t len = strlen((const char*) ptr);
mbed_Cookbook_SE 0:de03cbbcd0ff 119 if (len > 248) {
mbed_Cookbook_SE 0:de03cbbcd0ff 120 len = 248;
mbed_Cookbook_SE 0:de03cbbcd0ff 121 }
mbed_Cookbook_SE 0:de03cbbcd0ff 122 memcpy(&hci_cmd_buffer[pos], ptr, len);
mbed_Cookbook_SE 0:de03cbbcd0ff 123 if (len < 248) {
mbed_Cookbook_SE 0:de03cbbcd0ff 124 // fill remaining space with zeroes
mbed_Cookbook_SE 0:de03cbbcd0ff 125 memset(&hci_cmd_buffer[pos+len], 0, 248-len);
mbed_Cookbook_SE 0:de03cbbcd0ff 126 }
mbed_Cookbook_SE 0:de03cbbcd0ff 127 pos += 248;
mbed_Cookbook_SE 0:de03cbbcd0ff 128 break;
mbed_Cookbook_SE 0:de03cbbcd0ff 129 }
mbed_Cookbook_SE 0:de03cbbcd0ff 130 case 'P': // 16 byte PIN code or link key
mbed_Cookbook_SE 0:de03cbbcd0ff 131 ptr = va_arg(argptr, uint8_t *);
mbed_Cookbook_SE 0:de03cbbcd0ff 132 memcpy(&hci_cmd_buffer[pos], ptr, 16);
mbed_Cookbook_SE 0:de03cbbcd0ff 133 pos += 16;
mbed_Cookbook_SE 0:de03cbbcd0ff 134 break;
mbed_Cookbook_SE 0:de03cbbcd0ff 135 #ifdef HAVE_BLE
mbed_Cookbook_SE 0:de03cbbcd0ff 136 case 'A': // 31 bytes advertising data
mbed_Cookbook_SE 0:de03cbbcd0ff 137 ptr = va_arg(argptr, uint8_t *);
mbed_Cookbook_SE 0:de03cbbcd0ff 138 memcpy(&hci_cmd_buffer[pos], ptr, 31);
mbed_Cookbook_SE 0:de03cbbcd0ff 139 pos += 31;
mbed_Cookbook_SE 0:de03cbbcd0ff 140 break;
mbed_Cookbook_SE 0:de03cbbcd0ff 141 #endif
mbed_Cookbook_SE 0:de03cbbcd0ff 142 #ifdef HAVE_SDP
mbed_Cookbook_SE 0:de03cbbcd0ff 143 case 'S': { // Service Record (Data Element Sequence)
mbed_Cookbook_SE 0:de03cbbcd0ff 144 ptr = va_arg(argptr, uint8_t *);
mbed_Cookbook_SE 0:de03cbbcd0ff 145 uint16_t len = de_get_len(ptr);
mbed_Cookbook_SE 0:de03cbbcd0ff 146 memcpy(&hci_cmd_buffer[pos], ptr, len);
mbed_Cookbook_SE 0:de03cbbcd0ff 147 pos += len;
mbed_Cookbook_SE 0:de03cbbcd0ff 148 break;
mbed_Cookbook_SE 0:de03cbbcd0ff 149 }
mbed_Cookbook_SE 0:de03cbbcd0ff 150 #endif
mbed_Cookbook_SE 0:de03cbbcd0ff 151 default:
mbed_Cookbook_SE 0:de03cbbcd0ff 152 break;
mbed_Cookbook_SE 0:de03cbbcd0ff 153 }
mbed_Cookbook_SE 0:de03cbbcd0ff 154 format++;
mbed_Cookbook_SE 0:de03cbbcd0ff 155 };
mbed_Cookbook_SE 0:de03cbbcd0ff 156 hci_cmd_buffer[2] = pos - 3;
mbed_Cookbook_SE 0:de03cbbcd0ff 157 return pos;
mbed_Cookbook_SE 0:de03cbbcd0ff 158 }
mbed_Cookbook_SE 0:de03cbbcd0ff 159
mbed_Cookbook_SE 0:de03cbbcd0ff 160 /**
mbed_Cookbook_SE 0:de03cbbcd0ff 161 * construct HCI Command based on template
mbed_Cookbook_SE 0:de03cbbcd0ff 162 *
mbed_Cookbook_SE 0:de03cbbcd0ff 163 * mainly calls hci_create_cmd_internal
mbed_Cookbook_SE 0:de03cbbcd0ff 164 */
mbed_Cookbook_SE 0:de03cbbcd0ff 165 uint16_t hci_create_cmd(uint8_t *hci_cmd_buffer, hci_cmd_t *cmd, ...){
mbed_Cookbook_SE 0:de03cbbcd0ff 166 va_list argptr;
mbed_Cookbook_SE 0:de03cbbcd0ff 167 va_start(argptr, cmd);
mbed_Cookbook_SE 0:de03cbbcd0ff 168 uint16_t len = hci_create_cmd_internal(hci_cmd_buffer, cmd, argptr);
mbed_Cookbook_SE 0:de03cbbcd0ff 169 va_end(argptr);
mbed_Cookbook_SE 0:de03cbbcd0ff 170 return len;
mbed_Cookbook_SE 0:de03cbbcd0ff 171 }
mbed_Cookbook_SE 0:de03cbbcd0ff 172
mbed_Cookbook_SE 0:de03cbbcd0ff 173
mbed_Cookbook_SE 0:de03cbbcd0ff 174 /**
mbed_Cookbook_SE 0:de03cbbcd0ff 175 * Link Control Commands
mbed_Cookbook_SE 0:de03cbbcd0ff 176 */
mbed_Cookbook_SE 0:de03cbbcd0ff 177 const hci_cmd_t hci_inquiry = {
mbed_Cookbook_SE 0:de03cbbcd0ff 178 OPCODE(OGF_LINK_CONTROL, 0x01), "311"
mbed_Cookbook_SE 0:de03cbbcd0ff 179 // LAP, Inquiry length, Num_responses
mbed_Cookbook_SE 0:de03cbbcd0ff 180 };
mbed_Cookbook_SE 0:de03cbbcd0ff 181 const hci_cmd_t hci_inquiry_cancel = {
mbed_Cookbook_SE 0:de03cbbcd0ff 182 OPCODE(OGF_LINK_CONTROL, 0x02), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 183 // no params
mbed_Cookbook_SE 0:de03cbbcd0ff 184 };
mbed_Cookbook_SE 0:de03cbbcd0ff 185 const hci_cmd_t hci_create_connection = {
mbed_Cookbook_SE 0:de03cbbcd0ff 186 OPCODE(OGF_LINK_CONTROL, 0x05), "B21121"
mbed_Cookbook_SE 0:de03cbbcd0ff 187 // BD_ADDR, Packet_Type, Page_Scan_Repetition_Mode, Reserved, Clock_Offset, Allow_Role_Switch
mbed_Cookbook_SE 0:de03cbbcd0ff 188 };
mbed_Cookbook_SE 0:de03cbbcd0ff 189 const hci_cmd_t hci_disconnect = {
mbed_Cookbook_SE 0:de03cbbcd0ff 190 OPCODE(OGF_LINK_CONTROL, 0x06), "H1"
mbed_Cookbook_SE 0:de03cbbcd0ff 191 // Handle, Reason: 0x05, 0x13-0x15, 0x1a, 0x29
mbed_Cookbook_SE 0:de03cbbcd0ff 192 // see Errors Codes in BT Spec Part D
mbed_Cookbook_SE 0:de03cbbcd0ff 193 };
mbed_Cookbook_SE 0:de03cbbcd0ff 194 const hci_cmd_t hci_create_connection_cancel = {
mbed_Cookbook_SE 0:de03cbbcd0ff 195 OPCODE(OGF_LINK_CONTROL, 0x08), "B"
mbed_Cookbook_SE 0:de03cbbcd0ff 196 // BD_ADDR
mbed_Cookbook_SE 0:de03cbbcd0ff 197 };
mbed_Cookbook_SE 0:de03cbbcd0ff 198 const hci_cmd_t hci_accept_connection_request = {
mbed_Cookbook_SE 0:de03cbbcd0ff 199 OPCODE(OGF_LINK_CONTROL, 0x09), "B1"
mbed_Cookbook_SE 0:de03cbbcd0ff 200 // BD_ADDR, Role: become master, stay slave
mbed_Cookbook_SE 0:de03cbbcd0ff 201 };
mbed_Cookbook_SE 0:de03cbbcd0ff 202 const hci_cmd_t hci_reject_connection_request = {
mbed_Cookbook_SE 0:de03cbbcd0ff 203 OPCODE(OGF_LINK_CONTROL, 0x0a), "B1"
mbed_Cookbook_SE 0:de03cbbcd0ff 204 // BD_ADDR, reason e.g. CONNECTION REJECTED DUE TO LIMITED RESOURCES (0x0d)
mbed_Cookbook_SE 0:de03cbbcd0ff 205 };
mbed_Cookbook_SE 0:de03cbbcd0ff 206 const hci_cmd_t hci_link_key_request_reply = {
mbed_Cookbook_SE 0:de03cbbcd0ff 207 OPCODE(OGF_LINK_CONTROL, 0x0b), "BP"
mbed_Cookbook_SE 0:de03cbbcd0ff 208 // BD_ADDR, LINK_KEY
mbed_Cookbook_SE 0:de03cbbcd0ff 209 };
mbed_Cookbook_SE 0:de03cbbcd0ff 210 const hci_cmd_t hci_link_key_request_negative_reply = {
mbed_Cookbook_SE 0:de03cbbcd0ff 211 OPCODE(OGF_LINK_CONTROL, 0x0c), "B"
mbed_Cookbook_SE 0:de03cbbcd0ff 212 // BD_ADDR
mbed_Cookbook_SE 0:de03cbbcd0ff 213 };
mbed_Cookbook_SE 0:de03cbbcd0ff 214 const hci_cmd_t hci_pin_code_request_reply = {
mbed_Cookbook_SE 0:de03cbbcd0ff 215 OPCODE(OGF_LINK_CONTROL, 0x0d), "B1P"
mbed_Cookbook_SE 0:de03cbbcd0ff 216 // BD_ADDR, pin length, PIN: c-string
mbed_Cookbook_SE 0:de03cbbcd0ff 217 };
mbed_Cookbook_SE 0:de03cbbcd0ff 218 const hci_cmd_t hci_pin_code_request_negative_reply = {
mbed_Cookbook_SE 0:de03cbbcd0ff 219 OPCODE(OGF_LINK_CONTROL, 0x0e), "B"
mbed_Cookbook_SE 0:de03cbbcd0ff 220 // BD_ADDR
mbed_Cookbook_SE 0:de03cbbcd0ff 221 };
mbed_Cookbook_SE 0:de03cbbcd0ff 222 const hci_cmd_t hci_authentication_requested = {
mbed_Cookbook_SE 0:de03cbbcd0ff 223 OPCODE(OGF_LINK_CONTROL, 0x11), "H"
mbed_Cookbook_SE 0:de03cbbcd0ff 224 // Handle
mbed_Cookbook_SE 0:de03cbbcd0ff 225 };
mbed_Cookbook_SE 0:de03cbbcd0ff 226 const hci_cmd_t hci_set_connection_encryption = {
mbed_Cookbook_SE 0:de03cbbcd0ff 227 OPCODE(OGF_LINK_CONTROL, 0x13), "H1"
mbed_Cookbook_SE 0:de03cbbcd0ff 228 // Handle, Encryption_Enable
mbed_Cookbook_SE 0:de03cbbcd0ff 229 };
mbed_Cookbook_SE 0:de03cbbcd0ff 230 const hci_cmd_t hci_change_connection_link_key = {
mbed_Cookbook_SE 0:de03cbbcd0ff 231 OPCODE(OGF_LINK_CONTROL, 0x15), "H"
mbed_Cookbook_SE 0:de03cbbcd0ff 232 // Handle
mbed_Cookbook_SE 0:de03cbbcd0ff 233 };
mbed_Cookbook_SE 0:de03cbbcd0ff 234 const hci_cmd_t hci_remote_name_request = {
mbed_Cookbook_SE 0:de03cbbcd0ff 235 OPCODE(OGF_LINK_CONTROL, 0x19), "B112"
mbed_Cookbook_SE 0:de03cbbcd0ff 236 // BD_ADDR, Page_Scan_Repetition_Mode, Reserved, Clock_Offset
mbed_Cookbook_SE 0:de03cbbcd0ff 237 };
mbed_Cookbook_SE 0:de03cbbcd0ff 238 const hci_cmd_t hci_remote_name_request_cancel = {
mbed_Cookbook_SE 0:de03cbbcd0ff 239 OPCODE(OGF_LINK_CONTROL, 0x1A), "B"
mbed_Cookbook_SE 0:de03cbbcd0ff 240 // BD_ADDR
mbed_Cookbook_SE 0:de03cbbcd0ff 241 };
mbed_Cookbook_SE 0:de03cbbcd0ff 242
mbed_Cookbook_SE 0:de03cbbcd0ff 243 /**
mbed_Cookbook_SE 0:de03cbbcd0ff 244 * Link Policy Commands
mbed_Cookbook_SE 0:de03cbbcd0ff 245 */
mbed_Cookbook_SE 0:de03cbbcd0ff 246 const hci_cmd_t hci_sniff_mode = {
mbed_Cookbook_SE 0:de03cbbcd0ff 247 OPCODE(OGF_LINK_POLICY, 0x03), "H2222"
mbed_Cookbook_SE 0:de03cbbcd0ff 248 // handle, Sniff_Max_Interval, Sniff_Min_Interval, Sniff_Attempt, Sniff_Timeout:
mbed_Cookbook_SE 0:de03cbbcd0ff 249 };
mbed_Cookbook_SE 0:de03cbbcd0ff 250 const hci_cmd_t hci_qos_setup = {
mbed_Cookbook_SE 0:de03cbbcd0ff 251 OPCODE(OGF_LINK_POLICY, 0x07), "H114444"
mbed_Cookbook_SE 0:de03cbbcd0ff 252 // handle, flags, service_type, token rate (bytes/s), peak bandwith (bytes/s),
mbed_Cookbook_SE 0:de03cbbcd0ff 253 // latency (us), delay_variation (us)
mbed_Cookbook_SE 0:de03cbbcd0ff 254 };
mbed_Cookbook_SE 0:de03cbbcd0ff 255 const hci_cmd_t hci_role_discovery = {
mbed_Cookbook_SE 0:de03cbbcd0ff 256 OPCODE(OGF_LINK_POLICY, 0x09), "H"
mbed_Cookbook_SE 0:de03cbbcd0ff 257 // handle
mbed_Cookbook_SE 0:de03cbbcd0ff 258 };
mbed_Cookbook_SE 0:de03cbbcd0ff 259 const hci_cmd_t hci_switch_role_command= {
mbed_Cookbook_SE 0:de03cbbcd0ff 260 OPCODE(OGF_LINK_POLICY, 0x0b), "B1"
mbed_Cookbook_SE 0:de03cbbcd0ff 261 // BD_ADDR, role: {0=master,1=slave}
mbed_Cookbook_SE 0:de03cbbcd0ff 262 };
mbed_Cookbook_SE 0:de03cbbcd0ff 263 const hci_cmd_t hci_read_link_policy_settings = {
mbed_Cookbook_SE 0:de03cbbcd0ff 264 OPCODE(OGF_LINK_POLICY, 0x0c), "H"
mbed_Cookbook_SE 0:de03cbbcd0ff 265 // handle
mbed_Cookbook_SE 0:de03cbbcd0ff 266 };
mbed_Cookbook_SE 0:de03cbbcd0ff 267 const hci_cmd_t hci_write_link_policy_settings = {
mbed_Cookbook_SE 0:de03cbbcd0ff 268 OPCODE(OGF_LINK_POLICY, 0x0d), "H2"
mbed_Cookbook_SE 0:de03cbbcd0ff 269 // handle, settings
mbed_Cookbook_SE 0:de03cbbcd0ff 270 };
mbed_Cookbook_SE 0:de03cbbcd0ff 271
mbed_Cookbook_SE 0:de03cbbcd0ff 272 /**
mbed_Cookbook_SE 0:de03cbbcd0ff 273 * Controller & Baseband Commands
mbed_Cookbook_SE 0:de03cbbcd0ff 274 */
mbed_Cookbook_SE 0:de03cbbcd0ff 275 const hci_cmd_t hci_set_event_mask = {
mbed_Cookbook_SE 0:de03cbbcd0ff 276 OPCODE(OGF_CONTROLLER_BASEBAND, 0x01), "44"
mbed_Cookbook_SE 0:de03cbbcd0ff 277 // event_mask lower 4 octets, higher 4 bytes
mbed_Cookbook_SE 0:de03cbbcd0ff 278 };
mbed_Cookbook_SE 0:de03cbbcd0ff 279 const hci_cmd_t hci_reset = {
mbed_Cookbook_SE 0:de03cbbcd0ff 280 OPCODE(OGF_CONTROLLER_BASEBAND, 0x03), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 281 // no params
mbed_Cookbook_SE 0:de03cbbcd0ff 282 };
mbed_Cookbook_SE 0:de03cbbcd0ff 283 const hci_cmd_t hci_delete_stored_link_key = {
mbed_Cookbook_SE 0:de03cbbcd0ff 284 OPCODE(OGF_CONTROLLER_BASEBAND, 0x12), "B1"
mbed_Cookbook_SE 0:de03cbbcd0ff 285 // BD_ADDR, Delete_All_Flag
mbed_Cookbook_SE 0:de03cbbcd0ff 286 };
mbed_Cookbook_SE 0:de03cbbcd0ff 287 const hci_cmd_t hci_write_local_name = {
mbed_Cookbook_SE 0:de03cbbcd0ff 288 OPCODE(OGF_CONTROLLER_BASEBAND, 0x13), "N"
mbed_Cookbook_SE 0:de03cbbcd0ff 289 // Local name (UTF-8, Null Terminated, max 248 octets)
mbed_Cookbook_SE 0:de03cbbcd0ff 290 };
mbed_Cookbook_SE 0:de03cbbcd0ff 291 const hci_cmd_t hci_write_page_timeout = {
mbed_Cookbook_SE 0:de03cbbcd0ff 292 OPCODE(OGF_CONTROLLER_BASEBAND, 0x18), "2"
mbed_Cookbook_SE 0:de03cbbcd0ff 293 // Page_Timeout * 0.625 ms
mbed_Cookbook_SE 0:de03cbbcd0ff 294 };
mbed_Cookbook_SE 0:de03cbbcd0ff 295 const hci_cmd_t hci_write_scan_enable = {
mbed_Cookbook_SE 0:de03cbbcd0ff 296 OPCODE(OGF_CONTROLLER_BASEBAND, 0x1A), "1"
mbed_Cookbook_SE 0:de03cbbcd0ff 297 // Scan_enable: no, inq, page, inq+page
mbed_Cookbook_SE 0:de03cbbcd0ff 298 };
mbed_Cookbook_SE 0:de03cbbcd0ff 299 const hci_cmd_t hci_write_authentication_enable = {
mbed_Cookbook_SE 0:de03cbbcd0ff 300 OPCODE(OGF_CONTROLLER_BASEBAND, 0x20), "1"
mbed_Cookbook_SE 0:de03cbbcd0ff 301 // Authentication_Enable
mbed_Cookbook_SE 0:de03cbbcd0ff 302 };
mbed_Cookbook_SE 0:de03cbbcd0ff 303 const hci_cmd_t hci_write_class_of_device = {
mbed_Cookbook_SE 0:de03cbbcd0ff 304 OPCODE(OGF_CONTROLLER_BASEBAND, 0x24), "3"
mbed_Cookbook_SE 0:de03cbbcd0ff 305 // Class of Device
mbed_Cookbook_SE 0:de03cbbcd0ff 306 };
mbed_Cookbook_SE 0:de03cbbcd0ff 307 const hci_cmd_t hci_read_num_broadcast_retransmissions = {
mbed_Cookbook_SE 0:de03cbbcd0ff 308 OPCODE(OGF_CONTROLLER_BASEBAND, 0x29), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 309 };
mbed_Cookbook_SE 0:de03cbbcd0ff 310 const hci_cmd_t hci_write_num_broadcast_retransmissions = {
mbed_Cookbook_SE 0:de03cbbcd0ff 311 OPCODE(OGF_CONTROLLER_BASEBAND, 0x2a), "1"
mbed_Cookbook_SE 0:de03cbbcd0ff 312 // Num broadcast retransmissions (e.g. 0 for a single broadcast)
mbed_Cookbook_SE 0:de03cbbcd0ff 313 };
mbed_Cookbook_SE 0:de03cbbcd0ff 314 const hci_cmd_t hci_host_buffer_size = {
mbed_Cookbook_SE 0:de03cbbcd0ff 315 OPCODE(OGF_CONTROLLER_BASEBAND, 0x33), "2122"
mbed_Cookbook_SE 0:de03cbbcd0ff 316 // Host_ACL_Data_Packet_Length:, Host_Synchronous_Data_Packet_Length:, Host_Total_Num_ACL_Data_Packets:, Host_Total_Num_Synchronous_Data_Packets:
mbed_Cookbook_SE 0:de03cbbcd0ff 317 };
mbed_Cookbook_SE 0:de03cbbcd0ff 318 const hci_cmd_t hci_read_link_supervision_timeout = {
mbed_Cookbook_SE 0:de03cbbcd0ff 319 OPCODE(OGF_CONTROLLER_BASEBAND, 0x36), "H"
mbed_Cookbook_SE 0:de03cbbcd0ff 320 // handle
mbed_Cookbook_SE 0:de03cbbcd0ff 321 };
mbed_Cookbook_SE 0:de03cbbcd0ff 322 const hci_cmd_t hci_write_link_supervision_timeout = {
mbed_Cookbook_SE 0:de03cbbcd0ff 323 OPCODE(OGF_CONTROLLER_BASEBAND, 0x37), "H2"
mbed_Cookbook_SE 0:de03cbbcd0ff 324 // handle, Range for N: 0x0001 Ð 0xFFFF Time (Range: 0.625ms Ð 40.9 sec)
mbed_Cookbook_SE 0:de03cbbcd0ff 325 };
mbed_Cookbook_SE 0:de03cbbcd0ff 326 const hci_cmd_t hci_write_inquiry_mode = {
mbed_Cookbook_SE 0:de03cbbcd0ff 327 OPCODE(OGF_CONTROLLER_BASEBAND, 0x45), "1"
mbed_Cookbook_SE 0:de03cbbcd0ff 328 // Inquiry mode: 0x00 = standard, 0x01 = with RSSI, 0x02 = extended
mbed_Cookbook_SE 0:de03cbbcd0ff 329 };
mbed_Cookbook_SE 0:de03cbbcd0ff 330 const hci_cmd_t hci_write_extended_inquiry_response = {
mbed_Cookbook_SE 0:de03cbbcd0ff 331 OPCODE(OGF_CONTROLLER_BASEBAND, 0x52), "1E"
mbed_Cookbook_SE 0:de03cbbcd0ff 332 // FEC_Required, Exstended Inquiry Response
mbed_Cookbook_SE 0:de03cbbcd0ff 333 };
mbed_Cookbook_SE 0:de03cbbcd0ff 334 const hci_cmd_t hci_write_simple_pairing_mode = {
mbed_Cookbook_SE 0:de03cbbcd0ff 335 OPCODE(OGF_CONTROLLER_BASEBAND, 0x56), "1"
mbed_Cookbook_SE 0:de03cbbcd0ff 336 // mode: 0 = off, 1 = on
mbed_Cookbook_SE 0:de03cbbcd0ff 337 };
mbed_Cookbook_SE 0:de03cbbcd0ff 338 const hci_cmd_t hci_read_le_host_supported = {
mbed_Cookbook_SE 0:de03cbbcd0ff 339 OPCODE(OGF_CONTROLLER_BASEBAND, 0x6c), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 340 // params: none
mbed_Cookbook_SE 0:de03cbbcd0ff 341 // return: status, le supported host, simultaneous le host
mbed_Cookbook_SE 0:de03cbbcd0ff 342 };
mbed_Cookbook_SE 0:de03cbbcd0ff 343 const hci_cmd_t hci_write_le_host_supported = {
mbed_Cookbook_SE 0:de03cbbcd0ff 344 OPCODE(OGF_CONTROLLER_BASEBAND, 0x6d), "11"
mbed_Cookbook_SE 0:de03cbbcd0ff 345 // param: le supported host, simultaneous le host
mbed_Cookbook_SE 0:de03cbbcd0ff 346 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 347 };
mbed_Cookbook_SE 0:de03cbbcd0ff 348
mbed_Cookbook_SE 0:de03cbbcd0ff 349 /**
mbed_Cookbook_SE 0:de03cbbcd0ff 350 * Informational Parameters
mbed_Cookbook_SE 0:de03cbbcd0ff 351 */
mbed_Cookbook_SE 0:de03cbbcd0ff 352 const hci_cmd_t hci_read_local_supported_features = {
mbed_Cookbook_SE 0:de03cbbcd0ff 353 OPCODE(OGF_INFORMATIONAL_PARAMETERS, 0x03), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 354 // no params
mbed_Cookbook_SE 0:de03cbbcd0ff 355 };
mbed_Cookbook_SE 0:de03cbbcd0ff 356 const hci_cmd_t hci_read_buffer_size = {
mbed_Cookbook_SE 0:de03cbbcd0ff 357 OPCODE(OGF_INFORMATIONAL_PARAMETERS, 0x05), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 358 // no params
mbed_Cookbook_SE 0:de03cbbcd0ff 359 };
mbed_Cookbook_SE 0:de03cbbcd0ff 360 const hci_cmd_t hci_read_bd_addr = {
mbed_Cookbook_SE 0:de03cbbcd0ff 361 OPCODE(OGF_INFORMATIONAL_PARAMETERS, 0x09), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 362 // no params
mbed_Cookbook_SE 0:de03cbbcd0ff 363 };
mbed_Cookbook_SE 0:de03cbbcd0ff 364
mbed_Cookbook_SE 0:de03cbbcd0ff 365 #ifdef HAVE_BLE
mbed_Cookbook_SE 0:de03cbbcd0ff 366 /**
mbed_Cookbook_SE 0:de03cbbcd0ff 367 * Low Energy Commands
mbed_Cookbook_SE 0:de03cbbcd0ff 368 */
mbed_Cookbook_SE 0:de03cbbcd0ff 369 const hci_cmd_t hci_le_set_event_mask = {
mbed_Cookbook_SE 0:de03cbbcd0ff 370 OPCODE(OGF_LE_CONTROLLER, 0x01), "44"
mbed_Cookbook_SE 0:de03cbbcd0ff 371 // params: event_mask lower 4 octets, higher 4 bytes
mbed_Cookbook_SE 0:de03cbbcd0ff 372 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 373 };
mbed_Cookbook_SE 0:de03cbbcd0ff 374 const hci_cmd_t hci_le_read_buffer_size = {
mbed_Cookbook_SE 0:de03cbbcd0ff 375 OPCODE(OGF_LE_CONTROLLER, 0x02), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 376 // params: none
mbed_Cookbook_SE 0:de03cbbcd0ff 377 // return: status, le acl data packet len (16), total num le acl data packets(8)
mbed_Cookbook_SE 0:de03cbbcd0ff 378 };
mbed_Cookbook_SE 0:de03cbbcd0ff 379 const hci_cmd_t hci_le_read_supported_features = {
mbed_Cookbook_SE 0:de03cbbcd0ff 380 OPCODE(OGF_LE_CONTROLLER, 0x03), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 381 // params: none
mbed_Cookbook_SE 0:de03cbbcd0ff 382 // return: LE_Features See [Vol 6] Part B, Section 4.6
mbed_Cookbook_SE 0:de03cbbcd0ff 383 };
mbed_Cookbook_SE 0:de03cbbcd0ff 384 const hci_cmd_t hci_le_set_random_address = {
mbed_Cookbook_SE 0:de03cbbcd0ff 385 OPCODE(OGF_LE_CONTROLLER, 0x05), "B"
mbed_Cookbook_SE 0:de03cbbcd0ff 386 // params: random device address
mbed_Cookbook_SE 0:de03cbbcd0ff 387 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 388 };
mbed_Cookbook_SE 0:de03cbbcd0ff 389 const hci_cmd_t hci_le_set_advertising_parameters = {
mbed_Cookbook_SE 0:de03cbbcd0ff 390 OPCODE(OGF_LE_CONTROLLER, 0x06), "22111B11"
mbed_Cookbook_SE 0:de03cbbcd0ff 391 // param: min advertising interval, [0x0020,0x4000], default: 0x0800, unit: 0.625 msec
mbed_Cookbook_SE 0:de03cbbcd0ff 392 // param: max advertising interval, [0x0020,0x4000], default: 0x0800, unit: 0.625 msec
mbed_Cookbook_SE 0:de03cbbcd0ff 393 // param: advertising type (enum from 0): ADV_IND, ADC_DIRECT_IND, ADV_SCAN_IND, ADV_NONCONN_IND
mbed_Cookbook_SE 0:de03cbbcd0ff 394 // param: own address type (enum from 0): public device address, random device address
mbed_Cookbook_SE 0:de03cbbcd0ff 395 // param: direct address type (enum from 0): public device address, random device address
mbed_Cookbook_SE 0:de03cbbcd0ff 396 // param: direct address - public or random address of device to be connecteed
mbed_Cookbook_SE 0:de03cbbcd0ff 397 // param: advertising channel map (flags): chan_37(1), chan_38(2), chan_39(4)
mbed_Cookbook_SE 0:de03cbbcd0ff 398 // param: advertising filter policy (enum from 0): scan any conn any, scan whitelist, con any, scan any conn whitelist, scan whitelist, con whitelist
mbed_Cookbook_SE 0:de03cbbcd0ff 399 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 400 };
mbed_Cookbook_SE 0:de03cbbcd0ff 401 const hci_cmd_t hci_le_read_advertising_channel_tx_power = {
mbed_Cookbook_SE 0:de03cbbcd0ff 402 OPCODE(OGF_LE_CONTROLLER, 0x07), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 403 // params: none
mbed_Cookbook_SE 0:de03cbbcd0ff 404 // return: status, level [-20,10] signed int (8), units dBm
mbed_Cookbook_SE 0:de03cbbcd0ff 405 };
mbed_Cookbook_SE 0:de03cbbcd0ff 406 const hci_cmd_t hci_le_set_advertising_data= {
mbed_Cookbook_SE 0:de03cbbcd0ff 407 OPCODE(OGF_LE_CONTROLLER, 0x08), "1A"
mbed_Cookbook_SE 0:de03cbbcd0ff 408 // param: advertising data len
mbed_Cookbook_SE 0:de03cbbcd0ff 409 // param: advertising data (31 bytes)
mbed_Cookbook_SE 0:de03cbbcd0ff 410 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 411 };
mbed_Cookbook_SE 0:de03cbbcd0ff 412 const hci_cmd_t hci_le_set_scan_response_data= {
mbed_Cookbook_SE 0:de03cbbcd0ff 413 OPCODE(OGF_LE_CONTROLLER, 0x09), "1A"
mbed_Cookbook_SE 0:de03cbbcd0ff 414 // param: scan response data len
mbed_Cookbook_SE 0:de03cbbcd0ff 415 // param: scan response data (31 bytes)
mbed_Cookbook_SE 0:de03cbbcd0ff 416 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 417 };
mbed_Cookbook_SE 0:de03cbbcd0ff 418 const hci_cmd_t hci_le_set_advertise_enable = {
mbed_Cookbook_SE 0:de03cbbcd0ff 419 OPCODE(OGF_LE_CONTROLLER, 0x0a), "1"
mbed_Cookbook_SE 0:de03cbbcd0ff 420 // params: avertise enable: off (0), on (1)
mbed_Cookbook_SE 0:de03cbbcd0ff 421 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 422 };
mbed_Cookbook_SE 0:de03cbbcd0ff 423 const hci_cmd_t hci_le_set_scan_parameters = {
mbed_Cookbook_SE 0:de03cbbcd0ff 424 OPCODE(OGF_LE_CONTROLLER, 0x0b), "12211"
mbed_Cookbook_SE 0:de03cbbcd0ff 425 // param: le scan type: passive (0), active (1)
mbed_Cookbook_SE 0:de03cbbcd0ff 426 // param: le scan interval [0x0004,0x4000], unit: 0.625 msec
mbed_Cookbook_SE 0:de03cbbcd0ff 427 // param: le scan window [0x0004,0x4000], unit: 0.625 msec
mbed_Cookbook_SE 0:de03cbbcd0ff 428 // param: own address type: public (0), random (1)
mbed_Cookbook_SE 0:de03cbbcd0ff 429 // param: scanning filter policy: any (0), only whitelist (1)
mbed_Cookbook_SE 0:de03cbbcd0ff 430 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 431 };
mbed_Cookbook_SE 0:de03cbbcd0ff 432 const hci_cmd_t hci_le_set_scan_enable = {
mbed_Cookbook_SE 0:de03cbbcd0ff 433 OPCODE(OGF_LE_CONTROLLER, 0x0c), "11"
mbed_Cookbook_SE 0:de03cbbcd0ff 434 // param: le scan enable: disabled (0), enabled (1)
mbed_Cookbook_SE 0:de03cbbcd0ff 435 // param: filter duplices: disabled (0), enabled (1)
mbed_Cookbook_SE 0:de03cbbcd0ff 436 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 437 };
mbed_Cookbook_SE 0:de03cbbcd0ff 438 const hci_cmd_t hci_le_create_connection= {
mbed_Cookbook_SE 0:de03cbbcd0ff 439 OPCODE(OGF_LE_CONTROLLER, 0x0d), "2211B1222222"
mbed_Cookbook_SE 0:de03cbbcd0ff 440 // param: le scan interval, [0x0004, 0x4000], unit: 0.625 msec
mbed_Cookbook_SE 0:de03cbbcd0ff 441 // param: le scan window, [0x0004, 0x4000], unit: 0.625 msec
mbed_Cookbook_SE 0:de03cbbcd0ff 442 // param: initiator filter policy: peer address type + peer address (0), whitelist (1)
mbed_Cookbook_SE 0:de03cbbcd0ff 443 // param: peer address type: public (0), random (1)
mbed_Cookbook_SE 0:de03cbbcd0ff 444 // param: peer address
mbed_Cookbook_SE 0:de03cbbcd0ff 445 // param: own address type: public (0), random (1)
mbed_Cookbook_SE 0:de03cbbcd0ff 446 // param: conn interval min, [0x0006, 0x0c80], unit: 1.25 msec
mbed_Cookbook_SE 0:de03cbbcd0ff 447 // param: conn interval max, [0x0006, 0x0c80], unit: 1.25 msec
mbed_Cookbook_SE 0:de03cbbcd0ff 448 // param: conn latency, number of connection events [0x0000, 0x01f4]
mbed_Cookbook_SE 0:de03cbbcd0ff 449 // param: supervision timeout, [0x000a, 0x0c80], unit: 10 msec
mbed_Cookbook_SE 0:de03cbbcd0ff 450 // param: minimum CE length, [0x0000, 0xffff], unit: 0.625 msec
mbed_Cookbook_SE 0:de03cbbcd0ff 451 // return: none -> le create connection complete event
mbed_Cookbook_SE 0:de03cbbcd0ff 452 };
mbed_Cookbook_SE 0:de03cbbcd0ff 453 const hci_cmd_t hci_le_create_connection_cancel = {
mbed_Cookbook_SE 0:de03cbbcd0ff 454 OPCODE(OGF_LE_CONTROLLER, 0x0e), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 455 // params: none
mbed_Cookbook_SE 0:de03cbbcd0ff 456 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 457 };
mbed_Cookbook_SE 0:de03cbbcd0ff 458 const hci_cmd_t hci_le_read_white_list_size = {
mbed_Cookbook_SE 0:de03cbbcd0ff 459 OPCODE(OGF_LE_CONTROLLER, 0x0f), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 460 // params: none
mbed_Cookbook_SE 0:de03cbbcd0ff 461 // return: status, number of entries in controller whitelist
mbed_Cookbook_SE 0:de03cbbcd0ff 462 };
mbed_Cookbook_SE 0:de03cbbcd0ff 463 const hci_cmd_t hci_le_clear_white_list = {
mbed_Cookbook_SE 0:de03cbbcd0ff 464 OPCODE(OGF_LE_CONTROLLER, 0x10), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 465 // params: none
mbed_Cookbook_SE 0:de03cbbcd0ff 466 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 467 };
mbed_Cookbook_SE 0:de03cbbcd0ff 468 const hci_cmd_t hci_le_add_device_to_whitelist = {
mbed_Cookbook_SE 0:de03cbbcd0ff 469 OPCODE(OGF_LE_CONTROLLER, 0x11), "1B"
mbed_Cookbook_SE 0:de03cbbcd0ff 470 // param: address type: public (0), random (1)
mbed_Cookbook_SE 0:de03cbbcd0ff 471 // param: address
mbed_Cookbook_SE 0:de03cbbcd0ff 472 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 473 };
mbed_Cookbook_SE 0:de03cbbcd0ff 474 const hci_cmd_t hci_le_remove_device_from_whitelist = {
mbed_Cookbook_SE 0:de03cbbcd0ff 475 OPCODE(OGF_LE_CONTROLLER, 0x12), "1B"
mbed_Cookbook_SE 0:de03cbbcd0ff 476 // param: address type: public (0), random (1)
mbed_Cookbook_SE 0:de03cbbcd0ff 477 // param: address
mbed_Cookbook_SE 0:de03cbbcd0ff 478 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 479 };
mbed_Cookbook_SE 0:de03cbbcd0ff 480 const hci_cmd_t hci_le_connection_update = {
mbed_Cookbook_SE 0:de03cbbcd0ff 481 OPCODE(OGF_LE_CONTROLLER, 0x13), "H222222"
mbed_Cookbook_SE 0:de03cbbcd0ff 482 // param: conn handle
mbed_Cookbook_SE 0:de03cbbcd0ff 483 // param: conn interval min, [0x0006,0x0c80], unit: 1.25 msec
mbed_Cookbook_SE 0:de03cbbcd0ff 484 // param: conn interval max, [0x0006,0x0c80], unit: 1.25 msec
mbed_Cookbook_SE 0:de03cbbcd0ff 485 // param: conn latency, [0x0000,0x03e8], number of connection events
mbed_Cookbook_SE 0:de03cbbcd0ff 486 // param: supervision timeout, [0x000a,0x0c80], unit: 10 msec
mbed_Cookbook_SE 0:de03cbbcd0ff 487 // param: minimum CE length, [0x0000,0xffff], unit: 0.625 msec
mbed_Cookbook_SE 0:de03cbbcd0ff 488 // param: maximum CE length, [0x0000,0xffff], unit: 0.625 msec
mbed_Cookbook_SE 0:de03cbbcd0ff 489 // return: none -> le connection update complete event
mbed_Cookbook_SE 0:de03cbbcd0ff 490 };
mbed_Cookbook_SE 0:de03cbbcd0ff 491 const hci_cmd_t hci_le_set_host_channel_classification = {
mbed_Cookbook_SE 0:de03cbbcd0ff 492 OPCODE(OGF_LE_CONTROLLER, 0x14), "41"
mbed_Cookbook_SE 0:de03cbbcd0ff 493 // param: channel map 37 bit, split into first 32 and higher 5 bits
mbed_Cookbook_SE 0:de03cbbcd0ff 494 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 495 };
mbed_Cookbook_SE 0:de03cbbcd0ff 496 const hci_cmd_t hci_le_read_channel_map = {
mbed_Cookbook_SE 0:de03cbbcd0ff 497 OPCODE(OGF_LE_CONTROLLER, 0x15), "H"
mbed_Cookbook_SE 0:de03cbbcd0ff 498 // params: connection handle
mbed_Cookbook_SE 0:de03cbbcd0ff 499 // return: status, connection handle, channel map (5 bytes, 37 used)
mbed_Cookbook_SE 0:de03cbbcd0ff 500 };
mbed_Cookbook_SE 0:de03cbbcd0ff 501 const hci_cmd_t hci_le_read_remote_used_features = {
mbed_Cookbook_SE 0:de03cbbcd0ff 502 OPCODE(OGF_LE_CONTROLLER, 0x16), "H"
mbed_Cookbook_SE 0:de03cbbcd0ff 503 // params: connection handle
mbed_Cookbook_SE 0:de03cbbcd0ff 504 // return: none -> le read remote used features complete event
mbed_Cookbook_SE 0:de03cbbcd0ff 505 };
mbed_Cookbook_SE 0:de03cbbcd0ff 506 const hci_cmd_t hci_le_encrypt = {
mbed_Cookbook_SE 0:de03cbbcd0ff 507 OPCODE(OGF_LE_CONTROLLER, 0x17), "PP"
mbed_Cookbook_SE 0:de03cbbcd0ff 508 // param: key (128) for AES-128
mbed_Cookbook_SE 0:de03cbbcd0ff 509 // param: plain text (128)
mbed_Cookbook_SE 0:de03cbbcd0ff 510 // return: status, encrypted data (128)
mbed_Cookbook_SE 0:de03cbbcd0ff 511 };
mbed_Cookbook_SE 0:de03cbbcd0ff 512 const hci_cmd_t hci_le_rand = {
mbed_Cookbook_SE 0:de03cbbcd0ff 513 OPCODE(OGF_LE_CONTROLLER, 0x18), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 514 // params: none
mbed_Cookbook_SE 0:de03cbbcd0ff 515 // return: status, random number (64)
mbed_Cookbook_SE 0:de03cbbcd0ff 516 };
mbed_Cookbook_SE 0:de03cbbcd0ff 517 const hci_cmd_t hci_le_start_encryption = {
mbed_Cookbook_SE 0:de03cbbcd0ff 518 OPCODE(OGF_LE_CONTROLLER, 0x19), "H442P"
mbed_Cookbook_SE 0:de03cbbcd0ff 519 // param: connection handle
mbed_Cookbook_SE 0:de03cbbcd0ff 520 // param: 64 bit random number lower 32 bit
mbed_Cookbook_SE 0:de03cbbcd0ff 521 // param: 64 bit random number higher 32 bit
mbed_Cookbook_SE 0:de03cbbcd0ff 522 // param: encryption diversifier (16)
mbed_Cookbook_SE 0:de03cbbcd0ff 523 // param: long term key (128)
mbed_Cookbook_SE 0:de03cbbcd0ff 524 // return: none -> encryption changed or encryption key refresh complete event
mbed_Cookbook_SE 0:de03cbbcd0ff 525 };
mbed_Cookbook_SE 0:de03cbbcd0ff 526 const hci_cmd_t hci_le_long_term_key_request_reply = {
mbed_Cookbook_SE 0:de03cbbcd0ff 527 OPCODE(OGF_LE_CONTROLLER, 0x1a), "HP"
mbed_Cookbook_SE 0:de03cbbcd0ff 528 // param: connection handle
mbed_Cookbook_SE 0:de03cbbcd0ff 529 // param: long term key (128)
mbed_Cookbook_SE 0:de03cbbcd0ff 530 // return: status, connection handle
mbed_Cookbook_SE 0:de03cbbcd0ff 531 };
mbed_Cookbook_SE 0:de03cbbcd0ff 532 const hci_cmd_t hci_le_long_term_key_negative_reply = {
mbed_Cookbook_SE 0:de03cbbcd0ff 533 OPCODE(OGF_LE_CONTROLLER, 0x1b), "H"
mbed_Cookbook_SE 0:de03cbbcd0ff 534 // param: connection handle
mbed_Cookbook_SE 0:de03cbbcd0ff 535 // return: status, connection handle
mbed_Cookbook_SE 0:de03cbbcd0ff 536 };
mbed_Cookbook_SE 0:de03cbbcd0ff 537 const hci_cmd_t hci_le_read_supported_states = {
mbed_Cookbook_SE 0:de03cbbcd0ff 538 OPCODE(OGF_LE_CONTROLLER, 0x1c), "H"
mbed_Cookbook_SE 0:de03cbbcd0ff 539 // param: none
mbed_Cookbook_SE 0:de03cbbcd0ff 540 // return: status, LE states (64)
mbed_Cookbook_SE 0:de03cbbcd0ff 541 };
mbed_Cookbook_SE 0:de03cbbcd0ff 542 const hci_cmd_t hci_le_receiver_test = {
mbed_Cookbook_SE 0:de03cbbcd0ff 543 OPCODE(OGF_LE_CONTROLLER, 0x1d), "1"
mbed_Cookbook_SE 0:de03cbbcd0ff 544 // param: rx frequency, [0x00 0x27], frequency (MHz): 2420 + N*2
mbed_Cookbook_SE 0:de03cbbcd0ff 545 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 546 };
mbed_Cookbook_SE 0:de03cbbcd0ff 547 const hci_cmd_t hci_le_transmitter_test = {
mbed_Cookbook_SE 0:de03cbbcd0ff 548 OPCODE(OGF_LE_CONTROLLER, 0x1e), "111"
mbed_Cookbook_SE 0:de03cbbcd0ff 549 // param: tx frequency, [0x00 0x27], frequency (MHz): 2420 + N*2
mbed_Cookbook_SE 0:de03cbbcd0ff 550 // param: lengh of test payload [0x00,0x25]
mbed_Cookbook_SE 0:de03cbbcd0ff 551 // param: packet payload [0,7] different patterns
mbed_Cookbook_SE 0:de03cbbcd0ff 552 // return: status
mbed_Cookbook_SE 0:de03cbbcd0ff 553 };
mbed_Cookbook_SE 0:de03cbbcd0ff 554 const hci_cmd_t hci_le_test_end = {
mbed_Cookbook_SE 0:de03cbbcd0ff 555 OPCODE(OGF_LE_CONTROLLER, 0x1f), "1"
mbed_Cookbook_SE 0:de03cbbcd0ff 556 // params: none
mbed_Cookbook_SE 0:de03cbbcd0ff 557 // return: status, number of packets (8)
mbed_Cookbook_SE 0:de03cbbcd0ff 558 };
mbed_Cookbook_SE 0:de03cbbcd0ff 559 #endif
mbed_Cookbook_SE 0:de03cbbcd0ff 560
mbed_Cookbook_SE 0:de03cbbcd0ff 561 // BTstack commands
mbed_Cookbook_SE 0:de03cbbcd0ff 562 const hci_cmd_t btstack_get_state = {
mbed_Cookbook_SE 0:de03cbbcd0ff 563 OPCODE(OGF_BTSTACK, BTSTACK_GET_STATE), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 564 // no params ->
mbed_Cookbook_SE 0:de03cbbcd0ff 565 };
mbed_Cookbook_SE 0:de03cbbcd0ff 566
mbed_Cookbook_SE 0:de03cbbcd0ff 567 const hci_cmd_t btstack_set_power_mode = {
mbed_Cookbook_SE 0:de03cbbcd0ff 568 OPCODE(OGF_BTSTACK, BTSTACK_SET_POWER_MODE), "1"
mbed_Cookbook_SE 0:de03cbbcd0ff 569 // mode: 0 = off, 1 = on
mbed_Cookbook_SE 0:de03cbbcd0ff 570 };
mbed_Cookbook_SE 0:de03cbbcd0ff 571
mbed_Cookbook_SE 0:de03cbbcd0ff 572 const hci_cmd_t btstack_set_acl_capture_mode = {
mbed_Cookbook_SE 0:de03cbbcd0ff 573 OPCODE(OGF_BTSTACK, BTSTACK_SET_ACL_CAPTURE_MODE), "1"
mbed_Cookbook_SE 0:de03cbbcd0ff 574 // mode: 0 = off, 1 = on
mbed_Cookbook_SE 0:de03cbbcd0ff 575 };
mbed_Cookbook_SE 0:de03cbbcd0ff 576
mbed_Cookbook_SE 0:de03cbbcd0ff 577 const hci_cmd_t btstack_get_version = {
mbed_Cookbook_SE 0:de03cbbcd0ff 578 OPCODE(OGF_BTSTACK, BTSTACK_GET_VERSION), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 579 };
mbed_Cookbook_SE 0:de03cbbcd0ff 580
mbed_Cookbook_SE 0:de03cbbcd0ff 581 const hci_cmd_t btstack_get_system_bluetooth_enabled = {
mbed_Cookbook_SE 0:de03cbbcd0ff 582 OPCODE(OGF_BTSTACK, BTSTACK_GET_SYSTEM_BLUETOOTH_ENABLED), ""
mbed_Cookbook_SE 0:de03cbbcd0ff 583 };
mbed_Cookbook_SE 0:de03cbbcd0ff 584
mbed_Cookbook_SE 0:de03cbbcd0ff 585 const hci_cmd_t btstack_set_system_bluetooth_enabled = {
mbed_Cookbook_SE 0:de03cbbcd0ff 586 OPCODE(OGF_BTSTACK, BTSTACK_SET_SYSTEM_BLUETOOTH_ENABLED), "1"
mbed_Cookbook_SE 0:de03cbbcd0ff 587 };
mbed_Cookbook_SE 0:de03cbbcd0ff 588
mbed_Cookbook_SE 0:de03cbbcd0ff 589 const hci_cmd_t btstack_set_discoverable = {
mbed_Cookbook_SE 0:de03cbbcd0ff 590 OPCODE(OGF_BTSTACK, BTSTACK_SET_DISCOVERABLE), "1"
mbed_Cookbook_SE 0:de03cbbcd0ff 591 };
mbed_Cookbook_SE 0:de03cbbcd0ff 592
mbed_Cookbook_SE 0:de03cbbcd0ff 593 const hci_cmd_t btstack_set_bluetooth_enabled = {
mbed_Cookbook_SE 0:de03cbbcd0ff 594 // only used by btstack config
mbed_Cookbook_SE 0:de03cbbcd0ff 595 OPCODE(OGF_BTSTACK, BTSTACK_SET_BLUETOOTH_ENABLED), "1"
mbed_Cookbook_SE 0:de03cbbcd0ff 596 };
mbed_Cookbook_SE 0:de03cbbcd0ff 597
mbed_Cookbook_SE 0:de03cbbcd0ff 598 const hci_cmd_t l2cap_create_channel = {
mbed_Cookbook_SE 0:de03cbbcd0ff 599 OPCODE(OGF_BTSTACK, L2CAP_CREATE_CHANNEL), "B2"
mbed_Cookbook_SE 0:de03cbbcd0ff 600 // @param bd_addr(48), psm (16)
mbed_Cookbook_SE 0:de03cbbcd0ff 601 };
mbed_Cookbook_SE 0:de03cbbcd0ff 602 const hci_cmd_t l2cap_create_channel_mtu = {
mbed_Cookbook_SE 0:de03cbbcd0ff 603 OPCODE(OGF_BTSTACK, L2CAP_CREATE_CHANNEL_MTU), "B22"
mbed_Cookbook_SE 0:de03cbbcd0ff 604 // @param bd_addr(48), psm (16), mtu (16)
mbed_Cookbook_SE 0:de03cbbcd0ff 605 };
mbed_Cookbook_SE 0:de03cbbcd0ff 606 const hci_cmd_t l2cap_disconnect = {
mbed_Cookbook_SE 0:de03cbbcd0ff 607 OPCODE(OGF_BTSTACK, L2CAP_DISCONNECT), "21"
mbed_Cookbook_SE 0:de03cbbcd0ff 608 // @param channel(16), reason(8)
mbed_Cookbook_SE 0:de03cbbcd0ff 609 };
mbed_Cookbook_SE 0:de03cbbcd0ff 610 const hci_cmd_t l2cap_register_service = {
mbed_Cookbook_SE 0:de03cbbcd0ff 611 OPCODE(OGF_BTSTACK, L2CAP_REGISTER_SERVICE), "22"
mbed_Cookbook_SE 0:de03cbbcd0ff 612 // @param psm (16), mtu (16)
mbed_Cookbook_SE 0:de03cbbcd0ff 613 };
mbed_Cookbook_SE 0:de03cbbcd0ff 614 const hci_cmd_t l2cap_unregister_service = {
mbed_Cookbook_SE 0:de03cbbcd0ff 615 OPCODE(OGF_BTSTACK, L2CAP_UNREGISTER_SERVICE), "2"
mbed_Cookbook_SE 0:de03cbbcd0ff 616 // @param psm (16)
mbed_Cookbook_SE 0:de03cbbcd0ff 617 };
mbed_Cookbook_SE 0:de03cbbcd0ff 618 const hci_cmd_t l2cap_accept_connection = {
mbed_Cookbook_SE 0:de03cbbcd0ff 619 OPCODE(OGF_BTSTACK, L2CAP_ACCEPT_CONNECTION), "2"
mbed_Cookbook_SE 0:de03cbbcd0ff 620 // @param source cid (16)
mbed_Cookbook_SE 0:de03cbbcd0ff 621 };
mbed_Cookbook_SE 0:de03cbbcd0ff 622 const hci_cmd_t l2cap_decline_connection = {
mbed_Cookbook_SE 0:de03cbbcd0ff 623 OPCODE(OGF_BTSTACK, L2CAP_DECLINE_CONNECTION), "21"
mbed_Cookbook_SE 0:de03cbbcd0ff 624 // @param source cid (16), reason(8)
mbed_Cookbook_SE 0:de03cbbcd0ff 625 };
mbed_Cookbook_SE 0:de03cbbcd0ff 626 const hci_cmd_t sdp_register_service_record = {
mbed_Cookbook_SE 0:de03cbbcd0ff 627 OPCODE(OGF_BTSTACK, SDP_REGISTER_SERVICE_RECORD), "S"
mbed_Cookbook_SE 0:de03cbbcd0ff 628 // @param service record handle (DES)
mbed_Cookbook_SE 0:de03cbbcd0ff 629 };
mbed_Cookbook_SE 0:de03cbbcd0ff 630 const hci_cmd_t sdp_unregister_service_record = {
mbed_Cookbook_SE 0:de03cbbcd0ff 631 OPCODE(OGF_BTSTACK, SDP_UNREGISTER_SERVICE_RECORD), "4"
mbed_Cookbook_SE 0:de03cbbcd0ff 632 // @param service record handle (32)
mbed_Cookbook_SE 0:de03cbbcd0ff 633 };
mbed_Cookbook_SE 0:de03cbbcd0ff 634
mbed_Cookbook_SE 0:de03cbbcd0ff 635 // create rfcomm channel: @param bd_addr(48), channel (8)
mbed_Cookbook_SE 0:de03cbbcd0ff 636 const hci_cmd_t rfcomm_create_channel = {
mbed_Cookbook_SE 0:de03cbbcd0ff 637 OPCODE(OGF_BTSTACK, RFCOMM_CREATE_CHANNEL), "B1"
mbed_Cookbook_SE 0:de03cbbcd0ff 638 };
mbed_Cookbook_SE 0:de03cbbcd0ff 639 // create rfcomm channel: @param bd_addr(48), channel (8), mtu (16), credits (8)
mbed_Cookbook_SE 0:de03cbbcd0ff 640 const hci_cmd_t rfcomm_create_channel_with_initial_credits = {
mbed_Cookbook_SE 0:de03cbbcd0ff 641 OPCODE(OGF_BTSTACK, RFCOMM_CREATE_CHANNEL_WITH_CREDITS), "B121"
mbed_Cookbook_SE 0:de03cbbcd0ff 642 };
mbed_Cookbook_SE 0:de03cbbcd0ff 643 // grant credits: @param rfcomm_cid(16), credits (8)
mbed_Cookbook_SE 0:de03cbbcd0ff 644 const hci_cmd_t rfcomm_grants_credits= {
mbed_Cookbook_SE 0:de03cbbcd0ff 645 OPCODE(OGF_BTSTACK, RFCOMM_GRANT_CREDITS), "21"
mbed_Cookbook_SE 0:de03cbbcd0ff 646 };
mbed_Cookbook_SE 0:de03cbbcd0ff 647 // disconnect rfcomm disconnect, @param rfcomm_cid(16), reason(8)
mbed_Cookbook_SE 0:de03cbbcd0ff 648 const hci_cmd_t rfcomm_disconnect = {
mbed_Cookbook_SE 0:de03cbbcd0ff 649 OPCODE(OGF_BTSTACK, RFCOMM_DISCONNECT), "21"
mbed_Cookbook_SE 0:de03cbbcd0ff 650 };
mbed_Cookbook_SE 0:de03cbbcd0ff 651
mbed_Cookbook_SE 0:de03cbbcd0ff 652 // register rfcomm service: @param channel(8), mtu (16)
mbed_Cookbook_SE 0:de03cbbcd0ff 653 const hci_cmd_t rfcomm_register_service = {
mbed_Cookbook_SE 0:de03cbbcd0ff 654 OPCODE(OGF_BTSTACK, RFCOMM_REGISTER_SERVICE), "12"
mbed_Cookbook_SE 0:de03cbbcd0ff 655 };
mbed_Cookbook_SE 0:de03cbbcd0ff 656 // register rfcomm service: @param channel(8), mtu (16), initial credits (8)
mbed_Cookbook_SE 0:de03cbbcd0ff 657 const hci_cmd_t rfcomm_register_service_with_initial_credits = {
mbed_Cookbook_SE 0:de03cbbcd0ff 658 OPCODE(OGF_BTSTACK, RFCOMM_REGISTER_SERVICE_WITH_CREDITS), "121"
mbed_Cookbook_SE 0:de03cbbcd0ff 659 };
mbed_Cookbook_SE 0:de03cbbcd0ff 660
mbed_Cookbook_SE 0:de03cbbcd0ff 661 // unregister rfcomm service, @param service_channel(16)
mbed_Cookbook_SE 0:de03cbbcd0ff 662 const hci_cmd_t rfcomm_unregister_service = {
mbed_Cookbook_SE 0:de03cbbcd0ff 663 OPCODE(OGF_BTSTACK, RFCOMM_UNREGISTER_SERVICE), "2"
mbed_Cookbook_SE 0:de03cbbcd0ff 664 };
mbed_Cookbook_SE 0:de03cbbcd0ff 665 // accept connection @param source cid (16)
mbed_Cookbook_SE 0:de03cbbcd0ff 666 const hci_cmd_t rfcomm_accept_connection = {
mbed_Cookbook_SE 0:de03cbbcd0ff 667 OPCODE(OGF_BTSTACK, RFCOMM_ACCEPT_CONNECTION), "2"
mbed_Cookbook_SE 0:de03cbbcd0ff 668 };
mbed_Cookbook_SE 0:de03cbbcd0ff 669 // decline connection @param source cid (16)
mbed_Cookbook_SE 0:de03cbbcd0ff 670 const hci_cmd_t rfcomm_decline_connection = {
mbed_Cookbook_SE 0:de03cbbcd0ff 671 OPCODE(OGF_BTSTACK, RFCOMM_DECLINE_CONNECTION), "21"
mbed_Cookbook_SE 0:de03cbbcd0ff 672 };
mbed_Cookbook_SE 0:de03cbbcd0ff 673 // request persisten rfcomm channel number for named service
mbed_Cookbook_SE 0:de03cbbcd0ff 674 const hci_cmd_t rfcomm_persistent_channel_for_service = {
mbed_Cookbook_SE 0:de03cbbcd0ff 675 OPCODE(OGF_BTSTACK, RFCOMM_PERSISTENT_CHANNEL), "N"
mbed_Cookbook_SE 0:de03cbbcd0ff 676 };
mbed_Cookbook_SE 0:de03cbbcd0ff 677
mbed_Cookbook_SE 0:de03cbbcd0ff 678 // register rfcomm service: @param channel(8), mtu (16), initial credits (8)
mbed_Cookbook_SE 0:de03cbbcd0ff 679 extern const hci_cmd_t rfcomm_register_service_with_initial_credits;