hci.h 84 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605
  1. /**************************************************************************************************
  2. Phyplus Microelectronics Limited confidential and proprietary.
  3. All rights reserved.
  4. IMPORTANT: All rights of this software belong to Phyplus Microelectronics
  5. Limited ("Phyplus"). Your use of this Software is limited to those
  6. specific rights granted under the terms of the business contract, the
  7. confidential agreement, the non-disclosure agreement and any other forms
  8. of agreements as a customer or a partner of Phyplus. You may not use this
  9. Software unless you agree to abide by the terms of these agreements.
  10. You acknowledge that the Software may not be modified, copied,
  11. distributed or disclosed unless embedded on a Phyplus Bluetooth Low Energy
  12. (BLE) integrated circuit, either as a product or is integrated into your
  13. products. Other than for the aforementioned purposes, you may not use,
  14. reproduce, copy, prepare derivative works of, modify, distribute, perform,
  15. display or sell this Software and/or its documentation for any purposes.
  16. YOU FURTHER ACKNOWLEDGE AND AGREE THAT THE SOFTWARE AND DOCUMENTATION ARE
  17. PROVIDED AS IS WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED,
  18. INCLUDING WITHOUT LIMITATION, ANY WARRANTY OF MERCHANTABILITY, TITLE,
  19. NON-INFRINGEMENT AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL
  20. PHYPLUS OR ITS SUBSIDIARIES BE LIABLE OR OBLIGATED UNDER CONTRACT,
  21. NEGLIGENCE, STRICT LIABILITY, CONTRIBUTION, BREACH OF WARRANTY, OR OTHER
  22. LEGAL EQUITABLE THEORY ANY DIRECT OR INDIRECT DAMAGES OR EXPENSES
  23. INCLUDING BUT NOT LIMITED TO ANY INCIDENTAL, SPECIAL, INDIRECT, PUNITIVE
  24. OR CONSEQUENTIAL DAMAGES, LOST PROFITS OR LOST DATA, COST OF PROCUREMENT
  25. OF SUBSTITUTE GOODS, TECHNOLOGY, SERVICES, OR ANY CLAIMS BY THIRD PARTIES
  26. (INCLUDING BUT NOT LIMITED TO ANY DEFENSE THEREOF), OR OTHER SIMILAR COSTS.
  27. **************************************************************************************************/
  28. /*******************************************************************************
  29. Filename: hci.h
  30. Revised:
  31. Revision:
  32. Description: This file contains the Host Controller Interface (HCI) API.
  33. It provides the defines, types, and functions for all
  34. supported Bluetooth Low Energy (BLE) commands.
  35. All Bluetooth and BLE commands are based on:
  36. Bluetooth Core Specification, V4.0.0, Vol. 2, Part E.
  37. *******************************************************************************/
  38. #ifndef HCI_H
  39. #define HCI_H
  40. #ifdef __cplusplus
  41. extern "C"
  42. {
  43. #endif
  44. /*******************************************************************************
  45. * INCLUDES
  46. */
  47. #include "bcomdef.h"
  48. #include "OSAL.h"
  49. #include "ll.h"
  50. //#include "hal_assert.h"
  51. /*******************************************************************************
  52. * MACROS
  53. */
  54. /*******************************************************************************
  55. * CONSTANTS
  56. */
  57. /*
  58. ** HCI Status
  59. **
  60. ** Per the Bluetooth Core Specification, V4.0.0, Vol. 2, Part D.
  61. */
  62. #define HCI_SUCCESS 0x00
  63. #define HCI_ERROR_CODE_UNKNOWN_HCI_CMD 0x01
  64. #define HCI_ERROR_CODE_UNKNOWN_CONN_ID 0x02
  65. #define HCI_ERROR_CODE_HW_FAILURE 0x03
  66. #define HCI_ERROR_CODE_PAGE_TIMEOUT 0x04
  67. #define HCI_ERROR_CODE_AUTH_FAILURE 0x05
  68. #define HCI_ERROR_CODE_PIN_KEY_MISSING 0x06
  69. #define HCI_ERROR_CODE_MEM_CAP_EXCEEDED 0x07
  70. #define HCI_ERROR_CODE_CONN_TIMEOUT 0x08
  71. #define HCI_ERROR_CODE_CONN_LIMIT_EXCEEDED 0x09
  72. #define HCI_ERROR_CODE_SYNCH_CONN_LIMIT_EXCEEDED 0x0A
  73. #define HCI_ERROR_CODE_ACL_CONN_ALREADY_EXISTS 0x0B
  74. #define HCI_ERROR_CODE_CMD_DISALLOWED 0x0C
  75. #define HCI_ERROR_CODE_CONN_REJ_LIMITED_RESOURCES 0x0D
  76. #define HCI_ERROR_CODE_CONN_REJECTED_SECURITY_REASONS 0x0E
  77. #define HCI_ERROR_CODE_CONN_REJECTED_UNACCEPTABLE_BDADDR 0x0F
  78. #define HCI_ERROR_CODE_CONN_ACCEPT_TIMEOUT_EXCEEDED 0x10
  79. #define HCI_ERROR_CODE_UNSUPPORTED_FEATURE_PARAM_VALUE 0x11
  80. #define HCI_ERROR_CODE_INVALID_HCI_CMD_PARAMS 0x12
  81. #define HCI_ERROR_CODE_REMOTE_USER_TERM_CONN 0x13
  82. #define HCI_ERROR_CODE_REMOTE_DEVICE_TERM_CONN_LOW_RESOURCES 0x14
  83. #define HCI_ERROR_CODE_REMOTE_DEVICE_TERM_CONN_POWER_OFF 0x15
  84. #define HCI_ERROR_CODE_CONN_TERM_BY_LOCAL_HOST 0x16
  85. #define HCI_ERROR_CODE_REPEATED_ATTEMPTS 0x17
  86. #define HCI_ERROR_CODE_PAIRING_NOT_ALLOWED 0x18
  87. #define HCI_ERROR_CODE_UNKNOWN_LMP_PDU 0x19
  88. #define HCI_ERROR_CODE_UNSUPPORTED_REMOTE_FEATURE 0x1A
  89. #define HCI_ERROR_CODE_SCO_OFFSET_REJ 0x1B
  90. #define HCI_ERROR_CODE_SCO_INTERVAL_REJ 0x1C
  91. #define HCI_ERROR_CODE_SCO_AIR_MODE_REJ 0x1D
  92. #define HCI_ERROR_CODE_INVALID_LMP_PARAMS 0x1E
  93. #define HCI_ERROR_CODE_UNSPECIFIED_ERROR 0x1F
  94. #define HCI_ERROR_CODE_UNSUPPORTED_LMP_PARAM_VAL 0x20
  95. #define HCI_ERROR_CODE_ROLE_CHANGE_NOT_ALLOWED 0x21
  96. #define HCI_ERROR_CODE_LMP_LL_RESP_TIMEOUT 0x22
  97. #define HCI_ERROR_CODE_LMP_ERR_TRANSACTION_COLLISION 0x23
  98. #define HCI_ERROR_CODE_LMP_PDU_NOT_ALLOWED 0x24
  99. #define HCI_ERROR_CODE_ENCRYPT_MODE_NOT_ACCEPTABLE 0x25
  100. #define HCI_ERROR_CODE_LINK_KEY_CAN_NOT_BE_CHANGED 0x26
  101. #define HCI_ERROR_CODE_REQ_QOS_NOT_SUPPORTED 0x27
  102. #define HCI_ERROR_CODE_INSTANT_PASSED 0x28
  103. #define HCI_ERROR_CODE_PAIRING_WITH_UNIT_KEY_NOT_SUPPORTED 0x29
  104. #define HCI_ERROR_CODE_DIFFERENT_TRANSACTION_COLLISION 0x2A
  105. #define HCI_ERROR_CODE_RESERVED1 0x2B
  106. #define HCI_ERROR_CODE_QOS_UNACCEPTABLE_PARAM 0x2C
  107. #define HCI_ERROR_CODE_QOS_REJ 0x2D
  108. #define HCI_ERROR_CODE_CHAN_ASSESSMENT_NOT_SUPPORTED 0x2E
  109. #define HCI_ERROR_CODE_INSUFFICIENT_SECURITY 0x2F
  110. #define HCI_ERROR_CODE_PARAM_OUT_OF_MANDATORY_RANGE 0x30
  111. #define HCI_ERROR_CODE_RESERVED2 0x31
  112. #define HCI_ERROR_CODE_ROLE_SWITCH_PENDING 0x32
  113. #define HCI_ERROR_CODE_RESERVED3 0x33
  114. #define HCI_ERROR_CODE_RESERVED_SLOT_VIOLATION 0x34
  115. #define HCI_ERROR_CODE_ROLE_SWITCH_FAILED 0x35
  116. #define HCI_ERROR_CODE_EXTENDED_INQUIRY_RESP_TOO_LARGE 0x36
  117. #define HCI_ERROR_CODE_SIMPLE_PAIRING_NOT_SUPPORTED_BY_HOST 0x37
  118. #define HCI_ERROR_CODE_HOST_BUSY_PAIRING 0x38
  119. #define HCI_ERROR_CODE_CONN_REJ_NO_SUITABLE_CHAN_FOUND 0x39
  120. #define HCI_ERROR_CODE_CONTROLLER_BUSY 0x3A
  121. #define HCI_ERROR_CODE_UNACCEPTABLE_CONN_INTERVAL 0x3B
  122. #define HCI_ERROR_CODE_DIRECTED_ADV_TIMEOUT 0x3C
  123. #define HCI_ERROR_CODE_CONN_TERM_MIC_FAILURE 0x3D
  124. #define HCI_ERROR_CODE_CONN_FAILED_TO_ESTABLISH 0x3E
  125. #define HCI_ERROR_CODE_MAC_CONN_FAILED 0x3F
  126. /*
  127. ** Max Buffers Supported
  128. */
  129. #define HCI_MAX_NUM_DATA_BUFFERS LL_MAX_NUM_DATA_BUFFERS
  130. #define HCI_MAX_NUM_CMD_BUFFERS LL_MAX_NUM_CMD_BUFFERS
  131. /*
  132. ** HCI Command API Parameters
  133. */
  134. // Send Data Packet Boundary Flags
  135. #define FIRST_PKT_HOST_TO_CTRL LL_DATA_FIRST_PKT_HOST_TO_CTRL
  136. #define CONTINUING_PKT LL_DATA_CONTINUATION_PKT
  137. #define FIRST_PKT_CTRL_TO_HOST LL_DATA_FIRST_PKT_CTRL_TO_HOST
  138. // Receive Data Packet
  139. #define HCI_RSSI_NOT_AVAILABLE LL_RSSI_NOT_AVAILABLE
  140. // Disconnect Reasons
  141. #define HCI_DISCONNECT_AUTH_FAILURE HCI_ERROR_CODE_AUTH_FAILURE
  142. #define HCI_DISCONNECT_REMOTE_USER_TERM HCI_ERROR_CODE_REMOTE_USER_TERM_CONN
  143. #define HCI_DISCONNECT_REMOTE_DEV_LOW_RESOURCES HCI_ERROR_CODE_REMOTE_DEVICE_TERM_CONN_LOW_RESOURCES
  144. #define HCI_DISCONNECT_REMOTE_DEV_POWER_OFF HCI_ERROR_CODE_REMOTE_DEVICE_TERM_CONN_POWER_OFF
  145. #define HCI_DISCONNECT_UNSUPPORTED_REMOTE_FEATURE HCI_ERROR_CODE_UNSUPPORTED_REMOTE_FEATURE
  146. #define HCI_DISCONNECT_KEY_PAIRING_NOT_SUPPORTED HCI_ERROR_CODE_PAIRING_WITH_UNIT_KEY_NOT_SUPPORTED
  147. #define HCI_DISCONNECT_UNACCEPTABLE_CONN_INTERVAL HCI_ERROR_CODE_UNACCEPTABLE_CONN_INTERVAL
  148. // Tx Power Types
  149. #define HCI_READ_CURRENT_TX_POWER_LEVEL LL_READ_CURRENT_TX_POWER_LEVEL
  150. #define HCI_READ_MAX_TX_POWER_LEVEL LL_READ_MAX_TX_POWER_LEVEL
  151. // Host Flow Control
  152. #define HCI_CTRL_TO_HOST_FLOW_CTRL_OFF 0
  153. #define HCI_CTRL_TO_HOST_FLOW_CTRL_ACL_ON_SYNCH_OFF 1
  154. #define HCI_CTRL_TO_HOST_FLOW_CTRL_ACL_OFF_SYNCH_ON 2
  155. #define HCI_CTRL_TO_HOST_FLOW_CTRL_ACL_ON_SYNCH_ON 3
  156. // Device Address Type
  157. #define HCI_PUBLIC_DEVICE_ADDRESS LL_DEV_ADDR_TYPE_PUBLIC
  158. #define HCI_RANDOM_DEVICE_ADDRESS LL_DEV_ADDR_TYPE_RANDOM
  159. // Advertiser Events
  160. #define HCI_CONNECTABLE_UNDIRECTED_ADV LL_ADV_CONNECTABLE_UNDIRECTED_EVT
  161. #define HCI_CONNECTABLE_DIRECTED_HDC_ADV LL_ADV_CONNECTABLE_DIRECTED_HDC_EVT
  162. #define HCI_SCANNABLE_UNDIRECTED LL_ADV_SCANNABLE_UNDIRECTED_EVT
  163. #define HCI_NONCONNECTABLE_UNDIRECTED_ADV LL_ADV_NONCONNECTABLE_UNDIRECTED_EVT
  164. #define HCI_CONNECTABLE_DIRECTED_LDC_ADV LL_ADV_CONNECTABLE_DIRECTED_LDC_EVT
  165. // Advertiser Channels
  166. #define HCI_ADV_CHAN_37 LL_ADV_CHAN_37
  167. #define HCI_ADV_CHAN_38 LL_ADV_CHAN_38
  168. #define HCI_ADV_CHAN_39 LL_ADV_CHAN_39
  169. #define HCI_ADV_CHAN_ALL (LL_ADV_CHAN_37 | LL_ADV_CHAN_38 | LL_ADV_CHAN_39)
  170. // Advertiser White List Policy
  171. #define HCI_ADV_WL_POLICY_ANY_REQ LL_ADV_WL_POLICY_ANY_REQ
  172. #define HCI_ADV_WL_POLICY_WL_SCAN_REQ LL_ADV_WL_POLICY_WL_SCAN_REQ
  173. #define HCI_ADV_WL_POLICY_WL_CONNECT_REQ LL_ADV_WL_POLICY_WL_CONNECT_REQ
  174. #define HCI_ADV_WL_POLICY_WL_ALL_REQ LL_ADV_WL_POLICY_WL_ALL_REQ
  175. // Advertiser Commands
  176. #define HCI_ENABLE_ADV LL_ADV_MODE_ON
  177. #define HCI_DISABLE_ADV LL_ADV_MODE_OFF
  178. // Scan Types
  179. #define HCI_SCAN_PASSIVE LL_SCAN_PASSIVE
  180. #define HCI_SCAN_ACTIVE LL_SCAN_ACTIVE
  181. // Scan White List Policy
  182. #define HCI_SCAN_WL_POLICY_ANY_ADV_PKTS LL_SCAN_WL_POLICY_ANY_ADV_PKTS
  183. #define HCI_SCAN_WL_POLICY_USE_WHITE_LIST LL_SCAN_WL_POLICY_USE_WHITE_LIST
  184. // Scan Filtering
  185. #define HCI_FILTER_REPORTS_DISABLE LL_FILTER_REPORTS_DISABLE
  186. #define HCI_FILTER_REPORTS_ENABLE LL_FILTER_REPORTS_ENABLE
  187. // Scan Commands
  188. #define HCI_SCAN_STOP LL_SCAN_STOP
  189. #define HCI_SCAN_START LL_SCAN_START
  190. // Initiator White List Policy
  191. #define HCI_INIT_WL_POLICY_USE_PEER_ADDR LL_INIT_WL_POLICY_USE_PEER_ADDR
  192. #define HCI_INIT_WL_POLICY_USE_WHITE_LIST LL_INIT_WL_POLICY_USE_WHITE_LIST
  193. // Encryption Related
  194. #define HCI_ENCRYPTION_OFF LL_ENCRYPTION_OFF
  195. #define HCI_ENCRYPTION_ON LL_ENCRYPTION_ON
  196. // Direct Test Mode
  197. #define HCI_DTM_NUMBER_RF_CHANS LL_DIRECT_TEST_NUM_RF_CHANS
  198. #define HCI_DIRECT_TEST_MAX_PAYLOAD_LEN LL_DIRECT_TEST_MAX_PAYLOAD_LEN
  199. //
  200. #define HCI_DIRECT_TEST_PAYLOAD_PRBS9 LL_DIRECT_TEST_PAYLOAD_PRBS9
  201. #define HCI_DIRECT_TEST_PAYLOAD_0x0F LL_DIRECT_TEST_PAYLOAD_0x0F
  202. #define HCI_DIRECT_TEST_PAYLOAD_0x55 LL_DIRECT_TEST_PAYLOAD_0x55
  203. #define HCI_DIRECT_TEST_PAYLOAD_PRBS15 LL_DIRECT_TEST_PAYLOAD_PRBS15
  204. #define HCI_DIRECT_TEST_PAYLOAD_0xFF LL_DIRECT_TEST_PAYLOAD_0xFF
  205. #define HCI_DIRECT_TEST_PAYLOAD_0x00 LL_DIRECT_TEST_PAYLOAD_0x00
  206. #define HCI_DIRECT_TEST_PAYLOAD_0xF0 LL_DIRECT_TEST_PAYLOAD_0xF0
  207. #define HCI_DIRECT_TEST_PAYLOAD_0xAA LL_DIRECT_TEST_PAYLOAD_0xAA
  208. // Vendor Specific
  209. #define HCI_EXT_RX_GAIN_STD LL_EXT_RX_GAIN_STD
  210. #define HCI_EXT_RX_GAIN_HIGH LL_EXT_RX_GAIN_HIGH
  211. //
  212. #define HCI_EXT_TX_POWER_MINUS_23_DBM LL_EXT_TX_POWER_MINUS_23_DBM
  213. #define HCI_EXT_TX_POWER_MINUS_6_DBM LL_EXT_TX_POWER_MINUS_6_DBM
  214. #define HCI_EXT_TX_POWER_0_DBM LL_EXT_TX_POWER_0_DBM
  215. #define HCI_EXT_TX_POWER_4_DBM LL_EXT_TX_POWER_4_DBM
  216. //
  217. #define HCI_EXT_ENABLE_ONE_PKT_PER_EVT LL_EXT_ENABLE_ONE_PKT_PER_EVT
  218. #define HCI_EXT_DISABLE_ONE_PKT_PER_EVT LL_EXT_DISABLE_ONE_PKT_PER_EVT
  219. //
  220. #define HCI_EXT_ENABLE_CLK_DIVIDE_ON_HALT LL_EXT_ENABLE_CLK_DIVIDE_ON_HALT
  221. #define HCI_EXT_DISABLE_CLK_DIVIDE_ON_HALT LL_EXT_DISABLE_CLK_DIVIDE_ON_HALT
  222. //
  223. #define HCI_EXT_NV_IN_USE LL_EXT_NV_IN_USE
  224. #define HCI_EXT_NV_NOT_IN_USE LL_EXT_NV_NOT_IN_USE
  225. //
  226. #define HCI_EXT_ENABLE_FAST_TX_RESP_TIME LL_EXT_ENABLE_FAST_TX_RESP_TIME
  227. #define HCI_EXT_DISABLE_FAST_TX_RESP_TIME LL_EXT_DISABLE_FAST_TX_RESP_TIME
  228. //
  229. #define HCI_EXT_ENABLE_SL_OVERRIDE LL_EXT_ENABLE_SL_OVERRIDE
  230. #define HCI_EXT_DISABLE_SL_OVERRIDE LL_EXT_DISABLE_SL_OVERRIDE
  231. //
  232. #define HCI_EXT_TX_MODULATED_CARRIER LL_EXT_TX_MODULATED_CARRIER
  233. #define HCI_EXT_TX_UNMODULATED_CARRIER LL_EXT_TX_UNMODULATED_CARRIER
  234. //
  235. #define HCI_PTM_SET_FREQ_TUNE_DOWN LL_EXT_SET_FREQ_TUNE_DOWN
  236. #define HCI_PTM_SET_FREQ_TUNE_UP LL_EXT_SET_FREQ_TUNE_UP
  237. //
  238. #define HCI_EXT_PM_IO_PORT_P0 LL_EXT_PM_IO_PORT_P0
  239. #define HCI_EXT_PM_IO_PORT_P1 LL_EXT_PM_IO_PORT_P1
  240. #define HCI_EXT_PM_IO_PORT_P2 LL_EXT_PM_IO_PORT_P2
  241. #define HCI_EXT_PM_IO_PORT_NONE LL_EXT_PM_IO_PORT_NONE
  242. //
  243. #define HCI_EXT_PM_IO_PORT_PIN0 LL_EXT_PM_IO_PORT_PIN0
  244. #define HCI_EXT_PM_IO_PORT_PIN1 LL_EXT_PM_IO_PORT_PIN1
  245. #define HCI_EXT_PM_IO_PORT_PIN2 LL_EXT_PM_IO_PORT_PIN2
  246. #define HCI_EXT_PM_IO_PORT_PIN3 LL_EXT_PM_IO_PORT_PIN3
  247. #define HCI_EXT_PM_IO_PORT_PIN4 LL_EXT_PM_IO_PORT_PIN4
  248. #define HCI_EXT_PM_IO_PORT_PIN5 LL_EXT_PM_IO_PORT_PIN5
  249. #define HCI_EXT_PM_IO_PORT_PIN6 LL_EXT_PM_IO_PORT_PIN6
  250. #define HCI_EXT_PM_IO_PORT_PIN7 LL_EXT_PM_IO_PORT_PIN7
  251. //
  252. #define HCI_EXT_PER_RESET LL_EXT_PER_RESET
  253. #define HCI_EXT_PER_READ LL_EXT_PER_READ
  254. //
  255. #define HCI_EXT_HALT_DURING_RF_DISABLE LL_EXT_HALT_DURING_RF_DISABLE
  256. #define HCI_EXT_HALT_DURING_RF_ENABLE LL_EXT_HALT_DURING_RF_ENABLE
  257. //
  258. #define HCI_EXT_SET_USER_REVISION LL_EXT_SET_USER_REVISION
  259. #define HCI_EXT_READ_BUILD_REVISION LL_EXT_READ_BUILD_REVISION
  260. //
  261. #define HCI_EXT_RESET_SYSTEM_HARD LL_EXT_RESET_SYSTEM_HARD
  262. #define HCI_EXT_RESET_SYSTEM_SOFT LL_EXT_RESET_SYSTEM_SOFT
  263. //
  264. #define HCI_EXT_DISABLE_OVERLAPPED_PROCESSING LL_EXT_DISABLE_OVERLAPPED_PROCESSING
  265. #define HCI_EXT_ENABLE_OVERLAPPED_PROCESSING LL_EXT_ENABLE_OVERLAPPED_PROCESSING
  266. //
  267. #define HCI_EXT_DISABLE_NUM_COMPL_PKTS_ON_EVENT LL_EXT_DISABLE_NUM_COMPL_PKTS_ON_EVENT
  268. #define HCI_EXT_ENABLE_NUM_COMPL_PKTS_ON_EVENT LL_EXT_ENABLE_NUM_COMPL_PKTS_ON_EVENT
  269. /*
  270. ** HCI Event Parameters
  271. */
  272. // HCI Link Type for Buffer Overflow
  273. #define HCI_LINK_TYPE_SCO_BUFFER_OVERFLOW 0
  274. #define HCI_LINK_TYPE_ACL_BUFFER_OVERFLOW 1
  275. /*******************************************************************************
  276. * TYPEDEFS
  277. */
  278. typedef uint8 hciStatus_t;
  279. /*
  280. ** LE Events
  281. */
  282. // LE Connection Complete Event
  283. typedef struct
  284. {
  285. osal_event_hdr_t hdr;
  286. uint8 BLEEventCode;
  287. uint8 status;
  288. uint16 connectionHandle;
  289. uint8 role;
  290. uint8 peerAddrType;
  291. uint8 peerAddr[B_ADDR_LEN];
  292. uint16 connInterval;
  293. uint16 connLatency;
  294. uint16 connTimeout;
  295. uint8 clockAccuracy;
  296. } hciEvt_BLEConnComplete_t;
  297. // LE Advertising Report Event
  298. typedef struct
  299. {
  300. uint8 eventType; // advertisment or scan response event type
  301. uint8 addrType; // public or random address type
  302. uint8 addr[B_ADDR_LEN]; // device address
  303. uint8 dataLen; // length of report data
  304. uint8 rspData[B_MAX_ADV_LEN]; // report data given by dataLen
  305. int8 rssi; // report RSSI
  306. } hciEvt_DevInfo_t;
  307. typedef struct
  308. {
  309. osal_event_hdr_t hdr;
  310. uint8 BLEEventCode;
  311. uint8 numDevices;
  312. hciEvt_DevInfo_t* devInfo; // pointer to the array of devInfo
  313. } hciEvt_BLEAdvPktReport_t;
  314. // LE Connection Update Complete Event
  315. typedef struct
  316. {
  317. osal_event_hdr_t hdr;
  318. uint8 BLEEventCode;
  319. uint8 status;
  320. uint16 connectionHandle;
  321. uint16 connInterval;
  322. uint16 connLatency;
  323. uint16 connTimeout;
  324. } hciEvt_BLEConnUpdateComplete_t;
  325. // LE Read Remote Used Features Complete Event
  326. typedef struct
  327. {
  328. osal_event_hdr_t hdr;
  329. uint8 BLEEventCode;
  330. uint8 status;
  331. uint16 connectionHandle;
  332. uint8 features[8];
  333. } hciEvt_BLEReadRemoteFeatureComplete_t;
  334. // LE Encryption Change Event
  335. typedef struct
  336. {
  337. osal_event_hdr_t hdr;
  338. uint8 BLEEventCode;
  339. uint16 connHandle;
  340. uint8 reason;
  341. uint8 encEnable;
  342. } hciEvt_EncryptChange_t;
  343. // LE Long Term Key Requested Event
  344. typedef struct
  345. {
  346. osal_event_hdr_t hdr;
  347. uint8 BLEEventCode;
  348. uint16 connHandle;
  349. uint8 random[B_RANDOM_NUM_SIZE];
  350. uint16 encryptedDiversifier;
  351. } hciEvt_BLELTKReq_t;
  352. // LE DATE LENGTH CHANGE Event
  353. typedef struct
  354. {
  355. osal_event_hdr_t hdr;
  356. uint8 BLEEventCode;
  357. uint16 connHandle;
  358. uint16 MaxTxOctets;
  359. uint16 MaxTxTime;
  360. uint16 MaxRxOctets;
  361. uint16 MaxRxTime;
  362. } hciEvt_BLEDataLenChange_t;
  363. // LE PHY UPDATE Complete Event
  364. typedef struct
  365. {
  366. osal_event_hdr_t hdr;
  367. uint8 BLEEventCode;
  368. uint8 status;
  369. uint16 connHandle;
  370. uint8 txPhy;
  371. uint8 rxPhy;
  372. } hciEvt_BLEPhyUpdateComplete_t;
  373. // LE PHY UPDATE Complete Event
  374. typedef struct
  375. {
  376. osal_event_hdr_t hdr;
  377. uint8 BLEEventCode;
  378. } hciEvt_BLEEvent_Hdr_t;
  379. // Number of Completed Packets Event
  380. typedef struct
  381. {
  382. osal_event_hdr_t hdr;
  383. uint8 numHandles;
  384. uint16 *pConnectionHandle; // pointer to the connection handle array
  385. uint16 *pNumCompletedPackets; // pointer to the number of completed packets array
  386. } hciEvt_NumCompletedPkt_t;
  387. // Command Complete Event
  388. typedef struct
  389. {
  390. osal_event_hdr_t hdr;
  391. uint8 numHciCmdPkt; // number of HCI Command Packet
  392. uint16 cmdOpcode;
  393. uint8 *pReturnParam; // pointer to the return parameter
  394. } hciEvt_CmdComplete_t;
  395. // Command Status Event
  396. typedef struct
  397. {
  398. osal_event_hdr_t hdr;
  399. uint8 cmdStatus;
  400. uint8 numHciCmdPkt;
  401. uint16 cmdOpcode;
  402. } hciEvt_CommandStatus_t;
  403. // Hardware Error Event
  404. typedef struct
  405. {
  406. osal_event_hdr_t hdr;
  407. uint8 hardwareCode;
  408. } hciEvt_HardwareError_t;
  409. // Disconnection Complete Event
  410. typedef struct
  411. {
  412. osal_event_hdr_t hdr;
  413. uint8 status;
  414. uint16 connHandle; // connection handle
  415. uint8 reason;
  416. } hciEvt_DisconnComplete_t;
  417. // Data Buffer Overflow Event
  418. typedef struct
  419. {
  420. osal_event_hdr_t hdr;
  421. uint8 linkType; // synchronous or asynchronous buffer overflow
  422. } hciEvt_BufferOverflow_t;
  423. // Data structure for HCI Command Complete Event Return Parameter
  424. typedef struct
  425. {
  426. uint8 status;
  427. uint16 dataPktLen;
  428. uint8 numDataPkts;
  429. } hciRetParam_LeReadBufSize_t;
  430. typedef struct
  431. {
  432. osal_event_hdr_t hdr;
  433. uint8 *pData;
  434. } hciPacket_t;
  435. typedef struct
  436. {
  437. osal_event_hdr_t hdr;
  438. uint8 pktType;
  439. uint16 connHandle;
  440. uint8 pbFlag;
  441. uint16 pktLen;
  442. uint8 *pData;
  443. } hciDataPacket_t;
  444. // OSAL HCI_DATA_EVENT message format. This message is used to forward incoming
  445. // data messages up to an application
  446. typedef struct
  447. {
  448. osal_event_hdr_t hdr; // OSAL event header
  449. uint16 connHandle; // connection handle
  450. uint8 pbFlag; // data packet boundary flag
  451. uint16 len; // length of data packet
  452. uint8 *pData; // data packet given by len
  453. } hciDataEvent_t;
  454. /*******************************************************************************
  455. * LOCAL VARIABLES
  456. */
  457. /*******************************************************************************
  458. * GLOBAL VARIABLES
  459. */
  460. /*
  461. ** HCI Support Functions
  462. */
  463. /*******************************************************************************
  464. * @fn HCI_bm_alloc API
  465. *
  466. * @brief This API is used to allocate memory using buffer management.
  467. *
  468. * Note: This function should never be called by the application.
  469. * It is only used by HCI and L2CAP_bm_alloc.
  470. *
  471. * input parameters
  472. *
  473. * @param size - Number of bytes to allocate from the heap.
  474. *
  475. * output parameters
  476. *
  477. * @param None.
  478. *
  479. * @return Pointer to buffer, or NULL.
  480. */
  481. extern void *HCI_bm_alloc( uint16 size );
  482. /*******************************************************************************
  483. * @fn HCI_ValidConnTimeParams API
  484. *
  485. * @brief This API is used to check that the connection time parameter
  486. * ranges are valid, and that the connection time parameter
  487. * combination is valid.
  488. *
  489. * Note: Only connIntervalMax is used as part of the time parameter
  490. * combination check.
  491. *
  492. * input parameters
  493. *
  494. * @param connIntervalMin - Minimum connection interval.
  495. * @param connIntervalMax - Maximum connection interval.
  496. * @param connLatency - Connection slave latency.
  497. * @param connTimeout - Connection supervision timeout.
  498. *
  499. * output parameters
  500. *
  501. * @param None.
  502. *
  503. * @return TRUE: Connection time parameter check is valid.
  504. * FALSE: Connection time parameter check is invalid.
  505. */
  506. extern uint8 HCI_ValidConnTimeParams( uint16 connIntervalMin,
  507. uint16 connIntervalMax,
  508. uint16 connLatency,
  509. uint16 connTimeout );
  510. /*******************************************************************************
  511. * @fn HCI_TestAppTaskRegister
  512. *
  513. * @brief HCI vendor specific registration for HCI Test Application.
  514. *
  515. * input parameters
  516. *
  517. * @param taskID - The HCI Test Application OSAL task identifer.
  518. *
  519. * output parameters
  520. *
  521. * @param None.
  522. *
  523. * @return None.
  524. */
  525. extern void HCI_TestAppTaskRegister( uint8 taskID );
  526. /*******************************************************************************
  527. * @fn HCI_GAPTaskRegister
  528. *
  529. * @brief HCI vendor specific registration for Host GAP.
  530. *
  531. * input parameters
  532. *
  533. * @param taskID - The Host GAP OSAL task identifer.
  534. *
  535. * output parameters
  536. *
  537. * @param None.
  538. *
  539. * @return None.
  540. */
  541. extern void HCI_GAPTaskRegister( uint8 taskID );
  542. /*******************************************************************************
  543. *
  544. * @fn HCI_L2CAPTaskRegister
  545. *
  546. * @brief HCI vendor specific registration for Host L2CAP.
  547. *
  548. * input parameters
  549. *
  550. * @param taskID - The Host L2CAP OSAL task identifer.
  551. *
  552. * output parameters
  553. *
  554. * @param None.
  555. *
  556. * @return None.
  557. *
  558. */
  559. extern void HCI_L2CAPTaskRegister( uint8 taskID );
  560. /*******************************************************************************
  561. * @fn HCI_SMPTaskRegister
  562. *
  563. * @brief HCI vendor specific registration for Host SMP.
  564. *
  565. * input parameters
  566. *
  567. * @param taskID - The Host SMP OSAL task identifer.
  568. *
  569. * output parameters
  570. *
  571. * @param None.
  572. *
  573. * @return None.
  574. */
  575. extern void HCI_SMPTaskRegister( uint8 taskID );
  576. /*******************************************************************************
  577. * @fn HCI_ExtTaskRegister
  578. *
  579. * @brief HCI vendor specific registration for Host extended commands.
  580. *
  581. * input parameters
  582. *
  583. * @param taskID - The Host Extended Command OSAL task identifer.
  584. *
  585. * output parameters
  586. *
  587. * @param None.
  588. *
  589. * @return None.
  590. */
  591. extern void HCI_ExtTaskRegister( uint8 taskID );
  592. /*******************************************************************************
  593. * @fn HCI_SendDataPkt API
  594. *
  595. * @brief This API is used to send a ACL data packet over a connection.
  596. *
  597. * Note: Empty packets are not sent.
  598. *
  599. * Related Events: HCI_NumOfCompletedPacketsEvent
  600. *
  601. * input parameters
  602. *
  603. * @param connHandle - Connection ID (handle).
  604. * @param pbFlag - Packet Boundary Flag.
  605. * @param pktLen - Number of bytes of data to transmit.
  606. * @param *pData - Pointer to data buffer to transmit.
  607. *
  608. * output parameters
  609. *
  610. * @param None.
  611. *
  612. * @return hciStatus_t
  613. */
  614. extern hciStatus_t HCI_SendDataPkt( uint16 connHandle,
  615. uint8 pbFlag,
  616. uint16 pktLen,
  617. uint8 *pData );
  618. /*
  619. ** HCI API
  620. */
  621. /*******************************************************************************
  622. * @fn HCI_DisconnectCmd API
  623. *
  624. * @brief This BT API is used to terminate a connection.
  625. *
  626. * Related Events: HCI_CommandStatusEvent,
  627. * DisconnectEvent
  628. *
  629. * input parameters
  630. *
  631. * @param connHandle - Connection handle.
  632. * @param reason - Reason for disconnection:
  633. * HCI_DISCONNECT_AUTH_FAILURE,
  634. * HCI_DISCONNECT_REMOTE_USER_TERM,
  635. * HCI_DISCONNECT_REMOTE_DEV_POWER_OFF,
  636. * HCI_DISCONNECT_UNSUPPORTED_REMOTE_FEATURE,
  637. * HCI_DISCONNECT_KEY_PAIRING_NOT_SUPPORTED
  638. * HCI_DISCONNECT_UNACCEPTABLE_CONN_INTERVAL
  639. *
  640. * output parameters
  641. *
  642. * @param None.
  643. *
  644. * @return hciStatus_t
  645. */
  646. extern hciStatus_t HCI_DisconnectCmd( uint16 connHandle,
  647. uint8 reason );
  648. /*******************************************************************************
  649. * @fn HCI_ReadRemoteVersionInfoCmd API
  650. *
  651. * @brief This BT API is used to request version information from the
  652. * the remote device in a connection.
  653. *
  654. * Related Events: HCI_CommandStatusEvent,
  655. * ReadRemoteVersionInfoEvent
  656. *
  657. * input parameters
  658. *
  659. * @param connHandle - Connection handle.
  660. *
  661. * output parameters
  662. *
  663. * @param None.
  664. *
  665. * @return hciStatus_t
  666. */
  667. extern hciStatus_t HCI_ReadRemoteVersionInfoCmd( uint16 connHandle );
  668. /*******************************************************************************
  669. * @fn HCI_SetEventMaskCmd API
  670. *
  671. * @brief This BT API is used to set the HCI event mask, which is used to
  672. * determine which events are supported.
  673. *
  674. * Related Events: HCI_CommandCompleteEvent
  675. *
  676. * input parameters
  677. *
  678. * @param pMask - Pointer to an eight byte event mask.
  679. *
  680. * output parameters
  681. *
  682. * @param None.
  683. *
  684. * @return hciStatus_t
  685. */
  686. extern hciStatus_t HCI_SetEventMaskCmd( uint8 *pMask );
  687. /*******************************************************************************
  688. * @fn HCI_Reset API
  689. *
  690. * @brief This BT API is used to reset the Link Layer.
  691. *
  692. * Related Events: HCI_CommandCompleteEvent
  693. *
  694. * input parameters
  695. *
  696. * @param None.
  697. *
  698. * output parameters
  699. *
  700. * @param None.
  701. *
  702. * @return hciStatus_t
  703. */
  704. extern hciStatus_t HCI_ResetCmd( void );
  705. /*******************************************************************************
  706. * @fn HCI_ReadTransmitPowerLevelCmd API
  707. *
  708. * @brief This BT API is used to read the transmit power level.
  709. *
  710. * Related Events: HCI_CommandCompleteEvent
  711. *
  712. * input parameters
  713. *
  714. * @param connHandle - Connection handle.
  715. * @param txPwrType - HCI_READ_CURRENT_TX_POWER_LEVEL,
  716. * HCI_READ_MAXIMUM_TX_POWER_LEVEL
  717. *
  718. * output parameters
  719. *
  720. * @param None.
  721. *
  722. * @return hciStatus_t
  723. */
  724. extern hciStatus_t HCI_ReadTransmitPowerLevelCmd( uint16 connHandle,
  725. uint8 txPwrType );
  726. /*******************************************************************************
  727. * @fn HCI_SetControllerToHostFlowCtrlCmd API
  728. *
  729. * @brief This BT API is used by the Host to turn flow control on or off
  730. * for data sent from the Controller to Host.
  731. *
  732. * Note: This command is currently not supported.
  733. *
  734. * Related Events: HCI_CommandCompleteEvent
  735. *
  736. * input parameters
  737. *
  738. * @param flowControlEnable - HCI_CTRL_TO_HOST_FLOW_CTRL_OFF,
  739. * HCI_CTRL_TO_HOST_FLOW_CTRL_ACL_ON_SYNCH_OFF,
  740. * HCI_CTRL_TO_HOST_FLOW_CTRL_ACL_OFF_SYNCH_ON,
  741. * HCI_CTRL_TO_HOST_FLOW_CTRL_ACL_ON_SYNCH_ON
  742. *
  743. * output parameters
  744. *
  745. * @param None.
  746. *
  747. * @return hciStatus_t
  748. */
  749. extern hciStatus_t HCI_SetControllerToHostFlowCtrlCmd( uint8 flowControlEnable );
  750. /*******************************************************************************
  751. * @fn HCI_HostBufferSizeCmd API
  752. *
  753. * @brief This BT API is used by the Host to notify the Controller of the
  754. * maximum size ACL buffer size the Controller can send to the
  755. * Host.
  756. *
  757. * Note: This command is currently ignored by the Controller. It
  758. * is assumed that the Host can always handle the maximum
  759. * BLE data packet size.
  760. *
  761. * Related Events: HCI_CommandCompleteEvent
  762. *
  763. * input parameters
  764. *
  765. * @param hostAclPktLen - Host ACL data packet length.
  766. * @param hostSyncPktLen - Host SCO data packet length .
  767. * @param hostTotalNumAclPkts - Host total number of ACL data packets.
  768. * @param hostTotalNumSyncPkts - Host total number of SCO data packets.
  769. *
  770. * output parameters
  771. *
  772. * @param None.
  773. *
  774. * @return hciStatus_t
  775. */
  776. extern hciStatus_t HCI_HostBufferSizeCmd( uint16 hostAclPktLen,
  777. uint8 hostSyncPktLen,
  778. uint16 hostTotalNumAclPkts,
  779. uint16 hostTotalNumSyncPkts );
  780. /*******************************************************************************
  781. * @fn HCI_HostNumCompletedPktCmd API
  782. *
  783. * @brief This BT API is used by the Host to notify the Controller of the
  784. * number of HCI data packets that have been completed for each
  785. * connection handle since this command was previously sent to the
  786. * controller.
  787. *
  788. * The Host_Number_Of_Conpleted_Packets command is a special
  789. * command. No event is normally generated after the command
  790. * has completed. The command should only be issued by the
  791. * Host if flow control in the direction from controller to
  792. * the host is on and there is at least one connection, or
  793. * if the controller is in local loopback mode.
  794. *
  795. * Note: It is assumed that there will be at most only one handle.
  796. * Even if more than one handle is provided, the Controller
  797. * does not track Host buffers as a function of connection
  798. * handles (and isn't required to do so).
  799. *
  800. * Related Events: HCI_CommandCompleteEvent
  801. *
  802. * input parameters
  803. *
  804. * @param numHandles - Number of connection handles.
  805. * @param connHandles - Array of connection handles.
  806. * @param numCompletedPkts - Array of number of completed packets.
  807. *
  808. * output parameters
  809. *
  810. * @param None.
  811. *
  812. * @return hciStatus_t
  813. */
  814. extern hciStatus_t HCI_HostNumCompletedPktCmd( uint8 numHandles,
  815. uint16 *connHandles,
  816. uint16 *numCompletedPkts );
  817. /*******************************************************************************
  818. * @fn HCI_ReadLocalVersionInfoCmd API
  819. *
  820. * @brief This BT API is used to read the local version information.
  821. *
  822. * Related Events: HCI_CommandCompleteEvent
  823. *
  824. * input parameters
  825. *
  826. * @param None.
  827. *
  828. * output parameters
  829. *
  830. * @param None.
  831. *
  832. * @return hciStatus_t
  833. */
  834. extern hciStatus_t HCI_ReadLocalVersionInfoCmd( void );
  835. /*******************************************************************************
  836. * @fn HCI_ReadLocalSupportedCommandsCmd API
  837. *
  838. * @brief This BT API is used to read the locally supported commands.
  839. *
  840. * Related Events: HCI_CommandCompleteEvent
  841. *
  842. * input parameters
  843. *
  844. * @param None.
  845. *
  846. * output parameters
  847. *
  848. * @param None.
  849. *
  850. * @return hciStatus_t
  851. */
  852. extern hciStatus_t HCI_ReadLocalSupportedCommandsCmd( void );
  853. /*******************************************************************************
  854. * @fn HCI_ReadLocalSupportedFeaturesCmd API
  855. *
  856. * @brief This BT API is used to read the locally supported features.
  857. *
  858. * Related Events: HCI_CommandCompleteEvent
  859. *
  860. * input parameters
  861. *
  862. * @param None.
  863. *
  864. * output parameters
  865. *
  866. * @param None.
  867. *
  868. * @return hciStatus_t
  869. */
  870. extern hciStatus_t HCI_ReadLocalSupportedFeaturesCmd( void );
  871. /*******************************************************************************
  872. * @fn HCI_ReadBDADDRCmd API
  873. *
  874. * @brief This BT API is used to read this device's BLE address (BDADDR).
  875. *
  876. * Related Events: HCI_CommandCompleteEvent
  877. *
  878. * input parameters
  879. *
  880. * @param None.
  881. *
  882. * output parameters
  883. *
  884. * @param None.
  885. *
  886. * @return hciStatus_t
  887. */
  888. extern hciStatus_t HCI_ReadBDADDRCmd( void );
  889. /*******************************************************************************
  890. * @fn HCI_ReadRssiCmd API
  891. *
  892. * @brief This BT API is used to read the RSSI of the last packet
  893. * received on a connection given by the connection handle. If
  894. * the Receiver Modem test is running (HCI_EXT_ModemTestRx), then
  895. * the RF RSSI for the last received data will be returned. If
  896. * there is no RSSI value, then HCI_RSSI_NOT_AVAILABLE will be
  897. * returned.
  898. *
  899. * Related Events: HCI_CommandCompleteEvent
  900. *
  901. * input parameters
  902. *
  903. * @param connHandle - Connection handle.
  904. *
  905. * output parameters
  906. *
  907. * @param None.
  908. *
  909. * @return hciStatus_t
  910. */
  911. extern hciStatus_t HCI_ReadRssiCmd( uint16 connHandle );
  912. /*
  913. ** HCI Low Energy Commands
  914. */
  915. /*******************************************************************************
  916. * @fn HCI_LE_SetEventMaskCmd API
  917. *
  918. * @brief This LE API is used to set the HCI LE event mask, which is used
  919. * to determine which LE events are supported.
  920. *
  921. * Related Events: HCI_CommandCompleteEvent
  922. *
  923. * input parameters
  924. *
  925. * @param pEventMask - Pointer to LE event mask of 8 bytes.
  926. *
  927. * output parameters
  928. *
  929. * @param None.
  930. *
  931. * @return hciStatus_t
  932. */
  933. extern hciStatus_t HCI_LE_SetEventMaskCmd( uint8 *pEventMask );
  934. /*******************************************************************************
  935. * @fn HCI_LE_ReadBufSizeCmd API
  936. *
  937. * @brief This LE API is used by the Host to determine the maximum ACL
  938. * data packet size allowed by the Controller.
  939. *
  940. * Related Events: HCI_CommandCompleteEvent
  941. *
  942. * input parameters
  943. *
  944. * @param None.
  945. *
  946. * output parameters
  947. *
  948. * @param None.
  949. *
  950. * @return hciStatus_t
  951. */
  952. extern hciStatus_t HCI_LE_ReadBufSizeCmd( void );
  953. /*******************************************************************************
  954. * @fn HCI_LE_ReadLocalSupportedFeaturesCmd API
  955. *
  956. * @brief This LE API is used to read the LE locally supported features.
  957. *
  958. * Related Events: HCI_CommandCompleteEvent
  959. *
  960. * input parameters
  961. *
  962. * @param None.
  963. *
  964. * output parameters
  965. *
  966. * @param None.
  967. *
  968. * @return hciStatus_t
  969. */
  970. extern hciStatus_t HCI_LE_ReadLocalSupportedFeaturesCmd( void );
  971. /*******************************************************************************
  972. * @fn HCI_LE_SetRandomAddressCmd API
  973. *
  974. * @brief This LE API is used to set this device's Random address.
  975. *
  976. * Related Events: HCI_CommandCompleteEvent
  977. *
  978. * input parameters
  979. *
  980. * @param pRandAddr - Pointer to random address.
  981. *
  982. * output parameters
  983. *
  984. * @param None.
  985. *
  986. * @return hciStatus_t
  987. */
  988. extern hciStatus_t HCI_LE_SetRandomAddressCmd( uint8 *pRandAddr );
  989. /*******************************************************************************
  990. * @fn HCI_LE_SetAdvParamCmd API
  991. *
  992. * @brief This LE API is used to set the Advertising parameters.
  993. *
  994. * Related Events: HCI_CommandCompleteEvent
  995. *
  996. * input parameters
  997. *
  998. * @param advIntervalMin - Minimum allowed advertising interval.
  999. * @param advIntervalMax - Maximum allowed advertising interval.
  1000. * @param advType - HCI_CONNECTABLE_UNDIRECTED_ADV,
  1001. * HCI_CONNECTABLE_DIRECTED_HDC_ADV,
  1002. * HCI_SCANNABLE_UNDIRECTED,
  1003. * HCI_NONCONNECTABLE_UNDIRECTED_ADV
  1004. * HCI_CONNECTABLE_DIRECTED_LDC_ADV
  1005. * @param ownAddrType - HCI_PUBLIC_DEVICE_ADDRESS,
  1006. * HCI_RANDOM_DEVICE_ADDRESS
  1007. * @param directAddrType - HCI_PUBLIC_DEVICE_ADDRESS,
  1008. * HCI_RANDOM_DEVICE_ADDRESS
  1009. * @param directAddr - Pointer to address of device when using
  1010. * directed advertising.
  1011. * @param advChannelMap - HCI_ADV_CHAN_37,
  1012. * HCI_ADV_CHAN_38,
  1013. * HCI_ADV_CHAN_39,
  1014. * HCI_ADV_CHAN_37 | HCI_ADV_CHAN_38,
  1015. * HCI_ADV_CHAN_37 | HCI_ADV_CHAN_39,
  1016. * HCI_ADV_CHAN_38 | HCI_ADV_CHAN_39,
  1017. * HCI_ADV_CHAN_ALL
  1018. * @param advFilterPolicy - HCI_ADV_WL_POLICY_ANY_REQ,
  1019. * HCI_ADV_WL_POLICY_WL_SCAN_REQ,
  1020. * HCI_ADV_WL_POLICY_WL_CONNECT_REQ,
  1021. * HCI_ADV_WL_POLICY_WL_ALL_REQ
  1022. *
  1023. * output parameters
  1024. *
  1025. * @param None.
  1026. *
  1027. * @return hciStatus_t
  1028. */
  1029. extern hciStatus_t HCI_LE_SetAdvParamCmd( uint16 advIntervalMin,
  1030. uint16 advIntervalMax,
  1031. uint8 advType,
  1032. uint8 ownAddrType,
  1033. uint8 directAddrType,
  1034. uint8 *directAddr,
  1035. uint8 advChannelMap,
  1036. uint8 advFilterPolicy );
  1037. /*******************************************************************************
  1038. * @fn HCI_LE_SetAdvDataCmd API
  1039. *
  1040. * @brief This LE API is used to set the Advertising data.
  1041. *
  1042. * Related Events: HCI_CommandCompleteEvent
  1043. *
  1044. * input parameters
  1045. *
  1046. * @param dataLen - Length of Advertising data.
  1047. * @param pData - Pointer to Advertising data.
  1048. *
  1049. * output parameters
  1050. *
  1051. * @param None.
  1052. *
  1053. * @return hciStatus_t
  1054. */
  1055. extern hciStatus_t HCI_LE_SetAdvDataCmd( uint8 dataLen,
  1056. uint8 *pData );
  1057. /*******************************************************************************
  1058. * @fn HCI_LE_SetScanRspDataCmd API
  1059. *
  1060. * @brief This LE API is used to set the Advertising Scan Response data.
  1061. *
  1062. * Related Events: HCI_CommandCompleteEvent
  1063. *
  1064. * input parameters
  1065. *
  1066. * @param dataLen - Length of Scan Response data.
  1067. * @param pData - Pointer to Scan Response data.
  1068. *
  1069. * output parameters
  1070. *
  1071. * @param None.
  1072. *
  1073. * @return hciStatus_t
  1074. */
  1075. extern hciStatus_t HCI_LE_SetScanRspDataCmd( uint8 dataLen,
  1076. uint8 *pData );
  1077. /*******************************************************************************
  1078. * @fn HCI_LE_SetAdvEnableCmd API
  1079. *
  1080. * @brief This LE API is used to turn Advertising on or off.
  1081. *
  1082. * Related Events: HCI_CommandCompleteEvent
  1083. *
  1084. * input parameters
  1085. *
  1086. * @param advEnable - HCI_ENABLE_ADV, HCI_DISABLE_ADV
  1087. *
  1088. * output parameters
  1089. *
  1090. * @param None.
  1091. *
  1092. * @return hciStatus_t
  1093. */
  1094. extern hciStatus_t HCI_LE_SetAdvEnableCmd( uint8 advEnable );
  1095. /*******************************************************************************
  1096. * @fn HCI_LE_ReadAdvChanTxPowerCmd API
  1097. *
  1098. * @brief This LE API is used to read transmit power when Advertising.
  1099. *
  1100. * Related Events: HCI_CommandCompleteEvent
  1101. *
  1102. * input parameters
  1103. *
  1104. * @param None.
  1105. *
  1106. * output parameters
  1107. *
  1108. * @param None.
  1109. *
  1110. * @return hciStatus_t
  1111. */
  1112. extern hciStatus_t HCI_LE_ReadAdvChanTxPowerCmd( void );
  1113. /*******************************************************************************
  1114. * @fn HCI_LE_SetScanParamCmd API
  1115. *
  1116. * @brief This LE API is used to set the Scan parameters.
  1117. *
  1118. * Related Events: HCI_CommandCompleteEvent
  1119. *
  1120. * input parameters
  1121. *
  1122. * @param scanType - HCI_SCAN_PASSIVE, HCI_SCAN_ACTIVE
  1123. * @param scanInterval - Time between scan events.
  1124. * @param scanWindow - Time of scan before scan event ends.
  1125. * Note: When the scanWindow equals the scanInterval
  1126. * then scanning is continuous.
  1127. * @param ownAddrType - This device's address.
  1128. * @param filterPolicy - HCI_SCAN_PASSIVE, HCI_SCAN_ACTIVE
  1129. *
  1130. * output parameters
  1131. *
  1132. * @param None.
  1133. *
  1134. * @return hciStatus_t
  1135. */
  1136. extern hciStatus_t HCI_LE_SetScanParamCmd( uint8 scanType,
  1137. uint16 scanInterval,
  1138. uint16 scanWindow,
  1139. uint8 ownAddrType,
  1140. uint8 filterPolicy );
  1141. /*******************************************************************************
  1142. * @fn HCI_LE_SetScanEnableCmd API
  1143. *
  1144. * @brief This LE API is used to turn Scanning on or off.
  1145. *
  1146. * Related Events: HCI_CommandCompleteEvent,
  1147. * AdvReportEvent
  1148. *
  1149. * input parameters
  1150. *
  1151. * @param scanEnable - HCI_SCAN_START, HCI_SCAN_STOP
  1152. * @param filterDuplicates - HCI_FILTER_REPORTS_ENABLE,
  1153. * HCI_FILTER_REPORTS_DISABLE
  1154. *
  1155. * output parameters
  1156. *
  1157. * @param None.
  1158. *
  1159. * @return hciStatus_t
  1160. */
  1161. extern hciStatus_t HCI_LE_SetScanEnableCmd( uint8 scanEnable,
  1162. uint8 filterDuplicates );
  1163. /*******************************************************************************
  1164. * @fn HCI_LE_CreateConnCmd API
  1165. *
  1166. * @brief This LE API is used to create a connection.
  1167. *
  1168. * Related Events: HCI_CommandStatusEvent,
  1169. * ConnectionCompleteEvent
  1170. *
  1171. * input parameters
  1172. *
  1173. * @param scanInterval - Time between Init scan events.
  1174. * @param scanWindow - Time of scan before Init scan event ends.
  1175. * Note: When the scanWindow equals the
  1176. * scanInterval then scanning is
  1177. * continuous.
  1178. * @param initFilterPolicy - HCI_INIT_WL_POLICY_USE_PEER_ADDR,
  1179. * HCI_INIT_WL_POLICY_USE_WHITE_LIST
  1180. * @param addrTypePeer - HCI_PUBLIC_DEVICE_ADDRESS,
  1181. * HCI_RANDOM_DEVICE_ADDRESS
  1182. * @param peerAddr - Pointer to peer device's address.
  1183. * @param ownAddrType - HCI_PUBLIC_DEVICE_ADDRESS,
  1184. * HCI_RANDOM_DEVICE_ADDRESS
  1185. * @param connIntervalMin - Minimum allowed connection interval.
  1186. * @param connIntervalMax - Maximum allowed connection interval.
  1187. * @param connLatency - Number of skipped events (slave latency).
  1188. * @param connTimeout - Connection supervision timeout.
  1189. * @param minLen - Info parameter about min length of conn.
  1190. * @param maxLen - Info parameter about max length of conn.
  1191. *
  1192. * output parameters
  1193. *
  1194. * @param None.
  1195. *
  1196. * @return hciStatus_t
  1197. */
  1198. extern hciStatus_t HCI_LE_CreateConnCmd( uint16 scanInterval,
  1199. uint16 scanWindow,
  1200. uint8 initFilterPolicy,
  1201. uint8 addrTypePeer,
  1202. uint8 *peerAddr,
  1203. uint8 ownAddrType,
  1204. uint16 connIntervalMin,
  1205. uint16 connIntervalMax,
  1206. uint16 connLatency,
  1207. uint16 connTimeout,
  1208. uint16 minLen,
  1209. uint16 maxLen );
  1210. /*******************************************************************************
  1211. * @fn HCI_LE_CreateConnCancelCmd API
  1212. *
  1213. * @brief This LE API is used to cancel a create connection.
  1214. *
  1215. * Related Events: HCI_CommandCompleteEvent
  1216. *
  1217. * input parameters
  1218. *
  1219. * @param None.
  1220. *
  1221. * output parameters
  1222. *
  1223. * @param None.
  1224. *
  1225. * @return hciStatus_t
  1226. */
  1227. extern hciStatus_t HCI_LE_CreateConnCancelCmd( void );
  1228. /*******************************************************************************
  1229. * @fn HCI_LE_ReadWhiteListSizeCmd API
  1230. *
  1231. * @brief This LE API is used to read the white list.
  1232. *
  1233. * Related Events: HCI_CommandCompleteEvent
  1234. *
  1235. * input parameters
  1236. *
  1237. * @param None.
  1238. *
  1239. * output parameters
  1240. *
  1241. * @param None.
  1242. *
  1243. * @return hciStatus_t
  1244. */
  1245. extern hciStatus_t HCI_LE_ReadWhiteListSizeCmd( void );
  1246. /*******************************************************************************
  1247. * @fn HCI_LE_ClearWhiteListCmd API
  1248. *
  1249. * @brief This LE API is used to clear the white list.
  1250. *
  1251. * Related Events: HCI_CommandCompleteEvent
  1252. *
  1253. * input parameters
  1254. *
  1255. * @param None.
  1256. *
  1257. * output parameters
  1258. *
  1259. * @param None.
  1260. *
  1261. * @return hciStatus_t
  1262. */
  1263. extern hciStatus_t HCI_LE_ClearWhiteListCmd( void );
  1264. /*******************************************************************************
  1265. * @fn HCI_LE_AddWhiteListCmd API
  1266. *
  1267. * @brief This LE API is used to add a white list entry.
  1268. *
  1269. * Related Events: HCI_CommandCompleteEvent
  1270. *
  1271. * input parameters
  1272. *
  1273. * @param addrType - HCI_PUBLIC_DEVICE_ADDRESS, HCI_RANDOM_DEVICE_ADDRESS
  1274. * @param devAddr - Pointer to address of device to put in white list.
  1275. *
  1276. * output parameters
  1277. *
  1278. * @param None.
  1279. *
  1280. * @return hciStatus_t
  1281. */
  1282. extern hciStatus_t HCI_LE_AddWhiteListCmd( uint8 addrType,
  1283. uint8 *devAddr );
  1284. /*******************************************************************************
  1285. * @fn HCI_LE_RemoveWhiteListCmd API
  1286. *
  1287. * @brief This LE API is used to remove a white list entry.
  1288. *
  1289. * Related Events: HCI_CommandCompleteEvent
  1290. *
  1291. * input parameters
  1292. *
  1293. * @param addrType - HCI_PUBLIC_DEVICE_ADDRESS, HCI_RANDOM_DEVICE_ADDRESS
  1294. * @param devAddr - Pointer to address of device to remove from the
  1295. * white list.
  1296. *
  1297. * output parameters
  1298. *
  1299. * @param None.
  1300. *
  1301. * @return hciStatus_t
  1302. */
  1303. extern hciStatus_t HCI_LE_RemoveWhiteListCmd( uint8 addrType,
  1304. uint8 *devAddr );
  1305. /*******************************************************************************
  1306. * @fn HCI_LE_ConnUpdateCmd API
  1307. *
  1308. * @brief This LE API is used to update the connection parameters.
  1309. *
  1310. * Related Events: HCI_CommandStatusEvent,
  1311. * ConnectionUpdateCompleteEvent
  1312. *
  1313. * input parameters
  1314. *
  1315. * @param connHandle - Time between Init scan events.
  1316. * @param connIntervalMin - Minimum allowed connection interval.
  1317. * @param connIntervalMax - Maximum allowed connection interval.
  1318. * @param connLatency - Number of skipped events (slave latency).
  1319. * @param connTimeout - Connection supervision timeout.
  1320. * @param minLen - Info parameter about min length of conn.
  1321. * @param maxLen - Info parameter about max length of conn.
  1322. *
  1323. * output parameters
  1324. *
  1325. * @param None.
  1326. *
  1327. * @return hciStatus_t
  1328. */
  1329. extern hciStatus_t HCI_LE_ConnUpdateCmd( uint16 connHandle,
  1330. uint16 connIntervalMin,
  1331. uint16 connIntervalMax,
  1332. uint16 connLatency,
  1333. uint16 connTimeout,
  1334. uint16 minLen,
  1335. uint16 maxLen );
  1336. /*******************************************************************************
  1337. * @fn HCI_LE_SetHostChanClassificationCmd API
  1338. *
  1339. * @brief This LE API is used to update the current data channel map.
  1340. *
  1341. * Related Events: HCI_CommandCompleteEvent
  1342. *
  1343. * input parameters
  1344. *
  1345. * @param chanMap - Pointer to the new channel map.
  1346. *
  1347. * output parameters
  1348. *
  1349. * @param None.
  1350. *
  1351. * @return hciStatus_t
  1352. */
  1353. extern hciStatus_t HCI_LE_SetHostChanClassificationCmd( uint8 *chanMap );
  1354. /*******************************************************************************
  1355. * @fn HCI_LE_ReadChannelMapCmd API
  1356. *
  1357. * @brief This LE API is used to read a connection's data channel map.
  1358. *
  1359. * Related Events: HCI_CommandCompleteEvent
  1360. *
  1361. * input parameters
  1362. *
  1363. * @param connHandle - Connection handle.
  1364. *
  1365. * output parameters
  1366. *
  1367. * @param None.
  1368. *
  1369. * @return hciStatus_t
  1370. */
  1371. extern hciStatus_t HCI_LE_ReadChannelMapCmd( uint16 connHandle );
  1372. /*******************************************************************************
  1373. * @fn HCI_LE_ReadRemoteUsedFeaturesCmd API
  1374. *
  1375. * @brief This LE API is used to read the remote device's used features.
  1376. *
  1377. * Related Events: HCI_CommandStatusEvent,
  1378. * ReadRemoteUsedFeaturesCompleteEvent
  1379. *
  1380. * input parameters
  1381. *
  1382. * @param connHandle - Connection handle.
  1383. *
  1384. * output parameters
  1385. *
  1386. * @param None.
  1387. *
  1388. * @return hciStatus_t
  1389. */
  1390. extern hciStatus_t HCI_LE_ReadRemoteUsedFeaturesCmd( uint16 connHandle );
  1391. /*******************************************************************************
  1392. * @fn HCI_LE_EncryptCmd API
  1393. *
  1394. * @brief This LE API is used to perform an encryption using AES128.
  1395. *
  1396. * Note: Input parameters are ordered MSB..LSB.
  1397. *
  1398. * Related Events: HCI_CommandCompleteEvent
  1399. *
  1400. * input parameters
  1401. *
  1402. * @param key - Pointer to 16 byte encryption key.
  1403. * @param plainText - Pointer to 16 byte plaintext data.
  1404. *
  1405. * output parameters
  1406. *
  1407. * @param None.
  1408. *
  1409. * @return hciStatus_t
  1410. */
  1411. extern hciStatus_t HCI_LE_EncryptCmd( uint8 *key,
  1412. uint8 *plainText );
  1413. /*******************************************************************************
  1414. * @fn HCI_LE_RandCmd API
  1415. *
  1416. * @brief This LE API is used to generate a random number.
  1417. *
  1418. * Related Events: HCI_CommandCompleteEvent
  1419. *
  1420. * input parameters
  1421. *
  1422. * @param None.
  1423. *
  1424. * output parameters
  1425. *
  1426. * @param None.
  1427. *
  1428. * @return hciStatus_t
  1429. */
  1430. extern hciStatus_t HCI_LE_RandCmd( void );
  1431. /*******************************************************************************
  1432. * @fn HCI_LE_StartEncyptCmd API
  1433. *
  1434. * @brief This LE API is used to start encryption in a connection.
  1435. *
  1436. * Related Events: HCI_CommandStatusEvent,
  1437. * EncChangeEvent or
  1438. * EncKeyRefreshEvent
  1439. *
  1440. * input parameters
  1441. *
  1442. * @param connHandle - Connection handle.
  1443. * @param random - Pointer to eight byte Random number.
  1444. * @param encDiv - Pointer to two byte Encrypted Diversifier.
  1445. * @param ltk - Pointer to 16 byte Long Term Key.
  1446. *
  1447. * output parameters
  1448. *
  1449. * @param None.
  1450. *
  1451. * @return hciStatus_t
  1452. */
  1453. extern hciStatus_t HCI_LE_StartEncyptCmd( uint16 connHandle,
  1454. uint8 *random,
  1455. uint8 *encDiv,
  1456. uint8 *ltk );
  1457. /*******************************************************************************
  1458. * @fn HCI_LE_LtkReqReplyCmd API
  1459. *
  1460. * @brief This LE API is used by the Host to send to the Controller a
  1461. * positive LTK reply.
  1462. *
  1463. * Related Events: HCI_CommandCompleteEvent
  1464. *
  1465. * input parameters
  1466. *
  1467. * @param connHandle - Connection handle.
  1468. * @param ltk - Pointer to 16 byte Long Term Key.
  1469. *
  1470. * output parameters
  1471. *
  1472. * @param None.
  1473. *
  1474. * @return hciStatus_t
  1475. */
  1476. extern hciStatus_t HCI_LE_LtkReqReplyCmd( uint16 connHandle,
  1477. uint8 *ltk );
  1478. /*******************************************************************************
  1479. * @fn HCI_LE_LtkReqNegReplyCmd API
  1480. *
  1481. * @brief This LE API is used by the Host to send to the Controller a
  1482. * negative LTK reply.
  1483. *
  1484. * Related Events: HCI_CommandCompleteEvent
  1485. *
  1486. * input parameters
  1487. *
  1488. * @param connHandle - Connectin handle.
  1489. *
  1490. * output parameters
  1491. *
  1492. * @param None.
  1493. *
  1494. * @return hciStatus_t
  1495. */
  1496. extern hciStatus_t HCI_LE_LtkReqNegReplyCmd( uint16 connHandle );
  1497. /*******************************************************************************
  1498. * @fn HCI_LE_ReadSupportedStatesCmd API
  1499. *
  1500. * @brief This LE API is used to read the Controller's supported states.
  1501. *
  1502. * Related Events: HCI_CommandCompleteEvent
  1503. *
  1504. * input parameters
  1505. *
  1506. * @param None.
  1507. *
  1508. * output parameters
  1509. *
  1510. * @param None.
  1511. *
  1512. * @return hciStatus_t
  1513. */
  1514. extern hciStatus_t HCI_LE_ReadSupportedStatesCmd( void );
  1515. /*******************************************************************************
  1516. * @fn HCI_LE_ReceiverTestCmd API
  1517. *
  1518. * @brief This LE API is used to start the receiver Direct Test Mode test.
  1519. *
  1520. * Note: A HCI reset should be issued when done using DTM!
  1521. *
  1522. * Related Events: HCI_CommandCompleteEvent
  1523. *
  1524. * input parameters
  1525. *
  1526. * @param rxFreq - Rx RF frequency:
  1527. * k=0..HCI_DTM_NUMBER_RF_CHANS-1, where: F=2402+(k*2MHz)
  1528. *
  1529. * output parameters
  1530. *
  1531. * @param None.
  1532. *
  1533. * @return hciStatus_t
  1534. */
  1535. extern hciStatus_t HCI_LE_ReceiverTestCmd( uint8 rxFreq );
  1536. /*******************************************************************************
  1537. * @fn HCI_LE_TransmitterTestCmd API
  1538. *
  1539. * @brief This LE API is used to start the transmit Direct Test Mode test.
  1540. *
  1541. * Note: The BLE device is to transmit at maximum power!
  1542. *
  1543. * Note: A HCI reset should be issued when done using DTM!
  1544. *
  1545. * input parameters
  1546. *
  1547. * @param txFreq - Tx RF frequency:
  1548. * k=0..HCI_DTM_NUMBER_RF_CHANS-1, where:
  1549. * F=2402+(k*2MHz)
  1550. * @param dataLen - Test data length in bytes:
  1551. * 0..HCI_DIRECT_TEST_MAX_PAYLOAD_LEN
  1552. * @param payloadType - Type of packet payload, per Direct Test Mode spec:
  1553. * HCI_DIRECT_TEST_PAYLOAD_PRBS9,
  1554. * HCI_DIRECT_TEST_PAYLOAD_0x0F,
  1555. * HCI_DIRECT_TEST_PAYLOAD_0x55,
  1556. * HCI_DIRECT_TEST_PAYLOAD_PRBS15,
  1557. * HCI_DIRECT_TEST_PAYLOAD_0xFF,
  1558. * HCI_DIRECT_TEST_PAYLOAD_0x00,
  1559. * HCI_DIRECT_TEST_PAYLOAD_0xF0,
  1560. * HCI_DIRECT_TEST_PAYLOAD_0xAA
  1561. *
  1562. * output parameters
  1563. *
  1564. * @param None.
  1565. *
  1566. * @return hciStatus_t
  1567. */
  1568. extern hciStatus_t HCI_LE_TransmitterTestCmd( uint8 txFreq,
  1569. uint8 dataLen,
  1570. uint8 pktPayload );
  1571. /*******************************************************************************
  1572. * @fn HCI_LE_TestEndCmd API
  1573. *
  1574. * @brief This LE API is used to end the Direct Test Mode test.
  1575. *
  1576. * Note: A HCI reset should be issued when done using DTM!
  1577. *
  1578. * Related Events: HCI_CommandCompleteEvent
  1579. *
  1580. * input parameters
  1581. *
  1582. * @param None.
  1583. *
  1584. * output parameters
  1585. *
  1586. * @param None.
  1587. *
  1588. * @return hciStatus_t
  1589. */
  1590. extern hciStatus_t HCI_LE_TestEndCmd( void );
  1591. /*
  1592. ** HCI Vendor Specific Comamnds: Link Layer Extensions
  1593. */
  1594. /*******************************************************************************
  1595. * @fn HCI_EXT_SetRxGainCmd API
  1596. *
  1597. * @brief This HCI Extension API is used to set the receiver gain.
  1598. *
  1599. * Related Events: HCI_VendorSpecifcCommandCompleteEvent
  1600. *
  1601. * input parameters
  1602. *
  1603. * @param rxGain - HCI_EXT_RX_GAIN_STD, HCI_EXT_RX_GAIN_HIGH
  1604. *
  1605. * output parameters
  1606. *
  1607. * @param None.
  1608. *
  1609. * @return hciStatus_t
  1610. */
  1611. extern hciStatus_t HCI_EXT_SetRxGainCmd( uint8 rxGain );
  1612. /*******************************************************************************
  1613. * @fn HCI_EXT_SetTxPowerCmd API
  1614. *
  1615. * @brief This HCI Extension API is used to set the transmit power.
  1616. *
  1617. * Related Events: HCI_VendorSpecifcCommandCompleteEvent
  1618. *
  1619. * input parameters
  1620. *
  1621. * @param txPower - LL_EXT_TX_POWER_MINUS_23_DBM,
  1622. * LL_EXT_TX_POWER_MINUS_6_DBM,
  1623. * LL_EXT_TX_POWER_0_DBM,
  1624. * LL_EXT_TX_POWER_4_DBM
  1625. *
  1626. * output parameters
  1627. *
  1628. * @param None.
  1629. *
  1630. * @return hciStatus_t
  1631. */
  1632. extern hciStatus_t HCI_EXT_SetTxPowerCmd( uint8 txPower );
  1633. /*******************************************************************************
  1634. * @fn HCI_EXT_OnePktPerEvtCmd API
  1635. *
  1636. * @brief This HCI Extension API is used to set whether a connection will
  1637. * be limited to one packet per event.
  1638. *
  1639. * Related Events: HCI_VendorSpecifcCommandCompleteEvent
  1640. *
  1641. * input parameters
  1642. *
  1643. * @param control - HCI_EXT_ENABLE_ONE_PKT_PER_EVT,
  1644. * HCI_EXT_DISABLE_ONE_PKT_PER_EVT
  1645. *
  1646. * output parameters
  1647. *
  1648. * @param None.
  1649. *
  1650. * @return hciStatus_t
  1651. */
  1652. extern hciStatus_t HCI_EXT_OnePktPerEvtCmd( uint8 control );
  1653. /*******************************************************************************
  1654. * @fn HCI_EXT_ClkDivOnHaltCmd API
  1655. *
  1656. * @brief This HCI Extension API is used to set whether the system clock
  1657. * will be divided when the MCU is halted.
  1658. *
  1659. * Related Events: HCI_VendorSpecifcCommandCompleteEvent
  1660. *
  1661. * input parameters
  1662. *
  1663. * @param control - HCI_EXT_ENABLE_CLK_DIVIDE_ON_HALT,
  1664. * HCI_EXT_DISABLE_CLK_DIVIDE_ON_HALT
  1665. *
  1666. * output parameters
  1667. *
  1668. * @param None.
  1669. *
  1670. * @return hciStatus_t
  1671. */
  1672. extern hciStatus_t HCI_EXT_ClkDivOnHaltCmd( uint8 control );
  1673. /*******************************************************************************
  1674. * @fn HCI_EXT_DeclareNvUsageCmd API
  1675. *
  1676. * @brief This HCI Extension API is used to indicate to the Controller
  1677. * whether or not the Host will be using the NV memory during BLE
  1678. * operations.
  1679. *
  1680. * Related Events: HCI_VendorSpecifcCommandCompleteEvent
  1681. *
  1682. * input parameters
  1683. *
  1684. * @param mode - HCI_EXT_NV_IN_USE, HCI_EXT_NV_NOT_IN_USE
  1685. *
  1686. * output parameters
  1687. *
  1688. * @param None.
  1689. *
  1690. * @return hciStatus_t
  1691. */
  1692. extern hciStatus_t HCI_EXT_DeclareNvUsageCmd( uint8 mode );
  1693. /*******************************************************************************
  1694. * @fn HCI_EXT_DecryptCmd API
  1695. *
  1696. * @brief This HCI Extension API is used to decrypt encrypted data using
  1697. * AES128.
  1698. *
  1699. * Related Events: HCI_VendorSpecifcCommandCompleteEvent
  1700. *
  1701. * input parameters
  1702. *
  1703. * @param key - Pointer to 16 byte encryption key.
  1704. * @param encText - Pointer to 16 byte encrypted data.
  1705. *
  1706. * output parameters
  1707. *
  1708. * @param None.
  1709. *
  1710. * @return hciStatus_t
  1711. */
  1712. extern hciStatus_t HCI_EXT_DecryptCmd( uint8 *key,
  1713. uint8 *encText );
  1714. /*******************************************************************************
  1715. * @fn HCI_EXT_SetLocalSupportedFeaturesCmd API
  1716. *
  1717. * @brief This HCI Extension API is used to write this devie's supported
  1718. * features.
  1719. *
  1720. * Related Events: HCI_VendorSpecifcCommandCompleteEvent
  1721. *
  1722. * input parameters
  1723. *
  1724. * @param localFeatures - Pointer to eight bytes of local features.
  1725. *
  1726. * output parameters
  1727. *
  1728. * @param None.
  1729. *
  1730. * @return hciStatus_t
  1731. */
  1732. extern hciStatus_t HCI_EXT_SetLocalSupportedFeaturesCmd( uint8 *localFeatures );
  1733. /*******************************************************************************
  1734. * @fn HCI_EXT_SetFastTxResponseTimeCmd API
  1735. *
  1736. * @brief This HCI Extension API is used to set whether transmit data is
  1737. * sent as soon as possible even when slave latency is used.
  1738. *
  1739. * Related Events: HCI_VendorSpecifcCommandCompleteEvent
  1740. *
  1741. * input parameters
  1742. *
  1743. * @param control - HCI_EXT_ENABLE_FAST_TX_RESP_TIME,
  1744. * HCI_EXT_DISABLE_FAST_TX_RESP_TIME
  1745. *
  1746. * output parameters
  1747. *
  1748. * @param None.
  1749. *
  1750. * @return hciStatus_t
  1751. */
  1752. extern hciStatus_t HCI_EXT_SetFastTxResponseTimeCmd( uint8 control );
  1753. /*******************************************************************************
  1754. * @fn HCI_EXT_SetSlaveLatencyOverrideCmd API
  1755. *
  1756. * @brief This HCI Extension API is used to to enable or disable
  1757. * suspending slave latency.
  1758. *
  1759. * Related Events: HCI_VendorSpecifcCommandCompleteEvent
  1760. *
  1761. * input parameters
  1762. *
  1763. * @param control - HCI_EXT_ENABLE_SL_OVERRIDE,
  1764. * HCI_EXT_DISABLE_SL_OVERRIDE
  1765. *
  1766. * output parameters
  1767. *
  1768. * @param None.
  1769. *
  1770. * @return hciStatus_t
  1771. */
  1772. extern hciStatus_t HCI_EXT_SetSlaveLatencyOverrideCmd( uint8 control );
  1773. /*******************************************************************************
  1774. * @fn HCI_EXT_ModemTestTxCmd
  1775. *
  1776. * @brief This API is used start a continuous transmitter modem test,
  1777. * using either a modulated or unmodulated carrier wave tone, at
  1778. * the frequency that corresponds to the specified RF channel. Use
  1779. * HCI_EXT_EndModemTest command to end the test.
  1780. *
  1781. * Note: A Controller reset will be issued by HCI_EXT_EndModemTest!
  1782. * Note: The BLE device will transmit at maximum power.
  1783. * Note: This API can be used to verify this device meets Japan's
  1784. * TELEC regulations.
  1785. *
  1786. * Related Events: HCI_VendorSpecifcCommandCompleteEvent
  1787. *
  1788. * input parameters
  1789. *
  1790. * @param cwMode - HCI_EXT_TX_MODULATED_CARRIER,
  1791. * HCI_EXT_TX_UNMODULATED_CARRIER
  1792. * txFreq - Transmit RF channel k=0..39, where BLE F=2402+(k*2MHz).
  1793. *
  1794. * output parameters
  1795. *
  1796. * @param None.
  1797. *
  1798. * @return hciStatus_t
  1799. */
  1800. extern hciStatus_t HCI_EXT_ModemTestTxCmd( uint8 cwMode,
  1801. uint8 txFreq );
  1802. /*******************************************************************************
  1803. * @fn HCI_EXT_ModemHopTestTxCmd
  1804. *
  1805. * @brief This API is used to start a continuous transmitter direct test
  1806. * mode test using a modulated carrier wave and transmitting a
  1807. * 37 byte packet of Pseudo-Random 9-bit data. A packet is
  1808. * transmitted on a different frequency (linearly stepping through
  1809. * all RF channels 0..39) every 625us. Use HCI_EXT_EndModemTest
  1810. * command to end the test.
  1811. *
  1812. * Note: A Controller reset will be issued by HCI_EXT_EndModemTest!
  1813. * Note: The BLE device will transmit at maximum power.
  1814. * Note: This API can be used to verify this device meets Japan's
  1815. * TELEC regulations.
  1816. *
  1817. * input parameters
  1818. *
  1819. * @param None.
  1820. *
  1821. * output parameters
  1822. *
  1823. * @param None.
  1824. *
  1825. * @return hciStatus_t
  1826. */
  1827. extern hciStatus_t HCI_EXT_ModemHopTestTxCmd( void );
  1828. /*******************************************************************************
  1829. * @fn HCI_EXT_ModemTestRxCmd
  1830. *
  1831. * @brief This API is used to start a continuous receiver modem test
  1832. * using a modulated carrier wave tone, at the frequency that
  1833. * corresponds to the specific RF channel. Any received data is
  1834. * discarded. Receiver gain may be adjusted using the
  1835. * HCI_EXT_SetRxGain command. RSSI may be read during this test
  1836. * by using the HCI_ReadRssi command. Use HCI_EXT_EndModemTest
  1837. * command to end the test.
  1838. *
  1839. * Note: A Controller reset will be issued by HCI_EXT_EndModemTest!
  1840. * Note: The BLE device will transmit at maximum power.
  1841. *
  1842. * input parameters
  1843. *
  1844. * @param rxFreq - Receiver RF channel k=0..39, where BLE F=2402+(k*2MHz).
  1845. *
  1846. * output parameters
  1847. *
  1848. * @param None.
  1849. *
  1850. * @return hciStatus_t
  1851. */
  1852. extern hciStatus_t HCI_EXT_ModemTestRxCmd( uint8 rxFreq );
  1853. /*******************************************************************************
  1854. * @fn HCI_EXT_EndModemTestCmd
  1855. *
  1856. * @brief This API is used to shutdown a modem test. A complete Controller
  1857. * reset will take place.
  1858. *
  1859. * input parameters
  1860. *
  1861. * @param None.
  1862. *
  1863. * output parameters
  1864. *
  1865. * @param None.
  1866. *
  1867. * @return hciStatus_t
  1868. */
  1869. extern hciStatus_t HCI_EXT_EndModemTestCmd( void );
  1870. /*******************************************************************************
  1871. * @fn HCI_EXT_SetBDADDRCmd
  1872. *
  1873. * @brief This API is used to set this device's BLE address (BDADDR).
  1874. *
  1875. * Note: This command is only allowed when the device's state is
  1876. * Standby.
  1877. *
  1878. * Related Events: HCI_VendorSpecifcCommandCompleteEvent
  1879. *
  1880. * input parameters
  1881. *
  1882. * @param bdAddr - A pointer to a buffer to hold this device's address.
  1883. * An invalid address (i.e. all FF's) will restore this
  1884. * device's address to the address set at initialization.
  1885. *
  1886. * output parameters
  1887. *
  1888. * @param None.
  1889. *
  1890. * @return hciStatus_t
  1891. */
  1892. extern hciStatus_t HCI_EXT_SetBDADDRCmd( uint8 *bdAddr );
  1893. /*******************************************************************************
  1894. * @fn HCI_EXT_SetSCACmd
  1895. *
  1896. * @brief This API is used to set this device's Sleep Clock Accuracy.
  1897. *
  1898. * Note: For a slave device, this value is directly used, but only
  1899. * if power management is enabled. For a master device, this
  1900. * value is converted into one of eight ordinal values
  1901. * representing a SCA range, as specified in Table 2.2,
  1902. * Vol. 6, Part B, Section 2.3.3.1 of the Core specification.
  1903. *
  1904. * Note: This command is only allowed when the device is not in a
  1905. * connection.
  1906. *
  1907. * Note: The device's SCA value remains unaffected by a HCI_Reset.
  1908. *
  1909. * input parameters
  1910. *
  1911. * @param scaInPPM - A SCA value in PPM from 0..500.
  1912. *
  1913. * output parameters
  1914. *
  1915. * @param None.
  1916. *
  1917. * @return hciStatus_t
  1918. */
  1919. extern hciStatus_t HCI_EXT_SetSCACmd( uint16 scaInPPM );
  1920. /*******************************************************************************
  1921. * @fn HCI_EXT_EnablePTMCmd
  1922. *
  1923. * @brief This HCI Extension API is used to enable Production Test Mode.
  1924. *
  1925. * Note: This function can only be directly called from the
  1926. * application and is not available via an external transport
  1927. * interface such as RS232. Also, no vendor specific
  1928. * command complete will be returned.
  1929. *
  1930. * input parameters
  1931. *
  1932. * @param None.
  1933. *
  1934. * output parameters
  1935. *
  1936. * @param None.
  1937. *
  1938. * @return hciStatus_t
  1939. */
  1940. extern hciStatus_t HCI_EXT_EnablePTMCmd( void );
  1941. /*******************************************************************************
  1942. * @fn HCI_EXT_SetFreqTuneCmd
  1943. *
  1944. * @brief This HCI Extension API is used to set the frequency tuning up
  1945. * or down. Setting the mode up/down decreases/increases the amount
  1946. * of capacitance on the external crystal oscillator.
  1947. *
  1948. * Note: This is a Production Test Mode only command!
  1949. *
  1950. * input parameters
  1951. *
  1952. * @param step - HCI_PTM_SET_FREQ_TUNE_UP, HCI_PTM_SET_FREQ_TUNE_DOWN
  1953. *
  1954. * output parameters
  1955. *
  1956. * @param None.
  1957. *
  1958. * @return hciStatus_t
  1959. */
  1960. extern hciStatus_t HCI_EXT_SetFreqTuneCmd( uint8 step );
  1961. /*******************************************************************************
  1962. * @fn HCI_EXT_SaveFreqTuneCmd
  1963. *
  1964. * @brief This HCI Extension API is used to save the frequency tuning
  1965. * value to flash.
  1966. *
  1967. * Note: This is a Production Test Mode only command!
  1968. *
  1969. * input parameters
  1970. *
  1971. * @param None.
  1972. *
  1973. * output parameters
  1974. *
  1975. * @param None.
  1976. *
  1977. * @return hciStatus_t
  1978. */
  1979. extern hciStatus_t HCI_EXT_SaveFreqTuneCmd( void );
  1980. /*******************************************************************************
  1981. * @fn HCI_EXT_SetMaxDtmTxPowerCmd API
  1982. *
  1983. * @brief This HCI Extension API is used to set the maximum transmit
  1984. * output power for Direct Test Mode.
  1985. *
  1986. * Related Events: HCI_VendorSpecifcCommandCompleteEvent
  1987. *
  1988. * input parameters
  1989. *
  1990. * @param txPower - LL_EXT_TX_POWER_MINUS_23_DBM,
  1991. * LL_EXT_TX_POWER_MINUS_6_DBM,
  1992. * LL_EXT_TX_POWER_0_DBM,
  1993. * LL_EXT_TX_POWER_4_DBM
  1994. *
  1995. * output parameters
  1996. *
  1997. * @param None.
  1998. *
  1999. * @return hciStatus_t
  2000. */
  2001. extern hciStatus_t HCI_EXT_SetMaxDtmTxPowerCmd( uint8 txPower );
  2002. /*******************************************************************************
  2003. */
  2004. extern llStatus_t HCI_EXT_MapPmIoPortCmd( uint8 ioPort, uint8 ioPin );
  2005. /*******************************************************************************
  2006. * @fn HCI_EXT_DisconnectImmedCmd API
  2007. *
  2008. * @brief This HCI Extension API is used to disconnect the connection
  2009. * immediately.
  2010. *
  2011. * Note: The connection (if valid) is immediately terminated
  2012. * without notifying the remote device. The Host is still
  2013. * notified.
  2014. *
  2015. * input parameters
  2016. *
  2017. * @param connHandle - Connection handle.
  2018. *
  2019. * output parameters
  2020. *
  2021. * @param None.
  2022. *
  2023. * @return hciStatus_t
  2024. */
  2025. extern hciStatus_t HCI_EXT_DisconnectImmedCmd( uint16 connHandle );
  2026. /*******************************************************************************
  2027. * @fn HCI_EXT_PacketErrorRate Vendor Specific API
  2028. *
  2029. * @brief This function is used to Reset or Read the Packet Error Rate
  2030. * counters for a connection.
  2031. *
  2032. * Note: The counters are only 16 bits. At the shortest connection
  2033. * interval, this provides a bit over 8 minutes of data.
  2034. *
  2035. * input parameters
  2036. *
  2037. * @param connHandle - The LL connection ID on which to send this data.
  2038. * @param command - HCI_EXT_PER_RESET, HCI_EXT_PER_READ
  2039. *
  2040. * output parameters
  2041. *
  2042. * @param None.
  2043. *
  2044. * @return hciStatus_t
  2045. */
  2046. extern hciStatus_t HCI_EXT_PacketErrorRateCmd( uint16 connHandle, uint8 command );
  2047. /*******************************************************************************
  2048. * @fn HCI_EXT_PERbyChanCmd Vendor Specific API
  2049. *
  2050. * @brief This HCI Extension API is used to start or end Packet Error Rate
  2051. * by Channel counter accumulation for a connection. If the
  2052. * pointer is not NULL, it is assumed there is sufficient memory
  2053. * for the PER data, per the type perByChan_t. If NULL, then
  2054. * the operation is considered disabled.
  2055. *
  2056. * Note: It is the user's responsibility to make sure there is
  2057. * sufficient memory for the data, and that the counters
  2058. * are cleared prior to first use.
  2059. *
  2060. * Note: The counters are only 16 bits. At the shortest connection
  2061. * interval, this provides a bit over 8 minutes of data.
  2062. *
  2063. * input parameters
  2064. *
  2065. * @param connHandle - The LL connection ID on which to send this data.
  2066. * @param perByChan - Pointer to PER by Channel data, or NULL.
  2067. *
  2068. * output parameters
  2069. *
  2070. * @param None.
  2071. *
  2072. * @return hciStatus_t
  2073. */
  2074. extern hciStatus_t HCI_EXT_PERbyChanCmd( uint16 connHandle, perByChan_t *perByChan );
  2075. /*******************************************************************************
  2076. */
  2077. extern hciStatus_t HCI_EXT_ExtendRfRangeCmd( void );
  2078. /*******************************************************************************
  2079. * @fn HCI_EXT_HaltDuringRfCmd API
  2080. *
  2081. * @brief This HCI Extension API is used to enable or disable halting the
  2082. * CPU during RF. The system defaults to enabled.
  2083. *
  2084. * Related Events: HCI_VendorSpecifcCommandCompleteEvent
  2085. *
  2086. * input parameters
  2087. *
  2088. * @param mode - HCI_EXT_HALT_DURING_RF_ENABLE,
  2089. * HCI_EXT_HALT_DURING_RF_DISABLE
  2090. *
  2091. * output parameters
  2092. *
  2093. * @param None.
  2094. *
  2095. * @return hciStatus_t
  2096. */
  2097. extern hciStatus_t HCI_EXT_HaltDuringRfCmd( uint8 mode );
  2098. /*******************************************************************************
  2099. * @fn HCI_EXT_AdvEventNoticeCmd Vendor Specific API
  2100. *
  2101. * @brief This HCI Extension API is used to enable or disable a
  2102. * notification to the specified task using the specified task
  2103. * event whenever a Adv event ends. A non-zero taskEvent value is
  2104. * taken to be "enable", while a zero valued taskEvent is taken
  2105. * to be "disable".
  2106. *
  2107. * input parameters
  2108. *
  2109. * @param taskID - User's task ID.
  2110. * @param taskEvent - User's task event.
  2111. *
  2112. * output parameters
  2113. *
  2114. * @param None.
  2115. *
  2116. * @return hciStatus_t
  2117. */
  2118. extern hciStatus_t HCI_EXT_AdvEventNoticeCmd( uint8 taskID, uint16 taskEvent );
  2119. /*******************************************************************************
  2120. * @fn HCI_EXT_ConnEventNoticeCmd Vendor Specific API
  2121. *
  2122. * @brief This HCI Extension API is used to enable or disable a
  2123. * notification to the specified task using the specified task
  2124. * event whenever a Connection event ends. A non-zero taskEvent
  2125. * value is taken to be "enable", while a zero valued taskEvent
  2126. * taken to be "disable".
  2127. *
  2128. * Note: Currently, only a Slave connection is supported.
  2129. *
  2130. * input parameters
  2131. *
  2132. * @param taskID - User's task ID.
  2133. * @param taskEvent - User's task event.
  2134. *
  2135. * output parameters
  2136. *
  2137. * @param None.
  2138. *
  2139. * @return hciStatus_t
  2140. */
  2141. extern hciStatus_t HCI_EXT_ConnEventNoticeCmd( uint8 taskID, uint16 taskEvent );
  2142. /*******************************************************************************
  2143. * @fn HCI_EXT_BuildRevisionCmd Vendor Specific API
  2144. *
  2145. * @brief This HCI Extension API is used set a user revision number or
  2146. * read the build revision number.
  2147. *
  2148. * input parameters
  2149. *
  2150. * @param mode - HCI_EXT_SET_USER_REVISION | HCI_EXT_READ_BUILD_REVISION
  2151. *
  2152. * output parameters
  2153. *
  2154. * @param None.
  2155. *
  2156. * @return hciStatus_t
  2157. */
  2158. extern hciStatus_t HCI_EXT_BuildRevisionCmd( uint8 mode, uint16 userRevNum );
  2159. /*******************************************************************************
  2160. * @fn HCI_EXT_DelaySleepCmd Vendor Specific API
  2161. *
  2162. * @brief This HCI Extension API is used set the sleep delay.
  2163. *
  2164. * input parameters
  2165. *
  2166. * @param delay - 0..1000, in milliseconds.
  2167. *
  2168. * output parameters
  2169. *
  2170. * @param None.
  2171. *
  2172. * @return hciStatus_t
  2173. */
  2174. extern hciStatus_t HCI_EXT_DelaySleepCmd( uint16 delay );
  2175. /*******************************************************************************
  2176. * @fn HCI_EXT_ResetSystemCmd Vendor Specific API
  2177. *
  2178. * @brief This HCI Extension API is used to issue a soft or hard
  2179. * system reset.
  2180. *
  2181. * input parameters
  2182. *
  2183. * @param mode - HCI_EXT_RESET_SYSTEM_HARD | HCI_EXT_RESET_SYSTEM_SOFT
  2184. *
  2185. * output parameters
  2186. *
  2187. * @param None.
  2188. *
  2189. * @return hciStatus_t
  2190. */
  2191. extern hciStatus_t HCI_EXT_ResetSystemCmd( uint8 mode );
  2192. /*******************************************************************************
  2193. * @fn HCI_EXT_OverlappedProcessingCmd Vendor Specific API
  2194. *
  2195. * @brief This HCI Extension API is used to enable or disable overlapped
  2196. * processing.
  2197. *
  2198. * input parameters
  2199. *
  2200. * @param mode - HCI_EXT_ENABLE_OVERLAPPED_PROCESSING |
  2201. * HCI_EXT_DISABLE_OVERLAPPED_PROCESSING
  2202. *
  2203. * output parameters
  2204. *
  2205. * @param None.
  2206. *
  2207. * @return hciStatus_t
  2208. */
  2209. extern hciStatus_t HCI_EXT_OverlappedProcessingCmd( uint8 mode );
  2210. /*******************************************************************************
  2211. * @fn HCI_EXT_NumComplPktsLimitCmd Vendor Specific API
  2212. *
  2213. * @brief This HCI Extension API is used to set the minimum number of
  2214. * completed packets which must be met before a Number of
  2215. * Completed Packets event is returned. If the limit is not
  2216. * reach by the end of the connection event, then a Number of
  2217. * Completed Packets event will be returned (if non-zero) based
  2218. * on the flushOnEvt flag.
  2219. *
  2220. * input parameters
  2221. *
  2222. * @param limit - From 1 to HCI_MAX_NUM_DATA_BUFFERS.
  2223. * @param flushOnEvt - HCI_EXT_DISABLE_NUM_COMPL_PKTS_ON_EVENT |
  2224. * HCI_EXT_ENABLE_NUM_COMPL_PKTS_ON_EVENT
  2225. *
  2226. * output parameters
  2227. *
  2228. * @param None.
  2229. *
  2230. * @return hciStatus_t
  2231. */
  2232. extern hciStatus_t HCI_EXT_NumComplPktsLimitCmd( uint8 limit,
  2233. uint8 flushOnEvt );
  2234. /*******************************************************************************
  2235. * @fn HCI_PPLUS_AdvEventDoneNoticeCmd Vendor Specific API
  2236. *
  2237. * @brief This HCI Extension API is used to enable or disable a notification to the
  2238. * specified task using the specified task event whenever a Adv event ends.
  2239. * A non-zero taskEvent value is taken to be "enable", while a zero valued
  2240. * taskEvent is taken to be "disable".
  2241. *
  2242. * input parameters
  2243. *
  2244. * @param taskID - User's task ID.
  2245. * @param taskEvent - User's task event.
  2246. *
  2247. * output parameters
  2248. *
  2249. * @param None.
  2250. *
  2251. * @return hciStatus_t
  2252. */
  2253. hciStatus_t HCI_PPLUS_AdvEventDoneNoticeCmd( uint8 taskID, uint16 taskEvent );
  2254. /*******************************************************************************
  2255. * @fn HCI_PPLUS_ConnEventDoneNoticeCmd Vendor Specific API
  2256. *
  2257. * @brief This HCI Extension API is used to enable or disable a notification to the
  2258. * specified task using the specified task event whenever a Connection event
  2259. * ends. A non-zero taskEvent value is taken to be "enable", while a zero valued
  2260. * taskEvent is taken to be "disable".
  2261. *
  2262. * input parameters
  2263. *
  2264. * @param taskID - User's task ID.
  2265. * @param taskEvent - User's task event.
  2266. *
  2267. * output parameters
  2268. *
  2269. * @param None.
  2270. *
  2271. * @return hciStatus_t
  2272. */
  2273. hciStatus_t HCI_PPLUS_ConnEventDoneNoticeCmd( uint8 taskID, uint16 taskEvent );
  2274. /*******************************************************************************
  2275. * This HCI Extension API is used to enable or disable a notification to the
  2276. * specified task using the specified task event whenever a Connection event
  2277. * ends. A non-zero taskEvent value is taken to be "enable", while a zero valued
  2278. * taskEvent is taken to be "disable".
  2279. *
  2280. */
  2281. hciStatus_t HCI_PPLUS_DateLengthChangedNoticeCmd( uint8 taskID, uint16 taskEvent );
  2282. /*******************************************************************************
  2283. * This HCI Extension API is used to enable or disable a notification to the
  2284. * specified task using the specified task event whenever a Connection event
  2285. * ends. A non-zero taskEvent value is taken to be "enable", while a zero valued
  2286. * taskEvent is taken to be "disable".
  2287. *
  2288. */
  2289. hciStatus_t HCI_PPLUS_PhyUpdateNoticeCmd( uint8 taskID, uint16 taskEvent );
  2290. /*******************************************************************************
  2291. * @fn HCI_PPLUS_ExtendTRXCmd Vendor Specific API
  2292. *
  2293. * @brief This HCI Extension API is used to enable or disable Tx/Rx packets limit
  2294. * per connection event to 8(default is 4).
  2295. *
  2296. * input parameters
  2297. *
  2298. * @param enable - TRUE: 8Tx/8Rx; FALSE: 4Tx/4Rx
  2299. *
  2300. * output parameters
  2301. *
  2302. * @param None.
  2303. *
  2304. * @return hciStatus_t
  2305. */
  2306. hciStatus_t HCI_PPLUS_ExtendTRXCmd( uint8 enable );
  2307. /*******************************************************************************
  2308. */
  2309. hciStatus_t HCI_LE_SetDataLengthCmd( uint16 connHandle,
  2310. uint16 TxOctets,
  2311. uint16 TxTime );
  2312. /*******************************************************************************
  2313. */
  2314. hciStatus_t HCI_LE_ReadMaxDataLengthCmd(void);
  2315. /*******************************************************************************
  2316. * This LE API is used to read Suggested Default max Data length
  2317. *
  2318. * Public function defined in hci.h.
  2319. */
  2320. hciStatus_t HCI_LE_ReadSuggestedDefaultDataLengthCmd(void);
  2321. /*******************************************************************************
  2322. * This LE API is used to write Suggested Default Data length
  2323. *
  2324. * Public function defined in hci.h.
  2325. */
  2326. hciStatus_t HCI_LE_WriteSuggestedDefaultDataLengthCmd(uint16 suggestedMaxTxOctets,uint16 suggestedMaxTxTime);
  2327. /*******************************************************************************
  2328. * This LE API is used to set DefaultPhyMode
  2329. *
  2330. * Public function defined in hci.h.
  2331. */
  2332. hciStatus_t HCI_LE_SetDefaultPhyMode( uint16 connId,uint8 allPhy,uint8 txPhy, uint8 rxPhy);
  2333. /*******************************************************************************
  2334. * This LE API is used to Set PHY Mode
  2335. *
  2336. * Public function defined in hci.h.
  2337. */
  2338. hciStatus_t HCI_LE_SetPhyMode( uint16 connId,uint8 allPhy,uint8 txPhy, uint8 rxPhy,uint16 phyOptions);
  2339. /*******************************************************************************
  2340. * This LE API is used to Read PHY Mode
  2341. *
  2342. * Public function defined in hci.h.
  2343. */
  2344. hciStatus_t HCI_LE_ReadPhyMode( uint16 connId);
  2345. #ifdef __cplusplus
  2346. }
  2347. #endif
  2348. #endif /* HCI_H */