hci.h 62 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453
  1. /*
  2. *
  3. * BlueZ - Bluetooth protocol stack for Linux
  4. *
  5. * Copyright (C) 2000-2001 Qualcomm Incorporated
  6. * Copyright (C) 2002-2003 Maxim Krasnyansky <maxk@qualcomm.com>
  7. * Copyright (C) 2002-2010 Marcel Holtmann <marcel@holtmann.org>
  8. *
  9. *
  10. * This program is free software; you can redistribute it and/or modify
  11. * it under the terms of the GNU General Public License as published by
  12. * the Free Software Foundation; either version 2 of the License, or
  13. * (at your option) any later version.
  14. *
  15. * This program is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. * GNU General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU General Public License
  21. * along with this program; if not, write to the Free Software
  22. * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  23. *
  24. */
  25. #ifndef __HCI_H
  26. #define __HCI_H
  27. #ifdef __cplusplus
  28. extern "C" {
  29. #endif
  30. #include <sys/socket.h>
  31. #define HCI_MAX_DEV 16
  32. #define HCI_MAX_ACL_SIZE (1492 + 4)
  33. #define HCI_MAX_SCO_SIZE 255
  34. #define HCI_MAX_EVENT_SIZE 260
  35. #define HCI_MAX_FRAME_SIZE (HCI_MAX_ACL_SIZE + 4)
  36. /* HCI dev events */
  37. #define HCI_DEV_REG 1
  38. #define HCI_DEV_UNREG 2
  39. #define HCI_DEV_UP 3
  40. #define HCI_DEV_DOWN 4
  41. #define HCI_DEV_SUSPEND 5
  42. #define HCI_DEV_RESUME 6
  43. /* HCI bus types */
  44. #define HCI_VIRTUAL 0
  45. #define HCI_USB 1
  46. #define HCI_PCCARD 2
  47. #define HCI_UART 3
  48. #define HCI_RS232 4
  49. #define HCI_PCI 5
  50. #define HCI_SDIO 6
  51. #define HCI_SPI 7
  52. #define HCI_I2C 8
  53. /* HCI controller types */
  54. #define HCI_PRIMARY 0x00
  55. #define HCI_AMP 0x01
  56. #define HCI_BREDR HCI_PRIMARY
  57. /* HCI device flags */
  58. enum {
  59. HCI_UP,
  60. HCI_INIT,
  61. HCI_RUNNING,
  62. HCI_PSCAN,
  63. HCI_ISCAN,
  64. HCI_AUTH,
  65. HCI_ENCRYPT,
  66. HCI_INQUIRY,
  67. HCI_RAW,
  68. };
  69. /* LE address type */
  70. enum {
  71. LE_PUBLIC_ADDRESS = 0x00,
  72. LE_RANDOM_ADDRESS = 0x01
  73. };
  74. /* HCI ioctl defines */
  75. #define HCIDEVUP _IOW('H', 201, int)
  76. #define HCIDEVDOWN _IOW('H', 202, int)
  77. #define HCIDEVRESET _IOW('H', 203, int)
  78. #define HCIDEVRESTAT _IOW('H', 204, int)
  79. #define HCIGETDEVLIST _IOR('H', 210, int)
  80. #define HCIGETDEVINFO _IOR('H', 211, int)
  81. #define HCIGETCONNLIST _IOR('H', 212, int)
  82. #define HCIGETCONNINFO _IOR('H', 213, int)
  83. #define HCIGETAUTHINFO _IOR('H', 215, int)
  84. #define HCISETRAW _IOW('H', 220, int)
  85. #define HCISETSCAN _IOW('H', 221, int)
  86. #define HCISETAUTH _IOW('H', 222, int)
  87. #define HCISETENCRYPT _IOW('H', 223, int)
  88. #define HCISETPTYPE _IOW('H', 224, int)
  89. #define HCISETLINKPOL _IOW('H', 225, int)
  90. #define HCISETLINKMODE _IOW('H', 226, int)
  91. #define HCISETACLMTU _IOW('H', 227, int)
  92. #define HCISETSCOMTU _IOW('H', 228, int)
  93. #define HCIBLOCKADDR _IOW('H', 230, int)
  94. #define HCIUNBLOCKADDR _IOW('H', 231, int)
  95. #define HCIINQUIRY _IOR('H', 240, int)
  96. #ifndef __NO_HCI_DEFS
  97. /* HCI Packet types */
  98. #define HCI_COMMAND_PKT 0x01
  99. #define HCI_ACLDATA_PKT 0x02
  100. #define HCI_SCODATA_PKT 0x03
  101. #define HCI_EVENT_PKT 0x04
  102. #define HCI_VENDOR_PKT 0xff
  103. /* HCI Packet types */
  104. #define HCI_2DH1 0x0002
  105. #define HCI_3DH1 0x0004
  106. #define HCI_DM1 0x0008
  107. #define HCI_DH1 0x0010
  108. #define HCI_2DH3 0x0100
  109. #define HCI_3DH3 0x0200
  110. #define HCI_DM3 0x0400
  111. #define HCI_DH3 0x0800
  112. #define HCI_2DH5 0x1000
  113. #define HCI_3DH5 0x2000
  114. #define HCI_DM5 0x4000
  115. #define HCI_DH5 0x8000
  116. #define HCI_HV1 0x0020
  117. #define HCI_HV2 0x0040
  118. #define HCI_HV3 0x0080
  119. #define HCI_EV3 0x0008
  120. #define HCI_EV4 0x0010
  121. #define HCI_EV5 0x0020
  122. #define HCI_2EV3 0x0040
  123. #define HCI_3EV3 0x0080
  124. #define HCI_2EV5 0x0100
  125. #define HCI_3EV5 0x0200
  126. #define SCO_PTYPE_MASK (HCI_HV1 | HCI_HV2 | HCI_HV3)
  127. #define ACL_PTYPE_MASK (HCI_DM1 | HCI_DH1 | HCI_DM3 | HCI_DH3 | HCI_DM5 | HCI_DH5)
  128. /* HCI Error codes */
  129. #define HCI_UNKNOWN_COMMAND 0x01
  130. #define HCI_NO_CONNECTION 0x02
  131. #define HCI_HARDWARE_FAILURE 0x03
  132. #define HCI_PAGE_TIMEOUT 0x04
  133. #define HCI_AUTHENTICATION_FAILURE 0x05
  134. #define HCI_PIN_OR_KEY_MISSING 0x06
  135. #define HCI_MEMORY_FULL 0x07
  136. #define HCI_CONNECTION_TIMEOUT 0x08
  137. #define HCI_MAX_NUMBER_OF_CONNECTIONS 0x09
  138. #define HCI_MAX_NUMBER_OF_SCO_CONNECTIONS 0x0a
  139. #define HCI_ACL_CONNECTION_EXISTS 0x0b
  140. #define HCI_COMMAND_DISALLOWED 0x0c
  141. #define HCI_REJECTED_LIMITED_RESOURCES 0x0d
  142. #define HCI_REJECTED_SECURITY 0x0e
  143. #define HCI_REJECTED_PERSONAL 0x0f
  144. #define HCI_HOST_TIMEOUT 0x10
  145. #define HCI_UNSUPPORTED_FEATURE 0x11
  146. #define HCI_INVALID_PARAMETERS 0x12
  147. #define HCI_OE_USER_ENDED_CONNECTION 0x13
  148. #define HCI_OE_LOW_RESOURCES 0x14
  149. #define HCI_OE_POWER_OFF 0x15
  150. #define HCI_CONNECTION_TERMINATED 0x16
  151. #define HCI_REPEATED_ATTEMPTS 0x17
  152. #define HCI_PAIRING_NOT_ALLOWED 0x18
  153. #define HCI_UNKNOWN_LMP_PDU 0x19
  154. #define HCI_UNSUPPORTED_REMOTE_FEATURE 0x1a
  155. #define HCI_SCO_OFFSET_REJECTED 0x1b
  156. #define HCI_SCO_INTERVAL_REJECTED 0x1c
  157. #define HCI_AIR_MODE_REJECTED 0x1d
  158. #define HCI_INVALID_LMP_PARAMETERS 0x1e
  159. #define HCI_UNSPECIFIED_ERROR 0x1f
  160. #define HCI_UNSUPPORTED_LMP_PARAMETER_VALUE 0x20
  161. #define HCI_ROLE_CHANGE_NOT_ALLOWED 0x21
  162. #define HCI_LMP_RESPONSE_TIMEOUT 0x22
  163. #define HCI_LMP_ERROR_TRANSACTION_COLLISION 0x23
  164. #define HCI_LMP_PDU_NOT_ALLOWED 0x24
  165. #define HCI_ENCRYPTION_MODE_NOT_ACCEPTED 0x25
  166. #define HCI_UNIT_LINK_KEY_USED 0x26
  167. #define HCI_QOS_NOT_SUPPORTED 0x27
  168. #define HCI_INSTANT_PASSED 0x28
  169. #define HCI_PAIRING_NOT_SUPPORTED 0x29
  170. #define HCI_TRANSACTION_COLLISION 0x2a
  171. #define HCI_QOS_UNACCEPTABLE_PARAMETER 0x2c
  172. #define HCI_QOS_REJECTED 0x2d
  173. #define HCI_CLASSIFICATION_NOT_SUPPORTED 0x2e
  174. #define HCI_INSUFFICIENT_SECURITY 0x2f
  175. #define HCI_PARAMETER_OUT_OF_RANGE 0x30
  176. #define HCI_ROLE_SWITCH_PENDING 0x32
  177. #define HCI_SLOT_VIOLATION 0x34
  178. #define HCI_ROLE_SWITCH_FAILED 0x35
  179. #define HCI_EIR_TOO_LARGE 0x36
  180. #define HCI_SIMPLE_PAIRING_NOT_SUPPORTED 0x37
  181. #define HCI_HOST_BUSY_PAIRING 0x38
  182. /* ACL flags */
  183. #define ACL_START_NO_FLUSH 0x00
  184. #define ACL_CONT 0x01
  185. #define ACL_START 0x02
  186. #define ACL_ACTIVE_BCAST 0x04
  187. #define ACL_PICO_BCAST 0x08
  188. /* Baseband links */
  189. #define SCO_LINK 0x00
  190. #define ACL_LINK 0x01
  191. #define ESCO_LINK 0x02
  192. /* LMP features */
  193. #define LMP_3SLOT 0x01
  194. #define LMP_5SLOT 0x02
  195. #define LMP_ENCRYPT 0x04
  196. #define LMP_SOFFSET 0x08
  197. #define LMP_TACCURACY 0x10
  198. #define LMP_RSWITCH 0x20
  199. #define LMP_HOLD 0x40
  200. #define LMP_SNIFF 0x80
  201. #define LMP_PARK 0x01
  202. #define LMP_RSSI 0x02
  203. #define LMP_QUALITY 0x04
  204. #define LMP_SCO 0x08
  205. #define LMP_HV2 0x10
  206. #define LMP_HV3 0x20
  207. #define LMP_ULAW 0x40
  208. #define LMP_ALAW 0x80
  209. #define LMP_CVSD 0x01
  210. #define LMP_PSCHEME 0x02
  211. #define LMP_PCONTROL 0x04
  212. #define LMP_TRSP_SCO 0x08
  213. #define LMP_BCAST_ENC 0x80
  214. #define LMP_EDR_ACL_2M 0x02
  215. #define LMP_EDR_ACL_3M 0x04
  216. #define LMP_ENH_ISCAN 0x08
  217. #define LMP_ILACE_ISCAN 0x10
  218. #define LMP_ILACE_PSCAN 0x20
  219. #define LMP_RSSI_INQ 0x40
  220. #define LMP_ESCO 0x80
  221. #define LMP_EV4 0x01
  222. #define LMP_EV5 0x02
  223. #define LMP_AFH_CAP_SLV 0x08
  224. #define LMP_AFH_CLS_SLV 0x10
  225. #define LMP_NO_BREDR 0x20
  226. #define LMP_LE 0x40
  227. #define LMP_EDR_3SLOT 0x80
  228. #define LMP_EDR_5SLOT 0x01
  229. #define LMP_SNIFF_SUBR 0x02
  230. #define LMP_PAUSE_ENC 0x04
  231. #define LMP_AFH_CAP_MST 0x08
  232. #define LMP_AFH_CLS_MST 0x10
  233. #define LMP_EDR_ESCO_2M 0x20
  234. #define LMP_EDR_ESCO_3M 0x40
  235. #define LMP_EDR_3S_ESCO 0x80
  236. #define LMP_EXT_INQ 0x01
  237. #define LMP_LE_BREDR 0x02
  238. #define LMP_SIMPLE_PAIR 0x08
  239. #define LMP_ENCAPS_PDU 0x10
  240. #define LMP_ERR_DAT_REP 0x20
  241. #define LMP_NFLUSH_PKTS 0x40
  242. #define LMP_LSTO 0x01
  243. #define LMP_INQ_TX_PWR 0x02
  244. #define LMP_EPC 0x04
  245. #define LMP_EXT_FEAT 0x80
  246. /* Extended LMP features */
  247. #define LMP_HOST_SSP 0x01
  248. #define LMP_HOST_LE 0x02
  249. #define LMP_HOST_LE_BREDR 0x04
  250. /* Link policies */
  251. #define HCI_LP_RSWITCH 0x0001
  252. #define HCI_LP_HOLD 0x0002
  253. #define HCI_LP_SNIFF 0x0004
  254. #define HCI_LP_PARK 0x0008
  255. /* Link mode */
  256. #define HCI_LM_ACCEPT 0x8000
  257. #define HCI_LM_MASTER 0x0001
  258. #define HCI_LM_AUTH 0x0002
  259. #define HCI_LM_ENCRYPT 0x0004
  260. #define HCI_LM_TRUSTED 0x0008
  261. #define HCI_LM_RELIABLE 0x0010
  262. #define HCI_LM_SECURE 0x0020
  263. /* Link Key types */
  264. #define HCI_LK_COMBINATION 0x00
  265. #define HCI_LK_LOCAL_UNIT 0x01
  266. #define HCI_LK_REMOTE_UNIT 0x02
  267. #define HCI_LK_DEBUG_COMBINATION 0x03
  268. #define HCI_LK_UNAUTH_COMBINATION 0x04
  269. #define HCI_LK_AUTH_COMBINATION 0x05
  270. #define HCI_LK_CHANGED_COMBINATION 0x06
  271. #define HCI_LK_INVALID 0xFF
  272. /* ----- HCI Commands ----- */
  273. /* Link Control */
  274. #define OGF_LINK_CTL 0x01
  275. #define OCF_INQUIRY 0x0001
  276. typedef struct {
  277. uint8_t lap[3];
  278. uint8_t length; /* 1.28s units */
  279. uint8_t num_rsp;
  280. } __attribute__ ((packed)) inquiry_cp;
  281. #define INQUIRY_CP_SIZE 5
  282. typedef struct {
  283. uint8_t status;
  284. bdaddr_t bdaddr;
  285. } __attribute__ ((packed)) status_bdaddr_rp;
  286. #define STATUS_BDADDR_RP_SIZE 7
  287. #define OCF_INQUIRY_CANCEL 0x0002
  288. #define OCF_PERIODIC_INQUIRY 0x0003
  289. typedef struct {
  290. uint16_t max_period; /* 1.28s units */
  291. uint16_t min_period; /* 1.28s units */
  292. uint8_t lap[3];
  293. uint8_t length; /* 1.28s units */
  294. uint8_t num_rsp;
  295. } __attribute__ ((packed)) periodic_inquiry_cp;
  296. #define PERIODIC_INQUIRY_CP_SIZE 9
  297. #define OCF_EXIT_PERIODIC_INQUIRY 0x0004
  298. #define OCF_CREATE_CONN 0x0005
  299. typedef struct {
  300. bdaddr_t bdaddr;
  301. uint16_t pkt_type;
  302. uint8_t pscan_rep_mode;
  303. uint8_t pscan_mode;
  304. uint16_t clock_offset;
  305. uint8_t role_switch;
  306. } __attribute__ ((packed)) create_conn_cp;
  307. #define CREATE_CONN_CP_SIZE 13
  308. #define OCF_DISCONNECT 0x0006
  309. typedef struct {
  310. uint16_t handle;
  311. uint8_t reason;
  312. } __attribute__ ((packed)) disconnect_cp;
  313. #define DISCONNECT_CP_SIZE 3
  314. #define OCF_ADD_SCO 0x0007
  315. typedef struct {
  316. uint16_t handle;
  317. uint16_t pkt_type;
  318. } __attribute__ ((packed)) add_sco_cp;
  319. #define ADD_SCO_CP_SIZE 4
  320. #define OCF_CREATE_CONN_CANCEL 0x0008
  321. typedef struct {
  322. bdaddr_t bdaddr;
  323. } __attribute__ ((packed)) create_conn_cancel_cp;
  324. #define CREATE_CONN_CANCEL_CP_SIZE 6
  325. #define OCF_ACCEPT_CONN_REQ 0x0009
  326. typedef struct {
  327. bdaddr_t bdaddr;
  328. uint8_t role;
  329. } __attribute__ ((packed)) accept_conn_req_cp;
  330. #define ACCEPT_CONN_REQ_CP_SIZE 7
  331. #define OCF_REJECT_CONN_REQ 0x000A
  332. typedef struct {
  333. bdaddr_t bdaddr;
  334. uint8_t reason;
  335. } __attribute__ ((packed)) reject_conn_req_cp;
  336. #define REJECT_CONN_REQ_CP_SIZE 7
  337. #define OCF_LINK_KEY_REPLY 0x000B
  338. typedef struct {
  339. bdaddr_t bdaddr;
  340. uint8_t link_key[16];
  341. } __attribute__ ((packed)) link_key_reply_cp;
  342. #define LINK_KEY_REPLY_CP_SIZE 22
  343. #define OCF_LINK_KEY_NEG_REPLY 0x000C
  344. #define OCF_PIN_CODE_REPLY 0x000D
  345. typedef struct {
  346. bdaddr_t bdaddr;
  347. uint8_t pin_len;
  348. uint8_t pin_code[16];
  349. } __attribute__ ((packed)) pin_code_reply_cp;
  350. #define PIN_CODE_REPLY_CP_SIZE 23
  351. #define OCF_PIN_CODE_NEG_REPLY 0x000E
  352. #define OCF_SET_CONN_PTYPE 0x000F
  353. typedef struct {
  354. uint16_t handle;
  355. uint16_t pkt_type;
  356. } __attribute__ ((packed)) set_conn_ptype_cp;
  357. #define SET_CONN_PTYPE_CP_SIZE 4
  358. #define OCF_AUTH_REQUESTED 0x0011
  359. typedef struct {
  360. uint16_t handle;
  361. } __attribute__ ((packed)) auth_requested_cp;
  362. #define AUTH_REQUESTED_CP_SIZE 2
  363. #define OCF_SET_CONN_ENCRYPT 0x0013
  364. typedef struct {
  365. uint16_t handle;
  366. uint8_t encrypt;
  367. } __attribute__ ((packed)) set_conn_encrypt_cp;
  368. #define SET_CONN_ENCRYPT_CP_SIZE 3
  369. #define OCF_CHANGE_CONN_LINK_KEY 0x0015
  370. typedef struct {
  371. uint16_t handle;
  372. } __attribute__ ((packed)) change_conn_link_key_cp;
  373. #define CHANGE_CONN_LINK_KEY_CP_SIZE 2
  374. #define OCF_MASTER_LINK_KEY 0x0017
  375. typedef struct {
  376. uint8_t key_flag;
  377. } __attribute__ ((packed)) master_link_key_cp;
  378. #define MASTER_LINK_KEY_CP_SIZE 1
  379. #define OCF_REMOTE_NAME_REQ 0x0019
  380. typedef struct {
  381. bdaddr_t bdaddr;
  382. uint8_t pscan_rep_mode;
  383. uint8_t pscan_mode;
  384. uint16_t clock_offset;
  385. } __attribute__ ((packed)) remote_name_req_cp;
  386. #define REMOTE_NAME_REQ_CP_SIZE 10
  387. #define OCF_REMOTE_NAME_REQ_CANCEL 0x001A
  388. typedef struct {
  389. bdaddr_t bdaddr;
  390. } __attribute__ ((packed)) remote_name_req_cancel_cp;
  391. #define REMOTE_NAME_REQ_CANCEL_CP_SIZE 6
  392. #define OCF_READ_REMOTE_FEATURES 0x001B
  393. typedef struct {
  394. uint16_t handle;
  395. } __attribute__ ((packed)) read_remote_features_cp;
  396. #define READ_REMOTE_FEATURES_CP_SIZE 2
  397. #define OCF_READ_REMOTE_EXT_FEATURES 0x001C
  398. typedef struct {
  399. uint16_t handle;
  400. uint8_t page_num;
  401. } __attribute__ ((packed)) read_remote_ext_features_cp;
  402. #define READ_REMOTE_EXT_FEATURES_CP_SIZE 3
  403. #define OCF_READ_REMOTE_VERSION 0x001D
  404. typedef struct {
  405. uint16_t handle;
  406. } __attribute__ ((packed)) read_remote_version_cp;
  407. #define READ_REMOTE_VERSION_CP_SIZE 2
  408. #define OCF_READ_CLOCK_OFFSET 0x001F
  409. typedef struct {
  410. uint16_t handle;
  411. } __attribute__ ((packed)) read_clock_offset_cp;
  412. #define READ_CLOCK_OFFSET_CP_SIZE 2
  413. #define OCF_READ_LMP_HANDLE 0x0020
  414. #define OCF_SETUP_SYNC_CONN 0x0028
  415. typedef struct {
  416. uint16_t handle;
  417. uint32_t tx_bandwith;
  418. uint32_t rx_bandwith;
  419. uint16_t max_latency;
  420. uint16_t voice_setting;
  421. uint8_t retrans_effort;
  422. uint16_t pkt_type;
  423. } __attribute__ ((packed)) setup_sync_conn_cp;
  424. #define SETUP_SYNC_CONN_CP_SIZE 17
  425. #define OCF_ACCEPT_SYNC_CONN_REQ 0x0029
  426. typedef struct {
  427. bdaddr_t bdaddr;
  428. uint32_t tx_bandwith;
  429. uint32_t rx_bandwith;
  430. uint16_t max_latency;
  431. uint16_t voice_setting;
  432. uint8_t retrans_effort;
  433. uint16_t pkt_type;
  434. } __attribute__ ((packed)) accept_sync_conn_req_cp;
  435. #define ACCEPT_SYNC_CONN_REQ_CP_SIZE 21
  436. #define OCF_REJECT_SYNC_CONN_REQ 0x002A
  437. typedef struct {
  438. bdaddr_t bdaddr;
  439. uint8_t reason;
  440. } __attribute__ ((packed)) reject_sync_conn_req_cp;
  441. #define REJECT_SYNC_CONN_REQ_CP_SIZE 7
  442. #define OCF_IO_CAPABILITY_REPLY 0x002B
  443. typedef struct {
  444. bdaddr_t bdaddr;
  445. uint8_t capability;
  446. uint8_t oob_data;
  447. uint8_t authentication;
  448. } __attribute__ ((packed)) io_capability_reply_cp;
  449. #define IO_CAPABILITY_REPLY_CP_SIZE 9
  450. #define OCF_USER_CONFIRM_REPLY 0x002C
  451. typedef struct {
  452. bdaddr_t bdaddr;
  453. } __attribute__ ((packed)) user_confirm_reply_cp;
  454. #define USER_CONFIRM_REPLY_CP_SIZE 6
  455. #define OCF_USER_CONFIRM_NEG_REPLY 0x002D
  456. #define OCF_USER_PASSKEY_REPLY 0x002E
  457. typedef struct {
  458. bdaddr_t bdaddr;
  459. uint32_t passkey;
  460. } __attribute__ ((packed)) user_passkey_reply_cp;
  461. #define USER_PASSKEY_REPLY_CP_SIZE 10
  462. #define OCF_USER_PASSKEY_NEG_REPLY 0x002F
  463. #define OCF_REMOTE_OOB_DATA_REPLY 0x0030
  464. typedef struct {
  465. bdaddr_t bdaddr;
  466. uint8_t hash[16];
  467. uint8_t randomizer[16];
  468. } __attribute__ ((packed)) remote_oob_data_reply_cp;
  469. #define REMOTE_OOB_DATA_REPLY_CP_SIZE 38
  470. #define OCF_REMOTE_OOB_DATA_NEG_REPLY 0x0033
  471. #define OCF_IO_CAPABILITY_NEG_REPLY 0x0034
  472. typedef struct {
  473. bdaddr_t bdaddr;
  474. uint8_t reason;
  475. } __attribute__ ((packed)) io_capability_neg_reply_cp;
  476. #define IO_CAPABILITY_NEG_REPLY_CP_SIZE 7
  477. #define OCF_CREATE_PHYSICAL_LINK 0x0035
  478. typedef struct {
  479. uint8_t handle;
  480. uint8_t key_length;
  481. uint8_t key_type;
  482. uint8_t key[32];
  483. } __attribute__ ((packed)) create_physical_link_cp;
  484. #define CREATE_PHYSICAL_LINK_CP_SIZE 35
  485. #define OCF_ACCEPT_PHYSICAL_LINK 0x0036
  486. typedef struct {
  487. uint8_t handle;
  488. uint8_t key_length;
  489. uint8_t key_type;
  490. uint8_t key[32];
  491. } __attribute__ ((packed)) accept_physical_link_cp;
  492. #define ACCEPT_PHYSICAL_LINK_CP_SIZE 35
  493. #define OCF_DISCONNECT_PHYSICAL_LINK 0x0037
  494. typedef struct {
  495. uint8_t handle;
  496. uint8_t reason;
  497. } __attribute__ ((packed)) disconnect_physical_link_cp;
  498. #define DISCONNECT_PHYSICAL_LINK_CP_SIZE 2
  499. #define OCF_CREATE_LOGICAL_LINK 0x0038
  500. typedef struct {
  501. uint8_t handle;
  502. uint8_t tx_flow[16];
  503. uint8_t rx_flow[16];
  504. } __attribute__ ((packed)) create_logical_link_cp;
  505. #define CREATE_LOGICAL_LINK_CP_SIZE 33
  506. #define OCF_ACCEPT_LOGICAL_LINK 0x0039
  507. #define OCF_DISCONNECT_LOGICAL_LINK 0x003A
  508. typedef struct {
  509. uint16_t handle;
  510. } __attribute__ ((packed)) disconnect_logical_link_cp;
  511. #define DISCONNECT_LOGICAL_LINK_CP_SIZE 2
  512. #define OCF_LOGICAL_LINK_CANCEL 0x003B
  513. typedef struct {
  514. uint8_t handle;
  515. uint8_t tx_flow_id;
  516. } __attribute__ ((packed)) cancel_logical_link_cp;
  517. #define LOGICAL_LINK_CANCEL_CP_SIZE 2
  518. typedef struct {
  519. uint8_t status;
  520. uint8_t handle;
  521. uint8_t tx_flow_id;
  522. } __attribute__ ((packed)) cancel_logical_link_rp;
  523. #define LOGICAL_LINK_CANCEL_RP_SIZE 3
  524. #define OCF_FLOW_SPEC_MODIFY 0x003C
  525. /* Link Policy */
  526. #define OGF_LINK_POLICY 0x02
  527. #define OCF_HOLD_MODE 0x0001
  528. typedef struct {
  529. uint16_t handle;
  530. uint16_t max_interval;
  531. uint16_t min_interval;
  532. } __attribute__ ((packed)) hold_mode_cp;
  533. #define HOLD_MODE_CP_SIZE 6
  534. #define OCF_SNIFF_MODE 0x0003
  535. typedef struct {
  536. uint16_t handle;
  537. uint16_t max_interval;
  538. uint16_t min_interval;
  539. uint16_t attempt;
  540. uint16_t timeout;
  541. } __attribute__ ((packed)) sniff_mode_cp;
  542. #define SNIFF_MODE_CP_SIZE 10
  543. #define OCF_EXIT_SNIFF_MODE 0x0004
  544. typedef struct {
  545. uint16_t handle;
  546. } __attribute__ ((packed)) exit_sniff_mode_cp;
  547. #define EXIT_SNIFF_MODE_CP_SIZE 2
  548. #define OCF_PARK_MODE 0x0005
  549. typedef struct {
  550. uint16_t handle;
  551. uint16_t max_interval;
  552. uint16_t min_interval;
  553. } __attribute__ ((packed)) park_mode_cp;
  554. #define PARK_MODE_CP_SIZE 6
  555. #define OCF_EXIT_PARK_MODE 0x0006
  556. typedef struct {
  557. uint16_t handle;
  558. } __attribute__ ((packed)) exit_park_mode_cp;
  559. #define EXIT_PARK_MODE_CP_SIZE 2
  560. #define OCF_QOS_SETUP 0x0007
  561. typedef struct {
  562. uint8_t service_type; /* 1 = best effort */
  563. uint32_t token_rate; /* Byte per seconds */
  564. uint32_t peak_bandwidth; /* Byte per seconds */
  565. uint32_t latency; /* Microseconds */
  566. uint32_t delay_variation; /* Microseconds */
  567. } __attribute__ ((packed)) hci_qos;
  568. #define HCI_QOS_CP_SIZE 17
  569. typedef struct {
  570. uint16_t handle;
  571. uint8_t flags; /* Reserved */
  572. hci_qos qos;
  573. } __attribute__ ((packed)) qos_setup_cp;
  574. #define QOS_SETUP_CP_SIZE (3 + HCI_QOS_CP_SIZE)
  575. #define OCF_ROLE_DISCOVERY 0x0009
  576. typedef struct {
  577. uint16_t handle;
  578. } __attribute__ ((packed)) role_discovery_cp;
  579. #define ROLE_DISCOVERY_CP_SIZE 2
  580. typedef struct {
  581. uint8_t status;
  582. uint16_t handle;
  583. uint8_t role;
  584. } __attribute__ ((packed)) role_discovery_rp;
  585. #define ROLE_DISCOVERY_RP_SIZE 4
  586. #define OCF_SWITCH_ROLE 0x000B
  587. typedef struct {
  588. bdaddr_t bdaddr;
  589. uint8_t role;
  590. } __attribute__ ((packed)) switch_role_cp;
  591. #define SWITCH_ROLE_CP_SIZE 7
  592. #define OCF_READ_LINK_POLICY 0x000C
  593. typedef struct {
  594. uint16_t handle;
  595. } __attribute__ ((packed)) read_link_policy_cp;
  596. #define READ_LINK_POLICY_CP_SIZE 2
  597. typedef struct {
  598. uint8_t status;
  599. uint16_t handle;
  600. uint16_t policy;
  601. } __attribute__ ((packed)) read_link_policy_rp;
  602. #define READ_LINK_POLICY_RP_SIZE 5
  603. #define OCF_WRITE_LINK_POLICY 0x000D
  604. typedef struct {
  605. uint16_t handle;
  606. uint16_t policy;
  607. } __attribute__ ((packed)) write_link_policy_cp;
  608. #define WRITE_LINK_POLICY_CP_SIZE 4
  609. typedef struct {
  610. uint8_t status;
  611. uint16_t handle;
  612. } __attribute__ ((packed)) write_link_policy_rp;
  613. #define WRITE_LINK_POLICY_RP_SIZE 3
  614. #define OCF_READ_DEFAULT_LINK_POLICY 0x000E
  615. #define OCF_WRITE_DEFAULT_LINK_POLICY 0x000F
  616. #define OCF_FLOW_SPECIFICATION 0x0010
  617. #define OCF_SNIFF_SUBRATING 0x0011
  618. typedef struct {
  619. uint16_t handle;
  620. uint16_t max_latency;
  621. uint16_t min_remote_timeout;
  622. uint16_t min_local_timeout;
  623. } __attribute__ ((packed)) sniff_subrating_cp;
  624. #define SNIFF_SUBRATING_CP_SIZE 8
  625. /* Host Controller and Baseband */
  626. #define OGF_HOST_CTL 0x03
  627. #define OCF_SET_EVENT_MASK 0x0001
  628. typedef struct {
  629. uint8_t mask[8];
  630. } __attribute__ ((packed)) set_event_mask_cp;
  631. #define SET_EVENT_MASK_CP_SIZE 8
  632. #define OCF_RESET 0x0003
  633. #define OCF_SET_EVENT_FLT 0x0005
  634. typedef struct {
  635. uint8_t flt_type;
  636. uint8_t cond_type;
  637. uint8_t condition[0];
  638. } __attribute__ ((packed)) set_event_flt_cp;
  639. #define SET_EVENT_FLT_CP_SIZE 2
  640. /* Filter types */
  641. #define FLT_CLEAR_ALL 0x00
  642. #define FLT_INQ_RESULT 0x01
  643. #define FLT_CONN_SETUP 0x02
  644. /* INQ_RESULT Condition types */
  645. #define INQ_RESULT_RETURN_ALL 0x00
  646. #define INQ_RESULT_RETURN_CLASS 0x01
  647. #define INQ_RESULT_RETURN_BDADDR 0x02
  648. /* CONN_SETUP Condition types */
  649. #define CONN_SETUP_ALLOW_ALL 0x00
  650. #define CONN_SETUP_ALLOW_CLASS 0x01
  651. #define CONN_SETUP_ALLOW_BDADDR 0x02
  652. /* CONN_SETUP Conditions */
  653. #define CONN_SETUP_AUTO_OFF 0x01
  654. #define CONN_SETUP_AUTO_ON 0x02
  655. #define OCF_FLUSH 0x0008
  656. #define OCF_READ_PIN_TYPE 0x0009
  657. typedef struct {
  658. uint8_t status;
  659. uint8_t pin_type;
  660. } __attribute__ ((packed)) read_pin_type_rp;
  661. #define READ_PIN_TYPE_RP_SIZE 2
  662. #define OCF_WRITE_PIN_TYPE 0x000A
  663. typedef struct {
  664. uint8_t pin_type;
  665. } __attribute__ ((packed)) write_pin_type_cp;
  666. #define WRITE_PIN_TYPE_CP_SIZE 1
  667. #define OCF_CREATE_NEW_UNIT_KEY 0x000B
  668. #define OCF_READ_STORED_LINK_KEY 0x000D
  669. typedef struct {
  670. bdaddr_t bdaddr;
  671. uint8_t read_all;
  672. } __attribute__ ((packed)) read_stored_link_key_cp;
  673. #define READ_STORED_LINK_KEY_CP_SIZE 7
  674. typedef struct {
  675. uint8_t status;
  676. uint16_t max_keys;
  677. uint16_t num_keys;
  678. } __attribute__ ((packed)) read_stored_link_key_rp;
  679. #define READ_STORED_LINK_KEY_RP_SIZE 5
  680. #define OCF_WRITE_STORED_LINK_KEY 0x0011
  681. typedef struct {
  682. uint8_t num_keys;
  683. /* variable length part */
  684. } __attribute__ ((packed)) write_stored_link_key_cp;
  685. #define WRITE_STORED_LINK_KEY_CP_SIZE 1
  686. typedef struct {
  687. uint8_t status;
  688. uint8_t num_keys;
  689. } __attribute__ ((packed)) write_stored_link_key_rp;
  690. #define READ_WRITE_LINK_KEY_RP_SIZE 2
  691. #define OCF_DELETE_STORED_LINK_KEY 0x0012
  692. typedef struct {
  693. bdaddr_t bdaddr;
  694. uint8_t delete_all;
  695. } __attribute__ ((packed)) delete_stored_link_key_cp;
  696. #define DELETE_STORED_LINK_KEY_CP_SIZE 7
  697. typedef struct {
  698. uint8_t status;
  699. uint16_t num_keys;
  700. } __attribute__ ((packed)) delete_stored_link_key_rp;
  701. #define DELETE_STORED_LINK_KEY_RP_SIZE 3
  702. #define HCI_MAX_NAME_LENGTH 248
  703. #define OCF_CHANGE_LOCAL_NAME 0x0013
  704. typedef struct {
  705. uint8_t name[HCI_MAX_NAME_LENGTH];
  706. } __attribute__ ((packed)) change_local_name_cp;
  707. #define CHANGE_LOCAL_NAME_CP_SIZE 248
  708. #define OCF_READ_LOCAL_NAME 0x0014
  709. typedef struct {
  710. uint8_t status;
  711. uint8_t name[HCI_MAX_NAME_LENGTH];
  712. } __attribute__ ((packed)) read_local_name_rp;
  713. #define READ_LOCAL_NAME_RP_SIZE 249
  714. #define OCF_READ_CONN_ACCEPT_TIMEOUT 0x0015
  715. typedef struct {
  716. uint8_t status;
  717. uint16_t timeout;
  718. } __attribute__ ((packed)) read_conn_accept_timeout_rp;
  719. #define READ_CONN_ACCEPT_TIMEOUT_RP_SIZE 3
  720. #define OCF_WRITE_CONN_ACCEPT_TIMEOUT 0x0016
  721. typedef struct {
  722. uint16_t timeout;
  723. } __attribute__ ((packed)) write_conn_accept_timeout_cp;
  724. #define WRITE_CONN_ACCEPT_TIMEOUT_CP_SIZE 2
  725. #define OCF_READ_PAGE_TIMEOUT 0x0017
  726. typedef struct {
  727. uint8_t status;
  728. uint16_t timeout;
  729. } __attribute__ ((packed)) read_page_timeout_rp;
  730. #define READ_PAGE_TIMEOUT_RP_SIZE 3
  731. #define OCF_WRITE_PAGE_TIMEOUT 0x0018
  732. typedef struct {
  733. uint16_t timeout;
  734. } __attribute__ ((packed)) write_page_timeout_cp;
  735. #define WRITE_PAGE_TIMEOUT_CP_SIZE 2
  736. #define OCF_READ_SCAN_ENABLE 0x0019
  737. typedef struct {
  738. uint8_t status;
  739. uint8_t enable;
  740. } __attribute__ ((packed)) read_scan_enable_rp;
  741. #define READ_SCAN_ENABLE_RP_SIZE 2
  742. #define OCF_WRITE_SCAN_ENABLE 0x001A
  743. #define SCAN_DISABLED 0x00
  744. #define SCAN_INQUIRY 0x01
  745. #define SCAN_PAGE 0x02
  746. #define OCF_READ_PAGE_ACTIVITY 0x001B
  747. typedef struct {
  748. uint8_t status;
  749. uint16_t interval;
  750. uint16_t window;
  751. } __attribute__ ((packed)) read_page_activity_rp;
  752. #define READ_PAGE_ACTIVITY_RP_SIZE 5
  753. #define OCF_WRITE_PAGE_ACTIVITY 0x001C
  754. typedef struct {
  755. uint16_t interval;
  756. uint16_t window;
  757. } __attribute__ ((packed)) write_page_activity_cp;
  758. #define WRITE_PAGE_ACTIVITY_CP_SIZE 4
  759. #define OCF_READ_INQ_ACTIVITY 0x001D
  760. typedef struct {
  761. uint8_t status;
  762. uint16_t interval;
  763. uint16_t window;
  764. } __attribute__ ((packed)) read_inq_activity_rp;
  765. #define READ_INQ_ACTIVITY_RP_SIZE 5
  766. #define OCF_WRITE_INQ_ACTIVITY 0x001E
  767. typedef struct {
  768. uint16_t interval;
  769. uint16_t window;
  770. } __attribute__ ((packed)) write_inq_activity_cp;
  771. #define WRITE_INQ_ACTIVITY_CP_SIZE 4
  772. #define OCF_READ_AUTH_ENABLE 0x001F
  773. #define OCF_WRITE_AUTH_ENABLE 0x0020
  774. #define AUTH_DISABLED 0x00
  775. #define AUTH_ENABLED 0x01
  776. #define OCF_READ_ENCRYPT_MODE 0x0021
  777. #define OCF_WRITE_ENCRYPT_MODE 0x0022
  778. #define ENCRYPT_DISABLED 0x00
  779. #define ENCRYPT_P2P 0x01
  780. #define ENCRYPT_BOTH 0x02
  781. #define OCF_READ_CLASS_OF_DEV 0x0023
  782. typedef struct {
  783. uint8_t status;
  784. uint8_t dev_class[3];
  785. } __attribute__ ((packed)) read_class_of_dev_rp;
  786. #define READ_CLASS_OF_DEV_RP_SIZE 4
  787. #define OCF_WRITE_CLASS_OF_DEV 0x0024
  788. typedef struct {
  789. uint8_t dev_class[3];
  790. } __attribute__ ((packed)) write_class_of_dev_cp;
  791. #define WRITE_CLASS_OF_DEV_CP_SIZE 3
  792. #define OCF_READ_VOICE_SETTING 0x0025
  793. typedef struct {
  794. uint8_t status;
  795. uint16_t voice_setting;
  796. } __attribute__ ((packed)) read_voice_setting_rp;
  797. #define READ_VOICE_SETTING_RP_SIZE 3
  798. #define OCF_WRITE_VOICE_SETTING 0x0026
  799. typedef struct {
  800. uint16_t voice_setting;
  801. } __attribute__ ((packed)) write_voice_setting_cp;
  802. #define WRITE_VOICE_SETTING_CP_SIZE 2
  803. #define OCF_READ_AUTOMATIC_FLUSH_TIMEOUT 0x0027
  804. #define OCF_WRITE_AUTOMATIC_FLUSH_TIMEOUT 0x0028
  805. #define OCF_READ_NUM_BROADCAST_RETRANS 0x0029
  806. #define OCF_WRITE_NUM_BROADCAST_RETRANS 0x002A
  807. #define OCF_READ_HOLD_MODE_ACTIVITY 0x002B
  808. #define OCF_WRITE_HOLD_MODE_ACTIVITY 0x002C
  809. #define OCF_READ_TRANSMIT_POWER_LEVEL 0x002D
  810. typedef struct {
  811. uint16_t handle;
  812. uint8_t type;
  813. } __attribute__ ((packed)) read_transmit_power_level_cp;
  814. #define READ_TRANSMIT_POWER_LEVEL_CP_SIZE 3
  815. typedef struct {
  816. uint8_t status;
  817. uint16_t handle;
  818. int8_t level;
  819. } __attribute__ ((packed)) read_transmit_power_level_rp;
  820. #define READ_TRANSMIT_POWER_LEVEL_RP_SIZE 4
  821. #define OCF_READ_SYNC_FLOW_ENABLE 0x002E
  822. #define OCF_WRITE_SYNC_FLOW_ENABLE 0x002F
  823. #define OCF_SET_CONTROLLER_TO_HOST_FC 0x0031
  824. #define OCF_HOST_BUFFER_SIZE 0x0033
  825. typedef struct {
  826. uint16_t acl_mtu;
  827. uint8_t sco_mtu;
  828. uint16_t acl_max_pkt;
  829. uint16_t sco_max_pkt;
  830. } __attribute__ ((packed)) host_buffer_size_cp;
  831. #define HOST_BUFFER_SIZE_CP_SIZE 7
  832. #define OCF_HOST_NUM_COMP_PKTS 0x0035
  833. typedef struct {
  834. uint8_t num_hndl;
  835. /* variable length part */
  836. } __attribute__ ((packed)) host_num_comp_pkts_cp;
  837. #define HOST_NUM_COMP_PKTS_CP_SIZE 1
  838. #define OCF_READ_LINK_SUPERVISION_TIMEOUT 0x0036
  839. typedef struct {
  840. uint8_t status;
  841. uint16_t handle;
  842. uint16_t timeout;
  843. } __attribute__ ((packed)) read_link_supervision_timeout_rp;
  844. #define READ_LINK_SUPERVISION_TIMEOUT_RP_SIZE 5
  845. #define OCF_WRITE_LINK_SUPERVISION_TIMEOUT 0x0037
  846. typedef struct {
  847. uint16_t handle;
  848. uint16_t timeout;
  849. } __attribute__ ((packed)) write_link_supervision_timeout_cp;
  850. #define WRITE_LINK_SUPERVISION_TIMEOUT_CP_SIZE 4
  851. typedef struct {
  852. uint8_t status;
  853. uint16_t handle;
  854. } __attribute__ ((packed)) write_link_supervision_timeout_rp;
  855. #define WRITE_LINK_SUPERVISION_TIMEOUT_RP_SIZE 3
  856. #define OCF_READ_NUM_SUPPORTED_IAC 0x0038
  857. #define MAX_IAC_LAP 0x40
  858. #define OCF_READ_CURRENT_IAC_LAP 0x0039
  859. typedef struct {
  860. uint8_t status;
  861. uint8_t num_current_iac;
  862. uint8_t lap[MAX_IAC_LAP][3];
  863. } __attribute__ ((packed)) read_current_iac_lap_rp;
  864. #define READ_CURRENT_IAC_LAP_RP_SIZE 2+3*MAX_IAC_LAP
  865. #define OCF_WRITE_CURRENT_IAC_LAP 0x003A
  866. typedef struct {
  867. uint8_t num_current_iac;
  868. uint8_t lap[MAX_IAC_LAP][3];
  869. } __attribute__ ((packed)) write_current_iac_lap_cp;
  870. #define WRITE_CURRENT_IAC_LAP_CP_SIZE 1+3*MAX_IAC_LAP
  871. #define OCF_READ_PAGE_SCAN_PERIOD_MODE 0x003B
  872. #define OCF_WRITE_PAGE_SCAN_PERIOD_MODE 0x003C
  873. #define OCF_READ_PAGE_SCAN_MODE 0x003D
  874. #define OCF_WRITE_PAGE_SCAN_MODE 0x003E
  875. #define OCF_SET_AFH_CLASSIFICATION 0x003F
  876. typedef struct {
  877. uint8_t map[10];
  878. } __attribute__ ((packed)) set_afh_classification_cp;
  879. #define SET_AFH_CLASSIFICATION_CP_SIZE 10
  880. typedef struct {
  881. uint8_t status;
  882. } __attribute__ ((packed)) set_afh_classification_rp;
  883. #define SET_AFH_CLASSIFICATION_RP_SIZE 1
  884. #define OCF_READ_INQUIRY_SCAN_TYPE 0x0042
  885. typedef struct {
  886. uint8_t status;
  887. uint8_t type;
  888. } __attribute__ ((packed)) read_inquiry_scan_type_rp;
  889. #define READ_INQUIRY_SCAN_TYPE_RP_SIZE 2
  890. #define OCF_WRITE_INQUIRY_SCAN_TYPE 0x0043
  891. typedef struct {
  892. uint8_t type;
  893. } __attribute__ ((packed)) write_inquiry_scan_type_cp;
  894. #define WRITE_INQUIRY_SCAN_TYPE_CP_SIZE 1
  895. typedef struct {
  896. uint8_t status;
  897. } __attribute__ ((packed)) write_inquiry_scan_type_rp;
  898. #define WRITE_INQUIRY_SCAN_TYPE_RP_SIZE 1
  899. #define OCF_READ_INQUIRY_MODE 0x0044
  900. typedef struct {
  901. uint8_t status;
  902. uint8_t mode;
  903. } __attribute__ ((packed)) read_inquiry_mode_rp;
  904. #define READ_INQUIRY_MODE_RP_SIZE 2
  905. #define OCF_WRITE_INQUIRY_MODE 0x0045
  906. typedef struct {
  907. uint8_t mode;
  908. } __attribute__ ((packed)) write_inquiry_mode_cp;
  909. #define WRITE_INQUIRY_MODE_CP_SIZE 1
  910. typedef struct {
  911. uint8_t status;
  912. } __attribute__ ((packed)) write_inquiry_mode_rp;
  913. #define WRITE_INQUIRY_MODE_RP_SIZE 1
  914. #define OCF_READ_PAGE_SCAN_TYPE 0x0046
  915. #define OCF_WRITE_PAGE_SCAN_TYPE 0x0047
  916. #define PAGE_SCAN_TYPE_STANDARD 0x00
  917. #define PAGE_SCAN_TYPE_INTERLACED 0x01
  918. #define OCF_READ_AFH_MODE 0x0048
  919. typedef struct {
  920. uint8_t status;
  921. uint8_t mode;
  922. } __attribute__ ((packed)) read_afh_mode_rp;
  923. #define READ_AFH_MODE_RP_SIZE 2
  924. #define OCF_WRITE_AFH_MODE 0x0049
  925. typedef struct {
  926. uint8_t mode;
  927. } __attribute__ ((packed)) write_afh_mode_cp;
  928. #define WRITE_AFH_MODE_CP_SIZE 1
  929. typedef struct {
  930. uint8_t status;
  931. } __attribute__ ((packed)) write_afh_mode_rp;
  932. #define WRITE_AFH_MODE_RP_SIZE 1
  933. #define HCI_MAX_EIR_LENGTH 240
  934. #define OCF_READ_EXT_INQUIRY_RESPONSE 0x0051
  935. typedef struct {
  936. uint8_t status;
  937. uint8_t fec;
  938. uint8_t data[HCI_MAX_EIR_LENGTH];
  939. } __attribute__ ((packed)) read_ext_inquiry_response_rp;
  940. #define READ_EXT_INQUIRY_RESPONSE_RP_SIZE 242
  941. #define OCF_WRITE_EXT_INQUIRY_RESPONSE 0x0052
  942. typedef struct {
  943. uint8_t fec;
  944. uint8_t data[HCI_MAX_EIR_LENGTH];
  945. } __attribute__ ((packed)) write_ext_inquiry_response_cp;
  946. #define WRITE_EXT_INQUIRY_RESPONSE_CP_SIZE 241
  947. typedef struct {
  948. uint8_t status;
  949. } __attribute__ ((packed)) write_ext_inquiry_response_rp;
  950. #define WRITE_EXT_INQUIRY_RESPONSE_RP_SIZE 1
  951. #define OCF_REFRESH_ENCRYPTION_KEY 0x0053
  952. typedef struct {
  953. uint16_t handle;
  954. } __attribute__ ((packed)) refresh_encryption_key_cp;
  955. #define REFRESH_ENCRYPTION_KEY_CP_SIZE 2
  956. typedef struct {
  957. uint8_t status;
  958. } __attribute__ ((packed)) refresh_encryption_key_rp;
  959. #define REFRESH_ENCRYPTION_KEY_RP_SIZE 1
  960. #define OCF_READ_SIMPLE_PAIRING_MODE 0x0055
  961. typedef struct {
  962. uint8_t status;
  963. uint8_t mode;
  964. } __attribute__ ((packed)) read_simple_pairing_mode_rp;
  965. #define READ_SIMPLE_PAIRING_MODE_RP_SIZE 2
  966. #define OCF_WRITE_SIMPLE_PAIRING_MODE 0x0056
  967. typedef struct {
  968. uint8_t mode;
  969. } __attribute__ ((packed)) write_simple_pairing_mode_cp;
  970. #define WRITE_SIMPLE_PAIRING_MODE_CP_SIZE 1
  971. typedef struct {
  972. uint8_t status;
  973. } __attribute__ ((packed)) write_simple_pairing_mode_rp;
  974. #define WRITE_SIMPLE_PAIRING_MODE_RP_SIZE 1
  975. #define OCF_READ_LOCAL_OOB_DATA 0x0057
  976. typedef struct {
  977. uint8_t status;
  978. uint8_t hash[16];
  979. uint8_t randomizer[16];
  980. } __attribute__ ((packed)) read_local_oob_data_rp;
  981. #define READ_LOCAL_OOB_DATA_RP_SIZE 33
  982. #define OCF_READ_INQ_RESPONSE_TX_POWER_LEVEL 0x0058
  983. typedef struct {
  984. uint8_t status;
  985. int8_t level;
  986. } __attribute__ ((packed)) read_inq_response_tx_power_level_rp;
  987. #define READ_INQ_RESPONSE_TX_POWER_LEVEL_RP_SIZE 2
  988. #define OCF_READ_INQUIRY_TRANSMIT_POWER_LEVEL 0x0058
  989. typedef struct {
  990. uint8_t status;
  991. int8_t level;
  992. } __attribute__ ((packed)) read_inquiry_transmit_power_level_rp;
  993. #define READ_INQUIRY_TRANSMIT_POWER_LEVEL_RP_SIZE 2
  994. #define OCF_WRITE_INQUIRY_TRANSMIT_POWER_LEVEL 0x0059
  995. typedef struct {
  996. int8_t level;
  997. } __attribute__ ((packed)) write_inquiry_transmit_power_level_cp;
  998. #define WRITE_INQUIRY_TRANSMIT_POWER_LEVEL_CP_SIZE 1
  999. typedef struct {
  1000. uint8_t status;
  1001. } __attribute__ ((packed)) write_inquiry_transmit_power_level_rp;
  1002. #define WRITE_INQUIRY_TRANSMIT_POWER_LEVEL_RP_SIZE 1
  1003. #define OCF_READ_DEFAULT_ERROR_DATA_REPORTING 0x005A
  1004. typedef struct {
  1005. uint8_t status;
  1006. uint8_t reporting;
  1007. } __attribute__ ((packed)) read_default_error_data_reporting_rp;
  1008. #define READ_DEFAULT_ERROR_DATA_REPORTING_RP_SIZE 2
  1009. #define OCF_WRITE_DEFAULT_ERROR_DATA_REPORTING 0x005B
  1010. typedef struct {
  1011. uint8_t reporting;
  1012. } __attribute__ ((packed)) write_default_error_data_reporting_cp;
  1013. #define WRITE_DEFAULT_ERROR_DATA_REPORTING_CP_SIZE 1
  1014. typedef struct {
  1015. uint8_t status;
  1016. } __attribute__ ((packed)) write_default_error_data_reporting_rp;
  1017. #define WRITE_DEFAULT_ERROR_DATA_REPORTING_RP_SIZE 1
  1018. #define OCF_ENHANCED_FLUSH 0x005F
  1019. typedef struct {
  1020. uint16_t handle;
  1021. uint8_t type;
  1022. } __attribute__ ((packed)) enhanced_flush_cp;
  1023. #define ENHANCED_FLUSH_CP_SIZE 3
  1024. #define OCF_SEND_KEYPRESS_NOTIFY 0x0060
  1025. typedef struct {
  1026. bdaddr_t bdaddr;
  1027. uint8_t type;
  1028. } __attribute__ ((packed)) send_keypress_notify_cp;
  1029. #define SEND_KEYPRESS_NOTIFY_CP_SIZE 7
  1030. typedef struct {
  1031. uint8_t status;
  1032. } __attribute__ ((packed)) send_keypress_notify_rp;
  1033. #define SEND_KEYPRESS_NOTIFY_RP_SIZE 1
  1034. #define OCF_READ_LOGICAL_LINK_ACCEPT_TIMEOUT 0x0061
  1035. typedef struct {
  1036. uint8_t status;
  1037. uint16_t timeout;
  1038. } __attribute__ ((packed)) read_log_link_accept_timeout_rp;
  1039. #define READ_LOGICAL_LINK_ACCEPT_TIMEOUT_RP_SIZE 3
  1040. #define OCF_WRITE_LOGICAL_LINK_ACCEPT_TIMEOUT 0x0062
  1041. typedef struct {
  1042. uint16_t timeout;
  1043. } __attribute__ ((packed)) write_log_link_accept_timeout_cp;
  1044. #define WRITE_LOGICAL_LINK_ACCEPT_TIMEOUT_CP_SIZE 2
  1045. #define OCF_SET_EVENT_MASK_PAGE_2 0x0063
  1046. #define OCF_READ_LOCATION_DATA 0x0064
  1047. #define OCF_WRITE_LOCATION_DATA 0x0065
  1048. #define OCF_READ_FLOW_CONTROL_MODE 0x0066
  1049. #define OCF_WRITE_FLOW_CONTROL_MODE 0x0067
  1050. #define OCF_READ_ENHANCED_TRANSMIT_POWER_LEVEL 0x0068
  1051. typedef struct {
  1052. uint8_t status;
  1053. uint16_t handle;
  1054. int8_t level_gfsk;
  1055. int8_t level_dqpsk;
  1056. int8_t level_8dpsk;
  1057. } __attribute__ ((packed)) read_enhanced_transmit_power_level_rp;
  1058. #define READ_ENHANCED_TRANSMIT_POWER_LEVEL_RP_SIZE 6
  1059. #define OCF_READ_BEST_EFFORT_FLUSH_TIMEOUT 0x0069
  1060. typedef struct {
  1061. uint8_t status;
  1062. uint32_t timeout;
  1063. } __attribute__ ((packed)) read_best_effort_flush_timeout_rp;
  1064. #define READ_BEST_EFFORT_FLUSH_TIMEOUT_RP_SIZE 5
  1065. #define OCF_WRITE_BEST_EFFORT_FLUSH_TIMEOUT 0x006A
  1066. typedef struct {
  1067. uint16_t handle;
  1068. uint32_t timeout;
  1069. } __attribute__ ((packed)) write_best_effort_flush_timeout_cp;
  1070. #define WRITE_BEST_EFFORT_FLUSH_TIMEOUT_CP_SIZE 6
  1071. typedef struct {
  1072. uint8_t status;
  1073. } __attribute__ ((packed)) write_best_effort_flush_timeout_rp;
  1074. #define WRITE_BEST_EFFORT_FLUSH_TIMEOUT_RP_SIZE 1
  1075. #define OCF_READ_LE_HOST_SUPPORTED 0x006C
  1076. typedef struct {
  1077. uint8_t status;
  1078. uint8_t le;
  1079. uint8_t simul;
  1080. } __attribute__ ((packed)) read_le_host_supported_rp;
  1081. #define READ_LE_HOST_SUPPORTED_RP_SIZE 3
  1082. #define OCF_WRITE_LE_HOST_SUPPORTED 0x006D
  1083. typedef struct {
  1084. uint8_t le;
  1085. uint8_t simul;
  1086. } __attribute__ ((packed)) write_le_host_supported_cp;
  1087. #define WRITE_LE_HOST_SUPPORTED_CP_SIZE 2
  1088. /* Informational Parameters */
  1089. #define OGF_INFO_PARAM 0x04
  1090. #define OCF_READ_LOCAL_VERSION 0x0001
  1091. typedef struct {
  1092. uint8_t status;
  1093. uint8_t hci_ver;
  1094. uint16_t hci_rev;
  1095. uint8_t lmp_ver;
  1096. uint16_t manufacturer;
  1097. uint16_t lmp_subver;
  1098. } __attribute__ ((packed)) read_local_version_rp;
  1099. #define READ_LOCAL_VERSION_RP_SIZE 9
  1100. #define OCF_READ_LOCAL_COMMANDS 0x0002
  1101. typedef struct {
  1102. uint8_t status;
  1103. uint8_t commands[64];
  1104. } __attribute__ ((packed)) read_local_commands_rp;
  1105. #define READ_LOCAL_COMMANDS_RP_SIZE 65
  1106. #define OCF_READ_LOCAL_FEATURES 0x0003
  1107. typedef struct {
  1108. uint8_t status;
  1109. uint8_t features[8];
  1110. } __attribute__ ((packed)) read_local_features_rp;
  1111. #define READ_LOCAL_FEATURES_RP_SIZE 9
  1112. #define OCF_READ_LOCAL_EXT_FEATURES 0x0004
  1113. typedef struct {
  1114. uint8_t page_num;
  1115. } __attribute__ ((packed)) read_local_ext_features_cp;
  1116. #define READ_LOCAL_EXT_FEATURES_CP_SIZE 1
  1117. typedef struct {
  1118. uint8_t status;
  1119. uint8_t page_num;
  1120. uint8_t max_page_num;
  1121. uint8_t features[8];
  1122. } __attribute__ ((packed)) read_local_ext_features_rp;
  1123. #define READ_LOCAL_EXT_FEATURES_RP_SIZE 11
  1124. #define OCF_READ_BUFFER_SIZE 0x0005
  1125. typedef struct {
  1126. uint8_t status;
  1127. uint16_t acl_mtu;
  1128. uint8_t sco_mtu;
  1129. uint16_t acl_max_pkt;
  1130. uint16_t sco_max_pkt;
  1131. } __attribute__ ((packed)) read_buffer_size_rp;
  1132. #define READ_BUFFER_SIZE_RP_SIZE 8
  1133. #define OCF_READ_COUNTRY_CODE 0x0007
  1134. #define OCF_READ_BD_ADDR 0x0009
  1135. typedef struct {
  1136. uint8_t status;
  1137. bdaddr_t bdaddr;
  1138. } __attribute__ ((packed)) read_bd_addr_rp;
  1139. #define READ_BD_ADDR_RP_SIZE 7
  1140. #define OCF_READ_DATA_BLOCK_SIZE 0x000A
  1141. typedef struct {
  1142. uint8_t status;
  1143. uint16_t max_acl_len;
  1144. uint16_t data_block_len;
  1145. uint16_t num_blocks;
  1146. } __attribute__ ((packed)) read_data_block_size_rp;
  1147. /* Status params */
  1148. #define OGF_STATUS_PARAM 0x05
  1149. #define OCF_READ_FAILED_CONTACT_COUNTER 0x0001
  1150. typedef struct {
  1151. uint8_t status;
  1152. uint16_t handle;
  1153. uint8_t counter;
  1154. } __attribute__ ((packed)) read_failed_contact_counter_rp;
  1155. #define READ_FAILED_CONTACT_COUNTER_RP_SIZE 4
  1156. #define OCF_RESET_FAILED_CONTACT_COUNTER 0x0002
  1157. typedef struct {
  1158. uint8_t status;
  1159. uint16_t handle;
  1160. } __attribute__ ((packed)) reset_failed_contact_counter_rp;
  1161. #define RESET_FAILED_CONTACT_COUNTER_RP_SIZE 3
  1162. #define OCF_READ_LINK_QUALITY 0x0003
  1163. typedef struct {
  1164. uint8_t status;
  1165. uint16_t handle;
  1166. uint8_t link_quality;
  1167. } __attribute__ ((packed)) read_link_quality_rp;
  1168. #define READ_LINK_QUALITY_RP_SIZE 4
  1169. #define OCF_READ_RSSI 0x0005
  1170. typedef struct {
  1171. uint8_t status;
  1172. uint16_t handle;
  1173. int8_t rssi;
  1174. } __attribute__ ((packed)) read_rssi_rp;
  1175. #define READ_RSSI_RP_SIZE 4
  1176. #define OCF_READ_AFH_MAP 0x0006
  1177. typedef struct {
  1178. uint8_t status;
  1179. uint16_t handle;
  1180. uint8_t mode;
  1181. uint8_t map[10];
  1182. } __attribute__ ((packed)) read_afh_map_rp;
  1183. #define READ_AFH_MAP_RP_SIZE 14
  1184. #define OCF_READ_CLOCK 0x0007
  1185. typedef struct {
  1186. uint16_t handle;
  1187. uint8_t which_clock;
  1188. } __attribute__ ((packed)) read_clock_cp;
  1189. #define READ_CLOCK_CP_SIZE 3
  1190. typedef struct {
  1191. uint8_t status;
  1192. uint16_t handle;
  1193. uint32_t clock;
  1194. uint16_t accuracy;
  1195. } __attribute__ ((packed)) read_clock_rp;
  1196. #define READ_CLOCK_RP_SIZE 9
  1197. #define OCF_READ_LOCAL_AMP_INFO 0x0009
  1198. typedef struct {
  1199. uint8_t status;
  1200. uint8_t amp_status;
  1201. uint32_t total_bandwidth;
  1202. uint32_t max_guaranteed_bandwidth;
  1203. uint32_t min_latency;
  1204. uint32_t max_pdu_size;
  1205. uint8_t controller_type;
  1206. uint16_t pal_caps;
  1207. uint16_t max_amp_assoc_length;
  1208. uint32_t max_flush_timeout;
  1209. uint32_t best_effort_flush_timeout;
  1210. } __attribute__ ((packed)) read_local_amp_info_rp;
  1211. #define READ_LOCAL_AMP_INFO_RP_SIZE 31
  1212. #define OCF_READ_LOCAL_AMP_ASSOC 0x000A
  1213. typedef struct {
  1214. uint8_t handle;
  1215. uint16_t length_so_far;
  1216. uint16_t assoc_length;
  1217. } __attribute__ ((packed)) read_local_amp_assoc_cp;
  1218. #define READ_LOCAL_AMP_ASSOC_CP_SIZE 5
  1219. typedef struct {
  1220. uint8_t status;
  1221. uint8_t handle;
  1222. uint16_t length;
  1223. uint8_t fragment[HCI_MAX_NAME_LENGTH];
  1224. } __attribute__ ((packed)) read_local_amp_assoc_rp;
  1225. #define READ_LOCAL_AMP_ASSOC_RP_SIZE 252
  1226. #define OCF_WRITE_REMOTE_AMP_ASSOC 0x000B
  1227. typedef struct {
  1228. uint8_t handle;
  1229. uint16_t length_so_far;
  1230. uint16_t remaining_length;
  1231. uint8_t fragment[HCI_MAX_NAME_LENGTH];
  1232. } __attribute__ ((packed)) write_remote_amp_assoc_cp;
  1233. #define WRITE_REMOTE_AMP_ASSOC_CP_SIZE 253
  1234. typedef struct {
  1235. uint8_t status;
  1236. uint8_t handle;
  1237. } __attribute__ ((packed)) write_remote_amp_assoc_rp;
  1238. #define WRITE_REMOTE_AMP_ASSOC_RP_SIZE 2
  1239. /* Testing commands */
  1240. #define OGF_TESTING_CMD 0x3e
  1241. #define OCF_READ_LOOPBACK_MODE 0x0001
  1242. #define OCF_WRITE_LOOPBACK_MODE 0x0002
  1243. #define OCF_ENABLE_DEVICE_UNDER_TEST_MODE 0x0003
  1244. #define OCF_WRITE_SIMPLE_PAIRING_DEBUG_MODE 0x0004
  1245. typedef struct {
  1246. uint8_t mode;
  1247. } __attribute__ ((packed)) write_simple_pairing_debug_mode_cp;
  1248. #define WRITE_SIMPLE_PAIRING_DEBUG_MODE_CP_SIZE 1
  1249. typedef struct {
  1250. uint8_t status;
  1251. } __attribute__ ((packed)) write_simple_pairing_debug_mode_rp;
  1252. #define WRITE_SIMPLE_PAIRING_DEBUG_MODE_RP_SIZE 1
  1253. /* LE commands */
  1254. #define OGF_LE_CTL 0x08
  1255. #define OCF_LE_SET_EVENT_MASK 0x0001
  1256. typedef struct {
  1257. uint8_t mask[8];
  1258. } __attribute__ ((packed)) le_set_event_mask_cp;
  1259. #define LE_SET_EVENT_MASK_CP_SIZE 8
  1260. #define OCF_LE_READ_BUFFER_SIZE 0x0002
  1261. typedef struct {
  1262. uint8_t status;
  1263. uint16_t pkt_len;
  1264. uint8_t max_pkt;
  1265. } __attribute__ ((packed)) le_read_buffer_size_rp;
  1266. #define LE_READ_BUFFER_SIZE_RP_SIZE 4
  1267. #define OCF_LE_READ_LOCAL_SUPPORTED_FEATURES 0x0003
  1268. typedef struct {
  1269. uint8_t status;
  1270. uint8_t features[8];
  1271. } __attribute__ ((packed)) le_read_local_supported_features_rp;
  1272. #define LE_READ_LOCAL_SUPPORTED_FEATURES_RP_SIZE 9
  1273. #define OCF_LE_SET_RANDOM_ADDRESS 0x0005
  1274. typedef struct {
  1275. bdaddr_t bdaddr;
  1276. } __attribute__ ((packed)) le_set_random_address_cp;
  1277. #define LE_SET_RANDOM_ADDRESS_CP_SIZE 6
  1278. #define OCF_LE_SET_ADVERTISING_PARAMETERS 0x0006
  1279. typedef struct {
  1280. uint16_t min_interval;
  1281. uint16_t max_interval;
  1282. uint8_t advtype;
  1283. uint8_t own_bdaddr_type;
  1284. uint8_t direct_bdaddr_type;
  1285. bdaddr_t direct_bdaddr;
  1286. uint8_t chan_map;
  1287. uint8_t filter;
  1288. } __attribute__ ((packed)) le_set_advertising_parameters_cp;
  1289. #define LE_SET_ADVERTISING_PARAMETERS_CP_SIZE 15
  1290. #define OCF_LE_READ_ADVERTISING_CHANNEL_TX_POWER 0x0007
  1291. typedef struct {
  1292. uint8_t status;
  1293. int8_t level;
  1294. } __attribute__ ((packed)) le_read_advertising_channel_tx_power_rp;
  1295. #define LE_READ_ADVERTISING_CHANNEL_TX_POWER_RP_SIZE 2
  1296. #define OCF_LE_SET_ADVERTISING_DATA 0x0008
  1297. typedef struct {
  1298. uint8_t length;
  1299. uint8_t data[31];
  1300. } __attribute__ ((packed)) le_set_advertising_data_cp;
  1301. #define LE_SET_ADVERTISING_DATA_CP_SIZE 32
  1302. #define OCF_LE_SET_SCAN_RESPONSE_DATA 0x0009
  1303. typedef struct {
  1304. uint8_t length;
  1305. uint8_t data[31];
  1306. } __attribute__ ((packed)) le_set_scan_response_data_cp;
  1307. #define LE_SET_SCAN_RESPONSE_DATA_CP_SIZE 32
  1308. #define OCF_LE_SET_ADVERTISE_ENABLE 0x000A
  1309. typedef struct {
  1310. uint8_t enable;
  1311. } __attribute__ ((packed)) le_set_advertise_enable_cp;
  1312. #define LE_SET_ADVERTISE_ENABLE_CP_SIZE 1
  1313. #define OCF_LE_SET_SCAN_PARAMETERS 0x000B
  1314. typedef struct {
  1315. uint8_t type;
  1316. uint16_t interval;
  1317. uint16_t window;
  1318. uint8_t own_bdaddr_type;
  1319. uint8_t filter;
  1320. } __attribute__ ((packed)) le_set_scan_parameters_cp;
  1321. #define LE_SET_SCAN_PARAMETERS_CP_SIZE 7
  1322. #define OCF_LE_SET_SCAN_ENABLE 0x000C
  1323. typedef struct {
  1324. uint8_t enable;
  1325. uint8_t filter_dup;
  1326. } __attribute__ ((packed)) le_set_scan_enable_cp;
  1327. #define LE_SET_SCAN_ENABLE_CP_SIZE 2
  1328. #define OCF_LE_CREATE_CONN 0x000D
  1329. typedef struct {
  1330. uint16_t interval;
  1331. uint16_t window;
  1332. uint8_t initiator_filter;
  1333. uint8_t peer_bdaddr_type;
  1334. bdaddr_t peer_bdaddr;
  1335. uint8_t own_bdaddr_type;
  1336. uint16_t min_interval;
  1337. uint16_t max_interval;
  1338. uint16_t latency;
  1339. uint16_t supervision_timeout;
  1340. uint16_t min_ce_length;
  1341. uint16_t max_ce_length;
  1342. } __attribute__ ((packed)) le_create_connection_cp;
  1343. #define LE_CREATE_CONN_CP_SIZE 25
  1344. #define OCF_LE_CREATE_CONN_CANCEL 0x000E
  1345. #define OCF_LE_READ_WHITE_LIST_SIZE 0x000F
  1346. typedef struct {
  1347. uint8_t status;
  1348. uint8_t size;
  1349. } __attribute__ ((packed)) le_read_white_list_size_rp;
  1350. #define LE_READ_WHITE_LIST_SIZE_RP_SIZE 2
  1351. #define OCF_LE_CLEAR_WHITE_LIST 0x0010
  1352. #define OCF_LE_ADD_DEVICE_TO_WHITE_LIST 0x0011
  1353. typedef struct {
  1354. uint8_t bdaddr_type;
  1355. bdaddr_t bdaddr;
  1356. } __attribute__ ((packed)) le_add_device_to_white_list_cp;
  1357. #define LE_ADD_DEVICE_TO_WHITE_LIST_CP_SIZE 7
  1358. #define OCF_LE_REMOVE_DEVICE_FROM_WHITE_LIST 0x0012
  1359. typedef struct {
  1360. uint8_t bdaddr_type;
  1361. bdaddr_t bdaddr;
  1362. } __attribute__ ((packed)) le_remove_device_from_white_list_cp;
  1363. #define LE_REMOVE_DEVICE_FROM_WHITE_LIST_CP_SIZE 7
  1364. #define OCF_LE_CONN_UPDATE 0x0013
  1365. typedef struct {
  1366. uint16_t handle;
  1367. uint16_t min_interval;
  1368. uint16_t max_interval;
  1369. uint16_t latency;
  1370. uint16_t supervision_timeout;
  1371. uint16_t min_ce_length;
  1372. uint16_t max_ce_length;
  1373. } __attribute__ ((packed)) le_connection_update_cp;
  1374. #define LE_CONN_UPDATE_CP_SIZE 14
  1375. #define OCF_LE_SET_HOST_CHANNEL_CLASSIFICATION 0x0014
  1376. typedef struct {
  1377. uint8_t map[5];
  1378. } __attribute__ ((packed)) le_set_host_channel_classification_cp;
  1379. #define LE_SET_HOST_CHANNEL_CLASSIFICATION_CP_SIZE 5
  1380. #define OCF_LE_READ_CHANNEL_MAP 0x0015
  1381. typedef struct {
  1382. uint16_t handle;
  1383. } __attribute__ ((packed)) le_read_channel_map_cp;
  1384. #define LE_READ_CHANNEL_MAP_CP_SIZE 2
  1385. typedef struct {
  1386. uint8_t status;
  1387. uint16_t handle;
  1388. uint8_t map[5];
  1389. } __attribute__ ((packed)) le_read_channel_map_rp;
  1390. #define LE_READ_CHANNEL_MAP_RP_SIZE 8
  1391. #define OCF_LE_READ_REMOTE_USED_FEATURES 0x0016
  1392. typedef struct {
  1393. uint16_t handle;
  1394. } __attribute__ ((packed)) le_read_remote_used_features_cp;
  1395. #define LE_READ_REMOTE_USED_FEATURES_CP_SIZE 2
  1396. #define OCF_LE_ENCRYPT 0x0017
  1397. typedef struct {
  1398. uint8_t key[16];
  1399. uint8_t plaintext[16];
  1400. } __attribute__ ((packed)) le_encrypt_cp;
  1401. #define LE_ENCRYPT_CP_SIZE 32
  1402. typedef struct {
  1403. uint8_t status;
  1404. uint8_t data[16];
  1405. } __attribute__ ((packed)) le_encrypt_rp;
  1406. #define LE_ENCRYPT_RP_SIZE 17
  1407. #define OCF_LE_RAND 0x0018
  1408. typedef struct {
  1409. uint8_t status;
  1410. uint64_t random;
  1411. } __attribute__ ((packed)) le_rand_rp;
  1412. #define LE_RAND_RP_SIZE 9
  1413. #define OCF_LE_START_ENCRYPTION 0x0019
  1414. typedef struct {
  1415. uint16_t handle;
  1416. uint64_t random;
  1417. uint16_t diversifier;
  1418. uint8_t key[16];
  1419. } __attribute__ ((packed)) le_start_encryption_cp;
  1420. #define LE_START_ENCRYPTION_CP_SIZE 28
  1421. #define OCF_LE_LTK_REPLY 0x001A
  1422. typedef struct {
  1423. uint16_t handle;
  1424. uint8_t key[16];
  1425. } __attribute__ ((packed)) le_ltk_reply_cp;
  1426. #define LE_LTK_REPLY_CP_SIZE 18
  1427. typedef struct {
  1428. uint8_t status;
  1429. uint16_t handle;
  1430. } __attribute__ ((packed)) le_ltk_reply_rp;
  1431. #define LE_LTK_REPLY_RP_SIZE 3
  1432. #define OCF_LE_LTK_NEG_REPLY 0x001B
  1433. typedef struct {
  1434. uint16_t handle;
  1435. } __attribute__ ((packed)) le_ltk_neg_reply_cp;
  1436. #define LE_LTK_NEG_REPLY_CP_SIZE 2
  1437. typedef struct {
  1438. uint8_t status;
  1439. uint16_t handle;
  1440. } __attribute__ ((packed)) le_ltk_neg_reply_rp;
  1441. #define LE_LTK_NEG_REPLY_RP_SIZE 3
  1442. #define OCF_LE_READ_SUPPORTED_STATES 0x001C
  1443. typedef struct {
  1444. uint8_t status;
  1445. uint64_t states;
  1446. } __attribute__ ((packed)) le_read_supported_states_rp;
  1447. #define LE_READ_SUPPORTED_STATES_RP_SIZE 9
  1448. #define OCF_LE_RECEIVER_TEST 0x001D
  1449. typedef struct {
  1450. uint8_t frequency;
  1451. } __attribute__ ((packed)) le_receiver_test_cp;
  1452. #define LE_RECEIVER_TEST_CP_SIZE 1
  1453. #define OCF_LE_TRANSMITTER_TEST 0x001E
  1454. typedef struct {
  1455. uint8_t frequency;
  1456. uint8_t length;
  1457. uint8_t payload;
  1458. } __attribute__ ((packed)) le_transmitter_test_cp;
  1459. #define LE_TRANSMITTER_TEST_CP_SIZE 3
  1460. #define OCF_LE_TEST_END 0x001F
  1461. typedef struct {
  1462. uint8_t status;
  1463. uint16_t num_pkts;
  1464. } __attribute__ ((packed)) le_test_end_rp;
  1465. #define LE_TEST_END_RP_SIZE 3
  1466. #define OCF_LE_ADD_DEVICE_TO_RESOLV_LIST 0x0027
  1467. typedef struct {
  1468. uint8_t bdaddr_type;
  1469. bdaddr_t bdaddr;
  1470. uint8_t peer_irk[16];
  1471. uint8_t local_irk[16];
  1472. } __attribute__ ((packed)) le_add_device_to_resolv_list_cp;
  1473. #define LE_ADD_DEVICE_TO_RESOLV_LIST_CP_SIZE 39
  1474. #define OCF_LE_REMOVE_DEVICE_FROM_RESOLV_LIST 0x0028
  1475. typedef struct {
  1476. uint8_t bdaddr_type;
  1477. bdaddr_t bdaddr;
  1478. } __attribute__ ((packed)) le_remove_device_from_resolv_list_cp;
  1479. #define LE_REMOVE_DEVICE_FROM_RESOLV_LIST_CP_SIZE 7
  1480. #define OCF_LE_CLEAR_RESOLV_LIST 0x0029
  1481. #define OCF_LE_READ_RESOLV_LIST_SIZE 0x002A
  1482. typedef struct {
  1483. uint8_t status;
  1484. uint8_t size;
  1485. } __attribute__ ((packed)) le_read_resolv_list_size_rp;
  1486. #define LE_READ_RESOLV_LIST_SIZE_RP_SIZE 2
  1487. #define OCF_LE_SET_ADDRESS_RESOLUTION_ENABLE 0x002D
  1488. typedef struct {
  1489. uint8_t enable;
  1490. } __attribute__ ((packed)) le_set_address_resolution_enable_cp;
  1491. #define LE_SET_ADDRESS_RESOLUTION_ENABLE_CP_SIZE 1
  1492. /* Vendor specific commands */
  1493. #define OGF_VENDOR_CMD 0x3f
  1494. /* ---- HCI Events ---- */
  1495. #define EVT_INQUIRY_COMPLETE 0x01
  1496. #define EVT_INQUIRY_RESULT 0x02
  1497. typedef struct {
  1498. bdaddr_t bdaddr;
  1499. uint8_t pscan_rep_mode;
  1500. uint8_t pscan_period_mode;
  1501. uint8_t pscan_mode;
  1502. uint8_t dev_class[3];
  1503. uint16_t clock_offset;
  1504. } __attribute__ ((packed)) inquiry_info;
  1505. #define INQUIRY_INFO_SIZE 14
  1506. #define EVT_CONN_COMPLETE 0x03
  1507. typedef struct {
  1508. uint8_t status;
  1509. uint16_t handle;
  1510. bdaddr_t bdaddr;
  1511. uint8_t link_type;
  1512. uint8_t encr_mode;
  1513. } __attribute__ ((packed)) evt_conn_complete;
  1514. #define EVT_CONN_COMPLETE_SIZE 11
  1515. #define EVT_CONN_REQUEST 0x04
  1516. typedef struct {
  1517. bdaddr_t bdaddr;
  1518. uint8_t dev_class[3];
  1519. uint8_t link_type;
  1520. } __attribute__ ((packed)) evt_conn_request;
  1521. #define EVT_CONN_REQUEST_SIZE 10
  1522. #define EVT_DISCONN_COMPLETE 0x05
  1523. typedef struct {
  1524. uint8_t status;
  1525. uint16_t handle;
  1526. uint8_t reason;
  1527. } __attribute__ ((packed)) evt_disconn_complete;
  1528. #define EVT_DISCONN_COMPLETE_SIZE 4
  1529. #define EVT_AUTH_COMPLETE 0x06
  1530. typedef struct {
  1531. uint8_t status;
  1532. uint16_t handle;
  1533. } __attribute__ ((packed)) evt_auth_complete;
  1534. #define EVT_AUTH_COMPLETE_SIZE 3
  1535. #define EVT_REMOTE_NAME_REQ_COMPLETE 0x07
  1536. typedef struct {
  1537. uint8_t status;
  1538. bdaddr_t bdaddr;
  1539. uint8_t name[HCI_MAX_NAME_LENGTH];
  1540. } __attribute__ ((packed)) evt_remote_name_req_complete;
  1541. #define EVT_REMOTE_NAME_REQ_COMPLETE_SIZE 255
  1542. #define EVT_ENCRYPT_CHANGE 0x08
  1543. typedef struct {
  1544. uint8_t status;
  1545. uint16_t handle;
  1546. uint8_t encrypt;
  1547. } __attribute__ ((packed)) evt_encrypt_change;
  1548. #define EVT_ENCRYPT_CHANGE_SIZE 4
  1549. #define EVT_CHANGE_CONN_LINK_KEY_COMPLETE 0x09
  1550. typedef struct {
  1551. uint8_t status;
  1552. uint16_t handle;
  1553. } __attribute__ ((packed)) evt_change_conn_link_key_complete;
  1554. #define EVT_CHANGE_CONN_LINK_KEY_COMPLETE_SIZE 3
  1555. #define EVT_MASTER_LINK_KEY_COMPLETE 0x0A
  1556. typedef struct {
  1557. uint8_t status;
  1558. uint16_t handle;
  1559. uint8_t key_flag;
  1560. } __attribute__ ((packed)) evt_master_link_key_complete;
  1561. #define EVT_MASTER_LINK_KEY_COMPLETE_SIZE 4
  1562. #define EVT_READ_REMOTE_FEATURES_COMPLETE 0x0B
  1563. typedef struct {
  1564. uint8_t status;
  1565. uint16_t handle;
  1566. uint8_t features[8];
  1567. } __attribute__ ((packed)) evt_read_remote_features_complete;
  1568. #define EVT_READ_REMOTE_FEATURES_COMPLETE_SIZE 11
  1569. #define EVT_READ_REMOTE_VERSION_COMPLETE 0x0C
  1570. typedef struct {
  1571. uint8_t status;
  1572. uint16_t handle;
  1573. uint8_t lmp_ver;
  1574. uint16_t manufacturer;
  1575. uint16_t lmp_subver;
  1576. } __attribute__ ((packed)) evt_read_remote_version_complete;
  1577. #define EVT_READ_REMOTE_VERSION_COMPLETE_SIZE 8
  1578. #define EVT_QOS_SETUP_COMPLETE 0x0D
  1579. typedef struct {
  1580. uint8_t status;
  1581. uint16_t handle;
  1582. uint8_t flags; /* Reserved */
  1583. hci_qos qos;
  1584. } __attribute__ ((packed)) evt_qos_setup_complete;
  1585. #define EVT_QOS_SETUP_COMPLETE_SIZE (4 + HCI_QOS_CP_SIZE)
  1586. #define EVT_CMD_COMPLETE 0x0E
  1587. typedef struct {
  1588. uint8_t ncmd;
  1589. uint16_t opcode;
  1590. } __attribute__ ((packed)) evt_cmd_complete;
  1591. #define EVT_CMD_COMPLETE_SIZE 3
  1592. #define EVT_CMD_STATUS 0x0F
  1593. typedef struct {
  1594. uint8_t status;
  1595. uint8_t ncmd;
  1596. uint16_t opcode;
  1597. } __attribute__ ((packed)) evt_cmd_status;
  1598. #define EVT_CMD_STATUS_SIZE 4
  1599. #define EVT_HARDWARE_ERROR 0x10
  1600. typedef struct {
  1601. uint8_t code;
  1602. } __attribute__ ((packed)) evt_hardware_error;
  1603. #define EVT_HARDWARE_ERROR_SIZE 1
  1604. #define EVT_FLUSH_OCCURRED 0x11
  1605. typedef struct {
  1606. uint16_t handle;
  1607. } __attribute__ ((packed)) evt_flush_occured;
  1608. #define EVT_FLUSH_OCCURRED_SIZE 2
  1609. #define EVT_ROLE_CHANGE 0x12
  1610. typedef struct {
  1611. uint8_t status;
  1612. bdaddr_t bdaddr;
  1613. uint8_t role;
  1614. } __attribute__ ((packed)) evt_role_change;
  1615. #define EVT_ROLE_CHANGE_SIZE 8
  1616. #define EVT_NUM_COMP_PKTS 0x13
  1617. typedef struct {
  1618. uint8_t num_hndl;
  1619. /* variable length part */
  1620. } __attribute__ ((packed)) evt_num_comp_pkts;
  1621. #define EVT_NUM_COMP_PKTS_SIZE 1
  1622. #define EVT_MODE_CHANGE 0x14
  1623. typedef struct {
  1624. uint8_t status;
  1625. uint16_t handle;
  1626. uint8_t mode;
  1627. uint16_t interval;
  1628. } __attribute__ ((packed)) evt_mode_change;
  1629. #define EVT_MODE_CHANGE_SIZE 6
  1630. #define EVT_RETURN_LINK_KEYS 0x15
  1631. typedef struct {
  1632. uint8_t num_keys;
  1633. /* variable length part */
  1634. } __attribute__ ((packed)) evt_return_link_keys;
  1635. #define EVT_RETURN_LINK_KEYS_SIZE 1
  1636. #define EVT_PIN_CODE_REQ 0x16
  1637. typedef struct {
  1638. bdaddr_t bdaddr;
  1639. } __attribute__ ((packed)) evt_pin_code_req;
  1640. #define EVT_PIN_CODE_REQ_SIZE 6
  1641. #define EVT_LINK_KEY_REQ 0x17
  1642. typedef struct {
  1643. bdaddr_t bdaddr;
  1644. } __attribute__ ((packed)) evt_link_key_req;
  1645. #define EVT_LINK_KEY_REQ_SIZE 6
  1646. #define EVT_LINK_KEY_NOTIFY 0x18
  1647. typedef struct {
  1648. bdaddr_t bdaddr;
  1649. uint8_t link_key[16];
  1650. uint8_t key_type;
  1651. } __attribute__ ((packed)) evt_link_key_notify;
  1652. #define EVT_LINK_KEY_NOTIFY_SIZE 23
  1653. #define EVT_LOOPBACK_COMMAND 0x19
  1654. #define EVT_DATA_BUFFER_OVERFLOW 0x1A
  1655. typedef struct {
  1656. uint8_t link_type;
  1657. } __attribute__ ((packed)) evt_data_buffer_overflow;
  1658. #define EVT_DATA_BUFFER_OVERFLOW_SIZE 1
  1659. #define EVT_MAX_SLOTS_CHANGE 0x1B
  1660. typedef struct {
  1661. uint16_t handle;
  1662. uint8_t max_slots;
  1663. } __attribute__ ((packed)) evt_max_slots_change;
  1664. #define EVT_MAX_SLOTS_CHANGE_SIZE 3
  1665. #define EVT_READ_CLOCK_OFFSET_COMPLETE 0x1C
  1666. typedef struct {
  1667. uint8_t status;
  1668. uint16_t handle;
  1669. uint16_t clock_offset;
  1670. } __attribute__ ((packed)) evt_read_clock_offset_complete;
  1671. #define EVT_READ_CLOCK_OFFSET_COMPLETE_SIZE 5
  1672. #define EVT_CONN_PTYPE_CHANGED 0x1D
  1673. typedef struct {
  1674. uint8_t status;
  1675. uint16_t handle;
  1676. uint16_t ptype;
  1677. } __attribute__ ((packed)) evt_conn_ptype_changed;
  1678. #define EVT_CONN_PTYPE_CHANGED_SIZE 5
  1679. #define EVT_QOS_VIOLATION 0x1E
  1680. typedef struct {
  1681. uint16_t handle;
  1682. } __attribute__ ((packed)) evt_qos_violation;
  1683. #define EVT_QOS_VIOLATION_SIZE 2
  1684. #define EVT_PSCAN_REP_MODE_CHANGE 0x20
  1685. typedef struct {
  1686. bdaddr_t bdaddr;
  1687. uint8_t pscan_rep_mode;
  1688. } __attribute__ ((packed)) evt_pscan_rep_mode_change;
  1689. #define EVT_PSCAN_REP_MODE_CHANGE_SIZE 7
  1690. #define EVT_FLOW_SPEC_COMPLETE 0x21
  1691. typedef struct {
  1692. uint8_t status;
  1693. uint16_t handle;
  1694. uint8_t flags;
  1695. uint8_t direction;
  1696. hci_qos qos;
  1697. } __attribute__ ((packed)) evt_flow_spec_complete;
  1698. #define EVT_FLOW_SPEC_COMPLETE_SIZE (5 + HCI_QOS_CP_SIZE)
  1699. #define EVT_INQUIRY_RESULT_WITH_RSSI 0x22
  1700. typedef struct {
  1701. bdaddr_t bdaddr;
  1702. uint8_t pscan_rep_mode;
  1703. uint8_t pscan_period_mode;
  1704. uint8_t dev_class[3];
  1705. uint16_t clock_offset;
  1706. int8_t rssi;
  1707. } __attribute__ ((packed)) inquiry_info_with_rssi;
  1708. #define INQUIRY_INFO_WITH_RSSI_SIZE 14
  1709. typedef struct {
  1710. bdaddr_t bdaddr;
  1711. uint8_t pscan_rep_mode;
  1712. uint8_t pscan_period_mode;
  1713. uint8_t pscan_mode;
  1714. uint8_t dev_class[3];
  1715. uint16_t clock_offset;
  1716. int8_t rssi;
  1717. } __attribute__ ((packed)) inquiry_info_with_rssi_and_pscan_mode;
  1718. #define INQUIRY_INFO_WITH_RSSI_AND_PSCAN_MODE_SIZE 15
  1719. #define EVT_READ_REMOTE_EXT_FEATURES_COMPLETE 0x23
  1720. typedef struct {
  1721. uint8_t status;
  1722. uint16_t handle;
  1723. uint8_t page_num;
  1724. uint8_t max_page_num;
  1725. uint8_t features[8];
  1726. } __attribute__ ((packed)) evt_read_remote_ext_features_complete;
  1727. #define EVT_READ_REMOTE_EXT_FEATURES_COMPLETE_SIZE 13
  1728. #define EVT_SYNC_CONN_COMPLETE 0x2C
  1729. typedef struct {
  1730. uint8_t status;
  1731. uint16_t handle;
  1732. bdaddr_t bdaddr;
  1733. uint8_t link_type;
  1734. uint8_t trans_interval;
  1735. uint8_t retrans_window;
  1736. uint16_t rx_pkt_len;
  1737. uint16_t tx_pkt_len;
  1738. uint8_t air_mode;
  1739. } __attribute__ ((packed)) evt_sync_conn_complete;
  1740. #define EVT_SYNC_CONN_COMPLETE_SIZE 17
  1741. #define EVT_SYNC_CONN_CHANGED 0x2D
  1742. typedef struct {
  1743. uint8_t status;
  1744. uint16_t handle;
  1745. uint8_t trans_interval;
  1746. uint8_t retrans_window;
  1747. uint16_t rx_pkt_len;
  1748. uint16_t tx_pkt_len;
  1749. } __attribute__ ((packed)) evt_sync_conn_changed;
  1750. #define EVT_SYNC_CONN_CHANGED_SIZE 9
  1751. #define EVT_SNIFF_SUBRATING 0x2E
  1752. typedef struct {
  1753. uint8_t status;
  1754. uint16_t handle;
  1755. uint16_t max_tx_latency;
  1756. uint16_t max_rx_latency;
  1757. uint16_t min_remote_timeout;
  1758. uint16_t min_local_timeout;
  1759. } __attribute__ ((packed)) evt_sniff_subrating;
  1760. #define EVT_SNIFF_SUBRATING_SIZE 11
  1761. #define EVT_EXTENDED_INQUIRY_RESULT 0x2F
  1762. typedef struct {
  1763. bdaddr_t bdaddr;
  1764. uint8_t pscan_rep_mode;
  1765. uint8_t pscan_period_mode;
  1766. uint8_t dev_class[3];
  1767. uint16_t clock_offset;
  1768. int8_t rssi;
  1769. uint8_t data[HCI_MAX_EIR_LENGTH];
  1770. } __attribute__ ((packed)) extended_inquiry_info;
  1771. #define EXTENDED_INQUIRY_INFO_SIZE 254
  1772. #define EVT_ENCRYPTION_KEY_REFRESH_COMPLETE 0x30
  1773. typedef struct {
  1774. uint8_t status;
  1775. uint16_t handle;
  1776. } __attribute__ ((packed)) evt_encryption_key_refresh_complete;
  1777. #define EVT_ENCRYPTION_KEY_REFRESH_COMPLETE_SIZE 3
  1778. #define EVT_IO_CAPABILITY_REQUEST 0x31
  1779. typedef struct {
  1780. bdaddr_t bdaddr;
  1781. } __attribute__ ((packed)) evt_io_capability_request;
  1782. #define EVT_IO_CAPABILITY_REQUEST_SIZE 6
  1783. #define EVT_IO_CAPABILITY_RESPONSE 0x32
  1784. typedef struct {
  1785. bdaddr_t bdaddr;
  1786. uint8_t capability;
  1787. uint8_t oob_data;
  1788. uint8_t authentication;
  1789. } __attribute__ ((packed)) evt_io_capability_response;
  1790. #define EVT_IO_CAPABILITY_RESPONSE_SIZE 9
  1791. #define EVT_USER_CONFIRM_REQUEST 0x33
  1792. typedef struct {
  1793. bdaddr_t bdaddr;
  1794. uint32_t passkey;
  1795. } __attribute__ ((packed)) evt_user_confirm_request;
  1796. #define EVT_USER_CONFIRM_REQUEST_SIZE 10
  1797. #define EVT_USER_PASSKEY_REQUEST 0x34
  1798. typedef struct {
  1799. bdaddr_t bdaddr;
  1800. } __attribute__ ((packed)) evt_user_passkey_request;
  1801. #define EVT_USER_PASSKEY_REQUEST_SIZE 6
  1802. #define EVT_REMOTE_OOB_DATA_REQUEST 0x35
  1803. typedef struct {
  1804. bdaddr_t bdaddr;
  1805. } __attribute__ ((packed)) evt_remote_oob_data_request;
  1806. #define EVT_REMOTE_OOB_DATA_REQUEST_SIZE 6
  1807. #define EVT_SIMPLE_PAIRING_COMPLETE 0x36
  1808. typedef struct {
  1809. uint8_t status;
  1810. bdaddr_t bdaddr;
  1811. } __attribute__ ((packed)) evt_simple_pairing_complete;
  1812. #define EVT_SIMPLE_PAIRING_COMPLETE_SIZE 7
  1813. #define EVT_LINK_SUPERVISION_TIMEOUT_CHANGED 0x38
  1814. typedef struct {
  1815. uint16_t handle;
  1816. uint16_t timeout;
  1817. } __attribute__ ((packed)) evt_link_supervision_timeout_changed;
  1818. #define EVT_LINK_SUPERVISION_TIMEOUT_CHANGED_SIZE 4
  1819. #define EVT_ENHANCED_FLUSH_COMPLETE 0x39
  1820. typedef struct {
  1821. uint16_t handle;
  1822. } __attribute__ ((packed)) evt_enhanced_flush_complete;
  1823. #define EVT_ENHANCED_FLUSH_COMPLETE_SIZE 2
  1824. #define EVT_USER_PASSKEY_NOTIFY 0x3B
  1825. typedef struct {
  1826. bdaddr_t bdaddr;
  1827. uint32_t passkey;
  1828. } __attribute__ ((packed)) evt_user_passkey_notify;
  1829. #define EVT_USER_PASSKEY_NOTIFY_SIZE 10
  1830. #define EVT_KEYPRESS_NOTIFY 0x3C
  1831. typedef struct {
  1832. bdaddr_t bdaddr;
  1833. uint8_t type;
  1834. } __attribute__ ((packed)) evt_keypress_notify;
  1835. #define EVT_KEYPRESS_NOTIFY_SIZE 7
  1836. #define EVT_REMOTE_HOST_FEATURES_NOTIFY 0x3D
  1837. typedef struct {
  1838. bdaddr_t bdaddr;
  1839. uint8_t features[8];
  1840. } __attribute__ ((packed)) evt_remote_host_features_notify;
  1841. #define EVT_REMOTE_HOST_FEATURES_NOTIFY_SIZE 14
  1842. #define EVT_LE_META_EVENT 0x3E
  1843. typedef struct {
  1844. uint8_t subevent;
  1845. uint8_t data[0];
  1846. } __attribute__ ((packed)) evt_le_meta_event;
  1847. #define EVT_LE_META_EVENT_SIZE 1
  1848. #define EVT_LE_CONN_COMPLETE 0x01
  1849. typedef struct {
  1850. uint8_t status;
  1851. uint16_t handle;
  1852. uint8_t role;
  1853. uint8_t peer_bdaddr_type;
  1854. bdaddr_t peer_bdaddr;
  1855. uint16_t interval;
  1856. uint16_t latency;
  1857. uint16_t supervision_timeout;
  1858. uint8_t master_clock_accuracy;
  1859. } __attribute__ ((packed)) evt_le_connection_complete;
  1860. #define EVT_LE_CONN_COMPLETE_SIZE 18
  1861. #define EVT_LE_ADVERTISING_REPORT 0x02
  1862. typedef struct {
  1863. uint8_t evt_type;
  1864. uint8_t bdaddr_type;
  1865. bdaddr_t bdaddr;
  1866. uint8_t length;
  1867. uint8_t data[0];
  1868. } __attribute__ ((packed)) le_advertising_info;
  1869. #define LE_ADVERTISING_INFO_SIZE 9
  1870. #define EVT_LE_CONN_UPDATE_COMPLETE 0x03
  1871. typedef struct {
  1872. uint8_t status;
  1873. uint16_t handle;
  1874. uint16_t interval;
  1875. uint16_t latency;
  1876. uint16_t supervision_timeout;
  1877. } __attribute__ ((packed)) evt_le_connection_update_complete;
  1878. #define EVT_LE_CONN_UPDATE_COMPLETE_SIZE 9
  1879. #define EVT_LE_READ_REMOTE_USED_FEATURES_COMPLETE 0x04
  1880. typedef struct {
  1881. uint8_t status;
  1882. uint16_t handle;
  1883. uint8_t features[8];
  1884. } __attribute__ ((packed)) evt_le_read_remote_used_features_complete;
  1885. #define EVT_LE_READ_REMOTE_USED_FEATURES_COMPLETE_SIZE 11
  1886. #define EVT_LE_LTK_REQUEST 0x05
  1887. typedef struct {
  1888. uint16_t handle;
  1889. uint64_t random;
  1890. uint16_t diversifier;
  1891. } __attribute__ ((packed)) evt_le_long_term_key_request;
  1892. #define EVT_LE_LTK_REQUEST_SIZE 12
  1893. #define EVT_PHYSICAL_LINK_COMPLETE 0x40
  1894. typedef struct {
  1895. uint8_t status;
  1896. uint8_t handle;
  1897. } __attribute__ ((packed)) evt_physical_link_complete;
  1898. #define EVT_PHYSICAL_LINK_COMPLETE_SIZE 2
  1899. #define EVT_CHANNEL_SELECTED 0x41
  1900. #define EVT_DISCONNECT_PHYSICAL_LINK_COMPLETE 0x42
  1901. typedef struct {
  1902. uint8_t status;
  1903. uint8_t handle;
  1904. uint8_t reason;
  1905. } __attribute__ ((packed)) evt_disconn_physical_link_complete;
  1906. #define EVT_DISCONNECT_PHYSICAL_LINK_COMPLETE_SIZE 3
  1907. #define EVT_PHYSICAL_LINK_LOSS_EARLY_WARNING 0x43
  1908. typedef struct {
  1909. uint8_t handle;
  1910. uint8_t reason;
  1911. } __attribute__ ((packed)) evt_physical_link_loss_warning;
  1912. #define EVT_PHYSICAL_LINK_LOSS_WARNING_SIZE 2
  1913. #define EVT_PHYSICAL_LINK_RECOVERY 0x44
  1914. typedef struct {
  1915. uint8_t handle;
  1916. } __attribute__ ((packed)) evt_physical_link_recovery;
  1917. #define EVT_PHYSICAL_LINK_RECOVERY_SIZE 1
  1918. #define EVT_LOGICAL_LINK_COMPLETE 0x45
  1919. typedef struct {
  1920. uint8_t status;
  1921. uint16_t log_handle;
  1922. uint8_t handle;
  1923. uint8_t tx_flow_id;
  1924. } __attribute__ ((packed)) evt_logical_link_complete;
  1925. #define EVT_LOGICAL_LINK_COMPLETE_SIZE 5
  1926. #define EVT_DISCONNECT_LOGICAL_LINK_COMPLETE 0x46
  1927. #define EVT_FLOW_SPEC_MODIFY_COMPLETE 0x47
  1928. typedef struct {
  1929. uint8_t status;
  1930. uint16_t handle;
  1931. } __attribute__ ((packed)) evt_flow_spec_modify_complete;
  1932. #define EVT_FLOW_SPEC_MODIFY_COMPLETE_SIZE 3
  1933. #define EVT_NUMBER_COMPLETED_BLOCKS 0x48
  1934. typedef struct {
  1935. uint16_t handle;
  1936. uint16_t num_cmplt_pkts;
  1937. uint16_t num_cmplt_blks;
  1938. } __attribute__ ((packed)) cmplt_handle;
  1939. typedef struct {
  1940. uint16_t total_num_blocks;
  1941. uint8_t num_handles;
  1942. cmplt_handle handles[0];
  1943. } __attribute__ ((packed)) evt_num_completed_blocks;
  1944. #define EVT_AMP_STATUS_CHANGE 0x4D
  1945. typedef struct {
  1946. uint8_t status;
  1947. uint8_t amp_status;
  1948. } __attribute__ ((packed)) evt_amp_status_change;
  1949. #define EVT_AMP_STATUS_CHANGE_SIZE 2
  1950. #define EVT_TESTING 0xFE
  1951. #define EVT_VENDOR 0xFF
  1952. /* Internal events generated by BlueZ stack */
  1953. #define EVT_STACK_INTERNAL 0xFD
  1954. typedef struct {
  1955. uint16_t type;
  1956. uint8_t data[0];
  1957. } __attribute__ ((packed)) evt_stack_internal;
  1958. #define EVT_STACK_INTERNAL_SIZE 2
  1959. #define EVT_SI_DEVICE 0x01
  1960. typedef struct {
  1961. uint16_t event;
  1962. uint16_t dev_id;
  1963. } __attribute__ ((packed)) evt_si_device;
  1964. #define EVT_SI_DEVICE_SIZE 4
  1965. /* -------- HCI Packet structures -------- */
  1966. #define HCI_TYPE_LEN 1
  1967. typedef struct {
  1968. uint16_t opcode; /* OCF & OGF */
  1969. uint8_t plen;
  1970. } __attribute__ ((packed)) hci_command_hdr;
  1971. #define HCI_COMMAND_HDR_SIZE 3
  1972. typedef struct {
  1973. uint8_t evt;
  1974. uint8_t plen;
  1975. } __attribute__ ((packed)) hci_event_hdr;
  1976. #define HCI_EVENT_HDR_SIZE 2
  1977. typedef struct {
  1978. uint16_t handle; /* Handle & Flags(PB, BC) */
  1979. uint16_t dlen;
  1980. } __attribute__ ((packed)) hci_acl_hdr;
  1981. #define HCI_ACL_HDR_SIZE 4
  1982. typedef struct {
  1983. uint16_t handle;
  1984. uint8_t dlen;
  1985. } __attribute__ ((packed)) hci_sco_hdr;
  1986. #define HCI_SCO_HDR_SIZE 3
  1987. typedef struct {
  1988. uint16_t device;
  1989. uint16_t type;
  1990. uint16_t plen;
  1991. } __attribute__ ((packed)) hci_msg_hdr;
  1992. #define HCI_MSG_HDR_SIZE 6
  1993. /* Command opcode pack/unpack */
  1994. #define cmd_opcode_pack(ogf, ocf) (uint16_t)((ocf & 0x03ff)|(ogf << 10))
  1995. #define cmd_opcode_ogf(op) (op >> 10)
  1996. #define cmd_opcode_ocf(op) (op & 0x03ff)
  1997. /* ACL handle and flags pack/unpack */
  1998. #define acl_handle_pack(h, f) (uint16_t)((h & 0x0fff)|(f << 12))
  1999. #define acl_handle(h) (h & 0x0fff)
  2000. #define acl_flags(h) (h >> 12)
  2001. #endif /* _NO_HCI_DEFS */
  2002. /* HCI Socket options */
  2003. #define HCI_DATA_DIR 1
  2004. #define HCI_FILTER 2
  2005. #define HCI_TIME_STAMP 3
  2006. /* HCI CMSG flags */
  2007. #define HCI_CMSG_DIR 0x0001
  2008. #define HCI_CMSG_TSTAMP 0x0002
  2009. struct sockaddr_hci {
  2010. sa_family_t hci_family;
  2011. unsigned short hci_dev;
  2012. unsigned short hci_channel;
  2013. };
  2014. #define HCI_DEV_NONE 0xffff
  2015. #define HCI_CHANNEL_RAW 0
  2016. #define HCI_CHANNEL_USER 1
  2017. #define HCI_CHANNEL_MONITOR 2
  2018. #define HCI_CHANNEL_CONTROL 3
  2019. #define HCI_CHANNEL_LOGGING 4
  2020. struct hci_filter {
  2021. uint32_t type_mask;
  2022. uint32_t event_mask[2];
  2023. uint16_t opcode;
  2024. };
  2025. #define HCI_FLT_TYPE_BITS 31
  2026. #define HCI_FLT_EVENT_BITS 63
  2027. #define HCI_FLT_OGF_BITS 63
  2028. #define HCI_FLT_OCF_BITS 127
  2029. /* Ioctl requests structures */
  2030. struct hci_dev_stats {
  2031. uint32_t err_rx;
  2032. uint32_t err_tx;
  2033. uint32_t cmd_tx;
  2034. uint32_t evt_rx;
  2035. uint32_t acl_tx;
  2036. uint32_t acl_rx;
  2037. uint32_t sco_tx;
  2038. uint32_t sco_rx;
  2039. uint32_t byte_rx;
  2040. uint32_t byte_tx;
  2041. };
  2042. struct hci_dev_info {
  2043. uint16_t dev_id;
  2044. char name[8];
  2045. bdaddr_t bdaddr;
  2046. uint32_t flags;
  2047. uint8_t type;
  2048. uint8_t features[8];
  2049. uint32_t pkt_type;
  2050. uint32_t link_policy;
  2051. uint32_t link_mode;
  2052. uint16_t acl_mtu;
  2053. uint16_t acl_pkts;
  2054. uint16_t sco_mtu;
  2055. uint16_t sco_pkts;
  2056. struct hci_dev_stats stat;
  2057. };
  2058. struct hci_conn_info {
  2059. uint16_t handle;
  2060. bdaddr_t bdaddr;
  2061. uint8_t type;
  2062. uint8_t out;
  2063. uint16_t state;
  2064. uint32_t link_mode;
  2065. };
  2066. struct hci_dev_req {
  2067. uint16_t dev_id;
  2068. uint32_t dev_opt;
  2069. };
  2070. struct hci_dev_list_req {
  2071. uint16_t dev_num;
  2072. struct hci_dev_req dev_req[0]; /* hci_dev_req structures */
  2073. };
  2074. struct hci_conn_list_req {
  2075. uint16_t dev_id;
  2076. uint16_t conn_num;
  2077. struct hci_conn_info conn_info[0];
  2078. };
  2079. struct hci_conn_info_req {
  2080. bdaddr_t bdaddr;
  2081. uint8_t type;
  2082. struct hci_conn_info conn_info[0];
  2083. };
  2084. struct hci_auth_info_req {
  2085. bdaddr_t bdaddr;
  2086. uint8_t type;
  2087. };
  2088. struct hci_inquiry_req {
  2089. uint16_t dev_id;
  2090. uint16_t flags;
  2091. uint8_t lap[3];
  2092. uint8_t length;
  2093. uint8_t num_rsp;
  2094. };
  2095. #define IREQ_CACHE_FLUSH 0x0001
  2096. #ifdef __cplusplus
  2097. }
  2098. #endif
  2099. #endif /* __HCI_H */