| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609 |
- /******************************************************************************
- *
- * Copyright (C) 1999-2014 Broadcom Corporation
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at:
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- *
- ******************************************************************************/
- #ifndef HCIDEFS_H
- #define HCIDEFS_H
- #include "bt_target.h"
- #include "bt_types.h"
- #define HCI_PROTO_VERSION 0x01 /* Version for BT spec 1.1 */
- #define HCI_PROTO_VERSION_1_2 0x02 /* Version for BT spec 1.2 */
- #define HCI_PROTO_VERSION_2_0 0x03 /* Version for BT spec 2.0 */
- #define HCI_PROTO_VERSION_2_1 0x04 /* Version for BT spec 2.1 [Lisbon] */
- #define HCI_PROTO_VERSION_3_0 0x05 /* Version for BT spec 3.0 */
- #define HCI_PROTO_VERSION_4_0 0x06 /* Version for BT spec 4.0 */
- #define HCI_PROTO_VERSION_4_1 0x07 /* Version for BT spec 4.1 */
- #define HCI_PROTO_VERSION_4_2 0x08 /* Version for BT spec 4.2 */
- #define HCI_PROTO_REVISION 0x000C /* Current implementation version */
- /*
- ** Definitions for HCI groups
- */
- #define HCI_GRP_LINK_CONTROL_CMDS (0x01 << 10) /* 0x0400 */
- #define HCI_GRP_LINK_POLICY_CMDS (0x02 << 10) /* 0x0800 */
- #define HCI_GRP_HOST_CONT_BASEBAND_CMDS (0x03 << 10) /* 0x0C00 */
- #define HCI_GRP_INFORMATIONAL_PARAMS (0x04 << 10) /* 0x1000 */
- #define HCI_GRP_STATUS_PARAMS (0x05 << 10) /* 0x1400 */
- #define HCI_GRP_TESTING_CMDS (0x06 << 10) /* 0x1800 */
- #define HCI_GRP_VENDOR_SPECIFIC (0x3F << 10) /* 0xFC00 */
- /* Group occupies high 6 bits of the HCI command rest is opcode itself */
- #define HCI_OGF(p) (UINT8)((0xFC00 & (p)) >> 10)
- #define HCI_OCF(p) ( 0x3FF & (p))
- /*
- ** Definitions for Link Control Commands
- */
- /* Following opcode is used only in command complete event for flow control */
- #define HCI_COMMAND_NONE 0x0000
- /* Commands of HCI_GRP_LINK_CONTROL_CMDS group */
- #define HCI_INQUIRY (0x0001 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_INQUIRY_CANCEL (0x0002 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_PERIODIC_INQUIRY_MODE (0x0003 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_EXIT_PERIODIC_INQUIRY_MODE (0x0004 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_CREATE_CONNECTION (0x0005 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_DISCONNECT (0x0006 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_ADD_SCO_CONNECTION (0x0007 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_CREATE_CONNECTION_CANCEL (0x0008 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_ACCEPT_CONNECTION_REQUEST (0x0009 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_REJECT_CONNECTION_REQUEST (0x000A | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_LINK_KEY_REQUEST_REPLY (0x000B | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_LINK_KEY_REQUEST_NEG_REPLY (0x000C | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_PIN_CODE_REQUEST_REPLY (0x000D | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_PIN_CODE_REQUEST_NEG_REPLY (0x000E | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_CHANGE_CONN_PACKET_TYPE (0x000F | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_AUTHENTICATION_REQUESTED (0x0011 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_SET_CONN_ENCRYPTION (0x0013 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_CHANGE_CONN_LINK_KEY (0x0015 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_MASTER_LINK_KEY (0x0017 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_RMT_NAME_REQUEST (0x0019 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_RMT_NAME_REQUEST_CANCEL (0x001A | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_READ_RMT_FEATURES (0x001B | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_READ_RMT_EXT_FEATURES (0x001C | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_READ_RMT_VERSION_INFO (0x001D | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_READ_RMT_CLOCK_OFFSET (0x001F | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_READ_LMP_HANDLE (0x0020 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_SETUP_ESCO_CONNECTION (0x0028 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_ACCEPT_ESCO_CONNECTION (0x0029 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_REJECT_ESCO_CONNECTION (0x002A | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_IO_CAPABILITY_REQUEST_REPLY (0x002B | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_USER_CONF_REQUEST_REPLY (0x002C | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_USER_CONF_VALUE_NEG_REPLY (0x002D | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_USER_PASSKEY_REQ_REPLY (0x002E | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_USER_PASSKEY_REQ_NEG_REPLY (0x002F | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_REM_OOB_DATA_REQ_REPLY (0x0030 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_REM_OOB_DATA_REQ_NEG_REPLY (0x0033 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_IO_CAP_REQ_NEG_REPLY (0x0034 | HCI_GRP_LINK_CONTROL_CMDS)
- /* AMP HCI */
- #define HCI_CREATE_PHYSICAL_LINK (0x0035 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_ACCEPT_PHYSICAL_LINK (0x0036 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_DISCONNECT_PHYSICAL_LINK (0x0037 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_CREATE_LOGICAL_LINK (0x0038 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_ACCEPT_LOGICAL_LINK (0x0039 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_DISCONNECT_LOGICAL_LINK (0x003A | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_LOGICAL_LINK_CANCEL (0x003B | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_FLOW_SPEC_MODIFY (0x003C | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_ENH_SETUP_ESCO_CONNECTION (0x003D | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_ENH_ACCEPT_ESCO_CONNECTION (0x003E | HCI_GRP_LINK_CONTROL_CMDS)
- /* ConnectionLess Broadcast */
- #define HCI_TRUNCATED_PAGE (0x003F | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_TRUNCATED_PAGE_CANCEL (0x0040 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_SET_CLB (0x0041 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_RECEIVE_CLB (0x0042 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_START_SYNC_TRAIN (0x0043 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_RECEIVE_SYNC_TRAIN (0x0044 | HCI_GRP_LINK_CONTROL_CMDS)
- #define HCI_LINK_CTRL_CMDS_FIRST HCI_INQUIRY
- #define HCI_LINK_CTRL_CMDS_LAST HCI_RECEIVE_SYNC_TRAIN
- /* Commands of HCI_GRP_LINK_POLICY_CMDS */
- #define HCI_HOLD_MODE (0x0001 | HCI_GRP_LINK_POLICY_CMDS)
- #define HCI_SNIFF_MODE (0x0003 | HCI_GRP_LINK_POLICY_CMDS)
- #define HCI_EXIT_SNIFF_MODE (0x0004 | HCI_GRP_LINK_POLICY_CMDS)
- #define HCI_PARK_MODE (0x0005 | HCI_GRP_LINK_POLICY_CMDS)
- #define HCI_EXIT_PARK_MODE (0x0006 | HCI_GRP_LINK_POLICY_CMDS)
- #define HCI_QOS_SETUP (0x0007 | HCI_GRP_LINK_POLICY_CMDS)
- #define HCI_ROLE_DISCOVERY (0x0009 | HCI_GRP_LINK_POLICY_CMDS)
- #define HCI_SWITCH_ROLE (0x000B | HCI_GRP_LINK_POLICY_CMDS)
- #define HCI_READ_POLICY_SETTINGS (0x000C | HCI_GRP_LINK_POLICY_CMDS)
- #define HCI_WRITE_POLICY_SETTINGS (0x000D | HCI_GRP_LINK_POLICY_CMDS)
- #define HCI_READ_DEF_POLICY_SETTINGS (0x000E | HCI_GRP_LINK_POLICY_CMDS)
- #define HCI_WRITE_DEF_POLICY_SETTINGS (0x000F | HCI_GRP_LINK_POLICY_CMDS)
- #define HCI_FLOW_SPECIFICATION (0x0010 | HCI_GRP_LINK_POLICY_CMDS)
- #define HCI_SNIFF_SUB_RATE (0x0011 | HCI_GRP_LINK_POLICY_CMDS)
- #define HCI_LINK_POLICY_CMDS_FIRST HCI_HOLD_MODE
- #define HCI_LINK_POLICY_CMDS_LAST HCI_SNIFF_SUB_RATE
- /* Commands of HCI_GRP_HOST_CONT_BASEBAND_CMDS */
- #define HCI_SET_EVENT_MASK (0x0001 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_RESET (0x0003 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_SET_EVENT_FILTER (0x0005 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_FLUSH (0x0008 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_PIN_TYPE (0x0009 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_PIN_TYPE (0x000A | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_CREATE_NEW_UNIT_KEY (0x000B | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_GET_MWS_TRANS_LAYER_CFG (0x000C | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_STORED_LINK_KEY (0x000D | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_STORED_LINK_KEY (0x0011 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_DELETE_STORED_LINK_KEY (0x0012 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_CHANGE_LOCAL_NAME (0x0013 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_LOCAL_NAME (0x0014 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_CONN_ACCEPT_TOUT (0x0015 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_CONN_ACCEPT_TOUT (0x0016 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_PAGE_TOUT (0x0017 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_PAGE_TOUT (0x0018 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_SCAN_ENABLE (0x0019 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_SCAN_ENABLE (0x001A | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_PAGESCAN_CFG (0x001B | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_PAGESCAN_CFG (0x001C | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_INQUIRYSCAN_CFG (0x001D | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_INQUIRYSCAN_CFG (0x001E | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_AUTHENTICATION_ENABLE (0x001F | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_AUTHENTICATION_ENABLE (0x0020 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_ENCRYPTION_MODE (0x0021 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_ENCRYPTION_MODE (0x0022 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_CLASS_OF_DEVICE (0x0023 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_CLASS_OF_DEVICE (0x0024 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_VOICE_SETTINGS (0x0025 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_VOICE_SETTINGS (0x0026 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_AUTO_FLUSH_TOUT (0x0027 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_AUTO_FLUSH_TOUT (0x0028 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_NUM_BCAST_REXMITS (0x0029 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_NUM_BCAST_REXMITS (0x002A | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_HOLD_MODE_ACTIVITY (0x002B | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_HOLD_MODE_ACTIVITY (0x002C | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_TRANSMIT_POWER_LEVEL (0x002D | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_SCO_FLOW_CTRL_ENABLE (0x002E | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_SCO_FLOW_CTRL_ENABLE (0x002F | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_SET_HC_TO_HOST_FLOW_CTRL (0x0031 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_HOST_BUFFER_SIZE (0x0033 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_HOST_NUM_PACKETS_DONE (0x0035 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_LINK_SUPER_TOUT (0x0036 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_LINK_SUPER_TOUT (0x0037 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_NUM_SUPPORTED_IAC (0x0038 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_CURRENT_IAC_LAP (0x0039 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_CURRENT_IAC_LAP (0x003A | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_PAGESCAN_PERIOD_MODE (0x003B | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_PAGESCAN_PERIOD_MODE (0x003C | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_PAGESCAN_MODE (0x003D | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_PAGESCAN_MODE (0x003E | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_SET_AFH_CHANNELS (0x003F | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_INQSCAN_TYPE (0x0042 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_INQSCAN_TYPE (0x0043 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_INQUIRY_MODE (0x0044 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_INQUIRY_MODE (0x0045 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_PAGESCAN_TYPE (0x0046 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_PAGESCAN_TYPE (0x0047 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_AFH_ASSESSMENT_MODE (0x0048 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_AFH_ASSESSMENT_MODE (0x0049 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_EXT_INQ_RESPONSE (0x0051 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_EXT_INQ_RESPONSE (0x0052 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_REFRESH_ENCRYPTION_KEY (0x0053 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_SIMPLE_PAIRING_MODE (0x0055 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_SIMPLE_PAIRING_MODE (0x0056 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_LOCAL_OOB_DATA (0x0057 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_INQ_TX_POWER_LEVEL (0x0058 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_INQ_TX_POWER_LEVEL (0x0059 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_ERRONEOUS_DATA_RPT (0x005A | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_ERRONEOUS_DATA_RPT (0x005B | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_ENHANCED_FLUSH (0x005F | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_SEND_KEYPRESS_NOTIF (0x0060 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- /* AMP HCI */
- #define HCI_READ_LOGICAL_LINK_ACCEPT_TIMEOUT (0x0061 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_LOGICAL_LINK_ACCEPT_TIMEOUT (0x0062 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_SET_EVENT_MASK_PAGE_2 (0x0063 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_LOCATION_DATA (0x0064 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_LOCATION_DATA (0x0065 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_FLOW_CONTROL_MODE (0x0066 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_FLOW_CONTROL_MODE (0x0067 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_BE_FLUSH_TOUT (0x0069 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_BE_FLUSH_TOUT (0x006A | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_SHORT_RANGE_MODE (0x006B | HCI_GRP_HOST_CONT_BASEBAND_CMDS) /* 802.11 only */
- #define HCI_READ_LE_HOST_SUPPORT (0x006C | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_LE_HOST_SUPPORT (0x006D | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- /* MWS coexistence */
- #define HCI_SET_MWS_CHANNEL_PARAMETERS (0x006E | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_SET_EXTERNAL_FRAME_CONFIGURATION (0x006F | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_SET_MWS_SIGNALING (0x0070 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_SET_MWS_TRANSPORT_LAYER (0x0071 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_SET_MWS_SCAN_FREQUENCY_TABLE (0x0072 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_SET_MWS_PATTERN_CONFIGURATION (0x0073 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- /* Connectionless Broadcast */
- #define HCI_SET_RESERVED_LT_ADDR (0x0074 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_DELETE_RESERVED_LT_ADDR (0x0075 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_CLB_DATA (0x0076 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_SYNC_TRAIN_PARAM (0x0077 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_SYNC_TRAIN_PARAM (0x0078 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_READ_SECURE_CONNS_SUPPORT (0x0079 | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_WRITE_SECURE_CONNS_SUPPORT (0x007A | HCI_GRP_HOST_CONT_BASEBAND_CMDS)
- #define HCI_CONT_BASEBAND_CMDS_FIRST HCI_SET_EVENT_MASK
- #define HCI_CONT_BASEBAND_CMDS_LAST HCI_READ_SYNC_TRAIN_PARAM
- /* Commands of HCI_GRP_INFORMATIONAL_PARAMS group */
- #define HCI_READ_LOCAL_VERSION_INFO (0x0001 | HCI_GRP_INFORMATIONAL_PARAMS)
- #define HCI_READ_LOCAL_SUPPORTED_CMDS (0x0002 | HCI_GRP_INFORMATIONAL_PARAMS)
- #define HCI_READ_LOCAL_FEATURES (0x0003 | HCI_GRP_INFORMATIONAL_PARAMS)
- #define HCI_READ_LOCAL_EXT_FEATURES (0x0004 | HCI_GRP_INFORMATIONAL_PARAMS)
- #define HCI_READ_BUFFER_SIZE (0x0005 | HCI_GRP_INFORMATIONAL_PARAMS)
- #define HCI_READ_COUNTRY_CODE (0x0007 | HCI_GRP_INFORMATIONAL_PARAMS)
- #define HCI_READ_BD_ADDR (0x0009 | HCI_GRP_INFORMATIONAL_PARAMS)
- #define HCI_READ_DATA_BLOCK_SIZE (0x000A | HCI_GRP_INFORMATIONAL_PARAMS)
- #define HCI_READ_LOCAL_SUPPORTED_CODECS (0x000B | HCI_GRP_INFORMATIONAL_PARAMS)
- #define HCI_INFORMATIONAL_CMDS_FIRST HCI_READ_LOCAL_VERSION_INFO
- #define HCI_INFORMATIONAL_CMDS_LAST HCI_READ_LOCAL_SUPPORTED_CODECS
- /* Commands of HCI_GRP_STATUS_PARAMS group */
- #define HCI_READ_FAILED_CONTACT_COUNT (0x0001 | HCI_GRP_STATUS_PARAMS)
- #define HCI_RESET_FAILED_CONTACT_COUNT (0x0002 | HCI_GRP_STATUS_PARAMS)
- #define HCI_GET_LINK_QUALITY (0x0003 | HCI_GRP_STATUS_PARAMS)
- #define HCI_READ_RSSI (0x0005 | HCI_GRP_STATUS_PARAMS)
- #define HCI_READ_AFH_CH_MAP (0x0006 | HCI_GRP_STATUS_PARAMS)
- #define HCI_READ_CLOCK (0x0007 | HCI_GRP_STATUS_PARAMS)
- #define HCI_READ_ENCR_KEY_SIZE (0x0008 | HCI_GRP_STATUS_PARAMS)
- /* AMP HCI */
- #define HCI_READ_LOCAL_AMP_INFO (0x0009 | HCI_GRP_STATUS_PARAMS)
- #define HCI_READ_LOCAL_AMP_ASSOC (0x000A | HCI_GRP_STATUS_PARAMS)
- #define HCI_WRITE_REMOTE_AMP_ASSOC (0x000B | HCI_GRP_STATUS_PARAMS)
- #define HCI_STATUS_PARAMS_CMDS_FIRST HCI_READ_FAILED_CONTACT_COUNT
- #define HCI_STATUS_PARAMS_CMDS_LAST HCI_WRITE_REMOTE_AMP_ASSOC
- /* Commands of HCI_GRP_TESTING_CMDS group */
- #define HCI_READ_LOOPBACK_MODE (0x0001 | HCI_GRP_TESTING_CMDS)
- #define HCI_WRITE_LOOPBACK_MODE (0x0002 | HCI_GRP_TESTING_CMDS)
- #define HCI_ENABLE_DEV_UNDER_TEST_MODE (0x0003 | HCI_GRP_TESTING_CMDS)
- #define HCI_WRITE_SIMP_PAIR_DEBUG_MODE (0x0004 | HCI_GRP_TESTING_CMDS)
- /* AMP HCI */
- #define HCI_ENABLE_AMP_RCVR_REPORTS (0x0007 | HCI_GRP_TESTING_CMDS)
- #define HCI_AMP_TEST_END (0x0008 | HCI_GRP_TESTING_CMDS)
- #define HCI_AMP_TEST (0x0009 | HCI_GRP_TESTING_CMDS)
- #define HCI_TESTING_CMDS_FIRST HCI_READ_LOOPBACK_MODE
- #define HCI_TESTING_CMDS_LAST HCI_AMP_TEST
- #define HCI_VENDOR_CMDS_FIRST 0x0001
- #define HCI_VENDOR_CMDS_LAST 0xFFFF
- #define HCI_VSC_MULTI_AV_HANDLE 0x0AAA
- #define HCI_VSC_BURST_MODE_HANDLE 0x0BBB
- /* BLE HCI */
- #define HCI_GRP_BLE_CMDS (0x08 << 10)
- /* Commands of BLE Controller setup and configuration */
- #define HCI_BLE_SET_EVENT_MASK (0x0001 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_READ_BUFFER_SIZE (0x0002 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_READ_LOCAL_SPT_FEAT (0x0003 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_WRITE_LOCAL_SPT_FEAT (0x0004 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_WRITE_RANDOM_ADDR (0x0005 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_WRITE_ADV_PARAMS (0x0006 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_READ_ADV_CHNL_TX_POWER (0x0007 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_WRITE_ADV_DATA (0x0008 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_WRITE_SCAN_RSP_DATA (0x0009 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_WRITE_ADV_ENABLE (0x000A | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_WRITE_SCAN_PARAMS (0x000B | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_WRITE_SCAN_ENABLE (0x000C | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_CREATE_LL_CONN (0x000D | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_CREATE_CONN_CANCEL (0x000E | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_READ_WHITE_LIST_SIZE (0x000F | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_CLEAR_WHITE_LIST (0x0010 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_ADD_WHITE_LIST (0x0011 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_REMOVE_WHITE_LIST (0x0012 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_UPD_LL_CONN_PARAMS (0x0013 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_SET_HOST_CHNL_CLASS (0x0014 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_READ_CHNL_MAP (0x0015 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_READ_REMOTE_FEAT (0x0016 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_ENCRYPT (0x0017 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_RAND (0x0018 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_START_ENC (0x0019 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_LTK_REQ_REPLY (0x001A | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_LTK_REQ_NEG_REPLY (0x001B | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_READ_SUPPORTED_STATES (0x001C | HCI_GRP_BLE_CMDS)
- /*0x001D, 0x001E and 0x001F are reserved*/
- #define HCI_BLE_RECEIVER_TEST (0x001D | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_TRANSMITTER_TEST (0x001E | HCI_GRP_BLE_CMDS)
- /* BLE TEST COMMANDS */
- #define HCI_BLE_TEST_END (0x001F | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_RC_PARAM_REQ_REPLY (0x0020 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_RC_PARAM_REQ_NEG_REPLY (0x0021 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_SET_DATA_LENGTH (0x0022 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_READ_DEFAULT_DATA_LENGTH (0x0023 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_WRITE_DEFAULT_DATA_LENGTH (0x0024 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_ADD_DEV_RESOLVING_LIST (0x0027 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_RM_DEV_RESOLVING_LIST (0x0028 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_CLEAR_RESOLVING_LIST (0x0029 | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_READ_RESOLVING_LIST_SIZE (0x002A | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_READ_RESOLVABLE_ADDR_PEER (0x002B | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_READ_RESOLVABLE_ADDR_LOCAL (0x002C | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_SET_ADDR_RESOLUTION_ENABLE (0x002D | HCI_GRP_BLE_CMDS)
- #define HCI_BLE_SET_RAND_PRIV_ADDR_TIMOUT (0x002E | HCI_GRP_BLE_CMDS)
- /* LE Get Vendor Capabilities Command OCF */
- #define HCI_BLE_VENDOR_CAP_OCF (0x0153 | HCI_GRP_VENDOR_SPECIFIC)
- /* Multi adv OCF */
- #define HCI_BLE_MULTI_ADV_OCF (0x0154 | HCI_GRP_VENDOR_SPECIFIC)
- /* Batch scan OCF */
- #define HCI_BLE_BATCH_SCAN_OCF (0x0156 | HCI_GRP_VENDOR_SPECIFIC)
- /* ADV filter OCF */
- #define HCI_BLE_ADV_FILTER_OCF (0x0157 | HCI_GRP_VENDOR_SPECIFIC)
- /* Tracking OCF */
- #define HCI_BLE_TRACK_ADV_OCF (0x0158 | HCI_GRP_VENDOR_SPECIFIC)
- /* Energy info OCF */
- #define HCI_BLE_ENERGY_INFO_OCF (0x0159 | HCI_GRP_VENDOR_SPECIFIC)
- /* Extended BLE Scan parameters OCF */
- #define HCI_BLE_EXTENDED_SCAN_PARAMS_OCF (0x0160 | HCI_GRP_VENDOR_SPECIFIC)
- /* subcode for multi adv feature */
- #define BTM_BLE_MULTI_ADV_SET_PARAM 0x01
- #define BTM_BLE_MULTI_ADV_WRITE_ADV_DATA 0x02
- #define BTM_BLE_MULTI_ADV_WRITE_SCAN_RSP_DATA 0x03
- #define BTM_BLE_MULTI_ADV_SET_RANDOM_ADDR 0x04
- #define BTM_BLE_MULTI_ADV_ENB 0x05
- /* multi adv VSE subcode */
- #define HCI_VSE_SUBCODE_BLE_MULTI_ADV_ST_CHG 0x55 /* multi adv instance state change */
- /* subcode for batch scan feature */
- #define BTM_BLE_BATCH_SCAN_ENB_DISAB_CUST_FEATURE 0x01
- #define BTM_BLE_BATCH_SCAN_SET_STORAGE_PARAM 0x02
- #define BTM_BLE_BATCH_SCAN_SET_PARAMS 0x03
- #define BTM_BLE_BATCH_SCAN_READ_RESULTS 0x04
- /* batch scan VSE subcode */
- #define HCI_VSE_SUBCODE_BLE_THRESHOLD_SUB_EVT 0x54 /* Threshold event */
- /* tracking sub event */
- #define HCI_VSE_SUBCODE_BLE_TRACKING_SUB_EVT 0x56 /* Tracking event */
- /* LE supported states definition */
- #define HCI_LE_ADV_STATE 0x00000001
- #define HCI_LE_SCAN_STATE 0x00000002
- #define HCI_LE_INIT_STATE 0x00000004
- #define HCI_LE_CONN_SL_STATE 0x00000008
- #define HCI_LE_ADV_SCAN_STATE 0x00000010
- #define HCI_LE_ADV_INIT_STATE 0x00000020
- #define HCI_LE_ADV_MA_STATE 0x00000040
- #define HCI_LE_ADV_SL_STATE 0x00000080
- #define HCI_LE_SCAN_INIT_STATE 0x00000100
- #define HCI_LE_SCAN_MA_STATE 0x00000200
- #define HCI_LE_SCAN_SL_STATE 0x00000400
- #define HCI_LE_INIT_MA_STATE 0x00000800
- /* LE Supported States */
- /* Non Connectable Adv state is supported. 0x0000000000000001 */
- #define HCI_SUPP_LE_STATES_NON_CONN_ADV_MASK 0x01
- #define HCI_SUPP_LE_STATES_NON_CONN_ADV_OFF 0
- #define HCI_LE_STATES_NON_CONN_ADV_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_NON_CONN_ADV_OFF] & HCI_SUPP_LE_STATES_NON_CONN_ADV_MASK)
- /*Scanneable Connectable Adv state is supported. 0x0000000000000002 */
- #define HCI_SUPP_LE_STATES_SCAN_ADV_MASK 0x02
- #define HCI_SUPP_LE_STATESSCAN_ADV_OFF 0
- #define HCI_LE_STATES_SCAN_ADV_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATESSCAN_ADV_OFF] & HCI_SUPP_LE_STATES_SCAN_ADV_MASK)
- /* Connectable Adv state is supported. 0x0000000000000004 */
- #define HCI_SUPP_LE_STATES_CONN_ADV_MASK 0x04
- #define HCI_SUPP_LE_STATES_CONN_ADV_OFF 0
- #define HCI_LE_STATES_CONN_ADV_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_CONN_ADV_OFF] & HCI_SUPP_LE_STATES_CONN_ADV_MASK)
- /* Hi duty Cycle Directed Adv state is supported. 0x0000000000000008 */
- #define HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_MASK 0x08
- #define HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_OFF 0
- #define HCI_LE_STATES_HI_DUTY_DIR_ADV_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_OFF] & HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_MASK)
- /* Passive Scan state is supported. 0x0000000000000010 */
- #define HCI_SUPP_LE_STATES_PASS_SCAN_MASK 0x10
- #define HCI_SUPP_LE_STATES_PASS_SCAN_OFF 0
- #define HCI_LE_STATES_PASS_SCAN_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_PASS_SCAN_OFF] & HCI_SUPP_LE_STATES_PASS_SCAN_MASK)
- /* Active Scan state is supported. 0x0000000000000020 */
- #define HCI_SUPP_LE_STATES_ACTIVE_SCAN_MASK 0x20
- #define HCI_SUPP_LE_STATES_ACTIVE_SCAN_OFF 0
- #define HCI_LE_STATES_ACTIVE_SCAN_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_ACTIVE_SCAN_OFF] & HCI_SUPP_LE_STATES_ACTIVE_SCAN_MASK)
- /* Initiating state is supported. 0x0000000000000040 (or connection state in master role is also supported) */
- #define HCI_SUPP_LE_STATES_INIT_MASK 0x40
- #define HCI_SUPP_LE_STATES_INIT_OFF 0
- #define HCI_LE_STATES_INIT_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_INIT_OFF] & HCI_SUPP_LE_STATES_INIT_MASK)
- /*connection state in slave role is also supported. 0x0000000000000080 */
- #define HCI_SUPP_LE_STATES_SLAVE_MASK 0x80
- #define HCI_SUPP_LE_STATES_SLAVE_OFF 0
- #define HCI_LE_STATES_SLAVE_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_SLAVE_OFF] & HCI_SUPP_LE_STATES_SLAVE_MASK)
- /* Non Connectable Adv state and Passive Scanning State combination is supported. 0x0000000000000100 */
- #define HCI_SUPP_LE_STATES_NON_CONN_ADV_PASS_SCAN_MASK 0x01
- #define HCI_SUPP_LE_STATES_NON_CONN_ADV_PASS_SCAN_OFF 1
- #define HCI_LE_STATES_NON_CONN_ADV_PASS_SCAN_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_NON_CONN_ADV_PASS_SCAN_OFF] & HCI_SUPP_LE_STATES_NON_CONN_ADV_PASS_SCAN_MASK)
- /*Scannable Adv state and Passive Scanning State combination is supported. 0x0000000000000200 */
- #define HCI_SUPP_LE_STATES_SCAN_ADV_PASS_SCAN_MASK 0x02
- #define HCI_SUPP_LE_STATES_SCAN_ADV_PASS_SCAN_OFF 1
- #define HCI_LE_STATES_SCAN_ADV_PASS_SCAN_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_SCAN_ADV_PASS_SCAN_OFF] & HCI_SUPP_LE_STATES_SCAN_ADV_PASS_SCAN_MASK)
- /*Connectable Adv state and Passive Scanning State combination is supported. 0x0000000000000400 */
- #define HCI_SUPP_LE_STATES_CONN_ADV_PASS_SCAN_MASK 0x04
- #define HCI_SUPP_LE_STATES_CONN_ADV_PASS_SCAN_OFF 1
- #define HCI_LE_STATES_CONN_ADV_PASS_SCAN_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_CONN_ADV_PASS_SCAN_OFF] & HCI_SUPP_LE_STATES_CONN_ADV_PASS_SCAN_MASK)
- /*High Duty Cycl Directed ADv and Passive Scanning State combination is supported. 0x0000000000000800 */
- #define HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_PASS_SCAN_MASK 0x08
- #define HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_PASS_SCAN_OFF 1
- #define HCI_LE_STATES_HI_DUTY_DIR_ADV_PASS_SCAN_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_PASS_SCAN_MASK] & HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_PASS_SCAN_OFF)
- /*Non Connectable Adv state and Passive Scanning State combination is supported. 0x0000000000001000 */
- #define HCI_SUPP_LE_STATES_NON_CONN_ADV_ACTIVE_SCAN_MASK 0x10
- #define HCI_SUPP_LE_STATES_NON_CONN_ADV_ACTIVE_SCAN_OFF 1
- #define HCI_LE_STATES_NON_CONN_ADV_ACTIVE_SCAN_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_NON_CONN_ADV_ACTIVE_SCAN_OFF] & HCI_SUPP_LE_STATES_NON_CONN_ADV_ACTIVE_SCAN_MASK)
- /*Scannable Adv state and Active Scanning State combination is supported. 0x0000000000002000 */
- #define HCI_SUPP_LE_STATES_SCAN_ADV_ACTIVE_SCAN_MASK 0x20
- #define HCI_SUPP_LE_STATES_SCAN_ADV_ACTIVE_SCAN_OFF 1
- #define HCI_LE_STATES_SCAN_ADV_ACTIVE_SCAN_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_SCAN_ADV_ACTIVE_SCAN_OFF] & HCI_SUPP_LE_STATES_SCAN_ADV_ACTIVE_SCAN_MASK)
- /*Connectable Adv state and Active Scanning State combination is supported. 0x0000000000004000 */
- #define HCI_SUPP_LE_STATES_CONN_ADV_ACTIVE_SCAN_MASK 0x40
- #define HCI_SUPP_LE_STATES_CONN_ADV_ACTIVE_SCAN_OFF 1
- #define HCI_LE_STATES_CONN_ADV_ACTIVE_SCAN_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_CONN_ADV_ACTIVE_SCAN_OFF] & HCI_SUPP_LE_STATES_CONN_ADV_ACTIVE_SCAN_MASK)
- /*High Duty Cycl Directed ADv and ACtive Scanning State combination is supported. 0x0000000000008000 */
- #define HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_ACTIVE_SCAN_MASK 0x80
- #define HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_ACTIVE_SCAN_OFF 1
- #define HCI_LE_STATES_HI_DUTY_DIR_ADV_ACTIVE_SCAN_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_ACTIVE_SCAN_MASK] & HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_ACTIVE_SCAN_OFF)
- /*Non-Connectable Adv state and Initiating State combination is supported. 0x0000000000010000 */
- #define HCI_SUPP_LE_STATES_NON_CONN_INIT_MASK 0x01
- #define HCI_SUPP_LE_STATES_NON_CONN_INIT_OFF 2
- #define HCI_LE_STATES_NON_CONN_INIT_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_NON_CONN_INIT_OFF] & HCI_SUPP_LE_STATES_NON_CONN_INIT_MASK)
- /* Scannable Adv state and Initiating State combination is supported. 0x0000000000020000 */
- #define HCI_SUPP_LE_STATES_SCAN_ADV_INIT_MASK 0x02
- #define HCI_SUPP_LE_STATES_SCAN_ADV_INIT_OFF 2
- #define HCI_LE_STATES_SCAN_ADV_INIT_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_SCAN_ADV_INIT_OFF] & HCI_SUPP_LE_STATES_SCAN_ADV_INIT_MASK)
- /* Non-Connectable Adv state and Master Role combination is supported. 0x0000000000040000 */
- #define HCI_SUPP_LE_STATES_NON_CONN_ADV_MASTER_MASK 0x04
- #define HCI_SUPP_LE_STATES_NON_CONN_ADV_MASTER_OFF 2
- #define HCI_LE_STATES_NON_CONN_ADV_MASTER_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_NON_CONN_ADV_MASTER_OFF] & HCI_SUPP_LE_STATES_NON_CONN_ADV_MASTER_MASK)
- /*Scannable Adv state and Master Role combination is supported. 0x0000000000040000 */
- #define HCI_SUPP_LE_STATES_SCAN_ADV_MASTER_MASK 0x08
- #define HCI_SUPP_LE_STATES_SCAN_ADV_MASTER_OFF 2
- #define HCI_LE_STATES_SCAN_ADV_MASTER_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_SCAN_ADV_MASTER_OFF] & HCI_SUPP_LE_STATES_SCAN_ADV_MASTER_MASK)
- /* Non-Connectable Adv and Slave Role combination is supported. 0x000000000100000 */
- #define HCI_SUPP_LE_STATES_NON_CONN_ADV_SLAVE_MASK 0x10
- #define HCI_SUPP_LE_STATES_NON_CONN_ADV_SLAVE_OFF 2
- #define HCI_LE_STATES_NON_CONN_ADV_SLAVE_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_NON_CONN_ADV_SLAVE_OFF] & HCI_SUPP_LE_STATES_NON_CONN_ADV_SLAVE_MASK)
- /*Scannable Adv and Slave Role combination is supported. 0x000000000200000 */
- #define HCI_SUPP_LE_STATES_SCAN_ADV_SLAVE_MASK 0x20
- #define HCI_SUPP_LE_STATES_SCAN_ADV_SLAVE_OFF 2
- #define HCI_LE_STATES_SCAN_ADV_SLAVE_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_SCAN_ADV_SLAVE_OFF] & HCI_SUPP_LE_STATES_SCAN_ADV_SLAVE_MASK)
- /*Passive Scan and Initiating State combination is supported. 0x000000000400000 */
- #define HCI_SUPP_LE_STATES_PASS_SCAN_INIT_MASK 0x40
- #define HCI_SUPP_LE_STATES_PASS_SCAN_INIT_OFF 2
- #define HCI_LE_STATES_PASS_SCAN_INIT_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_PASS_SCAN_INIT_OFF] & HCI_SUPP_LE_STATES_PASS_SCAN_INIT_MASK)
- /*Active Scan and Initiating State combination is supported. 0x000000000800000 */
- #define HCI_SUPP_LE_STATES_ACTIVE_SCAN_INIT_MASK 0x80
- #define HCI_SUPP_LE_STATES_ACTIVE_SCAN_INIT_OFF 2
- #define HCI_LE_STATES_ACTIVE_SCAN_INIT_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_ACTIVE_SCAN_INIT_OFF] & HCI_SUPP_LE_STATES_ACTIVE_SCAN_INIT_MASK)
- /*Passive Scan and Master Role combination is supported. 0x000000001000000 */
- #define HCI_SUPP_LE_STATES_PASS_SCAN_MASTER_MASK 0x01
- #define HCI_SUPP_LE_STATES_PASS_SCAN_MASTER_OFF 3
- #define HCI_LE_STATES_PASS_SCAN_MASTER_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_PASS_SCAN_MASTER_OFF] & HCI_SUPP_LE_STATES_PASS_SCAN_MASTER_MASK)
- /*Active Scan and Master Role combination is supported. 0x000000002000000 */
- #define HCI_SUPP_LE_STATES_ACTIVE_SCAN_MASTER_MASK 0x02
- #define HCI_SUPP_LE_STATES_ACTIVE_SCAN_MASTER_OFF 3
- #define HCI_LE_STATES_ACTIVE_SCAN_MASTER_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_ACTIVE_SCAN_MASTER_OFF] & HCI_SUPP_LE_STATES_ACTIVE_SCAN_MASTER_MASK)
- /*Passive Scan and Slave Role combination is supported. 0x000000004000000 */
- #define HCI_SUPP_LE_STATES_PASS_SCAN_SLAVE_MASK 0x04
- #define HCI_SUPP_LE_STATES_PASS_SCAN_SLAVE_OFF 3
- #define HCI_LE_STATES_PASS_SCAN_SLAVE_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_PASS_SCAN_SLAVE_OFF] & HCI_SUPP_LE_STATES_PASS_SCAN_SLAVE_MASK)
- /*Active Scan and Slave Role combination is supported. 0x000000008000000 */
- #define HCI_SUPP_LE_STATES_ACTIVE_SCAN_SLAVE_MASK 0x08
- #define HCI_SUPP_LE_STATES_ACTIVE_SCAN_SLAVE_OFF 3
- #define HCI_LE_STATES_ACTIVE_SCAN_SLAVE_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_ACTIVE_SCAN_SLAVE_OFF] & HCI_SUPP_LE_STATES_ACTIVE_SCAN_SLAVE_MASK)
- /*Link Layer Topology Added States Combo */
- /*Initiating State and Master Role combination supported.
- Master Role and Master Role combination is also supported. 0x0000000010000000 */
- #define HCI_SUPP_LE_STATES_INIT_MASTER_MASK 0x10
- #define HCI_SUPP_LE_STATES_INIT_MASTER_OFF 3
- #define HCI_LE_STATES_INIT_MASTER_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_INIT_MASTER_OFF] & HCI_SUPP_LE_STATES_INIT_MASTER_MASK)
- /*Low Duty Cycle Directed Advertising State . 0x0000000020000000 */
- #define HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_MASK 0x20
- #define HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_OFF 3
- #define HCI_LE_STATES_LOW_DUTY_DIR_ADV_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_LOW_DUTY_DIR_ADV_OFF] & HCI_SUPP_LE_STATES_LOW_DUTY_DIR_ADV_MASK)
- /*Low Duty Cycle Directed Advertising State and Passive scan combination. 0x0000000040000000 */
- #define HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_PASS_SCAN_MASK 0x40
- #define HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_PASS_SCAN_OFF 3
- #define HCI_LE_STATES_LO_DUTY_DIR_ADV_PASS_SCAN_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_PASS_SCAN_OFF] & HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_PASS_SCAN_MASK)
- /*Low Duty Cycle Directed Advertising State and Active scan combination . 0x0000000080000000 */
- #define HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_ACTIVE_SCAN_MASK 0x80
- #define HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_ACTIVE_SCAN_OFF 3
- #define HCI_LE_STATES_LO_DUTY_DIR_ADV_ACTIVE_SCAN_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_ACTIVE_SCAN_OFF] & HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_ACTIVE_SCAN_MASK)
- /* Connectable Advertising State and Initiating State combination supported. 0x0000000100000000 */
- #define HCI_SUPP_LE_STATES_CONN_ADV_INIT_MASK 0x01
- #define HCI_SUPP_LE_STATES_CONN_ADV_INIT_OFF 4
- #define HCI_LE_STATES_CONN_ADV_INIT_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_CONN_ADV_INIT_OFF] & HCI_SUPP_LE_STATES_CONN_ADV_INIT_MASK)
- /* High Duty Cycle Directed Advertising State and Initiating State combination supported. */
- #define HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_INIT_MASK 0x02
- #define HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_INIT_OFF 4
- #define HCI_LE_STATES_HI_DUTY_DIR_ADV_INIT_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_INIT_OFF] & HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_INIT_MASK)
- /* Low Duty Cycle Directed Advertising State and Initiating State combination supported.*/
- #define HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_INIT_MASK 0x04
- #define HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_INIT_OFF 4
- #define HCI_LE_STATES_LO_DUTY_DIR_ADV_INIT_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_INIT_OFF] & HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_INIT_MASK)
- /* Connectable Advertising State and Master Role combination supported.*/
- #define HCI_SUPP_LE_STATES_CONN_ADV_MASTER_MASK 0x08
- #define HCI_SUPP_LE_STATES_CONN_ADV_MASTER_OFF 4
- #define HCI_LE_STATES_CONN_ADV_MASTER_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_CONN_ADV_MASTER_OFF] & HCI_SUPP_LE_STATES_CONN_ADV_MASTER_MASK)
- /* High Duty Cycle Directed Advertising State and Master Role combination supported.*/
- #define HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_MASTER_MASK 0x10
- #define HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_MASTER_OFF 4
- #define HCI_LE_STATES_HI_DUTY_DIR_ADV_MASTER_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_MASTER_OFF] & HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_MASTER_MASK)
- /* Low Duty Cycle Directed Advertising State and Master Role combination supported.*/
- #define HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_MASTER_MASK 0x20
- #define HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_MASTER_OFF 4
- #define HCI_LE_STATES_LO_DUTY_DIR_ADV_MASTER_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_MASTER_OFF] & HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_MASTER_MASK)
- /* Connectable Advertising State and Slave Role combination supported. */
- #define HCI_SUPP_LE_STATES_CONN_ADV_SLAVE_MASK 0x40
- #define HCI_SUPP_LE_STATES_CONN_ADV_SLAVE_OFF 4
- #define HCI_LE_STATES_CONN_ADV_SLAVE_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_CONN_ADV_SLAVE_OFF] & HCI_SUPP_LE_STATES_CONN_ADV_SLAVE_MASK)
- /* High Duty Cycle Directed Advertising State and slave Role combination supported.*/
- #define HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_SLAVE_MASK 0x80
- #define HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_SLAVE_OFF 4
- #define HCI_LE_STATES_HI_DUTY_DIR_ADV_SLAVE_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_SLAVE_OFF] & HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_SLAVE_MASK)
- /* Low Duty Cycle Directed Advertising State and slave Role combination supported.*/
- #define HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_SLAVE_MASK 0x01
- #define HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_SLAVE_OFF 5
- #define HCI_LE_STATES_LO_DUTY_DIR_ADV_SLAVE_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_SLAVE_OFF] & HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_SLAVE_MASK)
- /* Initiating State and Slave Role combination supported.
- Master Role and Slave Role combination also supported.
- */
- #define HCI_SUPP_LE_STATES_INIT_MASTER_SLAVE_MASK 0x02
- #define HCI_SUPP_LE_STATES_INIT_MASTER_SLAVE_OFF 5
- #define HCI_LE_STATES_INIT_MASTER_SLAVE_SUPPORTED(x) ((x)[HCI_SUPP_LE_STATES_INIT_MASTER_SLAVE_OFF] & HCI_SUPP_LE_STATES_INIT_MASTER_SLAVE_MASK)
- /*
- ** Definitions for HCI Events
- */
- #define HCI_INQUIRY_COMP_EVT 0x01
- #define HCI_INQUIRY_RESULT_EVT 0x02
- #define HCI_CONNECTION_COMP_EVT 0x03
- #define HCI_CONNECTION_REQUEST_EVT 0x04
- #define HCI_DISCONNECTION_COMP_EVT 0x05
- #define HCI_AUTHENTICATION_COMP_EVT 0x06
- #define HCI_RMT_NAME_REQUEST_COMP_EVT 0x07
- #define HCI_ENCRYPTION_CHANGE_EVT 0x08
- #define HCI_CHANGE_CONN_LINK_KEY_EVT 0x09
- #define HCI_MASTER_LINK_KEY_COMP_EVT 0x0A
- #define HCI_READ_RMT_FEATURES_COMP_EVT 0x0B
- #define HCI_READ_RMT_VERSION_COMP_EVT 0x0C
- #define HCI_QOS_SETUP_COMP_EVT 0x0D
- #define HCI_COMMAND_COMPLETE_EVT 0x0E
- #define HCI_COMMAND_STATUS_EVT 0x0F
- #define HCI_HARDWARE_ERROR_EVT 0x10
- #define HCI_FLUSH_OCCURED_EVT 0x11
- #define HCI_ROLE_CHANGE_EVT 0x12
- #define HCI_NUM_COMPL_DATA_PKTS_EVT 0x13
- #define HCI_MODE_CHANGE_EVT 0x14
- #define HCI_RETURN_LINK_KEYS_EVT 0x15
- #define HCI_PIN_CODE_REQUEST_EVT 0x16
- #define HCI_LINK_KEY_REQUEST_EVT 0x17
- #define HCI_LINK_KEY_NOTIFICATION_EVT 0x18
- #define HCI_LOOPBACK_COMMAND_EVT 0x19
- #define HCI_DATA_BUF_OVERFLOW_EVT 0x1A
- #define HCI_MAX_SLOTS_CHANGED_EVT 0x1B
- #define HCI_READ_CLOCK_OFF_COMP_EVT 0x1C
- #define HCI_CONN_PKT_TYPE_CHANGE_EVT 0x1D
- #define HCI_QOS_VIOLATION_EVT 0x1E
- #define HCI_PAGE_SCAN_MODE_CHANGE_EVT 0x1F
- #define HCI_PAGE_SCAN_REP_MODE_CHNG_EVT 0x20
- #define HCI_FLOW_SPECIFICATION_COMP_EVT 0x21
- #define HCI_INQUIRY_RSSI_RESULT_EVT 0x22
- #define HCI_READ_RMT_EXT_FEATURES_COMP_EVT 0x23
- #define HCI_ESCO_CONNECTION_COMP_EVT 0x2C
- #define HCI_ESCO_CONNECTION_CHANGED_EVT 0x2D
- #define HCI_SNIFF_SUB_RATE_EVT 0x2E
- #define HCI_EXTENDED_INQUIRY_RESULT_EVT 0x2F
- #define HCI_ENCRYPTION_KEY_REFRESH_COMP_EVT 0x30
- #define HCI_IO_CAPABILITY_REQUEST_EVT 0x31
- #define HCI_IO_CAPABILITY_RESPONSE_EVT 0x32
- #define HCI_USER_CONFIRMATION_REQUEST_EVT 0x33
- #define HCI_USER_PASSKEY_REQUEST_EVT 0x34
- #define HCI_REMOTE_OOB_DATA_REQUEST_EVT 0x35
- #define HCI_SIMPLE_PAIRING_COMPLETE_EVT 0x36
- #define HCI_LINK_SUPER_TOUT_CHANGED_EVT 0x38
- #define HCI_ENHANCED_FLUSH_COMPLETE_EVT 0x39
- #define HCI_USER_PASSKEY_NOTIFY_EVT 0x3B
- #define HCI_KEYPRESS_NOTIFY_EVT 0x3C
- #define HCI_RMT_HOST_SUP_FEAT_NOTIFY_EVT 0x3D
- /*#define HCI_GENERIC_AMP_LINK_KEY_NOTIF_EVT 0x3E Removed from spec */
- #define HCI_PHYSICAL_LINK_COMP_EVT 0x40
- #define HCI_CHANNEL_SELECTED_EVT 0x41
- #define HCI_DISC_PHYSICAL_LINK_COMP_EVT 0x42
- #define HCI_PHY_LINK_LOSS_EARLY_WARNING_EVT 0x43
- #define HCI_PHY_LINK_RECOVERY_EVT 0x44
- #define HCI_LOGICAL_LINK_COMP_EVT 0x45
- #define HCI_DISC_LOGICAL_LINK_COMP_EVT 0x46
- #define HCI_FLOW_SPEC_MODIFY_COMP_EVT 0x47
- #define HCI_NUM_COMPL_DATA_BLOCKS_EVT 0x48
- #define HCI_SHORT_RANGE_MODE_COMPLETE_EVT 0x4C
- #define HCI_AMP_STATUS_CHANGE_EVT 0x4D
- #define HCI_SET_TRIGGERED_CLOCK_CAPTURE_EVT 0x4E
- /* ULP HCI Event */
- #define HCI_BLE_EVENT 0x3e
- /* ULP Event sub code */
- #define HCI_BLE_CONN_COMPLETE_EVT 0x01
- #define HCI_BLE_ADV_PKT_RPT_EVT 0x02
- #define HCI_BLE_LL_CONN_PARAM_UPD_EVT 0x03
- #define HCI_BLE_READ_REMOTE_FEAT_CMPL_EVT 0x04
- #define HCI_BLE_LTK_REQ_EVT 0x05
- #define HCI_BLE_RC_PARAM_REQ_EVT 0x06
- #define HCI_BLE_DATA_LENGTH_CHANGE_EVT 0x07
- #define HCI_BLE_ENHANCED_CONN_COMPLETE_EVT 0x0a
- #define HCI_BLE_DIRECT_ADV_EVT 0x0b
- /* Definitions for LE Channel Map */
- #define HCI_BLE_CHNL_MAP_SIZE 5
- #define HCI_VENDOR_SPECIFIC_EVT 0xFF /* Vendor specific events */
- #define HCI_NAP_TRACE_EVT 0xFF /* was define 0xFE, 0xFD, change to 0xFF
- because conflict w/ TCI_EVT and per
- specification compliant */
- /*
- ** Defentions for HCI Error Codes that are past in the events
- */
- #define HCI_SUCCESS 0x00
- #define HCI_PENDING 0x00
- #define HCI_ERR_ILLEGAL_COMMAND 0x01
- #define HCI_ERR_NO_CONNECTION 0x02
- #define HCI_ERR_HW_FAILURE 0x03
- #define HCI_ERR_PAGE_TIMEOUT 0x04
- #define HCI_ERR_AUTH_FAILURE 0x05
- #define HCI_ERR_KEY_MISSING 0x06
- #define HCI_ERR_MEMORY_FULL 0x07
- #define HCI_ERR_CONNECTION_TOUT 0x08
- #define HCI_ERR_MAX_NUM_OF_CONNECTIONS 0x09
- #define HCI_ERR_MAX_NUM_OF_SCOS 0x0A
- #define HCI_ERR_CONNECTION_EXISTS 0x0B
- #define HCI_ERR_COMMAND_DISALLOWED 0x0C
- #define HCI_ERR_HOST_REJECT_RESOURCES 0x0D
- #define HCI_ERR_HOST_REJECT_SECURITY 0x0E
- #define HCI_ERR_HOST_REJECT_DEVICE 0x0F
- #define HCI_ERR_HOST_TIMEOUT 0x10
- #define HCI_ERR_UNSUPPORTED_VALUE 0x11
- #define HCI_ERR_ILLEGAL_PARAMETER_FMT 0x12
- #define HCI_ERR_PEER_USER 0x13
- #define HCI_ERR_PEER_LOW_RESOURCES 0x14
- #define HCI_ERR_PEER_POWER_OFF 0x15
- #define HCI_ERR_CONN_CAUSE_LOCAL_HOST 0x16
- #define HCI_ERR_REPEATED_ATTEMPTS 0x17
- #define HCI_ERR_PAIRING_NOT_ALLOWED 0x18
- #define HCI_ERR_UNKNOWN_LMP_PDU 0x19
- #define HCI_ERR_UNSUPPORTED_REM_FEATURE 0x1A
- #define HCI_ERR_SCO_OFFSET_REJECTED 0x1B
- #define HCI_ERR_SCO_INTERVAL_REJECTED 0x1C
- #define HCI_ERR_SCO_AIR_MODE 0x1D
- #define HCI_ERR_INVALID_LMP_PARAM 0x1E
- #define HCI_ERR_UNSPECIFIED 0x1F
- #define HCI_ERR_UNSUPPORTED_LMP_FEATURE 0x20
- #define HCI_ERR_ROLE_CHANGE_NOT_ALLOWED 0x21
- #define HCI_ERR_LMP_RESPONSE_TIMEOUT 0x22
- #define HCI_ERR_LMP_ERR_TRANS_COLLISION 0x23
- #define HCI_ERR_LMP_PDU_NOT_ALLOWED 0x24
- #define HCI_ERR_ENCRY_MODE_NOT_ACCEPTABLE 0x25
- #define HCI_ERR_UNIT_KEY_USED 0x26
- #define HCI_ERR_QOS_NOT_SUPPORTED 0x27
- #define HCI_ERR_INSTANT_PASSED 0x28
- #define HCI_ERR_PAIRING_WITH_UNIT_KEY_NOT_SUPPORTED 0x29
- #define HCI_ERR_DIFF_TRANSACTION_COLLISION 0x2A
- #define HCI_ERR_UNDEFINED_0x2B 0x2B
- #define HCI_ERR_QOS_UNACCEPTABLE_PARAM 0x2C
- #define HCI_ERR_QOS_REJECTED 0x2D
- #define HCI_ERR_CHAN_CLASSIF_NOT_SUPPORTED 0x2E
- #define HCI_ERR_INSUFFCIENT_SECURITY 0x2F
- #define HCI_ERR_PARAM_OUT_OF_RANGE 0x30
- #define HCI_ERR_UNDEFINED_0x31 0x31
- #define HCI_ERR_ROLE_SWITCH_PENDING 0x32
- #define HCI_ERR_UNDEFINED_0x33 0x33
- #define HCI_ERR_RESERVED_SLOT_VIOLATION 0x34
- #define HCI_ERR_ROLE_SWITCH_FAILED 0x35
- #define HCI_ERR_INQ_RSP_DATA_TOO_LARGE 0x36
- #define HCI_ERR_SIMPLE_PAIRING_NOT_SUPPORTED 0x37
- #define HCI_ERR_HOST_BUSY_PAIRING 0x38
- #define HCI_ERR_REJ_NO_SUITABLE_CHANNEL 0x39
- #define HCI_ERR_CONTROLLER_BUSY 0x3A
- #define HCI_ERR_UNACCEPT_CONN_INTERVAL 0x3B
- #define HCI_ERR_DIRECTED_ADVERTISING_TIMEOUT 0x3C
- #define HCI_ERR_CONN_TOUT_DUE_TO_MIC_FAILURE 0x3D
- #define HCI_ERR_CONN_FAILED_ESTABLISHMENT 0x3E
- #define HCI_ERR_MAC_CONNECTION_FAILED 0x3F
- /* ConnectionLess Broadcast errors */
- #define HCI_ERR_LT_ADDR_ALREADY_IN_USE 0x40
- #define HCI_ERR_LT_ADDR_NOT_ALLOCATED 0x41
- #define HCI_ERR_CLB_NOT_ENABLED 0x42
- #define HCI_ERR_CLB_DATA_TOO_BIG 0x43
- #define HCI_ERR_MAX_ERR 0x43
- //ESP vendor error code
- #define HCI_ERR_ESP_VENDOR_FAIL 0xE0
- #define HCI_HINT_TO_RECREATE_AMP_PHYS_LINK 0xFF
- /*
- ** Definitions for HCI enable event
- */
- #define HCI_INQUIRY_COMPLETE_EV(p) (*((UINT32 *)(p)) & 0x00000001)
- #define HCI_INQUIRY_RESULT_EV(p) (*((UINT32 *)(p)) & 0x00000002)
- #define HCI_CONNECTION_COMPLETE_EV(p) (*((UINT32 *)(p)) & 0x00000004)
- #define HCI_CONNECTION_REQUEST_EV(p) (*((UINT32 *)(p)) & 0x00000008)
- #define HCI_DISCONNECTION_COMPLETE_EV(p) (*((UINT32 *)(p)) & 0x00000010)
- #define HCI_AUTHENTICATION_COMPLETE_EV(p) (*((UINT32 *)(p)) & 0x00000020)
- #define HCI_RMT_NAME_REQUEST_COMPL_EV(p) (*((UINT32 *)(p)) & 0x00000040)
- #define HCI_CHANGE_CONN_ENCRPT_ENABLE_EV(p) (*((UINT32 *)(p)) & 0x00000080)
- #define HCI_CHANGE_CONN_LINK_KEY_EV(p) (*((UINT32 *)(p)) & 0x00000100)
- #define HCI_MASTER_LINK_KEY_COMPLETE_EV(p) (*((UINT32 *)(p)) & 0x00000200)
- #define HCI_READ_RMT_FEATURES_COMPL_EV(p) (*((UINT32 *)(p)) & 0x00000400)
- #define HCI_READ_RMT_VERSION_COMPL_EV(p) (*((UINT32 *)(p)) & 0x00000800)
- #define HCI_QOS_SETUP_COMPLETE_EV(p) (*((UINT32 *)(p)) & 0x00001000)
- #define HCI_COMMAND_COMPLETE_EV(p) (*((UINT32 *)(p)) & 0x00002000)
- #define HCI_COMMAND_STATUS_EV(p) (*((UINT32 *)(p)) & 0x00004000)
- #define HCI_HARDWARE_ERROR_EV(p) (*((UINT32 *)(p)) & 0x00008000)
- #define HCI_FLASH_OCCURED_EV(p) (*((UINT32 *)(p)) & 0x00010000)
- #define HCI_ROLE_CHANGE_EV(p) (*((UINT32 *)(p)) & 0x00020000)
- #define HCI_NUM_COMPLETED_PKTS_EV(p) (*((UINT32 *)(p)) & 0x00040000)
- #define HCI_MODE_CHANGE_EV(p) (*((UINT32 *)(p)) & 0x00080000)
- #define HCI_RETURN_LINK_KEYS_EV(p) (*((UINT32 *)(p)) & 0x00100000)
- #define HCI_PIN_CODE_REQUEST_EV(p) (*((UINT32 *)(p)) & 0x00200000)
- #define HCI_LINK_KEY_REQUEST_EV(p) (*((UINT32 *)(p)) & 0x00400000)
- #define HCI_LINK_KEY_NOTIFICATION_EV(p) (*((UINT32 *)(p)) & 0x00800000)
- #define HCI_LOOPBACK_COMMAND_EV(p) (*((UINT32 *)(p)) & 0x01000000)
- #define HCI_DATA_BUF_OVERFLOW_EV(p) (*((UINT32 *)(p)) & 0x02000000)
- #define HCI_MAX_SLOTS_CHANGE_EV(p) (*((UINT32 *)(p)) & 0x04000000)
- #define HCI_READ_CLOCK_OFFSET_COMP_EV(p) (*((UINT32 *)(p)) & 0x08000000)
- #define HCI_CONN_PKT_TYPE_CHANGED_EV(p) (*((UINT32 *)(p)) & 0x10000000)
- #define HCI_QOS_VIOLATION_EV(p) (*((UINT32 *)(p)) & 0x20000000)
- #define HCI_PAGE_SCAN_MODE_CHANGED_EV(p) (*((UINT32 *)(p)) & 0x40000000)
- #define HCI_PAGE_SCAN_REP_MODE_CHNG_EV(p) (*((UINT32 *)(p)) & 0x80000000)
- /* the default event mask for 2.1+EDR (Lisbon) does not include Lisbon events */
- #define HCI_DEFAULT_EVENT_MASK_0 0xFFFFFFFF
- #define HCI_DEFAULT_EVENT_MASK_1 0x00001FFF
- /* the event mask for 2.0 + EDR and later (includes Lisbon events) */
- #define HCI_LISBON_EVENT_MASK_0 0xFFFFFFFF
- #define HCI_LISBON_EVENT_MASK_1 0x1DBFFFFF
- #define HCI_LISBON_EVENT_MASK "\x0D\xBF\xFF\xFF\xFF\xFF\xFF\xFF"
- #define HCI_LISBON_EVENT_MASK_EXT "\x1D\xBF\xFF\xFF\xFF\xFF\xFF\xFF"
- #define HCI_DUMO_EVENT_MASK_EXT "\x3D\xBF\xFF\xFF\xFF\xFF\xFF\xFF"
- /* 0x00001FFF FFFFFFFF Default - no Lisbon events
- 0x00000800 00000000 Synchronous Connection Complete Event
- 0x00001000 00000000 Synchronous Connection Changed Event
- 0x00002000 00000000 Sniff Subrate Event
- 0x00004000 00000000 Extended Inquiry Result Event
- 0x00008000 00000000 Encryption Key Refresh Complete Event
- 0x00010000 00000000 IO Capability Request Event
- 0x00020000 00000000 IO Capability Response Event
- 0x00040000 00000000 User Confirmation Request Event
- 0x00080000 00000000 User Passkey Request Event
- 0x00100000 00000000 Remote OOB Data Request Event
- 0x00200000 00000000 Simple Pairing Complete Event
- 0x00400000 00000000 Generic AMP Link Key Notification Event
- 0x00800000 00000000 Link Supervision Timeout Changed Event
- 0x01000000 00000000 Enhanced Flush Complete Event
- 0x04000000 00000000 User Passkey Notification Event
- 0x08000000 00000000 Keypress Notification Event
- 0x10000000 00000000 Remote Host Supported Features Notification Event
- 0x20000000 00000000 LE Meta Event
- */
- /* the event mask for AMP controllers */
- #define HCI_AMP_EVENT_MASK_3_0 "\x00\x00\x00\x00\x00\x00\x3F\xFF"
- /* 0x0000000000000000 No events specified (default)
- 0x0000000000000001 Physical Link Complete Event
- 0x0000000000000002 Channel Selected Event
- 0x0000000000000004 Disconnection Physical Link Event
- 0x0000000000000008 Physical Link Loss Early Warning Event
- 0x0000000000000010 Physical Link Recovery Event
- 0x0000000000000020 Logical Link Complete Event
- 0x0000000000000040 Disconnection Logical Link Complete Event
- 0x0000000000000080 Flow Spec Modify Complete Event
- 0x0000000000000100 Number of Completed Data Blocks Event
- 0x0000000000000200 AMP Start Test Event
- 0x0000000000000400 AMP Test End Event
- 0x0000000000000800 AMP Receiver Report Event
- 0x0000000000001000 Short Range Mode Change Complete Event
- 0x0000000000002000 AMP Status Change Event
- */
- /* the event mask page 2 (CLB + CSA4) for BR/EDR controller */
- #define HCI_PAGE_2_EVENT_MASK "\x00\x00\x00\x00\x00\x7F\xC0\x00"
- /* 0x0000000000004000 Triggered Clock Capture Event
- 0x0000000000008000 Sync Train Complete Event
- 0x0000000000010000 Sync Train Received Event
- 0x0000000000020000 Connectionless Broadcast Receive Event
- 0x0000000000040000 Connectionless Broadcast Timeout Event
- 0x0000000000080000 Truncated Page Complete Event
- 0x0000000000100000 Salve Page Response Timeout Event
- 0x0000000000200000 Connectionless Broadcast Channel Map Change Event
- 0x0000000000400000 Inquiry Response Notification Event
- */
- #if BLE_PRIVACY_SPT == TRUE
- /* BLE event mask */
- #define HCI_BLE_EVENT_MASK_DEF "\x00\x00\x00\x00\x00\x00\x07\xff"
- #else
- #define HCI_BLE_EVENT_MASK_DEF "\x00\x00\x00\x00\x00\x00\x00\x7f"
- #endif
- /*
- ** Definitions for packet type masks (BT1.2 and BT2.0 definitions)
- */
- #define HCI_PKT_TYPES_MASK_NO_2_DH1 0x0002
- #define HCI_PKT_TYPES_MASK_NO_3_DH1 0x0004
- #define HCI_PKT_TYPES_MASK_DM1 0x0008
- #define HCI_PKT_TYPES_MASK_DH1 0x0010
- #define HCI_PKT_TYPES_MASK_HV1 0x0020
- #define HCI_PKT_TYPES_MASK_HV2 0x0040
- #define HCI_PKT_TYPES_MASK_HV3 0x0080
- #define HCI_PKT_TYPES_MASK_NO_2_DH3 0x0100
- #define HCI_PKT_TYPES_MASK_NO_3_DH3 0x0200
- #define HCI_PKT_TYPES_MASK_DM3 0x0400
- #define HCI_PKT_TYPES_MASK_DH3 0x0800
- #define HCI_PKT_TYPES_MASK_NO_2_DH5 0x1000
- #define HCI_PKT_TYPES_MASK_NO_3_DH5 0x2000
- #define HCI_PKT_TYPES_MASK_DM5 0x4000
- #define HCI_PKT_TYPES_MASK_DH5 0x8000
- /* Packet type should be one of valid but at least one should be specified */
- #define HCI_VALID_SCO_PKT_TYPE(t) (((((t) & ~(HCI_PKT_TYPES_MASK_HV1 \
- | HCI_PKT_TYPES_MASK_HV2 \
- | HCI_PKT_TYPES_MASK_HV3)) == 0)) \
- && ((t) != 0))
- /* Packet type should not be invalid and at least one should be specified */
- #define HCI_VALID_ACL_PKT_TYPE(t) (((((t) & ~(HCI_PKT_TYPES_MASK_DM1 \
- | HCI_PKT_TYPES_MASK_DH1 \
- | HCI_PKT_TYPES_MASK_DM3 \
- | HCI_PKT_TYPES_MASK_DH3 \
- | HCI_PKT_TYPES_MASK_DM5 \
- | HCI_PKT_TYPES_MASK_DH5 \
- | HCI_PKT_TYPES_MASK_NO_2_DH1 \
- | HCI_PKT_TYPES_MASK_NO_3_DH1 \
- | HCI_PKT_TYPES_MASK_NO_2_DH3 \
- | HCI_PKT_TYPES_MASK_NO_3_DH3 \
- | HCI_PKT_TYPES_MASK_NO_2_DH5 \
- | HCI_PKT_TYPES_MASK_NO_3_DH5 )) == 0)) \
- && (((t) & (HCI_PKT_TYPES_MASK_DM1 \
- | HCI_PKT_TYPES_MASK_DH1 \
- | HCI_PKT_TYPES_MASK_DM3 \
- | HCI_PKT_TYPES_MASK_DH3 \
- | HCI_PKT_TYPES_MASK_DM5 \
- | HCI_PKT_TYPES_MASK_DH5)) != 0))
- /*
- ** Definitions for eSCO packet type masks (BT1.2 and BT2.0 definitions)
- */
- #define HCI_ESCO_PKT_TYPES_MASK_HV1 0x0001
- #define HCI_ESCO_PKT_TYPES_MASK_HV2 0x0002
- #define HCI_ESCO_PKT_TYPES_MASK_HV3 0x0004
- #define HCI_ESCO_PKT_TYPES_MASK_EV3 0x0008
- #define HCI_ESCO_PKT_TYPES_MASK_EV4 0x0010
- #define HCI_ESCO_PKT_TYPES_MASK_EV5 0x0020
- #define HCI_ESCO_PKT_TYPES_MASK_NO_2_EV3 0x0040
- #define HCI_ESCO_PKT_TYPES_MASK_NO_3_EV3 0x0080
- #define HCI_ESCO_PKT_TYPES_MASK_NO_2_EV5 0x0100
- #define HCI_ESCO_PKT_TYPES_MASK_NO_3_EV5 0x0200
- /* Packet type should be one of valid but at least one should be specified for 1.2 */
- #define HCI_VALID_ESCO_PKT_TYPE(t) (((((t) & ~(HCI_ESCO_PKT_TYPES_MASK_EV3 \
- | HCI_ESCO_PKT_TYPES_MASK_EV4 \
- | HCI_ESCO_PKT_TYPES_MASK_EV5)) == 0)) \
- && ((t) != 0))/* Packet type should be one of valid but at least one should be specified */
- #define HCI_VALID_ESCO_SCOPKT_TYPE(t) (((((t) & ~(HCI_ESCO_PKT_TYPES_MASK_HV1 \
- | HCI_ESCO_PKT_TYPES_MASK_HV2 \
- | HCI_ESCO_PKT_TYPES_MASK_HV3)) == 0)) \
- && ((t) != 0))
- #define HCI_VALID_SCO_ALL_PKT_TYPE(t) (((((t) & ~(HCI_ESCO_PKT_TYPES_MASK_HV1 \
- | HCI_ESCO_PKT_TYPES_MASK_HV2 \
- | HCI_ESCO_PKT_TYPES_MASK_HV3 \
- | HCI_ESCO_PKT_TYPES_MASK_EV3 \
- | HCI_ESCO_PKT_TYPES_MASK_EV4 \
- | HCI_ESCO_PKT_TYPES_MASK_EV5)) == 0)) \
- && ((t) != 0))
- /*
- ** Define parameters to allow role switch during create connection
- */
- #define HCI_CR_CONN_NOT_ALLOW_SWITCH 0x00
- #define HCI_CR_CONN_ALLOW_SWITCH 0x01
- /*
- ** Hold Mode command destination
- */
- #define HOLD_MODE_DEST_LOCAL_DEVICE 0x00
- #define HOLD_MODE_DEST_RMT_DEVICE 0x01
- /*
- ** Definitions for different HCI parameters
- */
- #define HCI_PER_INQ_MIN_MAX_PERIOD 0x0003
- #define HCI_PER_INQ_MAX_MAX_PERIOD 0xFFFF
- #define HCI_PER_INQ_MIN_MIN_PERIOD 0x0002
- #define HCI_PER_INQ_MAX_MIN_PERIOD 0xFFFE
- #define HCI_MAX_INQUIRY_LENGTH 0x30
- #define HCI_MIN_INQ_LAP 0x9E8B00
- #define HCI_MAX_INQ_LAP 0x9E8B3F
- /* HCI role defenitions */
- #define HCI_ROLE_MASTER 0x00
- #define HCI_ROLE_SLAVE 0x01
- #define HCI_ROLE_UNKNOWN 0xff
- /* HCI mode defenitions */
- #define HCI_MODE_ACTIVE 0x00
- #define HCI_MODE_HOLD 0x01
- #define HCI_MODE_SNIFF 0x02
- #define HCI_MODE_PARK 0x03
- /* HCI Flow Control Mode defenitions */
- #define HCI_PACKET_BASED_FC_MODE 0x00
- #define HCI_BLOCK_BASED_FC_MODE 0x01
- /* Define Packet types as requested by the Host */
- #define HCI_ACL_PKT_TYPE_NONE 0x0000
- #define HCI_ACL_PKT_TYPE_DM1 0x0008
- #define HCI_ACL_PKT_TYPE_DH1 0x0010
- #define HCI_ACL_PKT_TYPE_AUX1 0x0200
- #define HCI_ACL_PKT_TYPE_DM3 0x0400
- #define HCI_ACL_PKT_TYPE_DH3 0x0800
- #define HCI_ACL_PKT_TYPE_DM5 0x4000
- #define HCI_ACL_PKT_TYPE_DH5 0x8000
- /* Define key type in the Master Link Key command */
- #define HCI_USE_SEMI_PERMANENT_KEY 0x00
- #define HCI_USE_TEMPORARY_KEY 0x01
- /* Page scan period modes */
- #define HCI_PAGE_SCAN_REP_MODE_R0 0x00
- #define HCI_PAGE_SCAN_REP_MODE_R1 0x01
- #define HCI_PAGE_SCAN_REP_MODE_R2 0x02
- /* Define limits for page scan repetition modes */
- #define HCI_PAGE_SCAN_R1_LIMIT 0x0800
- #define HCI_PAGE_SCAN_R2_LIMIT 0x1000
- /* Page scan period modes */
- #define HCI_PAGE_SCAN_PER_MODE_P0 0x00
- #define HCI_PAGE_SCAN_PER_MODE_P1 0x01
- #define HCI_PAGE_SCAN_PER_MODE_P2 0x02
- /* Page scan modes */
- #define HCI_MANDATARY_PAGE_SCAN_MODE 0x00
- #define HCI_OPTIONAL_PAGE_SCAN_MODE1 0x01
- #define HCI_OPTIONAL_PAGE_SCAN_MODE2 0x02
- #define HCI_OPTIONAL_PAGE_SCAN_MODE3 0x03
- /* Page and inquiry scan types */
- #define HCI_SCAN_TYPE_STANDARD 0x00
- #define HCI_SCAN_TYPE_INTERLACED 0x01 /* 1.2 devices or later */
- #define HCI_DEF_SCAN_TYPE HCI_SCAN_TYPE_STANDARD
- /* Definitions for quality of service service types */
- #define HCI_SERVICE_NO_TRAFFIC 0x00
- #define HCI_SERVICE_BEST_EFFORT 0x01
- #define HCI_SERVICE_GUARANTEED 0x02
- #define HCI_QOS_LATENCY_DO_NOT_CARE 0xFFFFFFFF
- #define HCI_QOS_DELAY_DO_NOT_CARE 0xFFFFFFFF
- /* Definitions for Flow Specification */
- #define HCI_FLOW_SPEC_LATENCY_DO_NOT_CARE 0xFFFFFFFF
- /* Definitions for AFH Channel Map */
- #define HCI_AFH_CHANNEL_MAP_LEN 10
- /* Definitions for Extended Inquiry Response */
- #define HCI_EXT_INQ_RESPONSE_LEN 240
- #define HCI_EIR_FLAGS_TYPE BT_EIR_FLAGS_TYPE
- #define HCI_EIR_MORE_16BITS_UUID_TYPE BT_EIR_MORE_16BITS_UUID_TYPE
- #define HCI_EIR_COMPLETE_16BITS_UUID_TYPE BT_EIR_COMPLETE_16BITS_UUID_TYPE
- #define HCI_EIR_MORE_32BITS_UUID_TYPE BT_EIR_MORE_32BITS_UUID_TYPE
- #define HCI_EIR_COMPLETE_32BITS_UUID_TYPE BT_EIR_COMPLETE_32BITS_UUID_TYPE
- #define HCI_EIR_MORE_128BITS_UUID_TYPE BT_EIR_MORE_128BITS_UUID_TYPE
- #define HCI_EIR_COMPLETE_128BITS_UUID_TYPE BT_EIR_COMPLETE_128BITS_UUID_TYPE
- #define HCI_EIR_SHORTENED_LOCAL_NAME_TYPE BT_EIR_SHORTENED_LOCAL_NAME_TYPE
- #define HCI_EIR_COMPLETE_LOCAL_NAME_TYPE BT_EIR_COMPLETE_LOCAL_NAME_TYPE
- #define HCI_EIR_TX_POWER_LEVEL_TYPE BT_EIR_TX_POWER_LEVEL_TYPE
- #define HCI_EIR_MANUFACTURER_SPECIFIC_TYPE BT_EIR_MANUFACTURER_SPECIFIC_TYPE
- #define HCI_EIR_OOB_BD_ADDR_TYPE BT_EIR_OOB_BD_ADDR_TYPE
- #define HCI_EIR_OOB_COD_TYPE BT_EIR_OOB_COD_TYPE
- #define HCI_EIR_OOB_SSP_HASH_C_TYPE BT_EIR_OOB_SSP_HASH_C_TYPE
- #define HCI_EIR_OOB_SSP_RAND_R_TYPE BT_EIR_OOB_SSP_RAND_R_TYPE
- /* Definitions for Write Simple Pairing Mode */
- #define HCI_SP_MODE_UNDEFINED 0x00
- #define HCI_SP_MODE_ENABLED 0x01
- /* Definitions for Write Simple Pairing Debug Mode */
- #define HCI_SPD_MODE_DISABLED 0x00
- #define HCI_SPD_MODE_ENABLED 0x01
- /* Definitions for Write Secure Connections Host Support */
- #define HCI_SC_MODE_DISABLED 0x00
- #define HCI_SC_MODE_ENABLED 0x01
- /* Definitions for IO Capability Response/Command */
- #define HCI_IO_CAP_DISPLAY_ONLY 0x00
- #define HCI_IO_CAP_DISPLAY_YESNO 0x01
- #define HCI_IO_CAP_KEYBOARD_ONLY 0x02
- #define HCI_IO_CAP_NO_IO 0x03
- #define HCI_OOB_AUTH_DATA_NOT_PRESENT 0x00
- #define HCI_OOB_REM_AUTH_DATA_PRESENT 0x01
- #define HCI_MITM_PROTECT_NOT_REQUIRED 0x00
- #define HCI_MITM_PROTECT_REQUIRED 0x01
- /* Policy settings status */
- #define HCI_DISABLE_ALL_LM_MODES 0x0000
- #define HCI_ENABLE_MASTER_SLAVE_SWITCH 0x0001
- #define HCI_ENABLE_HOLD_MODE 0x0002
- #define HCI_ENABLE_SNIFF_MODE 0x0004
- #define HCI_ENABLE_PARK_MODE 0x0008
- /* By default allow switch, because host can not allow that */
- /* that until he created the connection */
- #define HCI_DEFAULT_POLICY_SETTINGS HCI_DISABLE_ALL_LM_MODES
- /* Filters that are sent in set filter command */
- #define HCI_FILTER_TYPE_CLEAR_ALL 0x00
- #define HCI_FILTER_INQUIRY_RESULT 0x01
- #define HCI_FILTER_CONNECTION_SETUP 0x02
- #define HCI_FILTER_COND_NEW_DEVICE 0x00
- #define HCI_FILTER_COND_DEVICE_CLASS 0x01
- #define HCI_FILTER_COND_BD_ADDR 0x02
- #define HCI_DO_NOT_AUTO_ACCEPT_CONNECT 1
- #define HCI_DO_AUTO_ACCEPT_CONNECT 2 /* role switch disabled */
- #define HCI_DO_AUTO_ACCEPT_CONNECT_RS 3 /* role switch enabled (1.1 errata 1115) */
- /* Auto accept flags */
- #define HCI_AUTO_ACCEPT_OFF 0x00
- #define HCI_AUTO_ACCEPT_ACL_CONNECTIONS 0x01
- #define HCI_AUTO_ACCEPT_SCO_CONNECTIONS 0x02
- /* PIN type */
- #define HCI_PIN_TYPE_VARIABLE 0
- #define HCI_PIN_TYPE_FIXED 1
- /* Loopback Modes */
- #define HCI_LOOPBACK_MODE_DISABLED 0
- #define HCI_LOOPBACK_MODE_LOCAL 1
- #define HCI_LOOPBACK_MODE_REMOTE 2
- #define SLOTS_PER_10MS 16 /* 0.625 ms slots in a 10 ms tick */
- /* Maximum connection accept timeout in 0.625msec */
- #define HCI_MAX_CONN_ACCEPT_TOUT 0xB540 /* 29 sec */
- #define HCI_DEF_CONN_ACCEPT_TOUT 0x1F40 /* 5 sec */
- /* Page timeout is used in LC only and LC is counting down slots not using OS */
- #define HCI_DEFAULT_PAGE_TOUT 0x2000 /* 5.12 sec (in slots) */
- /* Scan enable flags */
- #define HCI_NO_SCAN_ENABLED 0x00
- #define HCI_INQUIRY_SCAN_ENABLED 0x01
- #define HCI_PAGE_SCAN_ENABLED 0x02
- /* Pagescan timer definitions in 0.625 ms */
- #define HCI_MIN_PAGESCAN_INTERVAL 0x12 /* 11.25 ms */
- #define HCI_MAX_PAGESCAN_INTERVAL 0x1000 /* 2.56 sec */
- #define HCI_DEF_PAGESCAN_INTERVAL 0x0800 /* 1.28 sec */
- /* Parameter for pagescan window is passed to LC and is kept in slots */
- #define HCI_MIN_PAGESCAN_WINDOW 0x11 /* 10.625 ms */
- #define HCI_MAX_PAGESCAN_WINDOW 0x1000 /* 2.56 sec */
- #define HCI_DEF_PAGESCAN_WINDOW 0x12 /* 11.25 ms */
- /* Inquiryscan timer definitions in 0.625 ms */
- #define HCI_MIN_INQUIRYSCAN_INTERVAL 0x12 /* 11.25 ms */
- #define HCI_MAX_INQUIRYSCAN_INTERVAL 0x1000 /* 2.56 sec */
- #define HCI_DEF_INQUIRYSCAN_INTERVAL 0x1000 /* 2.56 sec */
- /* Parameter for inquiryscan window is passed to LC and is kept in slots */
- #define HCI_MIN_INQUIRYSCAN_WINDOW 0x11 /* 10.625 ms */
- #define HCI_MAX_INQUIRYSCAN_WINDOW 0x1000 /* 2.56 sec */
- #define HCI_DEF_INQUIRYSCAN_WINDOW 0x12 /* 11.25 ms */
- /* Encryption modes */
- #define HCI_ENCRYPT_MODE_DISABLED 0x00
- #define HCI_ENCRYPT_MODE_POINT_TO_POINT 0x01
- #define HCI_ENCRYPT_MODE_ALL 0x02
- /* Voice settings */
- #define HCI_INP_CODING_LINEAR 0x0000 /* 0000000000 */
- #define HCI_INP_CODING_U_LAW 0x0100 /* 0100000000 */
- #define HCI_INP_CODING_A_LAW 0x0200 /* 1000000000 */
- #define HCI_INP_CODING_MASK 0x0300 /* 1100000000 */
- #define HCI_INP_DATA_FMT_1S_COMPLEMENT 0x0000 /* 0000000000 */
- #define HCI_INP_DATA_FMT_2S_COMPLEMENT 0x0040 /* 0001000000 */
- #define HCI_INP_DATA_FMT_SIGN_MAGNITUDE 0x0080 /* 0010000000 */
- #define HCI_INP_DATA_FMT_UNSIGNED 0x00c0 /* 0011000000 */
- #define HCI_INP_DATA_FMT_MASK 0x00c0 /* 0011000000 */
- #define HCI_INP_SAMPLE_SIZE_8BIT 0x0000 /* 0000000000 */
- #define HCI_INP_SAMPLE_SIZE_16BIT 0x0020 /* 0000100000 */
- #define HCI_INP_SAMPLE_SIZE_MASK 0x0020 /* 0000100000 */
- #define HCI_INP_LINEAR_PCM_BIT_POS_MASK 0x001c /* 0000011100 */
- #define HCI_INP_LINEAR_PCM_BIT_POS_OFFS 2
- #define HCI_AIR_CODING_FORMAT_CVSD 0x0000 /* 0000000000 */
- #define HCI_AIR_CODING_FORMAT_U_LAW 0x0001 /* 0000000001 */
- #define HCI_AIR_CODING_FORMAT_A_LAW 0x0002 /* 0000000010 */
- #define HCI_AIR_CODING_FORMAT_TRANSPNT 0x0003 /* 0000000011 */
- #define HCI_AIR_CODING_FORMAT_MASK 0x0003 /* 0000000011 */
- /* default 0001100000 */
- #define HCI_DEFAULT_VOICE_SETTINGS (HCI_INP_CODING_LINEAR \
- | HCI_INP_DATA_FMT_2S_COMPLEMENT \
- | HCI_INP_SAMPLE_SIZE_16BIT \
- | HCI_AIR_CODING_FORMAT_CVSD)
- #define HCI_CVSD_SUPPORTED(x) (((x) & HCI_AIR_CODING_FORMAT_MASK) == HCI_AIR_CODING_FORMAT_CVSD)
- #define HCI_U_LAW_SUPPORTED(x) (((x) & HCI_AIR_CODING_FORMAT_MASK) == HCI_AIR_CODING_FORMAT_U_LAW)
- #define HCI_A_LAW_SUPPORTED(x) (((x) & HCI_AIR_CODING_FORMAT_MASK) == HCI_AIR_CODING_FORMAT_A_LAW)
- #define HCI_TRANSPNT_SUPPORTED(x) (((x) & HCI_AIR_CODING_FORMAT_MASK) == HCI_AIR_CODING_FORMAT_TRANSPNT)
- /* Retransmit timer definitions in 0.625 */
- #define HCI_MAX_AUTO_FLUSH_TOUT 0x07FF
- #define HCI_DEFAULT_AUTO_FLUSH_TOUT 0 /* No auto flush */
- /* Broadcast retransmitions */
- #define HCI_DEFAULT_NUM_BCAST_RETRAN 1
- /* Define broadcast data types as passed in the hci data packet */
- #define HCI_DATA_POINT_TO_POINT 0x00
- #define HCI_DATA_ACTIVE_BCAST 0x01
- #define HCI_DATA_PICONET_BCAST 0x02
- /* Hold mode activity */
- #define HCI_MAINTAIN_CUR_POWER_STATE 0x00
- #define HCI_SUSPEND_PAGE_SCAN 0x01
- #define HCI_SUSPEND_INQUIRY_SCAN 0x02
- #define HCI_SUSPEND_PERIODIC_INQUIRIES 0x04
- /* Default Link Supervision timeoout */
- #define HCI_DEFAULT_INACT_TOUT 0x7D00 /* BR/EDR (20 seconds) */
- #define HCI_DEFAULT_AMP_INACT_TOUT 0x3E80 /* AMP (10 seconds) */
- /* Read transmit power level parameter */
- #define HCI_READ_CURRENT 0x00
- #define HCI_READ_MAXIMUM 0x01
- /* Link types for connection complete event */
- #define HCI_LINK_TYPE_SCO 0x00
- #define HCI_LINK_TYPE_ACL 0x01
- #define HCI_LINK_TYPE_ESCO 0x02
- /* Link Key Notification Event (Key Type) definitions */
- #define HCI_LKEY_TYPE_COMBINATION 0x00
- #define HCI_LKEY_TYPE_LOCAL_UNIT 0x01
- #define HCI_LKEY_TYPE_REMOTE_UNIT 0x02
- #define HCI_LKEY_TYPE_DEBUG_COMB 0x03
- #define HCI_LKEY_TYPE_UNAUTH_COMB 0x04
- #define HCI_LKEY_TYPE_AUTH_COMB 0x05
- #define HCI_LKEY_TYPE_CHANGED_COMB 0x06
- #define HCI_LKEY_TYPE_UNAUTH_COMB_P_256 0x07
- #define HCI_LKEY_TYPE_AUTH_COMB_P_256 0x08
- /* Internal definitions - not used over HCI */
- #define HCI_LKEY_TYPE_AMP_WIFI 0x80
- #define HCI_LKEY_TYPE_AMP_UWB 0x81
- #define HCI_LKEY_TYPE_UNKNOWN 0xff
- /* Read Local Version HCI Version return values (Command Complete Event) */
- #define HCI_VERSION_1_0B 0x00
- #define HCI_VERSION_1_1 0x01
- /* Define an invalid value for a handle */
- #define HCI_INVALID_HANDLE 0xFFFF
- /* Define max ammount of data in the HCI command */
- #define HCI_COMMAND_SIZE 255
- /* Define the preamble length for all HCI Commands.
- ** This is 2-bytes for opcode and 1 byte for length
- */
- #define HCIC_PREAMBLE_SIZE 3
- /* Define the preamble length for all HCI Events
- ** This is 1-byte for opcode and 1 byte for length
- */
- #define HCIE_PREAMBLE_SIZE 2
- #define HCI_SCO_PREAMBLE_SIZE 3
- #define HCI_DATA_PREAMBLE_SIZE 4
- /* local Bluetooth controller id for AMP HCI */
- #define LOCAL_BR_EDR_CONTROLLER_ID 0
- /* controller id types for AMP HCI */
- #define HCI_CONTROLLER_TYPE_BR_EDR 0
- #define HCI_CONTROLLER_TYPE_802_11 1
- #define HCI_CONTROLLER_TYPE_ECMA 2
- #define HCI_MAX_CONTROLLER_TYPES 3
- /* ConnectionLess Broadcast */
- #define HCI_CLB_DISABLE 0x00
- #define HCI_CLB_ENABLE 0x01
- /* ConnectionLess Broadcast Data fragment */
- #define HCI_CLB_FRAGMENT_CONT 0x00
- #define HCI_CLB_FRAGMENT_START 0x01
- #define HCI_CLB_FRAGMENT_END 0x02
- #define HCI_CLB_FRAGMENT_SINGLE 0x03
- /* AMP Controller Status codes
- */
- #define HCI_AMP_CTRLR_PHYSICALLY_DOWN 0
- #define HCI_AMP_CTRLR_USABLE_BY_BT 1
- #define HCI_AMP_CTRLR_UNUSABLE_FOR_BT 2
- #define HCI_AMP_CTRLR_LOW_CAP_FOR_BT 3
- #define HCI_AMP_CTRLR_MED_CAP_FOR_BT 4
- #define HCI_AMP_CTRLR_HIGH_CAP_FOR_BT 5
- #define HCI_AMP_CTRLR_FULL_CAP_FOR_BT 6
- #define HCI_MAX_AMP_STATUS_TYPES 7
- /* Define the extended flow specification fields used by AMP */
- typedef struct {
- UINT8 id;
- UINT8 stype;
- UINT16 max_sdu_size;
- UINT32 sdu_inter_time;
- UINT32 access_latency;
- UINT32 flush_timeout;
- } tHCI_EXT_FLOW_SPEC;
- /* HCI message type definitions (for H4 messages) */
- #define HCIT_TYPE_COMMAND 1
- #define HCIT_TYPE_ACL_DATA 2
- #define HCIT_TYPE_SCO_DATA 3
- #define HCIT_TYPE_EVENT 4
- #define HCIT_TYPE_LM_DIAG 7
- #define HCIT_TYPE_NFC 16
- #define HCIT_LM_DIAG_LENGTH 63
- /* Parameter information for HCI_BRCM_SET_ACL_PRIORITY */
- #define HCI_BRCM_ACL_PRIORITY_PARAM_SIZE 3
- #define HCI_BRCM_ACL_PRIORITY_LOW 0x00
- #define HCI_BRCM_ACL_PRIORITY_HIGH 0xFF
- #define HCI_BRCM_SET_ACL_PRIORITY (0x0057 | HCI_GRP_VENDOR_SPECIFIC)
- /* Define values for LMP Test Control parameters
- ** Test Scenario, Hopping Mode, Power Control Mode
- */
- #define LMP_TESTCTL_TESTSC_PAUSE 0
- #define LMP_TESTCTL_TESTSC_TXTEST_0 1
- #define LMP_TESTCTL_TESTSC_TXTEST_1 2
- #define LMP_TESTCTL_TESTSC_TXTEST_1010 3
- #define LMP_TESTCTL_TESTSC_PSRND_BITSEQ 4
- #define LMP_TESTCTL_TESTSC_CLOSEDLB_ACL 5
- #define LMP_TESTCTL_TESTSC_CLOSEDLB_SCO 6
- #define LMP_TESTCTL_TESTSC_ACL_NOWHIT 7
- #define LMP_TESTCTL_TESTSC_SCO_NOWHIT 8
- #define LMP_TESTCTL_TESTSC_TXTEST_11110000 9
- #define LMP_TESTCTL_TESTSC_EXITTESTMODE 255
- #define LMP_TESTCTL_HOPMOD_RXTX1FREQ 0
- #define LMP_TESTCTL_HOPMOD_HOP_EURUSA 1
- #define LMP_TESTCTL_HOPMOD_HOP_JAPAN 2
- #define LMP_TESTCTL_HOPMOD_HOP_FRANCE 3
- #define LMP_TESTCTL_HOPMOD_HOP_SPAIN 4
- #define LMP_TESTCTL_HOPMOD_REDUCED_HOP 5
- #define LMP_TESTCTL_POWCTL_FIXEDTX_OP 0
- #define LMP_TESTCTL_POWCTL_ADAPTIVE 1
- // TODO(zachoverflow): remove this once broadcom specific hacks are removed
- #define LMP_COMPID_BROADCOM 15
- /*
- ** Define the packet types in the packet header, and a couple extra
- */
- #define PKT_TYPE_NULL 0x00
- #define PKT_TYPE_POLL 0x01
- #define PKT_TYPE_FHS 0x02
- #define PKT_TYPE_DM1 0x03
- #define PKT_TYPE_DH1 0x04
- #define PKT_TYPE_HV1 0x05
- #define PKT_TYPE_HV2 0x06
- #define PKT_TYPE_HV3 0x07
- #define PKT_TYPE_DV 0x08
- #define PKT_TYPE_AUX1 0x09
- #define PKT_TYPE_DM3 0x0a
- #define PKT_TYPE_DH3 0x0b
- #define PKT_TYPE_DM5 0x0e
- #define PKT_TYPE_DH5 0x0f
- #define PKT_TYPE_ID 0x10 /* Internally used packet types */
- #define PKT_TYPE_BAD 0x11
- #define PKT_TYPE_NONE 0x12
- /*
- ** Define packet size
- */
- #define HCI_DM1_PACKET_SIZE 17
- #define HCI_DH1_PACKET_SIZE 27
- #define HCI_DM3_PACKET_SIZE 121
- #define HCI_DH3_PACKET_SIZE 183
- #define HCI_DM5_PACKET_SIZE 224
- #define HCI_DH5_PACKET_SIZE 339
- #define HCI_AUX1_PACKET_SIZE 29
- #define HCI_HV1_PACKET_SIZE 10
- #define HCI_HV2_PACKET_SIZE 20
- #define HCI_HV3_PACKET_SIZE 30
- #define HCI_DV_PACKET_SIZE 9
- #define HCI_EDR2_DH1_PACKET_SIZE 54
- #define HCI_EDR2_DH3_PACKET_SIZE 367
- #define HCI_EDR2_DH5_PACKET_SIZE 679
- #define HCI_EDR3_DH1_PACKET_SIZE 83
- #define HCI_EDR3_DH3_PACKET_SIZE 552
- #define HCI_EDR3_DH5_PACKET_SIZE 1021
- /* Feature Pages */
- #define HCI_EXT_FEATURES_PAGE_0 0 /* Extended Feature Page 0 (regular features) */
- #define HCI_EXT_FEATURES_PAGE_1 1 /* Extended Feature Page 1 */
- #define HCI_EXT_FEATURES_PAGE_2 2 /* Extended Feature Page 2 */
- #define HCI_EXT_FEATURES_PAGE_MAX HCI_EXT_FEATURES_PAGE_2
- #define HCI_FEATURE_BYTES_PER_PAGE 8
- #define HCI_FEATURES_KNOWN(x) ((x[0] | x[1] | x[2] | x[3] | x[4] | x[5] | x[6] | x[7]) != 0)
- /*
- ** LMP features encoding - page 0
- */
- #define HCI_FEATURE_3_SLOT_PACKETS_MASK 0x01
- #define HCI_FEATURE_3_SLOT_PACKETS_OFF 0
- #define HCI_3_SLOT_PACKETS_SUPPORTED(x) ((x)[HCI_FEATURE_3_SLOT_PACKETS_OFF] & HCI_FEATURE_3_SLOT_PACKETS_MASK)
- #define HCI_FEATURE_5_SLOT_PACKETS_MASK 0x02
- #define HCI_FEATURE_5_SLOT_PACKETS_OFF 0
- #define HCI_5_SLOT_PACKETS_SUPPORTED(x) ((x)[HCI_FEATURE_5_SLOT_PACKETS_OFF] & HCI_FEATURE_5_SLOT_PACKETS_MASK)
- #define HCI_FEATURE_ENCRYPTION_MASK 0x04
- #define HCI_FEATURE_ENCRYPTION_OFF 0
- #define HCI_ENCRYPTION_SUPPORTED(x) ((x)[HCI_FEATURE_ENCRYPTION_OFF] & HCI_FEATURE_ENCRYPTION_MASK)
- #define HCI_FEATURE_SLOT_OFFSET_MASK 0x08
- #define HCI_FEATURE_SLOT_OFFSET_OFF 0
- #define HCI_SLOT_OFFSET_SUPPORTED(x) ((x)[HCI_FEATURE_SLOT_OFFSET_OFF] & HCI_FEATURE_SLOT_OFFSET_MASK)
- #define HCI_FEATURE_TIMING_ACC_MASK 0x10
- #define HCI_FEATURE_TIMING_ACC_OFF 0
- #define HCI_TIMING_ACC_SUPPORTED(x) ((x)[HCI_FEATURE_TIMING_ACC_OFF] & HCI_FEATURE_TIMING_ACC_MASK)
- #define HCI_FEATURE_SWITCH_MASK 0x20
- #define HCI_FEATURE_SWITCH_OFF 0
- // temporarily disable ROLE_SWITCH since there is an issue to be fixed
- #define HCI_SWITCH_SUPPORTED(x) (0 & ((x)[HCI_FEATURE_SWITCH_OFF] & HCI_FEATURE_SWITCH_MASK))
- #define HCI_FEATURE_HOLD_MODE_MASK 0x40
- #define HCI_FEATURE_HOLD_MODE_OFF 0
- #define HCI_HOLD_MODE_SUPPORTED(x) ((x)[HCI_FEATURE_HOLD_MODE_OFF] & HCI_FEATURE_HOLD_MODE_MASK)
- #define HCI_FEATURE_SNIFF_MODE_MASK 0x80
- #define HCI_FEATURE_SNIFF_MODE_OFF 0
- #define HCI_SNIFF_MODE_SUPPORTED(x) ((x)[HCI_FEATURE_SNIFF_MODE_OFF] & HCI_FEATURE_SNIFF_MODE_MASK)
- #define HCI_FEATURE_PARK_MODE_MASK 0x01
- #define HCI_FEATURE_PARK_MODE_OFF 1
- #define HCI_PARK_MODE_SUPPORTED(x) ((x)[HCI_FEATURE_PARK_MODE_OFF] & HCI_FEATURE_PARK_MODE_MASK)
- #define HCI_FEATURE_RSSI_MASK 0x02
- #define HCI_FEATURE_RSSI_OFF 1
- #define HCI_RSSI_SUPPORTED(x) ((x)[HCI_FEATURE_RSSI_OFF] & HCI_FEATURE_RSSI_MASK)
- #define HCI_FEATURE_CQM_DATA_RATE_MASK 0x04
- #define HCI_FEATURE_CQM_DATA_RATE_OFF 1
- #define HCI_CQM_DATA_RATE_SUPPORTED(x) ((x)[HCI_FEATURE_CQM_DATA_RATE_OFF] & HCI_FEATURE_CQM_DATA_RATE_MASK)
- #define HCI_FEATURE_SCO_LINK_MASK 0x08
- #define HCI_FEATURE_SCO_LINK_OFF 1
- #define HCI_SCO_LINK_SUPPORTED(x) ((x)[HCI_FEATURE_SCO_LINK_OFF] & HCI_FEATURE_SCO_LINK_MASK)
- #define HCI_FEATURE_HV2_PACKETS_MASK 0x10
- #define HCI_FEATURE_HV2_PACKETS_OFF 1
- #define HCI_HV2_PACKETS_SUPPORTED(x) ((x)[HCI_FEATURE_HV2_PACKETS_OFF] & HCI_FEATURE_HV2_PACKETS_MASK)
- #define HCI_FEATURE_HV3_PACKETS_MASK 0x20
- #define HCI_FEATURE_HV3_PACKETS_OFF 1
- #define HCI_HV3_PACKETS_SUPPORTED(x) ((x)[HCI_FEATURE_HV3_PACKETS_OFF] & HCI_FEATURE_HV3_PACKETS_MASK)
- #define HCI_FEATURE_U_LAW_MASK 0x40
- #define HCI_FEATURE_U_LAW_OFF 1
- #define HCI_LMP_U_LAW_SUPPORTED(x) ((x)[HCI_FEATURE_U_LAW_OFF] & HCI_FEATURE_U_LAW_MASK)
- #define HCI_FEATURE_A_LAW_MASK 0x80
- #define HCI_FEATURE_A_LAW_OFF 1
- #define HCI_LMP_A_LAW_SUPPORTED(x) ((x)[HCI_FEATURE_A_LAW_OFF] & HCI_FEATURE_A_LAW_MASK)
- #define HCI_FEATURE_CVSD_MASK 0x01
- #define HCI_FEATURE_CVSD_OFF 2
- #define HCI_LMP_CVSD_SUPPORTED(x) ((x)[HCI_FEATURE_CVSD_OFF] & HCI_FEATURE_CVSD_MASK)
- #define HCI_FEATURE_PAGING_SCHEME_MASK 0x02
- #define HCI_FEATURE_PAGING_SCHEME_OFF 2
- #define HCI_PAGING_SCHEME_SUPPORTED(x) ((x)[HCI_FEATURE_PAGING_SCHEME_OFF] & HCI_FEATURE_PAGING_SCHEME_MASK)
- #define HCI_FEATURE_POWER_CTRL_MASK 0x04
- #define HCI_FEATURE_POWER_CTRL_OFF 2
- #define HCI_POWER_CTRL_SUPPORTED(x) ((x)[HCI_FEATURE_POWER_CTRL_OFF] & HCI_FEATURE_POWER_CTRL_MASK)
- #define HCI_FEATURE_TRANSPNT_MASK 0x08
- #define HCI_FEATURE_TRANSPNT_OFF 2
- #define HCI_LMP_TRANSPNT_SUPPORTED(x) ((x)[HCI_FEATURE_TRANSPNT_OFF] & HCI_FEATURE_TRANSPNT_MASK)
- #define HCI_FEATURE_FLOW_CTRL_LAG_MASK 0x70
- #define HCI_FEATURE_FLOW_CTRL_LAG_OFF 2
- #define HCI_FLOW_CTRL_LAG_VALUE(x) (((x)[HCI_FEATURE_FLOW_CTRL_LAG_OFF] & HCI_FEATURE_FLOW_CTRL_LAG_MASK) >> 4)
- #define HCI_FEATURE_BROADCAST_ENC_MASK 0x80
- #define HCI_FEATURE_BROADCAST_ENC_OFF 2
- #define HCI_LMP_BCAST_ENC_SUPPORTED(x) ((x)[HCI_FEATURE_BROADCAST_ENC_OFF] & HCI_FEATURE_BROADCAST_ENC_MASK)
- #define HCI_FEATURE_SCATTER_MODE_MASK 0x01
- #define HCI_FEATURE_SCATTER_MODE_OFF 3
- #define HCI_LMP_SCATTER_MODE_SUPPORTED(x) ((x)[HCI_FEATURE_SCATTER_MODE_OFF] & HCI_FEATURE_SCATTER_MODE_MASK)
- #define HCI_FEATURE_EDR_ACL_2MPS_MASK 0x02
- #define HCI_FEATURE_EDR_ACL_2MPS_OFF 3
- #define HCI_EDR_ACL_2MPS_SUPPORTED(x) ((x)[HCI_FEATURE_EDR_ACL_2MPS_OFF] & HCI_FEATURE_EDR_ACL_2MPS_MASK)
- #define HCI_FEATURE_EDR_ACL_3MPS_MASK 0x04
- #define HCI_FEATURE_EDR_ACL_3MPS_OFF 3
- #define HCI_EDR_ACL_3MPS_SUPPORTED(x) ((x)[HCI_FEATURE_EDR_ACL_3MPS_OFF] & HCI_FEATURE_EDR_ACL_3MPS_MASK)
- #define HCI_FEATURE_ENHANCED_INQ_MASK 0x08
- #define HCI_FEATURE_ENHANCED_INQ_OFF 3
- #define HCI_ENHANCED_INQ_SUPPORTED(x) ((x)[HCI_FEATURE_ENHANCED_INQ_OFF] & HCI_FEATURE_ENHANCED_INQ_MASK)
- #define HCI_FEATURE_INTERLACED_INQ_SCAN_MASK 0x10
- #define HCI_FEATURE_INTERLACED_INQ_SCAN_OFF 3
- #define HCI_LMP_INTERLACED_INQ_SCAN_SUPPORTED(x) ((x)[HCI_FEATURE_INTERLACED_INQ_SCAN_OFF] & HCI_FEATURE_INTERLACED_INQ_SCAN_MASK)
- #define HCI_FEATURE_INTERLACED_PAGE_SCAN_MASK 0x20
- #define HCI_FEATURE_INTERLACED_PAGE_SCAN_OFF 3
- #define HCI_LMP_INTERLACED_PAGE_SCAN_SUPPORTED(x) ((x)[HCI_FEATURE_INTERLACED_PAGE_SCAN_OFF] & HCI_FEATURE_INTERLACED_PAGE_SCAN_MASK)
- #define HCI_FEATURE_INQ_RSSI_MASK 0x40
- #define HCI_FEATURE_INQ_RSSI_OFF 3
- #define HCI_LMP_INQ_RSSI_SUPPORTED(x) ((x)[HCI_FEATURE_INQ_RSSI_OFF] & HCI_FEATURE_INQ_RSSI_MASK)
- #define HCI_FEATURE_ESCO_EV3_MASK 0x80
- #define HCI_FEATURE_ESCO_EV3_OFF 3
- #define HCI_ESCO_EV3_SUPPORTED(x) ((x)[HCI_FEATURE_ESCO_EV3_OFF] & HCI_FEATURE_ESCO_EV3_MASK)
- #define HCI_FEATURE_ESCO_EV4_MASK 0x01
- #define HCI_FEATURE_ESCO_EV4_OFF 4
- #define HCI_ESCO_EV4_SUPPORTED(x) ((x)[HCI_FEATURE_ESCO_EV4_OFF] & HCI_FEATURE_ESCO_EV4_MASK)
- #define HCI_FEATURE_ESCO_EV5_MASK 0x02
- #define HCI_FEATURE_ESCO_EV5_OFF 4
- #define HCI_ESCO_EV5_SUPPORTED(x) ((x)[HCI_FEATURE_ESCO_EV5_OFF] & HCI_FEATURE_ESCO_EV5_MASK)
- #define HCI_FEATURE_ABSENCE_MASKS_MASK 0x04
- #define HCI_FEATURE_ABSENCE_MASKS_OFF 4
- #define HCI_LMP_ABSENCE_MASKS_SUPPORTED(x) ((x)[HCI_FEATURE_ABSENCE_MASKS_OFF] & HCI_FEATURE_ABSENCE_MASKS_MASK)
- #define HCI_FEATURE_AFH_CAP_SLAVE_MASK 0x08
- #define HCI_FEATURE_AFH_CAP_SLAVE_OFF 4
- #define HCI_LMP_AFH_CAP_SLAVE_SUPPORTED(x) ((x)[HCI_FEATURE_AFH_CAP_SLAVE_OFF] & HCI_FEATURE_AFH_CAP_SLAVE_MASK)
- #define HCI_FEATURE_AFH_CLASS_SLAVE_MASK 0x10
- #define HCI_FEATURE_AFH_CLASS_SLAVE_OFF 4
- #define HCI_LMP_AFH_CLASS_SLAVE_SUPPORTED(x) ((x)[HCI_FEATURE_AFH_CLASS_SLAVE_OFF] & HCI_FEATURE_AFH_CLASS_SLAVE_MASK)
- #if 1
- #define HCI_FEATURE_BREDR_NOT_SPT_MASK 0x20
- #define HCI_FEATURE_BREDR_NOT_SPT_OFF 4
- #define HCI_BREDR_NOT_SPT_SUPPORTED(x) ((x)[HCI_FEATURE_BREDR_NOT_SPT_OFF] & HCI_FEATURE_BREDR_NOT_SPT_MASK)
- #define HCI_FEATURE_LE_SPT_MASK 0x40
- #define HCI_FEATURE_LE_SPT_OFF 4
- #define HCI_LE_SPT_SUPPORTED(x) ((x)[HCI_FEATURE_LE_SPT_OFF] & HCI_FEATURE_LE_SPT_MASK)
- #else
- #define HCI_FEATURE_ALIAS_AUTH_MASK 0x20
- #define HCI_FEATURE_ALIAS_AUTH_OFF 4
- #define HCI_LMP_ALIAS_AUTH_SUPPORTED(x) ((x)[HCI_FEATURE_ALIAS_AUTH_OFF] & HCI_FEATURE_ALIAS_AUTH_MASK)
- #define HCI_FEATURE_ANON_MODE_MASK 0x40
- #define HCI_FEATURE_ANON_MODE_OFF 4
- #define HCI_LMP_ANON_MODE_SUPPORTED(x) ((x)[HCI_FEATURE_ANON_MODE_OFF] & HCI_FEATURE_ANON_MODE_MASK)
- #endif
- #define HCI_FEATURE_3_SLOT_EDR_ACL_MASK 0x80
- #define HCI_FEATURE_3_SLOT_EDR_ACL_OFF 4
- #define HCI_3_SLOT_EDR_ACL_SUPPORTED(x) ((x)[HCI_FEATURE_3_SLOT_EDR_ACL_OFF] & HCI_FEATURE_3_SLOT_EDR_ACL_MASK)
- #define HCI_FEATURE_5_SLOT_EDR_ACL_MASK 0x01
- #define HCI_FEATURE_5_SLOT_EDR_ACL_OFF 5
- #define HCI_5_SLOT_EDR_ACL_SUPPORTED(x) ((x)[HCI_FEATURE_5_SLOT_EDR_ACL_OFF] & HCI_FEATURE_5_SLOT_EDR_ACL_MASK)
- #define HCI_FEATURE_SNIFF_SUB_RATE_MASK 0x02
- #define HCI_FEATURE_SNIFF_SUB_RATE_OFF 5
- #define HCI_SNIFF_SUB_RATE_SUPPORTED(x) ((x)[HCI_FEATURE_SNIFF_SUB_RATE_OFF] & HCI_FEATURE_SNIFF_SUB_RATE_MASK)
- #define HCI_FEATURE_ATOMIC_ENCRYPT_MASK 0x04
- #define HCI_FEATURE_ATOMIC_ENCRYPT_OFF 5
- #define HCI_ATOMIC_ENCRYPT_SUPPORTED(x) ((x)[HCI_FEATURE_ATOMIC_ENCRYPT_OFF] & HCI_FEATURE_ATOMIC_ENCRYPT_MASK)
- #define HCI_FEATURE_AFH_CAP_MASTR_MASK 0x08
- #define HCI_FEATURE_AFH_CAP_MASTR_OFF 5
- #define HCI_LMP_AFH_CAP_MASTR_SUPPORTED(x) ((x)[HCI_FEATURE_AFH_CAP_MASTR_OFF] & HCI_FEATURE_AFH_CAP_MASTR_MASK)
- #define HCI_FEATURE_AFH_CLASS_MASTR_MASK 0x10
- #define HCI_FEATURE_AFH_CLASS_MASTR_OFF 5
- #define HCI_LMP_AFH_CLASS_MASTR_SUPPORTED(x) ((x)[HCI_FEATURE_AFH_CLASS_MASTR_OFF] & HCI_FEATURE_AFH_CLASS_MASTR_MASK)
- #define HCI_FEATURE_EDR_ESCO_2MPS_MASK 0x20
- #define HCI_FEATURE_EDR_ESCO_2MPS_OFF 5
- #define HCI_EDR_ESCO_2MPS_SUPPORTED(x) ((x)[HCI_FEATURE_EDR_ESCO_2MPS_OFF] & HCI_FEATURE_EDR_ESCO_2MPS_MASK)
- #define HCI_FEATURE_EDR_ESCO_3MPS_MASK 0x40
- #define HCI_FEATURE_EDR_ESCO_3MPS_OFF 5
- #define HCI_EDR_ESCO_3MPS_SUPPORTED(x) ((x)[HCI_FEATURE_EDR_ESCO_3MPS_OFF] & HCI_FEATURE_EDR_ESCO_3MPS_MASK)
- #define HCI_FEATURE_3_SLOT_EDR_ESCO_MASK 0x80
- #define HCI_FEATURE_3_SLOT_EDR_ESCO_OFF 5
- #define HCI_3_SLOT_EDR_ESCO_SUPPORTED(x) ((x)[HCI_FEATURE_3_SLOT_EDR_ESCO_OFF] & HCI_FEATURE_3_SLOT_EDR_ESCO_MASK)
- #define HCI_FEATURE_EXT_INQ_RSP_MASK 0x01
- #define HCI_FEATURE_EXT_INQ_RSP_OFF 6
- #define HCI_EXT_INQ_RSP_SUPPORTED(x) ((x)[HCI_FEATURE_EXT_INQ_RSP_OFF] & HCI_FEATURE_EXT_INQ_RSP_MASK)
- #if 1 /* TOKYO spec definition */
- #define HCI_FEATURE_SIMUL_LE_BREDR_MASK 0x02
- #define HCI_FEATURE_SIMUL_LE_BREDR_OFF 6
- #define HCI_SIMUL_LE_BREDR_SUPPORTED(x) ((x)[HCI_FEATURE_SIMUL_LE_BREDR_OFF] & HCI_FEATURE_SIMUL_LE_BREDR_MASK)
- #else
- #define HCI_FEATURE_ANUM_PIN_AWARE_MASK 0x02
- #define HCI_FEATURE_ANUM_PIN_AWARE_OFF 6
- #define HCI_ANUM_PIN_AWARE_SUPPORTED(x) ((x)[HCI_FEATURE_ANUM_PIN_AWARE_OFF] & HCI_FEATURE_ANUM_PIN_AWARE_MASK)
- #endif
- #define HCI_FEATURE_ANUM_PIN_CAP_MASK 0x04
- #define HCI_FEATURE_ANUM_PIN_CAP_OFF 6
- #define HCI_ANUM_PIN_CAP_SUPPORTED(x) ((x)[HCI_FEATURE_ANUM_PIN_CAP_OFF] & HCI_FEATURE_ANUM_PIN_CAP_MASK)
- #define HCI_FEATURE_SIMPLE_PAIRING_MASK 0x08
- #define HCI_FEATURE_SIMPLE_PAIRING_OFF 6
- #define HCI_SIMPLE_PAIRING_SUPPORTED(x) ((x)[HCI_FEATURE_SIMPLE_PAIRING_OFF] & HCI_FEATURE_SIMPLE_PAIRING_MASK)
- #define HCI_FEATURE_ENCAP_PDU_MASK 0x10
- #define HCI_FEATURE_ENCAP_PDU_OFF 6
- #define HCI_ENCAP_PDU_SUPPORTED(x) ((x)[HCI_FEATURE_ENCAP_PDU_OFF] & HCI_FEATURE_ENCAP_PDU_MASK)
- #define HCI_FEATURE_ERROR_DATA_MASK 0x20
- #define HCI_FEATURE_ERROR_DATA_OFF 6
- #define HCI_ERROR_DATA_SUPPORTED(x) ((x)[HCI_FEATURE_ERROR_DATA_OFF] & HCI_FEATURE_ERROR_DATA_MASK)
- #define HCI_FEATURE_NON_FLUSHABLE_PB_MASK 0x40
- #define HCI_FEATURE_NON_FLUSHABLE_PB_OFF 6
- /* This feature is causing frequent link drops when doing call switch with certain av/hfp headsets */
- #define HCI_NON_FLUSHABLE_PB_SUPPORTED(x) (0)//((x)[HCI_FEATURE_NON_FLUSHABLE_PB_OFF] & HCI_FEATURE_NON_FLUSHABLE_PB_MASK)
- #define HCI_FEATURE_LINK_SUP_TO_EVT_MASK 0x01
- #define HCI_FEATURE_LINK_SUP_TO_EVT_OFF 7
- #define HCI_LINK_SUP_TO_EVT_SUPPORTED(x) ((x)[HCI_FEATURE_LINK_SUP_TO_EVT_OFF] & HCI_FEATURE_LINK_SUP_TO_EVT_MASK)
- #define HCI_FEATURE_INQ_RESP_TX_MASK 0x02
- #define HCI_FEATURE_INQ_RESP_TX_OFF 7
- #define HCI_INQ_RESP_TX_SUPPORTED(x) ((x)[HCI_FEATURE_INQ_RESP_TX_OFF] & HCI_FEATURE_INQ_RESP_TX_MASK)
- #define HCI_FEATURE_EXTENDED_MASK 0x80
- #define HCI_FEATURE_EXTENDED_OFF 7
- #define HCI_LMP_EXTENDED_SUPPORTED(x) ((x)[HCI_FEATURE_EXTENDED_OFF] & HCI_FEATURE_EXTENDED_MASK)
- /*
- ** LMP features encoding - page 1
- */
- #define HCI_EXT_FEATURE_SSP_HOST_MASK 0x01
- #define HCI_EXT_FEATURE_SSP_HOST_OFF 0
- #define HCI_SSP_HOST_SUPPORTED(x) ((x)[HCI_EXT_FEATURE_SSP_HOST_OFF] & HCI_EXT_FEATURE_SSP_HOST_MASK)
- #define HCI_EXT_FEATURE_LE_HOST_MASK 0x02
- #define HCI_EXT_FEATURE_LE_HOST_OFF 0
- #define HCI_LE_HOST_SUPPORTED(x) ((x)[HCI_EXT_FEATURE_LE_HOST_OFF] & HCI_EXT_FEATURE_LE_HOST_MASK)
- #define HCI_EXT_FEATURE_SIMUL_DUMO_HOST_MASK 0x04
- #define HCI_EXT_FEATURE_SIMUL_DUMO_HOST_OFF 0
- #define HCI_SIMUL_DUMO_HOST_SUPPORTED(x) ((x)[HCI_EXT_FEATURE_SIMUL_DUMO_HOST_OFF] & HCI_EXT_FEATURE_SIMUL_DUMO_HOST_MASK)
- #define HCI_EXT_FEATURE_SC_HOST_MASK 0x08
- #define HCI_EXT_FEATURE_SC_HOST_OFF 0
- #define HCI_SC_HOST_SUPPORTED(x) ((x)[HCI_EXT_FEATURE_SC_HOST_OFF] & HCI_EXT_FEATURE_SC_HOST_MASK)
- /*
- ** LMP features encoding - page 2
- */
- #define HCI_EXT_FEATURE_CSB_MASTER_MASK 0x01
- #define HCI_EXT_FEATURE_CSB_MASTER_OFF 0
- #define HCI_CSB_MASTER_SUPPORTED(x) ((x)[HCI_EXT_FEATURE_CSB_MASTER_OFF] & HCI_EXT_FEATURE_CSB_MASTER_MASK)
- #define HCI_EXT_FEATURE_CSB_SLAVE_MASK 0x02
- #define HCI_EXT_FEATURE_CSB_SLAVE_OFF 0
- #define HCI_CSB_SLAVE_SUPPORTED(x) ((x)[HCI_EXT_FEATURE_CSB_SLAVE_OFF] & HCI_EXT_FEATURE_CSB_SLAVE_MASK)
- #define HCI_EXT_FEATURE_SYNC_TRAIN_MASTER_MASK 0x04
- #define HCI_EXT_FEATURE_SYNC_TRAIN_MASTER_OFF 0
- #define HCI_SYNC_TRAIN_MASTER_SUPPORTED(x) ((x)[HCI_EXT_FEATURE_SYNC_TRAIN_MASTER_OFF] & HCI_EXT_FEATURE_SYNC_TRAIN_MASTER_MASK)
- #define HCI_EXT_FEATURE_SYNC_SCAN_SLAVE_MASK 0x08
- #define HCI_EXT_FEATURE_SYNC_SCAN_SLAVE_OFF 0
- #define HCI_SYNC_SCAN_SLAVE_SUPPORTED(x) ((x)[HCI_EXT_FEATURE_SYNC_SCAN_SLAVE_OFF] & HCI_EXT_FEATURE_SYNC_SCAN_SLAVE_MASK)
- #define HCI_EXT_FEATURE_INQ_RESP_NOTIF_MASK 0x10
- #define HCI_EXT_FEATURE_INQ_RESP_NOTIF_OFF 0
- #define HCI_INQ_RESP_NOTIF_SUPPORTED(x) ((x)[HCI_EXT_FEATURE_INQ_RESP_NOTIF_OFF] & HCI_EXT_FEATURE_INQ_RESP_NOTIF_MASK)
- #define HCI_EXT_FEATURE_SC_CTRLR_MASK 0x01
- #define HCI_EXT_FEATURE_SC_CTRLR_OFF 1
- #define HCI_SC_CTRLR_SUPPORTED(x) ((x)[HCI_EXT_FEATURE_SC_CTRLR_OFF] & HCI_EXT_FEATURE_SC_CTRLR_MASK)
- #define HCI_EXT_FEATURE_PING_MASK 0x02
- #define HCI_EXT_FEATURE_PING_OFF 1
- #define HCI_PING_SUPPORTED(x) ((x)[HCI_EXT_FEATURE_PING_OFF] & HCI_EXT_FEATURE_PING_MASK)
- /*
- ** LE features encoding - page 0 (the only page for now)
- */
- /* LE Encryption */
- #define HCI_LE_FEATURE_LE_ENCRYPTION_MASK 0x01
- #define HCI_LE_FEATURE_LE_ENCRYPTION_OFF 0
- #define HCI_LE_ENCRYPTION_SUPPORTED(x) ((x)[HCI_LE_FEATURE_LE_ENCRYPTION_OFF] & HCI_LE_FEATURE_LE_ENCRYPTION_MASK)
- /* Connection Parameters Request Procedure */
- #define HCI_LE_FEATURE_CONN_PARAM_REQ_MASK 0x02
- #define HCI_LE_FEATURE_CONN_PARAM_REQ_OFF 0
- #define HCI_LE_CONN_PARAM_REQ_SUPPORTED(x) ((x)[HCI_LE_FEATURE_CONN_PARAM_REQ_OFF] & HCI_LE_FEATURE_CONN_PARAM_REQ_MASK)
- /* Extended Reject Indication */
- #define HCI_LE_FEATURE_EXT_REJ_IND_MASK 0x04
- #define HCI_LE_FEATURE_EXT_REJ_IND_OFF 0
- #define HCI_LE_EXT_REJ_IND_SUPPORTED(x) ((x)[HCI_LE_FEATURE_EXT_REJ_IND_OFF] & HCI_LE_FEATURE_EXT_REJ_IND_MASK)
- /* Slave-initiated Features Exchange */
- #define HCI_LE_FEATURE_SLAVE_INIT_FEAT_EXC_MASK 0x08
- #define HCI_LE_FEATURE_SLAVE_INIT_FEAT_EXC_OFF 0
- #define HCI_LE_SLAVE_INIT_FEAT_EXC_SUPPORTED(x) ((x)[HCI_LE_FEATURE_SLAVE_INIT_FEAT_EXC_OFF] & HCI_LE_FEATURE_SLAVE_INIT_FEAT_EXC_MASK)
- /* Enhanced privacy Feature: bit 6 */
- #define HCI_LE_FEATURE_ENHANCED_PRIVACY_MASK 0x40
- #define HCI_LE_FEATURE_ENHANCED_PRIVACY_OFF 0
- #define HCI_LE_ENHANCED_PRIVACY_SUPPORTED(x) ((x)[HCI_LE_FEATURE_ENHANCED_PRIVACY_OFF] & HCI_LE_FEATURE_ENHANCED_PRIVACY_MASK)
- /* Extended scanner filter policy : 7 */
- #define HCI_LE_FEATURE_EXT_SCAN_FILTER_POLICY_MASK 0x80
- #define HCI_LE_FEATURE_EXT_SCAN_FILTER_POLICY_OFF 0
- #define HCI_LE_EXT_SCAN_FILTER_POLICY_SUPPORTED(x) ((x)[HCI_LE_FEATURE_EXT_SCAN_FILTER_POLICY_OFF] & HCI_LE_FEATURE_EXT_SCAN_FILTER_POLICY_MASK)
- /* Slave-initiated Features Exchange */
- #define HCI_LE_FEATURE_DATA_LEN_EXT_MASK 0x20
- #define HCI_LE_FEATURE_DATA_LEN_EXT_OFF 0
- #define HCI_LE_DATA_LEN_EXT_SUPPORTED(x) ((x)[HCI_LE_FEATURE_DATA_LEN_EXT_OFF] & HCI_LE_FEATURE_DATA_LEN_EXT_MASK)
- /*
- ** Local Supported Commands encoding
- */
- #define HCI_NUM_SUPP_COMMANDS_BYTES 64
- /* Supported Commands Byte 0 */
- #define HCI_SUPP_COMMANDS_INQUIRY_MASK 0x01
- #define HCI_SUPP_COMMANDS_INQUIRY_OFF 0
- #define HCI_INQUIRY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_INQUIRY_OFF] & HCI_SUPP_COMMANDS_INQUIRY_MASK)
- #define HCI_SUPP_COMMANDS_INQUIRY_CANCEL_MASK 0x02
- #define HCI_SUPP_COMMANDS_INQUIRY_CANCEL_OFF 0
- #define HCI_INQUIRY_CANCEL_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_INQUIRY_CANCEL_OFF] & HCI_SUPP_COMMANDS_INQUIRY_CANCEL_MASK)
- #define HCI_SUPP_COMMANDS_PERIODIC_INQUIRY_MASK 0x04
- #define HCI_SUPP_COMMANDS_PERIODIC_INQUIRY_OFF 0
- #define HCI_PERIODIC_INQUIRY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_PERIODIC_INQUIRY_OFF] & HCI_SUPP_COMMANDS_PERIODIC_INQUIRY_MASK)
- #define HCI_SUPP_COMMANDS_EXIT_PERIODIC_INQUIRY_MASK 0x08
- #define HCI_SUPP_COMMANDS_EXIT_PERIODIC_INQUIRY_OFF 0
- #define HCI_EXIT_PERIODIC_INQUIRY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_EXIT_PERIODIC_INQUIRY_OFF] & HCI_SUPP_COMMANDS_EXIT_PERIODIC_INQUIRY_MASK)
- #define HCI_SUPP_COMMANDS_CREATE_CONN_MASK 0x10
- #define HCI_SUPP_COMMANDS_CREATE_CONN_OFF 0
- #define HCI_CREATE_CONN_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_CREATE_CONN_OFF] & HCI_SUPP_COMMANDS_CREATE_CONN_MASK)
- #define HCI_SUPP_COMMANDS_DISCONNECT_MASK 0x20
- #define HCI_SUPP_COMMANDS_DISCONNECT_OFF 0
- #define HCI_DISCONNECT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_DISCONNECT_OFF] & HCI_SUPP_COMMANDS_DISCONNECT_MASK)
- #define HCI_SUPP_COMMANDS_ADD_SCO_CONN_MASK 0x40
- #define HCI_SUPP_COMMANDS_ADD_SCO_CONN_OFF 0
- #define HCI_ADD_SCO_CONN_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_ADD_SCO_CONN_OFF] & HCI_SUPP_COMMANDS_ADD_SCO_CONN_MASK)
- #define HCI_SUPP_COMMANDS_CANCEL_CREATE_CONN_MASK 0x80
- #define HCI_SUPP_COMMANDS_CANCEL_CREATE_CONN_OFF 0
- #define HCI_CANCEL_CREATE_CONN_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_CANCEL_CREATE_CONN_OFF] & HCI_SUPP_COMMANDS_CANCEL_CREATE_CONN_MASK)
- #define HCI_SUPP_COMMANDS_ACCEPT_CONN_REQUEST_MASK 0x01
- #define HCI_SUPP_COMMANDS_ACCEPT_CONN_REQUEST_OFF 1
- #define HCI_ACCEPT_CONN_REQUEST_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_ACCEPT_CONN_REQUEST_OFF] & HCI_SUPP_COMMANDS_ACCEPT_CONN_REQUEST_MASK)
- #define HCI_SUPP_COMMANDS_REJECT_CONN_REQUEST_MASK 0x02
- #define HCI_SUPP_COMMANDS_REJECT_CONN_REQUEST_OFF 1
- #define HCI_REJECT_CONN_REQUEST_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_REJECT_CONN_REQUEST_OFF] & HCI_SUPP_COMMANDS_REJECT_CONN_REQUEST_MASK)
- #define HCI_SUPP_COMMANDS_LINK_KEY_REQUEST_REPLY_MASK 0x04
- #define HCI_SUPP_COMMANDS_LINK_KEY_REQUEST_REPLY_OFF 1
- #define HCI_LINK_KEY_REQUEST_REPLY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_LINK_KEY_REQUEST_REPLY_OFF] & HCI_SUPP_COMMANDS_LINK_KEY_REQUEST_REPLY_MASK)
- #define HCI_SUPP_COMMANDS_LINK_KEY_REQUEST_NEG_REPLY_MASK 0x08
- #define HCI_SUPP_COMMANDS_LINK_KEY_REQUEST_NEG_REPLY_OFF 1
- #define HCI_LINK_KEY_REQUEST_NEG_REPLY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_LINK_KEY_REQUEST_NEG_REPLY_OFF] & HCI_SUPP_COMMANDS_LINK_KEY_REQUEST_NEG_REPLY_MASK)
- #define HCI_SUPP_COMMANDS_PIN_CODE_REQUEST_REPLY_MASK 0x10
- #define HCI_SUPP_COMMANDS_PIN_CODE_REQUEST_REPLY_OFF 1
- #define HCI_PIN_CODE_REQUEST_REPLY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_PIN_CODE_REQUEST_REPLY_OFF] & HCI_SUPP_COMMANDS_PIN_CODE_REQUEST_REPLY_MASK)
- #define HCI_SUPP_COMMANDS_PIN_CODE_REQUEST_NEG_REPLY_MASK 0x20
- #define HCI_SUPP_COMMANDS_PIN_CODE_REQUEST_NEG_REPLY_OFF 1
- #define HCI_PIN_CODE_REQUEST_NEG_REPLY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_PIN_CODE_REQUEST_NEG_REPLY_OFF] & HCI_SUPP_COMMANDS_PIN_CODE_REQUEST_NEG_REPLY_MASK)
- #define HCI_SUPP_COMMANDS_CHANGE_CONN_PKT_TYPE_MASK 0x40
- #define HCI_SUPP_COMMANDS_CHANGE_CONN_PKT_TYPE_OFF 1
- #define HCI_CHANGE_CONN_PKT_TYPE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_CHANGE_CONN_PKT_TYPE_OFF] & HCI_SUPP_COMMANDS_CHANGE_CONN_PKT_TYPE_MASK)
- #define HCI_SUPP_COMMANDS_AUTH_REQUEST_MASK 0x80
- #define HCI_SUPP_COMMANDS_AUTH_REQUEST_OFF 1
- #define HCI_AUTH_REQUEST_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_AUTH_REQUEST_OFF] & HCI_SUPP_COMMANDS_AUTH_REQUEST_MASK)
- #define HCI_SUPP_COMMANDS_SET_CONN_ENCRYPTION_MASK 0x01
- #define HCI_SUPP_COMMANDS_SET_CONN_ENCRYPTION_OFF 2
- #define HCI_SET_CONN_ENCRYPTION_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_CONN_ENCRYPTION_OFF] & HCI_SUPP_COMMANDS_SET_CONN_ENCRYPTION_MASK)
- #define HCI_SUPP_COMMANDS_CHANGE_CONN_LINK_KEY_MASK 0x02
- #define HCI_SUPP_COMMANDS_CHANGE_CONN_LINK_KEY_OFF 2
- #define HCI_CHANGE_CONN_LINK_KEY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_CHANGE_CONN_LINK_KEY_OFF] & HCI_SUPP_COMMANDS_CHANGE_CONN_LINK_KEY_MASK)
- #define HCI_SUPP_COMMANDS_MASTER_LINK_KEY_MASK 0x04
- #define HCI_SUPP_COMMANDS_MASTER_LINK_KEY_OFF 2
- #define HCI_MASTER_LINK_KEY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_MASTER_LINK_KEY_OFF] & HCI_SUPP_COMMANDS_MASTER_LINK_KEY_MASK)
- #define HCI_SUPP_COMMANDS_REMOTE_NAME_REQUEST_MASK 0x08
- #define HCI_SUPP_COMMANDS_REMOTE_NAME_REQUEST_OFF 2
- #define HCI_REMOTE_NAME_REQUEST_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_REMOTE_NAME_REQUEST_OFF] & HCI_SUPP_COMMANDS_REMOTE_NAME_REQUEST_MASK)
- #define HCI_SUPP_COMMANDS_CANCEL_REMOTE_NAME_REQUEST_MASK 0x10
- #define HCI_SUPP_COMMANDS_CANCEL_REMOTE_NAME_REQUEST_OFF 2
- #define HCI_CANCEL_REMOTE_NAME_REQUEST_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_CANCEL_REMOTE_NAME_REQUEST_OFF] & HCI_SUPP_COMMANDS_CANCEL_REMOTE_NAME_REQUEST_MASK)
- #define HCI_SUPP_COMMANDS_READ_REMOTE_SUPP_FEATURES_MASK 0x20
- #define HCI_SUPP_COMMANDS_READ_REMOTE_SUPP_FEATURES_OFF 2
- #define HCI_READ_REMOTE_SUPP_FEATURES_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_REMOTE_SUPP_FEATURES_OFF] & HCI_SUPP_COMMANDS_READ_REMOTE_SUPP_FEATURES_MASK)
- #define HCI_SUPP_COMMANDS_READ_REMOTE_EXT_FEATURES_MASK 0x40
- #define HCI_SUPP_COMMANDS_READ_REMOTE_EXT_FEATURES_OFF 2
- #define HCI_READ_REMOTE_EXT_FEATURES_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_REMOTE_EXT_FEATURES_OFF] & HCI_SUPP_COMMANDS_READ_REMOTE_EXT_FEATURES_MASK)
- #define HCI_SUPP_COMMANDS_READ_REMOTE_VER_INFO_MASK 0x80
- #define HCI_SUPP_COMMANDS_READ_REMOTE_VER_INFO_OFF 2
- #define HCI_READ_REMOTE_VER_INFO_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_REMOTE_VER_INFO_OFF] & HCI_SUPP_COMMANDS_READ_REMOTE_VER_INFO_MASK)
- #define HCI_SUPP_COMMANDS_READ_CLOCK_OFFSET_MASK 0x01
- #define HCI_SUPP_COMMANDS_READ_CLOCK_OFFSET_OFF 3
- #define HCI_READ_CLOCK_OFFSET_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_CLOCK_OFFSET_OFF] & HCI_SUPP_COMMANDS_READ_CLOCK_OFFSET_MASK)
- #define HCI_SUPP_COMMANDS_READ_LMP_HANDLE_MASK 0x02
- #define HCI_SUPP_COMMANDS_READ_LMP_HANDLE_OFF 3
- #define HCI_READ_LMP_HANDLE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LMP_HANDLE_OFF] & HCI_SUPP_COMMANDS_READ_LMP_HANDLE_MASK)
- #define HCI_SUPP_COMMANDS_HOLD_MODE_CMD_MASK 0x02
- #define HCI_SUPP_COMMANDS_HOLD_MODE_CMD_OFF 4
- #define HCI_HOLD_MODE_CMD_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_HOLD_MODE_CMD_OFF] & HCI_SUPP_COMMANDS_HOLD_MODE_CMD_MASK)
- #define HCI_SUPP_COMMANDS_SNIFF_MODE_CMD_MASK 0x04
- #define HCI_SUPP_COMMANDS_SNIFF_MODE_CMD_OFF 4
- #define HCI_SNIFF_MODE_CMD_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SNIFF_MODE_CMD_OFF] & HCI_SUPP_COMMANDS_SNIFF_MODE_CMD_MASK)
- #define HCI_SUPP_COMMANDS_EXIT_SNIFF_MODE_MASK 0x08
- #define HCI_SUPP_COMMANDS_EXIT_SNIFF_MODE_OFF 4
- #define HCI_EXIT_SNIFF_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_EXIT_SNIFF_MODE_OFF] & HCI_SUPP_COMMANDS_EXIT_SNIFF_MODE_MASK)
- #define HCI_SUPP_COMMANDS_PARK_STATE_MASK 0x10
- #define HCI_SUPP_COMMANDS_PARK_STATE_OFF 4
- #define HCI_PARK_STATE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_PARK_STATE_OFF] & HCI_SUPP_COMMANDS_PARK_STATE_MASK)
- #define HCI_SUPP_COMMANDS_EXIT_PARK_STATE_MASK 0x20
- #define HCI_SUPP_COMMANDS_EXIT_PARK_STATE_OFF 4
- #define HCI_EXIT_PARK_STATE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_EXIT_PARK_STATE_OFF] & HCI_SUPP_COMMANDS_EXIT_PARK_STATE_MASK)
- #define HCI_SUPP_COMMANDS_QOS_SETUP_MASK 0x40
- #define HCI_SUPP_COMMANDS_QOS_SETUP_OFF 4
- #define HCI_QOS_SETUP_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_QOS_SETUP_OFF] & HCI_SUPP_COMMANDS_QOS_SETUP_MASK)
- #define HCI_SUPP_COMMANDS_ROLE_DISCOVERY_MASK 0x80
- #define HCI_SUPP_COMMANDS_ROLE_DISCOVERY_OFF 4
- #define HCI_ROLE_DISCOVERY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_ROLE_DISCOVERY_OFF] & HCI_SUPP_COMMANDS_ROLE_DISCOVERY_MASK)
- #define HCI_SUPP_COMMANDS_SWITCH_ROLE_MASK 0x01
- #define HCI_SUPP_COMMANDS_SWITCH_ROLE_OFF 5
- #define HCI_SWITCH_ROLE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SWITCH_ROLE_OFF] & HCI_SUPP_COMMANDS_SWITCH_ROLE_MASK)
- #define HCI_SUPP_COMMANDS_READ_LINK_POLICY_SET_MASK 0x02
- #define HCI_SUPP_COMMANDS_READ_LINK_POLICY_SET_OFF 5
- #define HCI_READ_LINK_POLICY_SET_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LINK_POLICY_SET_OFF] & HCI_SUPP_COMMANDS_READ_LINK_POLICY_SET_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_LINK_POLICY_SET_MASK 0x04
- #define HCI_SUPP_COMMANDS_WRITE_LINK_POLICY_SET_OFF 5
- #define HCI_WRITE_LINK_POLICY_SET_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_LINK_POLICY_SET_OFF] & HCI_SUPP_COMMANDS_WRITE_LINK_POLICY_SET_MASK)
- #define HCI_SUPP_COMMANDS_READ_DEF_LINK_POLICY_SET_MASK 0x08
- #define HCI_SUPP_COMMANDS_READ_DEF_LINK_POLICY_SET_OFF 5
- #define HCI_READ_DEF_LINK_POLICY_SET_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_DEF_LINK_POLICY_SET_OFF] & HCI_SUPP_COMMANDS_READ_DEF_LINK_POLICY_SET_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_DEF_LINK_POLICY_SET_MASK 0x10
- #define HCI_SUPP_COMMANDS_WRITE_DEF_LINK_POLICY_SET_OFF 5
- #define HCI_WRITE_DEF_LINK_POLICY_SET_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_DEF_LINK_POLICY_SET_OFF] & HCI_SUPP_COMMANDS_WRITE_DEF_LINK_POLICY_SET_MASK)
- #define HCI_SUPP_COMMANDS_FLOW_SPECIFICATION_MASK 0x20
- #define HCI_SUPP_COMMANDS_FLOW_SPECIFICATION_OFF 5
- #define HCI_FLOW_SPECIFICATION_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_FLOW_SPECIFICATION_OFF] & HCI_SUPP_COMMANDS_FLOW_SPECIFICATION_MASK)
- #define HCI_SUPP_COMMANDS_SET_EVENT_MASK_MASK 0x40
- #define HCI_SUPP_COMMANDS_SET_EVENT_MASK_OFF 5
- #define HCI_SET_EVENT_MASK_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_EVENT_MASK_OFF] & HCI_SUPP_COMMANDS_SET_EVENT_MASK_MASK)
- #define HCI_SUPP_COMMANDS_RESET_MASK 0x80
- #define HCI_SUPP_COMMANDS_RESET_OFF 5
- #define HCI_RESET_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_RESET_OFF] & HCI_SUPP_COMMANDS_RESET_MASK)
- #define HCI_SUPP_COMMANDS_SET_EVENT_FILTER_MASK 0x01
- #define HCI_SUPP_COMMANDS_SET_EVENT_FILTER_OFF 6
- #define HCI_SET_EVENT_FILTER_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_EVENT_FILTER_OFF] & HCI_SUPP_COMMANDS_SET_EVENT_FILTER_MASK)
- #define HCI_SUPP_COMMANDS_FLUSH_MASK 0x02
- #define HCI_SUPP_COMMANDS_FLUSH_OFF 6
- #define HCI_FLUSH_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_FLUSH_OFF] & HCI_SUPP_COMMANDS_FLUSH_MASK)
- #define HCI_SUPP_COMMANDS_READ_PIN_TYPE_MASK 0x04
- #define HCI_SUPP_COMMANDS_READ_PIN_TYPE_OFF 6
- #define HCI_READ_PIN_TYPE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_PIN_TYPE_OFF] & HCI_SUPP_COMMANDS_READ_PIN_TYPE_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_PIN_TYPE_MASK 0x08
- #define HCI_SUPP_COMMANDS_WRITE_PIN_TYPE_OFF 6
- #define HCI_WRITE_PIN_TYPE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_PIN_TYPE_OFF] & HCI_SUPP_COMMANDS_WRITE_PIN_TYPE_MASK)
- #define HCI_SUPP_COMMANDS_CREATE_NEW_UNIT_KEY_MASK 0x10
- #define HCI_SUPP_COMMANDS_CREATE_NEW_UNIT_KEY_OFF 6
- #define HCI_CREATE_NEW_UNIT_KEY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_CREATE_NEW_UNIT_KEY_OFF] & HCI_SUPP_COMMANDS_CREATE_NEW_UNIT_KEY_MASK)
- #define HCI_SUPP_COMMANDS_READ_STORED_LINK_KEY_MASK 0x20
- #define HCI_SUPP_COMMANDS_READ_STORED_LINK_KEY_OFF 6
- #define HCI_READ_STORED_LINK_KEY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_STORED_LINK_KEY_OFF] & HCI_SUPP_COMMANDS_READ_STORED_LINK_KEY_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_STORED_LINK_KEY_MASK 0x40
- #define HCI_SUPP_COMMANDS_WRITE_STORED_LINK_KEY_OFF 6
- #define HCI_WRITE_STORED_LINK_KEY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_STORED_LINK_KEY_OFF] & HCI_SUPP_COMMANDS_WRITE_STORED_LINK_KEY_MASK)
- #define HCI_SUPP_COMMANDS_DELETE_STORED_LINK_KEY_MASK 0x80
- #define HCI_SUPP_COMMANDS_DELETE_STORED_LINK_KEY_OFF 6
- #define HCI_DELETE_STORED_LINK_KEY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_DELETE_STORED_LINK_KEY_OFF] & HCI_SUPP_COMMANDS_DELETE_STORED_LINK_KEY_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_LOCAL_NAME_MASK 0x01
- #define HCI_SUPP_COMMANDS_WRITE_LOCAL_NAME_OFF 7
- #define HCI_WRITE_LOCAL_NAME_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_LOCAL_NAME_OFF] & HCI_SUPP_COMMANDS_WRITE_LOCAL_NAME_MASK)
- #define HCI_SUPP_COMMANDS_READ_LOCAL_NAME_MASK 0x02
- #define HCI_SUPP_COMMANDS_READ_LOCAL_NAME_OFF 7
- #define HCI_READ_LOCAL_NAME_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LOCAL_NAME_OFF] & HCI_SUPP_COMMANDS_READ_LOCAL_NAME_MASK)
- #define HCI_SUPP_COMMANDS_READ_CONN_ACCEPT_TOUT_MASK 0x04
- #define HCI_SUPP_COMMANDS_READ_CONN_ACCEPT_TOUT_OFF 7
- #define HCI_READ_CONN_ACCEPT_TOUT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_CONN_ACCEPT_TOUT_OFF] & HCI_SUPP_COMMANDS_READ_CONN_ACCEPT_TOUT_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_CONN_ACCEPT_TOUT_MASK 0x08
- #define HCI_SUPP_COMMANDS_WRITE_CONN_ACCEPT_TOUT_OFF 7
- #define HCI_WRITE_CONN_ACCEPT_TOUT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_CONN_ACCEPT_TOUT_OFF] & HCI_SUPP_COMMANDS_WRITE_CONN_ACCEPT_TOUT_MASK)
- #define HCI_SUPP_COMMANDS_READ_PAGE_TOUT_MASK 0x10
- #define HCI_SUPP_COMMANDS_READ_PAGE_TOUT_OFF 7
- #define HCI_READ_PAGE_TOUT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_PAGE_TOUT_OFF] & HCI_SUPP_COMMANDS_READ_PAGE_TOUT_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_PAGE_TOUT_MASK 0x20
- #define HCI_SUPP_COMMANDS_WRITE_PAGE_TOUT_OFF 7
- #define HCI_WRITE_PAGE_TOUT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_PAGE_TOUT_OFF] & HCI_SUPP_COMMANDS_WRITE_PAGE_TOUT_MASK)
- #define HCI_SUPP_COMMANDS_READ_SCAN_ENABLE_MASK 0x40
- #define HCI_SUPP_COMMANDS_READ_SCAN_ENABLE_OFF 7
- #define HCI_READ_SCAN_ENABLE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_SCAN_ENABLE_OFF] & HCI_SUPP_COMMANDS_READ_SCAN_ENABLE_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_SCAN_ENABLE_MASK 0x80
- #define HCI_SUPP_COMMANDS_WRITE_SCAN_ENABLE_OFF 7
- #define HCI_WRITE_SCAN_ENABLE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_SCAN_ENABLE_OFF] & HCI_SUPP_COMMANDS_WRITE_SCAN_ENABLE_MASK)
- #define HCI_SUPP_COMMANDS_READ_PAGE_SCAN_ACTIVITY_MASK 0x01
- #define HCI_SUPP_COMMANDS_READ_PAGE_SCAN_ACTIVITY_OFF 8
- #define HCI_READ_PAGE_SCAN_ACTIVITY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_PAGE_SCAN_ACTIVITY_OFF] & HCI_SUPP_COMMANDS_READ_PAGE_SCAN_ACTIVITY_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_ACTIVITY_MASK 0x02
- #define HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_ACTIVITY_OFF 8
- #define HCI_WRITE_PAGE_SCAN_ACTIVITY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_ACTIVITY_OFF] & HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_ACTIVITY_MASK)
- #define HCI_SUPP_COMMANDS_READ_INQURIY_SCAN_ACTIVITY_MASK 0x04
- #define HCI_SUPP_COMMANDS_READ_INQURIY_SCAN_ACTIVITY_OFF 8
- #define HCI_READ_INQURIY_SCAN_ACTIVITY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_INQURIY_SCAN_ACTIVITY_OFF] & HCI_SUPP_COMMANDS_READ_INQURIY_SCAN_ACTIVITY_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_INQURIY_SCAN_ACTIVITY_MASK 0x08
- #define HCI_SUPP_COMMANDS_WRITE_INQURIY_SCAN_ACTIVITY_OFF 8
- #define HCI_WRITE_INQURIY_SCAN_ACTIVITY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_INQURIY_SCAN_ACTIVITY_OFF] & HCI_SUPP_COMMANDS_WRITE_INQURIY_SCAN_ACTIVITY_MASK)
- #define HCI_SUPP_COMMANDS_READ_AUTH_ENABLE_MASK 0x10
- #define HCI_SUPP_COMMANDS_READ_AUTH_ENABLE_OFF 8
- #define HCI_READ_AUTH_ENABLE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_AUTH_ENABLE_OFF] & HCI_SUPP_COMMANDS_READ_AUTH_ENABLE_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_AUTH_ENABLE_MASK 0x20
- #define HCI_SUPP_COMMANDS_WRITE_AUTH_ENABLE_OFF 8
- #define HCI_WRITE_AUTH_ENABLE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_AUTH_ENABLE_OFF] & HCI_SUPP_COMMANDS_WRITE_AUTH_ENABLE_MASK)
- #define HCI_SUPP_COMMANDS_READ_ENCRYPT_ENABLE_MASK 0x40
- #define HCI_SUPP_COMMANDS_READ_ENCRYPT_ENABLE_OFF 8
- #define HCI_READ_ENCRYPT_ENABLE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_ENCRYPT_ENABLE_OFF] & HCI_SUPP_COMMANDS_READ_ENCRYPT_ENABLE_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_ENCRYPT_ENABLE_MASK 0x80
- #define HCI_SUPP_COMMANDS_WRITE_ENCRYPT_ENABLE_OFF 8
- #define HCI_WRITE_ENCRYPT_ENABLE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_ENCRYPT_ENABLE_OFF] & HCI_SUPP_COMMANDS_WRITE_ENCRYPT_ENABLE_MASK)
- #define HCI_SUPP_COMMANDS_READ_CLASS_DEVICE_MASK 0x01
- #define HCI_SUPP_COMMANDS_READ_CLASS_DEVICE_OFF 9
- #define HCI_READ_CLASS_DEVICE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_CLASS_DEVICE_OFF] & HCI_SUPP_COMMANDS_READ_CLASS_DEVICE_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_CLASS_DEVICE_MASK 0x02
- #define HCI_SUPP_COMMANDS_WRITE_CLASS_DEVICE_OFF 9
- #define HCI_WRITE_CLASS_DEVICE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_CLASS_DEVICE_OFF] & HCI_SUPP_COMMANDS_WRITE_CLASS_DEVICE_MASK)
- #define HCI_SUPP_COMMANDS_READ_VOICE_SETTING_MASK 0x04
- #define HCI_SUPP_COMMANDS_READ_VOICE_SETTING_OFF 9
- #define HCI_READ_VOICE_SETTING_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_VOICE_SETTING_OFF] & HCI_SUPP_COMMANDS_READ_VOICE_SETTING_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_VOICE_SETTING_MASK 0x08
- #define HCI_SUPP_COMMANDS_WRITE_VOICE_SETTING_OFF 9
- #define HCI_WRITE_VOICE_SETTING_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_VOICE_SETTING_OFF] & HCI_SUPP_COMMANDS_WRITE_VOICE_SETTING_MASK)
- #define HCI_SUPP_COMMANDS_READ_AUTO_FLUSH_TOUT_MASK 0x10
- #define HCI_SUPP_COMMANDS_READ_AUTO_FLUSH_TOUT_OFF 9
- #define HCI_READ_AUTO_FLUSH_TOUT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_AUTO_FLUSH_TOUT_OFF] & HCI_SUPP_COMMANDS_READ_AUTO_FLUSH_TOUT_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_AUTO_FLUSH_TOUT_MASK 0x20
- #define HCI_SUPP_COMMANDS_WRITE_AUTO_FLUSH_TOUT_OFF 9
- #define HCI_WRITE_AUTO_FLUSH_TOUT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_AUTO_FLUSH_TOUT_OFF] & HCI_SUPP_COMMANDS_WRITE_AUTO_FLUSH_TOUT_MASK)
- #define HCI_SUPP_COMMANDS_READ_NUM_BROAD_RETRANS_MASK 0x40
- #define HCI_SUPP_COMMANDS_READ_NUM_BROAD_RETRANS_OFF 9
- #define HCI_READ_NUM_BROAD_RETRANS_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_NUM_BROAD_RETRANS_OFF] & HCI_SUPP_COMMANDS_READ_NUM_BROAD_RETRANS_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_NUM_BROAD_RETRANS_MASK 0x80
- #define HCI_SUPP_COMMANDS_WRITE_NUM_BROAD_RETRANS_OFF 9
- #define HCI_WRITE_NUM_BROAD_RETRANS_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_NUM_BROAD_RETRANS_OFF] & HCI_SUPP_COMMANDS_WRITE_NUM_BROAD_RETRANS_MASK)
- #define HCI_SUPP_COMMANDS_READ_HOLD_MODE_ACTIVITY_MASK 0x01
- #define HCI_SUPP_COMMANDS_READ_HOLD_MODE_ACTIVITY_OFF 10
- #define HCI_READ_HOLD_MODE_ACTIVITY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_HOLD_MODE_ACTIVITY_OFF] & HCI_SUPP_COMMANDS_READ_HOLD_MODE_ACTIVITY_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_HOLD_MODE_ACTIVITY_MASK 0x02
- #define HCI_SUPP_COMMANDS_WRITE_HOLD_MODE_ACTIVITY_OFF 10
- #define HCI_WRITE_HOLD_MODE_ACTIVITY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_HOLD_MODE_ACTIVITY_OFF] & HCI_SUPP_COMMANDS_WRITE_HOLD_MODE_ACTIVITY_MASK)
- #define HCI_SUPP_COMMANDS_READ_TRANS_PWR_LEVEL_MASK 0x04
- #define HCI_SUPP_COMMANDS_READ_TRANS_PWR_LEVEL_OFF 10
- #define HCI_READ_TRANS_PWR_LEVEL_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_TRANS_PWR_LEVEL_OFF] & HCI_SUPP_COMMANDS_READ_TRANS_PWR_LEVEL_MASK)
- #define HCI_SUPP_COMMANDS_READ_SYNCH_FLOW_CTRL_ENABLE_MASK 0x08
- #define HCI_SUPP_COMMANDS_READ_SYNCH_FLOW_CTRL_ENABLE_OFF 10
- #define HCI_READ_SYNCH_FLOW_CTRL_ENABLE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_SYNCH_FLOW_CTRL_ENABLE_OFF] & HCI_SUPP_COMMANDS_READ_SYNCH_FLOW_CTRL_ENABLE_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_SYNCH_FLOW_CTRL_ENABLE_MASK 0x10
- #define HCI_SUPP_COMMANDS_WRITE_SYNCH_FLOW_CTRL_ENABLE_OFF 10
- #define HCI_WRITE_SYNCH_FLOW_CTRL_ENABLE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_SYNCH_FLOW_CTRL_ENABLE_OFF] & HCI_SUPP_COMMANDS_WRITE_SYNCH_FLOW_CTRL_ENABLE_MASK)
- #define HCI_SUPP_COMMANDS_SET_HOST_CTRLR_TO_HOST_FC_MASK 0x20
- #define HCI_SUPP_COMMANDS_SET_HOST_CTRLR_TO_HOST_FC_OFF 10
- #define HCI_SET_HOST_CTRLR_TO_HOST_FC_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_HOST_CTRLR_TO_HOST_FC_OFF] & HCI_SUPP_COMMANDS_SET_HOST_CTRLR_TO_HOST_FC_MASK)
- #define HCI_SUPP_COMMANDS_HOST_BUFFER_SIZE_MASK 0x40
- #define HCI_SUPP_COMMANDS_HOST_BUFFER_SIZE_OFF 10
- #define HCI_HOST_BUFFER_SIZE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_HOST_BUFFER_SIZE_OFF] & HCI_SUPP_COMMANDS_HOST_BUFFER_SIZE_MASK)
- #define HCI_SUPP_COMMANDS_HOST_NUM_COMPLETED_PKTS_MASK 0x80
- #define HCI_SUPP_COMMANDS_HOST_NUM_COMPLETED_PKTS_OFF 10
- #define HCI_HOST_NUM_COMPLETED_PKTS_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_HOST_NUM_COMPLETED_PKTS_OFF] & HCI_SUPP_COMMANDS_HOST_NUM_COMPLETED_PKTS_MASK)
- #define HCI_SUPP_COMMANDS_READ_LINK_SUP_TOUT_MASK 0x01
- #define HCI_SUPP_COMMANDS_READ_LINK_SUP_TOUT_OFF 11
- #define HCI_READ_LINK_SUP_TOUT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LINK_SUP_TOUT_OFF] & HCI_SUPP_COMMANDS_READ_LINK_SUP_TOUT_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_LINK_SUP_TOUT_MASK 0x02
- #define HCI_SUPP_COMMANDS_WRITE_LINK_SUP_TOUT_OFF 11
- #define HCI_WRITE_LINK_SUP_TOUT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_LINK_SUP_TOUT_OFF] & HCI_SUPP_COMMANDS_WRITE_LINK_SUP_TOUT_MASK)
- #define HCI_SUPP_COMMANDS_READ_NUM_SUPP_IAC_MASK 0x04
- #define HCI_SUPP_COMMANDS_READ_NUM_SUPP_IAC_OFF 11
- #define HCI_READ_NUM_SUPP_IAC_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_NUM_SUPP_IAC_OFF] & HCI_SUPP_COMMANDS_READ_NUM_SUPP_IAC_MASK)
- #define HCI_SUPP_COMMANDS_READ_CURRENT_IAC_LAP_MASK 0x08
- #define HCI_SUPP_COMMANDS_READ_CURRENT_IAC_LAP_OFF 11
- #define HCI_READ_CURRENT_IAC_LAP_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_CURRENT_IAC_LAP_OFF] & HCI_SUPP_COMMANDS_READ_CURRENT_IAC_LAP_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_CURRENT_IAC_LAP_MASK 0x10
- #define HCI_SUPP_COMMANDS_WRITE_CURRENT_IAC_LAP_OFF 11
- #define HCI_WRITE_CURRENT_IAC_LAP_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_CURRENT_IAC_LAP_OFF] & HCI_SUPP_COMMANDS_WRITE_CURRENT_IAC_LAP_MASK)
- #define HCI_SUPP_COMMANDS_READ_PAGE_SCAN_PER_MODE_MASK 0x20
- #define HCI_SUPP_COMMANDS_READ_PAGE_SCAN_PER_MODE_OFF 11
- #define HCI_READ_PAGE_SCAN_PER_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_PAGE_SCAN_PER_MODE_OFF] & HCI_SUPP_COMMANDS_READ_PAGE_SCAN_PER_MODE_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_PER_MODE_MASK 0x40
- #define HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_PER_MODE_OFF 11
- #define HCI_WRITE_PAGE_SCAN_PER_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_PER_MODE_OFF] & HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_PER_MODE_MASK)
- #define HCI_SUPP_COMMANDS_READ_PAGE_SCAN_MODE_MASK 0x80
- #define HCI_SUPP_COMMANDS_READ_PAGE_SCAN_MODE_OFF 11
- #define HCI_READ_PAGE_SCAN_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_PAGE_SCAN_MODE_OFF] & HCI_SUPP_COMMANDS_READ_PAGE_SCAN_MODE_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_MODE_MASK 0x01
- #define HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_MODE_OFF 12
- #define HCI_WRITE_PAGE_SCAN_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_MODE_OFF] & HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_MODE_MASK)
- #define HCI_SUPP_COMMANDS_SET_AFH_CHNL_CLASS_MASK 0x02
- #define HCI_SUPP_COMMANDS_SET_AFH_CHNL_CLASS_OFF 12
- #define HCI_SET_AFH_CHNL_CLASS_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_AFH_CHNL_CLASS_OFF] & HCI_SUPP_COMMANDS_SET_AFH_CHNL_CLASS_MASK)
- #define HCI_SUPP_COMMANDS_READ_INQUIRY_SCAN_TYPE_MASK 0x10
- #define HCI_SUPP_COMMANDS_READ_INQUIRY_SCAN_TYPE_OFF 12
- #define HCI_READ_INQUIRY_SCAN_TYPE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_INQUIRY_SCAN_TYPE_OFF] & HCI_SUPP_COMMANDS_READ_INQUIRY_SCAN_TYPE_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_INQUIRY_SCAN_TYPE_MASK 0x20
- #define HCI_SUPP_COMMANDS_WRITE_INQUIRY_SCAN_TYPE_OFF 12
- #define HCI_WRITE_INQUIRY_SCAN_TYPE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_INQUIRY_SCAN_TYPE_OFF] & HCI_SUPP_COMMANDS_WRITE_INQUIRY_SCAN_TYPE_MASK)
- #define HCI_SUPP_COMMANDS_READ_INQUIRY_MODE_MASK 0x40
- #define HCI_SUPP_COMMANDS_READ_INQUIRY_MODE_OFF 12
- #define HCI_READ_INQUIRY_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_INQUIRY_MODE_OFF] & HCI_SUPP_COMMANDS_READ_INQUIRY_MODE_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_INQUIRY_MODE_MASK 0x80
- #define HCI_SUPP_COMMANDS_WRITE_INQUIRY_MODE_OFF 12
- #define HCI_WRITE_INQUIRY_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_INQUIRY_MODE_OFF] & HCI_SUPP_COMMANDS_WRITE_INQUIRY_MODE_MASK)
- #define HCI_SUPP_COMMANDS_READ_PAGE_SCAN_TYPE_MASK 0x01
- #define HCI_SUPP_COMMANDS_READ_PAGE_SCAN_TYPE_OFF 13
- #define HCI_READ_PAGE_SCAN_TYPE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_PAGE_SCAN_TYPE_OFF] & HCI_SUPP_COMMANDS_READ_PAGE_SCAN_TYPE_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_TYPE_MASK 0x02
- #define HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_TYPE_OFF 13
- #define HCI_WRITE_PAGE_SCAN_TYPE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_TYPE_OFF] & HCI_SUPP_COMMANDS_WRITE_PAGE_SCAN_TYPE_MASK)
- #define HCI_SUPP_COMMANDS_READ_AFH_CHNL_ASSESS_MODE_MASK 0x04
- #define HCI_SUPP_COMMANDS_READ_AFH_CHNL_ASSESS_MODE_OFF 13
- #define HCI_READ_AFH_CHNL_ASSESS_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_AFH_CHNL_ASSESS_MODE_OFF] & HCI_SUPP_COMMANDS_READ_AFH_CHNL_ASSESS_MODE_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_AFH_CHNL_ASSESS_MODE_MASK 0x08
- #define HCI_SUPP_COMMANDS_WRITE_AFH_CHNL_ASSESS_MODE_OFF 13
- #define HCI_WRITE_AFH_CHNL_ASSESS_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_AFH_CHNL_ASSESS_MODE_OFF] & HCI_SUPP_COMMANDS_WRITE_AFH_CHNL_ASSESS_MODE_MASK)
- #define HCI_SUPP_COMMANDS_READ_LOCAL_VER_INFO_MASK 0x08
- #define HCI_SUPP_COMMANDS_READ_LOCAL_VER_INFO_OFF 14
- #define HCI_READ_LOCAL_VER_INFO_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LOCAL_VER_INFO_OFF] & HCI_SUPP_COMMANDS_READ_LOCAL_VER_INFO_MASK)
- #define HCI_SUPP_COMMANDS_READ_LOCAL_SUP_CMDS_MASK 0x10
- #define HCI_SUPP_COMMANDS_READ_LOCAL_SUP_CMDS_OFF 14
- #define HCI_READ_LOCAL_SUP_CMDS_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LOCAL_SUP_CMDS_OFF] & HCI_SUPP_COMMANDS_READ_LOCAL_SUP_CMDS_MASK)
- #define HCI_SUPP_COMMANDS_READ_LOCAL_SUPP_FEATURES_MASK 0x20
- #define HCI_SUPP_COMMANDS_READ_LOCAL_SUPP_FEATURES_OFF 14
- #define HCI_READ_LOCAL_SUPP_FEATURES_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LOCAL_SUPP_FEATURES_OFF] & HCI_SUPP_COMMANDS_READ_LOCAL_SUPP_FEATURES_MASK)
- #define HCI_SUPP_COMMANDS_READ_LOCAL_EXT_FEATURES_MASK 0x40
- #define HCI_SUPP_COMMANDS_READ_LOCAL_EXT_FEATURES_OFF 14
- #define HCI_READ_LOCAL_EXT_FEATURES_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LOCAL_EXT_FEATURES_OFF] & HCI_SUPP_COMMANDS_READ_LOCAL_EXT_FEATURES_MASK)
- #define HCI_SUPP_COMMANDS_READ_BUFFER_SIZE_MASK 0x80
- #define HCI_SUPP_COMMANDS_READ_BUFFER_SIZE_OFF 14
- #define HCI_READ_BUFFER_SIZE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_BUFFER_SIZE_OFF] & HCI_SUPP_COMMANDS_READ_BUFFER_SIZE_MASK)
- #define HCI_SUPP_COMMANDS_READ_COUNTRY_CODE_MASK 0x01
- #define HCI_SUPP_COMMANDS_READ_COUNTRY_CODE_OFF 15
- #define HCI_READ_COUNTRY_CODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_COUNTRY_CODE_OFF] & HCI_SUPP_COMMANDS_READ_COUNTRY_CODE_MASK)
- #define HCI_SUPP_COMMANDS_READ_BD_ADDR_MASK 0x02
- #define HCI_SUPP_COMMANDS_READ_BD_ADDR_OFF 15
- #define HCI_READ_BD_ADDR_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_BD_ADDR_OFF] & HCI_SUPP_COMMANDS_READ_BD_ADDR_MASK)
- #define HCI_SUPP_COMMANDS_READ_FAIL_CONTACT_CNTR_MASK 0x04
- #define HCI_SUPP_COMMANDS_READ_FAIL_CONTACT_CNTR_OFF 15
- #define HCI_READ_FAIL_CONTACT_CNTR_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_FAIL_CONTACT_CNTR_OFF] & HCI_SUPP_COMMANDS_READ_FAIL_CONTACT_CNTR_MASK)
- #define HCI_SUPP_COMMANDS_RESET_FAIL_CONTACT_CNTR_MASK 0x08
- #define HCI_SUPP_COMMANDS_RESET_FAIL_CONTACT_CNTR_OFF 15
- #define HCI_RESET_FAIL_CONTACT_CNTR_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_RESET_FAIL_CONTACT_CNTR_OFF] & HCI_SUPP_COMMANDS_RESET_FAIL_CONTACT_CNTR_MASK)
- #define HCI_SUPP_COMMANDS_GET_LINK_QUALITY_MASK 0x10
- #define HCI_SUPP_COMMANDS_GET_LINK_QUALITY_OFF 15
- #define HCI_GET_LINK_QUALITY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_GET_LINK_QUALITY_OFF] & HCI_SUPP_COMMANDS_GET_LINK_QUALITY_MASK)
- #define HCI_SUPP_COMMANDS_READ_RSSI_MASK 0x20
- #define HCI_SUPP_COMMANDS_READ_RSSI_OFF 15
- #define HCI_READ_RSSI_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_RSSI_OFF] & HCI_SUPP_COMMANDS_READ_RSSI_MASK)
- #define HCI_SUPP_COMMANDS_READ_AFH_CH_MAP_MASK 0x40
- #define HCI_SUPP_COMMANDS_READ_AFH_CH_MAP_OFF 15
- #define HCI_READ_AFH_CH_MAP_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_AFH_CH_MAP_OFF] & HCI_SUPP_COMMANDS_READ_AFH_CH_MAP_MASK)
- #define HCI_SUPP_COMMANDS_READ_BD_CLOCK_MASK 0x80
- #define HCI_SUPP_COMMANDS_READ_BD_CLOCK_OFF 15
- #define HCI_READ_BD_CLOCK_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_BD_CLOCK_OFF] & HCI_SUPP_COMMANDS_READ_BD_CLOCK_MASK)
- #define HCI_SUPP_COMMANDS_READ_LOOPBACK_MODE_MASK 0x01
- #define HCI_SUPP_COMMANDS_READ_LOOPBACK_MODE_OFF 16
- #define HCI_READ_LOOPBACK_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LOOPBACK_MODE_OFF] & HCI_SUPP_COMMANDS_READ_LOOPBACK_MODE_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_LOOPBACK_MODE_MASK 0x02
- #define HCI_SUPP_COMMANDS_WRITE_LOOPBACK_MODE_OFF 16
- #define HCI_WRITE_LOOPBACK_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_LOOPBACK_MODE_OFF] & HCI_SUPP_COMMANDS_WRITE_LOOPBACK_MODE_MASK)
- #define HCI_SUPP_COMMANDS_ENABLE_DEV_UNDER_TEST_MASK 0x04
- #define HCI_SUPP_COMMANDS_ENABLE_DEV_UNDER_TEST_OFF 16
- #define HCI_ENABLE_DEV_UNDER_TEST_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_ENABLE_DEV_UNDER_TEST_OFF] & HCI_SUPP_COMMANDS_ENABLE_DEV_UNDER_TEST_MASK)
- #define HCI_SUPP_COMMANDS_SETUP_SYNCH_CONN_MASK 0x08
- #define HCI_SUPP_COMMANDS_SETUP_SYNCH_CONN_OFF 16
- #define HCI_SETUP_SYNCH_CONN_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SETUP_SYNCH_CONN_OFF] & HCI_SUPP_COMMANDS_SETUP_SYNCH_CONN_MASK)
- #define HCI_SUPP_COMMANDS_ACCEPT_SYNCH_CONN_MASK 0x10
- #define HCI_SUPP_COMMANDS_ACCEPT_SYNCH_CONN_OFF 16
- #define HCI_ACCEPT_SYNCH_CONN_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_ACCEPT_SYNCH_CONN_OFF] & HCI_SUPP_COMMANDS_ACCEPT_SYNCH_CONN_MASK)
- #define HCI_SUPP_COMMANDS_REJECT_SYNCH_CONN_MASK 0x20
- #define HCI_SUPP_COMMANDS_REJECT_SYNCH_CONN_OFF 16
- #define HCI_REJECT_SYNCH_CONN_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_REJECT_SYNCH_CONN_OFF] & HCI_SUPP_COMMANDS_REJECT_SYNCH_CONN_MASK)
- #define HCI_SUPP_COMMANDS_READ_EXT_INQUIRY_RESP_MASK 0x01
- #define HCI_SUPP_COMMANDS_READ_EXT_INQUIRY_RESP_OFF 17
- #define HCI_READ_EXT_INQUIRY_RESP_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_EXT_INQUIRY_RESP_OFF] & HCI_SUPP_COMMANDS_READ_EXT_INQUIRY_RESP_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_EXT_INQUIRY_RESP_MASK 0x02
- #define HCI_SUPP_COMMANDS_WRITE_EXT_INQUIRY_RESP_OFF 17
- #define HCI_WRITE_EXT_INQUIRY_RESP_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_EXT_INQUIRY_RESP_OFF] & HCI_SUPP_COMMANDS_WRITE_EXT_INQUIRY_RESP_MASK)
- #define HCI_SUPP_COMMANDS_REFRESH_ENCRYPTION_KEY_MASK 0x04
- #define HCI_SUPP_COMMANDS_REFRESH_ENCRYPTION_KEY_OFF 17
- #define HCI_REFRESH_ENCRYPTION_KEY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_REFRESH_ENCRYPTION_KEY_OFF] & HCI_SUPP_COMMANDS_REFRESH_ENCRYPTION_KEY_MASK)
- /* Octet 17, bit 3 is reserved */
- #define HCI_SUPP_COMMANDS_SNIFF_SUB_RATE_MASK 0x10
- #define HCI_SUPP_COMMANDS_SNIFF_SUB_RATE_OFF 17
- #define HCI_SNIFF_SUB_RATE_CMD_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SNIFF_SUB_RATE_OFF] & HCI_SUPP_COMMANDS_SNIFF_SUB_RATE_MASK)
- #define HCI_SUPP_COMMANDS_READ_SIMPLE_PAIRING_MODE_MASK 0x20
- #define HCI_SUPP_COMMANDS_READ_SIMPLE_PAIRING_MODE_OFF 17
- #define HCI_READ_SIMPLE_PAIRING_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_SIMPLE_PAIRING_MODE_OFF] & HCI_SUPP_COMMANDS_READ_SIMPLE_PAIRING_MODE_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_SIMPLE_PAIRING_MODE_MASK 0x40
- #define HCI_SUPP_COMMANDS_WRITE_SIMPLE_PAIRING_MODE_OFF 17
- #define HCI_WRITE_SIMPLE_PAIRING_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_SIMPLE_PAIRING_MODE_OFF] & HCI_SUPP_COMMANDS_WRITE_SIMPLE_PAIRING_MODE_MASK)
- #define HCI_SUPP_COMMANDS_READ_LOCAL_OOB_DATA_MASK 0x80
- #define HCI_SUPP_COMMANDS_READ_LOCAL_OOB_DATA_OFF 17
- #define HCI_READ_LOCAL_OOB_DATA_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LOCAL_OOB_DATA_OFF] & HCI_SUPP_COMMANDS_READ_LOCAL_OOB_DATA_MASK)
- #define HCI_SUPP_COMMANDS_READ_INQUIRY_RESPONSE_TX_POWER_MASK 0x01
- #define HCI_SUPP_COMMANDS_READ_INQUIRY_RESPONSE_TX_POWER_OFF 18
- #define HCI_READ_INQUIRY_RESPONSE_TX_POWER_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_INQUIRY_RESPONSE_TX_POWER_OFF] & HCI_SUPP_COMMANDS_READ_INQUIRY_RESPONSE_TX_POWER_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_INQUIRY_RESPONSE_TX_POWER_MASK 0x02
- #define HCI_SUPP_COMMANDS_WRITE_INQUIRY_RESPONSE_TX_POWER_OFF 18
- #define HCI_WRITE_INQUIRY_RESPONSE_TX_POWER_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_INQUIRY_RESPONSE_TX_POWER_OFF] & HCI_SUPP_COMMANDS_WRITE_INQUIRY_RESPONSE_TX_POWER_MASK)
- #define HCI_SUPP_COMMANDS_READ_DEFAULT_ERRONEOUS_DATA_REPORTING_MASK 0x04
- #define HCI_SUPP_COMMANDS_READ_DEFAULT_ERRONEOUS_DATA_REPORTING_OFF 18
- #define HCI_READ_DEFAULT_ERRONEOUS_DATA_REPORTING_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_DEFAULT_ERRONEOUS_DATA_REPORTING_OFF] & HCI_SUPP_COMMANDS_READ_DEFAULT_ERRONEOUS_DATA_REPORTING_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_DEFAULT_ERRONEOUS_DATA_REPORTING_MASK 0x08
- #define HCI_SUPP_COMMANDS_WRITE_DEFAULT_ERRONEOUS_DATA_REPORTING_OFF 18
- #define HCI_WRITE_DEFAULT_ERRONEOUS_DATA_REPORTING_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_DEFAULT_ERRONEOUS_DATA_REPORTING_OFF] & HCI_SUPP_COMMANDS_WRITE_DEFAULT_ERRONEOUS_DATA_REPORTING_MASK)
- #define HCI_SUPP_COMMANDS_IO_CAPABILITY_REQUEST_REPLY_MASK 0x80
- #define HCI_SUPP_COMMANDS_IO_CAPABILITY_REQUEST_REPLY_OFF 18
- #define HCI_IO_CAPABILITY_REQUEST_REPLY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_IO_CAPABILITY_REQUEST_REPLY_OFF] & HCI_SUPP_COMMANDS_IO_CAPABILITY_REQUEST_REPLY_MASK)
- #define HCI_SUPP_COMMANDS_USER_CONFIRMATION_REQUEST_REPLY_MASK 0x01
- #define HCI_SUPP_COMMANDS_USER_CONFIRMATION_REQUEST_REPLY_OFF 19
- #define HCI_USER_CONFIRMATION_REQUEST_REPLY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_USER_CONFIRMATION_REQUEST_REPLY_OFF] & HCI_SUPP_COMMANDS_USER_CONFIRMATION_REQUEST_REPLY_MASK)
- #define HCI_SUPP_COMMANDS_USER_CONFIRMATION_REQUEST_NEG_REPLY_MASK 0x02
- #define HCI_SUPP_COMMANDS_USER_CONFIRMATION_REQUEST_NEG_REPLY_OFF 19
- #define HCI_USER_CONFIRMATION_REQUEST_NEG_REPLY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_USER_CONFIRMATION_REQUEST_NEG_REPLY_OFF] & HCI_SUPP_COMMANDS_USER_CONFIRMATION_REQUEST_NEG_REPLY_MASK)
- #define HCI_SUPP_COMMANDS_USER_PASSKEY_REQUEST_REPLY_MASK 0x04
- #define HCI_SUPP_COMMANDS_USER_PASSKEY_REQUEST_REPLY_OFF 19
- #define HCI_USER_PASSKEY_REQUEST_REPLY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_USER_PASSKEY_REQUEST_REPLY_OFF] & HCI_SUPP_COMMANDS_USER_PASSKEY_REQUEST_REPLY_MASK)
- #define HCI_SUPP_COMMANDS_USER_PASSKEY_REQUEST_NEG_REPLY_MASK 0x08
- #define HCI_SUPP_COMMANDS_USER_PASSKEY_REQUEST_NEG_REPLY_OFF 19
- #define HCI_USER_PASSKEY_REQUEST_NEG_REPLY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_USER_PASSKEY_REQUEST_NEG_REPLY_OFF] & HCI_SUPP_COMMANDS_USER_PASSKEY_REQUEST_NEG_REPLY_MASK)
- #define HCI_SUPP_COMMANDS_REMOTE_OOB_DATA_REQUEST_REPLY_MASK 0x10
- #define HCI_SUPP_COMMANDS_REMOTE_OOB_DATA_REQUEST_REPLY_OFF 19
- #define HCI_REMOTE_OOB_DATA_REQUEST_REPLY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_REMOTE_OOB_DATA_REQUEST_REPLY_OFF] & HCI_SUPP_COMMANDS_REMOTE_OOB_DATA_REQUEST_REPLY_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_SIMPLE_PAIRING_DBG_MODE_MASK 0x20
- #define HCI_SUPP_COMMANDS_WRITE_SIMPLE_PAIRING_DBG_MODE_OFF 19
- #define HCI_WRITE_SIMPLE_PAIRING_DBG_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_SIMPLE_PAIRING_DBG_MODE_OFF] & HCI_SUPP_COMMANDS_WRITE_SIMPLE_PAIRING_DBG_MODE_MASK)
- #define HCI_SUPP_COMMANDS_ENHANCED_FLUSH_MASK 0x40
- #define HCI_SUPP_COMMANDS_ENHANCED_FLUSH_OFF 19
- #define HCI_ENHANCED_FLUSH_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_ENHANCED_FLUSH_OFF] & HCI_SUPP_COMMANDS_ENHANCED_FLUSH_MASK)
- #define HCI_SUPP_COMMANDS_REMOTE_OOB_DATA_REQUEST_NEG_REPLY_MASK 0x80
- #define HCI_SUPP_COMMANDS_REMOTE_OOB_DATA_REQUEST_NEG_REPLY_OFF 19
- #define HCI_REMOTE_OOB_DATA_REQUEST_NEG_REPLY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_REMOTE_OOB_DATA_REQUEST_NEG_REPLY_OFF] & HCI_SUPP_COMMANDS_REMOTE_OOB_DATA_REQUEST_NEG_REPLY_MASK)
- /* Supported Commands (Byte 20) */
- #define HCI_SUPP_COMMANDS_SEND_KEYPRESS_NOTIF_MASK 0x04
- #define HCI_SUPP_COMMANDS_SEND_KEYPRESS_NOTIF_OFF 20
- #define HCI_SEND_NOTIF_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SEND_KEYPRESS_NOTIF_OFF] & HCI_SUPP_COMMANDS_SEND_KEYPRESS_NOTIF_MASK)
- #define HCI_SUPP_COMMANDS_IO_CAP_REQ_NEG_REPLY_MASK 0x08
- #define HCI_SUPP_COMMANDS_IO_CAP_REQ_NEG_REPLY_OFF 20
- #define HCI_IO_CAP_REQ_NEG_REPLY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_IO_CAP_REQ_NEG_REPLY_OFF] & HCI_SUPP_COMMANDS_IO_CAP_REQ_NEG_REPLY_MASK)
- #define HCI_SUPP_COMMANDS_READ_ENCR_KEY_SIZE_MASK 0x10
- #define HCI_SUPP_COMMANDS_READ_ENCR_KEY_SIZE_OFF 20
- #define HCI_READ_ENCR_KEY_SIZE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_ENCR_KEY_SIZE_OFF] & HCI_SUPP_COMMANDS_READ_ENCR_KEY_SIZE_MASK)
- /* Supported Commands (Byte 21) */
- #define HCI_SUPP_COMMANDS_CREATE_PHYSICAL_LINK_MASK 0x01
- #define HCI_SUPP_COMMANDS_CREATE_PHYSICAL_LINK_OFF 21
- #define HCI_CREATE_PHYSICAL_LINK_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_CREATE_PHYSICAL_LINK_OFF] & HCI_SUPP_COMMANDS_CREATE_PHYSICAL_LINK_MASK)
- #define HCI_SUPP_COMMANDS_ACCEPT_PHYSICAL_LINK_MASK 0x02
- #define HCI_SUPP_COMMANDS_ACCEPT_PHYSICAL_LINK_OFF 21
- #define HCI_ACCEPT_PHYSICAL_LINK_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_ACCEPT_PHYSICAL_LINK_OFF] & HCI_SUPP_COMMANDS_ACCEPT_PHYSICAL_LINK_MASK)
- #define HCI_SUPP_COMMANDS_DISCONNECT_PHYSICAL_LINK_MASK 0x04
- #define HCI_SUPP_COMMANDS_DISCONNECT_PHYSICAL_LINK_OFF 21
- #define HCI_DISCONNECT_PHYSICAL_LINK_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_DISCONNECT_PHYSICAL_LINK_OFF] & HCI_SUPP_COMMANDS_DISCONNECT_PHYSICAL_LINK_MASK)
- #define HCI_SUPP_COMMANDS_CREATE_LOGICAL_LINK_MASK 0x08
- #define HCI_SUPP_COMMANDS_CREATE_LOGICAL_LINK_OFF 21
- #define HCI_CREATE_LOGICAL_LINK_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_CREATE_LOGICAL_LINK_OFF] & HCI_SUPP_COMMANDS_CREATE_LOGICAL_LINK_MASK)
- #define HCI_SUPP_COMMANDS_ACCEPT_LOGICAL_LINK_MASK 0x10
- #define HCI_SUPP_COMMANDS_ACCEPT_LOGICAL_LINK_OFF 21
- #define HCI_ACCEPT_LOGICAL_LINK_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_ACCEPT_LOGICAL_LINK_OFF] & HCI_SUPP_COMMANDS_ACCEPT_LOGICAL_LINK_MASK)
- #define HCI_SUPP_COMMANDS_DISCONNECT_LOGICAL_LINK_MASK 0x20
- #define HCI_SUPP_COMMANDS_DISCONNECT_LOGICAL_LINK_OFF 21
- #define HCI_DISCONNECT_LOGICAL_LINK_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_DISCONNECT_LOGICAL_LINK_OFF] & HCI_SUPP_COMMANDS_DISCONNECT_LOGICAL_LINK_MASK)
- #define HCI_SUPP_COMMANDS_LOGICAL_LINK_CANCEL_MASK 0x40
- #define HCI_SUPP_COMMANDS_LOGICAL_LINK_CANCEL_OFF 21
- #define HCI_LOGICAL_LINK_CANCEL_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_LOGICAL_LINK_CANCEL_OFF] & HCI_SUPP_COMMANDS_LOGICAL_LINK_CANCEL_MASK)
- #define HCI_SUPP_COMMANDS_FLOW_SPEC_MODIFY_MASK 0x80
- #define HCI_SUPP_COMMANDS_FLOW_SPEC_MODIFY_OFF 21
- #define HCI_FLOW_SPEC_MODIFY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_FLOW_SPEC_MODIFY_OFF] & HCI_SUPP_COMMANDS_FLOW_SPEC_MODIFY_MASK)
- /* Supported Commands (Byte 22) */
- #define HCI_SUPP_COMMANDS_READ_LOGICAL_LINK_ACCEPT_TIMEOUT_MASK 0x01
- #define HCI_SUPP_COMMANDS_READ_LOGICAL_LINK_ACCEPT_TIMEOUT_OFF 22
- #define HCI_READ_LOGICAL_LINK_ACCEPT_TIMEOUT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LOGICAL_LINK_ACCEPT_TIMEOUT_OFF] & HCI_SUPP_COMMANDS_READ_LOGICAL_LINK_ACCEPT_TIMEOUT_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_LOGICAL_LINK_ACCEPT_TIMEOUT_MASK 0x02
- #define HCI_SUPP_COMMANDS_WRITE_LOGICAL_LINK_ACCEPT_TIMEOUT_OFF 22
- #define HCI_WRITE_LOGICAL_LINK_ACCEPT_TIMEOUT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_LOGICAL_LINK_ACCEPT_TIMEOUT_OFF] & HCI_SUPP_COMMANDS_WRITE_LOGICAL_LINK_ACCEPT_TIMEOUT_MASK)
- #define HCI_SUPP_COMMANDS_SET_EVENT_MASK_PAGE_2_MASK 0x04
- #define HCI_SUPP_COMMANDS_SET_EVENT_MASK_PAGE_2_OFF 22
- #define HCI_SET_EVENT_MASK_PAGE_2_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_EVENT_MASK_PAGE_2_OFF] & HCI_SUPP_COMMANDS_SET_EVENT_MASK_PAGE_2_MASK)
- #define HCI_SUPP_COMMANDS_READ_LOCATION_DATA_MASK 0x08
- #define HCI_SUPP_COMMANDS_READ_LOCATION_DATA_OFF 22
- #define HCI_READ_LOCATION_DATA_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LOCATION_DATA_OFF] & HCI_SUPP_COMMANDS_READ_LOCATION_DATA_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_LOCATION_DATA_MASK 0x10
- #define HCI_SUPP_COMMANDS_WRITE_LOCATION_DATA_OFF 22
- #define HCI_WRITE_LOCATION_DATA_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_LOCATION_DATA_OFF] & HCI_SUPP_COMMANDS_WRITE_LOCATION_DATA_MASK)
- #define HCI_SUPP_COMMANDS_READ_LOCAL_AMP_INFO_MASK 0x20
- #define HCI_SUPP_COMMANDS_READ_LOCAL_AMP_INFO_OFF 22
- #define HCI_READ_LOCAL_AMP_INFO_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LOCAL_AMP_INFO_OFF] & HCI_SUPP_COMMANDS_READ_LOCAL_AMP_INFO_MASK)
- #define HCI_SUPP_COMMANDS_READ_LOCAL_AMP_ASSOC_MASK 0x40
- #define HCI_SUPP_COMMANDS_READ_LOCAL_AMP_ASSOC_OFF 22
- #define HCI_READ_LOCAL_AMP_ASSOC_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LOCAL_AMP_ASSOC_OFF] & HCI_SUPP_COMMANDS_READ_LOCAL_AMP_ASSOC_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_REMOTE_AMP_ASSOC_MASK 0x80
- #define HCI_SUPP_COMMANDS_WRITE_REMOTE_AMP_ASSOC_OFF 22
- #define HCI_WRITE_REMOTE_AMP_ASSOC_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_REMOTE_AMP_ASSOC_OFF] & HCI_SUPP_COMMANDS_WRITE_REMOTE_AMP_ASSOC_MASK)
- /* Supported Commands (Byte 23) */
- #define HCI_SUPP_COMMANDS_READ_FLOW_CONTROL_MODE_MASK 0x01
- #define HCI_SUPP_COMMANDS_READ_FLOW_CONTROL_MODE_OFF 23
- #define HCI_READ_FLOW_CONTROL_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_FLOW_CONTROL_MODE_OFF] & HCI_SUPP_COMMANDS_READ_FLOW_CONTROL_MODE_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_FLOW_CONTROL_MODE_MASK 0x02
- #define HCI_SUPP_COMMANDS_WRITE_FLOW_CONTROL_MODE_OFF 23
- #define HCI_WRITE_FLOW_CONTROL_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_FLOW_CONTROL_MODE_OFF] & HCI_SUPP_COMMANDS_WRITE_FLOW_CONTROL_MODE_MASK)
- #define HCI_SUPP_COMMANDS_READ_DATA_BLOCK_SIZE_MASK 0x04
- #define HCI_SUPP_COMMANDS_READ_DATA_BLOCK_SIZE_OFF 23
- #define HCI_READ_DATA_BLOCK_SIZE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_DATA_BLOCK_SIZE_OFF] & HCI_SUPP_COMMANDS_READ_DATA_BLOCK_SIZE_MASK)
- #define HCI_SUPP_COMMANDS_ENABLE_AMP_RCVR_REPORTS_MASK 0x20
- #define HCI_SUPP_COMMANDS_ENABLE_AMP_RCVR_REPORTS_OFF 23
- #define HCI_ENABLE_AMP_RCVR_REPORTS_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_ENABLE_AMP_RCVR_REPORTS_OFF] & HCI_SUPP_COMMANDS_ENABLE_AMP_RCVR_REPORTS_MASK)
- #define HCI_SUPP_COMMANDS_AMP_TEST_END_MASK 0x40
- #define HCI_SUPP_COMMANDS_AMP_TEST_END_OFF 23
- #define HCI_AMP_TEST_END_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_AMP_TEST_END_OFF] & HCI_SUPP_COMMANDS_AMP_TEST_END_MASK)
- #define HCI_SUPP_COMMANDS_AMP_TEST_MASK 0x80
- #define HCI_SUPP_COMMANDS_AMP_TEST_OFF 23
- #define HCI_AMP_TEST_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_AMP_TEST_OFF] & HCI_SUPP_COMMANDS_AMP_TEST_MASK)
- /* Supported Commands (Byte 24) */
- #define HCI_SUPP_COMMANDS_READ_TRANSMIT_POWER_LEVEL_MASK 0x01
- #define HCI_SUPP_COMMANDS_READ_TRANSMIT_POWER_LEVEL_OFF 24
- #define HCI_READ_TRANSMIT_POWER_LEVEL_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_TRANSMIT_POWER_LEVEL_OFF] & HCI_SUPP_COMMANDS_READ_TRANSMIT_POWER_LEVEL_MASK)
- #define HCI_SUPP_COMMANDS_READ_BE_FLUSH_TOUT_MASK 0x04
- #define HCI_SUPP_COMMANDS_READ_BE_FLUSH_TOUT_OFF 24
- #define HCI_READ_BE_FLUSH_TOUT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_BE_FLUSH_TOUT_OFF] & HCI_SUPP_COMMANDS_READ_BE_FLUSH_TOUT_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_BE_FLUSH_TOUT_MASK 0x08
- #define HCI_SUPP_COMMANDS_WRITE_BE_FLUSH_TOUT_OFF 24
- #define HCI_WRITE_BE_FLUSH_TOUT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_BE_FLUSH_TOUT_OFF] & HCI_SUPP_COMMANDS_WRITE_BE_FLUSH_TOUT_MASK)
- #define HCI_SUPP_COMMANDS_SHORT_RANGE_MODE_MASK 0x10
- #define HCI_SUPP_COMMANDS_SHORT_RANGE_MODE_OFF 24
- #define HCI_SHORT_RANGE_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SHORT_RANGE_MODE_OFF] & HCI_SUPP_COMMANDS_SHORT_RANGE_MODE_MASK)
- /* LE commands TBD
- ** Supported Commands (Byte 24 continued)
- ** Supported Commands (Byte 25)
- ** Supported Commands (Byte 26)
- ** Supported Commands (Byte 27)
- ** Supported Commands (Byte 28)
- */
- /* Supported Commands (Byte 29) */
- #define HCI_SUPP_COMMANDS_ENH_SETUP_SYNCH_CONN_MASK 0x08
- #define HCI_SUPP_COMMANDS_ENH_SETUP_SYNCH_CONN_OFF 29
- #define HCI_READ_ENH_SETUP_SYNCH_CONN_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_ENH_SETUP_SYNCH_CONN_OFF] & HCI_SUPP_COMMANDS_ENH_SETUP_SYNCH_CONN_MASK)
- #define HCI_SUPP_COMMANDS_ENH_ACCEPT_SYNCH_CONN_MASK 0x10
- #define HCI_SUPP_COMMANDS_ENH_ACCEPT_SYNCH_CONN_OFF 29
- #define HCI_READ_ENH_ACCEPT_SYNCH_CONN_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_ENH_ACCEPT_SYNCH_CONN_OFF] & HCI_SUPP_COMMANDS_ENH_ACCEPT_SYNCH_CONN_MASK)
- #define HCI_SUPP_COMMANDS_READ_LOCAL_CODECS_MASK 0x20
- #define HCI_SUPP_COMMANDS_READ_LOCAL_CODECS_OFF 29
- #define HCI_READ_LOCAL_CODECS_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LOCAL_CODECS_OFF] & HCI_SUPP_COMMANDS_READ_LOCAL_CODECS_MASK)
- #define HCI_SUPP_COMMANDS_SET_MWS_CHANN_PARAM_MASK 0x40
- #define HCI_SUPP_COMMANDS_SET_MWS_CHANN_PARAM_OFF 29
- #define HCI_SET_MWS_CHANNEL_PARAMETERS_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_MWS_CHANN_PARAM_OFF] & HCI_SUPP_COMMANDS_SET_MWS_CHANN_PARAM_MASK)
- #define HCI_SUPP_COMMANDS_SET_EXT_FRAME_CONF_MASK 0x80
- #define HCI_SUPP_COMMANDS_SET_EXT_FRAME_CONF_OFF 29
- #define HCI_SET_EXTERNAL_FRAME_CONFIGURATION_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_EXT_FRAME_CONF_OFF] & HCI_SUPP_COMMANDS_SET_EXT_FRAME_CONF_MASK)
- /* Supported Commands (Byte 30) */
- #define HCI_SUPP_COMMANDS_SET_MWS_SIGNALING_MASK 0x01
- #define HCI_SUPP_COMMANDS_SET_MWS_SIGNALING_OFF 30
- #define HCI_SET_MWS_SIGNALING_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_MWS_SIGNALING_OFF] & HCI_SUPP_COMMANDS_SET_MWS_SIGNALING_MASK)
- #define HCI_SUPP_COMMANDS_SET_MWS_TRANS_LAYER_MASK 0x02
- #define HCI_SUPP_COMMANDS_SET_MWS_TRANS_LAYER_OFF 30
- #define HCI_SET_MWS_TRANSPORT_LAYER_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_MWS_TRANS_LAYER_OFF] & HCI_SUPP_COMMANDS_SET_MWS_TRANS_LAYER_MASK)
- #define HCI_SUPP_COMMANDS_SET_MWS_SCAN_FREQ_TABLE_MASK 0x04
- #define HCI_SUPP_COMMANDS_SET_MWS_SCAN_FREQ_TABLE_OFF 30
- #define HCI_SET_MWS_SCAN_FREQUENCY_TABLE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_MWS_SCAN_FREQ_TABLE_OFF] & HCI_SUPP_COMMANDS_SET_MWS_SCAN_FREQ_TABLE_MASK)
- #define HCI_SUPP_COMMANDS_GET_TRANS_LAYER_CONF_MASK 0x08
- #define HCI_SUPP_COMMANDS_GET_TRANS_LAYER_CONF_OFF 30
- #define HCI_GET_MWS_TRANS_LAYER_CFG_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_GET_TRANS_LAYER_CONF_OFF] & HCI_SUPP_COMMANDS_GET_TRANS_LAYER_CONF_MASK)
- #define HCI_SUPP_COMMANDS_SET_MWS_PATTERN_CONF_MASK 0x10
- #define HCI_SUPP_COMMANDS_SET_MWS_PATTERN_CONF_OFF 30
- #define HCI_SET_MWS_PATTERN_CONFIGURATION_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_MWS_PATTERN_CONF_OFF] & HCI_SUPP_COMMANDS_SET_MWS_PATTERN_CONF_MASK)
- /* Supported Commands (Byte 30 bit 5) */
- #define HCI_SUPP_COMMANDS_SET_TRIG_CLK_CAP_MASK 0x20
- #define HCI_SUPP_COMMANDS_SET_TRIG_CLK_CAP_OFF 30
- #define HCI_SET_TRIG_CLK_CAP_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_TRIG_CLK_CAP_OFF] & HCI_SUPP_COMMANDS_SET_TRIG_CLK_CAP_MASK)
- /* Supported Commands (Byte 30 bit 6-7) */
- #define HCI_SUPP_COMMANDS_TRUNCATED_PAGE 0x06
- #define HCI_SUPP_COMMANDS_TRUNCATED_PAGE_OFF 30
- #define HCI_TRUNCATED_PAGE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_TRUNCATED_PAGE_OFF] & HCI_SUPP_COMMANDS_TRUNCATED_PAGE)
- #define HCI_SUPP_COMMANDS_TRUNCATED_PAGE_CANCEL 0x07
- #define HCI_SUPP_COMMANDS_TRUNCATED_PAGE_CANCEL_OFF 30
- #define HCI_TRUNCATED_PAGE_CANCEL_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_TRUNCATED_PAGE_CANCEL_OFF] & HCI_SUPP_COMMANDS_TRUNCATED_PAGE_CANCEL)
- /* Supported Commands (Byte 31 bit 6-7) */
- #define HCI_SUPP_COMMANDS_SET_CONLESS_SLAVE_BRCST 0x00
- #define HCI_SUPP_COMMANDS_SET_CONLESS_SLAVE_BRCST_OFF 31
- #define HCI_SET_CONLESS_SLAVE_BRCST_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_CONLESS_SLAVE_BRCST_OFF] & HCI_SUPP_COMMANDS_SET_CONLESS_SLAVE_BRCST)
- #define HCI_SUPP_COMMANDS_SET_CONLESS_SLAVE_BRCST_RECEIVE 0x01
- #define HCI_SUPP_COMMANDS_SET_CONLESS_SLAVE_BRCST_RECEIVE_OFF 31
- #define HCI_SET_CONLESS_SLAVE_BRCST_RECEIVE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_CONLESS_SLAVE_BRCST_RECEIVE_OFF] & HCI_SUPP_COMMANDS_SET_CONLESS_SLAVE_BRCST_RECEIVE)
- #define HCI_SUPP_COMMANDS_START_SYNC_TRAIN 0x02
- #define HCI_SUPP_COMMANDS_START_SYNC_TRAIN_OFF 31
- #define HCI_START_SYNC_TRAIN_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_START_SYNC_TRAIN_OFF] & HCI_SUPP_COMMANDS_START_SYNC_TRAIN)
- #define HCI_SUPP_COMMANDS_RECEIVE_SYNC_TRAIN 0x03
- #define HCI_SUPP_COMMANDS_RECEIVE_SYNC_TRAIN_OFF 31
- #define HCI_RECEIVE_SYNC_TRAIN_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_RECEIVE_SYNC_TRAIN_OFF] & HCI_SUPP_COMMANDS_RECEIVE_SYNC_TRAIN)
- #define HCI_SUPP_COMMANDS_SET_RESERVED_LT_ADDR 0x04
- #define HCI_SUPP_COMMANDS_SET_RESERVED_LT_ADDR_OFF 31
- #define HCI_SET_RESERVED_LT_ADDR_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_RESERVED_LT_ADDR_OFF] & HCI_SUPP_COMMANDS_SET_RESERVED_LT_ADDR)
- #define HCI_SUPP_COMMANDS_DELETE_RESERVED_LT_ADDR 0x05
- #define HCI_SUPP_COMMANDS_DELETE_RESERVED_LT_ADDR_OFF 31
- #define HCI_DELETE_RESERVED_LT_ADDR_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_DELETE_RESERVED_LT_ADDR_OFF] & HCI_SUPP_COMMANDS_DELETE_RESERVED_LT_ADDR)
- #define HCI_SUPP_COMMANDS_SET_CONLESS_SLAVE_BRCST_DATA 0x06
- #define HCI_SUPP_COMMANDS_SET_CONLESS_SLAVE_BRCST_DATA_OFF 31
- #define HCI_SET_CONLESS_SLAVE_BRCST_DATA_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_SET_CONLESS_SLAVE_BRCST_DATA_OFF] & HCI_SUPP_COMMANDS_SET_CONLESS_SLAVE_BRCST_DATA)
- #define HCI_SUPP_COMMANDS_READ_SYNC_TRAIN_PARAM 0x07
- #define HCI_SUPP_COMMANDS_READ_SYNC_TRAIN_PARAM_OFF 31
- #define HCI_READ_SYNC_TRAIN_PARAM_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_SYNC_TRAIN_PARAM_OFF] & HCI_SUPP_COMMANDS_READ_SYNC_TRAIN_PARAM)
- /* Supported Commands (Byte 32 bit 0) */
- #define HCI_SUPP_COMMANDS_WRITE_SYNC_TRAIN_PARAM 0x00
- #define HCI_SUPP_COMMANDS_WRITE_SYNC_TRAIN_PARAM_OFF 32
- #define HCI_WRITE_SYNC_TRAIN_PARAM_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_SYNC_TRAIN_PARAM_OFF] & HCI_SUPP_COMMANDS_WRITE_SYNC_TRAIN_PARAM)
- #define HCI_SUPP_COMMANDS_REMOTE_OOB_EXTENDED_DATA_REQUEST_REPLY_MASK 0x02
- #define HCI_SUPP_COMMANDS_REMOTE_OOB_EXTENDED_DATA_REQUEST_REPLY_OFF 32
- #define HCI_REMOTE_OOB_EXTENDED_DATA_REQUEST_REPLY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_REMOTE_OOB_EXTENDED_DATA_REQUEST_REPLY_OFF] & HCI_SUPP_COMMANDS_REMOTE_OOB_EXTENDED_DATA_REQUEST_REPLY_MASK)
- #define HCI_SUPP_COMMANDS_READ_SECURE_CONNS_SUPPORT_MASK 0x04
- #define HCI_SUPP_COMMANDS_READ_SECURE_CONNS_SUPPORT_OFF 32
- #define HCI_READ_SECURE_CONNS_SUPPORT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_SECURE_CONNS_SUPPORT_OFF] & HCI_SUPP_COMMANDS_READ_SECURE_CONNS_SUPPORT_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_SECURE_CONNS_SUPPORT_MASK 0x08
- #define HCI_SUPP_COMMANDS_WRITE_SECURE_CONNS_SUPPORT_OFF 32
- #define HCI_WRITE_SECURE_CONNS_SUPPORT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_SECURE_CONNS_SUPPORT_OFF] & HCI_SUPP_COMMANDS_WRITE_SECURE_CONNS_SUPPORT_MASK)
- #define HCI_SUPP_COMMANDS_READ_AUTHENT_PAYLOAD_TOUT_MASK 0x10
- #define HCI_SUPP_COMMANDS_READ_AUTHENT_PAYLOAD_TOUT_OFF 32
- #define HCI_READ_AUTHENT_PAYLOAD_TOUT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_AUTHENT_PAYLOAD_TOUT_OFF] & HCI_SUPP_COMMANDS_READ_AUTHENT_PAYLOAD_TOUT_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_AUTHENT_PAYLOAD_TOUT_MASK 0x20
- #define HCI_SUPP_COMMANDS_WRITE_AUTHENT_PAYLOAD_TOUT_OFF 32
- #define HCI_WRITE_AUTHENT_PAYLOAD_TOUT_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_AUTHENT_PAYLOAD_TOUT_OFF] & HCI_SUPP_COMMANDS_WRITE_AUTHENT_PAYLOAD_TOUT_MASK)
- #define HCI_SUPP_COMMANDS_READ_LOCAL_OOB_EXTENDED_DATA_MASK 0x40
- #define HCI_SUPP_COMMANDS_READ_LOCAL_OOB_EXTENDED_DATA_OFF 32
- #define HCI_READ_LOCAL_OOB_EXTENDED_DATA_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_READ_LOCAL_OOB_EXTENDED_DATA_OFF] & HCI_SUPP_COMMANDS_READ_LOCAL_OOB_EXTENDED_DATA_MASK)
- #define HCI_SUPP_COMMANDS_WRITE_SECURE_CONNECTIONS_TEST_MODE_MASK 0x80
- #define HCI_SUPP_COMMANDS_WRITE_SECURE_CONNECTIONS_TEST_MODE_OFF 32
- #define HCI_WRITE_SECURE_CONNECTIONS_TEST_MODE_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_WRITE_SECURE_CONNECTIONS_TEST_MODE_OFF] & HCI_SUPP_COMMANDS_WRITE_SECURE_CONNECTIONS_TEST_MODE_MASK)
- /* supported LE remote control connection parameter request reply */
- #define HCI_SUPP_COMMANDS_LE_RC_CONN_PARAM_UPD_RPY_MASK 0x10
- #define HCI_SUPP_COMMANDS_LE_RC_CONN_PARAM_UPD_RPY_OFF 33
- #define HCI_LE_RC_CONN_PARAM_UPD_RPY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_LE_RC_CONN_PARAM_UPD_RPY_OFF] & HCI_SUPP_COMMANDS_LE_RC_CONN_PARAM_UPD_RPY_MASK)
- #define HCI_SUPP_COMMANDS_RLE_RC_CONN_PARAM_UPD_NEG_RPY_MASK 0x20
- #define HCI_SUPP_COMMANDS_LE_RC_CONN_PARAM_UPD_NEG_RPY_OFF 33
- #define HCI_LE_RC_CONN_PARAM_UPD_NEG_RPY_SUPPORTED(x) ((x)[HCI_SUPP_COMMANDS_LE_RC_CONN_PARAM_UPD_NEG_RPY_OFF] & HCI_SUPP_COMMANDS_RLE_RC_CONN_PARAM_UPD_NEG_RPY_MASK)
- #endif
|