| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441 |
- /*
- ** Id: //Department/DaVinci/BRANCHES/MT6620_WIFI_DRIVER_V2_3/common/wlan_bow.c#1
- */
- /*! \file wlan_bow.c
- \brief This file contains the 802.11 PAL commands processing routines for
- MediaTek Inc. 802.11 Wireless LAN Adapters.
- */
- /*
- ** Log: wlan_bow.c
- *
- * 03 02 2012 terry.wu
- * NULL
- * Sync CFG80211 modification from branch 2,2.
- *
- * 01 16 2012 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Support BOW for 5GHz band.
- *
- * 01 09 2012 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * [ALPS00110632] [Rose][LCA42][Cross Feature][Bluetooth]The "KE" pops up after the device reboots automatically.(once)
- *
- * Fix bow link disconnected event dereference.
- *
- * 09 29 2011 cm.chang
- * NULL
- * Change the function prototype of rlmDomainGetChnlList()
- *
- * 07 06 2011 terry.wu
- * [WCXRP00000735] [MT6620 Wi-Fi][BoW][FW/Driver] Protect BoW connection establishment
- * Improve BoW connection establishment speed.
- *
- * 06 23 2011 cp.wu
- * [WCXRP00000798] [MT6620 Wi-Fi][Firmware] Follow-ups for WAPI frequency offset workaround in firmware SCN module
- * change parameter name from PeerAddr to BSSID
- *
- * 06 21 2011 terry.wu
- * NULL
- * Fix BoW KE.
- *
- * 06 20 2011 terry.wu
- * NULL
- * Add BoW Rate Limitation.
- *
- * 06 20 2011 cp.wu
- * [WCXRP00000798] [MT6620 Wi-Fi][Firmware] Follow-ups for WAPI frequency offset workaround in firmware SCN module
- * 1. specify target's BSSID when requesting channel privilege.
- * 2. pass BSSID information to firmware domain
- *
- * 06 17 2011 terry.wu
- * NULL
- * Add BoW 11N support.
- *
- * 06 07 2011 cp.wu
- * [WCXRP00000681] [MT5931][Firmware] HIF code size reduction
- * aware more compile options.
- *
- * 05 25 2011 terry.wu
- * [WCXRP00000735] [MT6620 Wi-Fi][BoW][FW/Driver] Protect BoW connection establishment
- * Add BoW Cancel Scan Request and Turn On deactive network function.
- *
- * 05 23 2011 terry.wu
- * [WCXRP00000735] [MT6620 Wi-Fi][BoW][FW/Driver] Protect BoW connection establishment
- * Add some BoW error handling.
- *
- * 05 22 2011 terry.wu
- * [WCXRP00000735] [MT6620 Wi-Fi][BoW][FW/Driver] Protect BoW connection establishment
- * .
- *
- * 05 22 2011 terry.wu
- * [WCXRP00000735] [MT6620 Wi-Fi][BoW][FW/Driver] Protect BoW connection establishment
- * Only reply probe response to its peer or mached SSID for BoW AP.
- *
- * 05 22 2011 terry.wu
- * [WCXRP00000735] [MT6620 Wi-Fi][BoW][FW/Driver] Protect BoW connection establishment
- * Add BoW SAA retry and disable disconnect event when AAA fail .
- *
- * 05 21 2011 terry.wu
- * [WCXRP00000735] [MT6620 Wi-Fi][BoW][FW/Driver] Protect BoW connection establishment
- * Protect BoW connection establishment.
- *
- * 05 17 2011 terry.wu
- * [WCXRP00000730] [MT6620 Wi-Fi][BoW] Send deauth while disconnecting
- * Send deauth while disconnecting BoW link.
- *
- * 05 17 2011 terry.wu
- * [WCXRP00000707] [MT6620 Wi-Fi][Driver] Fix BoW Multiple Physical Link connect/disconnect issue
- * Fix wrong StaRec state of BoW .
- *
- * 05 06 2011 terry.wu
- * [WCXRP00000707] [MT6620 Wi-Fi][Driver] Fix BoW Multiple Physical Link connect/disconnect issue
- * Fix BoW Multiple Physical Link connect/disconnect issue.
- *
- * 05 03 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Use kalMemAlloc to allocate event buffer for kalIndicateBOWEvent.
- *
- * 04 15 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Fix prAssocRspSwRfb casting.
- *
- * 04 15 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Add BOW short range mode.
- *
- * 04 12 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Add WMM IE for BOW initiator data.
- *
- * 04 10 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Change Link disconnection event procedure for hotspot and change skb length check to 1514 bytes.
- *
- * 04 09 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Change Link connection event procedure and change skb length check to 1512 bytes.
- *
- * 03 28 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Simplify link disconnected routine, remove link disconnected other routine.
- *
- * 03 27 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Support multiple physical link.
- *
- * 03 27 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Add new feature - multiple physical link support.
- *
- * 02 22 2011 wh.su
- * [WCXRP00000486] [MT6620 Wi-Fi][BOW] Fixed the bow send frame but not encrypted issue
- * fixed the BOW packet sending without encrypted issue.
- *
- * 02 21 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Fix BOW link disconnection bug.
- *
- * 02 16 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Add bowNotifyAllLinkDisconnected interface and change channel grant procedure for bow starting.
- *
- * 02 11 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Update BOW channel granted function.
- *
- * 02 10 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Fix kernel API change issue.
- * Before ALPS 2.2 (2.2 included), kfifo_alloc() is
- * struct kfifo *kfifo_alloc(unsigned int size, gfp_t gfp_mask, spinlock_t *lock);
- * After ALPS 2.3, kfifo_alloc() is changed to
- * int kfifo_alloc(struct kfifo *fifo, unsigned int size, gfp_t gfp_mask);
- *
- * 02 09 2011 cp.wu
- * [WCXRP00000430] [MT6620 Wi-Fi][Firmware][Driver] Create V1.2 branch for MT6620E1 and MT6620E3
- * create V1.2 driver branch based on label MT6620_WIFI_DRIVER_V1_2_110209_1031
- * with BOW and P2P enabled as default
- *
- * 02 08 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Replace kfifo_get and kfifo_put with kfifo_out and kfifo_in.
- * Update BOW get MAC status, remove returning event for AIS network type.
- *
- * 01 26 2011 cm.chang
- * [WCXRP00000395] [MT6620 Wi-Fi][Driver][FW] Search STA_REC with additional net type index argument
- * .
- *
- * 01 11 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Update BOW Activity Report structure and bug fix.
- *
- * 01 10 2011 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Update BOW to support multiple physical link.
- *
- * 12 08 2010 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Support concurrent networks.
- *
- * 12 07 2010 cm.chang
- * [WCXRP00000239] MT6620 Wi-Fi][Driver][FW] Merge concurrent branch back to maintrunk
- * 1. BSSINFO include RLM parameter
- * 2. free all sta records when network is disconnected
- *
- * 11 11 2010 chinghwa.yu
- * [WCXRP00000065] Update BoW design and settings
- * Fix BoW timer assert issue.
- *
- * 10 18 2010 chinghwa.yu
- * [WCXRP00000110] [MT6620 Wi-Fi] [Driver] Fix BoW Connected event size
- * Fix for event returnning Band.
- *
- * 10 18 2010 chinghwa.yu
- * [WCXRP00000110] [MT6620 Wi-Fi] [Driver] Fix BoW Connected event size
- * Fix wrong BoW event size.
- *
- * 10 04 2010 cp.wu
- * [WCXRP00000077] [MT6620 Wi-Fi][Driver][FW] Eliminate use of ENUM_NETWORK_TYPE_T and replaced
- * by ENUM_NETWORK_TYPE_INDEX_T only remove ENUM_NETWORK_TYPE_T definitions
- *
- * 09 27 2010 chinghwa.yu
- * [WCXRP00000063] Update BCM CoEx design and settings[WCXRP00000065] Update BoW design and settings
- * Update BCM/BoW design and settings.
- *
- * 09 16 2010 chinghwa.yu
- * NULL
- * Fix bowResponderScanDone error when prBssDesc is NULL.
- *
- * 09 14 2010 chinghwa.yu
- * NULL
- * Add bowRunEventAAAComplete.
- *
- * 09 14 2010 cp.wu
- * NULL
- * indicate correct AIS network information for PAL.
- *
- * 09 03 2010 kevin.huang
- * NULL
- * Refine #include sequence and solve recursive/nested #include issue
- *
- * 08 24 2010 cm.chang
- * NULL
- * Support RLM initail channel of Ad-hoc, P2P and BOW
- *
- * 08 24 2010 chinghwa.yu
- * NULL
- * Initialize nicActivateNetwork(prAdapter as soon as bow is starting..
- *
- * 08 24 2010 chinghwa.yu
- * NULL
- * Update BOW for the 1st time.
- *
- * 08 23 2010 cp.wu
- * NULL
- * revise constant definitions to be matched with implementation (original cmd-event definition is deprecated)
- *
- * 07 30 2010 cp.wu
- * NULL
- * 1) BoW wrapper: use definitions instead of hard-coded constant for error code
- * 2) AIS-FSM: eliminate use of desired RF parameters, use prTargetBssDesc instead
- * 3) add handling for RX_PKT_DESTINATION_HOST_WITH_FORWARD for GO-broadcast frames
- *
- * 07 15 2010 cp.wu
- *
- * sync. bluetooth-over-Wi-Fi interface to driver interface document v0.2.6.
- *
- * 07 08 2010 cp.wu
- *
- * [WPD00003833] [MT6620 and MT5931] Driver migration - move to new repository.
- *
- * 06 25 2010 cp.wu
- * [WPD00003833][MT6620 and MT5931] Driver migration
- * add API in que_mgt to retrieve sta-rec index for security frames.
- *
- * 06 24 2010 cp.wu
- * [WPD00003833][MT6620 and MT5931] Driver migration
- * 802.1x and bluetooth-over-Wi-Fi security frames are now delievered to firmware via command path instead of data path.
- *
- * 06 11 2010 cp.wu
- * [WPD00003833][MT6620 and MT5931] Driver migration
- * 1) migrate assoc.c.
- * 2) add ucTxSeqNum for tracking frames which needs TX-DONE awareness
- * 3) add configuration options for CNM_MEM and RSN modules
- * 4) add data path for management frames
- * 5) eliminate rPacketInfo of MSDU_INFO_T
- *
- * 06 06 2010 kevin.huang
- * [WPD00003832][MT6620 5931] Create driver base
- * [MT6620 5931] Create driver base
- *
- * 05 17 2010 cp.wu
- * [WPD00003831][MT6620 Wi-Fi] Add framework for Wi-Fi Direct support
- * 1) add timeout handler mechanism for pending command packets
- * 2) add p2p add/removal key
- *
- * 05 13 2010 cp.wu
- * [WPD00001943]Create WiFi test driver framework on WinXP
- * add NULL OID implementation for WOL-related OIDs.
- *
- * 05 13 2010 cp.wu
- * [WPD00003823][MT6620 Wi-Fi] Add Bluetooth-over-Wi-Fi support
- * 1) all BT physical handles shares the same RSSI/Link Quality.
- * 2) simplify BT command composing
- *
- * 04 28 2010 cp.wu
- * [WPD00003823][MT6620 Wi-Fi] Add Bluetooth-over-Wi-Fi support
- * change prefix for data structure used to communicate with 802.11 PAL
- * to avoid ambiguous naming with firmware interface
- *
- * 04 27 2010 cp.wu
- * [WPD00003823][MT6620 Wi-Fi] Add Bluetooth-over-Wi-Fi support
- * add multiple physical link support
- *
- * 04 14 2010 cp.wu
- * [WPD00001943]Create WiFi test driver framework on WinXP
- * information buffer for query oid/ioctl is now buffered in prCmdInfo
- * instead of glue-layer variable to improve multiple oid/ioctl capability
- *
- * 04 13 2010 cp.wu
- * [WPD00003823][MT6620 Wi-Fi] Add Bluetooth-over-Wi-Fi support
- * add framework for BT-over-Wi-Fi support.
- * * 1) prPendingCmdInfo is replaced by queue for multiple handler capability
- * * 2) command sequence number is now increased atomically
- * * 3) private data could be hold and taken use for other purpose
- **
- */
- /******************************************************************************
- * C O M P I L E R F L A G S
- *******************************************************************************
- */
- /******************************************************************************
- * E X T E R N A L R E F E R E N C E S
- *******************************************************************************
- */
- #include "precomp.h"
- #if CFG_ENABLE_BT_OVER_WIFI
- /******************************************************************************
- * C O N S T A N T S
- *******************************************************************************
- */
- /******************************************************************************
- * D A T A T Y P E S
- *******************************************************************************
- */
- /******************************************************************************
- * P U B L I C D A T A
- *******************************************************************************
- */
- static UINT_32 g_u4LinkCount;
- static UINT_32 g_u4Beaconing;
- static BOW_TABLE_T arBowTable[CFG_BOW_PHYSICAL_LINK_NUM];
- /******************************************************************************
- * P R I V A T E D A T A
- *******************************************************************************
- */
- const BOW_CMD_T arBowCmdTable[] = {
- {BOW_CMD_ID_GET_MAC_STATUS, bowCmdGetMacStatus},
- {BOW_CMD_ID_SETUP_CONNECTION, bowCmdSetupConnection},
- {BOW_CMD_ID_DESTROY_CONNECTION, bowCmdDestroyConnection},
- {BOW_CMD_ID_SET_PTK, bowCmdSetPTK},
- {BOW_CMD_ID_READ_RSSI, bowCmdReadRSSI},
- {BOW_CMD_ID_READ_LINK_QUALITY, bowCmdReadLinkQuality},
- {BOW_CMD_ID_SHORT_RANGE_MODE, bowCmdShortRangeMode},
- {BOW_CMD_ID_GET_CHANNEL_LIST, bowCmdGetChannelList},
- };
- /******************************************************************************
- * M A C R O S
- *******************************************************************************
- */
- /******************************************************************************
- * F U N C T I O N D E C L A R A T I O N S
- *******************************************************************************
- */
- /******************************************************************************
- * F U N C T I O N S
- *******************************************************************************
- */
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief command packet generation utility
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] ucCID Command ID
- * \param[in] fgSetQuery Set or Query
- * \param[in] fgNeedResp Need for response
- * \param[in] pfCmdDoneHandler Function pointer when command is done
- * \param[in] u4SetQueryInfoLen The length of the set/query buffer
- * \param[in] pucInfoBuffer Pointer to set/query buffer
- *
- *
- * \retval WLAN_STATUS_PENDING
- * \retval WLAN_STATUS_FAILURE
- */
- /*----------------------------------------------------------------------------*/
- WLAN_STATUS
- wlanoidSendSetQueryBowCmd(IN P_ADAPTER_T prAdapter,
- IN UINT_8 ucCID,
- IN BOOLEAN fgSetQuery,
- IN BOOLEAN fgNeedResp,
- IN PFN_CMD_DONE_HANDLER pfCmdDoneHandler,
- IN PFN_CMD_TIMEOUT_HANDLER pfCmdTimeoutHandler,
- IN UINT_32 u4SetQueryInfoLen, IN PUINT_8 pucInfoBuffer, IN UINT_8 ucSeqNumber)
- {
- P_GLUE_INFO_T prGlueInfo;
- P_CMD_INFO_T prCmdInfo;
- P_WIFI_CMD_T prWifiCmd;
- UINT_8 ucCmdSeqNum;
- ASSERT(prAdapter);
- prGlueInfo = prAdapter->prGlueInfo;
- ASSERT(prGlueInfo);
- DBGLOG(REQ, TRACE, "Command ID = 0x%08X\n", ucCID);
- prCmdInfo = cmdBufAllocateCmdInfo(prAdapter, (CMD_HDR_SIZE + u4SetQueryInfoLen));
- if (!prCmdInfo) {
- DBGLOG(INIT, ERROR, "Allocate CMD_INFO_T ==> FAILED.\n");
- return WLAN_STATUS_FAILURE;
- }
- /* increase command sequence number */
- ucCmdSeqNum = nicIncreaseCmdSeqNum(prAdapter);
- DBGLOG(REQ, TRACE, "ucCmdSeqNum =%d\n", ucCmdSeqNum);
- /* Setup common CMD Info Packet */
- prCmdInfo->eCmdType = COMMAND_TYPE_NETWORK_IOCTL;
- prCmdInfo->eNetworkType = NETWORK_TYPE_BOW_INDEX;
- prCmdInfo->u2InfoBufLen = (UINT_16) (CMD_HDR_SIZE + u4SetQueryInfoLen);
- prCmdInfo->pfCmdDoneHandler = pfCmdDoneHandler;
- prCmdInfo->pfCmdTimeoutHandler = pfCmdTimeoutHandler;
- prCmdInfo->fgIsOid = FALSE;
- prCmdInfo->ucCID = ucCID;
- prCmdInfo->fgSetQuery = fgSetQuery;
- prCmdInfo->fgNeedResp = fgNeedResp;
- prCmdInfo->fgDriverDomainMCR = FALSE;
- prCmdInfo->ucCmdSeqNum = ucCmdSeqNum;
- prCmdInfo->u4SetInfoLen = u4SetQueryInfoLen;
- prCmdInfo->pvInformationBuffer = NULL;
- prCmdInfo->u4InformationBufferLength = 0;
- prCmdInfo->u4PrivateData = (UINT_32) ucSeqNumber;
- /* Setup WIFI_CMD_T (no payload) */
- prWifiCmd = (P_WIFI_CMD_T) (prCmdInfo->pucInfoBuffer);
- prWifiCmd->u2TxByteCount_UserPriority = prCmdInfo->u2InfoBufLen;
- prWifiCmd->ucCID = prCmdInfo->ucCID;
- prWifiCmd->ucSetQuery = prCmdInfo->fgSetQuery;
- prWifiCmd->ucSeqNum = prCmdInfo->ucCmdSeqNum;
- if (u4SetQueryInfoLen > 0 && pucInfoBuffer != NULL)
- kalMemCopy(prWifiCmd->aucBuffer, pucInfoBuffer, u4SetQueryInfoLen);
- /* insert into prCmdQueue */
- kalEnqueueCommand(prGlueInfo, (P_QUE_ENTRY_T) prCmdInfo);
- /* wakeup txServiceThread later */
- GLUE_SET_EVENT(prGlueInfo);
- return WLAN_STATUS_PENDING;
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This routine is called to dispatch command coming from 802.11 PAL
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmd Pointer to the buffer that holds the command
- *
- * \retval WLAN_STATUS_SUCCESS
- * \retval WLAN_STATUS_INVALID_LENGTH
- */
- /*----------------------------------------------------------------------------*/
- WLAN_STATUS wlanbowHandleCommand(IN P_ADAPTER_T prAdapter, IN P_AMPC_COMMAND prCmd)
- {
- WLAN_STATUS retval = WLAN_STATUS_FAILURE;
- UINT_16 i;
- ASSERT(prAdapter);
- for (i = 0; i < sizeof(arBowCmdTable) / sizeof(BOW_CMD_T); i++) {
- if ((arBowCmdTable[i].uCmdID == prCmd->rHeader.ucCommandId) && arBowCmdTable[i].pfCmdHandle) {
- retval = arBowCmdTable[i].pfCmdHandle(prAdapter, prCmd);
- break;
- }
- }
- return retval;
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This is command handler for BOW_CMD_ID_GET_MAC_STATUS
- * coming from 802.11 PAL
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmd Pointer to the buffer that holds the command
- *
- * \retval WLAN_STATUS_SUCCESS
- * \retval WLAN_STATUS_INVALID_LENGTH
- */
- /*----------------------------------------------------------------------------*/
- WLAN_STATUS bowCmdGetMacStatus(IN P_ADAPTER_T prAdapter, IN P_AMPC_COMMAND prCmd)
- {
- P_AMPC_EVENT prEvent;
- P_BOW_MAC_STATUS prMacStatus;
- UINT_8 idx = 0;
- UINT_8 ucPrimaryChannel;
- ENUM_BAND_T eBand;
- ENUM_CHNL_EXT_T eBssSCO;
- UINT_8 ucNumOfChannel = 0; /* MAX_BOW_NUMBER_OF_CHANNEL; */
- RF_CHANNEL_INFO_T aucChannelList[MAX_BOW_NUMBER_OF_CHANNEL];
- ASSERT(prAdapter);
- /* 3 <1> If LinkCount != 0 -> OK (optional) */
- eBand = BAND_2G4;
- eBssSCO = CHNL_EXT_SCN;
- /* fill event header */
- prEvent = (P_AMPC_EVENT) kalMemAlloc((sizeof(AMPC_EVENT) + sizeof(BOW_MAC_STATUS)), VIR_MEM_TYPE);
- if (!prEvent) {
- ASSERT(FALSE);
- return WLAN_STATUS_FAILURE;
- }
- prEvent->rHeader.ucEventId = BOW_EVENT_ID_MAC_STATUS;
- prEvent->rHeader.ucSeqNumber = prCmd->rHeader.ucSeqNumber;
- prEvent->rHeader.u2PayloadLength = sizeof(BOW_MAC_STATUS);
- /* fill event body */
- prMacStatus = (P_BOW_MAC_STATUS) (prEvent->aucPayload);
- kalMemZero(prMacStatus, sizeof(BOW_MAC_STATUS));
- /* 3 <2> Call CNM to decide if BOW available. */
- if (cnmBowIsPermitted(prAdapter))
- prMacStatus->ucAvailability = TRUE;
- else
- prMacStatus->ucAvailability = FALSE;
- memcpy(prMacStatus->aucMacAddr, prAdapter->rWifiVar.aucDeviceAddress, PARAM_MAC_ADDR_LEN);
- if (cnmPreferredChannel(prAdapter, &eBand, &ucPrimaryChannel, &eBssSCO)) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, TRACE, "bowCmdGetMacStatus, Get preferred channel.\n");
- #endif
- prMacStatus->ucNumOfChannel = 1;
- prMacStatus->arChannelList[0].ucChannelBand = eBand;
- prMacStatus->arChannelList[0].ucChannelNum = ucPrimaryChannel;
- } else {
- #if CFG_BOW_TEST
- DBGLOG(BOW, TRACE,
- "bowCmdGetMacStatus, Get channel list. Current number of channel, %d.\n", ucNumOfChannel);
- #endif
- rlmDomainGetChnlList(prAdapter, BAND_2G4, MAX_BOW_NUMBER_OF_CHANNEL_2G4, &ucNumOfChannel,
- aucChannelList);
- if (ucNumOfChannel > 0) {
- for (idx = 0; idx < ucNumOfChannel /*MAX_BOW_NUMBER_OF_CHANNEL_2G4 */; idx++) {
- prMacStatus->arChannelList[idx].ucChannelBand = aucChannelList[idx].eBand;
- prMacStatus->arChannelList[idx].ucChannelNum = aucChannelList[idx].ucChannelNum;
- }
- prMacStatus->ucNumOfChannel = ucNumOfChannel;
- }
- rlmDomainGetChnlList(prAdapter, BAND_5G, MAX_BOW_NUMBER_OF_CHANNEL_5G, &ucNumOfChannel, aucChannelList);
- if (ucNumOfChannel > 0) {
- for (idx = 0; idx < ucNumOfChannel /*MAX_BOW_NUMBER_OF_CHANNEL_5G */; idx++) {
- prMacStatus->arChannelList[prMacStatus->ucNumOfChannel + idx].ucChannelBand =
- aucChannelList[idx].eBand;
- prMacStatus->arChannelList[prMacStatus->ucNumOfChannel + idx].ucChannelNum =
- aucChannelList[idx].ucChannelNum;
- }
- prMacStatus->ucNumOfChannel = prMacStatus->ucNumOfChannel + ucNumOfChannel;
- }
- }
- #if CFG_BOW_TEST
- DBGLOG(BOW, TRACE,
- "ucNumOfChannel,eBand,aucChannelList,%x,%x,%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x.\n",
- ucNumOfChannel, aucChannelList[0].eBand, aucChannelList[0].ucChannelNum, aucChannelList[1].ucChannelNum,
- aucChannelList[2].ucChannelNum, aucChannelList[3].ucChannelNum, aucChannelList[4].ucChannelNum,
- aucChannelList[5].ucChannelNum, aucChannelList[6].ucChannelNum, aucChannelList[7].ucChannelNum,
- aucChannelList[8].ucChannelNum, aucChannelList[9].ucChannelNum, aucChannelList[10].ucChannelNum,
- aucChannelList[11].ucChannelNum, aucChannelList[12].ucChannelNum, aucChannelList[13].ucChannelNum,
- aucChannelList[14].ucChannelNum, aucChannelList[15].ucChannelNum, aucChannelList[16].ucChannelNum,
- aucChannelList[17].ucChannelNum));
- DBGLOG(BOW, TRACE,
- "prMacStatus->ucNumOfChannel, eBand, %x, %x.\n",
- prMacStatus->ucNumOfChannel, prMacStatus->arChannelList[0].ucChannelBand);
- DBGLOG(BOW, TRACE,
- "prMacStatus->arChannelList, %x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x.\n",
- prMacStatus->arChannelList[0].ucChannelNum, prMacStatus->arChannelList[1].ucChannelNum,
- prMacStatus->arChannelList[2].ucChannelNum, prMacStatus->arChannelList[3].ucChannelNum,
- prMacStatus->arChannelList[4].ucChannelNum, prMacStatus->arChannelList[5].ucChannelNum,
- prMacStatus->arChannelList[6].ucChannelNum, prMacStatus->arChannelList[7].ucChannelNum,
- prMacStatus->arChannelList[8].ucChannelNum, prMacStatus->arChannelList[9].ucChannelNum,
- prMacStatus->arChannelList[10].ucChannelNum, prMacStatus->arChannelList[11].ucChannelNum,
- prMacStatus->arChannelList[12].ucChannelNum, prMacStatus->arChannelList[13].ucChannelNum,
- prMacStatus->arChannelList[14].ucChannelNum, prMacStatus->arChannelList[15].ucChannelNum,
- prMacStatus->arChannelList[16].ucChannelNum, prMacStatus->arChannelList[17].ucChannelNum));
- DBGLOG(BOW, TRACE, "prMacStatus->ucNumOfChannel, %x.\n", prMacStatus->ucNumOfChannel);
- DBGLOG(BOW, TRACE,
- "prMacStatus->arChannelList[0].ucChannelBand, %x.\n", prMacStatus->arChannelList[0].ucChannelBand);
- DBGLOG(BOW, TRACE,
- "prMacStatus->arChannelList[0].ucChannelNum, %x.\n", prMacStatus->arChannelList[0].ucChannelNum);
- DBGLOG(BOW, TRACE, "prMacStatus->ucAvailability, %x.\n", prMacStatus->ucAvailability);
- DBGLOG(BOW, TRACE, "prMacStatus->aucMacAddr, %x:%x:%x:%x:%x:%x.\n",
- prMacStatus->aucMacAddr[0],
- prMacStatus->aucMacAddr[1],
- prMacStatus->aucMacAddr[2],
- prMacStatus->aucMacAddr[3], prMacStatus->aucMacAddr[4], prMacStatus->aucMacAddr[5]));
- #endif
- kalIndicateBOWEvent(prAdapter->prGlueInfo, prEvent);
- kalMemFree(prEvent, VIR_MEM_TYPE, (sizeof(AMPC_EVENT) + sizeof(BOW_MAC_STATUS)));
- return WLAN_STATUS_SUCCESS;
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This is command handler for BOW_CMD_ID_SETUP_CONNECTION
- * coming from 802.11 PAL
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmd Pointer to the buffer that holds the command
- *
- * \retval WLAN_STATUS_SUCCESS
- * \retval WLAN_STATUS_INVALID_LENGTH
- */
- /*----------------------------------------------------------------------------*/
- WLAN_STATUS bowCmdSetupConnection(IN P_ADAPTER_T prAdapter, IN P_AMPC_COMMAND prCmd)
- {
- P_BOW_SETUP_CONNECTION prBowSetupConnection;
- CMD_BT_OVER_WIFI rCmdBtOverWifi;
- P_BOW_FSM_INFO_T prBowFsmInfo;
- BOW_TABLE_T rBowTable;
- UINT_8 ucBowTableIdx = 0;
- ASSERT(prAdapter);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- prBowSetupConnection = (P_BOW_SETUP_CONNECTION) &(prCmd->aucPayload[0]);
- /* parameter size check */
- if (prCmd->rHeader.u2PayloadLength != sizeof(BOW_SETUP_CONNECTION)) {
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_INVALID);
- return WLAN_STATUS_INVALID_LENGTH;
- }
- /* 3 <1> If ucLinkCount >= 4 -> Fail. */
- if (g_u4LinkCount >= CFG_BOW_PHYSICAL_LINK_NUM) {
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_UNACCEPTED);
- return WLAN_STATUS_NOT_ACCEPTED;
- }
- /* 3 <2> Call CNM, check if BOW is available. */
- if (!cnmBowIsPermitted(prAdapter)) {
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_UNACCEPTED);
- return WLAN_STATUS_NOT_ACCEPTED;
- }
- /* 3 <3> Lookup BOW Table, if Peer MAC address exist and valid -> Fail. */
- if (bowCheckBowTableIfVaild(prAdapter, prBowSetupConnection->aucPeerAddress)) {
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_UNACCEPTED);
- return WLAN_STATUS_NOT_ACCEPTED;
- }
- if (EQUAL_MAC_ADDR(prBowSetupConnection->aucPeerAddress, prAdapter->rWifiVar.aucDeviceAddress)) {
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_INVALID);
- return WLAN_STATUS_NOT_ACCEPTED;
- }
- /* fill CMD_BT_OVER_WIFI */
- rCmdBtOverWifi.ucAction = BOW_SETUP_CMD;
- rCmdBtOverWifi.ucChannelNum = prBowSetupConnection->ucChannelNum;
- COPY_MAC_ADDR(rCmdBtOverWifi.rPeerAddr, prBowSetupConnection->aucPeerAddress);
- rCmdBtOverWifi.u2BeaconInterval = prBowSetupConnection->u2BeaconInterval;
- rCmdBtOverWifi.ucTimeoutDiscovery = prBowSetupConnection->ucTimeoutDiscovery;
- rCmdBtOverWifi.ucTimeoutInactivity = prBowSetupConnection->ucTimeoutInactivity;
- rCmdBtOverWifi.ucRole = prBowSetupConnection->ucRole;
- rCmdBtOverWifi.PAL_Capabilities = prBowSetupConnection->ucPAL_Capabilities;
- rCmdBtOverWifi.cMaxTxPower = prBowSetupConnection->cMaxTxPower;
- if (prBowSetupConnection->ucChannelNum > 14)
- rCmdBtOverWifi.ucChannelBand = BAND_5G;
- else
- rCmdBtOverWifi.ucChannelBand = BAND_2G4;
- COPY_MAC_ADDR(prBowFsmInfo->aucPeerAddress, prBowSetupConnection->aucPeerAddress);
- #if CFG_BOW_PHYSICAL_LINK_NUM > 1
- /*Channel check for supporting multiple physical link */
- if (g_u4LinkCount > 0) {
- if (prBowSetupConnection->ucChannelNum != prBowFsmInfo->ucPrimaryChannel) {
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_UNACCEPTED);
- return WLAN_STATUS_NOT_ACCEPTED;
- }
- }
- #endif
- prBowFsmInfo->ucPrimaryChannel = prBowSetupConnection->ucChannelNum;
- prBowFsmInfo->eBand = rCmdBtOverWifi.ucChannelBand;
- prBowFsmInfo->u2BeaconInterval = prBowSetupConnection->u2BeaconInterval;
- prBowFsmInfo->ucRole = prBowSetupConnection->ucRole;
- if (prBowSetupConnection->ucPAL_Capabilities > 0)
- prBowFsmInfo->fgSupportQoS = TRUE;
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowCmdSetupConnection.\n");
- DBGLOG(BOW, EVENT, "rCmdBtOverWifi Channel Number - 0x%x.\n", rCmdBtOverWifi.ucChannelNum);
- DBGLOG(BOW, EVENT, "rCmdBtOverWifi Peer address - %x:%x:%x:%x:%x:%x.\n", rCmdBtOverWifi.rPeerAddr[0],
- rCmdBtOverWifi.rPeerAddr[1],
- rCmdBtOverWifi.rPeerAddr[2],
- rCmdBtOverWifi.rPeerAddr[3], rCmdBtOverWifi.rPeerAddr[4], rCmdBtOverWifi.rPeerAddr[5]);
- DBGLOG(BOW, EVENT, "rCmdBtOverWifi Beacon interval - 0x%x.\n", rCmdBtOverWifi.u2BeaconInterval);
- DBGLOG(BOW, EVENT, "rCmdBtOverWifi Timeout activity - 0x%x.\n", rCmdBtOverWifi.ucTimeoutDiscovery);
- DBGLOG(BOW, EVENT, "rCmdBtOverWifi Timeout inactivity - 0x%x.\n", rCmdBtOverWifi.ucTimeoutInactivity);
- DBGLOG(BOW, EVENT, "rCmdBtOverWifi Role - 0x%x.\n", rCmdBtOverWifi.ucRole);
- DBGLOG(BOW, EVENT, "rCmdBtOverWifi PAL capability - 0x%x.\n", rCmdBtOverWifi.PAL_Capabilities);
- DBGLOG(BOW, EVENT, "rCmdBtOverWifi Max Tx power - 0x%x.\n", rCmdBtOverWifi.cMaxTxPower);
- #endif
- /* 3 <4> Get a free BOW entry, mark as Valid, fill in Peer MAC address, LinkCount += 1, state == Starting. */
- if (!bowGetBowTableFreeEntry(prAdapter, &ucBowTableIdx)) {
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_UNACCEPTED);
- return WLAN_STATUS_NOT_ACCEPTED;
- }
- prBowFsmInfo->prTargetBssDesc = NULL;
- kalMemZero(&rBowTable, sizeof(BOW_TABLE_T));
- COPY_MAC_ADDR(rBowTable.aucPeerAddress, prBowSetupConnection->aucPeerAddress);
- /* owTable.eState = BOW_DEVICE_STATE_ACQUIRING_CHANNEL; */
- rBowTable.fgIsValid = TRUE;
- rBowTable.ucAcquireID = prBowFsmInfo->ucSeqNumOfChReq;
- /* rBowTable.ucRole = prBowSetupConnection->ucRole; */
- /* rBowTable.ucChannelNum = prBowSetupConnection->ucChannelNum; */
- bowSetBowTableContent(prAdapter, ucBowTableIdx, &rBowTable);
- kalSetBowRole(prAdapter->prGlueInfo, rCmdBtOverWifi.ucRole, prBowSetupConnection->aucPeerAddress);
- GLUE_INC_REF_CNT(g_u4LinkCount);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowStarting, g_u4LinkCount, %x.\n", g_u4LinkCount);
- #endif
- if (g_u4LinkCount == 1) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowStarting, cnmTimerInitTimer.\n");
- DBGLOG(BOW, EVENT, "prBowFsmInfo->u2BeaconInterval, %d.\n", prBowFsmInfo->u2BeaconInterval);
- #endif
- cnmTimerInitTimer(prAdapter,
- &prBowFsmInfo->rStartingBeaconTimer,
- (PFN_MGMT_TIMEOUT_FUNC) bowSendBeacon, (ULONG) NULL);
- cnmTimerInitTimer(prAdapter,
- &prBowFsmInfo->rChGrantedTimer,
- (PFN_MGMT_TIMEOUT_FUNC) bowChGrantedTimeout, (ULONG) NULL);
- /* Reset Global Variable */
- g_u4Beaconing = 0;
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowCmdSetupConnection, g_u4LinkCount, %x.\n", g_u4LinkCount);
- DBGLOG(BOW, EVENT, "kalInitBowDevice, bow0\n");
- #endif
- #if CFG_BOW_SEPARATE_DATA_PATH
- kalInitBowDevice(prAdapter->prGlueInfo, BOWDEVNAME);
- #endif
- /*Active BoW Network */
- SET_NET_ACTIVE(prAdapter, NETWORK_TYPE_BOW_INDEX);
- SET_NET_PWR_STATE_ACTIVE(prAdapter, NETWORK_TYPE_BOW_INDEX);
- nicActivateNetwork(prAdapter, NETWORK_TYPE_BOW_INDEX);
- }
- if (rCmdBtOverWifi.ucRole == BOW_INITIATOR) {
- bowSetBowTableState(prAdapter, prBowSetupConnection->aucPeerAddress,
- BOW_DEVICE_STATE_ACQUIRING_CHANNEL);
- bowRequestCh(prAdapter);
- } else {
- bowSetBowTableState(prAdapter, prBowSetupConnection->aucPeerAddress, BOW_DEVICE_STATE_SCANNING);
- bowResponderScan(prAdapter);
- }
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_SUCCESS);
- return WLAN_STATUS_SUCCESS;
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This is command handler for BOW_CMD_ID_DESTROY_CONNECTION
- * coming from 802.11 PAL
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmd Pointer to the buffer that holds the command
- *
- * \retval WLAN_STATUS_SUCCESS
- * \retval WLAN_STATUS_INVALID_LENGTH
- */
- /*----------------------------------------------------------------------------*/
- WLAN_STATUS bowCmdDestroyConnection(IN P_ADAPTER_T prAdapter, IN P_AMPC_COMMAND prCmd)
- {
- P_BOW_DESTROY_CONNECTION prBowDestroyConnection;
- CMD_BT_OVER_WIFI rCmdBtOverWifi;
- P_BOW_FSM_INFO_T prBowFsmInfo;
- #if CFG_BOW_TEST
- UINT_8 ucIdx;
- #endif
- ASSERT(prAdapter);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- /* 3 <1> If LinkCount == 0 ->Fail (Optional) */
- if (g_u4LinkCount == 0) {
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_UNACCEPTED);
- return WLAN_STATUS_NOT_ACCEPTED;
- }
- /* parameter size check */
- if (prCmd->rHeader.u2PayloadLength != sizeof(BOW_DESTROY_CONNECTION)) {
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_UNACCEPTED);
- return WLAN_STATUS_INVALID_LENGTH;
- }
- /* 3 <2> Lookup BOW table, check if is not exist (Valid and Peer MAC address) -> Fail */
- prBowDestroyConnection = (P_BOW_DESTROY_CONNECTION) &(prCmd->aucPayload[0]);
- if (!bowCheckBowTableIfVaild(prAdapter, prBowDestroyConnection->aucPeerAddress)) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowCmdDestroyConnection, bowCheckIfVaild, not accepted.\n");
- #endif
- return WLAN_STATUS_NOT_ACCEPTED;
- }
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT,
- "bowCmdDestroyConnection, destroy Peer address - %x:%x:%x:%x:%x:%x.\n",
- prBowDestroyConnection->aucPeerAddress[0], prBowDestroyConnection->aucPeerAddress[1],
- prBowDestroyConnection->aucPeerAddress[2], prBowDestroyConnection->aucPeerAddress[3],
- prBowDestroyConnection->aucPeerAddress[4], prBowDestroyConnection->aucPeerAddress[5]));
- #endif
- /* fill CMD_BT_OVER_WIFI */
- rCmdBtOverWifi.ucAction = 2;
- COPY_MAC_ADDR(rCmdBtOverWifi.rPeerAddr, prBowDestroyConnection->aucPeerAddress);
- COPY_MAC_ADDR(prBowFsmInfo->aucPeerAddress, prBowDestroyConnection->aucPeerAddress);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT,
- "bowCmdDestroyConnection, rCmdBtOverWifi.rPeerAddr - %x:%x:%x:%x:%x:%x.\n", rCmdBtOverWifi.rPeerAddr[0],
- rCmdBtOverWifi.rPeerAddr[1], rCmdBtOverWifi.rPeerAddr[2], rCmdBtOverWifi.rPeerAddr[3],
- rCmdBtOverWifi.rPeerAddr[4], rCmdBtOverWifi.rPeerAddr[5]);
- #endif
- #if CFG_BOW_TEST
- for (ucIdx = 0; ucIdx < 11; ucIdx++) {
- DBGLOG(BOW, EVENT,
- "BoW receiving PAL packet delta time vs packet number -- %d ms vs %x.\n", ucIdx,
- g_arBowRevPalPacketTime[ucIdx]);
- }
- #endif
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_SUCCESS);
- return wlanoidSendSetQueryBowCmd(prAdapter,
- CMD_ID_CMD_BT_OVER_WIFI,
- TRUE,
- FALSE,
- wlanbowCmdEventLinkDisconnected,
- wlanbowCmdTimeoutHandler,
- sizeof(CMD_BT_OVER_WIFI),
- (PUINT_8)&rCmdBtOverWifi, prCmd->rHeader.ucSeqNumber);
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This is command handler for BOW_CMD_ID_SET_PTK
- * coming from 802.11 PAL
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmd Pointer to the buffer that holds the command
- *
- * \retval WLAN_STATUS_SUCCESS
- * \retval WLAN_STATUS_INVALID_LENGTH
- */
- /*----------------------------------------------------------------------------*/
- WLAN_STATUS bowCmdSetPTK(IN P_ADAPTER_T prAdapter, IN P_AMPC_COMMAND prCmd)
- {
- P_BOW_SET_PTK prBowSetPTK;
- CMD_802_11_KEY rCmdKey;
- ASSERT(prAdapter);
- /* parameter size check */
- if (prCmd->rHeader.u2PayloadLength != sizeof(BOW_SET_PTK))
- return WLAN_STATUS_INVALID_LENGTH;
- prBowSetPTK = (P_BOW_SET_PTK) &(prCmd->aucPayload[0]);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "prBowSetPTK->aucPeerAddress, %x:%x:%x:%x:%x:%x.\n",
- prBowSetPTK->aucPeerAddress[0],
- prBowSetPTK->aucPeerAddress[1],
- prBowSetPTK->aucPeerAddress[2],
- prBowSetPTK->aucPeerAddress[3],
- prBowSetPTK->aucPeerAddress[4], prBowSetPTK->aucPeerAddress[5]));
- DBGLOG(BOW, EVENT,
- "rCmdKey.ucIsAuthenticator, %x.\n", kalGetBowRole(prAdapter->prGlueInfo, prBowSetPTK->aucPeerAddress));
- #endif
- if (!bowCheckBowTableIfVaild(prAdapter, prBowSetPTK->aucPeerAddress)) {
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_UNACCEPTED);
- return WLAN_STATUS_NOT_ACCEPTED;
- }
- if (bowGetBowTableState(prAdapter, prBowSetPTK->aucPeerAddress) != BOW_DEVICE_STATE_CONNECTED) {
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_FAILURE);
- return WLAN_STATUS_NOT_ACCEPTED;
- }
- /* fill CMD_802_11_KEY */
- rCmdKey.ucAddRemove = 1; /* add */
- rCmdKey.ucTxKey = 1;
- rCmdKey.ucKeyType = 1;
- rCmdKey.ucIsAuthenticator = kalGetBowRole(prAdapter->prGlueInfo, prBowSetPTK->aucPeerAddress);
- COPY_MAC_ADDR(rCmdKey.aucPeerAddr, prBowSetPTK->aucPeerAddress);
- rCmdKey.ucNetType = NETWORK_TYPE_BOW_INDEX; /* BT Over Wi-Fi */
- rCmdKey.ucAlgorithmId = CIPHER_SUITE_CCMP; /* AES */
- rCmdKey.ucKeyId = 0;
- rCmdKey.ucKeyLen = 16; /* AES = 128bit */
- kalMemCopy(rCmdKey.aucKeyMaterial, prBowSetPTK->aucTemporalKey, 16);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "prBowSetPTK->aucTemporalKey, %x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x.\n",
- prBowSetPTK->aucTemporalKey[0],
- prBowSetPTK->aucTemporalKey[1],
- prBowSetPTK->aucTemporalKey[2],
- prBowSetPTK->aucTemporalKey[3],
- prBowSetPTK->aucTemporalKey[4],
- prBowSetPTK->aucTemporalKey[5],
- prBowSetPTK->aucTemporalKey[6],
- prBowSetPTK->aucTemporalKey[7],
- prBowSetPTK->aucTemporalKey[8],
- prBowSetPTK->aucTemporalKey[9],
- prBowSetPTK->aucTemporalKey[10],
- prBowSetPTK->aucTemporalKey[11],
- prBowSetPTK->aucTemporalKey[12],
- prBowSetPTK->aucTemporalKey[13],
- prBowSetPTK->aucTemporalKey[14], prBowSetPTK->aucTemporalKey[15]));
- DBGLOG(BOW, EVENT, "rCmdKey.aucKeyMaterial, %x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x:%x.\n",
- rCmdKey.aucKeyMaterial[0],
- rCmdKey.aucKeyMaterial[1],
- rCmdKey.aucKeyMaterial[2],
- rCmdKey.aucKeyMaterial[3],
- rCmdKey.aucKeyMaterial[4],
- rCmdKey.aucKeyMaterial[5],
- rCmdKey.aucKeyMaterial[6],
- rCmdKey.aucKeyMaterial[7],
- rCmdKey.aucKeyMaterial[8],
- rCmdKey.aucKeyMaterial[9],
- rCmdKey.aucKeyMaterial[10],
- rCmdKey.aucKeyMaterial[11],
- rCmdKey.aucKeyMaterial[12],
- rCmdKey.aucKeyMaterial[13], rCmdKey.aucKeyMaterial[14], rCmdKey.aucKeyMaterial[15]));
- #endif
- return wlanoidSendSetQueryBowCmd(prAdapter,
- CMD_ID_ADD_REMOVE_KEY,
- TRUE,
- FALSE,
- wlanbowCmdEventSetCommon,
- wlanbowCmdTimeoutHandler,
- sizeof(CMD_802_11_KEY), (PUINT_8)&rCmdKey, prCmd->rHeader.ucSeqNumber);
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This is command handler for BOW_CMD_ID_READ_RSSI
- * coming from 802.11 PAL
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmd Pointer to the buffer that holds the command
- *
- * \retval WLAN_STATUS_SUCCESS
- * \retval WLAN_STATUS_INVALID_LENGTH
- */
- /*----------------------------------------------------------------------------*/
- WLAN_STATUS bowCmdReadRSSI(IN P_ADAPTER_T prAdapter, IN P_AMPC_COMMAND prCmd)
- {
- P_BOW_READ_RSSI prBowReadRSSI;
- ASSERT(prAdapter);
- /* parameter size check */
- if (prCmd->rHeader.u2PayloadLength != sizeof(BOW_READ_RSSI))
- return WLAN_STATUS_INVALID_LENGTH;
- prBowReadRSSI = (P_BOW_READ_RSSI) &(prCmd->aucPayload[0]);
- return wlanoidSendSetQueryBowCmd(prAdapter,
- CMD_ID_GET_LINK_QUALITY,
- FALSE,
- TRUE,
- wlanbowCmdEventReadRssi,
- wlanbowCmdTimeoutHandler, 0, NULL, prCmd->rHeader.ucSeqNumber);
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This is command handler for BOW_CMD_ID_READ_LINK_QUALITY
- * coming from 802.11 PAL
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmd Pointer to the buffer that holds the command
- *
- * \retval WLAN_STATUS_SUCCESS
- * \retval WLAN_STATUS_INVALID_LENGTH
- */
- /*----------------------------------------------------------------------------*/
- WLAN_STATUS bowCmdReadLinkQuality(IN P_ADAPTER_T prAdapter, IN P_AMPC_COMMAND prCmd)
- {
- P_BOW_READ_LINK_QUALITY prBowReadLinkQuality;
- ASSERT(prAdapter);
- /* parameter size check */
- if (prCmd->rHeader.u2PayloadLength != sizeof(P_BOW_READ_LINK_QUALITY))
- return WLAN_STATUS_INVALID_LENGTH;
- prBowReadLinkQuality = (P_BOW_READ_LINK_QUALITY) &(prCmd->aucPayload[0]);
- return wlanoidSendSetQueryBowCmd(prAdapter,
- CMD_ID_GET_LINK_QUALITY,
- FALSE,
- TRUE,
- wlanbowCmdEventReadLinkQuality,
- wlanbowCmdTimeoutHandler, 0, NULL, prCmd->rHeader.ucSeqNumber);
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This is command handler for BOW_CMD_ID_SHORT_RANGE_MODE
- * coming from 802.11 PAL
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmd Pointer to the buffer that holds the command
- *
- * \retval WLAN_STATUS_SUCCESS
- * \retval WLAN_STATUS_INVALID_LENGTH
- */
- /*----------------------------------------------------------------------------*/
- WLAN_STATUS bowCmdShortRangeMode(IN P_ADAPTER_T prAdapter, IN P_AMPC_COMMAND prCmd)
- {
- P_BOW_SHORT_RANGE_MODE prBowShortRangeMode;
- CMD_TX_PWR_T rTxPwrParam;
- ASSERT(prAdapter);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowCmdShortRangeMode.\n");
- #endif
- prBowShortRangeMode = (P_BOW_SHORT_RANGE_MODE) &(prCmd->aucPayload[0]);
- /* parameter size check */
- if (prCmd->rHeader.u2PayloadLength != sizeof(BOW_SHORT_RANGE_MODE)) {
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_UNACCEPTED);
- return WLAN_STATUS_INVALID_LENGTH;
- }
- if (!bowCheckBowTableIfVaild(prAdapter, prBowShortRangeMode->aucPeerAddress)) {
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_UNACCEPTED);
- return WLAN_STATUS_NOT_ACCEPTED;
- }
- if (bowGetBowTableState(prAdapter, prBowShortRangeMode->aucPeerAddress) != BOW_DEVICE_STATE_CONNECTED) {
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_FAILURE);
- return WLAN_STATUS_NOT_ACCEPTED;
- }
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "prBowShortRangeMode->aucPeerAddress, %x:%x:%x:%x:%x:%x.\n",
- prBowShortRangeMode->aucPeerAddress[0],
- prBowShortRangeMode->aucPeerAddress[1],
- prBowShortRangeMode->aucPeerAddress[2],
- prBowShortRangeMode->aucPeerAddress[3],
- prBowShortRangeMode->aucPeerAddress[4], prBowShortRangeMode->aucPeerAddress[5]));
- #endif
- rTxPwrParam.cTxPwr2G4Cck = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4OFDM_BPSK = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4OFDM_QPSK = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4OFDM_16QAM = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4OFDM_48Mbps = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4OFDM_54Mbps = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4HT20_BPSK = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4HT20_QPSK = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4HT20_16QAM = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4HT20_MCS5 = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4HT20_MCS6 = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4HT20_MCS7 = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4HT40_BPSK = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4HT40_QPSK = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4HT40_16QAM = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4HT40_MCS5 = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4HT40_MCS6 = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr2G4HT40_MCS7 = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GOFDM_BPSK = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GOFDM_QPSK = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GOFDM_16QAM = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GOFDM_48Mbps = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GOFDM_54Mbps = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GHT20_BPSK = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GHT20_QPSK = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GHT20_16QAM = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GHT20_MCS5 = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GHT20_MCS6 = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GHT20_MCS7 = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GHT40_BPSK = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GHT40_QPSK = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GHT40_16QAM = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GHT40_MCS5 = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GHT40_MCS6 = (prBowShortRangeMode->cTxPower << 1);
- rTxPwrParam.cTxPwr5GHT40_MCS7 = (prBowShortRangeMode->cTxPower << 1);
- if (nicUpdateTxPower(prAdapter, &rTxPwrParam) == WLAN_STATUS_SUCCESS) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowCmdShortRangeMode, %x.\n", WLAN_STATUS_SUCCESS);
- #endif
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_SUCCESS);
- return WLAN_STATUS_SUCCESS;
- }
- wlanbowCmdEventSetStatus(prAdapter, prCmd, BOWCMD_STATUS_FAILURE);
- return WLAN_STATUS_FAILURE;
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This is command handler for BOW_CMD_ID_GET_CHANNEL_LIST
- * coming from 802.11 PAL
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmd Pointer to the buffer that holds the command
- *
- * \retval WLAN_STATUS_SUCCESS
- * \retval WLAN_STATUS_INVALID_LENGTH
- */
- /*----------------------------------------------------------------------------*/
- WLAN_STATUS bowCmdGetChannelList(IN P_ADAPTER_T prAdapter, IN P_AMPC_COMMAND prCmd)
- {
- ASSERT(prAdapter);
- /* not supported yet */
- return WLAN_STATUS_FAILURE;
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This is generic command done handler
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmdInfo Pointer to the buffer that holds the command info
- * \param[in] pucEventBuf Pointer to the set buffer OR event buffer
- *
- * \retval none
- */
- /*----------------------------------------------------------------------------*/
- VOID wlanbowCmdEventSetStatus(IN P_ADAPTER_T prAdapter, IN P_AMPC_COMMAND prCmd, IN UINT_8 ucEventBuf)
- {
- P_AMPC_EVENT prEvent;
- P_BOW_COMMAND_STATUS prBowCmdStatus;
- ASSERT(prAdapter);
- /* fill event header */
- prEvent = (P_AMPC_EVENT) kalMemAlloc((sizeof(AMPC_EVENT) + sizeof(BOW_COMMAND_STATUS)), VIR_MEM_TYPE);
- if (!prEvent) {
- ASSERT(FALSE);
- return;
- }
- prEvent->rHeader.ucEventId = BOW_EVENT_ID_COMMAND_STATUS;
- prEvent->rHeader.ucSeqNumber = prCmd->rHeader.ucSeqNumber;
- prEvent->rHeader.u2PayloadLength = sizeof(BOW_COMMAND_STATUS);
- /* fill event body */
- prBowCmdStatus = (P_BOW_COMMAND_STATUS) (prEvent->aucPayload);
- kalMemZero(prBowCmdStatus, sizeof(BOW_COMMAND_STATUS));
- prBowCmdStatus->ucStatus = ucEventBuf;
- kalIndicateBOWEvent(prAdapter->prGlueInfo, prEvent);
- kalMemFree(prEvent, VIR_MEM_TYPE, (sizeof(AMPC_EVENT) + sizeof(BOW_COMMAND_STATUS)));
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This is generic command done handler
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmdInfo Pointer to the buffer that holds the command info
- * \param[in] pucEventBuf Pointer to the set buffer OR event buffer
- *
- * \retval none
- */
- /*----------------------------------------------------------------------------*/
- VOID wlanbowCmdEventSetCommon(IN P_ADAPTER_T prAdapter, IN P_CMD_INFO_T prCmdInfo, IN PUINT_8 pucEventBuf)
- {
- P_AMPC_EVENT prEvent;
- P_BOW_COMMAND_STATUS prBowCmdStatus;
- ASSERT(prAdapter);
- /* fill event header */
- prEvent = (P_AMPC_EVENT) kalMemAlloc((sizeof(AMPC_EVENT) + sizeof(BOW_COMMAND_STATUS)), VIR_MEM_TYPE);
- if (!prEvent) {
- ASSERT(FALSE);
- return;
- }
- prEvent->rHeader.ucEventId = BOW_EVENT_ID_COMMAND_STATUS;
- prEvent->rHeader.ucSeqNumber = (UINT_8) prCmdInfo->u4PrivateData;
- prEvent->rHeader.u2PayloadLength = sizeof(BOW_COMMAND_STATUS);
- /* fill event body */
- prBowCmdStatus = (P_BOW_COMMAND_STATUS) (prEvent->aucPayload);
- kalMemZero(prBowCmdStatus, sizeof(BOW_COMMAND_STATUS));
- prBowCmdStatus->ucStatus = BOWCMD_STATUS_SUCCESS;
- kalIndicateBOWEvent(prAdapter->prGlueInfo, prEvent);
- kalMemFree(prEvent, VIR_MEM_TYPE, (sizeof(AMPC_EVENT) + sizeof(BOW_COMMAND_STATUS)));
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief command done handler for CMD_ID_CMD_BT_OVER_WIFI
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmdInfo Pointer to the buffer that holds the command info
- * \param[in] pucEventBuf Pointer to the set buffer OR event buffer
- *
- * \retval none
- */
- /*----------------------------------------------------------------------------*/
- VOID wlanbowCmdEventLinkConnected(IN P_ADAPTER_T prAdapter, IN P_CMD_INFO_T prCmdInfo, IN PUINT_8 pucEventBuf)
- {
- P_AMPC_EVENT prEvent;
- P_BOW_LINK_CONNECTED prBowLinkConnected;
- P_BOW_FSM_INFO_T prBowFsmInfo;
- P_BSS_INFO_T prBssInfo;
- ASSERT(prAdapter);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- prBssInfo = &(prAdapter->rWifiVar.arBssInfo[NETWORK_TYPE_BOW_INDEX]);
- /* fill event header */
- prEvent = (P_AMPC_EVENT) kalMemAlloc((sizeof(AMPC_EVENT) + sizeof(BOW_LINK_CONNECTED)), VIR_MEM_TYPE);
- if (!prEvent) {
- ASSERT(FALSE);
- return;
- }
- prEvent->rHeader.ucEventId = BOW_EVENT_ID_LINK_CONNECTED;
- prEvent->rHeader.ucSeqNumber = (UINT_8) prCmdInfo->u4PrivateData;
- prEvent->rHeader.u2PayloadLength = sizeof(BOW_LINK_CONNECTED);
- /* fill event body */
- prBowLinkConnected = (P_BOW_LINK_CONNECTED) (prEvent->aucPayload);
- kalMemZero(prBowLinkConnected, sizeof(BOW_LINK_CONNECTED));
- prBowLinkConnected->rChannel.ucChannelNum = prBssInfo->ucPrimaryChannel;
- prBowLinkConnected->rChannel.ucChannelBand = prBssInfo->eBand;
- COPY_MAC_ADDR(prBowLinkConnected->aucPeerAddress, prBowFsmInfo->aucPeerAddress);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "prEvent->rHeader.ucEventId, 0x%x\n", prEvent->rHeader.ucEventId);
- DBGLOG(BOW, EVENT, "prEvent->rHeader.ucSeqNumber, 0x%x\n", prEvent->rHeader.ucSeqNumber);
- DBGLOG(BOW, EVENT, "prEvent->rHeader.u2PayloadLength, 0x%x\n", prEvent->rHeader.u2PayloadLength);
- DBGLOG(BOW, EVENT,
- "prBowLinkConnected->rChannel.ucChannelNum, 0x%x\n", prBowLinkConnected->rChannel.ucChannelNum);
- DBGLOG(BOW, EVENT,
- "prBowLinkConnected->rChannel.ucChannelBand, 0x%x\n", prBowLinkConnected->rChannel.ucChannelBand);
- DBGLOG(BOW, EVENT,
- "wlanbowCmdEventLinkConnected, prBowFsmInfo->aucPeerAddress, %x:%x:%x:%x:%x:%x.\n",
- prBowFsmInfo->aucPeerAddress[0], prBowFsmInfo->aucPeerAddress[1], prBowFsmInfo->aucPeerAddress[2],
- prBowFsmInfo->aucPeerAddress[3], prBowFsmInfo->aucPeerAddress[4], prBowFsmInfo->aucPeerAddress[5]);
- DBGLOG(BOW, EVENT,
- "wlanbowCmdEventLinkConnected, prBowLinkConnected->aucPeerAddress, %x:%x:%x:%x:%x:%x.\n",
- prBowLinkConnected->aucPeerAddress[0], prBowLinkConnected->aucPeerAddress[1],
- prBowLinkConnected->aucPeerAddress[2], prBowLinkConnected->aucPeerAddress[3],
- prBowLinkConnected->aucPeerAddress[4], prBowLinkConnected->aucPeerAddress[5]));
- DBGLOG(BOW, EVENT, "wlanbowCmdEventLinkConnected, g_u4LinkCount, %x.\n", g_u4LinkCount);
- #endif
- /*Indicate Event to PAL */
- kalIndicateBOWEvent(prAdapter->prGlueInfo, prEvent);
- kalMemFree(prEvent, VIR_MEM_TYPE, (sizeof(AMPC_EVENT) + sizeof(BOW_LINK_CONNECTED)));
- /*Release channel if granted */
- if (prBowFsmInfo->fgIsChannelGranted) {
- cnmTimerStopTimer(prAdapter, &prBowFsmInfo->rChGrantedTimer);
- /* bowReleaseCh(prAdapter); */
- /*Requested, not granted yet */
- } else if (prBowFsmInfo->fgIsChannelRequested) {
- prBowFsmInfo->fgIsChannelRequested = FALSE;
- }
- /* set to connected status */
- bowSetBowTableState(prAdapter, prBowFsmInfo->aucPeerAddress, BOW_DEVICE_STATE_CONNECTED);
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief command done handler for CMD_ID_CMD_BT_OVER_WIFI
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmdInfo Pointer to the buffer that holds the command info
- * \param[in] pucEventBuf Pointer to the set buffer OR event buffer
- *
- * \retval none
- */
- /*----------------------------------------------------------------------------*/
- VOID wlanbowCmdEventLinkDisconnected(IN P_ADAPTER_T prAdapter, IN P_CMD_INFO_T prCmdInfo, IN PUINT_8 pucEventBuf)
- {
- P_AMPC_EVENT prEvent;
- P_BOW_LINK_DISCONNECTED prBowLinkDisconnected;
- P_BOW_FSM_INFO_T prBowFsmInfo;
- BOW_TABLE_T rBowTable;
- UINT_8 ucBowTableIdx;
- ENUM_BOW_DEVICE_STATE eFsmState;
- BOOLEAN fgSendDeauth = FALSE;
- ASSERT(prAdapter);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- eFsmState = bowGetBowTableState(prAdapter, prBowFsmInfo->aucPeerAddress);
- if (eFsmState == BOW_DEVICE_STATE_DISCONNECTED) {
- /*do nothing */
- return;
- }
- /*Cancel scan */
- else if (eFsmState == BOW_DEVICE_STATE_SCANNING && !(prBowFsmInfo->fgIsChannelRequested)) {
- bowResponderCancelScan(prAdapter, FALSE);
- bowSetBowTableState(prAdapter, prBowFsmInfo->aucPeerAddress, BOW_DEVICE_STATE_DISCONNECTING);
- return;
- }
- /* fill event header */
- prEvent = (P_AMPC_EVENT) kalMemAlloc((sizeof(AMPC_EVENT) + sizeof(BOW_LINK_DISCONNECTED)), VIR_MEM_TYPE);
- if (!prEvent) {
- ASSERT(FALSE);
- return;
- }
- prEvent->rHeader.ucEventId = BOW_EVENT_ID_LINK_DISCONNECTED;
- if ((prCmdInfo->u4PrivateData))
- prEvent->rHeader.ucSeqNumber = (UINT_8) prCmdInfo->u4PrivateData;
- else
- prEvent->rHeader.ucSeqNumber = 0;
- prEvent->rHeader.u2PayloadLength = sizeof(BOW_LINK_DISCONNECTED);
- /* fill event body */
- prBowLinkDisconnected = (P_BOW_LINK_DISCONNECTED) (prEvent->aucPayload);
- kalMemZero(prBowLinkDisconnected, sizeof(BOW_LINK_DISCONNECTED));
- prBowLinkDisconnected->ucReason = 0x0;
- COPY_MAC_ADDR(prBowLinkDisconnected->aucPeerAddress, prBowFsmInfo->aucPeerAddress);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "prEvent->rHeader.ucEventId, 0x%x\n", prEvent->rHeader.ucEventId);
- DBGLOG(BOW, EVENT, "prEvent->rHeader.ucSeqNumber, 0x%x\n", prEvent->rHeader.ucSeqNumber);
- DBGLOG(BOW, EVENT, "prEvent->rHeader.u2PayloadLength, 0x%x\n", prEvent->rHeader.u2PayloadLength);
- DBGLOG(BOW, EVENT, "wlanbowCmdEventLinkDisconnected, prBowFsmInfo->aucPeerAddress, %x:%x:%x:%x:%x:%x.\n",
- prBowFsmInfo->aucPeerAddress[0],
- prBowFsmInfo->aucPeerAddress[1],
- prBowFsmInfo->aucPeerAddress[2],
- prBowFsmInfo->aucPeerAddress[3],
- prBowFsmInfo->aucPeerAddress[4], prBowFsmInfo->aucPeerAddress[5]));
- DBGLOG(BOW, EVENT,
- "wlanbowCmdEventLinkDisconnected, prBowLinkDisconnected->aucPeerAddress, %x:%x:%x:%x:%x:%x.\n",
- prBowLinkDisconnected->aucPeerAddress[0], prBowLinkDisconnected->aucPeerAddress[1],
- prBowLinkDisconnected->aucPeerAddress[2], prBowLinkDisconnected->aucPeerAddress[3],
- prBowLinkDisconnected->aucPeerAddress[4], prBowLinkDisconnected->aucPeerAddress[5]));
- DBGLOG(BOW, EVENT, "wlanbowCmdEventLinkDisconnected, g_u4LinkCount, %x.\n", g_u4LinkCount);
- #endif
- /*Indicate BoW event to PAL */
- #if 0
- kalIndicateBOWEvent(prAdapter->prGlueInfo, prEvent);
- kalMemFree(prEvent, VIR_MEM_TYPE, (sizeof(AMPC_EVENT) + sizeof(BOW_LINK_DISCONNECTED)));
- #endif
- /* set to disconnected status */
- prBowFsmInfo->prTargetStaRec =
- cnmGetStaRecByAddress(prAdapter, NETWORK_TYPE_BOW_INDEX, prBowLinkDisconnected->aucPeerAddress);
- if (!(prBowFsmInfo->prTargetStaRec)) {
- kalMemFree(prEvent, VIR_MEM_TYPE, (sizeof(AMPC_EVENT) + sizeof(BOW_LINK_DISCONNECTED)));
- ASSERT(FALSE);
- return;
- }
- /*Release channel if granted */
- if (prBowFsmInfo->fgIsChannelGranted) {
- cnmTimerStopTimer(prAdapter, &prBowFsmInfo->rChGrantedTimer);
- bowReleaseCh(prAdapter);
- /*Requested, not granted yet */
- } else if (prBowFsmInfo->fgIsChannelRequested) {
- prBowFsmInfo->fgIsChannelRequested = FALSE;
- /* bowReleaseCh(prAdapter); */
- }
- #if 1
- /*Send Deauth to connected peer */
- if (eFsmState == BOW_DEVICE_STATE_CONNECTED && (prBowFsmInfo->prTargetStaRec->ucStaState == STA_STATE_3)) {
- fgSendDeauth = TRUE;
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT,
- "wlanbowCmdEventLinkDisconnected, bowGetBowTableState, %x.\n",
- bowGetBowTableState(prAdapter, prBowLinkDisconnected->aucPeerAddress));
- #endif
- authSendDeauthFrame(prAdapter,
- prBowFsmInfo->prTargetStaRec,
- (P_SW_RFB_T) NULL,
- REASON_CODE_DEAUTH_LEAVING_BSS, (PFN_TX_DONE_HANDLER) bowDisconnectLink);
- }
- #endif
- #if 0
- /* 3 <3>Stop this link; flush Tx;
- * send deAuthentication -> abort. SAA, AAA. need to check BOW table state == Connected.
- */
- if (prAdapter->prGlueInfo->i4TxPendingFrameNum > 0)
- kalFlushPendingTxPackets(prAdapter->prGlueInfo);
- /* flush pending security frames */
- if (prAdapter->prGlueInfo->i4TxPendingSecurityFrameNum > 0)
- kalClearSecurityFrames(prAdapter->prGlueInfo);
- #endif
- /*Update BoW table */
- bowGetBowTableEntryByPeerAddress(prAdapter, prBowLinkDisconnected->aucPeerAddress, &ucBowTableIdx);
- rBowTable.fgIsValid = FALSE;
- rBowTable.eState = BOW_DEVICE_STATE_DISCONNECTED;
- kalMemZero(rBowTable.aucPeerAddress, sizeof(rBowTable.aucPeerAddress));
- bowSetBowTableContent(prAdapter, ucBowTableIdx, &rBowTable);
- /*Indicate BoW event to PAL */
- kalIndicateBOWEvent(prAdapter->prGlueInfo, prEvent);
- kalMemFree(prEvent, VIR_MEM_TYPE, (sizeof(AMPC_EVENT) + sizeof(BOW_LINK_DISCONNECTED)));
- /*Decrease link count */
- GLUE_DEC_REF_CNT(g_u4LinkCount);
- /*If no need to send deauth, DO disconnect now */
- /*If need to send deauth, DO disconnect at deauth Tx done */
- if (!fgSendDeauth)
- bowDisconnectLink(prAdapter, NULL, TX_RESULT_SUCCESS);
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief command done handler for CMD_ID_CMD_BT_OVER_WIFI
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmdInfo Pointer to the buffer that holds the command info
- * \param[in] pucEventBuf Pointer to the set buffer OR event buffer
- *
- * \retval none
- */
- /*----------------------------------------------------------------------------*/
- VOID wlanbowCmdEventSetSetupConnection(IN P_ADAPTER_T prAdapter, IN P_CMD_INFO_T prCmdInfo, IN PUINT_8 pucEventBuf)
- {
- P_AMPC_EVENT prEvent;
- P_BOW_COMMAND_STATUS prBowCmdStatus;
- P_WIFI_CMD_T prWifiCmd;
- P_CMD_BT_OVER_WIFI prCmdBtOverWifi;
- P_BOW_FSM_INFO_T prBowFsmInfo;
- ASSERT(prAdapter);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- /* restore original command for rPeerAddr */
- prWifiCmd = (P_WIFI_CMD_T) (prCmdInfo->pucInfoBuffer);
- prCmdBtOverWifi = (P_CMD_BT_OVER_WIFI) (prWifiCmd->aucBuffer);
- /* fill event header */
- prEvent = (P_AMPC_EVENT) kalMemAlloc((sizeof(AMPC_EVENT) + sizeof(BOW_COMMAND_STATUS)), VIR_MEM_TYPE);
- if (!prEvent) {
- ASSERT(FALSE);
- return;
- }
- prEvent->rHeader.ucEventId = BOW_EVENT_ID_COMMAND_STATUS;
- prEvent->rHeader.ucSeqNumber = (UINT_8) prCmdInfo->u4PrivateData;
- prEvent->rHeader.u2PayloadLength = sizeof(BOW_COMMAND_STATUS);
- /* fill event body */
- prBowCmdStatus = (P_BOW_COMMAND_STATUS) (prEvent->aucPayload);
- kalMemZero(prBowCmdStatus, sizeof(BOW_COMMAND_STATUS));
- prBowCmdStatus->ucStatus = BOWCMD_STATUS_SUCCESS;
- /*Indicate BoW event to PAL */
- kalIndicateBOWEvent(prAdapter->prGlueInfo, prEvent);
- kalMemFree(prEvent, VIR_MEM_TYPE, (sizeof(AMPC_EVENT) + sizeof(BOW_COMMAND_STATUS)));
- /* set to starting status */
- kalSetBowState(prAdapter->prGlueInfo, BOW_DEVICE_STATE_STARTING, prCmdBtOverWifi->rPeerAddr);
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This is the command done handler for BOW_CMD_ID_READ_LINK_QUALITY
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmdInfo Pointer to the buffer that holds the command info
- * \param[in] pucEventBuf Pointer to the set buffer OR event buffer
- *
- * \retval none
- */
- /*----------------------------------------------------------------------------*/
- VOID wlanbowCmdEventReadLinkQuality(IN P_ADAPTER_T prAdapter, IN P_CMD_INFO_T prCmdInfo, IN PUINT_8 pucEventBuf)
- {
- P_EVENT_LINK_QUALITY prLinkQuality;
- P_AMPC_EVENT prEvent;
- P_BOW_LINK_QUALITY prBowLinkQuality;
- ASSERT(prAdapter);
- prLinkQuality = (P_EVENT_LINK_QUALITY) pucEventBuf;
- /* fill event header */
- prEvent = (P_AMPC_EVENT) kalMemAlloc((sizeof(AMPC_EVENT) + sizeof(BOW_LINK_QUALITY)), VIR_MEM_TYPE);
- if (!prEvent) {
- ASSERT(FALSE);
- return;
- }
- prEvent->rHeader.ucEventId = BOW_EVENT_ID_LINK_QUALITY;
- prEvent->rHeader.ucSeqNumber = (UINT_8) prCmdInfo->u4PrivateData;
- prEvent->rHeader.u2PayloadLength = sizeof(BOW_LINK_QUALITY);
- /* fill event body */
- prBowLinkQuality = (P_BOW_LINK_QUALITY) (prEvent->aucPayload);
- kalMemZero(prBowLinkQuality, sizeof(BOW_LINK_QUALITY));
- prBowLinkQuality->ucLinkQuality = (UINT_8) prLinkQuality->cLinkQuality;
- kalIndicateBOWEvent(prAdapter->prGlueInfo, prEvent);
- kalMemFree(prEvent, VIR_MEM_TYPE, (sizeof(AMPC_EVENT) + sizeof(BOW_LINK_QUALITY)));
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This is the command done handler for BOW_CMD_ID_READ_RSSI
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmdInfo Pointer to the buffer that holds the command info
- * \param[in] pucEventBuf Pointer to the set buffer OR event buffer
- *
- * \retval none
- */
- /*----------------------------------------------------------------------------*/
- VOID wlanbowCmdEventReadRssi(IN P_ADAPTER_T prAdapter, IN P_CMD_INFO_T prCmdInfo, IN PUINT_8 pucEventBuf)
- {
- P_EVENT_LINK_QUALITY prLinkQuality;
- P_AMPC_EVENT prEvent;
- P_BOW_RSSI prBowRssi;
- ASSERT(prAdapter);
- prLinkQuality = (P_EVENT_LINK_QUALITY) pucEventBuf;
- /* fill event header */
- prEvent = (P_AMPC_EVENT) kalMemAlloc((sizeof(AMPC_EVENT) + sizeof(BOW_LINK_QUALITY)), VIR_MEM_TYPE);
- if (!prEvent) {
- ASSERT(FALSE);
- return;
- }
- prEvent->rHeader.ucEventId = BOW_EVENT_ID_RSSI;
- prEvent->rHeader.ucSeqNumber = (UINT_8) prCmdInfo->u4PrivateData;
- prEvent->rHeader.u2PayloadLength = sizeof(BOW_RSSI);
- /* fill event body */
- prBowRssi = (P_BOW_RSSI) (prEvent->aucPayload);
- kalMemZero(prBowRssi, sizeof(BOW_RSSI));
- prBowRssi->cRssi = (INT_8) prLinkQuality->cRssi;
- kalIndicateBOWEvent(prAdapter->prGlueInfo, prEvent);
- kalMemFree(prEvent, VIR_MEM_TYPE, (sizeof(AMPC_EVENT) + sizeof(BOW_LINK_QUALITY)));
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This is the default command timeout handler
- *
- * \param[in] prAdapter Pointer to the Adapter structure.
- * \param[in] prCmdInfo Pointer to the buffer that holds the command info
- *
- * \retval none
- */
- /*----------------------------------------------------------------------------*/
- VOID wlanbowCmdTimeoutHandler(IN P_ADAPTER_T prAdapter, IN P_CMD_INFO_T prCmdInfo)
- {
- P_AMPC_EVENT prEvent;
- P_BOW_COMMAND_STATUS prBowCmdStatus;
- ASSERT(prAdapter);
- /* fill event header */
- prEvent = (P_AMPC_EVENT) kalMemAlloc((sizeof(AMPC_EVENT) + sizeof(BOW_COMMAND_STATUS)), VIR_MEM_TYPE);
- if (!prEvent) {
- ASSERT(FALSE);
- return;
- }
- prEvent->rHeader.ucEventId = BOW_EVENT_ID_COMMAND_STATUS;
- prEvent->rHeader.ucSeqNumber = (UINT_8) prCmdInfo->u4PrivateData;
- prEvent->rHeader.u2PayloadLength = sizeof(BOW_COMMAND_STATUS);
- /* fill event body */
- prBowCmdStatus = (P_BOW_COMMAND_STATUS) (prEvent->aucPayload);
- kalMemZero(prBowCmdStatus, sizeof(BOW_COMMAND_STATUS));
- prBowCmdStatus->ucStatus = BOWCMD_STATUS_TIMEOUT; /* timeout */
- kalIndicateBOWEvent(prAdapter->prGlueInfo, prEvent);
- kalMemFree(prEvent, VIR_MEM_TYPE, (sizeof(AMPC_EVENT) + sizeof(BOW_COMMAND_STATUS)));
- }
- VOID bowStopping(IN P_ADAPTER_T prAdapter)
- {
- P_BOW_FSM_INFO_T prBowFsmInfo;
- P_BSS_INFO_T prBowBssInfo;
- ASSERT(prAdapter);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- prBowBssInfo = &(prAdapter->rWifiVar.arBssInfo[NETWORK_TYPE_BOW_INDEX]);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowStoping.\n");
- DBGLOG(BOW, EVENT, "bowStoping, SSID %s.\n", prBowBssInfo->aucSSID);
- DBGLOG(BOW, EVENT, "bowStoping, prBowBssInfo->aucBSSID, %x:%x:%x:%x:%x:%x.\n",
- prBowBssInfo->aucBSSID[0],
- prBowBssInfo->aucBSSID[1],
- prBowBssInfo->aucBSSID[2],
- prBowBssInfo->aucBSSID[3], prBowBssInfo->aucBSSID[4], prBowBssInfo->aucBSSID[5]));
- DBGLOG(BOW, EVENT, "bowStoping, prBssInfo->aucOwnMacAddr, %x:%x:%x:%x:%x:%x.\n",
- prBowBssInfo->aucOwnMacAddr[0],
- prBowBssInfo->aucOwnMacAddr[1],
- prBowBssInfo->aucOwnMacAddr[2],
- prBowBssInfo->aucOwnMacAddr[3],
- prBowBssInfo->aucOwnMacAddr[4], prBowBssInfo->aucOwnMacAddr[5]));
- DBGLOG(BOW, EVENT, "bowStoping, prAdapter->rWifiVar.aucDeviceAddress, %x:%x:%x:%x:%x:%x.\n",
- prAdapter->rWifiVar.aucDeviceAddress[0],
- prAdapter->rWifiVar.aucDeviceAddress[1],
- prAdapter->rWifiVar.aucDeviceAddress[2],
- prAdapter->rWifiVar.aucDeviceAddress[3],
- prAdapter->rWifiVar.aucDeviceAddress[4], prAdapter->rWifiVar.aucDeviceAddress[5]));
- DBGLOG(BOW, EVENT, "bowStopping, g_u4LinkCount, %x.\n", g_u4LinkCount);
- DBGLOG(BOW, EVENT, "prBowFsmInfo->aucPeerAddress, %x:%x:%x:%x:%x:%x.\n", prBowFsmInfo->aucPeerAddress[0],
- prBowFsmInfo->aucPeerAddress[1],
- prBowFsmInfo->aucPeerAddress[2],
- prBowFsmInfo->aucPeerAddress[3],
- prBowFsmInfo->aucPeerAddress[4], prBowFsmInfo->aucPeerAddress[5]));
- kalPrint("BoW Stoping,[%d,%d]\n", g_u4LinkCount, g_u4Beaconing);
- #endif
- if (g_u4LinkCount == 0) {
- /*Stop beaconing */
- GLUE_DEC_REF_CNT(g_u4Beaconing);
- /*Deactive BoW network */
- /* prBowBssInfo->fgIsNetActive = FALSE; */
- /* prBowBssInfo->fgIsBeaconActivated = FALSE; */
- nicPmIndicateBssAbort(prAdapter, NETWORK_TYPE_BOW_INDEX);
- bowChangeMediaState(prAdapter, PARAM_MEDIA_STATE_DISCONNECTED);
- nicUpdateBss(prAdapter, NETWORK_TYPE_BOW_INDEX);
- /*temp solution for FW hal_pwr_mgt.c#3037 ASSERT */
- nicDeactivateNetwork(prAdapter, NETWORK_TYPE_BOW_INDEX);
- SET_NET_PWR_STATE_IDLE(prAdapter, NETWORK_TYPE_BOW_INDEX);
- UNSET_NET_ACTIVE(prAdapter, NETWORK_TYPE_BOW_INDEX);
- }
- }
- VOID bowStarting(IN P_ADAPTER_T prAdapter)
- {
- P_BOW_FSM_INFO_T prBowFsmInfo;
- P_BSS_INFO_T prBssInfo;
- ASSERT(prAdapter);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- if (g_u4LinkCount == 1) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "BoW Starting.\n");
- DBGLOG(BOW, EVENT, "BoW channel granted.\n");
- #endif
- #if 0
- /*Active BoW Network */
- SET_NET_ACTIVE(prAdapter, NETWORK_TYPE_BOW_INDEX);
- SET_NET_PWR_STATE_ACTIVE(prAdapter, NETWORK_TYPE_BOW_INDEX);
- nicActivateNetwork(prAdapter, NETWORK_TYPE_BOW_INDEX);
- #endif
- /* 3 <1> Update BSS_INFO_T per Network Basis */
- /* 4 <1.1> Setup Operation Mode */
- prBssInfo = &(prAdapter->rWifiVar.arBssInfo[NETWORK_TYPE_BOW_INDEX]);
- prBssInfo->ucNetTypeIndex = NETWORK_TYPE_BOW_INDEX;
- prBssInfo->eCurrentOPMode = OP_MODE_BOW;
- /* 4 <1.2> Setup SSID */
- COPY_MAC_ADDR(prBssInfo->aucOwnMacAddr, prAdapter->rWifiVar.aucDeviceAddress);
- COPY_MAC_ADDR(prBssInfo->aucBSSID, prAdapter->rWifiVar.aucDeviceAddress);
- prBssInfo->ucSSIDLen = BOW_SSID_LEN;
- bowAssignSsid(prBssInfo->aucSSID, prBssInfo->aucOwnMacAddr);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "SSID %s.\n", prBssInfo->aucSSID);
- DBGLOG(BOW, EVENT, "prBssInfo->aucBSSID, %x:%x:%x:%x:%x:%x.\n",
- prBssInfo->aucBSSID[0],
- prBssInfo->aucBSSID[1],
- prBssInfo->aucBSSID[2],
- prBssInfo->aucBSSID[3], prBssInfo->aucBSSID[4], prBssInfo->aucBSSID[5]));
- DBGLOG(BOW, EVENT, "prBssInfo->aucOwnMacAddr, %x:%x:%x:%x:%x:%x.\n",
- prBssInfo->aucOwnMacAddr[0],
- prBssInfo->aucOwnMacAddr[1],
- prBssInfo->aucOwnMacAddr[2],
- prBssInfo->aucOwnMacAddr[3],
- prBssInfo->aucOwnMacAddr[4], prBssInfo->aucOwnMacAddr[5]));
- DBGLOG(BOW, EVENT, "prAdapter->rWifiVar.aucDeviceAddress, %x:%x:%x:%x:%x:%x.\n",
- prAdapter->rWifiVar.aucDeviceAddress[0],
- prAdapter->rWifiVar.aucDeviceAddress[1],
- prAdapter->rWifiVar.aucDeviceAddress[2],
- prAdapter->rWifiVar.aucDeviceAddress[3],
- prAdapter->rWifiVar.aucDeviceAddress[4], prAdapter->rWifiVar.aucDeviceAddress[5]));
- #endif
- /* 4 <1.3> Clear current AP's STA_RECORD_T and current AID */
- prBssInfo->prStaRecOfAP = (P_STA_RECORD_T) NULL;
- prBssInfo->u2AssocId = 0;
- /* 4 <1.4> Setup Channel, Band and Phy Attributes */
- prBssInfo->ucPrimaryChannel = prBowFsmInfo->ucPrimaryChannel;
- if (prBowFsmInfo->eBand == BAND_2G4)
- prBssInfo->eBand = BAND_2G4;
- else
- prBssInfo->eBand = BAND_5G;
- #if CFG_BOW_SUPPORT_11N
- /* Depend on eBand */
- prBssInfo->ucPhyTypeSet = prAdapter->rWifiVar.ucAvailablePhyTypeSet & PHY_TYPE_SET_802_11BGN;
- /* Depend on eCurrentOPMode and ucPhyTypeSet */
- prBssInfo->ucConfigAdHocAPMode = AP_MODE_MIXED_11BG;
- prBssInfo->ucNonHTBasicPhyType = (UINT_8)
- rNonHTApModeAttributes[prBssInfo->ucConfigAdHocAPMode].ePhyTypeIndex;
- prBssInfo->u2BSSBasicRateSet = rNonHTApModeAttributes[prBssInfo->ucConfigAdHocAPMode].u2BSSBasicRateSet;
- prBssInfo->u2OperationalRateSet =
- rNonHTPhyAttributes[prBssInfo->ucNonHTBasicPhyType].u2SupportedRateSet;
- rateGetDataRatesFromRateSet(prBssInfo->u2OperationalRateSet,
- prBssInfo->u2BSSBasicRateSet,
- prBssInfo->aucAllSupportedRates, &prBssInfo->ucAllSupportedRatesLen);
- #else
- if (prBssInfo->eBand == BAND_2G4) {
- /* Depend on eBand */
- prBssInfo->ucPhyTypeSet = PHY_TYPE_SET_802_11BG;
- /* Depend on eCurrentOPMode and ucPhyTypeSet */
- prBssInfo->ucConfigAdHocAPMode = AP_MODE_MIXED_11BG;
- /* RATE_SET_ERP; */
- prBssInfo->u2BSSBasicRateSet = BASIC_RATE_SET_ERP;
- prBssInfo->u2OperationalRateSet = RATE_SET_ERP;
- prBssInfo->ucNonHTBasicPhyType = PHY_TYPE_ERP_INDEX;
- } else {
- /* Depend on eBand */
- /* prBssInfo->ucPhyTypeSet = PHY_TYPE_SET_802_11BG; */
- /* Depend on eCurrentOPMode and ucPhyTypeSet */
- /* prBssInfo->ucConfigAdHocAPMode = AP_MODE_MIXED_11BG; */
- /* Depend on eBand */
- prBssInfo->ucPhyTypeSet = PHY_TYPE_SET_802_11A;
- /* Depend on eCurrentOPMode and ucPhyTypeSet */
- prBssInfo->ucConfigAdHocAPMode = AP_MODE_11A;
- /* RATE_SET_ERP; */
- /* prBssInfo->u2BSSBasicRateSet = BASIC_RATE_SET_ERP; */
- /* prBssInfo->u2OperationalRateSet = RATE_SET_ERP; */
- /* RATE_SET_ERP; */
- prBssInfo->u2BSSBasicRateSet = BASIC_RATE_SET_OFDM;
- prBssInfo->u2OperationalRateSet = RATE_SET_OFDM;
- prBssInfo->ucNonHTBasicPhyType = PHY_TYPE_OFDM_INDEX;
- }
- #endif
- prBssInfo->fgErpProtectMode = FALSE;
- /* 4 <1.5> Setup MIB for current BSS */
- prBssInfo->u2BeaconInterval = prBowFsmInfo->u2BeaconInterval;
- prBssInfo->ucDTIMPeriod = DOT11_DTIM_PERIOD_DEFAULT;
- prBssInfo->u2ATIMWindow = 0;
- prBssInfo->ucBeaconTimeoutCount = 0;
- if (prBowFsmInfo->fgSupportQoS) {
- prAdapter->rWifiVar.fgSupportQoS = TRUE;
- prBssInfo->fgIsQBSS = TRUE;
- }
- /* 3 <2> Update BSS_INFO_T common part */
- #if CFG_SUPPORT_AAA
- bssInitForAP(prAdapter, prBssInfo, TRUE);
- nicQmUpdateWmmParms(prAdapter, NETWORK_TYPE_BOW_INDEX);
- #endif /* CFG_SUPPORT_AAA */
- prBssInfo->fgIsNetActive = TRUE;
- prBssInfo->fgIsBeaconActivated = TRUE;
- /* 3 <3> Set MAC HW */
- /* 4 <2> Initiate BSS_INFO_T - common part */
- BOW_BSS_INFO_INIT(prAdapter, NETWORK_TYPE_BOW_INDEX);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT,
- "prBowFsmInfo->aucPeerAddress, %x:%x:%x:%x:%x:%x.\n", prBowFsmInfo->aucPeerAddress[0],
- prBowFsmInfo->aucPeerAddress[1], prBowFsmInfo->aucPeerAddress[2],
- prBowFsmInfo->aucPeerAddress[3], prBowFsmInfo->aucPeerAddress[4],
- prBowFsmInfo->aucPeerAddress[5]));
- #endif
- /* 4 <3.1> use command packets to inform firmware */
- rlmBssInitForAPandIbss(prAdapter, prBssInfo);
- nicUpdateBss(prAdapter, NETWORK_TYPE_BOW_INDEX);
- /* 4 <3.2> Update AdHoc PM parameter */
- nicPmIndicateBssCreated(prAdapter, NETWORK_TYPE_BOW_INDEX);
- /* 4 <3.1> Reset HW TSF Update Mode and Beacon Mode */
- /* 4 <3.2> Setup BSSID */
- /* TODO: rxmSetRxFilterBSSID0 */
- /* rxmSetRxFilterBSSID0(prBssInfo->ucHwBssidId, prBssInfo->aucBSSID); */
- /* 4 <3.3> Setup RX Filter to accept Probe Request */
- /* TODO: f get/set RX filter. */
- #if 0
- {
- UINT_32 u4RxFilter;
- if (halMacRxGetRxFilters(&u4RxFilter) == HAL_STATUS_SUCCESS) {
- u4RxFilter &= ~BIT(RXFILTER_DROP_PROBE_REQ);
- halMacRxSetRxFilters(u4RxFilter);
- }
- }
- #endif
- }
- /*Update BoW Table */
- bowSetBowTableState(prAdapter, prBowFsmInfo->aucPeerAddress, BOW_DEVICE_STATE_STARTING);
- #if CFG_BOW_TEST
- kalPrint("BoW Starting,[%d,%d]\n", g_u4LinkCount, g_u4Beaconing);
- DBGLOG(BOW, EVENT, "bowStarting, g_u4LinkCount, %x.\n", g_u4LinkCount);
- #endif
- /*Start beaconing */
- if (g_u4Beaconing < 1) {
- GLUE_INC_REF_CNT(g_u4Beaconing);
- bssSendBeaconProbeResponse(prAdapter, NETWORK_TYPE_BOW_INDEX, NULL, 0);
- cnmTimerStartTimer(prAdapter, &prBowFsmInfo->rStartingBeaconTimer, prBowFsmInfo->u2BeaconInterval);
- }
- #if 0
- /*Responder: Start to scan Initiator */
- if (prBowFsmInfo->ucRole == BOW_RESPONDER) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowStarting responder, start scan result searching.\n");
- #endif
- cnmTimerStopTimer(prAdapter, &prBowFsmInfo->rChGrantedTimer);
- bowReleaseCh(prAdapter);
- bowResponderScan(prAdapter);
- }
- /*Initiator: Request channel, wait for responder */
- else {
- /* Todo:: Nothing*/
- /* bowRequestCh(prAdapter); */
- }
- #endif
- }
- VOID bowAssignSsid(IN PUINT_8 pucSsid, IN PUINT_8 puOwnMacAddr)
- {
- UINT_8 i;
- UINT_8 aucSSID[] = BOW_WILDCARD_SSID;
- kalMemCopy(pucSsid, aucSSID, BOW_WILDCARD_SSID_LEN);
- for (i = 0; i < 6; i++) {
- pucSsid[(3 * i) + 3] = 0x2D;
- if ((*(puOwnMacAddr + i) >> 4) < 0xA)
- *(pucSsid + (3 * i) + 4) = (*(puOwnMacAddr + i) >> 4) + 0x30;
- else
- *(pucSsid + (3 * i) + 4) = (*(puOwnMacAddr + i) >> 4) + 0x57;
- if ((*(puOwnMacAddr + i) & 0x0F) < 0xA)
- pucSsid[(3 * i) + 5] = (*(puOwnMacAddr + i) & 0x0F) + 0x30;
- else
- pucSsid[(3 * i) + 5] = (*(puOwnMacAddr + i) & 0x0F) + 0x57;
- }
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * @brief This function will validate the Rx Probe Request Frame and then return
- * result to BSS to indicate if need to send the corresponding Probe Response
- * Frame if the specified conditions were matched.
- *
- * @param[in] prAdapter Pointer to the Adapter structure.
- * @param[in] prSwRfb Pointer to SW RFB data structure.
- * @param[out] pu4ControlFlags Control flags for replying the Probe Response
- *
- * @retval TRUE Reply the Probe Response
- * @retval FALSE Don't reply the Probe Response
- */
- /*----------------------------------------------------------------------------*/
- BOOLEAN bowValidateProbeReq(IN P_ADAPTER_T prAdapter, IN P_SW_RFB_T prSwRfb, OUT PUINT_32 pu4ControlFlags)
- {
- P_WLAN_MAC_MGMT_HEADER_T prMgtHdr;
- P_BOW_FSM_INFO_T prBowFsmInfo;
- P_BSS_INFO_T prBssInfo;
- P_IE_SSID_T prIeSsid = (P_IE_SSID_T) NULL;
- PUINT_8 pucIE;
- UINT_16 u2IELength;
- UINT_16 u2Offset = 0;
- BOOLEAN fgReplyProbeResp = FALSE;
- ASSERT(prSwRfb);
- ASSERT(pu4ControlFlags);
- prBssInfo = &(prAdapter->rWifiVar.arBssInfo[NETWORK_TYPE_BOW_INDEX]);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- #if 0 /* CFG_BOW_TEST */
- DBGLOG(BOW, EVENT, "bowValidateProbeReq.\n");
- #endif
- /* 4 <1> Parse Probe Req IE and Get IE ptr (SSID, Supported Rate IE, ...) */
- prMgtHdr = (P_WLAN_MAC_MGMT_HEADER_T) prSwRfb->pvHeader;
- u2IELength = prSwRfb->u2PacketLen - prSwRfb->u2HeaderLen;
- pucIE = (PUINT_8) ((ULONG) prSwRfb->pvHeader + prSwRfb->u2HeaderLen);
- IE_FOR_EACH(pucIE, u2IELength, u2Offset) {
- if (ELEM_ID_SSID == IE_ID(pucIE)) {
- if ((!prIeSsid) && (IE_LEN(pucIE) <= ELEM_MAX_LEN_SSID))
- prIeSsid = (P_IE_SSID_T) pucIE;
- break;
- }
- } /* end of IE_FOR_EACH */
- IE_FOR_EACH(pucIE, u2IELength, u2Offset) {
- if (ELEM_ID_SSID == IE_ID(pucIE)) {
- if ((!prIeSsid) && (IE_LEN(pucIE) <= ELEM_MAX_LEN_SSID))
- prIeSsid = (P_IE_SSID_T) pucIE;
- break;
- }
- } /* end of IE_FOR_EACH */
- /* 4 <2> Check network conditions */
- /*If BoW AP is beaconing */
- if (prBssInfo->eCurrentOPMode == OP_MODE_BOW && g_u4Beaconing > 0) {
- /*Check the probe requset sender is our peer */
- if (bowCheckBowTableIfVaild(prAdapter, prMgtHdr->aucSrcAddr))
- fgReplyProbeResp = TRUE;
- /*Check the probe request target SSID is our SSID */
- else if ((prIeSsid) &&
- EQUAL_SSID(prBssInfo->aucSSID, prBssInfo->ucSSIDLen, prIeSsid->aucSSID, prIeSsid->ucLength))
- fgReplyProbeResp = TRUE;
- else
- fgReplyProbeResp = FALSE;
- }
- return fgReplyProbeResp;
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * @brief This function will indicate an Event of "Media Disconnect" to HOST
- *
- * @param[in] u4Param Unused timer parameter
- *
- * @return (none)
- */
- /*----------------------------------------------------------------------------*/
- VOID bowSendBeacon(IN P_ADAPTER_T prAdapter, IN ULONG ulParam)
- {
- P_BOW_FSM_INFO_T prBowFsmInfo;
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- if ((g_u4Beaconing != 0) && (g_u4LinkCount > 0) && (g_u4LinkCount < CFG_BOW_PHYSICAL_LINK_NUM)) {
- /* Send beacon */
- bssSendBeaconProbeResponse(prAdapter, NETWORK_TYPE_BOW_INDEX, NULL, 0);
- cnmTimerStartTimer(prAdapter, &prBowFsmInfo->rStartingBeaconTimer, prBowFsmInfo->u2BeaconInterval);
- }
- #if CFG_BOW_TEST
- else
- kalPrint("BoW Send Beacon,[%d,%d]\n", g_u4LinkCount, g_u4Beaconing);
- #endif
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * @brief This function will indicate an Event of "Media Disconnect" to HOST
- *
- * @param[in] u4Param Unused timer parameter
- *
- * @return (none)
- */
- /*----------------------------------------------------------------------------*/
- VOID bowResponderScan(IN P_ADAPTER_T prAdapter)
- {
- P_BOW_FSM_INFO_T prBowFsmInfo;
- P_MSG_SCN_SCAN_REQ prScanReqMsg;
- P_BSS_INFO_T prBssInfo;
- ASSERT(prAdapter);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- prBssInfo = &(prAdapter->rWifiVar.arBssInfo[NETWORK_TYPE_BOW_INDEX]);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowResponderScan.\n");
- kalPrint("BOW SCAN [REQ:%d]\n", prBowFsmInfo->ucSeqNumOfScanReq + 1);
- #endif
- prScanReqMsg = (P_MSG_SCN_SCAN_REQ) cnmMemAlloc(prAdapter, RAM_TYPE_MSG, sizeof(MSG_SCN_SCAN_REQ));
- if (!prScanReqMsg) {
- ASSERT(0); /* Can't trigger SCAN FSM */
- return;
- }
- /*Fill scan message */
- prScanReqMsg->rMsgHdr.eMsgId = MID_BOW_SCN_SCAN_REQ;
- prScanReqMsg->ucSeqNum = ++prBowFsmInfo->ucSeqNumOfScanReq;
- prScanReqMsg->ucNetTypeIndex = (UINT_8) NETWORK_TYPE_BOW_INDEX;
- prScanReqMsg->eScanType = SCAN_TYPE_ACTIVE_SCAN;
- prScanReqMsg->ucSSIDType = SCAN_REQ_SSID_SPECIFIED;
- prScanReqMsg->ucSSIDLength = BOW_SSID_LEN;
- bowAssignSsid(prScanReqMsg->aucSSID, prBowFsmInfo->aucPeerAddress);
- prScanReqMsg->ucChannelListNum = 1;
- if (prBowFsmInfo->eBand == BAND_2G4) {
- prScanReqMsg->eScanChannel = SCAN_CHANNEL_SPECIFIED;
- prScanReqMsg->arChnlInfoList[0].eBand = BAND_2G4;
- } else {
- prScanReqMsg->eScanChannel = SCAN_CHANNEL_5G;
- prScanReqMsg->arChnlInfoList[0].eBand = BAND_5G;
- }
- prScanReqMsg->arChnlInfoList[0].ucChannelNum = prBowFsmInfo->ucPrimaryChannel;
- prScanReqMsg->u2IELen = 0;
- /*Send scan message */
- mboxSendMsg(prAdapter, MBOX_ID_0, (P_MSG_HDR_T) prScanReqMsg, MSG_SEND_METHOD_BUF);
- /*Change state to SCANNING */
- bowSetBowTableState(prAdapter, prBowFsmInfo->aucPeerAddress, BOW_DEVICE_STATE_SCANNING);
- /* prBowFsmInfo->fgTryScan = FALSE; */ /* Will enable background sleep for infrastructure */
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief
- *
- * \param[in]
- *
- * \return none
- */
- /*----------------------------------------------------------------------------*/
- VOID bowResponderScanDone(IN P_ADAPTER_T prAdapter, IN P_MSG_HDR_T prMsgHdr)
- {
- P_MSG_SCN_SCAN_DONE prScanDoneMsg;
- P_BOW_FSM_INFO_T prBowFsmInfo;
- P_BSS_DESC_T prBssDesc;
- UINT_8 ucSeqNumOfCompMsg;
- P_CONNECTION_SETTINGS_T prConnSettings;
- ENUM_BOW_DEVICE_STATE eFsmState;
- ENUM_SCAN_STATUS eScanStatus;
- ASSERT(prAdapter);
- ASSERT(prMsgHdr);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- prConnSettings = &(prAdapter->rWifiVar.rConnSettings);
- prScanDoneMsg = (P_MSG_SCN_SCAN_DONE) prMsgHdr;
- eFsmState = bowGetBowTableState(prAdapter, prBowFsmInfo->aucPeerAddress);
- ASSERT(prScanDoneMsg->ucNetTypeIndex == NETWORK_TYPE_BOW_INDEX);
- ucSeqNumOfCompMsg = prScanDoneMsg->ucSeqNum;
- eScanStatus = prScanDoneMsg->eScanStatus;
- cnmMemFree(prAdapter, prMsgHdr);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowResponderScanDone.\n");
- kalPrint("BOW SCAN [DONE:%d]\n", ucSeqNumOfCompMsg);
- #endif
- if (eScanStatus == SCAN_STATUS_CANCELLED) {
- #if CFG_BOW_TEST
- kalPrint("BOW SCAN [CANCELLED:%d]\n", ucSeqNumOfCompMsg);
- #endif
- if (eFsmState == BOW_DEVICE_STATE_DISCONNECTING) {
- wlanoidSendSetQueryBowCmd(prAdapter,
- CMD_ID_CMD_BT_OVER_WIFI,
- TRUE,
- FALSE,
- wlanbowCmdEventLinkDisconnected,
- wlanbowCmdTimeoutHandler, 0, NULL, 0);
- }
- return;
- } else if (eFsmState == BOW_DEVICE_STATE_DISCONNECTED) {
- /* bowDisconnectLink(prAdapter, NULL, TX_RESULT_SUCCESS); */
- return;
- } else if (ucSeqNumOfCompMsg != prBowFsmInfo->ucSeqNumOfScanReq) {
- DBGLOG(BOW, EVENT, "Sequence no. of BOW Responder scan done is not matched.\n");
- return;
- }
- prConnSettings->fgIsScanReqIssued = FALSE;
- prBssDesc = scanSearchBssDescByBssid(prAdapter, prBowFsmInfo->aucPeerAddress);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "End scan result searching.\n");
- #endif
- /* Initiator is FOUND */
- if (prBssDesc != NULL) {
- /* (prBssDesc->aucBSSID != NULL)) */
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "Search Bow Peer address - %x:%x:%x:%x:%x:%x.\n", prBssDesc->aucBSSID[0],
- prBssDesc->aucBSSID[1],
- prBssDesc->aucBSSID[2],
- prBssDesc->aucBSSID[3], prBssDesc->aucBSSID[4], prBssDesc->aucBSSID[5]);
- DBGLOG(BOW, EVENT, "Starting to join initiator.\n");
- #endif
- /*Set target BssDesc */
- prBowFsmInfo->prTargetBssDesc = prBssDesc;
- /*Request channel to do JOIN */
- bowSetBowTableState(prAdapter, prBowFsmInfo->aucPeerAddress,
- BOW_DEVICE_STATE_ACQUIRING_CHANNEL);
- bowRequestCh(prAdapter);
- }
- /*Initiator is NOT FOUND */
- else {
- /*Scan again, until PAL timeout */
- bowResponderScan(prAdapter);
- #if 0
- wlanoidSendSetQueryBowCmd(prAdapter,
- CMD_ID_CMD_BT_OVER_WIFI,
- TRUE,
- FALSE,
- wlanbowCmdEventLinkDisconnected,
- wlanbowCmdTimeoutHandler, 0, NULL, 0);
- #endif
- }
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * @brief Function for cancelling scan request. There is another option to extend channel privilige
- * for another purpose.
- *
- * @param fgIsChannelExtention - Keep the channel previlege, but can cancel scan timer.
- *
- * @return (none)
- */
- /*----------------------------------------------------------------------------*/
- VOID bowResponderCancelScan(IN P_ADAPTER_T prAdapter, IN BOOLEAN fgIsChannelExtention)
- {
- P_MSG_SCN_SCAN_CANCEL prScanCancel = (P_MSG_SCN_SCAN_CANCEL) NULL;
- P_BOW_FSM_INFO_T prBowFsmInfo = (P_BOW_FSM_INFO_T) NULL;
- DEBUGFUNC("bowResponderCancelScan()");
- do {
- ASSERT(prAdapter);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- if (TRUE) {
- #if CFG_BOW_TEST
- kalPrint("BOW SCAN [CANCEL:%d]\n", prBowFsmInfo->ucSeqNumOfScanReq);
- #endif
- /* There is a channel privilege on hand. */
- DBGLOG(P2P, TRACE, "BOW Cancel Scan\n");
- prScanCancel =
- (P_MSG_SCN_SCAN_CANCEL) cnmMemAlloc(prAdapter, RAM_TYPE_MSG, sizeof(MSG_SCN_SCAN_CANCEL));
- if (!prScanCancel) {
- /* Buffer not enough, can not cancel scan request. */
- DBGLOG(P2P, TRACE, "Buffer not enough, can not cancel scan.\n");
- ASSERT(FALSE);
- break;
- }
- prScanCancel->rMsgHdr.eMsgId = MID_BOW_SCN_SCAN_CANCEL;
- prScanCancel->ucNetTypeIndex = NETWORK_TYPE_BOW_INDEX;
- prScanCancel->ucSeqNum = prBowFsmInfo->ucSeqNumOfScanReq;
- #if CFG_ENABLE_WIFI_DIRECT
- prScanCancel->fgIsChannelExt = fgIsChannelExtention;
- #endif
- mboxSendMsg(prAdapter, MBOX_ID_0, (P_MSG_HDR_T) prScanCancel, MSG_SEND_METHOD_BUF);
- }
- } while (FALSE);
- } /* bowResponderCancelScan */
- /*----------------------------------------------------------------------------*/
- /*!
- * @brief Initialization of JOIN STATE
- *
- * @param[in] prBssDesc The pointer of BSS_DESC_T which is the BSS we will try to join with.
- *
- * @return (none)
- */
- /*----------------------------------------------------------------------------*/
- VOID bowResponderJoin(IN P_ADAPTER_T prAdapter, IN P_BSS_DESC_T prBssDesc)
- {
- P_BOW_FSM_INFO_T prBowFsmInfo;
- P_BSS_INFO_T prBssInfo;
- P_CONNECTION_SETTINGS_T prConnSettings;
- P_STA_RECORD_T prStaRec;
- P_MSG_JOIN_REQ_T prJoinReqMsg;
- ASSERT(prBssDesc);
- ASSERT(prAdapter);
- DBGLOG(BOW, EVENT, "Starting bowResponderJoin.\n");
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- prBssInfo = &(prAdapter->rWifiVar.arBssInfo[NETWORK_TYPE_BOW_INDEX]);
- prConnSettings = &(prAdapter->rWifiVar.rConnSettings);
- /* 4 <1> We are going to connect to this BSS. */
- prBssDesc->fgIsConnecting = TRUE;
- bowSetBowTableState(prAdapter, prBowFsmInfo->aucPeerAddress, BOW_DEVICE_STATE_CONNECTING);
- /* 4 <2> Setup corresponding STA_RECORD_T */
- /*Support First JOIN and retry */
- prStaRec = bssCreateStaRecFromBssDesc(prAdapter, STA_TYPE_BOW_AP, NETWORK_TYPE_BOW_INDEX, prBssDesc);
- if (!prStaRec)
- return;
- prBowFsmInfo->prTargetStaRec = prStaRec;
- /* 4 <3> Update ucAvailableAuthTypes which we can choice during SAA */
- prStaRec->fgIsReAssoc = FALSE;
- prBowFsmInfo->ucAvailableAuthTypes = (UINT_8) AUTH_TYPE_OPEN_SYSTEM;
- prStaRec->ucTxAuthAssocRetryLimit = TX_AUTH_ASSOCI_RETRY_LIMIT;
- /* 4 <4> Use an appropriate Authentication Algorithm Number among the ucAvailableAuthTypes */
- if (prBowFsmInfo->ucAvailableAuthTypes & (UINT_8) AUTH_TYPE_OPEN_SYSTEM) {
- DBGLOG(BOW, LOUD, "JOIN INIT: Try to do Authentication with AuthType == OPEN_SYSTEM.\n");
- prBowFsmInfo->ucAvailableAuthTypes &= ~(UINT_8) AUTH_TYPE_OPEN_SYSTEM;
- prStaRec->ucAuthAlgNum = (UINT_8) AUTH_ALGORITHM_NUM_OPEN_SYSTEM;
- } else {
- ASSERT(0);
- }
- /* 4 <4.1> sync. to firmware domain */
- cnmStaRecChangeState(prAdapter, prStaRec, STA_STATE_1);
- /* 4 <5> Overwrite Connection Setting for eConnectionPolicy */
- if (prBssDesc->ucSSIDLen) {
- COPY_SSID(prConnSettings->aucSSID, prConnSettings->ucSSIDLen, prBssDesc->aucSSID, prBssDesc->ucSSIDLen);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowResponderJoin, SSID %s.\n", prBssDesc->aucSSID);
- DBGLOG(BOW, EVENT, "bowResponderJoin, SSID %s.\n", prConnSettings->aucSSID);
- #endif
- }
- /* 4 <6> Send a Msg to trigger SAA to start JOIN process. */
- prJoinReqMsg = (P_MSG_JOIN_REQ_T) cnmMemAlloc(prAdapter, RAM_TYPE_MSG, sizeof(MSG_JOIN_REQ_T));
- if (!prJoinReqMsg) {
- ASSERT(0); /* Can't trigger SAA FSM */
- return;
- }
- prJoinReqMsg->rMsgHdr.eMsgId = MID_BOW_SAA_FSM_START;
- prJoinReqMsg->ucSeqNum = ++prBowFsmInfo->ucSeqNumOfReqMsg;
- prJoinReqMsg->prStaRec = prStaRec;
- prBssInfo->prStaRecOfAP = prStaRec;
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "prStaRec->eStaType, %x.\n", prStaRec->eStaType);
- DBGLOG(BOW, INFO, "BoW trigger SAA [%pM]\n", prStaRec->aucMacAddr);
- #endif
- mboxSendMsg(prAdapter, MBOX_ID_0, (P_MSG_HDR_T) prJoinReqMsg, MSG_SEND_METHOD_BUF);
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * @brief This function will handle the Join Complete Event from SAA FSM for BOW FSM
- *
- * @param[in] prMsgHdr Message of Join Complete of SAA FSM.
- *
- * @return (none)
- */
- /*----------------------------------------------------------------------------*/
- VOID bowFsmRunEventJoinComplete(IN P_ADAPTER_T prAdapter, IN P_MSG_HDR_T prMsgHdr)
- {
- P_MSG_JOIN_COMP_T prJoinCompMsg;
- P_BOW_FSM_INFO_T prBowFsmInfo;
- P_STA_RECORD_T prStaRec;
- P_SW_RFB_T prAssocRspSwRfb;
- P_BSS_INFO_T prBssInfo;
- P_WLAN_ASSOC_RSP_FRAME_T prAssocRspFrame = (P_WLAN_ASSOC_RSP_FRAME_T) NULL;
- UINT_16 u2IELength;
- PUINT_8 pucIE;
- P_BSS_INFO_T prBowBssInfo = &(prAdapter->rWifiVar.arBssInfo[NETWORK_TYPE_BOW_INDEX]);
- ASSERT(prAdapter);
- ASSERT(prMsgHdr);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- prJoinCompMsg = (P_MSG_JOIN_COMP_T) prMsgHdr;
- prStaRec = prJoinCompMsg->prStaRec;
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "Start bowfsmRunEventJoinComplete.\n");
- DBGLOG(BOW, EVENT, "bowfsmRunEventJoinComplete ptr check\n");
- DBGLOG(BOW, EVENT, "prMsgHdr %x\n", prMsgHdr);
- DBGLOG(BOW, EVENT, "prAdapter %x\n", prAdapter);
- DBGLOG(BOW, EVENT, "prBowFsmInfo %x\n", prBowFsmInfo);
- DBGLOG(BOW, EVENT, "prStaRec %x\n", prStaRec);
- #endif
- ASSERT(prStaRec);
- ASSERT(prBowFsmInfo);
- /* Check SEQ NUM */
- if (prJoinCompMsg->ucSeqNum == prBowFsmInfo->ucSeqNumOfReqMsg) {
- COPY_MAC_ADDR(prBowFsmInfo->aucPeerAddress, prStaRec->aucMacAddr);
- /* 4 <1> JOIN was successful */
- if (prJoinCompMsg->rJoinStatus == WLAN_STATUS_SUCCESS) {
- prAssocRspSwRfb = prJoinCompMsg->prSwRfb;
- prAssocRspFrame = (P_WLAN_ASSOC_RSP_FRAME_T) prAssocRspSwRfb->pvHeader;
- prBssInfo = &(prAdapter->rWifiVar.arBssInfo[NETWORK_TYPE_BOW_INDEX]);
- u2IELength = (UINT_16) ((prAssocRspSwRfb->u2PacketLen - prAssocRspSwRfb->u2HeaderLen) -
- (OFFSET_OF(WLAN_ASSOC_RSP_FRAME_T, aucInfoElem[0]) -
- WLAN_MAC_MGMT_HEADER_LEN));
- pucIE = prAssocRspFrame->aucInfoElem;
- prStaRec->eStaType = STA_TYPE_BOW_AP;
- prStaRec->u2DesiredNonHTRateSet &= prBowBssInfo->u2OperationalRateSet;
- prStaRec->ucDesiredPhyTypeSet = prStaRec->ucPhyTypeSet & prBowBssInfo->ucPhyTypeSet;
- #if CFG_BOW_RATE_LIMITATION
- /* 4 <1.2>Update Rate Set */
- /*Limit Rate Set to 24M, 48M, 54M */
- prStaRec->u2DesiredNonHTRateSet &= (RATE_SET_BIT_24M | RATE_SET_BIT_48M | RATE_SET_BIT_54M);
- /*If peer cannot support the above rate set, fix on the available highest rate */
- if (prStaRec->u2DesiredNonHTRateSet == 0) {
- UINT_8 ucHighestRateIndex;
- if (rateGetHighestRateIndexFromRateSet
- (prBowBssInfo->u2OperationalRateSet, &ucHighestRateIndex)) {
- prStaRec->u2DesiredNonHTRateSet = BIT(ucHighestRateIndex);
- }
- }
- #endif
- /* 4 <1.1> Change FW's Media State immediately. */
- bowChangeMediaState(prAdapter, PARAM_MEDIA_STATE_CONNECTED);
- mqmProcessAssocRsp(prAdapter, prAssocRspSwRfb, pucIE, u2IELength);
- /* 4 <1.2> Update HT information and set channel */
- /* Record HT related parameters in rStaRec and rBssInfo
- * Note: it shall be called before nicUpdateBss()
- */
- #if CFG_BOW_SUPPORT_11N
- rlmProcessAssocRsp(prAdapter, prAssocRspSwRfb, pucIE, u2IELength);
- #endif
- /* 4 <1.3> Update BSS_INFO_T */
- nicUpdateBss(prAdapter, NETWORK_TYPE_BOW_INDEX);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "Finish bowUpdateBssInfoForJOIN.\n");
- #endif
- /* 4 <1.4> Activate current AP's STA_RECORD_T in Driver. */
- cnmStaRecChangeState(prAdapter, prStaRec, STA_STATE_3);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowFsmRunEventJoinComplete, qmActivateStaRec.\n");
- #endif
- /* 4 <1.7> Set the Next State of BOW FSM */
- wlanoidSendSetQueryBowCmd(prAdapter,
- CMD_ID_CMD_BT_OVER_WIFI,
- TRUE,
- FALSE,
- wlanbowCmdEventLinkConnected, wlanbowCmdTimeoutHandler, 0, NULL, 0);
- }
- /* 4 <2> JOIN was not successful */
- else {
- /*Retry */
- bowResponderJoin(prAdapter, prBowFsmInfo->prTargetBssDesc);
- #if 0
- wlanoidSendSetQueryBowCmd(prAdapter,
- CMD_ID_CMD_BT_OVER_WIFI,
- TRUE,
- FALSE,
- wlanbowCmdEventLinkDisconnected,
- wlanbowCmdTimeoutHandler, 0, NULL, 0);
- #endif
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "Start bowfsmRunEventJoinComplete -- Join failed.\n");
- DBGLOG(BOW, INFO, "BoW trigger SAA REJOIN\n");
- #endif
- }
- }
- cnmMemFree(prAdapter, prMsgHdr);
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * @brief This function will indicate the Media State to HOST
- *
- * @param[in] eConnectionState Current Media State
- * @param[in] fgDelayIndication Set TRUE for postponing the Disconnect Indication.
- *
- * @return (none)
- */
- /*----------------------------------------------------------------------------*/
- VOID
- bowIndicationOfMediaStateToHost(IN P_ADAPTER_T prAdapter,
- IN ENUM_PARAM_MEDIA_STATE_T eConnectionState, IN BOOLEAN fgDelayIndication)
- {
- EVENT_CONNECTION_STATUS rEventConnStatus;
- P_CONNECTION_SETTINGS_T prConnSettings;
- P_BSS_INFO_T prBssInfo;
- P_BOW_FSM_INFO_T prBowFsmInfo;
- prConnSettings = &(prAdapter->rWifiVar.rConnSettings);
- prBssInfo = &(prAdapter->rWifiVar.arBssInfo[NETWORK_TYPE_BOW_INDEX]);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- /* NOTE(Kevin): Move following line to bowChangeMediaState() macro per CM's request. */
- /* prBowBssInfo->eConnectionState = eConnectionState; */
- /* For indicating the Disconnect Event only if current media state is
- * disconnected and we didn't do indication yet.
- */
- if (prBssInfo->eConnectionState == PARAM_MEDIA_STATE_DISCONNECTED) {
- if (prBssInfo->eConnectionStateIndicated == eConnectionState)
- return;
- }
- if (!fgDelayIndication) {
- /* 4 <0> Cancel Delay Timer */
- cnmTimerStopTimer(prAdapter, &prBowFsmInfo->rIndicationOfDisconnectTimer);
- /* 4 <1> Fill EVENT_CONNECTION_STATUS */
- rEventConnStatus.ucMediaStatus = (UINT_8) eConnectionState;
- if (eConnectionState == PARAM_MEDIA_STATE_CONNECTED) {
- rEventConnStatus.ucReasonOfDisconnect = DISCONNECT_REASON_CODE_RESERVED;
- if (prBssInfo->eCurrentOPMode == OP_MODE_BOW) {
- rEventConnStatus.ucInfraMode = (UINT_8) NET_TYPE_INFRA;
- rEventConnStatus.u2AID = prBssInfo->u2AssocId;
- rEventConnStatus.u2ATIMWindow = 0;
- } else if (prBssInfo->eCurrentOPMode == OP_MODE_IBSS) {
- rEventConnStatus.ucInfraMode = (UINT_8) NET_TYPE_IBSS;
- rEventConnStatus.u2AID = 0;
- rEventConnStatus.u2ATIMWindow = prBssInfo->u2ATIMWindow;
- } else {
- ASSERT(0);
- }
- COPY_SSID(rEventConnStatus.aucSsid,
- rEventConnStatus.ucSsidLen, prConnSettings->aucSSID, prConnSettings->ucSSIDLen);
- COPY_MAC_ADDR(rEventConnStatus.aucBssid, prBssInfo->aucBSSID);
- rEventConnStatus.u2BeaconPeriod = prBssInfo->u2BeaconInterval;
- rEventConnStatus.u4FreqInKHz = nicChannelNum2Freq(prBssInfo->ucPrimaryChannel);
- switch (prBssInfo->ucNonHTBasicPhyType) {
- case PHY_TYPE_HR_DSSS_INDEX:
- rEventConnStatus.ucNetworkType = (UINT_8) PARAM_NETWORK_TYPE_DS;
- break;
- case PHY_TYPE_ERP_INDEX:
- rEventConnStatus.ucNetworkType = (UINT_8) PARAM_NETWORK_TYPE_OFDM24;
- break;
- case PHY_TYPE_OFDM_INDEX:
- rEventConnStatus.ucNetworkType = (UINT_8) PARAM_NETWORK_TYPE_OFDM5;
- break;
- default:
- ASSERT(0);
- rEventConnStatus.ucNetworkType = (UINT_8) PARAM_NETWORK_TYPE_DS;
- break;
- }
- } else {
- #if CFG_PRIVACY_MIGRATION
- /* Clear the pmkid cache while media disconnect */
- secClearPmkid(prAdapter);
- #endif
- rEventConnStatus.ucReasonOfDisconnect = prBssInfo->ucReasonOfDisconnect;
- }
- /* 4 <2> Indication */
- nicMediaStateChange(prAdapter, NETWORK_TYPE_BOW_INDEX, &rEventConnStatus);
- prBssInfo->eConnectionStateIndicated = eConnectionState;
- } else {
- /* NOTE: Only delay the Indication of Disconnect Event */
- ASSERT(eConnectionState == PARAM_MEDIA_STATE_DISCONNECTED);
- DBGLOG(BOW, INFO, "Postpone the indication of Disconnect for %d seconds\n",
- prConnSettings->ucDelayTimeOfDisconnectEvent);
- cnmTimerStartTimer(prAdapter,
- &prBowFsmInfo->rIndicationOfDisconnectTimer,
- SEC_TO_MSEC(prConnSettings->ucDelayTimeOfDisconnectEvent));
- }
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * @brief This function will indicate the Event of Tx Fail of AAA Module.
- *
- * @param[in] prAdapter Pointer to the Adapter structure.
- * @param[in] prStaRec Pointer to the STA_RECORD_T
- *
- * @return (none)
- */
- /*----------------------------------------------------------------------------*/
- VOID bowRunEventAAATxFail(IN P_ADAPTER_T prAdapter, IN P_STA_RECORD_T prStaRec)
- {
- P_BSS_INFO_T prBssInfo;
- ASSERT(prAdapter);
- ASSERT(prStaRec);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowRunEventAAATxFail , bssRemoveStaRecFromClientList.\n");
- DBGLOG(BOW, INFO, "BoW AAA TxFail, target state %d\n", prStaRec->ucStaState + 1);
- #endif
- prBssInfo = &(prAdapter->rWifiVar.arBssInfo[prStaRec->ucNetTypeIndex]);
- bssRemoveStaRecFromClientList(prAdapter, prBssInfo, prStaRec);
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * @brief This function will indicate the Event of Successful Completion of AAA Module.
- *
- * @param[in] prAdapter Pointer to the Adapter structure.
- * @param[in] prStaRec Pointer to the STA_RECORD_T
- *
- * @return (none)
- */
- /*----------------------------------------------------------------------------*/
- WLAN_STATUS bowRunEventAAAComplete(IN P_ADAPTER_T prAdapter, IN P_STA_RECORD_T prStaRec)
- {
- P_BOW_FSM_INFO_T prBowFsmInfo;
- ASSERT(prStaRec);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowRunEventAAAComplete, cnmStaRecChangeState, STA_STATE_3.\n");
- DBGLOG(BOW, INFO, "BoW AAA complete [%pM]\n", prStaRec->aucMacAddr);
- #endif
- /*Update BssInfo to connected */
- bowChangeMediaState(prAdapter, PARAM_MEDIA_STATE_CONNECTED);
- nicUpdateBss(prAdapter, NETWORK_TYPE_BOW_INDEX);
- /*Update StaRec to State3 */
- cnmStaRecChangeState(prAdapter, prStaRec, STA_STATE_3);
- /*Connected */
- wlanoidSendSetQueryBowCmd(prAdapter,
- CMD_ID_CMD_BT_OVER_WIFI,
- TRUE, FALSE, wlanbowCmdEventLinkConnected, wlanbowCmdTimeoutHandler, 0, NULL, 0);
- return WLAN_STATUS_SUCCESS;
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * @brief This function will handle RxDeauth
- *
- * @param[in] prAdapter Pointer to the Adapter structure.
- * @param[in] prStaRec Pointer to the STA_RECORD_T
- *
- * @return (none)
- */
- /*----------------------------------------------------------------------------*/
- WLAN_STATUS bowRunEventRxDeAuth(IN P_ADAPTER_T prAdapter, IN P_STA_RECORD_T prStaRec, IN P_SW_RFB_T prSwRfb)
- {
- P_BSS_INFO_T prBowBssInfo;
- P_BOW_FSM_INFO_T prBowFsmInfo;
- ENUM_BOW_DEVICE_STATE eFsmState;
- ASSERT(prAdapter);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- prBowBssInfo = &(prAdapter->rWifiVar.arBssInfo[NETWORK_TYPE_BOW_INDEX]);
- if (!IS_STA_IN_BOW(prStaRec))
- return WLAN_STATUS_NOT_ACCEPTED;
- eFsmState = bowGetBowTableState(prAdapter, prStaRec->aucMacAddr);
- if (eFsmState == BOW_DEVICE_STATE_DISCONNECTED) {
- /*do nothing */
- return WLAN_STATUS_NOT_ACCEPTED;
- }
- if (prStaRec->ucStaState > STA_STATE_1) {
- if (STA_STATE_3 == prStaRec->ucStaState) {
- /* P_MSG_AIS_ABORT_T prAisAbortMsg; */
- /* NOTE(Kevin): Change state immediately to avoid starvation of
- * MSG buffer because of too many deauth frames before changing
- * the STA state.
- */
- cnmStaRecChangeState(prAdapter, prStaRec, STA_STATE_1);
- }
- COPY_MAC_ADDR(prBowFsmInfo->aucPeerAddress, prStaRec->aucMacAddr);
- wlanoidSendSetQueryBowCmd(prAdapter,
- CMD_ID_CMD_BT_OVER_WIFI,
- TRUE,
- FALSE, wlanbowCmdEventLinkDisconnected, wlanbowCmdTimeoutHandler, 0, NULL, 0);
- return WLAN_STATUS_SUCCESS;
- }
- return WLAN_STATUS_NOT_ACCEPTED;
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This function handle BoW Link disconnect.
- *
- * \param[in] pMsduInfo Pointer to the Msdu Info
- * \param[in] rStatus The Tx done status
- *
- * \return -
- *
- * \note after receive deauth frame, callback function call this
- */
- /*----------------------------------------------------------------------------*/
- VOID bowDisconnectLink(IN P_ADAPTER_T prAdapter, IN P_MSDU_INFO_T prMsduInfo, IN ENUM_TX_RESULT_CODE_T rTxDoneStatus)
- {
- P_BOW_FSM_INFO_T prBowFsmInfo;
- P_STA_RECORD_T prStaRec;
- ASSERT(prAdapter);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- /*Free target StaRec */
- if (prMsduInfo)
- prStaRec = cnmGetStaRecByIndex(prAdapter, prMsduInfo->ucStaRecIndex);
- else
- prStaRec = prBowFsmInfo->prTargetStaRec;
- if (prStaRec)
- /* cnmStaRecFree(prAdapter, prStaRec, TRUE); */
- cnmStaRecChangeState(prAdapter, prStaRec, STA_STATE_1);
- kalPrint("bowDisconnectLink\n");
- /*No one connected */
- if (g_u4LinkCount == 0 && g_u4Beaconing != 0) {
- cnmTimerStopTimer(prAdapter, &prBowFsmInfo->rStartingBeaconTimer);
- bowStopping(prAdapter);
- kalPrint("bowStopping\n");
- /*Restore TxPower from Short range mode */
- #if CFG_SUPPORT_NVRAM && 0
- wlanLoadManufactureData(prAdapter, kalGetConfiguration(prAdapter->prGlueInfo));
- #endif
- /*Uninit BoW Interface */
- #if CFG_BOW_SEPARATE_DATA_PATH
- kalUninitBowDevice(prAdapter->prGlueInfo);
- #endif
- }
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * @brief This function will validate the Rx Assoc Req Frame and then return
- * the status code to AAA to indicate if need to perform following actions
- * when the specified conditions were matched.
- *
- * @param[in] prAdapter Pointer to the Adapter structure.
- * @param[in] prSwRfb Pointer to SW RFB data structure.
- * @param[out] pu2StatusCode The Status Code of Validation Result
- *
- * @retval TRUE Reply the Assoc Resp
- * @retval FALSE Don't reply the Assoc Resp
- */
- /*----------------------------------------------------------------------------*/
- BOOLEAN bowValidateAssocReq(IN P_ADAPTER_T prAdapter, IN P_SW_RFB_T prSwRfb, OUT PUINT_16 pu2StatusCode)
- {
- BOOLEAN fgReplyAssocResp = FALSE;
- P_BSS_INFO_T prBowBssInfo = &(prAdapter->rWifiVar.arBssInfo[NETWORK_TYPE_BOW_INDEX]);
- P_STA_RECORD_T prStaRec = (P_STA_RECORD_T) NULL;
- P_BOW_FSM_INFO_T prBowFsmInfo;
- P_WLAN_ASSOC_REQ_FRAME_T prAssocReqFrame = (P_WLAN_ASSOC_REQ_FRAME_T) NULL;
- OS_SYSTIME rCurrentTime;
- static OS_SYSTIME rLastRejectAssocTime;
- ASSERT(prAdapter);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- prAssocReqFrame = (P_WLAN_ASSOC_REQ_FRAME_T) prSwRfb->pvHeader;
- *pu2StatusCode = STATUS_CODE_REQ_DECLINED;
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowValidateAssocReq, prBowFsmInfo->aucPeerAddress, %x:%x:%x:%x:%x:%x.\n",
- prBowFsmInfo->aucPeerAddress[0],
- prBowFsmInfo->aucPeerAddress[1],
- prBowFsmInfo->aucPeerAddress[2],
- prBowFsmInfo->aucPeerAddress[3],
- prBowFsmInfo->aucPeerAddress[4], prBowFsmInfo->aucPeerAddress[5]));
- DBGLOG(BOW, EVENT, "bowValidateAssocReq, prAssocReqFrame->aucSrcAddr, %x:%x:%x:%x:%x:%x.\n",
- prAssocReqFrame->aucSrcAddr[0],
- prAssocReqFrame->aucSrcAddr[1],
- prAssocReqFrame->aucSrcAddr[2],
- prAssocReqFrame->aucSrcAddr[3],
- prAssocReqFrame->aucSrcAddr[4], prAssocReqFrame->aucSrcAddr[5]));
- #endif
- /*Assoc Accept */
- while (EQUAL_MAC_ADDR(prAssocReqFrame->aucSrcAddr, prBowFsmInfo->aucPeerAddress)) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowValidateAssocReq, return wlanbowCmdEventLinkConnected.\n");
- #endif
- /*Update StaRec */
- prStaRec = cnmGetStaRecByAddress(prAdapter,
- (UINT_8) NETWORK_TYPE_BOW_INDEX, prAssocReqFrame->aucSrcAddr);
- if (!prStaRec)
- break;
- prStaRec->eStaType = STA_TYPE_BOW_CLIENT;
- prStaRec->u2DesiredNonHTRateSet &= prBowBssInfo->u2OperationalRateSet;
- prStaRec->ucDesiredPhyTypeSet = prStaRec->ucPhyTypeSet & prBowBssInfo->ucPhyTypeSet;
- #if CFG_BOW_RATE_LIMITATION
- /*Limit Rate Set to 24M, 48M, 54M */
- prStaRec->u2DesiredNonHTRateSet &= (RATE_SET_BIT_24M | RATE_SET_BIT_48M | RATE_SET_BIT_54M);
- /*If peer cannot support the above rate set, fix on the available highest rate */
- if (prStaRec->u2DesiredNonHTRateSet == 0) {
- UINT_8 ucHighestRateIndex;
- if (rateGetHighestRateIndexFromRateSet(prBowBssInfo->u2OperationalRateSet, &ucHighestRateIndex))
- prStaRec->u2DesiredNonHTRateSet = BIT(ucHighestRateIndex);
- else {
- /*If no available rate is found, DECLINE the association */
- *pu2StatusCode = STATUS_CODE_ASSOC_DENIED_RATE_NOT_SUPPORTED;
- break;
- }
- }
- #endif
- prStaRec->ucNetTypeIndex = NETWORK_TYPE_BOW_INDEX;
- /*Undpate BssInfo to FW */
- bowChangeMediaState(prAdapter, PARAM_MEDIA_STATE_CONNECTED);
- nicUpdateBss(prAdapter, NETWORK_TYPE_BOW_INDEX);
- /*reply successful */
- *pu2StatusCode = STATUS_CODE_SUCCESSFUL;
- fgReplyAssocResp = TRUE;
- break;
- }
- /*Reject Assoc */
- if (*pu2StatusCode != STATUS_CODE_SUCCESSFUL) {
- /*Reply Assoc with reject every 5s */
- rCurrentTime = kalGetTimeTick();
- if (CHECK_FOR_TIMEOUT(rCurrentTime, rLastRejectAssocTime, MSEC_TO_SYSTIME(5000)) ||
- rLastRejectAssocTime == 0) {
- fgReplyAssocResp = TRUE;
- rLastRejectAssocTime = rCurrentTime;
- }
- }
- return fgReplyAssocResp;
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * @brief This function will validate the Rx Auth Frame and then return
- * the status code to AAA to indicate if need to perform following actions
- * when the specified conditions were matched.
- *
- * @param[in] prAdapter Pointer to the Adapter structure.
- * @param[in] prSwRfb Pointer to SW RFB data structure.
- * @param[in] pprStaRec Pointer to pointer of STA_RECORD_T structure.
- * @param[out] pu2StatusCode The Status Code of Validation Result
- *
- * @retval TRUE Reply the Auth
- * @retval FALSE Don't reply the Auth
- */
- /*----------------------------------------------------------------------------*/
- BOOLEAN
- bowValidateAuth(IN P_ADAPTER_T prAdapter,
- IN P_SW_RFB_T prSwRfb, IN PP_STA_RECORD_T pprStaRec, OUT PUINT_16 pu2StatusCode)
- {
- BOOLEAN fgReplyAuth = FALSE;
- P_BSS_INFO_T prBowBssInfo = &(prAdapter->rWifiVar.arBssInfo[NETWORK_TYPE_BOW_INDEX]);
- P_STA_RECORD_T prStaRec = (P_STA_RECORD_T) NULL;
- P_BOW_FSM_INFO_T prBowFsmInfo;
- P_WLAN_AUTH_FRAME_T prAuthFrame = (P_WLAN_AUTH_FRAME_T) NULL;
- OS_SYSTIME rCurrentTime;
- static OS_SYSTIME rLastRejectAuthTime;
- /* TODO(Kevin): Call BoW functions to check ..
- 1. Check we are BoW now.
- 2. Check we can accept connection from thsi peer
- 3. Check Black List here.
- */
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- prAuthFrame = (P_WLAN_AUTH_FRAME_T) prSwRfb->pvHeader;
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowValidateAuth, prBowFsmInfo->aucPeerAddress, %x:%x:%x:%x:%x:%x.\n",
- prBowFsmInfo->aucPeerAddress[0],
- prBowFsmInfo->aucPeerAddress[1],
- prBowFsmInfo->aucPeerAddress[2],
- prBowFsmInfo->aucPeerAddress[3],
- prBowFsmInfo->aucPeerAddress[4], prBowFsmInfo->aucPeerAddress[5]));
- DBGLOG(BOW, EVENT, "bowValidateAuth, prAuthFrame->aucSrcAddr, %x:%x:%x:%x:%x:%x.\n",
- prAuthFrame->aucSrcAddr[0],
- prAuthFrame->aucSrcAddr[1],
- prAuthFrame->aucSrcAddr[2],
- prAuthFrame->aucSrcAddr[3], prAuthFrame->aucSrcAddr[4], prAuthFrame->aucSrcAddr[5]));
- #endif
- prStaRec = cnmGetStaRecByAddress(prAdapter, (UINT_8) NETWORK_TYPE_BOW_INDEX, prAuthFrame->aucSrcAddr);
- if (!prStaRec) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowValidateAuth, cnmStaRecAlloc.\n");
- #endif
- prStaRec = cnmStaRecAlloc(prAdapter, (UINT_8) NETWORK_TYPE_BOW_INDEX);
- /* TODO(Kevin): Error handling of allocation of STA_RECORD_T for
- * exhausted case and do removal of unused STA_RECORD_T.
- */
- if (!prStaRec)
- return fgReplyAuth;
- COPY_MAC_ADDR(prStaRec->aucMacAddr, prAuthFrame->aucSrcAddr);
- prSwRfb->ucStaRecIdx = prStaRec->ucIndex;
- prBowBssInfo->prStaRecOfAP = prStaRec;
- /* NOTE(Kevin): Better to change state here, not at TX Done */
- cnmStaRecChangeState(prAdapter, prStaRec, STA_STATE_1);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowValidateAuth, cnmStaRecChangeState.\n");
- #endif
- } else {
- prSwRfb->ucStaRecIdx = prStaRec->ucIndex;
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowValidateAuth, prStaRec->ucIndex, %x.\n", prStaRec->ucIndex);
- #endif
- bssRemoveStaRecFromClientList(prAdapter, prBowBssInfo, prStaRec);
- }
- if (EQUAL_MAC_ADDR(prAuthFrame->aucSrcAddr, prBowFsmInfo->aucPeerAddress)) {
- prStaRec->eStaType = STA_TYPE_BOW_CLIENT;
- prStaRec->ucNetTypeIndex = NETWORK_TYPE_BOW_INDEX;
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowValidateAuth, prStaRec->eStaType, %x.\n", prStaRec->eStaType);
- DBGLOG(BOW, EVENT, "bowValidateAuth, prStaRec->ucNetTypeIndex, %x.\n", prStaRec->ucNetTypeIndex);
- #endif
- /* Update Station Record - Status/Reason Code */
- prStaRec->u2StatusCode = STATUS_CODE_SUCCESSFUL;
- prStaRec->ucJoinFailureCount = 0;
- *pprStaRec = prStaRec;
- *pu2StatusCode = STATUS_CODE_SUCCESSFUL;
- fgReplyAuth = TRUE;
- } else {
- cnmStaRecFree(prAdapter, prStaRec, FALSE);
- *pu2StatusCode = STATUS_CODE_REQ_DECLINED;
- /*Reply auth with reject every 5s */
- rCurrentTime = kalGetTimeTick();
- if (CHECK_FOR_TIMEOUT(rCurrentTime, rLastRejectAuthTime, MSEC_TO_SYSTIME(5000)) ||
- rLastRejectAuthTime == 0) {
- fgReplyAuth = TRUE;
- rLastRejectAuthTime = rCurrentTime;
- }
- }
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowValidateAuth, fgReplyAuth, %x.\n", fgReplyAuth);
- #endif
- return fgReplyAuth;
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This function is invoked when CNM granted channel privilege
- *
- * \param[in] prAdapter Pointer of ADAPTER_T
- *
- * \return none
- */
- /*----------------------------------------------------------------------------*/
- VOID bowRunEventChGrant(IN P_ADAPTER_T prAdapter, IN P_MSG_HDR_T prMsgHdr)
- {
- P_BSS_INFO_T prBowBssInfo;
- P_BOW_FSM_INFO_T prBowFsmInfo;
- P_MSG_CH_GRANT_T prMsgChGrant;
- UINT_8 ucTokenID;
- UINT_32 u4GrantInterval;
- ENUM_BOW_DEVICE_STATE eFsmState;
- ASSERT(prAdapter);
- ASSERT(prMsgHdr);
- prBowBssInfo = &(prAdapter->rWifiVar.arBssInfo[NETWORK_TYPE_BOW_INDEX]);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- prMsgChGrant = (P_MSG_CH_GRANT_T) prMsgHdr;
- ucTokenID = prMsgChGrant->ucTokenID;
- u4GrantInterval = prMsgChGrant->u4GrantInterval;
- /* 1. free message */
- cnmMemFree(prAdapter, prMsgHdr);
- prBowFsmInfo->fgIsChannelGranted = TRUE;
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "Entering bowRunEventChGrant.\n");
- #endif
- eFsmState = bowGetBowTableState(prAdapter, prBowFsmInfo->aucPeerAddress);
- /*Release channel */
- if ((!prBowFsmInfo->fgIsChannelRequested) ||
- (prBowFsmInfo->ucSeqNumOfChReq != ucTokenID) ||
- (eFsmState == BOW_DEVICE_STATE_DISCONNECTED) || (eFsmState == BOW_DEVICE_STATE_DISCONNECTING)) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, INFO, "BoW Channel [GIVE UP:%d]\n", ucTokenID);
- DBGLOG(BOW, INFO, "[Requested:%d][ucSeqNumOfChReq:%d][eFsmState:%d]\n",
- prBowFsmInfo->fgIsChannelRequested, prBowFsmInfo->ucSeqNumOfChReq, eFsmState);
- #endif
- bowReleaseCh(prAdapter);
- return;
- }
- /* 2. channel privilege has been approved */
- prBowFsmInfo->u4ChGrantedInterval = u4GrantInterval;
- #if 0
- cnmTimerStartTimer(prAdapter,
- &prBowFsmInfo->rChGrantedTimer,
- prBowFsmInfo->u4ChGrantedInterval - BOW_JOIN_CH_GRANT_THRESHOLD);
- #else
- cnmTimerStartTimer(prAdapter,
- &prBowFsmInfo->rChGrantedTimer, BOW_JOIN_CH_REQUEST_INTERVAL - BOW_JOIN_CH_GRANT_THRESHOLD);
- #endif
- /* 3.2 set local variable to indicate join timer is ticking */
- prBowFsmInfo->fgIsInfraChannelFinished = FALSE;
- #if CFG_BOW_TEST
- DBGLOG(BOW, INFO, "BoW Channel [GRANTED:%d].\n", ucTokenID);
- #endif
- if (eFsmState == BOW_DEVICE_STATE_ACQUIRING_CHANNEL) {
- bowStarting(prAdapter);
- bowReleaseCh(prAdapter);
- if (prBowFsmInfo->ucRole == BOW_RESPONDER)
- bowResponderJoin(prAdapter, prBowFsmInfo->prTargetBssDesc);
- } else {
- /*update bssinfo */
- nicUpdateBss(prAdapter, NETWORK_TYPE_BOW_INDEX);
- bowReleaseCh(prAdapter);
- }
- } /* end of aisFsmRunEventChGrant() */
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This function is to inform CNM for channel privilege requesting
- * has been released
- *
- * \param[in] prAdapter Pointer of ADAPTER_T
- *
- * \return none
- */
- /*----------------------------------------------------------------------------*/
- VOID bowRequestCh(IN P_ADAPTER_T prAdapter)
- {
- P_BOW_FSM_INFO_T prBowFsmInfo;
- P_MSG_CH_REQ_T prMsgChReq;
- ASSERT(prAdapter);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- if (prBowFsmInfo->fgIsChannelGranted == FALSE) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, INFO, "BoW channel [REQUEST:%d], %d, %d.\n", prBowFsmInfo->ucSeqNumOfChReq + 1,
- prBowFsmInfo->ucPrimaryChannel, prBowFsmInfo->eBand);
- #endif
- prMsgChReq = (P_MSG_CH_REQ_T) cnmMemAlloc(prAdapter, RAM_TYPE_MSG, sizeof(MSG_CH_REQ_T));
- if (!prMsgChReq) {
- ASSERT(0); /* Can't indicate CNM for channel acquiring */
- return;
- }
- prMsgChReq->rMsgHdr.eMsgId = MID_MNY_CNM_CH_REQ;
- prMsgChReq->ucNetTypeIndex = NETWORK_TYPE_BOW_INDEX;
- prMsgChReq->ucTokenID = ++prBowFsmInfo->ucSeqNumOfChReq;
- prMsgChReq->eReqType = CH_REQ_TYPE_JOIN;
- #if 0
- prMsgChReq->u4MaxInterval = BOW_JOIN_CH_REQUEST_INTERVAL;
- #else
- prMsgChReq->u4MaxInterval = 1;
- #endif
- /* prBowFsmInfo->prTargetBssDesc->ucChannelNum; */
- prMsgChReq->ucPrimaryChannel = prBowFsmInfo->ucPrimaryChannel;
- /* prBowFsmInfo->prTargetBssDesc->eSco; */
- prMsgChReq->eRfSco = CHNL_EXT_SCN;
- /* prBowFsmInfo->prTargetBssDesc->eBand; */
- prMsgChReq->eRfBand = prBowFsmInfo->eBand;
- COPY_MAC_ADDR(prMsgChReq->aucBSSID, prBowFsmInfo->aucPeerAddress);
- prBowFsmInfo->fgIsChannelRequested = TRUE;
- mboxSendMsg(prAdapter, MBOX_ID_0, (P_MSG_HDR_T) prMsgChReq, MSG_SEND_METHOD_BUF);
- }
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief This function is to inform BOW that channel privilege is granted
- * has been released
- *
- * \param[in] prAdapter Pointer of ADAPTER_T
- *
- * \return none
- */
- /*----------------------------------------------------------------------------*/
- VOID bowReleaseCh(IN P_ADAPTER_T prAdapter)
- {
- P_BOW_FSM_INFO_T prBowFsmInfo;
- P_MSG_CH_ABORT_T prMsgChAbort;
- ASSERT(prAdapter);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- if (prBowFsmInfo->fgIsChannelGranted != FALSE || prBowFsmInfo->fgIsChannelRequested != FALSE) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, INFO, "BoW channel [RELEASE:%d] %d, %d.\n", prBowFsmInfo->ucSeqNumOfChReq,
- prBowFsmInfo->ucPrimaryChannel, prBowFsmInfo->eBand);
- #endif
- prBowFsmInfo->fgIsChannelRequested = FALSE;
- prBowFsmInfo->fgIsChannelGranted = FALSE;
- /* 1. return channel privilege to CNM immediately */
- prMsgChAbort = (P_MSG_CH_ABORT_T) cnmMemAlloc(prAdapter, RAM_TYPE_MSG, sizeof(MSG_CH_ABORT_T));
- if (!prMsgChAbort) {
- ASSERT(0); /* Can't release Channel to CNM */
- return;
- }
- prMsgChAbort->rMsgHdr.eMsgId = MID_MNY_CNM_CH_ABORT;
- prMsgChAbort->ucNetTypeIndex = NETWORK_TYPE_BOW_INDEX;
- prMsgChAbort->ucTokenID = prBowFsmInfo->ucSeqNumOfChReq;
- mboxSendMsg(prAdapter, MBOX_ID_0, (P_MSG_HDR_T) prMsgChAbort, MSG_SEND_METHOD_BUF);
- }
- } /* end of aisFsmReleaseCh() */
- /*----------------------------------------------------------------------------*/
- /*!
- * @brief This function will indicate an Event of "Media Disconnect" to HOST
- *
- * @param[in] u4Param Unused timer parameter
- *
- * @return (none)
- */
- /*----------------------------------------------------------------------------*/
- VOID bowChGrantedTimeout(IN P_ADAPTER_T prAdapter, IN ULONG ulParam)
- {
- P_BOW_FSM_INFO_T prBowFsmInfo;
- ENUM_BOW_DEVICE_STATE eFsmState;
- ASSERT(prAdapter);
- prBowFsmInfo = &(prAdapter->rWifiVar.rBowFsmInfo);
- #if CFG_BOW_TEST
- DBGLOG(BOW, INFO, "BoW Channel [TIMEOUT]\n");
- #endif
- #if 1
- /* bowReleaseCh(prAdapter); */
- eFsmState = bowGetBowTableState(prAdapter, prBowFsmInfo->aucPeerAddress);
- /*If connecting is not completed, request CH again */
- if ((eFsmState == BOW_DEVICE_STATE_CONNECTING) || (eFsmState == BOW_DEVICE_STATE_STARTING))
- bowRequestCh(prAdapter);
- #endif
- }
- BOOLEAN bowNotifyAllLinkDisconnected(IN P_ADAPTER_T prAdapter)
- {
- UINT_8 ucBowTableIdx = 0;
- CMD_INFO_T rCmdInfo;
- ASSERT(prAdapter);
- kalMemZero(&rCmdInfo, sizeof(CMD_INFO_T));
- while (ucBowTableIdx < CFG_BOW_PHYSICAL_LINK_NUM) {
- if (arBowTable[ucBowTableIdx].fgIsValid) {
- COPY_MAC_ADDR(prAdapter->rWifiVar.rBowFsmInfo.aucPeerAddress,
- arBowTable[ucBowTableIdx].aucPeerAddress);
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT,
- "bowNotifyAllLinkDisconnected, arBowTable[%x].aucPeerAddress, %x:%x:%x:%x:%x:%x.\n",
- ucBowTableIdx, arBowTable[ucBowTableIdx].aucPeerAddress[0],
- arBowTable[ucBowTableIdx].aucPeerAddress[1],
- arBowTable[ucBowTableIdx].aucPeerAddress[2],
- arBowTable[ucBowTableIdx].aucPeerAddress[3],
- arBowTable[ucBowTableIdx].aucPeerAddress[4],
- arBowTable[ucBowTableIdx].aucPeerAddress[5]));
- DBGLOG(BOW, EVENT,
- "bowNotifyAllLinkDisconnected, arBowTable[%x].fgIsValid, %x.\n", ucBowTableIdx,
- arBowTable[ucBowTableIdx].fgIsValid);
- #endif
- #if 1
- wlanoidSendSetQueryBowCmd(prAdapter,
- CMD_ID_CMD_BT_OVER_WIFI,
- TRUE,
- FALSE,
- wlanbowCmdEventLinkDisconnected,
- wlanbowCmdTimeoutHandler, 0, NULL, 0);
- #else
- wlanbowCmdEventLinkDisconnected(prAdapter, &rCmdInfo, NULL);
- #endif
- }
- ucBowTableIdx += 1;
- }
- return TRUE;
- }
- /*----------------------------------------------------------------------------*/
- /*!
- * \brief to retrieve Bluetooth-over-Wi-Fi state from glue layer
- *
- * \param[in]
- * prGlueInfo
- * rPeerAddr
- * \return
- * ENUM_BOW_DEVICE_STATE
- */
- /*----------------------------------------------------------------------------*/
- BOOLEAN bowCheckBowTableIfVaild(IN P_ADAPTER_T prAdapter, IN UINT_8 aucPeerAddress[6])
- {
- UINT_8 idx;
- KAL_SPIN_LOCK_DECLARATION();
- KAL_ACQUIRE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- for (idx = 0; idx < CFG_BOW_PHYSICAL_LINK_NUM; idx++) {
- if (arBowTable[idx].fgIsValid && EQUAL_MAC_ADDR(arBowTable[idx].aucPeerAddress, aucPeerAddress)) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "kalCheckBowifVaild, aucPeerAddress %x, %x:%x:%x:%x:%x:%x.\n", idx,
- aucPeerAddress[0],
- aucPeerAddress[1],
- aucPeerAddress[2],
- aucPeerAddress[3], aucPeerAddress[4], aucPeerAddress[5]));
- DBGLOG(BOW, EVENT,
- "kalCheckBowifVaild, arBowTable[idx].aucPeerAddress %x, %x:%x:%x:%x:%x:%x.\n", idx,
- arBowTable[idx].aucPeerAddress[0], arBowTable[idx].aucPeerAddress[1],
- arBowTable[idx].aucPeerAddress[2], arBowTable[idx].aucPeerAddress[3],
- arBowTable[idx].aucPeerAddress[4], arBowTable[idx].aucPeerAddress[5]));
- DBGLOG(BOW, EVENT,
- "kalCheckBowifVaild, arBowTable[idx].fgIsValid, %x, %x.\n", idx,
- arBowTable[idx].fgIsValid);
- #endif
- KAL_RELEASE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- return TRUE;
- }
- }
- KAL_RELEASE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- return FALSE;
- }
- BOOLEAN bowGetBowTableContent(IN P_ADAPTER_T prAdapter, IN UINT_8 ucBowTableIdx, OUT P_BOW_TABLE_T prBowTable)
- {
- KAL_SPIN_LOCK_DECLARATION();
- KAL_ACQUIRE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- if (arBowTable[ucBowTableIdx].fgIsValid) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT,
- "bowGetBowTableContent, arBowTable[idx].fgIsValid, %x, %x.\n", ucBowTableIdx,
- arBowTable[ucBowTableIdx].fgIsValid);
- DBGLOG(BOW, INFO, "GET State [%d]\n", arBowTable[ucBowTableIdx].eState);
- #endif
- prBowTable = &(arBowTable[ucBowTableIdx]);
- KAL_RELEASE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- return TRUE;
- }
- KAL_RELEASE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- return FALSE;
- }
- BOOLEAN bowSetBowTableContent(IN P_ADAPTER_T prAdapter, IN UINT_8 ucBowTableIdx, IN P_BOW_TABLE_T prBowTable)
- {
- KAL_SPIN_LOCK_DECLARATION();
- KAL_ACQUIRE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- COPY_MAC_ADDR(arBowTable[ucBowTableIdx].aucPeerAddress, prBowTable->aucPeerAddress);
- arBowTable[ucBowTableIdx].eState = prBowTable->eState;
- arBowTable[ucBowTableIdx].fgIsValid = prBowTable->fgIsValid;
- arBowTable[ucBowTableIdx].ucAcquireID = prBowTable->ucAcquireID;
- KAL_RELEASE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- kalSetBowState(prAdapter->prGlueInfo, prBowTable->eState, prBowTable->aucPeerAddress);
- /* kalSetBowRole(prAdapter->prGlueInfo, prBowTable->ucRole, prBowTable->aucPeerAddress); */
- #if CFG_BOW_TEST
- DBGLOG(BOW, INFO, "SET State [%d]\n", arBowTable[ucBowTableIdx].eState);
- DBGLOG(BOW, EVENT,
- "kalCheckBowifVaild, arBowTable[ucBowTableIdx].fgIsValid, %x, %x.\n", ucBowTableIdx,
- arBowTable[ucBowTableIdx].fgIsValid);
- #endif
- return TRUE;
- }
- BOOLEAN
- bowGetBowTableEntryByPeerAddress(IN P_ADAPTER_T prAdapter, IN UINT_8 aucPeerAddress[6], OUT PUINT_8 pucBowTableIdx)
- {
- UINT_8 idx;
- KAL_SPIN_LOCK_DECLARATION();
- KAL_ACQUIRE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- for (idx = 0; idx < CFG_BOW_PHYSICAL_LINK_NUM; idx++) {
- if (arBowTable[idx].fgIsValid && EQUAL_MAC_ADDR(arBowTable[idx].aucPeerAddress, aucPeerAddress)) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "kalCheckBowifVaild, aucPeerAddress %x, %x:%x:%x:%x:%x:%x.\n", idx,
- aucPeerAddress[0],
- aucPeerAddress[1],
- aucPeerAddress[2],
- aucPeerAddress[3], aucPeerAddress[4], aucPeerAddress[5]));
- DBGLOG(BOW, EVENT,
- "kalCheckBowifVaild, arBowTable[idx].aucPeerAddress %x, %x:%x:%x:%x:%x:%x.\n", idx,
- arBowTable[idx].aucPeerAddress[0], arBowTable[idx].aucPeerAddress[1],
- arBowTable[idx].aucPeerAddress[2], arBowTable[idx].aucPeerAddress[3],
- arBowTable[idx].aucPeerAddress[4], arBowTable[idx].aucPeerAddress[5]));
- DBGLOG(BOW, EVENT,
- "kalCheckBowifVaild, arBowTable[idx].fgIsValid, %x, %x.\n", idx,
- arBowTable[idx].fgIsValid);
- #endif
- KAL_RELEASE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- *pucBowTableIdx = idx;
- return TRUE;
- }
- }
- KAL_RELEASE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- return FALSE;
- }
- BOOLEAN bowGetBowTableFreeEntry(IN P_ADAPTER_T prAdapter, OUT PUINT_8 pucBowTableIdx)
- {
- UINT_8 idx;
- KAL_SPIN_LOCK_DECLARATION();
- KAL_ACQUIRE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- for (idx = 0; idx < CFG_BOW_PHYSICAL_LINK_NUM; idx++) {
- if (!arBowTable[idx].fgIsValid) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT,
- "bowGetBowTableFreeEntry, arBowTable[idx].fgIsValid, %x, %x.\n", idx,
- arBowTable[idx].fgIsValid);
- #endif
- *pucBowTableIdx = idx;
- arBowTable[idx].fgIsValid = TRUE;
- KAL_RELEASE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- return TRUE;
- }
- }
- KAL_RELEASE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- return FALSE;
- }
- ENUM_BOW_DEVICE_STATE bowGetBowTableState(IN P_ADAPTER_T prAdapter, IN UINT_8 aucPeerAddress[6])
- {
- UINT_8 idx;
- KAL_SPIN_LOCK_DECLARATION();
- KAL_ACQUIRE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- for (idx = 0; idx < CFG_BOW_PHYSICAL_LINK_NUM; idx++) {
- if (arBowTable[idx].fgIsValid && EQUAL_MAC_ADDR(arBowTable[idx].aucPeerAddress, aucPeerAddress)) {
- #if CFG_BOW_TEST
- DBGLOG(BOW, EVENT, "bowGetState, aucPeerAddress %x, %x:%x:%x:%x:%x:%x.\n", idx,
- aucPeerAddress[0],
- aucPeerAddress[1],
- aucPeerAddress[2],
- aucPeerAddress[3], aucPeerAddress[4], aucPeerAddress[5]));
- DBGLOG(BOW, EVENT, "bowGetState, arBowTable[idx].aucPeerAddress %x, %x:%x:%x:%x:%x:%x.\n", idx,
- arBowTable[idx].aucPeerAddress[0],
- arBowTable[idx].aucPeerAddress[1],
- arBowTable[idx].aucPeerAddress[2],
- arBowTable[idx].aucPeerAddress[3],
- arBowTable[idx].aucPeerAddress[4], arBowTable[idx].aucPeerAddress[5]));
- DBGLOG(BOW, EVENT,
- "bowGetState, arBowTable[idx].fgIsValid, %x, %x.\n", idx, arBowTable[idx].fgIsValid);
- DBGLOG(BOW, EVENT,
- "bowGetState, arBowTable[idx].eState;, %x, %x.\n", idx, arBowTable[idx].eState);
- DBGLOG(BOW, INFO, "GET State [%d]\n", arBowTable[idx].eState);
- #endif
- KAL_RELEASE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- return arBowTable[idx].eState;
- }
- }
- KAL_RELEASE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- return BOW_DEVICE_STATE_DISCONNECTED;
- }
- BOOLEAN bowSetBowTableState(IN P_ADAPTER_T prAdapter, IN UINT_8 aucPeerAddress[6], IN ENUM_BOW_DEVICE_STATE eState)
- {
- UINT_8 ucBowTableIdx;
- if (bowGetBowTableEntryByPeerAddress(prAdapter, aucPeerAddress, &ucBowTableIdx)) {
- KAL_SPIN_LOCK_DECLARATION();
- KAL_ACQUIRE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- arBowTable[ucBowTableIdx].eState = eState;
- #if CFG_BOW_TEST
- DBGLOG(BOW, INFO, "SET State [%d]\n", eState);
- #endif
- KAL_RELEASE_SPIN_LOCK(prAdapter, SPIN_LOCK_BOW_TABLE);
- kalSetBowState(prAdapter->prGlueInfo, eState, aucPeerAddress);
- return TRUE;
- }
- return FALSE;
- }
- #endif
|