btm_ble_gap.c 171 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614
  1. /******************************************************************************
  2. *
  3. * Copyright (C) 2008-2014 Broadcom Corporation
  4. *
  5. * Licensed under the Apache License, Version 2.0 (the "License");
  6. * you may not use this file except in compliance with the License.
  7. * You may obtain a copy of the License at:
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. *
  17. ******************************************************************************/
  18. /******************************************************************************
  19. *
  20. * This file contains functions for BLE GAP.
  21. *
  22. ******************************************************************************/
  23. #include <string.h>
  24. //#include <stdio.h>
  25. #include <stddef.h>
  26. #include "stack/bt_types.h"
  27. //#include "bt_utils.h"
  28. #include "btm_int.h"
  29. #include "stack/btm_ble_api.h"
  30. #include "stack/btu.h"
  31. #include "device/controller.h"
  32. #include "stack/hcimsgs.h"
  33. #include "stack/gap_api.h"
  34. #include "hci/hci_layer.h"
  35. #if BLE_INCLUDED == TRUE
  36. #include "l2c_int.h"
  37. #include "stack/gattdefs.h"
  38. #include "gatt_int.h"
  39. #include "btm_ble_int.h"
  40. //#define LOG_TAG "bt_btm_ble"
  41. //#include "osi/include/log.h"
  42. #include "osi/osi.h"
  43. #include "osi/mutex.h"
  44. #define BTM_BLE_NAME_SHORT 0x01
  45. #define BTM_BLE_NAME_CMPL 0x02
  46. #define BTM_BLE_FILTER_TARGET_UNKNOWN 0xff
  47. #define BTM_BLE_POLICY_UNKNOWN 0xff
  48. #define BTM_EXT_BLE_RMT_NAME_TIMEOUT 30
  49. #define MIN_ADV_LENGTH 2
  50. #define BTM_VSC_CHIP_CAPABILITY_RSP_LEN_L_RELEASE 9
  51. #define BTM_BLE_GAP_ADV_RPT_BATCH_SIZE (10)
  52. #if BTM_DYNAMIC_MEMORY == FALSE
  53. static tBTM_BLE_VSC_CB cmn_ble_gap_vsc_cb;
  54. #else
  55. static tBTM_BLE_VSC_CB *cmn_ble_gap_vsc_cb_ptr;
  56. #define cmn_ble_gap_vsc_cb (*cmn_ble_gap_vsc_cb_ptr)
  57. #endif
  58. #if BLE_VND_INCLUDED == TRUE
  59. static tBTM_BLE_CTRL_FEATURES_CBACK *p_ctrl_le_feature_rd_cmpl_cback = NULL;
  60. #endif
  61. tBTM_CallbackFunc conn_param_update_cb;
  62. /*******************************************************************************
  63. ** Local functions
  64. *******************************************************************************/
  65. static void btm_ble_update_adv_flag(UINT8 flag);
  66. static void btm_ble_process_adv_pkt_cont(BD_ADDR bda, UINT8 addr_type, UINT8 evt_type, UINT8 *p);
  67. UINT8 *btm_ble_build_adv_data(tBTM_BLE_AD_MASK *p_data_mask, UINT8 **p_dst,
  68. tBTM_BLE_ADV_DATA *p_data);
  69. static UINT8 btm_set_conn_mode_adv_init_addr(tBTM_BLE_INQ_CB *p_cb,
  70. BD_ADDR_PTR p_peer_addr_ptr,
  71. tBLE_ADDR_TYPE *p_peer_addr_type,
  72. tBLE_ADDR_TYPE *p_own_addr_type);
  73. static void btm_ble_stop_observe(void);
  74. static void btm_ble_stop_discover(void);
  75. static void btm_adv_pkt_handler(void *arg);
  76. uint32_t BTM_BleUpdateOwnType(uint8_t *own_bda_type, tBTM_START_ADV_CMPL_CBACK *cb);
  77. #define BTM_BLE_INQ_RESULT 0x01
  78. #define BTM_BLE_OBS_RESULT 0x02
  79. #define BTM_BLE_SEL_CONN_RESULT 0x04
  80. #define BTM_BLE_DISCO_RESULT 0x08
  81. static bool is_ble50_inter = false;
  82. void btm_ble_inter_set(bool extble_inter)
  83. {
  84. is_ble50_inter = extble_inter;
  85. }
  86. bool btm_ble_inter_get(void)
  87. {
  88. return is_ble50_inter;
  89. }
  90. /* LE states combo bit to check */
  91. const UINT8 btm_le_state_combo_tbl[BTM_BLE_STATE_MAX][BTM_BLE_STATE_MAX][2] = {
  92. {/* single state support */
  93. {HCI_SUPP_LE_STATES_CONN_ADV_MASK, HCI_SUPP_LE_STATES_CONN_ADV_OFF}, /* conn_adv */
  94. {HCI_SUPP_LE_STATES_INIT_MASK, HCI_SUPP_LE_STATES_INIT_OFF}, /* init */
  95. {HCI_SUPP_LE_STATES_INIT_MASK, HCI_SUPP_LE_STATES_INIT_OFF}, /* master */
  96. {HCI_SUPP_LE_STATES_SLAVE_MASK, HCI_SUPP_LE_STATES_SLAVE_OFF}, /* slave */
  97. {HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_MASK, HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_OFF}, /* lo du dir adv */
  98. {HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_MASK, HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_OFF}, /* hi duty dir adv */
  99. {HCI_SUPP_LE_STATES_NON_CONN_ADV_MASK, HCI_SUPP_LE_STATES_NON_CONN_ADV_OFF}, /* non connectable adv */
  100. {HCI_SUPP_LE_STATES_PASS_SCAN_MASK, HCI_SUPP_LE_STATES_PASS_SCAN_OFF}, /* passive scan */
  101. {HCI_SUPP_LE_STATES_ACTIVE_SCAN_MASK, HCI_SUPP_LE_STATES_ACTIVE_SCAN_OFF}, /* active scan */
  102. {HCI_SUPP_LE_STATES_SCAN_ADV_MASK, HCI_SUPP_LE_STATESSCAN_ADV_OFF} /* scanable adv */
  103. },
  104. { /* conn_adv =0 */
  105. {0, 0}, /* conn_adv */
  106. {HCI_SUPP_LE_STATES_CONN_ADV_INIT_MASK, HCI_SUPP_LE_STATES_CONN_ADV_INIT_OFF}, /* init: 32 */
  107. {HCI_SUPP_LE_STATES_CONN_ADV_MASTER_MASK, HCI_SUPP_LE_STATES_CONN_ADV_MASTER_OFF}, /* master: 35 */
  108. {HCI_SUPP_LE_STATES_CONN_ADV_SLAVE_MASK, HCI_SUPP_LE_STATES_CONN_ADV_SLAVE_OFF}, /* slave: 38,*/
  109. {0, 0}, /* lo du dir adv */
  110. {0, 0}, /* hi duty dir adv */
  111. {0, 0}, /* non connectable adv */
  112. {HCI_SUPP_LE_STATES_CONN_ADV_PASS_SCAN_MASK, HCI_SUPP_LE_STATES_CONN_ADV_PASS_SCAN_OFF}, /* passive scan */
  113. {HCI_SUPP_LE_STATES_CONN_ADV_ACTIVE_SCAN_MASK, HCI_SUPP_LE_STATES_CONN_ADV_ACTIVE_SCAN_OFF}, /* active scan */
  114. {0, 0} /* scanable adv */
  115. },
  116. { /* init */
  117. {HCI_SUPP_LE_STATES_CONN_ADV_INIT_MASK, HCI_SUPP_LE_STATES_CONN_ADV_INIT_OFF}, /* conn_adv: 32 */
  118. {0, 0}, /* init */
  119. {HCI_SUPP_LE_STATES_INIT_MASTER_MASK, HCI_SUPP_LE_STATES_INIT_MASTER_OFF}, /* master 28 */
  120. {HCI_SUPP_LE_STATES_INIT_MASTER_SLAVE_MASK, HCI_SUPP_LE_STATES_INIT_MASTER_SLAVE_OFF}, /* slave 41 */
  121. {HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_INIT_MASK, HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_INIT_OFF} ,/* lo du dir adv 34 */
  122. {HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_INIT_MASK, HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_INIT_OFF}, /* hi duty dir adv 33 */
  123. {HCI_SUPP_LE_STATES_NON_CONN_INIT_MASK, HCI_SUPP_LE_STATES_NON_CONN_INIT_OFF}, /* non connectable adv */
  124. {HCI_SUPP_LE_STATES_PASS_SCAN_INIT_MASK, HCI_SUPP_LE_STATES_PASS_SCAN_INIT_OFF}, /* passive scan */
  125. {HCI_SUPP_LE_STATES_ACTIVE_SCAN_INIT_MASK, HCI_SUPP_LE_STATES_ACTIVE_SCAN_INIT_OFF}, /* active scan */
  126. {HCI_SUPP_LE_STATES_SCAN_ADV_INIT_MASK, HCI_SUPP_LE_STATES_SCAN_ADV_INIT_OFF} /* scanable adv */
  127. },
  128. { /* master */
  129. {HCI_SUPP_LE_STATES_CONN_ADV_MASTER_MASK, HCI_SUPP_LE_STATES_CONN_ADV_MASTER_OFF}, /* conn_adv: 35 */
  130. {HCI_SUPP_LE_STATES_INIT_MASTER_MASK, HCI_SUPP_LE_STATES_INIT_MASTER_OFF}, /* init 28 */
  131. {HCI_SUPP_LE_STATES_INIT_MASTER_MASK, HCI_SUPP_LE_STATES_INIT_MASTER_OFF}, /* master 28 */
  132. {HCI_SUPP_LE_STATES_CONN_ADV_INIT_MASK, HCI_SUPP_LE_STATES_CONN_ADV_INIT_OFF}, /* slave: 32 */
  133. {HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_MASTER_MASK, HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_MASTER_OFF}, /* lo duty cycle adv 37 */
  134. {HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_MASTER_MASK, HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_MASTER_OFF}, /* hi duty cycle adv 36 */
  135. {HCI_SUPP_LE_STATES_NON_CONN_ADV_MASTER_MASK, HCI_SUPP_LE_STATES_NON_CONN_ADV_MASTER_OFF}, /* non connectable adv */
  136. {HCI_SUPP_LE_STATES_PASS_SCAN_MASTER_MASK, HCI_SUPP_LE_STATES_PASS_SCAN_MASTER_OFF}, /* passive scan */
  137. {HCI_SUPP_LE_STATES_ACTIVE_SCAN_MASTER_MASK, HCI_SUPP_LE_STATES_ACTIVE_SCAN_MASTER_OFF}, /* active scan */
  138. {HCI_SUPP_LE_STATES_SCAN_ADV_MASTER_MASK, HCI_SUPP_LE_STATES_SCAN_ADV_MASTER_OFF} /* scanable adv */
  139. },
  140. { /* slave */
  141. {HCI_SUPP_LE_STATES_CONN_ADV_SLAVE_MASK, HCI_SUPP_LE_STATES_CONN_ADV_SLAVE_OFF}, /* conn_adv: 38,*/
  142. {HCI_SUPP_LE_STATES_INIT_MASTER_SLAVE_MASK, HCI_SUPP_LE_STATES_INIT_MASTER_SLAVE_OFF}, /* init 41 */
  143. {HCI_SUPP_LE_STATES_INIT_MASTER_SLAVE_MASK, HCI_SUPP_LE_STATES_INIT_MASTER_SLAVE_OFF}, /* master 41 */
  144. {HCI_SUPP_LE_STATES_CONN_ADV_SLAVE_MASK, HCI_SUPP_LE_STATES_CONN_ADV_SLAVE_OFF}, /* slave: 38,*/
  145. {HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_SLAVE_MASK, HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_SLAVE_OFF}, /* lo duty cycle adv 40 */
  146. {HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_SLAVE_MASK, HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_SLAVE_OFF}, /* hi duty cycle adv 39 */
  147. {HCI_SUPP_LE_STATES_NON_CONN_ADV_SLAVE_MASK, HCI_SUPP_LE_STATES_NON_CONN_ADV_SLAVE_OFF}, /* non connectable adv */
  148. {HCI_SUPP_LE_STATES_PASS_SCAN_SLAVE_MASK, HCI_SUPP_LE_STATES_PASS_SCAN_SLAVE_OFF}, /* passive scan */
  149. {HCI_SUPP_LE_STATES_ACTIVE_SCAN_SLAVE_MASK, HCI_SUPP_LE_STATES_ACTIVE_SCAN_SLAVE_OFF}, /* active scan */
  150. {HCI_SUPP_LE_STATES_SCAN_ADV_SLAVE_MASK, HCI_SUPP_LE_STATES_SCAN_ADV_SLAVE_OFF} /* scanable adv */
  151. },
  152. { /* lo duty cycle adv */
  153. {0, 0}, /* conn_adv: 38,*/
  154. {HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_INIT_MASK, HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_INIT_OFF} ,/* init 34 */
  155. {HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_MASTER_MASK, HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_MASTER_OFF}, /* master 37 */
  156. {HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_SLAVE_MASK, HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_SLAVE_OFF}, /* slave: 40 */
  157. {0, 0}, /* lo duty cycle adv 40 */
  158. {0, 0}, /* hi duty cycle adv 39 */
  159. {0, 0}, /* non connectable adv */
  160. {HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_PASS_SCAN_MASK, HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_PASS_SCAN_OFF}, /* passive scan */
  161. {HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_ACTIVE_SCAN_MASK, HCI_SUPP_LE_STATES_LO_DUTY_DIR_ADV_ACTIVE_SCAN_OFF}, /* active scan */
  162. {0, 0} /* scanable adv */
  163. },
  164. { /* hi duty cycle adv */
  165. {0, 0}, /* conn_adv: 38,*/
  166. {HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_INIT_MASK, HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_INIT_OFF}, /* init 33 */
  167. {HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_MASTER_MASK, HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_MASTER_OFF}, /* master 36 */
  168. {HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_SLAVE_MASK, HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_SLAVE_OFF}, /* slave: 39*/
  169. {0, 0}, /* lo duty cycle adv 40 */
  170. {0, 0}, /* hi duty cycle adv 39 */
  171. {0, 0}, /* non connectable adv */
  172. {HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_PASS_SCAN_MASK, HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_PASS_SCAN_OFF}, /* passive scan */
  173. {HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_ACTIVE_SCAN_MASK, HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_ACTIVE_SCAN_OFF}, /* active scan */
  174. {0, 0} /* scanable adv */
  175. },
  176. { /* non connectable adv */
  177. {0, 0}, /* conn_adv: */
  178. {HCI_SUPP_LE_STATES_NON_CONN_INIT_MASK, HCI_SUPP_LE_STATES_NON_CONN_INIT_OFF}, /* init */
  179. {HCI_SUPP_LE_STATES_NON_CONN_ADV_MASTER_MASK, HCI_SUPP_LE_STATES_NON_CONN_ADV_MASTER_OFF}, /* master */
  180. {HCI_SUPP_LE_STATES_NON_CONN_ADV_SLAVE_MASK, HCI_SUPP_LE_STATES_NON_CONN_ADV_SLAVE_OFF}, /* slave: */
  181. {0, 0}, /* lo duty cycle adv */
  182. {0, 0}, /* hi duty cycle adv */
  183. {0, 0}, /* non connectable adv */
  184. {HCI_SUPP_LE_STATES_NON_CONN_ADV_PASS_SCAN_MASK, HCI_SUPP_LE_STATES_NON_CONN_ADV_PASS_SCAN_OFF}, /* passive scan */
  185. {HCI_SUPP_LE_STATES_NON_CONN_ADV_ACTIVE_SCAN_MASK, HCI_SUPP_LE_STATES_NON_CONN_ADV_ACTIVE_SCAN_OFF}, /* active scan */
  186. {0, 0} /* scanable adv */
  187. },
  188. { /* passive scan */
  189. {HCI_SUPP_LE_STATES_CONN_ADV_PASS_SCAN_MASK, HCI_SUPP_LE_STATES_CONN_ADV_PASS_SCAN_OFF}, /* conn_adv: */
  190. {HCI_SUPP_LE_STATES_PASS_SCAN_INIT_MASK, HCI_SUPP_LE_STATES_PASS_SCAN_INIT_OFF}, /* init */
  191. {HCI_SUPP_LE_STATES_PASS_SCAN_MASTER_MASK, HCI_SUPP_LE_STATES_PASS_SCAN_MASTER_OFF}, /* master */
  192. {HCI_SUPP_LE_STATES_PASS_SCAN_SLAVE_MASK, HCI_SUPP_LE_STATES_PASS_SCAN_SLAVE_OFF}, /* slave: */
  193. {0, 0}, /* lo duty cycle adv */
  194. {HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_PASS_SCAN_MASK, HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_PASS_SCAN_OFF}, /* hi duty cycle adv */
  195. {HCI_SUPP_LE_STATES_NON_CONN_ADV_PASS_SCAN_MASK, HCI_SUPP_LE_STATES_NON_CONN_ADV_PASS_SCAN_OFF}, /* non connectable adv */
  196. {0, 0}, /* passive scan */
  197. {0, 0}, /* active scan */
  198. {HCI_SUPP_LE_STATES_SCAN_ADV_PASS_SCAN_MASK, HCI_SUPP_LE_STATES_SCAN_ADV_PASS_SCAN_OFF} /* scanable adv */
  199. },
  200. { /* active scan */
  201. {HCI_SUPP_LE_STATES_CONN_ADV_ACTIVE_SCAN_MASK, HCI_SUPP_LE_STATES_CONN_ADV_ACTIVE_SCAN_OFF}, /* conn_adv: */
  202. {HCI_SUPP_LE_STATES_ACTIVE_SCAN_INIT_MASK, HCI_SUPP_LE_STATES_ACTIVE_SCAN_INIT_OFF}, /* init */
  203. {HCI_SUPP_LE_STATES_ACTIVE_SCAN_MASTER_MASK, HCI_SUPP_LE_STATES_ACTIVE_SCAN_MASTER_OFF}, /* master */
  204. {HCI_SUPP_LE_STATES_ACTIVE_SCAN_SLAVE_MASK, HCI_SUPP_LE_STATES_ACTIVE_SCAN_SLAVE_OFF}, /* slave: */
  205. {0, 0}, /* lo duty cycle adv */
  206. {HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_ACTIVE_SCAN_MASK, HCI_SUPP_LE_STATES_HI_DUTY_DIR_ADV_ACTIVE_SCAN_OFF}, /* hi duty cycle adv */
  207. {HCI_SUPP_LE_STATES_NON_CONN_ADV_ACTIVE_SCAN_MASK, HCI_SUPP_LE_STATES_NON_CONN_ADV_ACTIVE_SCAN_OFF}, /* non connectable adv */
  208. {0, 0}, /* TODO: passive scan */
  209. {0, 0}, /* TODO: active scan */
  210. {HCI_SUPP_LE_STATES_SCAN_ADV_ACTIVE_SCAN_MASK, HCI_SUPP_LE_STATES_SCAN_ADV_ACTIVE_SCAN_OFF} /* scanable adv */
  211. },
  212. { /* scanable adv */
  213. {0, 0}, /* conn_adv: */
  214. {HCI_SUPP_LE_STATES_SCAN_ADV_INIT_MASK, HCI_SUPP_LE_STATES_SCAN_ADV_INIT_OFF}, /* init */
  215. {HCI_SUPP_LE_STATES_SCAN_ADV_MASTER_MASK, HCI_SUPP_LE_STATES_SCAN_ADV_MASTER_OFF}, /* master */
  216. {HCI_SUPP_LE_STATES_SCAN_ADV_SLAVE_MASK, HCI_SUPP_LE_STATES_SCAN_ADV_SLAVE_OFF}, /* slave: */
  217. {0, 0}, /* lo duty cycle adv */
  218. {0, 0}, /* hi duty cycle adv */
  219. {0, 0}, /* non connectable adv */
  220. {HCI_SUPP_LE_STATES_SCAN_ADV_PASS_SCAN_MASK, HCI_SUPP_LE_STATES_SCAN_ADV_PASS_SCAN_OFF}, /* passive scan */
  221. {HCI_SUPP_LE_STATES_SCAN_ADV_ACTIVE_SCAN_MASK, HCI_SUPP_LE_STATES_SCAN_ADV_ACTIVE_SCAN_OFF}, /* active scan */
  222. {0, 0} /* scanable adv */
  223. }
  224. };
  225. /* check LE combo state supported */
  226. #define BTM_LE_STATES_SUPPORTED(x, y, z) ((x)[(z)] & (y))
  227. static osi_mutex_t adv_enable_lock;
  228. static osi_mutex_t adv_data_lock;
  229. static osi_mutex_t adv_param_lock;
  230. static osi_mutex_t scan_enable_lock;
  231. static osi_mutex_t scan_param_lock;
  232. osi_sem_t adv_enable_sem;
  233. osi_sem_t adv_data_sem;
  234. osi_sem_t adv_param_sem;
  235. osi_sem_t scan_enable_sem;
  236. osi_sem_t scan_param_sem;
  237. uint8_t adv_enable_status = 0;
  238. uint8_t adv_data_status = 0;
  239. uint8_t adv_param_status = 0;
  240. uint8_t scan_enable_status = 0;
  241. uint8_t scan_param_status = 0;
  242. void btm_ble_lock_init(void)
  243. {
  244. osi_mutex_new(&adv_enable_lock);
  245. osi_mutex_new(&adv_data_lock);
  246. osi_mutex_new(&adv_param_lock);
  247. osi_mutex_new(&scan_enable_lock);
  248. osi_mutex_new(&scan_param_lock);
  249. }
  250. void btm_ble_lock_free(void)
  251. {
  252. osi_mutex_free(&adv_enable_lock);
  253. osi_mutex_free(&adv_data_lock);
  254. osi_mutex_free(&adv_param_lock);
  255. osi_mutex_free(&scan_enable_lock);
  256. osi_mutex_free(&scan_param_lock);
  257. }
  258. void btm_ble_sem_init(void)
  259. {
  260. osi_sem_new(&adv_enable_sem, 1, 0);
  261. osi_sem_new(&adv_data_sem, 1, 0);
  262. osi_sem_new(&adv_param_sem, 1, 0);
  263. osi_sem_new(&scan_enable_sem, 1, 0);
  264. osi_sem_new(&scan_param_sem, 1, 0);
  265. }
  266. void btm_ble_sem_free(void)
  267. {
  268. osi_sem_free(&adv_enable_sem);
  269. osi_sem_free(&adv_data_sem);
  270. osi_sem_free(&adv_param_sem);
  271. osi_sem_free(&scan_enable_sem);
  272. osi_sem_free(&scan_param_sem);
  273. }
  274. /*******************************************************************************
  275. **
  276. ** Function BTM_BleRegiseterConnParamCallback
  277. **
  278. ** Description register connection parameters update callback func
  279. **
  280. ** Returns void
  281. **
  282. *******************************************************************************/
  283. void BTM_BleRegiseterConnParamCallback(tBTM_UPDATE_CONN_PARAM_CBACK *update_conn_param_cb)
  284. {
  285. conn_param_update_cb.update_conn_param_cb = update_conn_param_cb;
  286. }
  287. /*******************************************************************************
  288. **
  289. ** Function BTM_BleUpdateAdvWhitelist
  290. **
  291. ** Description Add or remove device from advertising white list
  292. **
  293. ** Returns void
  294. **
  295. *******************************************************************************/
  296. BOOLEAN BTM_BleUpdateAdvWhitelist(BOOLEAN add_remove, BD_ADDR remote_bda, tBLE_ADDR_TYPE addr_type, tBTM_ADD_WHITELIST_CBACK *add_wl_cb)
  297. {
  298. return btm_update_dev_to_white_list(add_remove, remote_bda, addr_type, add_wl_cb);
  299. }
  300. /*******************************************************************************
  301. **
  302. ** Function BTM_BleUpdateAdvWhitelist
  303. **
  304. ** Description Add or remove device from advertising white list
  305. **
  306. ** Returns void
  307. **
  308. *******************************************************************************/
  309. void BTM_BleClearWhitelist(void)
  310. {
  311. btm_ble_clear_white_list();
  312. }
  313. /*******************************************************************************
  314. **
  315. ** Function BTM_BleUpdateAdvFilterPolicy
  316. **
  317. ** Description This function update the filter policy of advertiser.
  318. **
  319. ** Parameter adv_policy: advertising filter policy
  320. **
  321. ** Return void
  322. *******************************************************************************/
  323. void BTM_BleUpdateAdvFilterPolicy(tBTM_BLE_AFP adv_policy)
  324. {
  325. tBTM_BLE_INQ_CB *p_cb = &btm_cb.ble_ctr_cb.inq_var;
  326. tBLE_ADDR_TYPE init_addr_type = BLE_ADDR_PUBLIC;
  327. BD_ADDR p_addr_ptr = {0};
  328. UINT8 adv_mode = p_cb->adv_mode;
  329. BTM_TRACE_EVENT ("BTM_BleUpdateAdvFilterPolicy\n");
  330. if (!controller_get_interface()->supports_ble()) {
  331. return;
  332. }
  333. if (p_cb->afp != adv_policy) {
  334. p_cb->afp = adv_policy;
  335. /* if adv active, stop and restart */
  336. btm_ble_stop_adv ();
  337. if (p_cb->connectable_mode & BTM_BLE_CONNECTABLE) {
  338. p_cb->evt_type = btm_set_conn_mode_adv_init_addr(p_cb, p_addr_ptr, &init_addr_type,
  339. &p_cb->adv_addr_type);
  340. }
  341. btsnd_hcic_ble_write_adv_params ((UINT16)(p_cb->adv_interval_min ? p_cb->adv_interval_min :
  342. BTM_BLE_GAP_ADV_SLOW_INT),
  343. (UINT16)(p_cb->adv_interval_max ? p_cb->adv_interval_max :
  344. BTM_BLE_GAP_ADV_SLOW_INT),
  345. p_cb->evt_type,
  346. p_cb->adv_addr_type,
  347. init_addr_type,
  348. p_addr_ptr,
  349. p_cb->adv_chnl_map,
  350. p_cb->afp);
  351. if (adv_mode == BTM_BLE_ADV_ENABLE) {
  352. btm_ble_start_adv ();
  353. }
  354. }
  355. }
  356. /*******************************************************************************
  357. **
  358. ** Function btm_ble_send_extended_scan_params
  359. **
  360. ** Description This function sends out the extended scan parameters command to the controller
  361. **
  362. ** Parameters scan_type - Scan type
  363. ** scan_int - Scan interval
  364. ** scan_win - Scan window
  365. ** addr_type_own - Own address type
  366. ** scan_filter_policy - Scan filter policy
  367. **
  368. ** Returns TRUE or FALSE
  369. **
  370. *******************************************************************************/
  371. BOOLEAN btm_ble_send_extended_scan_params(UINT8 scan_type, UINT32 scan_int,
  372. UINT32 scan_win, UINT8 addr_type_own,
  373. UINT8 scan_filter_policy)
  374. {
  375. UINT8 scan_param[HCIC_PARAM_SIZE_BLE_WRITE_EXTENDED_SCAN_PARAM];
  376. UINT8 *pp_scan = scan_param;
  377. memset(scan_param, 0, HCIC_PARAM_SIZE_BLE_WRITE_EXTENDED_SCAN_PARAM);
  378. UINT8_TO_STREAM(pp_scan, scan_type);
  379. UINT32_TO_STREAM(pp_scan, scan_int);
  380. UINT32_TO_STREAM(pp_scan, scan_win);
  381. UINT8_TO_STREAM(pp_scan, addr_type_own);
  382. UINT8_TO_STREAM(pp_scan, scan_filter_policy);
  383. BTM_TRACE_DEBUG("%s, %d, %d", __func__, scan_int, scan_win);
  384. if ((BTM_VendorSpecificCommand(HCI_BLE_EXTENDED_SCAN_PARAMS_OCF,
  385. HCIC_PARAM_SIZE_BLE_WRITE_EXTENDED_SCAN_PARAM, scan_param, NULL)) != BTM_SUCCESS) {
  386. BTM_TRACE_ERROR("%s error sending extended scan parameters", __func__);
  387. return FALSE;
  388. }
  389. return TRUE;
  390. }
  391. /*******************************************************************************
  392. **
  393. ** Function BTM_BleObserve
  394. **
  395. ** Description This procedure keep the device listening for advertising
  396. ** events from a broadcast device.
  397. **
  398. ** Parameters start: start or stop observe.
  399. ** white_list: use white list in observer mode or not.
  400. **
  401. ** Returns void
  402. **
  403. *******************************************************************************/
  404. tBTM_STATUS BTM_BleObserve(BOOLEAN start, UINT32 duration,
  405. tBTM_INQ_RESULTS_CB *p_results_cb, tBTM_CMPL_CB *p_cmpl_cb)
  406. {
  407. tBTM_BLE_INQ_CB *p_inq = &btm_cb.ble_ctr_cb.inq_var;
  408. tBTM_STATUS status = BTM_WRONG_MODE;
  409. UINT32 scan_interval = !p_inq->scan_interval ? BTM_BLE_GAP_DISC_SCAN_INT : p_inq->scan_interval;
  410. UINT32 scan_window = !p_inq->scan_window ? BTM_BLE_GAP_DISC_SCAN_WIN : p_inq->scan_window;
  411. BTM_TRACE_EVENT ("%s : scan_type:%d, %d, %d\n", __func__, btm_cb.btm_inq_vars.scan_type,
  412. p_inq->scan_interval, p_inq->scan_window);
  413. if (!controller_get_interface()->supports_ble()) {
  414. return BTM_ILLEGAL_VALUE;
  415. }
  416. if (start) {
  417. /* shared inquiry database, do not allow observe if any inquiry is active */
  418. if (BTM_BLE_IS_OBS_ACTIVE(btm_cb.ble_ctr_cb.scan_activity)) {
  419. BTM_TRACE_ERROR("%s Observe Already Active", __func__);
  420. return status;
  421. }
  422. btm_cb.ble_ctr_cb.p_obs_results_cb = p_results_cb;
  423. btm_cb.ble_ctr_cb.p_obs_cmpl_cb = p_cmpl_cb;
  424. status = BTM_CMD_STARTED;
  425. /* scan is not started */
  426. if (!BTM_BLE_IS_SCAN_ACTIVE(btm_cb.ble_ctr_cb.scan_activity)) {
  427. /* allow config of scan type */
  428. p_inq->scan_type = (p_inq->scan_type == BTM_BLE_SCAN_MODE_NONE) ?
  429. BTM_BLE_SCAN_MODE_ACTI : p_inq->scan_type;
  430. /* assume observe always not using white list */
  431. #if (defined BLE_PRIVACY_SPT && BLE_PRIVACY_SPT == TRUE)
  432. /* enable resolving list */
  433. //btm_ble_enable_resolving_list_for_platform(BTM_BLE_RL_SCAN);
  434. #endif
  435. if (cmn_ble_gap_vsc_cb.extended_scan_support == 0) {
  436. btsnd_hcic_ble_set_scan_params(p_inq->scan_type, (UINT16)scan_interval,
  437. (UINT16)scan_window,
  438. btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type,
  439. BTM_BLE_DEFAULT_SFP);
  440. } else {
  441. btm_ble_send_extended_scan_params(p_inq->scan_type, scan_interval, scan_window,
  442. btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type,
  443. BTM_BLE_DEFAULT_SFP);
  444. }
  445. status = btm_ble_start_scan();
  446. }
  447. if (status == BTM_CMD_STARTED) {
  448. btm_cb.ble_ctr_cb.scan_activity |= BTM_LE_OBSERVE_ACTIVE;
  449. if (duration != 0)
  450. /* start observer timer */
  451. {
  452. btu_start_timer (&btm_cb.ble_ctr_cb.obs_timer_ent, BTU_TTYPE_BLE_OBSERVE, duration);
  453. }
  454. }
  455. } else if (BTM_BLE_IS_OBS_ACTIVE(btm_cb.ble_ctr_cb.scan_activity)) {
  456. status = BTM_CMD_STARTED;
  457. btm_ble_stop_observe();
  458. } else {
  459. BTM_TRACE_ERROR("%s Observe not active\n", __func__);
  460. }
  461. return status;
  462. }
  463. /*******************************************************************************
  464. **
  465. ** Function BTM_BleScan
  466. **
  467. ** Description This procedure keep the device listening for advertising
  468. ** events from a broadcast device.
  469. **
  470. ** Parameters start: start or stop scan.
  471. ** white_list: use white list in observer mode or not.
  472. **
  473. ** Returns void
  474. **
  475. *******************************************************************************/
  476. tBTM_STATUS BTM_BleScan(BOOLEAN start, UINT32 duration,
  477. tBTM_INQ_RESULTS_CB *p_results_cb, tBTM_CMPL_CB *p_cmpl_cb, tBTM_INQ_DIS_CB *p_discard_cb)
  478. {
  479. tBTM_BLE_INQ_CB *p_inq = &btm_cb.ble_ctr_cb.inq_var;
  480. tBTM_STATUS status = BTM_WRONG_MODE;
  481. if (!controller_get_interface()->supports_ble()) {
  482. return BTM_ILLEGAL_VALUE;
  483. }
  484. if (start) {
  485. /* shared inquiry database, do not allow scan if any inquiry is active */
  486. if (BTM_BLE_IS_DISCO_ACTIVE(btm_cb.ble_ctr_cb.scan_activity)) {
  487. BTM_TRACE_ERROR("%s scan already active", __func__);
  488. return status;
  489. }
  490. btm_cb.ble_ctr_cb.p_scan_results_cb = p_results_cb;
  491. btm_cb.ble_ctr_cb.p_scan_cmpl_cb = p_cmpl_cb;
  492. btm_cb.ble_ctr_cb.p_obs_discard_cb = p_discard_cb;
  493. status = BTM_CMD_STARTED;
  494. /* scan is not started */
  495. if (!BTM_BLE_IS_SCAN_ACTIVE(btm_cb.ble_ctr_cb.scan_activity)) {
  496. /* assume observe always not using white list */
  497. #if (defined BLE_PRIVACY_SPT && BLE_PRIVACY_SPT == TRUE)
  498. /* enable resolving list */
  499. //btm_ble_enable_resolving_list_for_platform(BTM_BLE_RL_SCAN);
  500. #endif
  501. // if not set scan params, set default scan params
  502. if (!p_inq->scan_params_set) {
  503. /* allow config of scan type */
  504. p_inq->scan_type = BTM_BLE_SCAN_MODE_ACTI;
  505. p_inq->scan_interval = BTM_BLE_GAP_DISC_SCAN_INT;
  506. p_inq->scan_window = BTM_BLE_GAP_DISC_SCAN_WIN;
  507. p_inq->sfp = BTM_BLE_DEFAULT_SFP;
  508. p_inq->scan_params_set = TRUE;
  509. p_inq->scan_duplicate_filter = BTM_BLE_DUPLICATE_DISABLE;
  510. btsnd_hcic_ble_set_scan_params(p_inq->scan_type, p_inq->scan_interval,
  511. p_inq->scan_window,
  512. btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type,
  513. p_inq->sfp);
  514. }
  515. status = btm_ble_start_scan();
  516. }
  517. if (status == BTM_CMD_STARTED) {
  518. btm_cb.ble_ctr_cb.scan_activity |= BTM_LE_DISCOVER_ACTIVE;
  519. if (duration != 0)
  520. /* start observer timer */
  521. {
  522. btu_start_timer (&btm_cb.ble_ctr_cb.scan_timer_ent, BTU_TTYPE_BLE_SCAN, duration);
  523. }
  524. }
  525. } else if (BTM_BLE_IS_DISCO_ACTIVE(btm_cb.ble_ctr_cb.scan_activity)) {
  526. status = BTM_CMD_STARTED;
  527. btm_ble_stop_discover();
  528. } else {
  529. BTM_TRACE_ERROR("%s scan not active\n", __func__);
  530. }
  531. return status;
  532. }
  533. /*******************************************************************************
  534. **
  535. ** Function BTM_BleBroadcast
  536. **
  537. ** Description This function is to start or stop broadcasting.
  538. **
  539. ** Parameters start: start or stop broadcasting.
  540. **
  541. ** Returns status.
  542. **
  543. *******************************************************************************/
  544. tBTM_STATUS BTM_BleBroadcast(BOOLEAN start, tBTM_START_STOP_ADV_CMPL_CBACK *p_stop_adv_cback)
  545. {
  546. tBTM_STATUS status = BTM_NO_RESOURCES;
  547. tBTM_LE_RANDOM_CB *p_addr_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
  548. tBTM_BLE_INQ_CB *p_cb = &btm_cb.ble_ctr_cb.inq_var;
  549. UINT8 evt_type = p_cb->scan_rsp ? BTM_BLE_DISCOVER_EVT : BTM_BLE_NON_CONNECT_EVT;
  550. if (!controller_get_interface()->supports_ble()) {
  551. return BTM_ILLEGAL_VALUE;
  552. }
  553. #ifdef BTM_BLE_PC_ADV_TEST_MODE
  554. if (BTM_BLE_PC_ADV_TEST_MODE) {
  555. evt_type = p_cb->scan_rsp ? BTM_BLE_CONNECT_EVT : BTM_BLE_NON_CONNECT_EVT;
  556. }
  557. #endif
  558. if (start) {
  559. /* update adv params */
  560. if (!btsnd_hcic_ble_write_adv_params ((UINT16)(p_cb->adv_interval_min ? p_cb->adv_interval_min :
  561. BTM_BLE_GAP_ADV_INT),
  562. (UINT16)(p_cb->adv_interval_max ? p_cb->adv_interval_max :
  563. BTM_BLE_GAP_ADV_INT),
  564. evt_type,
  565. p_addr_cb->own_addr_type,
  566. p_cb->direct_bda.type,
  567. p_cb->direct_bda.bda,
  568. p_cb->adv_chnl_map,
  569. p_cb->afp))
  570. {
  571. status = BTM_NO_RESOURCES;
  572. } else {
  573. p_cb->evt_type = evt_type;
  574. }
  575. status = btm_ble_start_adv ();
  576. } else {
  577. //save the stop adv callback to the BTM env.
  578. p_cb->p_stop_adv_cb = p_stop_adv_cback;
  579. status = btm_ble_stop_adv();
  580. #if BLE_PRIVACY_SPT == TRUE
  581. btm_ble_disable_resolving_list(BTM_BLE_RL_ADV, TRUE);
  582. #endif
  583. }
  584. return status;
  585. }
  586. #if BLE_VND_INCLUDED == TRUE
  587. /*******************************************************************************
  588. **
  589. ** Function btm_vsc_brcm_features_complete
  590. **
  591. ** Description Command Complete callback for HCI_BLE_VENDOR_CAP_OCF
  592. **
  593. ** Returns void
  594. **
  595. *******************************************************************************/
  596. static void btm_ble_vendor_capability_vsc_cmpl_cback (tBTM_VSC_CMPL *p_vcs_cplt_params)
  597. {
  598. UINT8 status = 0xFF;
  599. UINT8 *p;
  600. BTM_TRACE_DEBUG("%s", __func__);
  601. /* Check status of command complete event */
  602. if ((p_vcs_cplt_params->opcode == HCI_BLE_VENDOR_CAP_OCF) &&
  603. (p_vcs_cplt_params->param_len > 0)) {
  604. p = p_vcs_cplt_params->p_param_buf;
  605. STREAM_TO_UINT8(status, p);
  606. }
  607. if (status == HCI_SUCCESS) {
  608. STREAM_TO_UINT8(btm_cb.cmn_ble_vsc_cb.adv_inst_max, p);
  609. STREAM_TO_UINT8(btm_cb.cmn_ble_vsc_cb.rpa_offloading, p);
  610. STREAM_TO_UINT16(btm_cb.cmn_ble_vsc_cb.tot_scan_results_strg, p);
  611. STREAM_TO_UINT8(btm_cb.cmn_ble_vsc_cb.max_irk_list_sz, p);
  612. STREAM_TO_UINT8(btm_cb.cmn_ble_vsc_cb.filter_support, p);
  613. STREAM_TO_UINT8(btm_cb.cmn_ble_vsc_cb.max_filter, p);
  614. STREAM_TO_UINT8(btm_cb.cmn_ble_vsc_cb.energy_support, p);
  615. if (p_vcs_cplt_params->param_len > BTM_VSC_CHIP_CAPABILITY_RSP_LEN_L_RELEASE) {
  616. STREAM_TO_UINT16(btm_cb.cmn_ble_vsc_cb.version_supported, p);
  617. } else {
  618. btm_cb.cmn_ble_vsc_cb.version_supported = BTM_VSC_CHIP_CAPABILITY_L_VERSION;
  619. }
  620. if (btm_cb.cmn_ble_vsc_cb.version_supported >= BTM_VSC_CHIP_CAPABILITY_M_VERSION) {
  621. STREAM_TO_UINT16(btm_cb.cmn_ble_vsc_cb.total_trackable_advertisers, p);
  622. STREAM_TO_UINT16(btm_cb.cmn_ble_vsc_cb.extended_scan_support, p);
  623. STREAM_TO_UINT16(btm_cb.cmn_ble_vsc_cb.debug_logging_supported, p);
  624. }
  625. btm_cb.cmn_ble_vsc_cb.values_read = TRUE;
  626. }
  627. BTM_TRACE_DEBUG("%s: stat=%d, irk=%d, ADV ins:%d, rpa=%d, ener=%d, ext_scan=%d",
  628. __func__, status, btm_cb.cmn_ble_vsc_cb.max_irk_list_sz,
  629. btm_cb.cmn_ble_vsc_cb.adv_inst_max, btm_cb.cmn_ble_vsc_cb.rpa_offloading,
  630. btm_cb.cmn_ble_vsc_cb.energy_support, btm_cb.cmn_ble_vsc_cb.extended_scan_support);
  631. if (BTM_BleMaxMultiAdvInstanceCount() > 0) {
  632. btm_ble_multi_adv_init();
  633. }
  634. if (btm_cb.cmn_ble_vsc_cb.max_filter > 0) {
  635. btm_ble_adv_filter_init();
  636. }
  637. #if (defined BLE_PRIVACY_SPT && BLE_PRIVACY_SPT == TRUE)
  638. /* VS capability included and non-4.2 device */
  639. if (btm_cb.cmn_ble_vsc_cb.max_irk_list_sz > 0 &&
  640. controller_get_interface()->get_ble_resolving_list_max_size() == 0) {
  641. btm_ble_resolving_list_init(btm_cb.cmn_ble_vsc_cb.max_irk_list_sz);
  642. }
  643. #endif
  644. if (btm_cb.cmn_ble_vsc_cb.tot_scan_results_strg > 0) {
  645. btm_ble_batchscan_init();
  646. }
  647. if (p_ctrl_le_feature_rd_cmpl_cback != NULL) {
  648. p_ctrl_le_feature_rd_cmpl_cback(status);
  649. }
  650. }
  651. #endif
  652. /*******************************************************************************
  653. **
  654. ** Function BTM_BleGetVendorCapabilities
  655. **
  656. ** Description This function reads local LE features
  657. **
  658. ** Parameters p_cmn_vsc_cb : Locala LE capability structure
  659. **
  660. ** Returns void
  661. **
  662. *******************************************************************************/
  663. extern void BTM_BleGetVendorCapabilities(tBTM_BLE_VSC_CB *p_cmn_vsc_cb)
  664. {
  665. BTM_TRACE_DEBUG("BTM_BleGetVendorCapabilities");
  666. if (NULL != p_cmn_vsc_cb) {
  667. *p_cmn_vsc_cb = btm_cb.cmn_ble_vsc_cb;
  668. }
  669. }
  670. /******************************************************************************
  671. **
  672. ** Function BTM_BleReadControllerFeatures
  673. **
  674. ** Description Reads BLE specific controller features
  675. **
  676. ** Parameters: tBTM_BLE_CTRL_FEATURES_CBACK : Callback to notify when features are read
  677. **
  678. ** Returns void
  679. **
  680. *******************************************************************************/
  681. extern void BTM_BleReadControllerFeatures(tBTM_BLE_CTRL_FEATURES_CBACK *p_vsc_cback)
  682. {
  683. if (TRUE == btm_cb.cmn_ble_vsc_cb.values_read) {
  684. return;
  685. }
  686. #if BLE_VND_INCLUDED == TRUE
  687. BTM_TRACE_DEBUG("BTM_BleReadControllerFeatures");
  688. p_ctrl_le_feature_rd_cmpl_cback = p_vsc_cback;
  689. if ( BTM_VendorSpecificCommand (HCI_BLE_VENDOR_CAP_OCF,
  690. 0,
  691. NULL,
  692. btm_ble_vendor_capability_vsc_cmpl_cback)
  693. != BTM_CMD_STARTED) {
  694. BTM_TRACE_ERROR("LE Get_Vendor Capabilities Command Failed.");
  695. }
  696. #else
  697. UNUSED(p_vsc_cback);
  698. #endif
  699. return ;
  700. }
  701. void BTM_VendorHciEchoCmdCallback(tBTM_VSC_CMPL *p1)
  702. {
  703. #if (!CONFIG_BT_STACK_NO_LOG)
  704. if (!p1) {
  705. return;
  706. }
  707. uint8_t *p = p1->p_param_buf;
  708. uint8_t status, echo;
  709. STREAM_TO_UINT8 (status, p);
  710. STREAM_TO_UINT8 (echo, p);
  711. #endif
  712. BTM_TRACE_DEBUG("%s status 0x%x echo 0x%x", __func__, status, echo);
  713. }
  714. /******************************************************************************
  715. **
  716. ** Function BTM_VendorHciEchoCmdTest
  717. **
  718. ** Description vendor common echo hci cmd test, controller will return status and echo
  719. **
  720. ** Parameters: echo : echo value
  721. **
  722. ** Returns void
  723. **
  724. *******************************************************************************/
  725. void BTM_VendorHciEchoCmdTest(uint8_t echo)
  726. {
  727. BTM_VendorSpecificCommand (HCI_VENDOR_COMMON_ECHO_CMD_OPCODE,
  728. 1,
  729. &echo,
  730. BTM_VendorHciEchoCmdCallback);
  731. }
  732. /*******************************************************************************
  733. **
  734. ** Function BTM_BleEnableMixedPrivacyMode
  735. **
  736. ** Description This function is called to enabled Mixed mode if privacy 1.2
  737. ** is applicable in controller.
  738. **
  739. ** Parameters mixed_on: mixed mode to be used or not.
  740. **
  741. ** Returns void
  742. **
  743. *******************************************************************************/
  744. void BTM_BleEnableMixedPrivacyMode(BOOLEAN mixed_on)
  745. {
  746. #if BLE_PRIVACY_SPT == TRUE
  747. btm_cb.ble_ctr_cb.mixed_mode = mixed_on;
  748. /* TODO: send VSC to enabled mixed mode */
  749. #endif
  750. }
  751. /*******************************************************************************
  752. **
  753. ** Function BTM_BleConfigPrivacy
  754. **
  755. ** Description This function is called to enable or disable the privacy in
  756. ** LE channel of the local device.
  757. **
  758. ** Parameters privacy_mode: privacy mode on or off.
  759. **
  760. ** Returns BOOLEAN privacy mode set success; otherwise failed.
  761. **
  762. *******************************************************************************/
  763. BOOLEAN BTM_BleConfigPrivacy(BOOLEAN privacy_mode, tBTM_SET_LOCAL_PRIVACY_CBACK *set_local_privacy_cback)
  764. {
  765. #if BLE_PRIVACY_SPT == TRUE
  766. tBTM_BLE_CB *p_cb = &btm_cb.ble_ctr_cb;
  767. tBTM_LE_RANDOM_CB *random_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
  768. if (random_cb){
  769. random_cb->set_local_privacy_cback = set_local_privacy_cback;
  770. }else{
  771. BTM_TRACE_ERROR("%s,random_cb = NULL", __func__);
  772. }
  773. BTM_TRACE_EVENT ("%s\n", __func__);
  774. /* if LE is not supported, return error */
  775. if (!controller_get_interface()->supports_ble()) {
  776. return FALSE;
  777. }
  778. if (!(p_cb->inq_var.state == BTM_BLE_STOP_SCAN || p_cb->inq_var.state == BTM_BLE_STOP_ADV || p_cb->inq_var.state == BTM_BLE_IDLE)) {
  779. BTM_TRACE_ERROR("Advertising or scaning now, can't set privacy ");
  780. if (random_cb && random_cb->set_local_privacy_cback){
  781. (*random_cb->set_local_privacy_cback)(BTM_SET_PRIVACY_FAIL);
  782. random_cb->set_local_privacy_cback = NULL;
  783. }
  784. return FALSE;
  785. }
  786. #if (defined(GAP_INCLUDED) && GAP_INCLUDED == TRUE && GATTS_INCLUDED == TRUE)
  787. uint8_t addr_resolution = 0;
  788. #endif /* defined(GAP_INCLUDED) && GAP_INCLUDED == TRUE && GATTS_INCLUDED == TRUE */
  789. if (!privacy_mode) { /* if privacy disabled, always use public address */
  790. p_cb->addr_mgnt_cb.exist_addr_bit &= (~BTM_BLE_GAP_ADDR_BIT_RESOLVABLE);
  791. memset(p_cb->addr_mgnt_cb.resolvale_addr, 0, BD_ADDR_LEN);
  792. p_cb->addr_mgnt_cb.own_addr_type = BLE_ADDR_PUBLIC;
  793. p_cb->privacy_mode = BTM_PRIVACY_NONE;
  794. if (random_cb && random_cb->set_local_privacy_cback){
  795. (*random_cb->set_local_privacy_cback)(BTM_SET_PRIVACY_SUCCESS);
  796. random_cb->set_local_privacy_cback = NULL;
  797. }
  798. // Disable RPA function
  799. btsnd_hcic_ble_set_addr_resolution_enable(FALSE);
  800. } else { /* privacy is turned on*/
  801. /* always set host random address, used when privacy 1.1 or priavcy 1.2 is disabled */
  802. btm_gen_resolvable_private_addr((void *)btm_gen_resolve_paddr_low);
  803. if (BTM_BleMaxMultiAdvInstanceCount() > 0) {
  804. btm_ble_multi_adv_enb_privacy(privacy_mode);
  805. }
  806. /* 4.2 controller only allow privacy 1.2 or mixed mode, resolvable private address in controller */
  807. if (controller_get_interface()->supports_ble_privacy()) {
  808. #if (defined(GAP_INCLUDED) && GAP_INCLUDED == TRUE && GATTS_INCLUDED == TRUE)
  809. addr_resolution = 1;
  810. #endif /* defined(GAP_INCLUDED) && GAP_INCLUDED == TRUE && GATTS_INCLUDED == TRUE */
  811. /* check vendor specific capability */
  812. p_cb->privacy_mode = btm_cb.ble_ctr_cb.mixed_mode ? BTM_PRIVACY_MIXED : BTM_PRIVACY_1_2;
  813. } else { /* 4.1/4.0 controller */
  814. p_cb->privacy_mode = BTM_PRIVACY_1_1;
  815. }
  816. // Disable RPA function
  817. btsnd_hcic_ble_set_addr_resolution_enable(TRUE);
  818. }
  819. #if (defined(GAP_INCLUDED) && GAP_INCLUDED == TRUE && GATTS_INCLUDED == TRUE)
  820. GAP_BleAttrDBUpdate (GATT_UUID_GAP_CENTRAL_ADDR_RESOL, (tGAP_BLE_ATTR_VALUE *)&addr_resolution);
  821. #endif
  822. return TRUE;
  823. #else
  824. return FALSE;
  825. #endif
  826. }
  827. /*******************************************************************************
  828. **
  829. ** Function BTMGetLocalResolvablePrivateAddr
  830. **
  831. ** Description This function is called to get local RPA address
  832. **
  833. ** Parameters bda: address pointer.
  834. **
  835. **
  836. *******************************************************************************/
  837. BOOLEAN BTM_GetLocalResolvablePrivateAddr(BD_ADDR bda)
  838. {
  839. tBTM_LE_RANDOM_CB *p_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
  840. BTM_TRACE_DEBUG ("get owm resolvable random address");
  841. if (bda) {
  842. /* if privacy disabled, return false */
  843. if ((p_cb->exist_addr_bit & BTM_BLE_GAP_ADDR_BIT_RESOLVABLE) == BTM_BLE_GAP_ADDR_BIT_RESOLVABLE) {
  844. memcpy(bda, p_cb->resolvale_addr, BD_ADDR_LEN);
  845. BTM_TRACE_DEBUG("own resolvable random address: 0x%02x:%02x:%02x:%02x:%02x:%02x",
  846. p_cb->resolvale_addr[0], p_cb->resolvale_addr[1],
  847. p_cb->resolvale_addr[2], p_cb->resolvale_addr[3],
  848. p_cb->resolvale_addr[4], p_cb->resolvale_addr[5]);
  849. return TRUE;
  850. }
  851. return FALSE;
  852. }
  853. return FALSE;
  854. }
  855. /*******************************************************************************
  856. **
  857. ** Function BTM_UpdateAddrInfor
  858. **
  859. ** Description This function is called to update address information
  860. **
  861. ** Parameters addr_type: address type
  862. ** bda: address pointer.
  863. **
  864. **
  865. *******************************************************************************/
  866. void BTM_UpdateAddrInfor(uint8_t addr_type, BD_ADDR bda)
  867. {
  868. btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type = addr_type;
  869. memcpy(btm_cb.ble_ctr_cb.addr_mgnt_cb.private_addr, bda, BD_ADDR_LEN);
  870. }
  871. /*******************************************************************************
  872. **
  873. ** Function BTM_BleSetStaticAddr
  874. **
  875. ** Description This function is called to save random address
  876. **
  877. ** Parameters rand_addr: address pointer.
  878. **
  879. **
  880. *******************************************************************************/
  881. void BTM_BleSetStaticAddr(BD_ADDR rand_addr)
  882. {
  883. memcpy(btm_cb.ble_ctr_cb.addr_mgnt_cb.static_rand_addr, rand_addr, BD_ADDR_LEN);
  884. btm_cb.ble_ctr_cb.addr_mgnt_cb.exist_addr_bit |= BTM_BLE_GAP_ADDR_BIT_RANDOM;
  885. }
  886. uint32_t BTM_BleUpdateOwnType(uint8_t *own_bda_type, tBTM_START_ADV_CMPL_CBACK *cb)
  887. {
  888. if(*own_bda_type == BLE_ADDR_RANDOM) {
  889. if((btm_cb.ble_ctr_cb.addr_mgnt_cb.exist_addr_bit & BTM_BLE_GAP_ADDR_BIT_RANDOM) == BTM_BLE_GAP_ADDR_BIT_RANDOM) {
  890. //close privacy
  891. #if BLE_PRIVACY_SPT == TRUE
  892. if (btm_cb.ble_ctr_cb.privacy_mode != BTM_PRIVACY_NONE) {
  893. BTM_BleConfigPrivacy(FALSE, NULL);
  894. }
  895. #endif
  896. btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type = BLE_ADDR_RANDOM;
  897. memcpy(btm_cb.ble_ctr_cb.addr_mgnt_cb.private_addr, btm_cb.ble_ctr_cb.addr_mgnt_cb.static_rand_addr, BD_ADDR_LEN);
  898. // set address to controller
  899. btsnd_hcic_ble_set_random_addr(btm_cb.ble_ctr_cb.addr_mgnt_cb.static_rand_addr);
  900. } else if((btm_cb.ble_ctr_cb.addr_mgnt_cb.exist_addr_bit & BTM_BLE_GAP_ADDR_BIT_RESOLVABLE) == BTM_BLE_GAP_ADDR_BIT_RESOLVABLE) {
  901. btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type = BLE_ADDR_RANDOM;
  902. memcpy(btm_cb.ble_ctr_cb.addr_mgnt_cb.private_addr, btm_cb.ble_ctr_cb.addr_mgnt_cb.resolvale_addr, BD_ADDR_LEN);
  903. btsnd_hcic_ble_set_random_addr(btm_cb.ble_ctr_cb.addr_mgnt_cb.resolvale_addr);
  904. }else {
  905. BTM_TRACE_ERROR ("No random address yet, please set random address and try\n");
  906. if(cb) {
  907. (* cb)(HCI_ERR_ESP_VENDOR_FAIL);
  908. }
  909. return BTM_ILLEGAL_VALUE;
  910. }
  911. } else if(*own_bda_type == BLE_ADDR_PUBLIC_ID || *own_bda_type == BLE_ADDR_RANDOM_ID) {
  912. if((btm_cb.ble_ctr_cb.addr_mgnt_cb.exist_addr_bit & BTM_BLE_GAP_ADDR_BIT_RESOLVABLE) == BTM_BLE_GAP_ADDR_BIT_RESOLVABLE) {
  913. *own_bda_type = BLE_ADDR_RANDOM;
  914. btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type = BLE_ADDR_RANDOM;
  915. memcpy(btm_cb.ble_ctr_cb.addr_mgnt_cb.private_addr, btm_cb.ble_ctr_cb.addr_mgnt_cb.resolvale_addr, BD_ADDR_LEN);
  916. btsnd_hcic_ble_set_random_addr(btm_cb.ble_ctr_cb.addr_mgnt_cb.resolvale_addr);
  917. } else {
  918. #if BLE_PRIVACY_SPT == TRUE
  919. if(btm_cb.ble_ctr_cb.privacy_mode != BTM_PRIVACY_NONE) {
  920. BTM_TRACE_ERROR ("Error state\n");
  921. if(cb) {
  922. (* cb)(HCI_ERR_ESP_VENDOR_FAIL);
  923. }
  924. return BTM_ILLEGAL_VALUE;
  925. }
  926. #endif
  927. if(*own_bda_type == BLE_ADDR_PUBLIC_ID) {
  928. *own_bda_type = BLE_ADDR_PUBLIC;
  929. btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type = BLE_ADDR_PUBLIC;
  930. } else { //own_bda_type == BLE_ADDR_RANDOM_ID
  931. if((btm_cb.ble_ctr_cb.addr_mgnt_cb.exist_addr_bit & BTM_BLE_GAP_ADDR_BIT_RANDOM) == BTM_BLE_GAP_ADDR_BIT_RANDOM) {
  932. *own_bda_type = BLE_ADDR_RANDOM;
  933. btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type = BLE_ADDR_RANDOM;
  934. memcpy(btm_cb.ble_ctr_cb.addr_mgnt_cb.private_addr, btm_cb.ble_ctr_cb.addr_mgnt_cb.static_rand_addr, BD_ADDR_LEN);
  935. btsnd_hcic_ble_set_random_addr(btm_cb.ble_ctr_cb.addr_mgnt_cb.static_rand_addr);
  936. } else {
  937. BTM_TRACE_ERROR ("No RPA and no random address yet, please set RPA or random address and try\n");
  938. if(cb) {
  939. (* cb)(HCI_ERR_ESP_VENDOR_FAIL);
  940. }
  941. return BTM_ILLEGAL_VALUE;
  942. }
  943. }
  944. }
  945. } else {
  946. btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type = BLE_ADDR_PUBLIC;
  947. }
  948. return BTM_SUCCESS;
  949. }
  950. /*******************************************************************************
  951. **
  952. ** Function BTM_BleConfigLocalIcon
  953. **
  954. ** Description This function is called to set local icon
  955. **
  956. ** Parameters icon: appearance value.
  957. **
  958. **
  959. *******************************************************************************/
  960. void BTM_BleConfigLocalIcon(uint16_t icon)
  961. {
  962. #if (defined(GAP_INCLUDED) && GAP_INCLUDED == TRUE && GATTS_INCLUDED == TRUE)
  963. tGAP_BLE_ATTR_VALUE p_value;
  964. p_value.icon = icon;
  965. GAP_BleAttrDBUpdate(GATT_UUID_GAP_ICON, &p_value);
  966. #else
  967. BTM_TRACE_ERROR("%s\n", __func__);
  968. #endif
  969. }
  970. /*******************************************************************************
  971. **
  972. ** Function BTM_BleConfigConnParams
  973. **
  974. ** Description This function is called to set the connection parameters
  975. **
  976. ** Parameters int_min: minimum connection interval
  977. ** int_max: maximum connection interval
  978. ** latency: slave latency
  979. ** timeout: supervision timeout
  980. **
  981. *******************************************************************************/
  982. void BTM_BleConfigConnParams(uint16_t int_min, uint16_t int_max, uint16_t latency, uint16_t timeout)
  983. {
  984. #if (defined(GAP_INCLUDED) && GAP_INCLUDED == TRUE && GATTS_INCLUDED == TRUE)
  985. tGAP_BLE_ATTR_VALUE p_value;
  986. p_value.conn_param.int_min = int_min;
  987. p_value.conn_param.int_max = int_max;
  988. p_value.conn_param.latency = latency;
  989. p_value.conn_param.sp_tout = timeout;
  990. GAP_BleAttrDBUpdate(GATT_UUID_GAP_PREF_CONN_PARAM, &p_value);
  991. #else
  992. BTM_TRACE_ERROR("%s\n", __func__);
  993. #endif
  994. }
  995. /*******************************************************************************
  996. **
  997. ** Function BTM_BleMaxMultiAdvInstanceCount
  998. **
  999. ** Description Returns max number of multi adv instances supported by controller
  1000. **
  1001. ** Returns Max multi adv instance count
  1002. **
  1003. *******************************************************************************/
  1004. extern UINT8 BTM_BleMaxMultiAdvInstanceCount(void)
  1005. {
  1006. return btm_cb.cmn_ble_vsc_cb.adv_inst_max < BTM_BLE_MULTI_ADV_MAX ?
  1007. btm_cb.cmn_ble_vsc_cb.adv_inst_max : BTM_BLE_MULTI_ADV_MAX;
  1008. }
  1009. #if BLE_PRIVACY_SPT == TRUE
  1010. /*******************************************************************************
  1011. **
  1012. ** Function btm_ble_resolve_random_addr_on_adv
  1013. **
  1014. ** Description resolve random address complete callback.
  1015. **
  1016. ** Returns void
  1017. **
  1018. *******************************************************************************/
  1019. static void btm_ble_resolve_random_addr_on_adv(void *p_rec, void *p)
  1020. {
  1021. tBTM_SEC_DEV_REC *match_rec = (tBTM_SEC_DEV_REC *) p_rec;
  1022. UINT8 addr_type = BLE_ADDR_RANDOM;
  1023. BD_ADDR bda;
  1024. UINT8 *pp = (UINT8 *)p + 1;
  1025. UINT8 evt_type;
  1026. BTM_TRACE_EVENT ("btm_ble_resolve_random_addr_on_adv ");
  1027. STREAM_TO_UINT8 (evt_type, pp);
  1028. STREAM_TO_UINT8 (addr_type, pp);
  1029. STREAM_TO_BDADDR (bda, pp);
  1030. if (match_rec) {
  1031. BTM_TRACE_DEBUG("Random match");
  1032. match_rec->ble.active_addr_type = BTM_BLE_ADDR_RRA;
  1033. memcpy(match_rec->ble.cur_rand_addr, bda, BD_ADDR_LEN);
  1034. if (btm_ble_init_pseudo_addr(match_rec, bda)) {
  1035. memcpy(bda, match_rec->bd_addr, BD_ADDR_LEN);
  1036. } else {
  1037. // Assign the original address to be the current report address
  1038. memcpy(bda, match_rec->ble.pseudo_addr, BD_ADDR_LEN);
  1039. }
  1040. }
  1041. btm_ble_process_adv_pkt_cont(bda, addr_type, evt_type, pp);
  1042. return;
  1043. }
  1044. #endif
  1045. /*******************************************************************************
  1046. **
  1047. ** Function BTM_BleLocalPrivacyEnabled
  1048. **
  1049. ** Description Checks if local device supports private address
  1050. **
  1051. ** Returns Return TRUE if local privacy is enabled else FALSE
  1052. **
  1053. *******************************************************************************/
  1054. BOOLEAN BTM_BleLocalPrivacyEnabled(void)
  1055. {
  1056. #if BLE_PRIVACY_SPT == TRUE
  1057. return (btm_cb.ble_ctr_cb.privacy_mode != BTM_PRIVACY_NONE);
  1058. #else
  1059. return false;
  1060. #endif
  1061. }
  1062. /*******************************************************************************
  1063. **
  1064. ** Function BTM_BleSetBgConnType
  1065. **
  1066. ** Description This function is called to set BLE connectable mode for a
  1067. ** peripheral device.
  1068. **
  1069. ** Parameters bg_conn_type: it can be auto connection, or selective connection.
  1070. ** p_select_cback: callback function when selective connection procedure
  1071. ** is being used.
  1072. **
  1073. ** Returns void
  1074. **
  1075. *******************************************************************************/
  1076. BOOLEAN BTM_BleSetBgConnType(tBTM_BLE_CONN_TYPE bg_conn_type,
  1077. tBTM_BLE_SEL_CBACK *p_select_cback)
  1078. {
  1079. BOOLEAN started = TRUE;
  1080. BTM_TRACE_EVENT ("BTM_BleSetBgConnType ");
  1081. if (!controller_get_interface()->supports_ble()) {
  1082. return FALSE;
  1083. }
  1084. if (btm_cb.ble_ctr_cb.bg_conn_type != bg_conn_type) {
  1085. switch (bg_conn_type) {
  1086. case BTM_BLE_CONN_AUTO:
  1087. btm_ble_start_auto_conn(TRUE);
  1088. break;
  1089. case BTM_BLE_CONN_SELECTIVE:
  1090. if (btm_cb.ble_ctr_cb.bg_conn_type == BTM_BLE_CONN_AUTO) {
  1091. btm_ble_start_auto_conn(FALSE);
  1092. }
  1093. btm_ble_start_select_conn(TRUE, p_select_cback);
  1094. break;
  1095. case BTM_BLE_CONN_NONE:
  1096. if (btm_cb.ble_ctr_cb.bg_conn_type == BTM_BLE_CONN_AUTO) {
  1097. btm_ble_start_auto_conn(FALSE);
  1098. } else if (btm_cb.ble_ctr_cb.bg_conn_type == BTM_BLE_CONN_SELECTIVE) {
  1099. btm_ble_start_select_conn(FALSE, NULL);
  1100. }
  1101. started = TRUE;
  1102. break;
  1103. default:
  1104. BTM_TRACE_ERROR("invalid bg connection type : %d ", bg_conn_type);
  1105. started = FALSE;
  1106. break;
  1107. }
  1108. if (started) {
  1109. btm_cb.ble_ctr_cb.bg_conn_type = bg_conn_type;
  1110. }
  1111. }
  1112. return started;
  1113. }
  1114. /*******************************************************************************
  1115. **
  1116. ** Function BTM_BleClearBgConnDev
  1117. **
  1118. ** Description This function is called to clear the whitelist,
  1119. ** end any pending whitelist connections,
  1120. * and reset the local bg device list.
  1121. **
  1122. ** Parameters void
  1123. **
  1124. ** Returns void
  1125. **
  1126. *******************************************************************************/
  1127. void BTM_BleClearBgConnDev(void)
  1128. {
  1129. btm_ble_start_auto_conn(FALSE);
  1130. btm_ble_clear_white_list();
  1131. gatt_reset_bgdev_list();
  1132. }
  1133. /*******************************************************************************
  1134. **
  1135. ** Function BTM_BleUpdateBgConnDev
  1136. **
  1137. ** Description This function is called to add or remove a device into/from
  1138. ** background connection procedure. The background connection
  1139. * procedure is decided by the background connection type, it can be
  1140. * auto connection, or selective connection.
  1141. **
  1142. ** Parameters add_remove: TRUE to add; FALSE to remove.
  1143. ** remote_bda: device address to add/remove.
  1144. **
  1145. ** Returns void
  1146. **
  1147. *******************************************************************************/
  1148. BOOLEAN BTM_BleUpdateBgConnDev(BOOLEAN add_remove, BD_ADDR remote_bda)
  1149. {
  1150. BTM_TRACE_EVENT("%s() add=%d", __func__, add_remove);
  1151. return btm_update_dev_to_white_list(add_remove, remote_bda, 0, NULL);
  1152. }
  1153. /*******************************************************************************
  1154. **
  1155. ** Function BTM_BleSetConnectableMode
  1156. **
  1157. ** Description This function is called to set BLE connectable mode for a
  1158. ** peripheral device.
  1159. **
  1160. ** Parameters conn_mode: directed connectable mode, or non-directed.It can
  1161. ** be BTM_BLE_CONNECT_EVT, BTM_BLE_CONNECT_DIR_EVT or
  1162. ** BTM_BLE_CONNECT_LO_DUTY_DIR_EVT
  1163. **
  1164. ** Returns BTM_ILLEGAL_VALUE if controller does not support BLE.
  1165. ** BTM_SUCCESS is status set successfully; otherwise failure.
  1166. **
  1167. *******************************************************************************/
  1168. tBTM_STATUS BTM_BleSetConnectableMode(tBTM_BLE_CONN_MODE connectable_mode)
  1169. {
  1170. tBTM_BLE_INQ_CB *p_cb = &btm_cb.ble_ctr_cb.inq_var;
  1171. BTM_TRACE_EVENT ("%s connectable_mode = %d ", __func__, connectable_mode);
  1172. if (!controller_get_interface()->supports_ble()) {
  1173. return BTM_ILLEGAL_VALUE;
  1174. }
  1175. p_cb->directed_conn = connectable_mode;
  1176. return btm_ble_set_connectability( p_cb->connectable_mode);
  1177. }
  1178. /*******************************************************************************
  1179. **
  1180. ** Function btm_set_conn_mode_adv_init_addr
  1181. **
  1182. ** Description set initator address type and local address type based on adv
  1183. ** mode.
  1184. **
  1185. **
  1186. *******************************************************************************/
  1187. static UINT8 btm_set_conn_mode_adv_init_addr(tBTM_BLE_INQ_CB *p_cb,
  1188. BD_ADDR_PTR p_peer_addr_ptr,
  1189. tBLE_ADDR_TYPE *p_peer_addr_type,
  1190. tBLE_ADDR_TYPE *p_own_addr_type)
  1191. {
  1192. UINT8 evt_type;
  1193. #if BLE_PRIVACY_SPT == TRUE
  1194. UINT8 i = BTM_SEC_MAX_DEVICE_RECORDS;
  1195. tBTM_SEC_DEV_REC *p_dev_rec;
  1196. list_node_t *p_node = NULL;
  1197. #endif ///BLE_PRIVACY_SPT == TRUE
  1198. evt_type = (p_cb->connectable_mode == BTM_BLE_NON_CONNECTABLE) ? \
  1199. ((p_cb->scan_rsp) ? BTM_BLE_DISCOVER_EVT : BTM_BLE_NON_CONNECT_EVT )\
  1200. : BTM_BLE_CONNECT_EVT;
  1201. if (evt_type == BTM_BLE_CONNECT_EVT) {
  1202. evt_type = p_cb->directed_conn;
  1203. if ( p_cb->directed_conn == BTM_BLE_CONNECT_DIR_EVT ||
  1204. p_cb->directed_conn == BTM_BLE_CONNECT_LO_DUTY_DIR_EVT) {
  1205. #if BLE_PRIVACY_SPT == TRUE
  1206. /* for privacy 1.2, convert peer address as static, own address set as ID addr */
  1207. if (btm_cb.ble_ctr_cb.privacy_mode == BTM_PRIVACY_1_2 ||
  1208. btm_cb.ble_ctr_cb.privacy_mode == BTM_PRIVACY_MIXED) {
  1209. /* only do so for bonded device */
  1210. if ((p_dev_rec = btm_find_or_alloc_dev (p_cb->direct_bda.bda)) != NULL &&
  1211. p_dev_rec->ble.in_controller_list & BTM_RESOLVING_LIST_BIT) {
  1212. //btm_ble_enable_resolving_list(BTM_BLE_RL_ADV);
  1213. memcpy(p_peer_addr_ptr, p_dev_rec->ble.static_addr, BD_ADDR_LEN);
  1214. *p_peer_addr_type = p_dev_rec->ble.static_addr_type;
  1215. *p_own_addr_type = BLE_ADDR_RANDOM_ID;
  1216. return evt_type;
  1217. }
  1218. /* otherwise fall though as normal directed adv */
  1219. else {
  1220. btm_ble_disable_resolving_list(BTM_BLE_RL_ADV, TRUE);
  1221. }
  1222. }
  1223. #endif
  1224. /* direct adv mode does not have privacy, if privacy is not enabled */
  1225. *p_peer_addr_type = p_cb->direct_bda.type;
  1226. memcpy(p_peer_addr_ptr, p_cb->direct_bda.bda, BD_ADDR_LEN);
  1227. return evt_type;
  1228. }
  1229. }
  1230. /* undirect adv mode or non-connectable mode*/
  1231. #if BLE_PRIVACY_SPT == TRUE
  1232. /* when privacy 1.2 privacy only mode is used, or mixed mode */
  1233. if ((btm_cb.ble_ctr_cb.privacy_mode == BTM_PRIVACY_1_2 && p_cb->afp != AP_SCAN_CONN_ALL) ||
  1234. btm_cb.ble_ctr_cb.privacy_mode == BTM_PRIVACY_MIXED) {
  1235. /* if enhanced privacy is required, set Identity address and matching IRK peer */
  1236. for (p_node = list_begin(btm_cb.p_sec_dev_rec_list); p_node; p_node = list_next(p_node)) {
  1237. p_dev_rec = list_node(p_node);
  1238. if ((p_dev_rec->sec_flags & BTM_SEC_IN_USE) != 0 &&
  1239. (p_dev_rec->ble.in_controller_list & BTM_RESOLVING_LIST_BIT) != 0) {
  1240. memcpy(p_peer_addr_ptr, p_dev_rec->ble.static_addr, BD_ADDR_LEN);
  1241. *p_peer_addr_type = p_dev_rec->ble.static_addr_type;
  1242. break;
  1243. }
  1244. }
  1245. if (i != BTM_SEC_MAX_DEVICE_RECORDS) {
  1246. *p_own_addr_type = BLE_ADDR_RANDOM_ID;
  1247. } else
  1248. /* resolving list is empty, not enabled */
  1249. {
  1250. *p_own_addr_type = BLE_ADDR_RANDOM;
  1251. }
  1252. }
  1253. /* privacy 1.1, or privacy 1.2, general discoverable/connectable mode, disable privacy in */
  1254. /* controller fall back to host based privacy */
  1255. else if (btm_cb.ble_ctr_cb.privacy_mode != BTM_PRIVACY_NONE) {
  1256. *p_own_addr_type = BLE_ADDR_RANDOM;
  1257. }
  1258. #endif
  1259. /* if no privacy,do not set any peer address,*/
  1260. /* local address type go by global privacy setting */
  1261. return evt_type;
  1262. }
  1263. /*******************************************************************************
  1264. **
  1265. ** Function BTM_BleSetAdvParams
  1266. **
  1267. ** Description This function is called to set advertising parameters.
  1268. **
  1269. ** Parameters adv_int_min: minimum advertising interval
  1270. ** adv_int_max: maximum advertising interval
  1271. ** p_dir_bda: connectable direct initiator's LE device address
  1272. ** chnl_map: advertising channel map.
  1273. **
  1274. ** Returns void
  1275. **
  1276. *******************************************************************************/
  1277. tBTM_STATUS BTM_BleSetAdvParams(UINT16 adv_int_min, UINT16 adv_int_max,
  1278. tBLE_BD_ADDR *p_dir_bda,
  1279. tBTM_BLE_ADV_CHNL_MAP chnl_map)
  1280. {
  1281. tBTM_LE_RANDOM_CB *p_addr_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
  1282. tBTM_BLE_INQ_CB *p_cb = &btm_cb.ble_ctr_cb.inq_var;
  1283. tBTM_STATUS status = BTM_SUCCESS;
  1284. BD_ADDR p_addr_ptr = {0};
  1285. tBLE_ADDR_TYPE init_addr_type = BLE_ADDR_PUBLIC;
  1286. tBLE_ADDR_TYPE own_addr_type = p_addr_cb->own_addr_type;
  1287. UINT8 adv_mode = p_cb->adv_mode;
  1288. BTM_TRACE_EVENT ("BTM_BleSetAdvParams");
  1289. if (!controller_get_interface()->supports_ble()) {
  1290. return BTM_ILLEGAL_VALUE;
  1291. }
  1292. if (!BTM_BLE_ISVALID_PARAM(adv_int_min, BTM_BLE_ADV_INT_MIN, BTM_BLE_ADV_INT_MAX) ||
  1293. !BTM_BLE_ISVALID_PARAM(adv_int_max, BTM_BLE_ADV_INT_MIN, BTM_BLE_ADV_INT_MAX)) {
  1294. return BTM_ILLEGAL_VALUE;
  1295. }
  1296. p_cb->adv_interval_min = adv_int_min;
  1297. p_cb->adv_interval_max = adv_int_max;
  1298. p_cb->adv_chnl_map = chnl_map;
  1299. if (p_dir_bda) {
  1300. memcpy(&p_cb->direct_bda, p_dir_bda, sizeof(tBLE_BD_ADDR));
  1301. }
  1302. BTM_TRACE_EVENT ("update params for an active adv\n");
  1303. btm_ble_stop_adv();
  1304. p_cb->evt_type = btm_set_conn_mode_adv_init_addr(p_cb, p_addr_ptr, &init_addr_type,
  1305. &own_addr_type);
  1306. /* update adv params */
  1307. btsnd_hcic_ble_write_adv_params (p_cb->adv_interval_min,
  1308. p_cb->adv_interval_max,
  1309. p_cb->evt_type,
  1310. own_addr_type,
  1311. init_addr_type,
  1312. p_addr_ptr,
  1313. p_cb->adv_chnl_map,
  1314. p_cb->afp);
  1315. if (adv_mode == BTM_BLE_ADV_ENABLE) {
  1316. btm_ble_start_adv();
  1317. }
  1318. return status;
  1319. }
  1320. /*******************************************************************************
  1321. **
  1322. ** Function BTM_BleSetAdvParamsAll
  1323. **
  1324. ** Description This function is called to set all of the advertising parameters.
  1325. **
  1326. ** Parameters: None.
  1327. **
  1328. ** Returns void
  1329. **
  1330. *******************************************************************************/
  1331. tBTM_STATUS BTM_BleSetAdvParamsAll(UINT16 adv_int_min, UINT16 adv_int_max, UINT8 adv_type,
  1332. tBLE_ADDR_TYPE own_bda_type, tBLE_BD_ADDR *p_dir_bda,
  1333. tBTM_BLE_ADV_CHNL_MAP chnl_map, tBTM_BLE_AFP afp, tBTM_START_ADV_CMPL_CBACK *adv_cb)
  1334. {
  1335. tBTM_LE_RANDOM_CB *p_addr_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
  1336. tBTM_BLE_INQ_CB *p_cb = &btm_cb.ble_ctr_cb.inq_var;
  1337. BTM_TRACE_EVENT ("BTM_BleSetAdvParamsAll\n");
  1338. if (!controller_get_interface()->supports_ble()) {
  1339. return BTM_ILLEGAL_VALUE;
  1340. }
  1341. if (BTM_BleUpdateOwnType(&own_bda_type, adv_cb) != 0) {
  1342. return BTM_ILLEGAL_VALUE;
  1343. }
  1344. if (!BTM_BLE_ISVALID_PARAM(adv_int_min, BTM_BLE_ADV_INT_MIN, BTM_BLE_ADV_INT_MAX) ||
  1345. !BTM_BLE_ISVALID_PARAM(adv_int_max, BTM_BLE_ADV_INT_MIN, BTM_BLE_ADV_INT_MAX)) {
  1346. BTM_TRACE_ERROR ("adv_int_min or adv_int_max is invalid\n");
  1347. if(adv_cb) {
  1348. (* adv_cb)(HCI_ERR_ESP_VENDOR_FAIL);
  1349. }
  1350. return BTM_ILLEGAL_VALUE;
  1351. }
  1352. btm_ble_stop_adv();
  1353. osi_mutex_lock(&adv_param_lock, OSI_MUTEX_MAX_TIMEOUT);
  1354. if(adv_type == BTM_BLE_CONNECT_DIR_EVT){
  1355. btm_ble_set_topology_mask(BTM_BLE_STATE_HI_DUTY_DIR_ADV_BIT);
  1356. }else if(adv_type == BTM_BLE_CONNECT_LO_DUTY_DIR_EVT){
  1357. btm_ble_set_topology_mask(BTM_BLE_STATE_LO_DUTY_DIR_ADV_BIT);
  1358. }else if(adv_type == BTM_BLE_NON_CONNECT_EVT){
  1359. btm_ble_set_topology_mask(BTM_BLE_STATE_NON_CONN_ADV_BIT);
  1360. }
  1361. p_cb->adv_interval_min = adv_int_min;
  1362. p_cb->adv_interval_max = adv_int_max;
  1363. p_cb->adv_chnl_map = chnl_map;
  1364. p_addr_cb->own_addr_type = own_bda_type;
  1365. p_cb->evt_type = adv_type;
  1366. p_cb->afp = afp;
  1367. p_cb->p_adv_cb = adv_cb;
  1368. if (p_dir_bda) {
  1369. memcpy(&p_cb->direct_bda, p_dir_bda, sizeof(tBLE_BD_ADDR));
  1370. } else {
  1371. return BTM_ILLEGAL_VALUE;
  1372. }
  1373. BTM_TRACE_EVENT ("update params for an active adv\n");
  1374. tBTM_STATUS status = BTM_SUCCESS;
  1375. /* update adv params */
  1376. if (btsnd_hcic_ble_write_adv_params (adv_int_min,
  1377. adv_int_max,
  1378. adv_type,
  1379. own_bda_type,
  1380. p_dir_bda->type,
  1381. p_dir_bda->bda,
  1382. chnl_map,
  1383. p_cb->afp)) {
  1384. osi_sem_take(&adv_param_sem, OSI_SEM_MAX_TIMEOUT);
  1385. status = adv_param_status;
  1386. } else {
  1387. status = BTM_NO_RESOURCES;
  1388. }
  1389. osi_mutex_unlock(&adv_param_lock);
  1390. return status;
  1391. }
  1392. tBTM_STATUS BTM_BleStartAdv(void)
  1393. {
  1394. tBTM_STATUS status = BTM_SUCCESS;
  1395. if (!controller_get_interface()->supports_ble()) {
  1396. return BTM_ILLEGAL_VALUE;
  1397. }
  1398. btm_ble_stop_adv();
  1399. status = btm_ble_start_adv();
  1400. return status;
  1401. }
  1402. /*******************************************************************************
  1403. **
  1404. ** Function BTM_BleReadAdvParams
  1405. **
  1406. ** Description This function is called to set advertising parameters.
  1407. **
  1408. ** Parameters adv_int_min: minimum advertising interval
  1409. ** adv_int_max: maximum advertising interval
  1410. ** p_dir_bda: connectable direct initiator's LE device address
  1411. ** chnl_map: advertising channel map.
  1412. **
  1413. ** Returns void
  1414. **
  1415. *******************************************************************************/
  1416. void BTM_BleReadAdvParams (UINT16 *adv_int_min, UINT16 *adv_int_max,
  1417. tBLE_BD_ADDR *p_dir_bda, tBTM_BLE_ADV_CHNL_MAP *p_chnl_map)
  1418. {
  1419. tBTM_BLE_INQ_CB *p_cb = &btm_cb.ble_ctr_cb.inq_var;
  1420. BTM_TRACE_EVENT ("BTM_BleReadAdvParams ");
  1421. if (!controller_get_interface()->supports_ble()) {
  1422. return ;
  1423. }
  1424. *adv_int_min = p_cb->adv_interval_min;
  1425. *adv_int_max = p_cb->adv_interval_max;
  1426. *p_chnl_map = p_cb->adv_chnl_map;
  1427. if (p_dir_bda != NULL) {
  1428. memcpy(p_dir_bda, &p_cb->direct_bda, sizeof(tBLE_BD_ADDR));
  1429. }
  1430. }
  1431. /*******************************************************************************
  1432. **
  1433. ** Function BTM_BleSetScanParams
  1434. **
  1435. ** Description This function is called to set scan parameters.
  1436. **
  1437. ** Parameters client_if - Client IF
  1438. ** scan_interval - Scan interval
  1439. ** scan_window - Scan window
  1440. ** scan_mode - Scan mode
  1441. ** scan_setup_status_cback - Scan param setup status callback
  1442. **
  1443. ** Returns void
  1444. **
  1445. *******************************************************************************/
  1446. void BTM_BleSetScanParams(tGATT_IF client_if, UINT32 scan_interval, UINT32 scan_window,
  1447. tBLE_SCAN_MODE scan_mode,
  1448. tBLE_SCAN_PARAM_SETUP_CBACK scan_setup_status_cback)
  1449. {
  1450. tBTM_BLE_INQ_CB *p_cb = &btm_cb.ble_ctr_cb.inq_var;
  1451. UINT32 max_scan_interval;
  1452. UINT32 max_scan_window;
  1453. BTM_TRACE_EVENT ("%s\n", __func__);
  1454. if (!controller_get_interface()->supports_ble()) {
  1455. return;
  1456. }
  1457. /* If not supporting extended scan support, use the older range for checking */
  1458. if (btm_cb.cmn_ble_vsc_cb.extended_scan_support == 0) {
  1459. max_scan_interval = BTM_BLE_SCAN_INT_MAX;
  1460. max_scan_window = BTM_BLE_SCAN_WIN_MAX;
  1461. } else {
  1462. /* If supporting extended scan support, use the new extended range for checking */
  1463. max_scan_interval = BTM_BLE_EXT_SCAN_INT_MAX;
  1464. max_scan_window = BTM_BLE_EXT_SCAN_WIN_MAX;
  1465. }
  1466. if (BTM_BLE_ISVALID_PARAM(scan_interval, BTM_BLE_SCAN_INT_MIN, max_scan_interval) &&
  1467. BTM_BLE_ISVALID_PARAM(scan_window, BTM_BLE_SCAN_WIN_MIN, max_scan_window) &&
  1468. (scan_mode == BTM_BLE_SCAN_MODE_ACTI || scan_mode == BTM_BLE_SCAN_MODE_PASS)) {
  1469. p_cb->scan_type = scan_mode;
  1470. p_cb->scan_interval = scan_interval;
  1471. p_cb->scan_window = scan_window;
  1472. if (scan_setup_status_cback != NULL) {
  1473. scan_setup_status_cback(client_if, BTM_SUCCESS);
  1474. }
  1475. } else {
  1476. if (scan_setup_status_cback != NULL) {
  1477. scan_setup_status_cback(client_if, BTM_ILLEGAL_VALUE);
  1478. }
  1479. BTM_TRACE_ERROR("Illegal params: scan_interval = %d scan_window = %d\n",
  1480. scan_interval, scan_window);
  1481. }
  1482. }
  1483. tBTM_STATUS BTM_BleSetScanFilterParams(tGATT_IF client_if, UINT32 scan_interval, UINT32 scan_window,
  1484. tBLE_SCAN_MODE scan_mode, UINT8 addr_type_own, UINT8 scan_duplicate_filter, tBTM_BLE_SFP scan_filter_policy,
  1485. tBLE_SCAN_PARAM_SETUP_CBACK scan_setup_status_cback)
  1486. {
  1487. tBTM_BLE_INQ_CB *p_cb = &btm_cb.ble_ctr_cb.inq_var;
  1488. UINT32 max_scan_interval;
  1489. UINT32 max_scan_window;
  1490. tBTM_STATUS ret = BTM_SUCCESS;
  1491. BTM_TRACE_EVENT ("%s\n", __func__);
  1492. if (!controller_get_interface()->supports_ble()) {
  1493. return BTM_ILLEGAL_VALUE;
  1494. }
  1495. if (BTM_BleUpdateOwnType(&addr_type_own, NULL) != 0) {
  1496. return BTM_ILLEGAL_VALUE;
  1497. }
  1498. /* If not supporting extended scan support, use the older range for checking */
  1499. if (btm_cb.cmn_ble_vsc_cb.extended_scan_support == 0) {
  1500. max_scan_interval = BTM_BLE_SCAN_INT_MAX;
  1501. max_scan_window = BTM_BLE_SCAN_WIN_MAX;
  1502. } else {
  1503. /* If supporting extended scan support, use the new extended range for checking */
  1504. max_scan_interval = BTM_BLE_EXT_SCAN_INT_MAX;
  1505. max_scan_window = BTM_BLE_EXT_SCAN_WIN_MAX;
  1506. }
  1507. osi_mutex_lock(&scan_param_lock, OSI_MUTEX_MAX_TIMEOUT);
  1508. if (BTM_BLE_ISVALID_PARAM(scan_interval, BTM_BLE_SCAN_INT_MIN, max_scan_interval) &&
  1509. BTM_BLE_ISVALID_PARAM(scan_window, BTM_BLE_SCAN_WIN_MIN, max_scan_window) &&
  1510. (scan_mode == BTM_BLE_SCAN_MODE_ACTI || scan_mode == BTM_BLE_SCAN_MODE_PASS) &&
  1511. (scan_duplicate_filter < BTM_BLE_SCAN_DUPLICATE_MAX) && (scan_window <= scan_interval)) {
  1512. p_cb->scan_type = scan_mode;
  1513. p_cb->scan_interval = scan_interval;
  1514. p_cb->scan_window = scan_window;
  1515. p_cb->sfp = scan_filter_policy;
  1516. p_cb->scan_params_set = TRUE;
  1517. p_cb->scan_duplicate_filter = scan_duplicate_filter;
  1518. if (btsnd_hcic_ble_set_scan_params(p_cb->scan_type, (UINT16)scan_interval,
  1519. (UINT16)scan_window,
  1520. addr_type_own,
  1521. scan_filter_policy)) {
  1522. osi_sem_take(&scan_param_sem, OSI_SEM_MAX_TIMEOUT);
  1523. ret = scan_param_status;
  1524. }
  1525. } else {
  1526. ret = BTM_ILLEGAL_VALUE;
  1527. BTM_TRACE_ERROR("Illegal params: scan_interval = %d scan_window = %d\n",
  1528. scan_interval, scan_window);
  1529. }
  1530. osi_mutex_unlock(&scan_param_lock);
  1531. return ret;
  1532. }
  1533. /*******************************************************************************
  1534. **
  1535. ** Function BTM_BleWriteScanRsp
  1536. **
  1537. ** Description This function is called to write LE scan response.
  1538. **
  1539. ** Parameters: p_scan_rsp: scan response information.
  1540. **
  1541. ** Returns void
  1542. **
  1543. *******************************************************************************/
  1544. tBTM_STATUS BTM_BleWriteScanRsp(tBTM_BLE_AD_MASK data_mask, tBTM_BLE_ADV_DATA *p_data)
  1545. {
  1546. tBTM_STATUS ret;
  1547. UINT8 rsp_data[BTM_BLE_AD_DATA_LEN],
  1548. *p = rsp_data;
  1549. BTM_TRACE_EVENT (" BTM_BleWriteScanRsp");
  1550. if (!controller_get_interface()->supports_ble()) {
  1551. return BTM_ILLEGAL_VALUE;
  1552. }
  1553. osi_mutex_lock(&adv_data_lock, OSI_MUTEX_MAX_TIMEOUT);
  1554. memset(rsp_data, 0, BTM_BLE_AD_DATA_LEN);
  1555. btm_ble_build_adv_data(&data_mask, &p, p_data);
  1556. if (data_mask != 0) {
  1557. //data length should not exceed 31 bytes
  1558. BTM_TRACE_WARNING("%s, Partial data write into ADV", __func__);
  1559. }
  1560. if (btsnd_hcic_ble_set_scan_rsp_data((UINT8)(p - rsp_data), rsp_data)) {
  1561. osi_sem_take(&adv_data_sem, OSI_SEM_MAX_TIMEOUT);
  1562. ret = adv_data_status;
  1563. if (adv_data_status == BTM_SUCCESS && data_mask != 0) {
  1564. btm_cb.ble_ctr_cb.inq_var.scan_rsp = TRUE;
  1565. } else {
  1566. btm_cb.ble_ctr_cb.inq_var.scan_rsp = FALSE;
  1567. }
  1568. } else {
  1569. ret = BTM_ILLEGAL_VALUE;
  1570. }
  1571. osi_mutex_unlock(&adv_data_lock);
  1572. return ret;
  1573. }
  1574. /*******************************************************************************
  1575. **
  1576. ** Function BTM_BleWriteScanRspRaw
  1577. **
  1578. ** Description This function is called to write raw scan response data
  1579. **
  1580. ** Parameters: None.
  1581. **
  1582. ** Returns void
  1583. **
  1584. *******************************************************************************/
  1585. tBTM_STATUS BTM_BleWriteScanRspRaw(UINT8 *p_raw_scan_rsp, UINT32 raw_scan_rsp_len)
  1586. {
  1587. tBTM_STATUS ret;
  1588. osi_mutex_lock(&adv_data_lock, OSI_MUTEX_MAX_TIMEOUT);
  1589. if (btsnd_hcic_ble_set_scan_rsp_data((UINT8)raw_scan_rsp_len, p_raw_scan_rsp)) {
  1590. osi_sem_take(&adv_data_sem, OSI_SEM_MAX_TIMEOUT);
  1591. ret = adv_data_status;
  1592. } else {
  1593. ret = BTM_NO_RESOURCES;
  1594. }
  1595. osi_mutex_unlock(&adv_data_lock);
  1596. return ret;
  1597. }
  1598. /*******************************************************************************
  1599. **
  1600. ** Function BTM_UpdateBleDuplicateExceptionalList
  1601. **
  1602. ** Description This function is called to update duplicate scan exceptional list.
  1603. **
  1604. ** Parameters: subcode: add, remove or clean duplicate scan exceptional list.
  1605. ** type: device info type
  1606. ** device_info: device information
  1607. ** update_exceptional_list_cmp_cb: complete callback
  1608. **
  1609. ** Returns status
  1610. **
  1611. *******************************************************************************/
  1612. tBTM_STATUS BTM_UpdateBleDuplicateExceptionalList(uint8_t subcode, uint32_t type, BD_ADDR device_info,
  1613. tBTM_UPDATE_DUPLICATE_EXCEPTIONAL_LIST_CMPL_CBACK update_exceptional_list_cmp_cb)
  1614. {
  1615. tBTM_BLE_CB *ble_cb = &btm_cb.ble_ctr_cb;
  1616. tBTM_STATUS status = BTM_NO_RESOURCES;
  1617. ble_cb->update_exceptional_list_cmp_cb = update_exceptional_list_cmp_cb;
  1618. if (!controller_get_interface()->supports_ble()) {
  1619. return BTM_ILLEGAL_VALUE;
  1620. }
  1621. if(!device_info) {
  1622. return BTM_ILLEGAL_VALUE;
  1623. }
  1624. // subcoe + type + device info
  1625. uint8_t device_info_array[1 + 4 + BD_ADDR_LEN] = {0};
  1626. device_info_array[0] = subcode;
  1627. device_info_array[1] = type & 0xff;
  1628. device_info_array[2] = (type >> 8) & 0xff;
  1629. device_info_array[3] = (type >> 16) & 0xff;
  1630. device_info_array[4] = (type >> 24) & 0xff;
  1631. switch (type)
  1632. {
  1633. case BTM_DUPLICATE_SCAN_EXCEPTIONAL_INFO_ADV_ADDR:
  1634. bt_rcopy(&device_info_array[5], device_info, BD_ADDR_LEN);
  1635. break;
  1636. case BTM_DUPLICATE_SCAN_EXCEPTIONAL_INFO_MESH_LINK_ID:
  1637. memcpy(&device_info_array[5], device_info, 4);
  1638. break;
  1639. case BTM_DUPLICATE_SCAN_EXCEPTIONAL_INFO_MESH_BEACON_TYPE:
  1640. //do nothing
  1641. break;
  1642. case BTM_DUPLICATE_SCAN_EXCEPTIONAL_INFO_MESH_PROV_SRV_ADV:
  1643. //do nothing
  1644. break;
  1645. case BTM_DUPLICATE_SCAN_EXCEPTIONAL_INFO_MESH_PROXY_SRV_ADV:
  1646. //do nothing
  1647. break;
  1648. default:
  1649. //do nothing
  1650. break;
  1651. }
  1652. status = BTM_VendorSpecificCommand(HCI_VENDOR_BLE_UPDATE_DUPLICATE_EXCEPTIONAL_LIST, 1 + 4 + BD_ADDR_LEN, device_info_array, NULL);
  1653. if(status == BTM_CMD_STARTED) {
  1654. status = BTM_SUCCESS;
  1655. }
  1656. return status;
  1657. }
  1658. /*******************************************************************************
  1659. **
  1660. ** Function BTM_BleWriteAdvData
  1661. **
  1662. ** Description This function is called to write advertising data.
  1663. **
  1664. ** Parameters: None.
  1665. **
  1666. ** Returns void
  1667. **
  1668. *******************************************************************************/
  1669. tBTM_STATUS BTM_BleWriteAdvData(tBTM_BLE_AD_MASK data_mask, tBTM_BLE_ADV_DATA *p_data)
  1670. {
  1671. tBTM_BLE_LOCAL_ADV_DATA *p_cb_data = &btm_cb.ble_ctr_cb.inq_var.adv_data;
  1672. UINT8 *p;
  1673. tBTM_BLE_AD_MASK mask = data_mask;
  1674. tBTM_STATUS ret;
  1675. BTM_TRACE_EVENT ("BTM_BleWriteAdvData ");
  1676. if (!controller_get_interface()->supports_ble()) {
  1677. return BTM_ILLEGAL_VALUE;
  1678. }
  1679. osi_mutex_lock(&adv_data_lock, OSI_MUTEX_MAX_TIMEOUT);
  1680. memset(p_cb_data, 0, sizeof(tBTM_BLE_LOCAL_ADV_DATA));
  1681. p = p_cb_data->ad_data;
  1682. p_cb_data->data_mask = data_mask;
  1683. p_cb_data->p_flags = btm_ble_build_adv_data(&mask, &p, p_data);
  1684. p_cb_data->p_pad = p;
  1685. if (mask != 0) {
  1686. //data length should not exceed 31 bytes
  1687. BTM_TRACE_WARNING("%s, Partial data write into ADV", __func__);
  1688. }
  1689. p_cb_data->data_mask &= ~mask;
  1690. if (btsnd_hcic_ble_set_adv_data((UINT8)(p_cb_data->p_pad - p_cb_data->ad_data),
  1691. p_cb_data->ad_data)) {
  1692. osi_sem_take(&adv_data_sem, OSI_SEM_MAX_TIMEOUT);
  1693. ret = adv_data_status;
  1694. } else {
  1695. ret = BTM_NO_RESOURCES;
  1696. }
  1697. osi_mutex_unlock(&adv_data_lock);
  1698. return ret;
  1699. }
  1700. /*******************************************************************************
  1701. **
  1702. ** Function BTM_BleWriteLongAdvData
  1703. **
  1704. ** Description This function is called to write long advertising data.
  1705. **
  1706. ** Parameters: adv_data: long advertising data
  1707. ** adv_data_len: the length of long advertising data
  1708. **
  1709. ** Returns void
  1710. **
  1711. *******************************************************************************/
  1712. tBTM_STATUS BTM_BleWriteLongAdvData(uint8_t *adv_data, uint8_t adv_data_len)
  1713. {
  1714. tBTM_STATUS status = BTM_NO_RESOURCES;
  1715. if (!controller_get_interface()->supports_ble()) {
  1716. return BTM_ILLEGAL_VALUE;
  1717. }
  1718. if(!adv_data || adv_data_len <= 0 || adv_data_len > BTM_BLE_LONG_ADV_MAX_LEN) {
  1719. return BTM_ILLEGAL_VALUE;
  1720. }
  1721. uint8_t long_adv[BTM_BLE_LONG_ADV_MAX_LEN + 1] = {0};
  1722. long_adv[0] = adv_data_len;
  1723. memcpy(&long_adv[1], adv_data, adv_data_len);
  1724. status = BTM_VendorSpecificCommand(HCI_VENDOR_BLE_LONG_ADV_DATA, BTM_BLE_LONG_ADV_MAX_LEN + 1, long_adv, NULL);
  1725. if(status == BTM_CMD_STARTED) {
  1726. status = BTM_SUCCESS;
  1727. }
  1728. return status;
  1729. }
  1730. /*******************************************************************************
  1731. **
  1732. ** Function BTM_BleWriteAdvDataRaw
  1733. **
  1734. ** Description This function is called to write raw advertising data.
  1735. **
  1736. ** Parameters: None.
  1737. **
  1738. ** Returns void
  1739. **
  1740. *******************************************************************************/
  1741. tBTM_STATUS BTM_BleWriteAdvDataRaw(UINT8 *p_raw_adv, UINT32 raw_adv_len)
  1742. {
  1743. tBTM_STATUS ret;
  1744. osi_mutex_lock(&adv_data_lock, OSI_MUTEX_MAX_TIMEOUT);
  1745. if (btsnd_hcic_ble_set_adv_data((UINT8)raw_adv_len, p_raw_adv)) {
  1746. osi_sem_take(&adv_data_sem, OSI_SEM_MAX_TIMEOUT);
  1747. ret = adv_data_status;
  1748. } else {
  1749. ret = BTM_NO_RESOURCES;
  1750. }
  1751. osi_mutex_unlock(&adv_data_lock);
  1752. return ret;
  1753. }
  1754. /*******************************************************************************
  1755. **
  1756. ** Function BTM_BleSetRandAddress
  1757. **
  1758. ** Description This function is called to set the LE random address.
  1759. **
  1760. ** Parameters: None.
  1761. **
  1762. ** Returns void
  1763. **
  1764. *******************************************************************************/
  1765. tBTM_STATUS BTM_BleSetRandAddress(BD_ADDR rand_addr)
  1766. {
  1767. if (rand_addr == NULL) {
  1768. return BTM_SET_STATIC_RAND_ADDR_FAIL;
  1769. }
  1770. if (!(btm_cb.ble_ctr_cb.inq_var.state == BTM_BLE_STOP_SCAN || btm_cb.ble_ctr_cb.inq_var.state == BTM_BLE_STOP_ADV || btm_cb.ble_ctr_cb.inq_var.state == BTM_BLE_IDLE)) {
  1771. BTM_TRACE_ERROR("Advertising or scaning now, can't set randaddress %d", btm_cb.ble_ctr_cb.inq_var.state);
  1772. return BTM_SET_STATIC_RAND_ADDR_FAIL;
  1773. }
  1774. memcpy(btm_cb.ble_ctr_cb.addr_mgnt_cb.private_addr, rand_addr, BD_ADDR_LEN);
  1775. memcpy(btm_cb.ble_ctr_cb.addr_mgnt_cb.static_rand_addr, rand_addr, BD_ADDR_LEN);
  1776. //send the set random address to the controller
  1777. if(btsnd_hcic_ble_set_random_addr(rand_addr)) {
  1778. btm_cb.ble_ctr_cb.addr_mgnt_cb.exist_addr_bit |= BTM_BLE_GAP_ADDR_BIT_RANDOM;
  1779. return BTM_SUCCESS;
  1780. } else {
  1781. return BTM_SET_STATIC_RAND_ADDR_FAIL;
  1782. }
  1783. }
  1784. /*******************************************************************************
  1785. **
  1786. ** Function BTM_BleClearRandAddress
  1787. **
  1788. ** Description This function is called to clear the LE random address.
  1789. **
  1790. ** Parameters: None.
  1791. **
  1792. ** Returns void
  1793. **
  1794. *******************************************************************************/
  1795. void BTM_BleClearRandAddress(void)
  1796. {
  1797. tBTM_BLE_CB *p_cb = &btm_cb.ble_ctr_cb;
  1798. if (btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type == BLE_ADDR_RANDOM && (!(p_cb->inq_var.state == BTM_BLE_STOP_SCAN || p_cb->inq_var.state == BTM_BLE_STOP_ADV || p_cb->inq_var.state == BTM_BLE_IDLE))) {
  1799. BTM_TRACE_ERROR("Advertising or scaning now, can't restore public address ");
  1800. return;
  1801. }
  1802. memset(btm_cb.ble_ctr_cb.addr_mgnt_cb.static_rand_addr, 0, BD_ADDR_LEN);
  1803. btm_cb.ble_ctr_cb.addr_mgnt_cb.exist_addr_bit &= (~BTM_BLE_GAP_ADDR_BIT_RANDOM);
  1804. btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type = BLE_ADDR_PUBLIC;
  1805. }
  1806. /*******************************************************************************
  1807. **
  1808. ** Function BTM_BleGetCurrentAddress
  1809. **
  1810. ** Description This function is called to get local used BLE address.
  1811. **
  1812. ** Parameters: None.
  1813. **
  1814. ** Returns success or fail
  1815. **
  1816. *******************************************************************************/
  1817. BOOLEAN BTM_BleGetCurrentAddress(BD_ADDR addr, uint8_t *addr_type)
  1818. {
  1819. if(addr == NULL || addr_type == NULL) {
  1820. BTM_TRACE_ERROR("%s addr or addr_type is NULL\n", __func__);
  1821. return FALSE;
  1822. }
  1823. if(btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type == BLE_ADDR_RANDOM) {
  1824. *addr_type = BLE_ADDR_RANDOM;
  1825. memcpy(addr, btm_cb.ble_ctr_cb.addr_mgnt_cb.private_addr, BD_ADDR_LEN);
  1826. } else if(btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type == BLE_ADDR_PUBLIC) {
  1827. *addr_type = BLE_ADDR_PUBLIC;
  1828. memcpy(addr, &controller_get_interface()->get_address()->address, BD_ADDR_LEN);
  1829. } else {
  1830. BTM_TRACE_ERROR("%s\n", __func__);
  1831. memset(addr, 0, BD_ADDR_LEN);
  1832. return FALSE;
  1833. }
  1834. return TRUE;
  1835. }
  1836. /*******************************************************************************
  1837. **
  1838. ** Function BTM_CheckAdvData
  1839. **
  1840. ** Description This function is called to get ADV data for a specific type.
  1841. **
  1842. ** Parameters p_adv - pointer of ADV data
  1843. ** type - finding ADV data type
  1844. ** p_length - return the length of ADV data not including type
  1845. **
  1846. ** Returns pointer of ADV data
  1847. **
  1848. *******************************************************************************/
  1849. UINT8 *BTM_CheckAdvData( UINT8 *p_adv, UINT8 type, UINT8 *p_length)
  1850. {
  1851. UINT8 *p = p_adv;
  1852. UINT8 length;
  1853. UINT8 adv_type;
  1854. BTM_TRACE_API("BTM_CheckAdvData type=0x%02X", type);
  1855. STREAM_TO_UINT8(length, p);
  1856. while ( length && (p - p_adv <= BTM_BLE_CACHE_ADV_DATA_MAX)) {
  1857. STREAM_TO_UINT8(adv_type, p);
  1858. if ( adv_type == type ) {
  1859. /* length doesn't include itself */
  1860. *p_length = length - 1; /* minus the length of type */
  1861. return p;
  1862. }
  1863. p += length - 1; /* skip the length of data */
  1864. STREAM_TO_UINT8(length, p);
  1865. }
  1866. *p_length = 0;
  1867. return NULL;
  1868. }
  1869. /*******************************************************************************
  1870. **
  1871. ** Function BTM__BLEReadDiscoverability
  1872. **
  1873. ** Description This function is called to read the current LE discoverability
  1874. ** mode of the device.
  1875. **
  1876. ** Returns BTM_BLE_NON_DISCOVERABLE ,BTM_BLE_LIMITED_DISCOVERABLE or
  1877. ** BTM_BLE_GENRAL_DISCOVERABLE
  1878. **
  1879. *******************************************************************************/
  1880. UINT16 BTM_BleReadDiscoverability(void)
  1881. {
  1882. BTM_TRACE_API("%s\n", __FUNCTION__);
  1883. return (btm_cb.ble_ctr_cb.inq_var.discoverable_mode);
  1884. }
  1885. /*******************************************************************************
  1886. **
  1887. ** Function BTM__BLEReadConnectability
  1888. **
  1889. ** Description This function is called to read the current LE connectibility
  1890. ** mode of the device.
  1891. **
  1892. ** Returns BTM_BLE_NON_CONNECTABLE or BTM_BLE_CONNECTABLE
  1893. **
  1894. *******************************************************************************/
  1895. UINT16 BTM_BleReadConnectability(void)
  1896. {
  1897. BTM_TRACE_API ("%s\n", __FUNCTION__);
  1898. return (btm_cb.ble_ctr_cb.inq_var.connectable_mode);
  1899. }
  1900. void BTM_Recovery_Pre_State(void)
  1901. {
  1902. tBTM_BLE_INQ_CB *ble_inq_cb = &btm_cb.ble_ctr_cb.inq_var;
  1903. if (ble_inq_cb->state == BTM_BLE_ADVERTISING) {
  1904. btm_ble_stop_adv();
  1905. btm_ble_start_adv();
  1906. } else if (ble_inq_cb->state == BTM_BLE_SCANNING) {
  1907. btm_ble_start_scan();
  1908. }
  1909. return;
  1910. }
  1911. /*******************************************************************************
  1912. **
  1913. ** Function BTM_GetCurrentConnParams
  1914. **
  1915. ** Description This function is called to read the current connection parameters
  1916. ** of the device
  1917. **
  1918. ** Returns TRUE or FALSE
  1919. **
  1920. *******************************************************************************/
  1921. BOOLEAN BTM_GetCurrentConnParams(BD_ADDR bda, uint16_t *interval, uint16_t *latency, uint16_t *timeout)
  1922. {
  1923. if( (interval == NULL) || (latency == NULL) || (timeout == NULL) ) {
  1924. BTM_TRACE_ERROR("%s error ", __func__);
  1925. return FALSE;
  1926. }
  1927. if(btm_get_current_conn_params(bda, interval, latency, timeout)) {
  1928. return TRUE;
  1929. }
  1930. return FALSE;
  1931. }
  1932. /*******************************************************************************
  1933. **
  1934. ** Function btm_ble_build_adv_data
  1935. **
  1936. ** Description This function is called build the adv data and rsp data.
  1937. *******************************************************************************/
  1938. UINT8 *btm_ble_build_adv_data(tBTM_BLE_AD_MASK *p_data_mask, UINT8 **p_dst,
  1939. tBTM_BLE_ADV_DATA *p_data)
  1940. {
  1941. UINT32 data_mask = *p_data_mask;
  1942. UINT8 *p = *p_dst,
  1943. *p_flag = NULL;
  1944. UINT16 len = BTM_BLE_AD_DATA_LEN, cp_len = 0;
  1945. UINT8 i = 0;
  1946. tBTM_BLE_PROP_ELEM *p_elem;
  1947. BTM_TRACE_EVENT (" btm_ble_build_adv_data");
  1948. /* build the adv data structure and build the data string */
  1949. if (data_mask) {
  1950. /* flags */
  1951. if (data_mask & BTM_BLE_AD_BIT_FLAGS) {
  1952. *p++ = MIN_ADV_LENGTH;
  1953. *p++ = BTM_BLE_AD_TYPE_FLAG;
  1954. p_flag = p;
  1955. if (p_data) {
  1956. *p++ = p_data->flag;
  1957. } else {
  1958. *p++ = 0;
  1959. }
  1960. len -= 3;
  1961. data_mask &= ~BTM_BLE_AD_BIT_FLAGS;
  1962. }
  1963. /* appearance data */
  1964. if (len > 3 && data_mask & BTM_BLE_AD_BIT_APPEARANCE) {
  1965. *p++ = 3; /* length */
  1966. *p++ = BTM_BLE_AD_TYPE_APPEARANCE;
  1967. UINT16_TO_STREAM(p, p_data->appearance);
  1968. len -= 4;
  1969. data_mask &= ~BTM_BLE_AD_BIT_APPEARANCE;
  1970. }
  1971. /* device name */
  1972. #if BTM_MAX_LOC_BD_NAME_LEN > 0
  1973. if (len > MIN_ADV_LENGTH && data_mask & BTM_BLE_AD_BIT_DEV_NAME) {
  1974. if (strlen(btm_cb.cfg.bd_name) > (UINT16)(len - MIN_ADV_LENGTH)) {
  1975. *p++ = len - MIN_ADV_LENGTH + 1;
  1976. *p++ = BTM_BLE_AD_TYPE_NAME_SHORT;
  1977. ARRAY_TO_STREAM(p, btm_cb.cfg.bd_name, len - MIN_ADV_LENGTH);
  1978. } else {
  1979. cp_len = (UINT16)strlen(btm_cb.cfg.bd_name);
  1980. *p++ = cp_len + 1;
  1981. *p++ = BTM_BLE_AD_TYPE_NAME_CMPL;
  1982. ARRAY_TO_STREAM(p, btm_cb.cfg.bd_name, cp_len);
  1983. }
  1984. len -= (cp_len + MIN_ADV_LENGTH);
  1985. data_mask &= ~BTM_BLE_AD_BIT_DEV_NAME;
  1986. }
  1987. #endif
  1988. /* manufacturer data */
  1989. if (len > MIN_ADV_LENGTH && data_mask & BTM_BLE_AD_BIT_MANU &&
  1990. p_data && p_data->p_manu &&
  1991. p_data->p_manu->len != 0 && p_data->p_manu->p_val) {
  1992. if (p_data->p_manu->len > (len - MIN_ADV_LENGTH)) {
  1993. cp_len = len - MIN_ADV_LENGTH;
  1994. } else {
  1995. cp_len = p_data->p_manu->len;
  1996. }
  1997. BTM_TRACE_DEBUG("cp_len = %d\n,p_data->p_manu->len=%d\n", cp_len, p_data->p_manu->len);
  1998. for (int i = 0; i < p_data->p_manu->len; i++) {
  1999. BTM_TRACE_DEBUG("p_data->p_manu->p_val[%d] = %x\n", i, p_data->p_manu->p_val[i]);
  2000. }
  2001. *p++ = cp_len + 1;
  2002. *p++ = BTM_BLE_AD_TYPE_MANU;
  2003. ARRAY_TO_STREAM(p, p_data->p_manu->p_val, cp_len);
  2004. BTM_TRACE_DEBUG("p_addr = %p\n,p_data->p_manu->p_val = %p\n", p, p_data->p_manu->p_val);
  2005. len -= (cp_len + MIN_ADV_LENGTH);
  2006. data_mask &= ~BTM_BLE_AD_BIT_MANU;
  2007. }
  2008. /* TX power */
  2009. if (len > MIN_ADV_LENGTH && data_mask & BTM_BLE_AD_BIT_TX_PWR) {
  2010. *p++ = MIN_ADV_LENGTH;
  2011. *p++ = BTM_BLE_AD_TYPE_TX_PWR;
  2012. if (p_data->tx_power > BTM_BLE_ADV_TX_POWER_MAX) {
  2013. p_data->tx_power = BTM_BLE_ADV_TX_POWER_MAX;
  2014. }
  2015. *p++ = btm_ble_map_adv_tx_power(p_data->tx_power);
  2016. len -= 3;
  2017. data_mask &= ~BTM_BLE_AD_BIT_TX_PWR;
  2018. }
  2019. /* 16 bits services */
  2020. if (len > MIN_ADV_LENGTH && data_mask & BTM_BLE_AD_BIT_SERVICE &&
  2021. p_data && p_data->p_services &&
  2022. p_data->p_services->num_service != 0 &&
  2023. p_data->p_services->p_uuid) {
  2024. if (p_data->p_services->num_service * LEN_UUID_16 > (len - MIN_ADV_LENGTH)) {
  2025. cp_len = (len - MIN_ADV_LENGTH) / LEN_UUID_16;
  2026. *p ++ = 1 + cp_len * LEN_UUID_16;
  2027. *p++ = BTM_BLE_AD_TYPE_16SRV_PART;
  2028. } else {
  2029. cp_len = p_data->p_services->num_service;
  2030. *p++ = 1 + cp_len * LEN_UUID_16;
  2031. *p++ = BTM_BLE_AD_TYPE_16SRV_CMPL;
  2032. }
  2033. for (i = 0; i < cp_len; i ++) {
  2034. UINT16_TO_STREAM(p, *(p_data->p_services->p_uuid + i));
  2035. }
  2036. len -= (cp_len * MIN_ADV_LENGTH + MIN_ADV_LENGTH);
  2037. data_mask &= ~BTM_BLE_AD_BIT_SERVICE;
  2038. }
  2039. /* 32 bits service uuid */
  2040. if (len > MIN_ADV_LENGTH && data_mask & BTM_BLE_AD_BIT_SERVICE_32 &&
  2041. p_data && p_data->p_service_32b &&
  2042. p_data->p_service_32b->num_service != 0 &&
  2043. p_data->p_service_32b->p_uuid) {
  2044. if ((p_data->p_service_32b->num_service * LEN_UUID_32) > (len - MIN_ADV_LENGTH)) {
  2045. cp_len = (len - MIN_ADV_LENGTH) / LEN_UUID_32;
  2046. *p ++ = 1 + cp_len * LEN_UUID_32;
  2047. *p++ = BTM_BLE_AD_TYPE_32SRV_PART;
  2048. } else {
  2049. cp_len = p_data->p_service_32b->num_service;
  2050. *p++ = 1 + cp_len * LEN_UUID_32;
  2051. *p++ = BTM_BLE_AD_TYPE_32SRV_CMPL;
  2052. }
  2053. for (i = 0; i < cp_len; i ++) {
  2054. UINT32_TO_STREAM(p, *(p_data->p_service_32b->p_uuid + i));
  2055. }
  2056. len -= (cp_len * LEN_UUID_32 + MIN_ADV_LENGTH);
  2057. data_mask &= ~BTM_BLE_AD_BIT_SERVICE_32;
  2058. }
  2059. /* 128 bits services */
  2060. if (len >= (MAX_UUID_SIZE + 2) && data_mask & BTM_BLE_AD_BIT_SERVICE_128 &&
  2061. p_data && p_data->p_services_128b) {
  2062. *p ++ = 1 + MAX_UUID_SIZE;
  2063. if (!p_data->p_services_128b->list_cmpl) {
  2064. *p++ = BTM_BLE_AD_TYPE_128SRV_PART;
  2065. } else {
  2066. *p++ = BTM_BLE_AD_TYPE_128SRV_CMPL;
  2067. }
  2068. ARRAY_TO_STREAM(p, p_data->p_services_128b->uuid128, MAX_UUID_SIZE);
  2069. len -= (MAX_UUID_SIZE + MIN_ADV_LENGTH);
  2070. data_mask &= ~BTM_BLE_AD_BIT_SERVICE_128;
  2071. }
  2072. /* 32 bits Service Solicitation UUIDs */
  2073. if (len > MIN_ADV_LENGTH && data_mask & BTM_BLE_AD_BIT_SERVICE_32SOL &&
  2074. p_data && p_data->p_sol_service_32b &&
  2075. p_data->p_sol_service_32b->num_service != 0 &&
  2076. p_data->p_sol_service_32b->p_uuid) {
  2077. if ((p_data->p_sol_service_32b->num_service * LEN_UUID_32) > (len - MIN_ADV_LENGTH)) {
  2078. cp_len = (len - MIN_ADV_LENGTH) / LEN_UUID_32;
  2079. *p ++ = 1 + cp_len * LEN_UUID_32;
  2080. } else {
  2081. cp_len = p_data->p_sol_service_32b->num_service;
  2082. *p++ = 1 + cp_len * LEN_UUID_32;
  2083. }
  2084. *p++ = BTM_BLE_AD_TYPE_32SOL_SRV_UUID;
  2085. for (i = 0; i < cp_len; i ++) {
  2086. UINT32_TO_STREAM(p, *(p_data->p_sol_service_32b->p_uuid + i));
  2087. }
  2088. len -= (cp_len * LEN_UUID_32 + MIN_ADV_LENGTH);
  2089. data_mask &= ~BTM_BLE_AD_BIT_SERVICE_32SOL;
  2090. }
  2091. /* 128 bits Solicitation services UUID */
  2092. if (len >= (MAX_UUID_SIZE + MIN_ADV_LENGTH) && data_mask & BTM_BLE_AD_BIT_SERVICE_128SOL &&
  2093. p_data && p_data->p_sol_service_128b) {
  2094. *p ++ = 1 + MAX_UUID_SIZE;
  2095. *p++ = BTM_BLE_AD_TYPE_128SOL_SRV_UUID;
  2096. ARRAY_TO_STREAM(p, p_data->p_sol_service_128b->uuid128, MAX_UUID_SIZE);
  2097. len -= (MAX_UUID_SIZE + MIN_ADV_LENGTH);
  2098. data_mask &= ~BTM_BLE_AD_BIT_SERVICE_128SOL;
  2099. }
  2100. /* 16bits/32bits/128bits Service Data */
  2101. if (len > MIN_ADV_LENGTH && data_mask & BTM_BLE_AD_BIT_SERVICE_DATA &&
  2102. p_data && p_data->p_service_data->len != 0 && p_data->p_service_data->p_val) {
  2103. if (len > (p_data->p_service_data->service_uuid.len + MIN_ADV_LENGTH)) {
  2104. if (p_data->p_service_data->len > (len - MIN_ADV_LENGTH)) {
  2105. cp_len = len - MIN_ADV_LENGTH - p_data->p_service_data->service_uuid.len;
  2106. } else {
  2107. cp_len = p_data->p_service_data->len;
  2108. }
  2109. *p++ = cp_len + 1 + p_data->p_service_data->service_uuid.len;
  2110. if (p_data->p_service_data->service_uuid.len == LEN_UUID_16) {
  2111. *p++ = BTM_BLE_AD_TYPE_SERVICE_DATA;
  2112. UINT16_TO_STREAM(p, p_data->p_service_data->service_uuid.uu.uuid16);
  2113. } else if (p_data->p_service_data->service_uuid.len == LEN_UUID_32) {
  2114. *p++ = BTM_BLE_AD_TYPE_32SERVICE_DATA;
  2115. UINT32_TO_STREAM(p, p_data->p_service_data->service_uuid.uu.uuid32);
  2116. } else {
  2117. *p++ = BTM_BLE_AD_TYPE_128SERVICE_DATA;
  2118. ARRAY_TO_STREAM(p, p_data->p_service_data->service_uuid.uu.uuid128,
  2119. LEN_UUID_128);
  2120. }
  2121. ARRAY_TO_STREAM(p, p_data->p_service_data->p_val, cp_len);
  2122. len -= (cp_len + MIN_ADV_LENGTH + p_data->p_service_data->service_uuid.len);
  2123. data_mask &= ~BTM_BLE_AD_BIT_SERVICE_DATA;
  2124. } else {
  2125. BTM_TRACE_WARNING("service data does not fit");
  2126. }
  2127. }
  2128. if (len >= 6 && data_mask & BTM_BLE_AD_BIT_INT_RANGE &&
  2129. p_data) {
  2130. *p++ = 5;
  2131. *p++ = BTM_BLE_AD_TYPE_INT_RANGE;
  2132. UINT16_TO_STREAM(p, p_data->int_range.low);
  2133. UINT16_TO_STREAM(p, p_data->int_range.hi);
  2134. len -= 6;
  2135. data_mask &= ~BTM_BLE_AD_BIT_INT_RANGE;
  2136. }
  2137. if (data_mask & BTM_BLE_AD_BIT_PROPRIETARY && p_data && p_data->p_proprietary) {
  2138. for (i = 0; i < p_data->p_proprietary->num_elem ; i ++) {
  2139. p_elem = p_data->p_proprietary->p_elem + i;
  2140. if (len >= (MIN_ADV_LENGTH + p_elem->len))/* len byte(1) + ATTR type(1) + Uuid len(2)
  2141. + value length */
  2142. {
  2143. *p ++ = p_elem->len + 1; /* Uuid len + value length */
  2144. *p ++ = p_elem->adv_type;
  2145. ARRAY_TO_STREAM(p, p_elem->p_val, p_elem->len);
  2146. len -= (MIN_ADV_LENGTH + p_elem->len);
  2147. } else {
  2148. BTM_TRACE_WARNING("data exceed max adv packet length");
  2149. break;
  2150. }
  2151. }
  2152. data_mask &= ~BTM_BLE_AD_BIT_PROPRIETARY;
  2153. }
  2154. }
  2155. *p_data_mask = data_mask;
  2156. *p_dst = p;
  2157. return p_flag;
  2158. }
  2159. /*******************************************************************************
  2160. **
  2161. ** Function btm_ble_select_adv_interval
  2162. **
  2163. ** Description select adv interval based on device mode
  2164. **
  2165. ** Returns void
  2166. **
  2167. *******************************************************************************/
  2168. void btm_ble_select_adv_interval(tBTM_BLE_INQ_CB *p_cb, UINT8 evt_type, UINT16 *p_adv_int_min, UINT16 *p_adv_int_max)
  2169. {
  2170. if (p_cb->adv_interval_min && p_cb->adv_interval_max) {
  2171. *p_adv_int_min = p_cb->adv_interval_min;
  2172. *p_adv_int_max = p_cb->adv_interval_max;
  2173. } else {
  2174. switch (evt_type) {
  2175. case BTM_BLE_CONNECT_EVT:
  2176. case BTM_BLE_CONNECT_LO_DUTY_DIR_EVT:
  2177. *p_adv_int_min = *p_adv_int_max = BTM_BLE_GAP_ADV_FAST_INT_1;
  2178. break;
  2179. case BTM_BLE_NON_CONNECT_EVT:
  2180. case BTM_BLE_DISCOVER_EVT:
  2181. *p_adv_int_min = *p_adv_int_max = BTM_BLE_GAP_ADV_FAST_INT_2;
  2182. break;
  2183. /* connectable directed event */
  2184. case BTM_BLE_CONNECT_DIR_EVT:
  2185. *p_adv_int_min = BTM_BLE_GAP_ADV_DIR_MIN_INT;
  2186. *p_adv_int_max = BTM_BLE_GAP_ADV_DIR_MAX_INT;
  2187. break;
  2188. default:
  2189. *p_adv_int_min = *p_adv_int_max = BTM_BLE_GAP_ADV_SLOW_INT;
  2190. break;
  2191. }
  2192. }
  2193. return;
  2194. }
  2195. /*******************************************************************************
  2196. **
  2197. ** Function btm_ble_update_dmt_flag_bits
  2198. **
  2199. ** Description Obtain updated adv flag value based on connect and discoverability mode.
  2200. ** Also, setup DMT support value in the flag based on whether the controller
  2201. ** supports both LE and BR/EDR.
  2202. **
  2203. ** Parameters: flag_value (Input / Output) - flag value
  2204. ** connect_mode (Input) - Connect mode value
  2205. ** disc_mode (Input) - discoverability mode
  2206. **
  2207. ** Returns void
  2208. **
  2209. *******************************************************************************/
  2210. void btm_ble_update_dmt_flag_bits(UINT8 *adv_flag_value, const UINT16 connect_mode,
  2211. const UINT16 disc_mode)
  2212. {
  2213. /* BR/EDR non-discoverable , non-connectable */
  2214. if ((disc_mode & BTM_DISCOVERABLE_MASK) == 0 &&
  2215. (connect_mode & BTM_CONNECTABLE_MASK) == 0) {
  2216. *adv_flag_value |= BTM_BLE_BREDR_NOT_SPT;
  2217. } else {
  2218. *adv_flag_value &= ~BTM_BLE_BREDR_NOT_SPT;
  2219. }
  2220. /* if local controller support, mark both controller and host support in flag */
  2221. if (controller_get_interface()->supports_simultaneous_le_bredr()) {
  2222. *adv_flag_value |= (BTM_BLE_DMT_CONTROLLER_SPT | BTM_BLE_DMT_HOST_SPT);
  2223. } else {
  2224. *adv_flag_value &= ~(BTM_BLE_DMT_CONTROLLER_SPT | BTM_BLE_DMT_HOST_SPT);
  2225. }
  2226. }
  2227. /*******************************************************************************
  2228. **
  2229. ** Function btm_ble_set_adv_flag
  2230. **
  2231. ** Description Set adv flag in adv data.
  2232. **
  2233. ** Parameters: connect_mode (Input)- Connect mode value
  2234. ** disc_mode (Input) - discoverability mode
  2235. **
  2236. ** Returns void
  2237. **
  2238. *******************************************************************************/
  2239. void btm_ble_set_adv_flag(UINT16 connect_mode, UINT16 disc_mode)
  2240. {
  2241. UINT8 flag = 0, old_flag = 0;
  2242. tBTM_BLE_LOCAL_ADV_DATA *p_adv_data = &btm_cb.ble_ctr_cb.inq_var.adv_data;
  2243. if (p_adv_data->p_flags != NULL) {
  2244. flag = old_flag = *(p_adv_data->p_flags);
  2245. }
  2246. btm_ble_update_dmt_flag_bits (&flag, connect_mode, disc_mode);
  2247. BTM_TRACE_DEBUG("disc_mode %04x", disc_mode);
  2248. /* update discoverable flag */
  2249. if (disc_mode & BTM_BLE_LIMITED_DISCOVERABLE) {
  2250. flag &= ~BTM_BLE_GEN_DISC_FLAG;
  2251. flag |= BTM_BLE_LIMIT_DISC_FLAG;
  2252. } else if (disc_mode & BTM_BLE_GENERAL_DISCOVERABLE) {
  2253. flag |= BTM_BLE_GEN_DISC_FLAG;
  2254. flag &= ~BTM_BLE_LIMIT_DISC_FLAG;
  2255. } else { /* remove all discoverable flags */
  2256. flag &= ~(BTM_BLE_LIMIT_DISC_FLAG | BTM_BLE_GEN_DISC_FLAG);
  2257. }
  2258. if (flag != old_flag) {
  2259. BTM_TRACE_ERROR("flag = 0x%x,old_flag = 0x%x", flag, old_flag);
  2260. btm_ble_update_adv_flag(flag);
  2261. }
  2262. }
  2263. /*******************************************************************************
  2264. **
  2265. ** Function btm_ble_set_discoverability
  2266. **
  2267. ** Description This function is called to set BLE discoverable mode.
  2268. **
  2269. ** Parameters: combined_mode: discoverability mode.
  2270. **
  2271. ** Returns BTM_SUCCESS is status set successfully; otherwise failure.
  2272. **
  2273. *******************************************************************************/
  2274. tBTM_STATUS btm_ble_set_discoverability(UINT16 combined_mode)
  2275. {
  2276. tBTM_LE_RANDOM_CB *p_addr_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
  2277. tBTM_BLE_INQ_CB *p_cb = &btm_cb.ble_ctr_cb.inq_var;
  2278. UINT16 mode = (combined_mode & BTM_BLE_DISCOVERABLE_MASK);
  2279. UINT8 new_mode = BTM_BLE_ADV_ENABLE;
  2280. UINT8 evt_type;
  2281. tBTM_STATUS status = BTM_SUCCESS;
  2282. BD_ADDR p_addr_ptr = {0};
  2283. tBLE_ADDR_TYPE init_addr_type = BLE_ADDR_PUBLIC,
  2284. own_addr_type = p_addr_cb->own_addr_type;
  2285. UINT16 adv_int_min, adv_int_max;
  2286. BTM_TRACE_EVENT ("%s mode=0x%0x combined_mode=0x%x\n", __FUNCTION__, mode, combined_mode);
  2287. /*** Check mode parameter ***/
  2288. if (mode > BTM_BLE_MAX_DISCOVERABLE) {
  2289. return (BTM_ILLEGAL_VALUE);
  2290. }
  2291. p_cb->discoverable_mode = mode;
  2292. evt_type = btm_set_conn_mode_adv_init_addr(p_cb, p_addr_ptr, &init_addr_type, &own_addr_type);
  2293. if (p_cb->connectable_mode == BTM_BLE_NON_CONNECTABLE && mode == BTM_BLE_NON_DISCOVERABLE) {
  2294. new_mode = BTM_BLE_ADV_DISABLE;
  2295. }
  2296. btm_ble_select_adv_interval(p_cb, evt_type, &adv_int_min, &adv_int_max);
  2297. btu_stop_timer(&p_cb->fast_adv_timer);
  2298. /* update adv params if start advertising */
  2299. BTM_TRACE_EVENT ("evt_type=0x%x p-cb->evt_type=0x%x\n ", evt_type, p_cb->evt_type);
  2300. if (new_mode == BTM_BLE_ADV_ENABLE) {
  2301. btm_ble_set_adv_flag (btm_cb.btm_inq_vars.connectable_mode, combined_mode);
  2302. if (evt_type != p_cb->evt_type || p_cb->adv_addr_type != own_addr_type
  2303. || !p_cb->fast_adv_on) {
  2304. btm_ble_stop_adv();
  2305. /* update adv params */
  2306. if (!btsnd_hcic_ble_write_adv_params (adv_int_min,
  2307. adv_int_max,
  2308. evt_type,
  2309. own_addr_type,
  2310. init_addr_type,
  2311. p_addr_ptr,
  2312. p_cb->adv_chnl_map,
  2313. p_cb->afp)) {
  2314. status = BTM_NO_RESOURCES;
  2315. } else {
  2316. p_cb->evt_type = evt_type;
  2317. p_cb->adv_addr_type = own_addr_type;
  2318. }
  2319. }
  2320. }
  2321. if (status == BTM_SUCCESS && p_cb->adv_mode != new_mode) {
  2322. if (new_mode == BTM_BLE_ADV_ENABLE) {
  2323. status = btm_ble_start_adv();
  2324. } else {
  2325. status = btm_ble_stop_adv();
  2326. }
  2327. }
  2328. if (p_cb->adv_mode == BTM_BLE_ADV_ENABLE) {
  2329. p_cb->fast_adv_on = TRUE;
  2330. /* start initial GAP mode adv timer */
  2331. btu_start_timer (&p_cb->fast_adv_timer, BTU_TTYPE_BLE_GAP_FAST_ADV,
  2332. BTM_BLE_GAP_FAST_ADV_TOUT);
  2333. } else {
  2334. #if BLE_PRIVACY_SPT == TRUE
  2335. btm_ble_disable_resolving_list(BTM_BLE_RL_ADV, TRUE);
  2336. #endif
  2337. }
  2338. /* set up stop advertising timer */
  2339. if (status == BTM_SUCCESS && mode == BTM_BLE_LIMITED_DISCOVERABLE) {
  2340. BTM_TRACE_EVENT ("start timer for limited disc mode duration=%d (180 secs)", BTM_BLE_GAP_LIM_TOUT);
  2341. /* start Tgap(lim_timeout) */
  2342. btu_start_timer (&p_cb->inq_timer_ent, BTU_TTYPE_BLE_GAP_LIM_DISC,
  2343. BTM_BLE_GAP_LIM_TOUT);
  2344. }
  2345. return status;
  2346. }
  2347. /*******************************************************************************
  2348. **
  2349. ** Function btm_ble_set_connectability
  2350. **
  2351. ** Description This function is called to set BLE connectability mode.
  2352. **
  2353. ** Parameters: combined_mode: connectability mode.
  2354. **
  2355. ** Returns BTM_SUCCESS is status set successfully; otherwise failure.
  2356. **
  2357. *******************************************************************************/
  2358. tBTM_STATUS btm_ble_set_connectability(UINT16 combined_mode)
  2359. {
  2360. tBTM_LE_RANDOM_CB *p_addr_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
  2361. tBTM_BLE_INQ_CB *p_cb = &btm_cb.ble_ctr_cb.inq_var;
  2362. UINT16 mode = (combined_mode & BTM_BLE_CONNECTABLE_MASK);
  2363. UINT8 new_mode = BTM_BLE_ADV_ENABLE;
  2364. UINT8 evt_type;
  2365. tBTM_STATUS status = BTM_SUCCESS;
  2366. BD_ADDR p_addr_ptr = {0};
  2367. tBLE_ADDR_TYPE peer_addr_type = BLE_ADDR_PUBLIC,
  2368. own_addr_type = p_addr_cb->own_addr_type;
  2369. UINT16 adv_int_min, adv_int_max;
  2370. BTM_TRACE_EVENT ("%s mode=0x%0x combined_mode=0x%x\n", __FUNCTION__, mode, combined_mode);
  2371. /*** Check mode parameter ***/
  2372. if (mode > BTM_BLE_MAX_CONNECTABLE) {
  2373. return (BTM_ILLEGAL_VALUE);
  2374. }
  2375. p_cb->connectable_mode = mode;
  2376. evt_type = btm_set_conn_mode_adv_init_addr(p_cb, p_addr_ptr, &peer_addr_type, &own_addr_type);
  2377. if (mode == BTM_BLE_NON_CONNECTABLE && p_cb->discoverable_mode == BTM_BLE_NON_DISCOVERABLE) {
  2378. new_mode = BTM_BLE_ADV_DISABLE;
  2379. }
  2380. btm_ble_select_adv_interval(p_cb, evt_type, &adv_int_min, &adv_int_max);
  2381. btu_stop_timer(&p_cb->fast_adv_timer);
  2382. /* update adv params if needed */
  2383. if (new_mode == BTM_BLE_ADV_ENABLE) {
  2384. btm_ble_set_adv_flag (combined_mode, btm_cb.btm_inq_vars.discoverable_mode);
  2385. if (p_cb->evt_type != evt_type || p_cb->adv_addr_type != p_addr_cb->own_addr_type
  2386. || !p_cb->fast_adv_on) {
  2387. btm_ble_stop_adv();
  2388. if (!btsnd_hcic_ble_write_adv_params (adv_int_min,
  2389. adv_int_max,
  2390. evt_type,
  2391. own_addr_type,
  2392. peer_addr_type,
  2393. p_addr_ptr,
  2394. p_cb->adv_chnl_map,
  2395. p_cb->afp)) {
  2396. status = BTM_NO_RESOURCES;
  2397. } else {
  2398. p_cb->evt_type = evt_type;
  2399. p_cb->adv_addr_type = own_addr_type;
  2400. }
  2401. }
  2402. }
  2403. /* update advertising mode */
  2404. if (status == BTM_SUCCESS && new_mode != p_cb->adv_mode) {
  2405. if (new_mode == BTM_BLE_ADV_ENABLE) {
  2406. status = btm_ble_start_adv();
  2407. } else {
  2408. status = btm_ble_stop_adv();
  2409. }
  2410. }
  2411. if (p_cb->adv_mode == BTM_BLE_ADV_ENABLE) {
  2412. p_cb->fast_adv_on = TRUE;
  2413. /* start initial GAP mode adv timer */
  2414. btu_start_timer (&p_cb->fast_adv_timer, BTU_TTYPE_BLE_GAP_FAST_ADV,
  2415. BTM_BLE_GAP_FAST_ADV_TOUT);
  2416. } else {
  2417. #if BLE_PRIVACY_SPT == TRUE
  2418. btm_ble_disable_resolving_list(BTM_BLE_RL_ADV, TRUE);
  2419. #endif
  2420. }
  2421. return status;
  2422. }
  2423. /*******************************************************************************
  2424. **
  2425. ** Function btm_ble_start_inquiry
  2426. **
  2427. ** Description This function is called to start BLE inquiry procedure.
  2428. ** If the duration is zero, the periodic inquiry mode is cancelled.
  2429. **
  2430. ** Parameters: mode - GENERAL or LIMITED inquiry
  2431. ** p_inq_params - pointer to the BLE inquiry parameter.
  2432. ** p_results_cb - callback returning pointer to results (tBTM_INQ_RESULTS)
  2433. ** p_cmpl_cb - callback indicating the end of an inquiry
  2434. **
  2435. **
  2436. **
  2437. ** Returns BTM_CMD_STARTED if successfully started
  2438. ** BTM_NO_RESOURCES if could not allocate a message buffer
  2439. ** BTM_BUSY - if an inquiry is already active
  2440. **
  2441. *******************************************************************************/
  2442. tBTM_STATUS btm_ble_start_inquiry (UINT8 mode, UINT8 duration)
  2443. {
  2444. tBTM_STATUS status = BTM_CMD_STARTED;
  2445. tBTM_BLE_CB *p_ble_cb = &btm_cb.ble_ctr_cb;
  2446. tBTM_INQUIRY_VAR_ST *p_inq = &btm_cb.btm_inq_vars;
  2447. BTM_TRACE_DEBUG("btm_ble_start_inquiry: mode = %02x inq_active = 0x%02x", mode, btm_cb.btm_inq_vars.inq_active);
  2448. /* if selective connection is active, or inquiry is already active, reject it */
  2449. if (BTM_BLE_IS_INQ_ACTIVE(p_ble_cb->scan_activity) ||
  2450. BTM_BLE_IS_SEL_CONN_ACTIVE (p_ble_cb->scan_activity)) {
  2451. BTM_TRACE_ERROR("LE Inquiry is active, can not start inquiry");
  2452. return (BTM_BUSY);
  2453. }
  2454. if (!BTM_BLE_IS_SCAN_ACTIVE(p_ble_cb->scan_activity)) {
  2455. btsnd_hcic_ble_set_scan_params(BTM_BLE_SCAN_MODE_ACTI,
  2456. BTM_BLE_LOW_LATENCY_SCAN_INT,
  2457. BTM_BLE_LOW_LATENCY_SCAN_WIN,
  2458. btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type,
  2459. SP_ADV_ALL);
  2460. #if (defined BLE_PRIVACY_SPT && BLE_PRIVACY_SPT == TRUE)
  2461. /* enable IRK list */
  2462. //btm_ble_enable_resolving_list_for_platform(BTM_BLE_RL_SCAN);
  2463. #endif
  2464. status = btm_ble_start_scan();
  2465. } else if ((p_ble_cb->inq_var.scan_interval != BTM_BLE_LOW_LATENCY_SCAN_INT) ||
  2466. (p_ble_cb->inq_var.scan_window != BTM_BLE_LOW_LATENCY_SCAN_WIN)) {
  2467. BTM_TRACE_DEBUG("%s, restart LE scan with low latency scan params", __FUNCTION__);
  2468. btsnd_hcic_ble_set_scan_enable(BTM_BLE_SCAN_DISABLE, BTM_BLE_DUPLICATE_ENABLE);
  2469. btsnd_hcic_ble_set_scan_params(BTM_BLE_SCAN_MODE_ACTI,
  2470. BTM_BLE_LOW_LATENCY_SCAN_INT,
  2471. BTM_BLE_LOW_LATENCY_SCAN_WIN,
  2472. btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type,
  2473. SP_ADV_ALL);
  2474. btsnd_hcic_ble_set_scan_enable(BTM_BLE_SCAN_ENABLE, BTM_BLE_DUPLICATE_DISABLE);
  2475. }
  2476. if (status == BTM_CMD_STARTED) {
  2477. p_inq->inq_active |= mode;
  2478. p_ble_cb->scan_activity |= mode;
  2479. BTM_TRACE_DEBUG("btm_ble_start_inquiry inq_active = 0x%02x", p_inq->inq_active);
  2480. if (duration != 0) {
  2481. /* start inquiry timer */
  2482. btu_start_timer (&p_ble_cb->inq_var.inq_timer_ent, BTU_TTYPE_BLE_INQUIRY, duration);
  2483. }
  2484. }
  2485. return status;
  2486. }
  2487. /*******************************************************************************
  2488. **
  2489. ** Function btm_ble_read_remote_name_cmpl
  2490. **
  2491. ** Description This function is called when BLE remote name is received.
  2492. **
  2493. ** Returns void
  2494. **
  2495. *******************************************************************************/
  2496. void btm_ble_read_remote_name_cmpl(BOOLEAN status, BD_ADDR bda, UINT16 length, char *p_name)
  2497. {
  2498. UINT8 hci_status = HCI_SUCCESS;
  2499. BD_NAME bd_name;
  2500. memset(bd_name, 0, (BD_NAME_LEN + 1));
  2501. if (length > BD_NAME_LEN) {
  2502. length = BD_NAME_LEN;
  2503. }
  2504. memcpy((UINT8 *)bd_name, p_name, length);
  2505. if ((!status) || (length == 0)) {
  2506. hci_status = HCI_ERR_HOST_TIMEOUT;
  2507. }
  2508. btm_process_remote_name(bda, bd_name, length + 1, hci_status);
  2509. #if (SMP_INCLUDED == TRUE)
  2510. btm_sec_rmt_name_request_complete (bda, (UINT8 *)p_name, hci_status);
  2511. #endif ///SMP_INCLUDED == TRUE
  2512. }
  2513. /*******************************************************************************
  2514. **
  2515. ** Function btm_ble_read_remote_name
  2516. **
  2517. ** Description This function read remote LE device name using GATT read
  2518. ** procedure.
  2519. **
  2520. ** Parameters: None.
  2521. **
  2522. ** Returns void
  2523. **
  2524. *******************************************************************************/
  2525. tBTM_STATUS btm_ble_read_remote_name(BD_ADDR remote_bda, tBTM_INQ_INFO *p_cur, tBTM_CMPL_CB *p_cb)
  2526. {
  2527. tBTM_INQUIRY_VAR_ST *p_inq = &btm_cb.btm_inq_vars;
  2528. if (!controller_get_interface()->supports_ble()) {
  2529. return BTM_ERR_PROCESSING;
  2530. }
  2531. if (p_cur &&
  2532. p_cur->results.ble_evt_type != BTM_BLE_EVT_CONN_ADV &&
  2533. p_cur->results.ble_evt_type != BTM_BLE_EVT_CONN_DIR_ADV) {
  2534. BTM_TRACE_DEBUG("name request to non-connectable device failed.");
  2535. return BTM_ERR_PROCESSING;
  2536. }
  2537. /* read remote device name using GATT procedure */
  2538. if (p_inq->remname_active) {
  2539. return BTM_BUSY;
  2540. }
  2541. #if (defined(GAP_INCLUDED) && GAP_INCLUDED == TRUE && GATTS_INCLUDED == TRUE)
  2542. if (!GAP_BleReadPeerDevName(remote_bda, btm_ble_read_remote_name_cmpl)) {
  2543. return BTM_BUSY;
  2544. }
  2545. #endif
  2546. p_inq->p_remname_cmpl_cb = p_cb;
  2547. p_inq->remname_active = TRUE;
  2548. memcpy(p_inq->remname_bda, remote_bda, BD_ADDR_LEN);
  2549. btu_start_timer (&p_inq->rmt_name_timer_ent,
  2550. BTU_TTYPE_BTM_RMT_NAME,
  2551. BTM_EXT_BLE_RMT_NAME_TIMEOUT);
  2552. return BTM_CMD_STARTED;
  2553. }
  2554. /*******************************************************************************
  2555. **
  2556. ** Function btm_ble_cancel_remote_name
  2557. **
  2558. ** Description This function cancel read remote LE device name.
  2559. **
  2560. ** Parameters: None.
  2561. **
  2562. ** Returns void
  2563. **
  2564. *******************************************************************************/
  2565. BOOLEAN btm_ble_cancel_remote_name(BD_ADDR remote_bda)
  2566. {
  2567. tBTM_INQUIRY_VAR_ST *p_inq = &btm_cb.btm_inq_vars;
  2568. BOOLEAN status = TRUE;
  2569. #if (defined(GAP_INCLUDED) && GAP_INCLUDED == TRUE && GATTS_INCLUDED == TRUE)
  2570. status = GAP_BleCancelReadPeerDevName(remote_bda);
  2571. #endif
  2572. p_inq->remname_active = FALSE;
  2573. memset(p_inq->remname_bda, 0, BD_ADDR_LEN);
  2574. btu_stop_timer(&p_inq->rmt_name_timer_ent);
  2575. return status;
  2576. }
  2577. /*******************************************************************************
  2578. **
  2579. ** Function btm_ble_update_adv_flag
  2580. **
  2581. ** Description This function update the limited discoverable flag in the adv
  2582. ** data.
  2583. **
  2584. ** Parameters: None.
  2585. **
  2586. ** Returns void
  2587. **
  2588. *******************************************************************************/
  2589. static void btm_ble_update_adv_flag(UINT8 flag)
  2590. {
  2591. tBTM_BLE_LOCAL_ADV_DATA *p_adv_data = &btm_cb.ble_ctr_cb.inq_var.adv_data;
  2592. UINT8 *p;
  2593. BTM_TRACE_DEBUG ("btm_ble_update_adv_flag new=0x%x", flag);
  2594. if (p_adv_data->p_flags != NULL) {
  2595. BTM_TRACE_DEBUG ("btm_ble_update_adv_flag old=0x%x", *p_adv_data->p_flags);
  2596. *p_adv_data->p_flags = flag;
  2597. } else { /* no FLAGS in ADV data*/
  2598. p = (p_adv_data->p_pad == NULL) ? p_adv_data->ad_data : p_adv_data->p_pad;
  2599. /* need 3 bytes space to stuff in the flags, if not */
  2600. /* erase all written data, just for flags */
  2601. if ((BTM_BLE_AD_DATA_LEN - (p - p_adv_data->ad_data)) < 3) {
  2602. p = p_adv_data->p_pad = p_adv_data->ad_data;
  2603. memset(p_adv_data->ad_data, 0, BTM_BLE_AD_DATA_LEN);
  2604. }
  2605. *p++ = 2;
  2606. *p++ = BTM_BLE_AD_TYPE_FLAG;
  2607. p_adv_data->p_flags = p;
  2608. *p++ = flag;
  2609. p_adv_data->p_pad = p;
  2610. }
  2611. if (btsnd_hcic_ble_set_adv_data((UINT8)(p_adv_data->p_pad - p_adv_data->ad_data),
  2612. p_adv_data->ad_data)) {
  2613. p_adv_data->data_mask |= BTM_BLE_AD_BIT_FLAGS;
  2614. }
  2615. }
  2616. #if 0
  2617. /*******************************************************************************
  2618. **
  2619. ** Function btm_ble_parse_adv_data
  2620. **
  2621. ** Description This function parse the adv data into a structure.
  2622. **
  2623. ** Returns pointer to entry, or NULL if not found
  2624. **
  2625. *******************************************************************************/
  2626. static void btm_ble_parse_adv_data(tBTM_INQ_INFO *p_info, UINT8 *p_data,
  2627. UINT8 len, tBTM_BLE_INQ_DATA *p_adv_data, UINT8 *p_buf)
  2628. {
  2629. UINT8 *p_cur = p_data;
  2630. UINT8 ad_len, ad_type, ad_flag;
  2631. BTM_TRACE_EVENT (" btm_ble_parse_adv_data");
  2632. while (len > 0) {
  2633. BTM_TRACE_DEBUG("btm_ble_parse_adv_data: len = %d", len);
  2634. if ((ad_len = *p_cur ++) == 0) {
  2635. break;
  2636. }
  2637. ad_type = *p_cur ++;
  2638. BTM_TRACE_DEBUG(" ad_type = %02x ad_len = %d", ad_type, ad_len);
  2639. switch (ad_type) {
  2640. case BTM_BLE_AD_TYPE_NAME_SHORT:
  2641. case BTM_BLE_AD_TYPE_NAME_CMPL:
  2642. p_adv_data->ad_mask |= BTM_BLE_AD_BIT_DEV_NAME;
  2643. if (p_info) {
  2644. p_info->remote_name_type = (ad_type == BTM_BLE_AD_TYPE_NAME_SHORT) ?
  2645. BTM_BLE_NAME_SHORT : BTM_BLE_NAME_CMPL;
  2646. memcpy(p_info->remote_name, p_cur, ad_len - 1);
  2647. p_info->remote_name[ad_len] = 0;
  2648. p_adv_data->p_remote_name = p_info->remote_name;
  2649. p_info->remote_name_len = p_adv_data->remote_name_len = ad_len - 1;
  2650. BTM_TRACE_DEBUG("BTM_BLE_AD_TYPE_NAME name = %s", p_adv_data->p_remote_name);
  2651. }
  2652. p_cur += (ad_len - 1);
  2653. break;
  2654. case BTM_BLE_AD_TYPE_FLAG:
  2655. p_adv_data->ad_mask |= BTM_BLE_AD_BIT_FLAGS;
  2656. ad_flag = *p_cur ++;
  2657. p_adv_data->flag = (UINT8)(ad_flag & BTM_BLE_ADV_FLAG_MASK) ;
  2658. BTM_TRACE_DEBUG("BTM_BLE_AD_TYPE_FLAG flag = %s | %s | %s",
  2659. (p_adv_data->flag & BTM_BLE_LIMIT_DISC_FLAG) ? "LE_LIMIT_DISC" : "",
  2660. (p_adv_data->flag & BTM_BLE_GEN_DISC_FLAG) ? "LE_GENERAL_DISC" : "",
  2661. (p_adv_data->flag & BTM_BLE_BREDR_NOT_SPT) ? "LE Only device" : "");
  2662. break;
  2663. case BTM_BLE_AD_TYPE_TX_PWR:
  2664. p_adv_data->ad_mask |= BTM_BLE_AD_BIT_TX_PWR;
  2665. p_adv_data->tx_power_level = (INT8) * p_cur ++;
  2666. BTM_TRACE_DEBUG("BTM_BLE_AD_TYPE_TX_PWR tx_level = %d", p_adv_data->tx_power_level);
  2667. break;
  2668. case BTM_BLE_AD_TYPE_MANU:
  2669. case BTM_BLE_AD_TYPE_16SRV_PART:
  2670. case BTM_BLE_AD_TYPE_16SRV_CMPL:
  2671. p_adv_data->ad_mask |= BTM_BLE_AD_BIT_SERVICE;
  2672. /* need allocate memory to store UUID list */
  2673. p_adv_data->service.num_service = (ad_len - 1) / 2;
  2674. BTM_TRACE_DEBUG("service UUID list, num = %d", p_adv_data->service.num_service);
  2675. p_cur += (ad_len - 1);
  2676. break;
  2677. case BTM_BLE_AD_TYPE_SOL_SRV_UUID:
  2678. p_adv_data->ad_mask |= BTM_BLE_AD_BIT_SERVICE_SOL;
  2679. /* need allocate memory to store UUID list */
  2680. p_adv_data->service.num_service = (ad_len - 1) / 2;
  2681. BTM_TRACE_DEBUG("service UUID list, num = %d", p_adv_data->service.num_service);
  2682. p_cur += (ad_len - 1);
  2683. break;
  2684. case BTM_BLE_AD_TYPE_128SOL_SRV_UUID:
  2685. p_adv_data->ad_mask |= BTM_BLE_AD_BIT_SERVICE_128SOL;
  2686. /* need allocate memory to store UUID list */
  2687. p_adv_data->service.num_service = (ad_len - 1) / 16;
  2688. BTM_TRACE_DEBUG("service UUID list, num = %d", p_adv_data->service.num_service);
  2689. p_cur += (ad_len - 1);
  2690. break;
  2691. case BTM_BLE_AD_TYPE_APPEARANCE:
  2692. case BTM_BLE_AD_TYPE_PUBLIC_TARGET:
  2693. case BTM_BLE_AD_TYPE_RANDOM_TARGET:
  2694. default:
  2695. break;
  2696. }
  2697. len -= (ad_len + 1);
  2698. }
  2699. }
  2700. #endif
  2701. /*******************************************************************************
  2702. **
  2703. ** Function btm_ble_cache_adv_data
  2704. **
  2705. ** Description Update advertising cache data.
  2706. **
  2707. ** Returns void
  2708. **
  2709. *******************************************************************************/
  2710. void btm_ble_cache_adv_data(BD_ADDR bda, tBTM_INQ_RESULTS *p_cur, UINT8 data_len, UINT8 *p, UINT8 evt_type)
  2711. {
  2712. tBTM_BLE_INQ_CB *p_le_inq_cb = &btm_cb.ble_ctr_cb.inq_var;
  2713. UINT8 *p_cache;
  2714. //UINT8 length;
  2715. /* cache adv report/scan response data */
  2716. if (evt_type != BTM_BLE_SCAN_RSP_EVT) {
  2717. p_le_inq_cb->adv_len = 0;
  2718. memset(p_le_inq_cb->adv_data_cache, 0, BTM_BLE_CACHE_ADV_DATA_MAX);
  2719. p_cur->adv_data_len = 0;
  2720. p_cur->scan_rsp_len = 0;
  2721. }
  2722. //Clear the adv cache if the addresses are not equal
  2723. if(memcmp(bda, p_le_inq_cb->adv_addr, BD_ADDR_LEN) != 0) {
  2724. p_le_inq_cb->adv_len = 0;
  2725. memcpy(p_le_inq_cb->adv_addr, bda, BD_ADDR_LEN);
  2726. memset(p_le_inq_cb->adv_data_cache, 0, BTM_BLE_CACHE_ADV_DATA_MAX);
  2727. p_cur->adv_data_len = 0;
  2728. p_cur->scan_rsp_len = 0;
  2729. }
  2730. if (data_len > 0) {
  2731. p_cache = &p_le_inq_cb->adv_data_cache[p_le_inq_cb->adv_len];
  2732. if((data_len + p_le_inq_cb->adv_len) <= BTM_BLE_CACHE_ADV_DATA_MAX) {
  2733. memcpy(p_cache, p, data_len);
  2734. p_le_inq_cb->adv_len += data_len;
  2735. }
  2736. }
  2737. if (evt_type != BTM_BLE_SCAN_RSP_EVT) {
  2738. p_cur->adv_data_len = p_le_inq_cb->adv_len;
  2739. }
  2740. else {
  2741. p_cur->scan_rsp_len = p_le_inq_cb->adv_len - p_cur->adv_data_len;
  2742. }
  2743. /* parse service UUID from adv packet and save it in inq db eir_uuid */
  2744. /* TODO */
  2745. }
  2746. /*******************************************************************************
  2747. **
  2748. ** Function btm_ble_is_discoverable
  2749. **
  2750. ** Description check ADV flag to make sure device is discoverable and match
  2751. ** the search condition
  2752. **
  2753. ** Parameters
  2754. **
  2755. ** Returns void
  2756. **
  2757. *******************************************************************************/
  2758. UINT8 btm_ble_is_discoverable(BD_ADDR bda, UINT8 evt_type, UINT8 *p)
  2759. {
  2760. UINT8 *p_flag, flag = 0, rt = 0;
  2761. UINT8 data_len;
  2762. tBTM_INQ_PARMS *p_cond = &btm_cb.btm_inq_vars.inqparms;
  2763. tBTM_BLE_INQ_CB *p_le_inq_cb = &btm_cb.ble_ctr_cb.inq_var;
  2764. UNUSED(p);
  2765. /* for observer, always "discoverable */
  2766. if (BTM_BLE_IS_OBS_ACTIVE(btm_cb.ble_ctr_cb.scan_activity)) {
  2767. rt |= BTM_BLE_OBS_RESULT;
  2768. }
  2769. /* for discover, always "discoverable */
  2770. if (BTM_BLE_IS_DISCO_ACTIVE(btm_cb.ble_ctr_cb.scan_activity)) {
  2771. rt |= BTM_BLE_DISCO_RESULT;
  2772. }
  2773. if (BTM_BLE_IS_SEL_CONN_ACTIVE(btm_cb.ble_ctr_cb.scan_activity) &&
  2774. (evt_type == BTM_BLE_CONNECT_EVT || evt_type == BTM_BLE_CONNECT_DIR_EVT)) {
  2775. rt |= BTM_BLE_SEL_CONN_RESULT;
  2776. }
  2777. /* does not match filter condition */
  2778. if (p_cond->filter_cond_type == BTM_FILTER_COND_BD_ADDR &&
  2779. memcmp(bda, p_cond->filter_cond.bdaddr_cond, BD_ADDR_LEN) != 0) {
  2780. BTM_TRACE_DEBUG("BD ADDR does not meet filter condition");
  2781. return rt;
  2782. }
  2783. if (p_le_inq_cb->adv_len != 0) {
  2784. if ((p_flag = BTM_CheckAdvData(p_le_inq_cb->adv_data_cache,
  2785. BTM_BLE_AD_TYPE_FLAG, &data_len)) != NULL) {
  2786. flag = * p_flag;
  2787. if ((btm_cb.btm_inq_vars.inq_active & BTM_BLE_GENERAL_INQUIRY) &&
  2788. (flag & (BTM_BLE_LIMIT_DISC_FLAG | BTM_BLE_GEN_DISC_FLAG)) != 0) {
  2789. BTM_TRACE_DEBUG("Find Generable Discoverable device");
  2790. rt |= BTM_BLE_INQ_RESULT;
  2791. }
  2792. else if (btm_cb.btm_inq_vars.inq_active & BTM_BLE_LIMITED_INQUIRY &&
  2793. (flag & BTM_BLE_LIMIT_DISC_FLAG) != 0) {
  2794. BTM_TRACE_DEBUG("Find limited discoverable device");
  2795. rt |= BTM_BLE_INQ_RESULT;
  2796. }
  2797. }
  2798. }
  2799. return rt;
  2800. }
  2801. static void btm_ble_appearance_to_cod(UINT16 appearance, UINT8 *dev_class)
  2802. {
  2803. dev_class[0] = 0;
  2804. switch (appearance) {
  2805. case BTM_BLE_APPEARANCE_GENERIC_PHONE:
  2806. dev_class[1] = BTM_COD_MAJOR_PHONE;
  2807. dev_class[2] = BTM_COD_MINOR_UNCLASSIFIED;
  2808. break;
  2809. case BTM_BLE_APPEARANCE_GENERIC_COMPUTER:
  2810. dev_class[1] = BTM_COD_MAJOR_COMPUTER;
  2811. dev_class[2] = BTM_COD_MINOR_UNCLASSIFIED;
  2812. break;
  2813. case BTM_BLE_APPEARANCE_GENERIC_REMOTE:
  2814. dev_class[1] = BTM_COD_MAJOR_PERIPHERAL;
  2815. dev_class[2] = BTM_COD_MINOR_REMOTE_CONTROL;
  2816. break;
  2817. case BTM_BLE_APPEARANCE_GENERIC_THERMOMETER:
  2818. case BTM_BLE_APPEARANCE_THERMOMETER_EAR:
  2819. dev_class[1] = BTM_COD_MAJOR_HEALTH;
  2820. dev_class[2] = BTM_COD_MINOR_THERMOMETER;
  2821. break;
  2822. case BTM_BLE_APPEARANCE_GENERIC_HEART_RATE:
  2823. case BTM_BLE_APPEARANCE_HEART_RATE_BELT:
  2824. dev_class[1] = BTM_COD_MAJOR_HEALTH;
  2825. dev_class[2] = BTM_COD_MINOR_HEART_PULSE_MONITOR;
  2826. break;
  2827. case BTM_BLE_APPEARANCE_GENERIC_BLOOD_PRESSURE:
  2828. case BTM_BLE_APPEARANCE_BLOOD_PRESSURE_ARM:
  2829. case BTM_BLE_APPEARANCE_BLOOD_PRESSURE_WRIST:
  2830. dev_class[1] = BTM_COD_MAJOR_HEALTH;
  2831. dev_class[2] = BTM_COD_MINOR_BLOOD_MONITOR;
  2832. break;
  2833. case BTM_BLE_APPEARANCE_GENERIC_PULSE_OXIMETER:
  2834. case BTM_BLE_APPEARANCE_PULSE_OXIMETER_FINGERTIP:
  2835. case BTM_BLE_APPEARANCE_PULSE_OXIMETER_WRIST:
  2836. dev_class[1] = BTM_COD_MAJOR_HEALTH;
  2837. dev_class[2] = BTM_COD_MINOR_PULSE_OXIMETER;
  2838. break;
  2839. case BTM_BLE_APPEARANCE_GENERIC_GLUCOSE:
  2840. dev_class[1] = BTM_COD_MAJOR_HEALTH;
  2841. dev_class[2] = BTM_COD_MINOR_GLUCOSE_METER;
  2842. break;
  2843. case BTM_BLE_APPEARANCE_GENERIC_WEIGHT:
  2844. dev_class[1] = BTM_COD_MAJOR_HEALTH;
  2845. dev_class[2] = BTM_COD_MINOR_WEIGHING_SCALE;
  2846. break;
  2847. case BTM_BLE_APPEARANCE_GENERIC_WALKING:
  2848. case BTM_BLE_APPEARANCE_WALKING_IN_SHOE:
  2849. case BTM_BLE_APPEARANCE_WALKING_ON_SHOE:
  2850. case BTM_BLE_APPEARANCE_WALKING_ON_HIP:
  2851. dev_class[1] = BTM_COD_MAJOR_HEALTH;
  2852. dev_class[2] = BTM_COD_MINOR_STEP_COUNTER;
  2853. break;
  2854. case BTM_BLE_APPEARANCE_GENERIC_WATCH:
  2855. case BTM_BLE_APPEARANCE_SPORTS_WATCH:
  2856. dev_class[1] = BTM_COD_MAJOR_WEARABLE;
  2857. dev_class[2] = BTM_COD_MINOR_WRIST_WATCH;
  2858. break;
  2859. case BTM_BLE_APPEARANCE_GENERIC_EYEGLASSES:
  2860. dev_class[1] = BTM_COD_MAJOR_WEARABLE;
  2861. dev_class[2] = BTM_COD_MINOR_GLASSES;
  2862. break;
  2863. case BTM_BLE_APPEARANCE_GENERIC_DISPLAY:
  2864. dev_class[1] = BTM_COD_MAJOR_IMAGING;
  2865. dev_class[2] = BTM_COD_MINOR_DISPLAY;
  2866. break;
  2867. case BTM_BLE_APPEARANCE_GENERIC_MEDIA_PLAYER:
  2868. dev_class[1] = BTM_COD_MAJOR_AUDIO;
  2869. dev_class[2] = BTM_COD_MINOR_UNCLASSIFIED;
  2870. break;
  2871. case BTM_BLE_APPEARANCE_GENERIC_BARCODE_SCANNER:
  2872. case BTM_BLE_APPEARANCE_HID_BARCODE_SCANNER:
  2873. case BTM_BLE_APPEARANCE_GENERIC_HID:
  2874. dev_class[1] = BTM_COD_MAJOR_PERIPHERAL;
  2875. dev_class[2] = BTM_COD_MINOR_UNCLASSIFIED;
  2876. break;
  2877. case BTM_BLE_APPEARANCE_HID_KEYBOARD:
  2878. dev_class[1] = BTM_COD_MAJOR_PERIPHERAL;
  2879. dev_class[2] = BTM_COD_MINOR_KEYBOARD;
  2880. break;
  2881. case BTM_BLE_APPEARANCE_HID_MOUSE:
  2882. dev_class[1] = BTM_COD_MAJOR_PERIPHERAL;
  2883. dev_class[2] = BTM_COD_MINOR_POINTING;
  2884. break;
  2885. case BTM_BLE_APPEARANCE_HID_JOYSTICK:
  2886. dev_class[1] = BTM_COD_MAJOR_PERIPHERAL;
  2887. dev_class[2] = BTM_COD_MINOR_JOYSTICK;
  2888. break;
  2889. case BTM_BLE_APPEARANCE_HID_GAMEPAD:
  2890. dev_class[1] = BTM_COD_MAJOR_PERIPHERAL;
  2891. dev_class[2] = BTM_COD_MINOR_GAMEPAD;
  2892. break;
  2893. case BTM_BLE_APPEARANCE_HID_DIGITIZER_TABLET:
  2894. dev_class[1] = BTM_COD_MAJOR_PERIPHERAL;
  2895. dev_class[2] = BTM_COD_MINOR_DIGITIZING_TABLET;
  2896. break;
  2897. case BTM_BLE_APPEARANCE_HID_CARD_READER:
  2898. dev_class[1] = BTM_COD_MAJOR_PERIPHERAL;
  2899. dev_class[2] = BTM_COD_MINOR_CARD_READER;
  2900. break;
  2901. case BTM_BLE_APPEARANCE_HID_DIGITAL_PEN:
  2902. dev_class[1] = BTM_COD_MAJOR_PERIPHERAL;
  2903. dev_class[2] = BTM_COD_MINOR_DIGITAL_PAN;
  2904. break;
  2905. case BTM_BLE_APPEARANCE_UNKNOWN:
  2906. case BTM_BLE_APPEARANCE_GENERIC_CLOCK:
  2907. case BTM_BLE_APPEARANCE_GENERIC_TAG:
  2908. case BTM_BLE_APPEARANCE_GENERIC_KEYRING:
  2909. case BTM_BLE_APPEARANCE_GENERIC_CYCLING:
  2910. case BTM_BLE_APPEARANCE_CYCLING_COMPUTER:
  2911. case BTM_BLE_APPEARANCE_CYCLING_SPEED:
  2912. case BTM_BLE_APPEARANCE_CYCLING_CADENCE:
  2913. case BTM_BLE_APPEARANCE_CYCLING_POWER:
  2914. case BTM_BLE_APPEARANCE_CYCLING_SPEED_CADENCE:
  2915. case BTM_BLE_APPEARANCE_GENERIC_OUTDOOR_SPORTS:
  2916. case BTM_BLE_APPEARANCE_OUTDOOR_SPORTS_LOCATION:
  2917. case BTM_BLE_APPEARANCE_OUTDOOR_SPORTS_LOCATION_AND_NAV:
  2918. case BTM_BLE_APPEARANCE_OUTDOOR_SPORTS_LOCATION_POD:
  2919. case BTM_BLE_APPEARANCE_OUTDOOR_SPORTS_LOCATION_POD_AND_NAV:
  2920. default:
  2921. dev_class[1] = BTM_COD_MAJOR_UNCLASSIFIED;
  2922. dev_class[2] = BTM_COD_MINOR_UNCLASSIFIED;
  2923. };
  2924. }
  2925. /*******************************************************************************
  2926. **
  2927. ** Function btm_ble_update_inq_result
  2928. **
  2929. ** Description Update adv packet information into inquiry result.
  2930. **
  2931. ** Parameters
  2932. **
  2933. ** Returns void
  2934. **
  2935. *******************************************************************************/
  2936. BOOLEAN btm_ble_update_inq_result(BD_ADDR bda, tINQ_DB_ENT *p_i, UINT8 addr_type, UINT8 evt_type, UINT8 *p)
  2937. {
  2938. BOOLEAN to_report = TRUE;
  2939. tBTM_INQ_RESULTS *p_cur = &p_i->inq_info.results;
  2940. UINT8 len;
  2941. UINT8 *p_flag;
  2942. tBTM_INQUIRY_VAR_ST *p_inq = &btm_cb.btm_inq_vars;
  2943. UINT8 data_len, rssi;
  2944. tBTM_BLE_INQ_CB *p_le_inq_cb = &btm_cb.ble_ctr_cb.inq_var;
  2945. UINT8 *p1;
  2946. UINT8 *p_uuid16;
  2947. STREAM_TO_UINT8 (data_len, p);
  2948. if (data_len > BTM_BLE_ADV_DATA_LEN_MAX) {
  2949. BTM_TRACE_WARNING("EIR data too long %d. discard", data_len);
  2950. return FALSE;
  2951. }
  2952. btm_ble_cache_adv_data(bda, p_cur, data_len, p, evt_type);
  2953. p1 = (p + data_len);
  2954. STREAM_TO_UINT8 (rssi, p1);
  2955. /* Save the info */
  2956. p_cur->inq_result_type = BTM_INQ_RESULT_BLE;
  2957. p_cur->ble_addr_type = addr_type;
  2958. p_cur->rssi = rssi;
  2959. /* active scan, always wait until get scan_rsp to report the result */
  2960. if ((btm_cb.ble_ctr_cb.inq_var.scan_type == BTM_BLE_SCAN_MODE_ACTI &&
  2961. (evt_type == BTM_BLE_CONNECT_EVT || evt_type == BTM_BLE_DISCOVER_EVT))) {
  2962. BTM_TRACE_DEBUG("btm_ble_update_inq_result scan_rsp=false, to_report=false,\
  2963. scan_type_active=%d", btm_cb.ble_ctr_cb.inq_var.scan_type);
  2964. p_i->scan_rsp = FALSE;
  2965. #if BTM_BLE_ACTIVE_SCAN_REPORT_ADV_SCAN_RSP_INDIVIDUALLY == FALSE
  2966. to_report = FALSE;
  2967. #endif
  2968. } else {
  2969. p_i->scan_rsp = TRUE;
  2970. }
  2971. if (p_i->inq_count != p_inq->inq_counter) {
  2972. p_cur->device_type = BT_DEVICE_TYPE_BLE;
  2973. } else {
  2974. p_cur->device_type |= BT_DEVICE_TYPE_BLE;
  2975. }
  2976. if (evt_type != BTM_BLE_SCAN_RSP_EVT) {
  2977. p_cur->ble_evt_type = evt_type;
  2978. }
  2979. p_i->inq_count = p_inq->inq_counter; /* Mark entry for current inquiry */
  2980. if (p_le_inq_cb->adv_len != 0) {
  2981. if ((p_flag = BTM_CheckAdvData(p_le_inq_cb->adv_data_cache, BTM_BLE_AD_TYPE_FLAG, &len)) != NULL) {
  2982. p_cur->flag = * p_flag;
  2983. }
  2984. }
  2985. if (p_le_inq_cb->adv_len != 0) {
  2986. /* Check to see the BLE device has the Appearance UUID in the advertising data. If it does
  2987. * then try to convert the appearance value to a class of device value Bluedroid can use.
  2988. * Otherwise fall back to trying to infer if it is a HID device based on the service class.
  2989. */
  2990. p_uuid16 = BTM_CheckAdvData(p_le_inq_cb->adv_data_cache, BTM_BLE_AD_TYPE_APPEARANCE, &len);
  2991. if (p_uuid16 && len == 2) {
  2992. btm_ble_appearance_to_cod((UINT16)p_uuid16[0] | (p_uuid16[1] << 8), p_cur->dev_class);
  2993. } else {
  2994. if ((p_uuid16 = BTM_CheckAdvData(p_le_inq_cb->adv_data_cache,
  2995. BTM_BLE_AD_TYPE_16SRV_CMPL, &len)) != NULL) {
  2996. UINT8 i;
  2997. for (i = 0; i + 2 <= len; i = i + 2) {
  2998. #if BTA_HH_LE_INCLUDED == TRUE
  2999. /* if this BLE device support HID over LE, set HID Major in class of device */
  3000. if ((p_uuid16[i] | (p_uuid16[i + 1] << 8)) == UUID_SERVCLASS_LE_HID) {
  3001. p_cur->dev_class[0] = 0;
  3002. p_cur->dev_class[1] = BTM_COD_MAJOR_PERIPHERAL;
  3003. p_cur->dev_class[2] = 0;
  3004. break;
  3005. }
  3006. #endif /* BTA_HH_LE_INCLUDED */
  3007. }
  3008. }
  3009. }
  3010. }
  3011. /* if BR/EDR not supported is not set, assume is a DUMO device */
  3012. if ((p_cur->flag & BTM_BLE_BREDR_NOT_SPT) == 0 &&
  3013. evt_type != BTM_BLE_CONNECT_DIR_EVT) {
  3014. if (p_cur->ble_addr_type != BLE_ADDR_RANDOM) {
  3015. BTM_TRACE_DEBUG("BR/EDR NOT support bit not set, treat as DUMO");
  3016. p_cur->device_type |= BT_DEVICE_TYPE_DUMO;
  3017. } else {
  3018. BTM_TRACE_DEBUG("Random address, treating device as LE only");
  3019. }
  3020. } else {
  3021. BTM_TRACE_DEBUG("BR/EDR NOT SUPPORT bit set, LE only device");
  3022. }
  3023. return to_report;
  3024. }
  3025. /*******************************************************************************
  3026. **
  3027. ** Function btm_clear_all_pending_le_entry
  3028. **
  3029. ** Description This function is called to clear all LE pending entry in
  3030. ** inquiry database.
  3031. **
  3032. ** Returns void
  3033. **
  3034. *******************************************************************************/
  3035. void btm_clear_all_pending_le_entry(void)
  3036. {
  3037. UINT16 xx;
  3038. tINQ_DB_ENT *p_ent = btm_cb.btm_inq_vars.inq_db;
  3039. for (xx = 0; xx < BTM_INQ_DB_SIZE; xx++, p_ent++) {
  3040. /* mark all pending LE entry as unused if an LE only device has scan response outstanding */
  3041. if ((p_ent->in_use) &&
  3042. (p_ent->inq_info.results.device_type == BT_DEVICE_TYPE_BLE) &&
  3043. !p_ent->scan_rsp) {
  3044. p_ent->in_use = FALSE;
  3045. }
  3046. }
  3047. }
  3048. /*******************************************************************************
  3049. **
  3050. ** Function btm_send_sel_conn_callback
  3051. **
  3052. ** Description send selection connection request callback.
  3053. **
  3054. ** Parameters
  3055. **
  3056. ** Returns void
  3057. **
  3058. *******************************************************************************/
  3059. void btm_send_sel_conn_callback(BD_ADDR remote_bda, UINT8 evt_type, UINT8 *p_data, UINT8 addr_type)
  3060. {
  3061. UINT8 data_len, len;
  3062. UINT8 *p_dev_name, remname[31] = {0};
  3063. UNUSED(addr_type);
  3064. if (btm_cb.ble_ctr_cb.p_select_cback == NULL ||
  3065. /* non-connectable device */
  3066. (evt_type != BTM_BLE_EVT_CONN_ADV && evt_type != BTM_BLE_EVT_CONN_DIR_ADV)) {
  3067. return;
  3068. }
  3069. STREAM_TO_UINT8 (data_len, p_data);
  3070. /* get the device name if exist in ADV data */
  3071. if (data_len != 0) {
  3072. p_dev_name = BTM_CheckAdvData(p_data, BTM_BLE_AD_TYPE_NAME_CMPL, &len);
  3073. if (p_dev_name == NULL) {
  3074. p_dev_name = BTM_CheckAdvData(p_data, BTM_BLE_AD_TYPE_NAME_SHORT, &len);
  3075. }
  3076. if (p_dev_name) {
  3077. memcpy(remname, p_dev_name, len);
  3078. }
  3079. }
  3080. /* allow connection */
  3081. if ((* btm_cb.ble_ctr_cb.p_select_cback)(remote_bda, remname)) {
  3082. /* terminate selective connection, initiate connection */
  3083. btm_ble_initiate_select_conn(remote_bda);
  3084. }
  3085. }
  3086. static void btm_adv_pkt_handler(void *arg)
  3087. {
  3088. UINT8 hci_evt_code, hci_evt_len;
  3089. UINT8 ble_sub_code;
  3090. tBTM_BLE_CB *p_cb = &btm_cb.ble_ctr_cb;
  3091. size_t pkts_to_process = pkt_queue_length(p_cb->adv_rpt_queue);
  3092. if (pkts_to_process > BTM_BLE_GAP_ADV_RPT_BATCH_SIZE) {
  3093. pkts_to_process = BTM_BLE_GAP_ADV_RPT_BATCH_SIZE;
  3094. }
  3095. for (size_t i = 0; i < pkts_to_process; i++) {
  3096. pkt_linked_item_t *linked_pkt = pkt_queue_dequeue(p_cb->adv_rpt_queue);
  3097. assert(linked_pkt != NULL);
  3098. BT_HDR *packet = (BT_HDR *)linked_pkt->data;
  3099. uint8_t *p = packet->data + packet->offset;
  3100. STREAM_TO_UINT8 (hci_evt_code, p);
  3101. STREAM_TO_UINT8 (hci_evt_len, p);
  3102. STREAM_TO_UINT8 (ble_sub_code, p);
  3103. if (ble_sub_code == HCI_BLE_ADV_PKT_RPT_EVT) {
  3104. btm_ble_process_adv_pkt(p);
  3105. } else if (ble_sub_code == HCI_BLE_ADV_DISCARD_REPORT_EVT) {
  3106. btm_ble_process_adv_discard_evt(p);
  3107. } else if (ble_sub_code == HCI_BLE_DIRECT_ADV_EVT) {
  3108. btm_ble_process_direct_adv_pkt(p);
  3109. } else {
  3110. assert (0);
  3111. }
  3112. osi_free(linked_pkt);
  3113. #if (BLE_ADV_REPORT_FLOW_CONTROL == TRUE)
  3114. hci_adv_credits_try_release(1);
  3115. #endif
  3116. }
  3117. if (pkt_queue_length(p_cb->adv_rpt_queue) != 0) {
  3118. btu_task_post(SIG_BTU_HCI_ADV_RPT_MSG, NULL, OSI_THREAD_MAX_TIMEOUT);
  3119. }
  3120. UNUSED(hci_evt_code);
  3121. UNUSED(hci_evt_len);
  3122. }
  3123. /*******************************************************************************
  3124. **
  3125. ** Function btm_ble_process_adv_pkt
  3126. **
  3127. ** Description This function is called when adv packet report events are
  3128. ** received from the device. It updates the inquiry database.
  3129. ** If the inquiry database is full, the oldest entry is discarded.
  3130. **
  3131. ** Parameters
  3132. **
  3133. ** Returns void
  3134. **
  3135. *******************************************************************************/
  3136. void btm_ble_process_adv_pkt (UINT8 *p_data)
  3137. {
  3138. BD_ADDR bda;
  3139. UINT8 evt_type = 0, *p = p_data;
  3140. UINT8 addr_type = 0;
  3141. UINT8 num_reports;
  3142. UINT8 data_len;
  3143. #if (defined BLE_PRIVACY_SPT && BLE_PRIVACY_SPT == TRUE)
  3144. BOOLEAN match = FALSE;
  3145. #if (!CONTROLLER_RPA_LIST_ENABLE)
  3146. BD_ADDR temp_bda;
  3147. UINT8 temp_addr_type = 0;
  3148. #endif // (!CONTROLLER_RPA_LIST_ENABLE)
  3149. #endif//(defined BLE_PRIVACY_SPT && BLE_PRIVACY_SPT == TRUE)
  3150. /* Only process the results if the inquiry is still active */
  3151. if (!BTM_BLE_IS_SCAN_ACTIVE(btm_cb.ble_ctr_cb.scan_activity)) {
  3152. return;
  3153. }
  3154. /* Extract the number of reports in this event. */
  3155. STREAM_TO_UINT8(num_reports, p);
  3156. while (num_reports--) {
  3157. /* Extract inquiry results */
  3158. STREAM_TO_UINT8 (evt_type, p);
  3159. STREAM_TO_UINT8 (addr_type, p);
  3160. STREAM_TO_BDADDR (bda, p);
  3161. //BTM_TRACE_ERROR("btm_ble_process_adv_pkt:bda= %0x:%0x:%0x:%0x:%0x:%0x\n",
  3162. // bda[0],bda[1],bda[2],bda[3],bda[4],bda[5]);
  3163. #if (defined BLE_PRIVACY_SPT && BLE_PRIVACY_SPT == TRUE)
  3164. #if (!CONTROLLER_RPA_LIST_ENABLE)
  3165. temp_addr_type = addr_type;
  3166. memcpy(temp_bda, bda, BD_ADDR_LEN);
  3167. #endif // (!CONTROLLER_RPA_LIST_ENABLE)
  3168. /* map address to security record */
  3169. match = btm_identity_addr_to_random_pseudo(bda, &addr_type, FALSE);
  3170. // BTM_TRACE_ERROR("btm_ble_process_adv_pkt:bda= %0x:%0x:%0x:%0x:%0x:%0x\n",
  3171. // bda[0],bda[1],bda[2],bda[3],bda[4],bda[5]);
  3172. /* always do RRA resolution on host */
  3173. if (!match && BTM_BLE_IS_RESOLVE_BDA(bda)) {
  3174. btm_ble_resolve_random_addr(bda, btm_ble_resolve_random_addr_on_adv, p_data);
  3175. } else
  3176. #endif
  3177. btm_ble_process_adv_pkt_cont(bda, addr_type, evt_type, p);
  3178. #if (defined BLE_PRIVACY_SPT && BLE_PRIVACY_SPT == TRUE && (!CONTROLLER_RPA_LIST_ENABLE))
  3179. //save current adv addr information if p_dev_rec!= NULL
  3180. tBTM_SEC_DEV_REC *p_dev_rec = btm_find_dev (bda);
  3181. if(p_dev_rec) {
  3182. p_dev_rec->ble.current_addr_type = temp_addr_type;
  3183. memcpy(p_dev_rec->ble.current_addr, temp_bda, BD_ADDR_LEN);
  3184. p_dev_rec->ble.current_addr_valid = true;
  3185. }
  3186. #endif
  3187. STREAM_TO_UINT8(data_len, p);
  3188. /* Advance to the next event data_len + rssi byte */
  3189. p += data_len + 1;
  3190. }
  3191. }
  3192. /*******************************************************************************
  3193. **
  3194. ** Function btm_ble_process_last_adv_pkt
  3195. **
  3196. ** Description This function is called to report last adv packet
  3197. **
  3198. ** Parameters
  3199. **
  3200. ** Returns void
  3201. **
  3202. *******************************************************************************/
  3203. static void btm_ble_process_last_adv_pkt(void)
  3204. {
  3205. UINT8 result = 0;
  3206. UINT8 null_bda[6] = {0};
  3207. tBTM_INQUIRY_VAR_ST *p_inq = &btm_cb.btm_inq_vars;
  3208. tBTM_INQ_RESULTS_CB *p_inq_results_cb = p_inq->p_inq_results_cb;
  3209. tBTM_INQ_RESULTS_CB *p_obs_results_cb = btm_cb.ble_ctr_cb.p_obs_results_cb;
  3210. tBTM_INQ_RESULTS_CB *p_scan_results_cb = btm_cb.ble_ctr_cb.p_scan_results_cb;
  3211. tBTM_BLE_INQ_CB *p_le_inq_cb = &btm_cb.ble_ctr_cb.inq_var;
  3212. tINQ_DB_ENT *p_i = btm_inq_db_find (p_le_inq_cb->adv_addr);
  3213. if(memcmp(null_bda, p_le_inq_cb->adv_addr, BD_ADDR_LEN) == 0) {
  3214. return;
  3215. }
  3216. if(p_i == NULL) {
  3217. BTM_TRACE_DEBUG("no last adv");
  3218. return;
  3219. }
  3220. if ((result = btm_ble_is_discoverable(p_le_inq_cb->adv_addr, p_i->inq_info.results.ble_evt_type, NULL)) == 0) {
  3221. BTM_TRACE_WARNING("%s device is no longer discoverable so discarding advertising packet pkt",
  3222. __func__);
  3223. return;
  3224. }
  3225. /* background connection in selective connection mode */
  3226. if (btm_cb.ble_ctr_cb.bg_conn_type == BTM_BLE_CONN_SELECTIVE) {
  3227. //do nothing
  3228. } else {
  3229. if (p_inq_results_cb && (result & BTM_BLE_INQ_RESULT)) {
  3230. (p_inq_results_cb)((tBTM_INQ_RESULTS *) &p_i->inq_info.results, p_le_inq_cb->adv_data_cache);
  3231. p_le_inq_cb->adv_len = 0;
  3232. memset(p_le_inq_cb->adv_addr, 0, BD_ADDR_LEN);
  3233. p_i->inq_info.results.adv_data_len = 0;
  3234. p_i->inq_info.results.scan_rsp_len = 0;
  3235. }
  3236. if (p_obs_results_cb && (result & BTM_BLE_OBS_RESULT)) {
  3237. (p_obs_results_cb)((tBTM_INQ_RESULTS *) &p_i->inq_info.results, p_le_inq_cb->adv_data_cache);
  3238. p_le_inq_cb->adv_len = 0;
  3239. memset(p_le_inq_cb->adv_addr, 0, BD_ADDR_LEN);
  3240. p_i->inq_info.results.adv_data_len = 0;
  3241. p_i->inq_info.results.scan_rsp_len = 0;
  3242. }
  3243. if (p_scan_results_cb && (result & BTM_BLE_DISCO_RESULT)) {
  3244. (p_scan_results_cb)((tBTM_INQ_RESULTS *) &p_i->inq_info.results, p_le_inq_cb->adv_data_cache);
  3245. p_le_inq_cb->adv_len = 0;
  3246. memset(p_le_inq_cb->adv_addr, 0, BD_ADDR_LEN);
  3247. p_i->inq_info.results.adv_data_len = 0;
  3248. p_i->inq_info.results.scan_rsp_len = 0;
  3249. }
  3250. }
  3251. }
  3252. /*******************************************************************************
  3253. **
  3254. ** Function btm_ble_process_adv_pkt_cont
  3255. **
  3256. ** Description This function is called after random address resolution is
  3257. ** done, and proceed to process adv packet.
  3258. **
  3259. ** Parameters
  3260. **
  3261. ** Returns void
  3262. **
  3263. *******************************************************************************/
  3264. static void btm_ble_process_adv_pkt_cont(BD_ADDR bda, UINT8 addr_type, UINT8 evt_type, UINT8 *p)
  3265. {
  3266. tINQ_DB_ENT *p_i;
  3267. tBTM_INQUIRY_VAR_ST *p_inq = &btm_cb.btm_inq_vars;
  3268. tBTM_INQ_RESULTS_CB *p_inq_results_cb = p_inq->p_inq_results_cb;
  3269. tBTM_INQ_RESULTS_CB *p_obs_results_cb = btm_cb.ble_ctr_cb.p_obs_results_cb;
  3270. tBTM_INQ_RESULTS_CB *p_scan_results_cb = btm_cb.ble_ctr_cb.p_scan_results_cb;
  3271. tBTM_BLE_INQ_CB *p_le_inq_cb = &btm_cb.ble_ctr_cb.inq_var;
  3272. BOOLEAN update = TRUE;
  3273. UINT8 result = 0;
  3274. /* Event_Type:
  3275. 0x00 Connectable undirected advertising (ADV_IND).
  3276. 0x01 Connectable directed advertising (ADV_DIRECT_IND)
  3277. 0x02 Scannable undirected advertising (ADV_SCAN_IND)
  3278. 0x03 Non connectable undirected advertising (ADV_NONCONN_IND)
  3279. 0x04 Scan Response (SCAN_RSP)
  3280. 0x05-0xFF Reserved for future use
  3281. */
  3282. //if scan duplicate is enabled, the adv packet without scan response is allowed to report to higher layer
  3283. if(p_le_inq_cb->scan_duplicate_filter == BTM_BLE_SCAN_DUPLICATE_ENABLE) {
  3284. /*
  3285. Bluedroid will put the advertising packet and scan response into a packet and send it to the higher layer.
  3286. If two advertising packets are not with the same address, or can't be combined into a packet, then the first advertising
  3287. packet will be discarded. So we added the following judgment:
  3288. 1. For different addresses, send the last advertising packet to higher layer
  3289. 2. For same address and same advertising type (not scan response), send the last advertising packet to higher layer
  3290. 3. For same address and scan response, do nothing
  3291. */
  3292. int same_addr = memcmp(bda, p_le_inq_cb->adv_addr, BD_ADDR_LEN);
  3293. if (same_addr != 0 || (same_addr == 0 && evt_type != BTM_BLE_SCAN_RSP_EVT)) {
  3294. btm_ble_process_last_adv_pkt();
  3295. }
  3296. }
  3297. p_i = btm_inq_db_find (bda);
  3298. /* Check if this address has already been processed for this inquiry */
  3299. if (btm_inq_find_bdaddr(bda)) {
  3300. /* never been report as an LE device */
  3301. if (p_i &&
  3302. (!(p_i->inq_info.results.device_type & BT_DEVICE_TYPE_BLE) ||
  3303. /* scan repsonse to be updated */
  3304. (!p_i->scan_rsp))) {
  3305. update = TRUE;
  3306. } else if (BTM_BLE_IS_DISCO_ACTIVE(btm_cb.ble_ctr_cb.scan_activity)) {
  3307. update = FALSE;
  3308. } else {
  3309. /* if yes, skip it */
  3310. return; /* assumption: one result per event */
  3311. }
  3312. }
  3313. /* If existing entry, use that, else get a new one (possibly reusing the oldest) */
  3314. if (p_i == NULL) {
  3315. if ((p_i = btm_inq_db_new (bda)) != NULL) {
  3316. p_inq->inq_cmpl_info.num_resp++;
  3317. } else {
  3318. return;
  3319. }
  3320. } else if (p_i->inq_count != p_inq->inq_counter) { /* first time seen in this inquiry */
  3321. p_inq->inq_cmpl_info.num_resp++;
  3322. }
  3323. /* update the LE device information in inquiry database */
  3324. if (!btm_ble_update_inq_result(bda, p_i, addr_type, evt_type, p)) {
  3325. return;
  3326. }
  3327. if ((result = btm_ble_is_discoverable(bda, evt_type, p)) == 0) {
  3328. BTM_TRACE_WARNING("%s device is no longer discoverable so discarding advertising packet pkt",
  3329. __func__);
  3330. return;
  3331. }
  3332. if (!update) {
  3333. result &= ~BTM_BLE_INQ_RESULT;
  3334. }
  3335. /* If the number of responses found and limited, issue a cancel inquiry */
  3336. if (p_inq->inqparms.max_resps &&
  3337. p_inq->inq_cmpl_info.num_resp == p_inq->inqparms.max_resps) {
  3338. /* new device */
  3339. if (p_i == NULL ||
  3340. /* assume a DUMO device, BR/EDR inquiry is always active */
  3341. (p_i &&
  3342. (p_i->inq_info.results.device_type & BT_DEVICE_TYPE_BLE) == BT_DEVICE_TYPE_BLE &&
  3343. p_i->scan_rsp)) {
  3344. BTM_TRACE_WARNING("INQ RES: Extra Response Received...cancelling inquiry..");
  3345. /* if is non-periodic inquiry active, cancel now */
  3346. if ((p_inq->inq_active & BTM_BR_INQ_ACTIVE_MASK) != 0 &&
  3347. (p_inq->inq_active & BTM_PERIODIC_INQUIRY_ACTIVE) == 0) {
  3348. btsnd_hcic_inq_cancel();
  3349. }
  3350. btm_ble_stop_inquiry();
  3351. btm_acl_update_busy_level (BTM_BLI_INQ_DONE_EVT);
  3352. }
  3353. }
  3354. /* background connection in selective connection mode */
  3355. if (btm_cb.ble_ctr_cb.bg_conn_type == BTM_BLE_CONN_SELECTIVE) {
  3356. if (result & BTM_BLE_SEL_CONN_RESULT) {
  3357. btm_send_sel_conn_callback(bda, evt_type, p, addr_type);
  3358. } else {
  3359. BTM_TRACE_DEBUG("None LE device, can not initiate selective connection\n");
  3360. }
  3361. } else {
  3362. if (p_inq_results_cb && (result & BTM_BLE_INQ_RESULT)) {
  3363. (p_inq_results_cb)((tBTM_INQ_RESULTS *) &p_i->inq_info.results, p_le_inq_cb->adv_data_cache);
  3364. p_le_inq_cb->adv_len = 0;
  3365. memset(p_le_inq_cb->adv_addr, 0, BD_ADDR_LEN);
  3366. p_i->inq_info.results.adv_data_len = 0;
  3367. p_i->inq_info.results.scan_rsp_len = 0;
  3368. }
  3369. if (p_obs_results_cb && (result & BTM_BLE_OBS_RESULT)) {
  3370. (p_obs_results_cb)((tBTM_INQ_RESULTS *) &p_i->inq_info.results, p_le_inq_cb->adv_data_cache);
  3371. p_le_inq_cb->adv_len = 0;
  3372. memset(p_le_inq_cb->adv_addr, 0, BD_ADDR_LEN);
  3373. p_i->inq_info.results.adv_data_len = 0;
  3374. p_i->inq_info.results.scan_rsp_len = 0;
  3375. }
  3376. if (p_scan_results_cb && (result & BTM_BLE_DISCO_RESULT)) {
  3377. (p_scan_results_cb)((tBTM_INQ_RESULTS *) &p_i->inq_info.results, p_le_inq_cb->adv_data_cache);
  3378. p_le_inq_cb->adv_len = 0;
  3379. memset(p_le_inq_cb->adv_addr, 0, BD_ADDR_LEN);
  3380. p_i->inq_info.results.adv_data_len = 0;
  3381. p_i->inq_info.results.scan_rsp_len = 0;
  3382. }
  3383. }
  3384. }
  3385. void btm_ble_process_adv_discard_evt(UINT8 *p)
  3386. {
  3387. #if (BLE_ADV_REPORT_FLOW_CONTROL == TRUE)
  3388. uint32_t num_dis = 0;
  3389. STREAM_TO_UINT32 (num_dis, p);
  3390. tBTM_INQ_DIS_CB *p_obs_discard_cb = btm_cb.ble_ctr_cb.p_obs_discard_cb;
  3391. if(p_obs_discard_cb) {
  3392. (p_obs_discard_cb)(num_dis);
  3393. }
  3394. #endif
  3395. }
  3396. void btm_ble_process_direct_adv_pkt(UINT8 *p)
  3397. {
  3398. // TODO
  3399. }
  3400. /*******************************************************************************
  3401. **
  3402. ** Function btm_ble_start_scan
  3403. **
  3404. ** Description Start the BLE scan.
  3405. **
  3406. ** Returns void
  3407. **
  3408. *******************************************************************************/
  3409. tBTM_STATUS btm_ble_start_scan(void)
  3410. {
  3411. tBTM_BLE_INQ_CB *p_inq = &btm_cb.ble_ctr_cb.inq_var;
  3412. tBTM_STATUS status = BTM_CMD_STARTED;
  3413. osi_mutex_lock(&scan_enable_lock, OSI_MUTEX_MAX_TIMEOUT);
  3414. if(p_inq->scan_duplicate_filter > BTM_BLE_DUPLICATE_MAX) {
  3415. p_inq->scan_duplicate_filter = BTM_BLE_DUPLICATE_DISABLE;
  3416. }
  3417. /* start scan, disable duplicate filtering */
  3418. if (!btsnd_hcic_ble_set_scan_enable (BTM_BLE_SCAN_ENABLE, p_inq->scan_duplicate_filter)) {
  3419. status = BTM_NO_RESOURCES;
  3420. } else {
  3421. osi_sem_take(&scan_enable_sem, OSI_SEM_MAX_TIMEOUT);
  3422. if(scan_enable_status != BTM_SUCCESS) {
  3423. status = BTM_NO_RESOURCES;
  3424. }
  3425. btm_cb.ble_ctr_cb.inq_var.state = BTM_BLE_SCANNING;
  3426. if (p_inq->scan_type == BTM_BLE_SCAN_MODE_ACTI) {
  3427. btm_ble_set_topology_mask(BTM_BLE_STATE_ACTIVE_SCAN_BIT);
  3428. } else {
  3429. btm_ble_set_topology_mask(BTM_BLE_STATE_PASSIVE_SCAN_BIT);
  3430. }
  3431. }
  3432. osi_mutex_unlock(&scan_enable_lock);
  3433. return status;
  3434. }
  3435. /*******************************************************************************
  3436. **
  3437. ** Function btm_ble_stop_scan
  3438. **
  3439. ** Description Stop the BLE scan.
  3440. **
  3441. ** Returns void
  3442. **
  3443. *******************************************************************************/
  3444. void btm_ble_stop_scan(void)
  3445. {
  3446. BTM_TRACE_EVENT ("btm_ble_stop_scan ");
  3447. /* Clear the inquiry callback if set */
  3448. btm_cb.ble_ctr_cb.inq_var.scan_type = BTM_BLE_SCAN_MODE_NONE;
  3449. btm_cb.ble_ctr_cb.inq_var.state = BTM_BLE_STOP_SCAN;
  3450. /* stop discovery now */
  3451. btsnd_hcic_ble_set_scan_enable (BTM_BLE_SCAN_DISABLE, BTM_BLE_DUPLICATE_ENABLE);
  3452. btm_update_scanner_filter_policy(SP_ADV_ALL);
  3453. btm_cb.ble_ctr_cb.wl_state &= ~BTM_BLE_WL_SCAN;
  3454. }
  3455. /*******************************************************************************
  3456. **
  3457. ** Function btm_ble_stop_inquiry
  3458. **
  3459. ** Description Stop the BLE Inquiry.
  3460. **
  3461. ** Returns void
  3462. **
  3463. *******************************************************************************/
  3464. void btm_ble_stop_inquiry(void)
  3465. {
  3466. tBTM_INQUIRY_VAR_ST *p_inq = &btm_cb.btm_inq_vars;
  3467. tBTM_BLE_CB *p_ble_cb = &btm_cb.ble_ctr_cb;
  3468. btu_stop_timer (&p_ble_cb->inq_var.inq_timer_ent);
  3469. p_ble_cb->scan_activity &= ~BTM_BLE_INQUIRY_MASK;
  3470. /* If no more scan activity, stop LE scan now */
  3471. if (!BTM_BLE_IS_SCAN_ACTIVE(p_ble_cb->scan_activity)) {
  3472. btm_ble_stop_scan();
  3473. } else if ((p_ble_cb->inq_var.scan_interval != BTM_BLE_LOW_LATENCY_SCAN_INT) ||
  3474. (p_ble_cb->inq_var.scan_window != BTM_BLE_LOW_LATENCY_SCAN_WIN)) {
  3475. BTM_TRACE_DEBUG("%s: setting default params for ongoing observe", __FUNCTION__);
  3476. btm_ble_stop_scan();
  3477. btm_ble_start_scan();
  3478. }
  3479. /* If we have a callback registered for inquiry complete, call it */
  3480. BTM_TRACE_DEBUG ("BTM Inq Compl Callback: status 0x%02x, num results %d",
  3481. p_inq->inq_cmpl_info.status, p_inq->inq_cmpl_info.num_resp);
  3482. btm_process_inq_complete(HCI_SUCCESS, (UINT8)(p_inq->inqparms.mode & BTM_BLE_INQUIRY_MASK));
  3483. }
  3484. /*******************************************************************************
  3485. **
  3486. ** Function btm_ble_stop_observe
  3487. **
  3488. ** Description Stop the BLE Observe.
  3489. **
  3490. ** Returns void
  3491. **
  3492. *******************************************************************************/
  3493. static void btm_ble_stop_observe(void)
  3494. {
  3495. tBTM_BLE_CB *p_ble_cb = & btm_cb.ble_ctr_cb;
  3496. tBTM_CMPL_CB *p_obs_cb = p_ble_cb->p_obs_cmpl_cb;
  3497. btu_stop_timer (&p_ble_cb->obs_timer_ent);
  3498. p_ble_cb->scan_activity &= ~BTM_LE_OBSERVE_ACTIVE;
  3499. p_ble_cb->p_obs_results_cb = NULL;
  3500. p_ble_cb->p_obs_cmpl_cb = NULL;
  3501. if (!BTM_BLE_IS_SCAN_ACTIVE(p_ble_cb->scan_activity)) {
  3502. btm_ble_stop_scan();
  3503. }
  3504. if (p_obs_cb) {
  3505. (p_obs_cb)((tBTM_INQUIRY_CMPL *) &btm_cb.btm_inq_vars.inq_cmpl_info);
  3506. }
  3507. }
  3508. /*******************************************************************************
  3509. **
  3510. ** Function btm_ble_stop_observe
  3511. **
  3512. ** Description Stop the BLE Observe.
  3513. **
  3514. ** Returns void
  3515. **
  3516. *******************************************************************************/
  3517. static void btm_ble_stop_discover(void)
  3518. {
  3519. tBTM_BLE_CB *p_ble_cb = & btm_cb.ble_ctr_cb;
  3520. tBTM_CMPL_CB *p_scan_cb = p_ble_cb->p_scan_cmpl_cb;
  3521. btu_stop_timer (&p_ble_cb->scan_timer_ent);
  3522. osi_mutex_lock(&scan_enable_lock, OSI_MUTEX_MAX_TIMEOUT);
  3523. p_ble_cb->scan_activity &= ~BTM_LE_DISCOVER_ACTIVE;
  3524. p_ble_cb->p_scan_results_cb = NULL;
  3525. p_ble_cb->p_scan_cmpl_cb = NULL;
  3526. if (!BTM_BLE_IS_SCAN_ACTIVE(p_ble_cb->scan_activity)) {
  3527. /* Clear the inquiry callback if set */
  3528. btm_cb.ble_ctr_cb.inq_var.scan_type = BTM_BLE_SCAN_MODE_NONE;
  3529. btm_cb.ble_ctr_cb.inq_var.state = BTM_BLE_STOP_SCAN;
  3530. /* stop discovery now */
  3531. if(btsnd_hcic_ble_set_scan_enable (BTM_BLE_SCAN_DISABLE, BTM_BLE_DUPLICATE_ENABLE)) {
  3532. osi_sem_take(&scan_enable_sem, OSI_SEM_MAX_TIMEOUT);
  3533. }
  3534. }
  3535. if (p_scan_cb) {
  3536. (p_scan_cb)((tBTM_INQUIRY_CMPL *) &btm_cb.btm_inq_vars.inq_cmpl_info);
  3537. }
  3538. osi_mutex_unlock(&scan_enable_lock);
  3539. }
  3540. /*******************************************************************************
  3541. **
  3542. ** Function btm_ble_adv_states_operation
  3543. **
  3544. ** Description Set or clear adv states in topology mask
  3545. **
  3546. ** Returns operation status. TRUE if sucessful, FALSE otherwise.
  3547. **
  3548. *******************************************************************************/
  3549. typedef BOOLEAN (BTM_TOPOLOGY_FUNC_PTR)(tBTM_BLE_STATE_MASK);
  3550. static BOOLEAN btm_ble_adv_states_operation(BTM_TOPOLOGY_FUNC_PTR *p_handler, UINT8 adv_evt)
  3551. {
  3552. BOOLEAN rt = FALSE;
  3553. switch (adv_evt) {
  3554. case BTM_BLE_CONNECT_EVT:
  3555. rt = (*p_handler)(BTM_BLE_STATE_CONN_ADV_BIT);
  3556. break;
  3557. case BTM_BLE_NON_CONNECT_EVT:
  3558. rt = (*p_handler) (BTM_BLE_STATE_NON_CONN_ADV_BIT);
  3559. break;
  3560. case BTM_BLE_CONNECT_DIR_EVT:
  3561. rt = (*p_handler) (BTM_BLE_STATE_HI_DUTY_DIR_ADV_BIT);
  3562. break;
  3563. case BTM_BLE_DISCOVER_EVT:
  3564. rt = (*p_handler) (BTM_BLE_STATE_SCAN_ADV_BIT);
  3565. break;
  3566. case BTM_BLE_CONNECT_LO_DUTY_DIR_EVT:
  3567. rt = (*p_handler) (BTM_BLE_STATE_LO_DUTY_DIR_ADV_BIT);
  3568. break;
  3569. default:
  3570. BTM_TRACE_ERROR("unknown adv event : %d", adv_evt);
  3571. break;
  3572. }
  3573. return rt;
  3574. }
  3575. /*******************************************************************************
  3576. **
  3577. ** Function btm_ble_start_adv
  3578. **
  3579. ** Description start the BLE advertising.
  3580. **
  3581. ** Returns void
  3582. **
  3583. *******************************************************************************/
  3584. tBTM_STATUS btm_ble_start_adv(void)
  3585. {
  3586. tBTM_BLE_INQ_CB *p_cb = &btm_cb.ble_ctr_cb.inq_var;
  3587. tBTM_STATUS rt = BTM_NO_RESOURCES;
  3588. BTM_TRACE_EVENT ("btm_ble_start_adv\n");
  3589. if (!btm_ble_adv_states_operation (btm_ble_topology_check, p_cb->evt_type)) {
  3590. return BTM_WRONG_MODE;
  3591. }
  3592. osi_mutex_lock(&adv_enable_lock, OSI_MUTEX_MAX_TIMEOUT);
  3593. #if (defined BLE_PRIVACY_SPT && BLE_PRIVACY_SPT == TRUE)
  3594. /* To relax resolving list, always have resolving list enabled, unless directed adv */
  3595. if (p_cb->evt_type != BTM_BLE_CONNECT_LO_DUTY_DIR_EVT &&
  3596. p_cb->evt_type != BTM_BLE_CONNECT_DIR_EVT)
  3597. /* enable resolving list is desired */
  3598. {
  3599. //btm_ble_enable_resolving_list_for_platform(BTM_BLE_RL_ADV);
  3600. }
  3601. #endif
  3602. if (p_cb->afp != AP_SCAN_CONN_ALL) {
  3603. //find the device in the btm dev buffer and write it to the controller white list
  3604. btm_execute_wl_dev_operation();
  3605. btm_cb.ble_ctr_cb.wl_state |= BTM_BLE_WL_ADV;
  3606. }
  3607. /* The complete event comes up immediately after the 'btsnd_hcic_ble_set_adv_enable' being called in dual core,
  3608. this causes the 'adv_mode' and 'state' not be set yet, so we set the state first */
  3609. tBTM_BLE_GAP_STATE temp_state = p_cb->state;
  3610. UINT8 adv_mode = p_cb->adv_mode;
  3611. p_cb->adv_mode = BTM_BLE_ADV_ENABLE;
  3612. p_cb->state = BTM_BLE_ADVERTISING;
  3613. btm_ble_adv_states_operation(btm_ble_set_topology_mask, p_cb->evt_type);
  3614. if (btsnd_hcic_ble_set_adv_enable (BTM_BLE_ADV_ENABLE)) {
  3615. osi_sem_take(&adv_enable_sem, OSI_SEM_MAX_TIMEOUT);
  3616. rt = adv_enable_status;
  3617. BTM_TRACE_EVENT ("BTM_SUCCESS\n");
  3618. } else {
  3619. p_cb->adv_mode = BTM_BLE_ADV_DISABLE;
  3620. p_cb->state = temp_state;
  3621. p_cb->adv_mode = adv_mode;
  3622. btm_ble_adv_states_operation(btm_ble_clear_topology_mask, p_cb->evt_type);
  3623. btm_cb.ble_ctr_cb.wl_state &= ~BTM_BLE_WL_ADV;
  3624. }
  3625. if(adv_enable_status != HCI_SUCCESS) {
  3626. p_cb->adv_mode = adv_mode;
  3627. }
  3628. osi_mutex_unlock(&adv_enable_lock);
  3629. return rt;
  3630. }
  3631. /*******************************************************************************
  3632. **
  3633. ** Function btm_ble_stop_adv
  3634. **
  3635. ** Description Stop the BLE advertising.
  3636. **
  3637. ** Returns void
  3638. **
  3639. *******************************************************************************/
  3640. tBTM_STATUS btm_ble_stop_adv(void)
  3641. {
  3642. tBTM_BLE_INQ_CB *p_cb = &btm_cb.ble_ctr_cb.inq_var;
  3643. tBTM_STATUS rt = BTM_SUCCESS;
  3644. if (p_cb) {
  3645. osi_mutex_lock(&adv_enable_lock, OSI_MUTEX_MAX_TIMEOUT);
  3646. UINT8 temp_adv_mode = p_cb->adv_mode;
  3647. BOOLEAN temp_fast_adv_on = p_cb->fast_adv_on;
  3648. tBTM_BLE_GAP_STATE temp_state = p_cb->state;
  3649. tBTM_BLE_WL_STATE temp_wl_state = btm_cb.ble_ctr_cb.wl_state;
  3650. tBTM_BLE_STATE_MASK temp_mask = btm_ble_get_topology_mask ();
  3651. p_cb->fast_adv_on = FALSE;
  3652. p_cb->adv_mode = BTM_BLE_ADV_DISABLE;
  3653. p_cb->state = BTM_BLE_STOP_ADV;
  3654. btm_cb.ble_ctr_cb.wl_state &= ~BTM_BLE_WL_ADV;
  3655. /* clear all adv states */
  3656. btm_ble_clear_topology_mask (BTM_BLE_STATE_ALL_ADV_MASK);
  3657. if (btsnd_hcic_ble_set_adv_enable (BTM_BLE_ADV_DISABLE)) {
  3658. osi_sem_take(&adv_enable_sem, OSI_SEM_MAX_TIMEOUT);
  3659. rt = adv_enable_status;
  3660. } else {
  3661. // reset state
  3662. p_cb->fast_adv_on = temp_fast_adv_on;
  3663. p_cb->adv_mode = temp_adv_mode;
  3664. p_cb->state = temp_state;
  3665. btm_cb.ble_ctr_cb.wl_state = temp_wl_state;
  3666. btm_ble_set_topology_mask (temp_mask);
  3667. rt = BTM_NO_RESOURCES;
  3668. }
  3669. if(adv_enable_status != HCI_SUCCESS) {
  3670. p_cb->adv_mode = temp_adv_mode;
  3671. }
  3672. osi_mutex_unlock(&adv_enable_lock);
  3673. }
  3674. return rt;
  3675. }
  3676. /*******************************************************************************
  3677. **
  3678. ** Function btm_ble_start_slow_adv
  3679. **
  3680. ** Description Restart adv with slow adv interval
  3681. **
  3682. ** Returns void
  3683. **
  3684. *******************************************************************************/
  3685. static void btm_ble_start_slow_adv (void)
  3686. {
  3687. tBTM_BLE_INQ_CB *p_cb = &btm_cb.ble_ctr_cb.inq_var;
  3688. if (p_cb->adv_mode == BTM_BLE_ADV_ENABLE) {
  3689. tBTM_LE_RANDOM_CB *p_addr_cb = &btm_cb.ble_ctr_cb.addr_mgnt_cb;
  3690. BD_ADDR p_addr_ptr = {0};
  3691. tBLE_ADDR_TYPE init_addr_type = BLE_ADDR_PUBLIC;
  3692. tBLE_ADDR_TYPE own_addr_type = p_addr_cb->own_addr_type;
  3693. btm_ble_stop_adv();
  3694. p_cb->evt_type = btm_set_conn_mode_adv_init_addr(p_cb, p_addr_ptr, &init_addr_type,
  3695. &own_addr_type);
  3696. /* slow adv mode never goes into directed adv */
  3697. btsnd_hcic_ble_write_adv_params (BTM_BLE_GAP_ADV_SLOW_INT, BTM_BLE_GAP_ADV_SLOW_INT,
  3698. p_cb->evt_type, own_addr_type,
  3699. init_addr_type, p_addr_ptr,
  3700. p_cb->adv_chnl_map, p_cb->afp);
  3701. btm_ble_start_adv();
  3702. }
  3703. }
  3704. /*******************************************************************************
  3705. **
  3706. ** Function btm_ble_timeout
  3707. **
  3708. ** Description Called when BTM BLE inquiry timer expires
  3709. **
  3710. ** Returns void
  3711. **
  3712. *******************************************************************************/
  3713. void btm_ble_timeout(TIMER_LIST_ENT *p_tle)
  3714. {
  3715. BTM_TRACE_EVENT ("btm_ble_timeout");
  3716. switch (p_tle->event) {
  3717. case BTU_TTYPE_BLE_OBSERVE:
  3718. btm_ble_stop_observe();
  3719. break;
  3720. case BTU_TTYPE_BLE_SCAN:
  3721. btm_ble_stop_discover();
  3722. break;
  3723. case BTU_TTYPE_BLE_INQUIRY:
  3724. btm_ble_stop_inquiry();
  3725. break;
  3726. case BTU_TTYPE_BLE_GAP_LIM_DISC:
  3727. /* lim_timeout expiried, limited discovery should exit now */
  3728. btm_cb.btm_inq_vars.discoverable_mode &= ~BTM_BLE_LIMITED_DISCOVERABLE;
  3729. btm_ble_set_adv_flag(btm_cb.btm_inq_vars.connectable_mode, btm_cb.btm_inq_vars.discoverable_mode);
  3730. break;
  3731. case BTU_TTYPE_BLE_RANDOM_ADDR:
  3732. if (btm_cb.ble_ctr_cb.addr_mgnt_cb.own_addr_type == BLE_ADDR_RANDOM) {
  3733. if (NULL == (void *)(p_tle->param)) {
  3734. /* refresh the random addr */
  3735. btm_gen_resolvable_private_addr((void *)btm_gen_resolve_paddr_low);
  3736. } else {
  3737. if (BTM_BleMaxMultiAdvInstanceCount() > 0) {
  3738. btm_ble_multi_adv_configure_rpa((tBTM_BLE_MULTI_ADV_INST *)p_tle->param);
  3739. }
  3740. }
  3741. }
  3742. break;
  3743. case BTU_TTYPE_BLE_GAP_FAST_ADV:
  3744. /* fast adv is completed, fall back to slow adv interval */
  3745. btm_ble_start_slow_adv();
  3746. break;
  3747. default:
  3748. break;
  3749. }
  3750. }
  3751. /*******************************************************************************
  3752. **
  3753. ** Function btm_ble_read_remote_features_complete
  3754. **
  3755. ** Description This function is called when the command complete message
  3756. ** is received from the HCI for the read LE remote feature supported
  3757. ** complete event.
  3758. **
  3759. ** Returns void
  3760. **
  3761. *******************************************************************************/
  3762. void btm_ble_read_remote_features_complete(UINT8 *p)
  3763. {
  3764. tACL_CONN *p_acl_cb = NULL;
  3765. UINT16 handle;
  3766. UINT8 status;
  3767. BTM_TRACE_EVENT ("btm_ble_read_remote_features_complete ");
  3768. STREAM_TO_UINT8(status, p);
  3769. // if LE read remote feature failed for HCI_ERR_CONN_FAILED_ESTABLISHMENT,
  3770. // expect disconnect complete to be received
  3771. if (status != HCI_ERR_CONN_FAILED_ESTABLISHMENT) {
  3772. STREAM_TO_UINT16 (handle, p);
  3773. /* Look up the connection by handle and copy features */
  3774. p_acl_cb = btm_handle_to_acl(handle);
  3775. if (p_acl_cb) {
  3776. {
  3777. STREAM_TO_ARRAY(p_acl_cb->peer_le_features, p, BD_FEATURES_LEN);
  3778. #if BLE_INCLUDED == TRUE
  3779. /* In the original Bluedroid version, slave need to send LL_VERSION_IND(call btsnd_hcic_rmt_ver_req)
  3780. * to remote device if it has not received ll_version_ind.
  3781. * Delete it to resolve Android 7.0 incompatible problem. But it may cause that slave host
  3782. * can't get remote device's version.*/
  3783. if (p_acl_cb->link_role == HCI_ROLE_MASTER){
  3784. btsnd_hcic_rmt_ver_req (p_acl_cb->hci_handle);
  3785. }
  3786. else{
  3787. if (p_acl_cb->transport == BT_TRANSPORT_LE) {
  3788. if (HCI_LE_DATA_LEN_EXT_SUPPORTED(p_acl_cb->peer_le_features)) {
  3789. uint16_t data_length = controller_get_interface()->get_ble_default_data_packet_length();
  3790. uint16_t data_txtime = controller_get_interface()->get_ble_default_data_packet_txtime();
  3791. p_acl_cb->data_len_updating = true;
  3792. btsnd_hcic_ble_set_data_length(p_acl_cb->hci_handle, data_length, data_txtime);
  3793. }
  3794. l2cble_notify_le_connection (p_acl_cb->remote_addr);
  3795. }
  3796. }
  3797. #endif
  3798. }
  3799. }
  3800. }
  3801. }
  3802. /*******************************************************************************
  3803. **
  3804. ** Function btm_ble_write_adv_enable_complete
  3805. **
  3806. ** Description This function process the write adv enable command complete.
  3807. **
  3808. ** Returns void
  3809. **
  3810. *******************************************************************************/
  3811. void btm_ble_write_adv_enable_complete(UINT8 *p)
  3812. {
  3813. /* if write adv enable/disbale not succeed */
  3814. if (*p != HCI_SUCCESS) {
  3815. BTM_TRACE_ERROR("%s failed", __func__);
  3816. }
  3817. }
  3818. /*******************************************************************************
  3819. **
  3820. ** Function btm_ble_dir_adv_tout
  3821. **
  3822. ** Description when directed adv time out
  3823. **
  3824. ** Returns void
  3825. **
  3826. *******************************************************************************/
  3827. void btm_ble_dir_adv_tout(void)
  3828. {
  3829. btm_cb.ble_ctr_cb.inq_var.adv_mode = BTM_BLE_ADV_DISABLE;
  3830. /* make device fall back into undirected adv mode by default */
  3831. btm_cb.ble_ctr_cb.inq_var.directed_conn = FALSE;
  3832. }
  3833. /*******************************************************************************
  3834. **
  3835. ** Function btm_ble_set_topology_mask
  3836. **
  3837. ** Description set BLE topology mask
  3838. **
  3839. ** Returns TRUE is request is allowed, FALSE otherwise.
  3840. **
  3841. *******************************************************************************/
  3842. BOOLEAN btm_ble_set_topology_mask(tBTM_BLE_STATE_MASK request_state_mask)
  3843. {
  3844. request_state_mask &= BTM_BLE_STATE_ALL_MASK;
  3845. btm_cb.ble_ctr_cb.cur_states |= (request_state_mask & BTM_BLE_STATE_ALL_MASK);
  3846. return TRUE;
  3847. }
  3848. /*******************************************************************************
  3849. **
  3850. ** Function btm_ble_clear_topology_mask
  3851. **
  3852. ** Description Clear BLE topology bit mask
  3853. **
  3854. ** Returns TRUE is request is allowed, FALSE otherwise.
  3855. **
  3856. *******************************************************************************/
  3857. BOOLEAN btm_ble_clear_topology_mask (tBTM_BLE_STATE_MASK request_state_mask)
  3858. {
  3859. request_state_mask &= BTM_BLE_STATE_ALL_MASK;
  3860. btm_cb.ble_ctr_cb.cur_states &= ~request_state_mask;
  3861. return TRUE;
  3862. }
  3863. /*******************************************************************************
  3864. **
  3865. ** Function btm_ble_get_topology_mask
  3866. **
  3867. ** Description Get BLE topology bit mask
  3868. **
  3869. ** Returns state mask.
  3870. **
  3871. *******************************************************************************/
  3872. tBTM_BLE_STATE_MASK btm_ble_get_topology_mask (void)
  3873. {
  3874. return btm_cb.ble_ctr_cb.cur_states;
  3875. }
  3876. /*******************************************************************************
  3877. **
  3878. ** Function btm_ble_update_link_topology_mask
  3879. **
  3880. ** Description This function update the link topology mask
  3881. **
  3882. ** Returns void
  3883. **
  3884. *******************************************************************************/
  3885. void btm_ble_update_link_topology_mask(UINT8 link_role, BOOLEAN increase)
  3886. {
  3887. btm_ble_clear_topology_mask (BTM_BLE_STATE_ALL_CONN_MASK);
  3888. if (increase) {
  3889. btm_cb.ble_ctr_cb.link_count[link_role]++;
  3890. } else if (btm_cb.ble_ctr_cb.link_count[link_role] > 0) {
  3891. btm_cb.ble_ctr_cb.link_count[link_role]--;
  3892. }
  3893. if (btm_cb.ble_ctr_cb.link_count[HCI_ROLE_MASTER]) {
  3894. btm_ble_set_topology_mask (BTM_BLE_STATE_MASTER_BIT);
  3895. }
  3896. if (btm_cb.ble_ctr_cb.link_count[HCI_ROLE_SLAVE]) {
  3897. btm_ble_set_topology_mask(BTM_BLE_STATE_SLAVE_BIT);
  3898. }
  3899. if (link_role == HCI_ROLE_SLAVE && increase) {
  3900. btm_cb.ble_ctr_cb.inq_var.adv_mode = BTM_BLE_ADV_DISABLE;
  3901. /* make device fall back into undirected adv mode by default */
  3902. btm_cb.ble_ctr_cb.inq_var.directed_conn = BTM_BLE_CONNECT_EVT;
  3903. /* clear all adv states */
  3904. btm_ble_clear_topology_mask(BTM_BLE_STATE_ALL_ADV_MASK);
  3905. }
  3906. }
  3907. /*******************************************************************************
  3908. **
  3909. ** Function btm_ble_update_mode_operation
  3910. **
  3911. ** Description This function update the GAP role operation when a link status
  3912. ** is updated.
  3913. **
  3914. ** Returns void
  3915. **
  3916. *******************************************************************************/
  3917. BOOLEAN btm_ble_update_mode_operation(UINT8 link_role, BD_ADDR bd_addr, UINT8 status)
  3918. {
  3919. BOOLEAN bg_con = FALSE;
  3920. if (status == HCI_ERR_DIRECTED_ADVERTISING_TIMEOUT) {
  3921. btm_cb.ble_ctr_cb.inq_var.adv_mode = BTM_BLE_ADV_DISABLE;
  3922. /* make device fall back into undirected adv mode by default */
  3923. btm_cb.ble_ctr_cb.inq_var.directed_conn = BTM_BLE_CONNECT_EVT;
  3924. /* clear all adv states */
  3925. btm_ble_clear_topology_mask (BTM_BLE_STATE_ALL_ADV_MASK);
  3926. }
  3927. if (btm_cb.ble_ctr_cb.inq_var.connectable_mode == BTM_BLE_CONNECTABLE) {
  3928. btm_ble_set_connectability(btm_cb.btm_inq_vars.connectable_mode |
  3929. btm_cb.ble_ctr_cb.inq_var.connectable_mode);
  3930. }
  3931. /* when no connection is attempted, and controller is not rejecting last request
  3932. due to resource limitation, start next direct connection or background connection
  3933. now in order */
  3934. if (btm_ble_get_conn_st() == BLE_CONN_IDLE && status != HCI_ERR_HOST_REJECT_RESOURCES &&
  3935. !btm_send_pending_direct_conn()) {
  3936. bg_con = btm_ble_resume_bg_conn();
  3937. }
  3938. return bg_con;
  3939. }
  3940. /*******************************************************************************
  3941. **
  3942. ** Function btm_ble_init
  3943. **
  3944. ** Description Initialize the control block variable values.
  3945. **
  3946. ** Returns void
  3947. **
  3948. *******************************************************************************/
  3949. void btm_ble_init (void)
  3950. {
  3951. BTM_TRACE_DEBUG("%s", __func__);
  3952. #if BTM_DYNAMIC_MEMORY == TRUE
  3953. cmn_ble_gap_vsc_cb_ptr = (tBTM_BLE_VSC_CB *)osi_malloc(sizeof(tBTM_BLE_VSC_CB));
  3954. if (cmn_ble_gap_vsc_cb_ptr == NULL) {
  3955. BTM_TRACE_ERROR("%s malloc failed", __func__);
  3956. return;
  3957. }
  3958. #endif
  3959. tBTM_BLE_CB *p_cb = &btm_cb.ble_ctr_cb;
  3960. btu_free_timer(&p_cb->obs_timer_ent);
  3961. btu_free_timer(&p_cb->scan_timer_ent);
  3962. btu_free_timer(&p_cb->inq_var.fast_adv_timer);
  3963. memset(p_cb, 0, sizeof(tBTM_BLE_CB));
  3964. memset(&(btm_cb.cmn_ble_vsc_cb), 0 , sizeof(tBTM_BLE_VSC_CB));
  3965. btm_cb.cmn_ble_vsc_cb.values_read = FALSE;
  3966. p_cb->cur_states = 0;
  3967. p_cb->conn_pending_q = fixed_queue_new(QUEUE_SIZE_MAX);
  3968. p_cb->inq_var.adv_mode = BTM_BLE_ADV_DISABLE;
  3969. p_cb->inq_var.scan_type = BTM_BLE_SCAN_MODE_NONE;
  3970. p_cb->inq_var.adv_chnl_map = BTM_BLE_DEFAULT_ADV_CHNL_MAP;
  3971. p_cb->inq_var.afp = BTM_BLE_DEFAULT_AFP;
  3972. p_cb->inq_var.sfp = BTM_BLE_DEFAULT_SFP;
  3973. p_cb->inq_var.connectable_mode = BTM_BLE_NON_CONNECTABLE;
  3974. p_cb->inq_var.discoverable_mode = BTM_BLE_NON_DISCOVERABLE;
  3975. /* for background connection, reset connection params to be undefined */
  3976. p_cb->scan_int = p_cb->scan_win = BTM_BLE_SCAN_PARAM_UNDEF;
  3977. p_cb->inq_var.evt_type = BTM_BLE_NON_CONNECT_EVT;
  3978. p_cb->adv_rpt_queue = pkt_queue_create();
  3979. assert(p_cb->adv_rpt_queue != NULL);
  3980. p_cb->adv_rpt_ready = osi_event_create(btm_adv_pkt_handler, NULL);
  3981. assert(p_cb->adv_rpt_ready != NULL);
  3982. osi_event_bind(p_cb->adv_rpt_ready, btu_get_current_thread(), 0);
  3983. #if BLE_VND_INCLUDED == FALSE
  3984. btm_ble_adv_filter_init();
  3985. #endif
  3986. }
  3987. /*******************************************************************************
  3988. **
  3989. ** Function btm_ble_free
  3990. **
  3991. ** Description free the control block variable values.
  3992. **
  3993. ** Returns void
  3994. **
  3995. *******************************************************************************/
  3996. void btm_ble_free (void)
  3997. {
  3998. tBTM_BLE_CB *p_cb = &btm_cb.ble_ctr_cb;
  3999. BTM_TRACE_DEBUG("%s", __func__);
  4000. fixed_queue_free(p_cb->conn_pending_q, osi_free_func);
  4001. pkt_queue_destroy(p_cb->adv_rpt_queue, NULL);
  4002. p_cb->adv_rpt_queue = NULL;
  4003. osi_event_delete(p_cb->adv_rpt_ready);
  4004. p_cb->adv_rpt_ready = NULL;
  4005. #if BTM_DYNAMIC_MEMORY == TRUE
  4006. osi_free(cmn_ble_gap_vsc_cb_ptr);
  4007. cmn_ble_gap_vsc_cb_ptr = NULL;
  4008. #endif
  4009. }
  4010. /*******************************************************************************
  4011. **
  4012. ** Function btm_ble_topology_check
  4013. **
  4014. ** Description check to see requested state is supported. One state check at
  4015. ** a time is supported
  4016. **
  4017. ** Returns TRUE is request is allowed, FALSE otherwise.
  4018. **
  4019. *******************************************************************************/
  4020. BOOLEAN btm_ble_topology_check(tBTM_BLE_STATE_MASK request_state_mask)
  4021. {
  4022. BOOLEAN rt = FALSE;
  4023. UINT8 state_offset = 0;
  4024. UINT16 cur_states = btm_cb.ble_ctr_cb.cur_states;
  4025. UINT8 mask, offset;
  4026. UINT8 request_state = 0;
  4027. /* check only one bit is set and within valid range */
  4028. if (request_state_mask == BTM_BLE_STATE_INVALID ||
  4029. request_state_mask > BTM_BLE_STATE_SCAN_ADV_BIT ||
  4030. (request_state_mask & (request_state_mask - 1 )) != 0) {
  4031. BTM_TRACE_ERROR("illegal state requested: %d", request_state_mask);
  4032. return rt;
  4033. }
  4034. while (request_state_mask) {
  4035. request_state_mask >>= 1;
  4036. request_state ++;
  4037. }
  4038. /* check if the requested state is supported or not */
  4039. mask = btm_le_state_combo_tbl[0][request_state - 1][0];
  4040. offset = btm_le_state_combo_tbl[0][request_state - 1][1];
  4041. const uint8_t *ble_supported_states = controller_get_interface()->get_ble_supported_states();
  4042. if (!BTM_LE_STATES_SUPPORTED(ble_supported_states, mask, offset)) {
  4043. BTM_TRACE_ERROR("state requested not supported: %d", request_state);
  4044. return rt;
  4045. }
  4046. rt = TRUE;
  4047. /* make sure currently active states are all supported in conjunction with the requested
  4048. state. If the bit in table is not set, the combination is not supported */
  4049. while (cur_states != 0) {
  4050. if (cur_states & 0x01) {
  4051. mask = btm_le_state_combo_tbl[request_state][state_offset][0];
  4052. offset = btm_le_state_combo_tbl[request_state][state_offset][1];
  4053. if (mask != 0 && offset != 0) {
  4054. if (!BTM_LE_STATES_SUPPORTED(ble_supported_states, mask, offset)) {
  4055. rt = FALSE;
  4056. break;
  4057. }
  4058. }
  4059. }
  4060. cur_states >>= 1;
  4061. state_offset ++;
  4062. }
  4063. return rt;
  4064. }
  4065. /*******************************************************************************
  4066. **
  4067. ** Function BTM_Ble_Authorization
  4068. **
  4069. ** Description This function is used to authorize a specified device
  4070. **
  4071. ** Returns TRUE or FALSE
  4072. **
  4073. *******************************************************************************/
  4074. BOOLEAN BTM_Ble_Authorization(BD_ADDR bd_addr, BOOLEAN authorize)
  4075. {
  4076. if (bd_addr == NULL) {
  4077. BTM_TRACE_ERROR("bd_addr is NULL");
  4078. return FALSE;
  4079. }
  4080. if (btm_sec_dev_authorization(bd_addr, authorize)) {
  4081. return TRUE;
  4082. }
  4083. BTM_TRACE_ERROR("Authorization fail");
  4084. return FALSE;
  4085. }
  4086. bool btm_ble_adv_pkt_ready(void)
  4087. {
  4088. tBTM_BLE_CB *p_cb = &btm_cb.ble_ctr_cb;
  4089. osi_thread_post_event(p_cb->adv_rpt_ready, OSI_THREAD_MAX_TIMEOUT);
  4090. return true;
  4091. }
  4092. bool btm_ble_adv_pkt_post(pkt_linked_item_t *pkt)
  4093. {
  4094. if (pkt == NULL) {
  4095. return false;
  4096. }
  4097. tBTM_BLE_CB *p_cb = &btm_cb.ble_ctr_cb;
  4098. pkt_queue_enqueue(p_cb->adv_rpt_queue, pkt);
  4099. return true;
  4100. }
  4101. #endif /* BLE_INCLUDED */