802.11.h 206 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365
  1. /*
  2. * Fundamental types and constants relating to 802.11
  3. *
  4. * Portions of this code are copyright (c) 2020 Cypress Semiconductor Corporation
  5. *
  6. * Copyright (C) 1999-2020, Broadcom Corporation
  7. *
  8. * Unless you and Broadcom execute a separate written software license
  9. * agreement governing use of this software, this software is licensed to you
  10. * under the terms of the GNU General Public License version 2 (the "GPL"),
  11. * available at http://www.broadcom.com/licenses/GPLv2.php, with the
  12. * following added to such license:
  13. *
  14. * As a special exception, the copyright holders of this software give you
  15. * permission to link this software with independent modules, and to copy and
  16. * distribute the resulting executable under terms of your choice, provided that
  17. * you also meet, for each linked independent module, the terms and conditions of
  18. * the license of that module. An independent module is a module which is not
  19. * derived from this software. The special exception does not apply to any
  20. * modifications of the software.
  21. *
  22. * Notwithstanding the above, under no circumstances may you combine this
  23. * software in any way with any other Broadcom software provided under a license
  24. * other than the GPL, without Broadcom's express prior written consent.
  25. *
  26. *
  27. * <<Broadcom-WL-IPTag/Open:>>
  28. *
  29. * $Id: 802.11.h 715562 2019-05-24 18:41:53Z $
  30. */
  31. #ifndef _802_11_H_
  32. #define _802_11_H_
  33. #ifndef _TYPEDEFS_H_
  34. #include <typedefs.h>
  35. #endif // endif
  36. #ifndef _NET_ETHERNET_H_
  37. #include <ethernet.h>
  38. #endif // endif
  39. #include <wpa.h>
  40. /* This marks the start of a packed structure section. */
  41. #include <packed_section_start.h>
  42. #define DOT11_TU_TO_US 1024 /* 802.11 Time Unit is 1024 microseconds */
  43. /* Generic 802.11 frame constants */
  44. #define DOT11_A3_HDR_LEN 24 /* d11 header length with A3 */
  45. #define DOT11_A4_HDR_LEN 30 /* d11 header length with A4 */
  46. #define DOT11_MAC_HDR_LEN DOT11_A3_HDR_LEN /* MAC header length */
  47. #define DOT11_FCS_LEN 4u /* d11 FCS length */
  48. #define DOT11_ICV_LEN 4 /* d11 ICV length */
  49. #define DOT11_ICV_AES_LEN 8 /* d11 ICV/AES length */
  50. #define DOT11_MAX_ICV_AES_LEN 16 /* d11 MAX ICV/AES length */
  51. #define DOT11_QOS_LEN 2 /* d11 QoS length */
  52. #define DOT11_HTC_LEN 4 /* d11 HT Control field length */
  53. #define DOT11_KEY_INDEX_SHIFT 6 /* d11 key index shift */
  54. #define DOT11_IV_LEN 4 /* d11 IV length */
  55. #define DOT11_IV_TKIP_LEN 8 /* d11 IV TKIP length */
  56. #define DOT11_IV_AES_OCB_LEN 4 /* d11 IV/AES/OCB length */
  57. #define DOT11_IV_AES_CCM_LEN 8 /* d11 IV/AES/CCM length */
  58. #define DOT11_IV_MAX_LEN 8 /* maximum iv len for any encryption */
  59. /* Includes MIC */
  60. #define DOT11_MAX_MPDU_BODY_LEN 2304 /* max MPDU body length */
  61. /* A4 header + QoS + CCMP + PDU + ICV + FCS = 2352 */
  62. #define DOT11_MAX_MPDU_LEN (DOT11_A4_HDR_LEN + \
  63. DOT11_QOS_LEN + \
  64. DOT11_IV_AES_CCM_LEN + \
  65. DOT11_MAX_MPDU_BODY_LEN + \
  66. DOT11_ICV_LEN + \
  67. DOT11_FCS_LEN) /* d11 max MPDU length */
  68. #define DOT11_MAX_SSID_LEN 32 /* d11 max ssid length */
  69. /* dot11RTSThreshold */
  70. #define DOT11_DEFAULT_RTS_LEN 2347 /* d11 default RTS length */
  71. #define DOT11_MAX_RTS_LEN 2347 /* d11 max RTS length */
  72. /* dot11FragmentationThreshold */
  73. #define DOT11_MIN_FRAG_LEN 256 /* d11 min fragmentation length */
  74. #define DOT11_MAX_FRAG_LEN 2346 /* Max frag is also limited by aMPDUMaxLength
  75. * of the attached PHY
  76. */
  77. #define DOT11_DEFAULT_FRAG_LEN 2346 /* d11 default fragmentation length */
  78. /* dot11BeaconPeriod */
  79. #define DOT11_MIN_BEACON_PERIOD 1 /* d11 min beacon period */
  80. #define DOT11_MAX_BEACON_PERIOD 0xFFFF /* d11 max beacon period */
  81. /* dot11DTIMPeriod */
  82. #define DOT11_MIN_DTIM_PERIOD 1 /* d11 min DTIM period */
  83. #define DOT11_MAX_DTIM_PERIOD 0xFF /* d11 max DTIM period */
  84. /** 802.2 LLC/SNAP header used by 802.11 per 802.1H */
  85. #define DOT11_LLC_SNAP_HDR_LEN 8 /* d11 LLC/SNAP header length */
  86. /* minimum LLC header length; DSAP, SSAP, 8 bit Control (unnumbered) */
  87. #define DOT11_LLC_HDR_LEN_MIN 3
  88. #define DOT11_OUI_LEN 3 /* d11 OUI length */
  89. BWL_PRE_PACKED_STRUCT struct dot11_llc_snap_header {
  90. uint8 dsap; /* always 0xAA */
  91. uint8 ssap; /* always 0xAA */
  92. uint8 ctl; /* always 0x03 */
  93. uint8 oui[DOT11_OUI_LEN]; /* RFC1042: 0x00 0x00 0x00
  94. * Bridge-Tunnel: 0x00 0x00 0xF8
  95. */
  96. uint16 type; /* ethertype */
  97. } BWL_POST_PACKED_STRUCT;
  98. /* RFC1042 header used by 802.11 per 802.1H */
  99. #define RFC1042_HDR_LEN (ETHER_HDR_LEN + DOT11_LLC_SNAP_HDR_LEN) /* RCF1042 header length */
  100. /* Generic 802.11 MAC header */
  101. /**
  102. * N.B.: This struct reflects the full 4 address 802.11 MAC header.
  103. * The fields are defined such that the shorter 1, 2, and 3
  104. * address headers just use the first k fields.
  105. */
  106. BWL_PRE_PACKED_STRUCT struct dot11_header {
  107. uint16 fc; /* frame control */
  108. uint16 durid; /* duration/ID */
  109. struct ether_addr a1; /* address 1 */
  110. struct ether_addr a2; /* address 2 */
  111. struct ether_addr a3; /* address 3 */
  112. uint16 seq; /* sequence control */
  113. struct ether_addr a4; /* address 4 */
  114. } BWL_POST_PACKED_STRUCT;
  115. /* Control frames */
  116. BWL_PRE_PACKED_STRUCT struct dot11_rts_frame {
  117. uint16 fc; /* frame control */
  118. uint16 durid; /* duration/ID */
  119. struct ether_addr ra; /* receiver address */
  120. struct ether_addr ta; /* transmitter address */
  121. } BWL_POST_PACKED_STRUCT;
  122. #define DOT11_RTS_LEN 16 /* d11 RTS frame length */
  123. BWL_PRE_PACKED_STRUCT struct dot11_cts_frame {
  124. uint16 fc; /* frame control */
  125. uint16 durid; /* duration/ID */
  126. struct ether_addr ra; /* receiver address */
  127. } BWL_POST_PACKED_STRUCT;
  128. #define DOT11_CTS_LEN 10u /* d11 CTS frame length */
  129. BWL_PRE_PACKED_STRUCT struct dot11_ack_frame {
  130. uint16 fc; /* frame control */
  131. uint16 durid; /* duration/ID */
  132. struct ether_addr ra; /* receiver address */
  133. } BWL_POST_PACKED_STRUCT;
  134. #define DOT11_ACK_LEN 10 /* d11 ACK frame length */
  135. BWL_PRE_PACKED_STRUCT struct dot11_ps_poll_frame {
  136. uint16 fc; /* frame control */
  137. uint16 durid; /* AID */
  138. struct ether_addr bssid; /* receiver address, STA in AP */
  139. struct ether_addr ta; /* transmitter address */
  140. } BWL_POST_PACKED_STRUCT;
  141. #define DOT11_PS_POLL_LEN 16 /* d11 PS poll frame length */
  142. BWL_PRE_PACKED_STRUCT struct dot11_cf_end_frame {
  143. uint16 fc; /* frame control */
  144. uint16 durid; /* duration/ID */
  145. struct ether_addr ra; /* receiver address */
  146. struct ether_addr bssid; /* transmitter address, STA in AP */
  147. } BWL_POST_PACKED_STRUCT;
  148. #define DOT11_CS_END_LEN 16 /* d11 CF-END frame length */
  149. /**
  150. * RWL wifi protocol: The Vendor Specific Action frame is defined for vendor-specific signaling
  151. * category+OUI+vendor specific content ( this can be variable)
  152. */
  153. BWL_PRE_PACKED_STRUCT struct dot11_action_wifi_vendor_specific {
  154. uint8 category;
  155. uint8 OUI[3];
  156. uint8 type;
  157. uint8 subtype;
  158. uint8 data[1040];
  159. } BWL_POST_PACKED_STRUCT;
  160. typedef struct dot11_action_wifi_vendor_specific dot11_action_wifi_vendor_specific_t;
  161. /** generic vendor specific action frame with variable length */
  162. BWL_PRE_PACKED_STRUCT struct dot11_action_vs_frmhdr {
  163. uint8 category;
  164. uint8 OUI[3];
  165. uint8 type;
  166. uint8 subtype;
  167. uint8 data[1];
  168. } BWL_POST_PACKED_STRUCT;
  169. typedef struct dot11_action_vs_frmhdr dot11_action_vs_frmhdr_t;
  170. #define DOT11_ACTION_VS_HDR_LEN 6
  171. #define BCM_ACTION_OUI_BYTE0 0x00
  172. #define BCM_ACTION_OUI_BYTE1 0x90
  173. #define BCM_ACTION_OUI_BYTE2 0x4c
  174. /* BA/BAR Control parameters */
  175. #define DOT11_BA_CTL_POLICY_NORMAL 0x0000 /* normal ack */
  176. #define DOT11_BA_CTL_POLICY_NOACK 0x0001 /* no ack */
  177. #define DOT11_BA_CTL_POLICY_MASK 0x0001 /* ack policy mask */
  178. #define DOT11_BA_CTL_MTID 0x0002 /* multi tid BA */
  179. #define DOT11_BA_CTL_COMPRESSED 0x0004 /* compressed bitmap */
  180. #define DOT11_BA_CTL_NUMMSDU_MASK 0x0FC0 /* num msdu in bitmap mask */
  181. #define DOT11_BA_CTL_NUMMSDU_SHIFT 6 /* num msdu in bitmap shift */
  182. #define DOT11_BA_CTL_TID_MASK 0xF000 /* tid mask */
  183. #define DOT11_BA_CTL_TID_SHIFT 12 /* tid shift */
  184. /** control frame header (BA/BAR) */
  185. BWL_PRE_PACKED_STRUCT struct dot11_ctl_header {
  186. uint16 fc; /* frame control */
  187. uint16 durid; /* duration/ID */
  188. struct ether_addr ra; /* receiver address */
  189. struct ether_addr ta; /* transmitter address */
  190. } BWL_POST_PACKED_STRUCT;
  191. #define DOT11_CTL_HDR_LEN 16 /* control frame hdr len */
  192. /** BAR frame payload */
  193. BWL_PRE_PACKED_STRUCT struct dot11_bar {
  194. uint16 bar_control; /* BAR Control */
  195. uint16 seqnum; /* Starting Sequence control */
  196. } BWL_POST_PACKED_STRUCT;
  197. #define DOT11_BAR_LEN 4 /* BAR frame payload length */
  198. #define DOT11_BA_BITMAP_LEN 128 /* bitmap length */
  199. #define DOT11_BA_CMP_BITMAP_LEN 8 /* compressed bitmap length */
  200. /** BA frame payload */
  201. BWL_PRE_PACKED_STRUCT struct dot11_ba {
  202. uint16 ba_control; /* BA Control */
  203. uint16 seqnum; /* Starting Sequence control */
  204. uint8 bitmap[DOT11_BA_BITMAP_LEN]; /* Block Ack Bitmap */
  205. } BWL_POST_PACKED_STRUCT;
  206. #define DOT11_BA_LEN 4 /* BA frame payload len (wo bitmap) */
  207. /** Management frame header */
  208. BWL_PRE_PACKED_STRUCT struct dot11_management_header {
  209. uint16 fc; /* frame control */
  210. uint16 durid; /* duration/ID */
  211. struct ether_addr da; /* receiver address */
  212. struct ether_addr sa; /* transmitter address */
  213. struct ether_addr bssid; /* BSS ID */
  214. uint16 seq; /* sequence control */
  215. } BWL_POST_PACKED_STRUCT;
  216. typedef struct dot11_management_header dot11_management_header_t;
  217. #define DOT11_MGMT_HDR_LEN 24 /* d11 management header length */
  218. /* Management frame payloads */
  219. BWL_PRE_PACKED_STRUCT struct dot11_bcn_prb {
  220. uint32 timestamp[2];
  221. uint16 beacon_interval;
  222. uint16 capability;
  223. } BWL_POST_PACKED_STRUCT;
  224. #define DOT11_BCN_PRB_LEN 12 /* 802.11 beacon/probe frame fixed length */
  225. #define DOT11_BCN_PRB_FIXED_LEN 12u /* 802.11 beacon/probe frame fixed length */
  226. BWL_PRE_PACKED_STRUCT struct dot11_auth {
  227. uint16 alg; /* algorithm */
  228. uint16 seq; /* sequence control */
  229. uint16 status; /* status code */
  230. } BWL_POST_PACKED_STRUCT;
  231. #define DOT11_AUTH_FIXED_LEN 6 /* length of auth frame without challenge IE */
  232. #define DOT11_AUTH_SEQ_STATUS_LEN 4 /* length of auth frame without challenge IE and
  233. * without algorithm
  234. */
  235. BWL_PRE_PACKED_STRUCT struct dot11_assoc_req {
  236. uint16 capability; /* capability information */
  237. uint16 listen; /* listen interval */
  238. } BWL_POST_PACKED_STRUCT;
  239. #define DOT11_ASSOC_REQ_FIXED_LEN 4 /* length of assoc frame without info elts */
  240. BWL_PRE_PACKED_STRUCT struct dot11_reassoc_req {
  241. uint16 capability; /* capability information */
  242. uint16 listen; /* listen interval */
  243. struct ether_addr ap; /* Current AP address */
  244. } BWL_POST_PACKED_STRUCT;
  245. #define DOT11_REASSOC_REQ_FIXED_LEN 10 /* length of assoc frame without info elts */
  246. BWL_PRE_PACKED_STRUCT struct dot11_assoc_resp {
  247. uint16 capability; /* capability information */
  248. uint16 status; /* status code */
  249. uint16 aid; /* association ID */
  250. } BWL_POST_PACKED_STRUCT;
  251. #define DOT11_ASSOC_RESP_FIXED_LEN 6 /* length of assoc resp frame without info elts */
  252. BWL_PRE_PACKED_STRUCT struct dot11_action_measure {
  253. uint8 category;
  254. uint8 action;
  255. uint8 token;
  256. uint8 data[1];
  257. } BWL_POST_PACKED_STRUCT;
  258. #define DOT11_ACTION_MEASURE_LEN 3 /* d11 action measurement header length */
  259. BWL_PRE_PACKED_STRUCT struct dot11_action_ht_ch_width {
  260. uint8 category;
  261. uint8 action;
  262. uint8 ch_width;
  263. } BWL_POST_PACKED_STRUCT;
  264. BWL_PRE_PACKED_STRUCT struct dot11_action_ht_mimops {
  265. uint8 category;
  266. uint8 action;
  267. uint8 control;
  268. } BWL_POST_PACKED_STRUCT;
  269. BWL_PRE_PACKED_STRUCT struct dot11_action_sa_query {
  270. uint8 category;
  271. uint8 action;
  272. uint16 id;
  273. } BWL_POST_PACKED_STRUCT;
  274. BWL_PRE_PACKED_STRUCT struct dot11_action_vht_oper_mode {
  275. uint8 category;
  276. uint8 action;
  277. uint8 mode;
  278. } BWL_POST_PACKED_STRUCT;
  279. /* These lengths assume 64 MU groups, as specified in 802.11ac-2013 */
  280. #define DOT11_ACTION_GID_MEMBERSHIP_LEN 8 /* bytes */
  281. #define DOT11_ACTION_GID_USER_POS_LEN 16 /* bytes */
  282. BWL_PRE_PACKED_STRUCT struct dot11_action_group_id {
  283. uint8 category;
  284. uint8 action;
  285. uint8 membership_status[DOT11_ACTION_GID_MEMBERSHIP_LEN];
  286. uint8 user_position[DOT11_ACTION_GID_USER_POS_LEN];
  287. } BWL_POST_PACKED_STRUCT;
  288. #define SM_PWRSAVE_ENABLE 1
  289. #define SM_PWRSAVE_MODE 2
  290. /* ************* 802.11h related definitions. ************* */
  291. BWL_PRE_PACKED_STRUCT struct dot11_power_cnst {
  292. uint8 id;
  293. uint8 len;
  294. uint8 power;
  295. } BWL_POST_PACKED_STRUCT;
  296. typedef struct dot11_power_cnst dot11_power_cnst_t;
  297. BWL_PRE_PACKED_STRUCT struct dot11_power_cap {
  298. int8 min;
  299. int8 max;
  300. } BWL_POST_PACKED_STRUCT;
  301. typedef struct dot11_power_cap dot11_power_cap_t;
  302. BWL_PRE_PACKED_STRUCT struct dot11_tpc_rep {
  303. uint8 id;
  304. uint8 len;
  305. uint8 tx_pwr;
  306. uint8 margin;
  307. } BWL_POST_PACKED_STRUCT;
  308. typedef struct dot11_tpc_rep dot11_tpc_rep_t;
  309. #define DOT11_MNG_IE_TPC_REPORT_SIZE (sizeof(dot11_tpc_rep_t))
  310. #define DOT11_MNG_IE_TPC_REPORT_LEN 2 /* length of IE data, not including 2 byte header */
  311. BWL_PRE_PACKED_STRUCT struct dot11_supp_channels {
  312. uint8 id;
  313. uint8 len;
  314. uint8 first_channel;
  315. uint8 num_channels;
  316. } BWL_POST_PACKED_STRUCT;
  317. typedef struct dot11_supp_channels dot11_supp_channels_t;
  318. /**
  319. * Extension Channel Offset IE: 802.11n-D1.0 spec. added sideband
  320. * offset for 40MHz operation. The possible 3 values are:
  321. * 1 = above control channel
  322. * 3 = below control channel
  323. * 0 = no extension channel
  324. */
  325. BWL_PRE_PACKED_STRUCT struct dot11_extch {
  326. uint8 id; /* IE ID, 62, DOT11_MNG_EXT_CHANNEL_OFFSET */
  327. uint8 len; /* IE length */
  328. uint8 extch;
  329. } BWL_POST_PACKED_STRUCT;
  330. typedef struct dot11_extch dot11_extch_ie_t;
  331. BWL_PRE_PACKED_STRUCT struct dot11_brcm_extch {
  332. uint8 id; /* IE ID, 221, DOT11_MNG_PROPR_ID */
  333. uint8 len; /* IE length */
  334. uint8 oui[3];
  335. uint8 type; /* type indicates what follows */
  336. uint8 extch;
  337. } BWL_POST_PACKED_STRUCT;
  338. typedef struct dot11_brcm_extch dot11_brcm_extch_ie_t;
  339. #define BRCM_EXTCH_IE_LEN 5
  340. #define BRCM_EXTCH_IE_TYPE 53 /* 802.11n ID not yet assigned */
  341. #define DOT11_EXTCH_IE_LEN 1
  342. #define DOT11_EXT_CH_MASK 0x03 /* extension channel mask */
  343. #define DOT11_EXT_CH_UPPER 0x01 /* ext. ch. on upper sb */
  344. #define DOT11_EXT_CH_LOWER 0x03 /* ext. ch. on lower sb */
  345. #define DOT11_EXT_CH_NONE 0x00 /* no extension ch. */
  346. BWL_PRE_PACKED_STRUCT struct dot11_action_frmhdr {
  347. uint8 category;
  348. uint8 action;
  349. uint8 data[1];
  350. } BWL_POST_PACKED_STRUCT;
  351. typedef struct dot11_action_frmhdr dot11_action_frmhdr_t;
  352. /* Action Field length */
  353. #define DOT11_ACTION_CATEGORY_LEN 1u
  354. #define DOT11_ACTION_ACTION_LEN 1u
  355. #define DOT11_ACTION_DIALOG_TOKEN_LEN 1u
  356. #define DOT11_ACTION_CAPABILITY_LEN 2u
  357. #define DOT11_ACTION_STATUS_CODE_LEN 2u
  358. #define DOT11_ACTION_REASON_CODE_LEN 2u
  359. #define DOT11_ACTION_TARGET_CH_LEN 1u
  360. #define DOT11_ACTION_OPER_CLASS_LEN 1u
  361. #define DOT11_ACTION_FRMHDR_LEN 2
  362. /** CSA IE data structure */
  363. BWL_PRE_PACKED_STRUCT struct dot11_channel_switch {
  364. uint8 id; /* id DOT11_MNG_CHANNEL_SWITCH_ID */
  365. uint8 len; /* length of IE */
  366. uint8 mode; /* mode 0 or 1 */
  367. uint8 channel; /* channel switch to */
  368. uint8 count; /* number of beacons before switching */
  369. } BWL_POST_PACKED_STRUCT;
  370. typedef struct dot11_channel_switch dot11_chan_switch_ie_t;
  371. #define DOT11_SWITCH_IE_LEN 3 /* length of IE data, not including 2 byte header */
  372. /* CSA mode - 802.11h-2003 $7.3.2.20 */
  373. #define DOT11_CSA_MODE_ADVISORY 0 /* no DOT11_CSA_MODE_NO_TX restriction imposed */
  374. #define DOT11_CSA_MODE_NO_TX 1 /* no transmission upon receiving CSA frame. */
  375. BWL_PRE_PACKED_STRUCT struct dot11_action_switch_channel {
  376. uint8 category;
  377. uint8 action;
  378. dot11_chan_switch_ie_t chan_switch_ie; /* for switch IE */
  379. dot11_brcm_extch_ie_t extch_ie; /* extension channel offset */
  380. } BWL_POST_PACKED_STRUCT;
  381. BWL_PRE_PACKED_STRUCT struct dot11_csa_body {
  382. uint8 mode; /* mode 0 or 1 */
  383. uint8 reg; /* regulatory class */
  384. uint8 channel; /* channel switch to */
  385. uint8 count; /* number of beacons before switching */
  386. } BWL_POST_PACKED_STRUCT;
  387. /** 11n Extended Channel Switch IE data structure */
  388. BWL_PRE_PACKED_STRUCT struct dot11_ext_csa {
  389. uint8 id; /* id DOT11_MNG_EXT_CSA_ID */
  390. uint8 len; /* length of IE */
  391. struct dot11_csa_body b; /* body of the ie */
  392. } BWL_POST_PACKED_STRUCT;
  393. typedef struct dot11_ext_csa dot11_ext_csa_ie_t;
  394. #define DOT11_EXT_CSA_IE_LEN 4 /* length of extended channel switch IE body */
  395. BWL_PRE_PACKED_STRUCT struct dot11_action_ext_csa {
  396. uint8 category;
  397. uint8 action;
  398. dot11_ext_csa_ie_t chan_switch_ie; /* for switch IE */
  399. } BWL_POST_PACKED_STRUCT;
  400. BWL_PRE_PACKED_STRUCT struct dot11y_action_ext_csa {
  401. uint8 category;
  402. uint8 action;
  403. struct dot11_csa_body b; /* body of the ie */
  404. } BWL_POST_PACKED_STRUCT;
  405. /** Wide Bandwidth Channel Switch IE data structure */
  406. BWL_PRE_PACKED_STRUCT struct dot11_wide_bw_channel_switch {
  407. uint8 id; /* id DOT11_MNG_WIDE_BW_CHANNEL_SWITCH_ID */
  408. uint8 len; /* length of IE */
  409. uint8 channel_width; /* new channel width */
  410. uint8 center_frequency_segment_0; /* center frequency segment 0 */
  411. uint8 center_frequency_segment_1; /* center frequency segment 1 */
  412. } BWL_POST_PACKED_STRUCT;
  413. typedef struct dot11_wide_bw_channel_switch dot11_wide_bw_chan_switch_ie_t;
  414. #define DOT11_WIDE_BW_SWITCH_IE_LEN 3 /* length of IE data, not including 2 byte header */
  415. /** Channel Switch Wrapper IE data structure */
  416. BWL_PRE_PACKED_STRUCT struct dot11_channel_switch_wrapper {
  417. uint8 id; /* id DOT11_MNG_WIDE_BW_CHANNEL_SWITCH_ID */
  418. uint8 len; /* length of IE */
  419. dot11_wide_bw_chan_switch_ie_t wb_chan_switch_ie;
  420. } BWL_POST_PACKED_STRUCT;
  421. typedef struct dot11_channel_switch_wrapper dot11_chan_switch_wrapper_ie_t;
  422. typedef enum wide_bw_chan_width {
  423. WIDE_BW_CHAN_WIDTH_20 = 0,
  424. WIDE_BW_CHAN_WIDTH_40 = 1,
  425. WIDE_BW_CHAN_WIDTH_80 = 2,
  426. WIDE_BW_CHAN_WIDTH_160 = 3,
  427. WIDE_BW_CHAN_WIDTH_80_80 = 4
  428. } wide_bw_chan_width_t;
  429. /** Wide Bandwidth Channel IE data structure */
  430. BWL_PRE_PACKED_STRUCT struct dot11_wide_bw_channel {
  431. uint8 id; /* id DOT11_MNG_WIDE_BW_CHANNEL_ID */
  432. uint8 len; /* length of IE */
  433. uint8 channel_width; /* channel width */
  434. uint8 center_frequency_segment_0; /* center frequency segment 0 */
  435. uint8 center_frequency_segment_1; /* center frequency segment 1 */
  436. } BWL_POST_PACKED_STRUCT;
  437. typedef struct dot11_wide_bw_channel dot11_wide_bw_chan_ie_t;
  438. #define DOT11_WIDE_BW_IE_LEN 3 /* length of IE data, not including 2 byte header */
  439. /** VHT Transmit Power Envelope IE data structure */
  440. BWL_PRE_PACKED_STRUCT struct dot11_vht_transmit_power_envelope {
  441. uint8 id; /* id DOT11_MNG_WIDE_BW_CHANNEL_SWITCH_ID */
  442. uint8 len; /* length of IE */
  443. uint8 transmit_power_info;
  444. uint8 local_max_transmit_power_20;
  445. } BWL_POST_PACKED_STRUCT;
  446. typedef struct dot11_vht_transmit_power_envelope dot11_vht_transmit_power_envelope_ie_t;
  447. /* vht transmit power envelope IE length depends on channel width */
  448. #define DOT11_VHT_TRANSMIT_PWR_ENVELOPE_IE_LEN_40MHZ 1
  449. #define DOT11_VHT_TRANSMIT_PWR_ENVELOPE_IE_LEN_80MHZ 2
  450. #define DOT11_VHT_TRANSMIT_PWR_ENVELOPE_IE_LEN_160MHZ 3
  451. BWL_PRE_PACKED_STRUCT struct dot11_obss_coex {
  452. uint8 id;
  453. uint8 len;
  454. uint8 info;
  455. } BWL_POST_PACKED_STRUCT;
  456. typedef struct dot11_obss_coex dot11_obss_coex_t;
  457. #define DOT11_OBSS_COEXINFO_LEN 1 /* length of OBSS Coexistence INFO IE */
  458. #define DOT11_OBSS_COEX_INFO_REQ 0x01
  459. #define DOT11_OBSS_COEX_40MHZ_INTOLERANT 0x02
  460. #define DOT11_OBSS_COEX_20MHZ_WIDTH_REQ 0x04
  461. BWL_PRE_PACKED_STRUCT struct dot11_obss_chanlist {
  462. uint8 id;
  463. uint8 len;
  464. uint8 regclass;
  465. uint8 chanlist[1];
  466. } BWL_POST_PACKED_STRUCT;
  467. typedef struct dot11_obss_chanlist dot11_obss_chanlist_t;
  468. #define DOT11_OBSS_CHANLIST_FIXED_LEN 1 /* fixed length of regclass */
  469. BWL_PRE_PACKED_STRUCT struct dot11_extcap_ie {
  470. uint8 id;
  471. uint8 len;
  472. uint8 cap[1];
  473. } BWL_POST_PACKED_STRUCT;
  474. typedef struct dot11_extcap_ie dot11_extcap_ie_t;
  475. #define DOT11_EXTCAP_LEN_COEX 1
  476. #define DOT11_EXTCAP_LEN_BT 3
  477. #define DOT11_EXTCAP_LEN_IW 4
  478. #define DOT11_EXTCAP_LEN_SI 6
  479. #define DOT11_EXTCAP_LEN_TDLS 5
  480. #define DOT11_11AC_EXTCAP_LEN_TDLS 8
  481. #define DOT11_EXTCAP_LEN_FMS 2
  482. #define DOT11_EXTCAP_LEN_PROXY_ARP 2
  483. #define DOT11_EXTCAP_LEN_TFS 3
  484. #define DOT11_EXTCAP_LEN_WNM_SLEEP 3
  485. #define DOT11_EXTCAP_LEN_TIMBC 3
  486. #define DOT11_EXTCAP_LEN_BSSTRANS 3
  487. #define DOT11_EXTCAP_LEN_DMS 4
  488. #define DOT11_EXTCAP_LEN_WNM_NOTIFICATION 6
  489. #define DOT11_EXTCAP_LEN_TDLS_WBW 8
  490. #define DOT11_EXTCAP_LEN_OPMODE_NOTIFICATION 8
  491. #define DOT11_EXTCAP_LEN_TWT 10u
  492. /* TDLS Capabilities */
  493. #define DOT11_TDLS_CAP_TDLS 37 /* TDLS support */
  494. #define DOT11_TDLS_CAP_PU_BUFFER_STA 28 /* TDLS Peer U-APSD buffer STA support */
  495. #define DOT11_TDLS_CAP_PEER_PSM 20 /* TDLS Peer PSM support */
  496. #define DOT11_TDLS_CAP_CH_SW 30 /* TDLS Channel switch */
  497. #define DOT11_TDLS_CAP_PROH 38 /* TDLS prohibited */
  498. #define DOT11_TDLS_CAP_CH_SW_PROH 39 /* TDLS Channel switch prohibited */
  499. #define DOT11_TDLS_CAP_TDLS_WIDER_BW 61 /* TDLS Wider Band-Width */
  500. #define TDLS_CAP_MAX_BIT 39 /* TDLS max bit defined in ext cap */
  501. /* 802.11h/802.11k Measurement Request/Report IEs */
  502. /* Measurement Type field */
  503. #define DOT11_MEASURE_TYPE_BASIC 0 /* d11 measurement basic type */
  504. #define DOT11_MEASURE_TYPE_CCA 1 /* d11 measurement CCA type */
  505. #define DOT11_MEASURE_TYPE_RPI 2 /* d11 measurement RPI type */
  506. #define DOT11_MEASURE_TYPE_CHLOAD 3 /* d11 measurement Channel Load type */
  507. #define DOT11_MEASURE_TYPE_NOISE 4 /* d11 measurement Noise Histogram type */
  508. #define DOT11_MEASURE_TYPE_BEACON 5 /* d11 measurement Beacon type */
  509. #define DOT11_MEASURE_TYPE_FRAME 6 /* d11 measurement Frame type */
  510. #define DOT11_MEASURE_TYPE_STAT 7 /* d11 measurement STA Statistics type */
  511. #define DOT11_MEASURE_TYPE_LCI 8 /* d11 measurement LCI type */
  512. #define DOT11_MEASURE_TYPE_TXSTREAM 9 /* d11 measurement TX Stream type */
  513. #define DOT11_MEASURE_TYPE_MCDIAGS 10 /* d11 measurement multicast diagnostics */
  514. #define DOT11_MEASURE_TYPE_CIVICLOC 11 /* d11 measurement location civic */
  515. #define DOT11_MEASURE_TYPE_LOC_ID 12 /* d11 measurement location identifier */
  516. #define DOT11_MEASURE_TYPE_DIRCHANQ 13 /* d11 measurement dir channel quality */
  517. #define DOT11_MEASURE_TYPE_DIRMEAS 14 /* d11 measurement directional */
  518. #define DOT11_MEASURE_TYPE_DIRSTATS 15 /* d11 measurement directional stats */
  519. #define DOT11_MEASURE_TYPE_FTMRANGE 16 /* d11 measurement Fine Timing */
  520. #define DOT11_MEASURE_TYPE_PAUSE 255 /* d11 measurement pause type */
  521. /* Measurement Request Modes */
  522. #define DOT11_MEASURE_MODE_PARALLEL (1<<0) /* d11 measurement parallel */
  523. #define DOT11_MEASURE_MODE_ENABLE (1<<1) /* d11 measurement enable */
  524. #define DOT11_MEASURE_MODE_REQUEST (1<<2) /* d11 measurement request */
  525. #define DOT11_MEASURE_MODE_REPORT (1<<3) /* d11 measurement report */
  526. #define DOT11_MEASURE_MODE_DUR (1<<4) /* d11 measurement dur mandatory */
  527. /* Measurement Report Modes */
  528. #define DOT11_MEASURE_MODE_LATE (1<<0) /* d11 measurement late */
  529. #define DOT11_MEASURE_MODE_INCAPABLE (1<<1) /* d11 measurement incapable */
  530. #define DOT11_MEASURE_MODE_REFUSED (1<<2) /* d11 measurement refuse */
  531. /* Basic Measurement Map bits */
  532. #define DOT11_MEASURE_BASIC_MAP_BSS ((uint8)(1<<0)) /* d11 measurement basic map BSS */
  533. #define DOT11_MEASURE_BASIC_MAP_OFDM ((uint8)(1<<1)) /* d11 measurement map OFDM */
  534. #define DOT11_MEASURE_BASIC_MAP_UKNOWN ((uint8)(1<<2)) /* d11 measurement map unknown */
  535. #define DOT11_MEASURE_BASIC_MAP_RADAR ((uint8)(1<<3)) /* d11 measurement map radar */
  536. #define DOT11_MEASURE_BASIC_MAP_UNMEAS ((uint8)(1<<4)) /* d11 measurement map unmeasuremnt */
  537. BWL_PRE_PACKED_STRUCT struct dot11_meas_req {
  538. uint8 id;
  539. uint8 len;
  540. uint8 token;
  541. uint8 mode;
  542. uint8 type;
  543. uint8 channel;
  544. uint8 start_time[8];
  545. uint16 duration;
  546. } BWL_POST_PACKED_STRUCT;
  547. typedef struct dot11_meas_req dot11_meas_req_t;
  548. #define DOT11_MNG_IE_MREQ_LEN 14 /* d11 measurement request IE length */
  549. /* length of Measure Request IE data not including variable len */
  550. #define DOT11_MNG_IE_MREQ_FIXED_LEN 3 /* d11 measurement request IE fixed length */
  551. BWL_PRE_PACKED_STRUCT struct dot11_meas_req_loc {
  552. uint8 id;
  553. uint8 len;
  554. uint8 token;
  555. uint8 mode;
  556. uint8 type;
  557. BWL_PRE_PACKED_STRUCT union
  558. {
  559. BWL_PRE_PACKED_STRUCT struct {
  560. uint8 subject;
  561. uint8 data[1];
  562. } BWL_POST_PACKED_STRUCT lci;
  563. BWL_PRE_PACKED_STRUCT struct {
  564. uint8 subject;
  565. uint8 type; /* type of civic location */
  566. uint8 siu; /* service interval units */
  567. uint16 si; /* service interval */
  568. uint8 data[1];
  569. } BWL_POST_PACKED_STRUCT civic;
  570. BWL_PRE_PACKED_STRUCT struct {
  571. uint8 subject;
  572. uint8 siu; /* service interval units */
  573. uint16 si; /* service interval */
  574. uint8 data[1];
  575. } BWL_POST_PACKED_STRUCT locid;
  576. BWL_PRE_PACKED_STRUCT struct {
  577. uint16 max_init_delay; /* maximum random initial delay */
  578. uint8 min_ap_count;
  579. uint8 data[1];
  580. } BWL_POST_PACKED_STRUCT ftm_range;
  581. } BWL_POST_PACKED_STRUCT req;
  582. } BWL_POST_PACKED_STRUCT;
  583. typedef struct dot11_meas_req_loc dot11_meas_req_loc_t;
  584. #define DOT11_MNG_IE_MREQ_MIN_LEN 4 /* d11 measurement report IE length */
  585. #define DOT11_MNG_IE_MREQ_LCI_FIXED_LEN 4 /* d11 measurement report IE length */
  586. #define DOT11_MNG_IE_MREQ_CIVIC_FIXED_LEN 8 /* d11 measurement report IE length */
  587. #define DOT11_MNG_IE_MREQ_FRNG_FIXED_LEN 6 /* d11 measurement report IE length */
  588. BWL_PRE_PACKED_STRUCT struct dot11_lci_subelement {
  589. uint8 subelement;
  590. uint8 length;
  591. uint8 lci_data[1];
  592. } BWL_POST_PACKED_STRUCT;
  593. typedef struct dot11_lci_subelement dot11_lci_subelement_t;
  594. BWL_PRE_PACKED_STRUCT struct dot11_colocated_bssid_list_se {
  595. uint8 sub_id;
  596. uint8 length;
  597. uint8 max_bssid_ind; /* MaxBSSID Indicator */
  598. struct ether_addr bssid[1]; /* variable */
  599. } BWL_POST_PACKED_STRUCT;
  600. typedef struct dot11_colocated_bssid_list_se dot11_colocated_bssid_list_se_t;
  601. #define DOT11_LCI_COLOCATED_BSSID_LIST_FIXED_LEN 3
  602. #define DOT11_LCI_COLOCATED_BSSID_SUBELEM_ID 7
  603. BWL_PRE_PACKED_STRUCT struct dot11_civic_subelement {
  604. uint8 type; /* type of civic location */
  605. uint8 subelement;
  606. uint8 length;
  607. uint8 civic_data[1];
  608. } BWL_POST_PACKED_STRUCT;
  609. typedef struct dot11_civic_subelement dot11_civic_subelement_t;
  610. BWL_PRE_PACKED_STRUCT struct dot11_meas_rep {
  611. uint8 id;
  612. uint8 len;
  613. uint8 token;
  614. uint8 mode;
  615. uint8 type;
  616. BWL_PRE_PACKED_STRUCT union
  617. {
  618. BWL_PRE_PACKED_STRUCT struct {
  619. uint8 channel;
  620. uint8 start_time[8];
  621. uint16 duration;
  622. uint8 map;
  623. } BWL_POST_PACKED_STRUCT basic;
  624. BWL_PRE_PACKED_STRUCT struct {
  625. uint8 subelement;
  626. uint8 length;
  627. uint8 data[1];
  628. } BWL_POST_PACKED_STRUCT lci;
  629. BWL_PRE_PACKED_STRUCT struct {
  630. uint8 type; /* type of civic location */
  631. uint8 subelement;
  632. uint8 length;
  633. uint8 data[1];
  634. } BWL_POST_PACKED_STRUCT civic;
  635. BWL_PRE_PACKED_STRUCT struct {
  636. uint8 exp_tsf[8];
  637. uint8 subelement;
  638. uint8 length;
  639. uint8 data[1];
  640. } BWL_POST_PACKED_STRUCT locid;
  641. BWL_PRE_PACKED_STRUCT struct {
  642. uint8 entry_count;
  643. uint8 data[1];
  644. } BWL_POST_PACKED_STRUCT ftm_range;
  645. uint8 data[1];
  646. } BWL_POST_PACKED_STRUCT rep;
  647. } BWL_POST_PACKED_STRUCT;
  648. typedef struct dot11_meas_rep dot11_meas_rep_t;
  649. #define DOT11_MNG_IE_MREP_MIN_LEN 5 /* d11 measurement report IE length */
  650. #define DOT11_MNG_IE_MREP_LCI_FIXED_LEN 5 /* d11 measurement report IE length */
  651. #define DOT11_MNG_IE_MREP_CIVIC_FIXED_LEN 6 /* d11 measurement report IE length */
  652. #define DOT11_MNG_IE_MREP_LOCID_FIXED_LEN 13 /* d11 measurement report IE length */
  653. #define DOT11_MNG_IE_MREP_BASIC_FIXED_LEN 15 /* d11 measurement report IE length */
  654. #define DOT11_MNG_IE_MREP_FRNG_FIXED_LEN 4
  655. /* length of Measure Report IE data not including variable len */
  656. #define DOT11_MNG_IE_MREP_FIXED_LEN 3 /* d11 measurement response IE fixed length */
  657. BWL_PRE_PACKED_STRUCT struct dot11_meas_rep_basic {
  658. uint8 channel;
  659. uint8 start_time[8];
  660. uint16 duration;
  661. uint8 map;
  662. } BWL_POST_PACKED_STRUCT;
  663. typedef struct dot11_meas_rep_basic dot11_meas_rep_basic_t;
  664. #define DOT11_MEASURE_BASIC_REP_LEN 12 /* d11 measurement basic report length */
  665. BWL_PRE_PACKED_STRUCT struct dot11_quiet {
  666. uint8 id;
  667. uint8 len;
  668. uint8 count; /* TBTTs until beacon interval in quiet starts */
  669. uint8 period; /* Beacon intervals between periodic quiet periods ? */
  670. uint16 duration; /* Length of quiet period, in TU's */
  671. uint16 offset; /* TU's offset from TBTT in Count field */
  672. } BWL_POST_PACKED_STRUCT;
  673. typedef struct dot11_quiet dot11_quiet_t;
  674. BWL_PRE_PACKED_STRUCT struct chan_map_tuple {
  675. uint8 channel;
  676. uint8 map;
  677. } BWL_POST_PACKED_STRUCT;
  678. typedef struct chan_map_tuple chan_map_tuple_t;
  679. BWL_PRE_PACKED_STRUCT struct dot11_ibss_dfs {
  680. uint8 id;
  681. uint8 len;
  682. uint8 eaddr[ETHER_ADDR_LEN];
  683. uint8 interval;
  684. chan_map_tuple_t map[1];
  685. } BWL_POST_PACKED_STRUCT;
  686. typedef struct dot11_ibss_dfs dot11_ibss_dfs_t;
  687. /* WME Elements */
  688. #define WME_OUI "\x00\x50\xf2" /* WME OUI */
  689. #define WME_OUI_LEN 3
  690. #define WME_OUI_TYPE 2 /* WME type */
  691. #define WME_TYPE 2 /* WME type, deprecated */
  692. #define WME_SUBTYPE_IE 0 /* Information Element */
  693. #define WME_SUBTYPE_PARAM_IE 1 /* Parameter Element */
  694. #define WME_SUBTYPE_TSPEC 2 /* Traffic Specification */
  695. #define WME_VER 1 /* WME version */
  696. /* WME Access Category Indices (ACIs) */
  697. #define AC_BE 0 /* Best Effort */
  698. #define AC_BK 1 /* Background */
  699. #define AC_VI 2 /* Video */
  700. #define AC_VO 3 /* Voice */
  701. #define AC_COUNT 4 /* number of ACs */
  702. typedef uint8 ac_bitmap_t; /* AC bitmap of (1 << AC_xx) */
  703. #define AC_BITMAP_NONE 0x0 /* No ACs */
  704. #define AC_BITMAP_ALL 0xf /* All ACs */
  705. #define AC_BITMAP_TST(ab, ac) (((ab) & (1 << (ac))) != 0)
  706. #define AC_BITMAP_SET(ab, ac) (((ab) |= (1 << (ac))))
  707. #define AC_BITMAP_RESET(ab, ac) (((ab) &= ~(1 << (ac))))
  708. /* Management PKT Lifetime indices */
  709. /* Removing flag checks 'BCMINTERNAL || WLTEST'
  710. * while merging MERGE BIS120RC4 to DINGO2
  711. */
  712. #define MGMT_ALL 0xffff
  713. #define MGMT_AUTH_LT FC_SUBTYPE_AUTH
  714. #define MGMT_ASSOC_LT FC_SUBTYPE_ASSOC_REQ
  715. /** WME Information Element (IE) */
  716. BWL_PRE_PACKED_STRUCT struct wme_ie {
  717. uint8 oui[3];
  718. uint8 type;
  719. uint8 subtype;
  720. uint8 version;
  721. uint8 qosinfo;
  722. } BWL_POST_PACKED_STRUCT;
  723. typedef struct wme_ie wme_ie_t;
  724. #define WME_IE_LEN 7 /* WME IE length */
  725. BWL_PRE_PACKED_STRUCT struct edcf_acparam {
  726. uint8 ACI;
  727. uint8 ECW;
  728. uint16 TXOP; /* stored in network order (ls octet first) */
  729. } BWL_POST_PACKED_STRUCT;
  730. typedef struct edcf_acparam edcf_acparam_t;
  731. /** WME Parameter Element (PE) */
  732. BWL_PRE_PACKED_STRUCT struct wme_param_ie {
  733. uint8 oui[3];
  734. uint8 type;
  735. uint8 subtype;
  736. uint8 version;
  737. uint8 qosinfo;
  738. uint8 rsvd;
  739. edcf_acparam_t acparam[AC_COUNT];
  740. } BWL_POST_PACKED_STRUCT;
  741. typedef struct wme_param_ie wme_param_ie_t;
  742. #define WME_PARAM_IE_LEN 24 /* WME Parameter IE length */
  743. /* QoS Info field for IE as sent from AP */
  744. #define WME_QI_AP_APSD_MASK 0x80 /* U-APSD Supported mask */
  745. #define WME_QI_AP_APSD_SHIFT 7 /* U-APSD Supported shift */
  746. #define WME_QI_AP_COUNT_MASK 0x0f /* Parameter set count mask */
  747. #define WME_QI_AP_COUNT_SHIFT 0 /* Parameter set count shift */
  748. /* QoS Info field for IE as sent from STA */
  749. #define WME_QI_STA_MAXSPLEN_MASK 0x60 /* Max Service Period Length mask */
  750. #define WME_QI_STA_MAXSPLEN_SHIFT 5 /* Max Service Period Length shift */
  751. #define WME_QI_STA_APSD_ALL_MASK 0xf /* APSD all AC bits mask */
  752. #define WME_QI_STA_APSD_ALL_SHIFT 0 /* APSD all AC bits shift */
  753. #define WME_QI_STA_APSD_BE_MASK 0x8 /* APSD AC_BE mask */
  754. #define WME_QI_STA_APSD_BE_SHIFT 3 /* APSD AC_BE shift */
  755. #define WME_QI_STA_APSD_BK_MASK 0x4 /* APSD AC_BK mask */
  756. #define WME_QI_STA_APSD_BK_SHIFT 2 /* APSD AC_BK shift */
  757. #define WME_QI_STA_APSD_VI_MASK 0x2 /* APSD AC_VI mask */
  758. #define WME_QI_STA_APSD_VI_SHIFT 1 /* APSD AC_VI shift */
  759. #define WME_QI_STA_APSD_VO_MASK 0x1 /* APSD AC_VO mask */
  760. #define WME_QI_STA_APSD_VO_SHIFT 0 /* APSD AC_VO shift */
  761. /* ACI */
  762. #define EDCF_AIFSN_MIN 1 /* AIFSN minimum value */
  763. #define EDCF_AIFSN_MAX 15 /* AIFSN maximum value */
  764. #define EDCF_AIFSN_MASK 0x0f /* AIFSN mask */
  765. #define EDCF_ACM_MASK 0x10 /* ACM mask */
  766. #define EDCF_ACI_MASK 0x60 /* ACI mask */
  767. #define EDCF_ACI_SHIFT 5 /* ACI shift */
  768. #define EDCF_AIFSN_SHIFT 12 /* 4 MSB(0xFFF) in ifs_ctl for AC idx */
  769. /* ECW */
  770. #define EDCF_ECW_MIN 0 /* cwmin/cwmax exponent minimum value */
  771. #define EDCF_ECW_MAX 15 /* cwmin/cwmax exponent maximum value */
  772. #define EDCF_ECW2CW(exp) ((1 << (exp)) - 1)
  773. #define EDCF_ECWMIN_MASK 0x0f /* cwmin exponent form mask */
  774. #define EDCF_ECWMAX_MASK 0xf0 /* cwmax exponent form mask */
  775. #define EDCF_ECWMAX_SHIFT 4 /* cwmax exponent form shift */
  776. /* TXOP */
  777. #define EDCF_TXOP_MIN 0 /* TXOP minimum value */
  778. #define EDCF_TXOP_MAX 65535 /* TXOP maximum value */
  779. #define EDCF_TXOP2USEC(txop) ((txop) << 5)
  780. /* Default BE ACI value for non-WME connection STA */
  781. #define NON_EDCF_AC_BE_ACI_STA 0x02
  782. /* Default EDCF parameters that AP advertises for STA to use; WMM draft Table 12 */
  783. #define EDCF_AC_BE_ACI_STA 0x03 /* STA ACI value for best effort AC */
  784. #define EDCF_AC_BE_ECW_STA 0xA4 /* STA ECW value for best effort AC */
  785. #define EDCF_AC_BE_TXOP_STA 0x0000 /* STA TXOP value for best effort AC */
  786. #define EDCF_AC_BK_ACI_STA 0x27 /* STA ACI value for background AC */
  787. #define EDCF_AC_BK_ECW_STA 0xA4 /* STA ECW value for background AC */
  788. #define EDCF_AC_BK_TXOP_STA 0x0000 /* STA TXOP value for background AC */
  789. #define EDCF_AC_VI_ACI_STA 0x42 /* STA ACI value for video AC */
  790. #define EDCF_AC_VI_ECW_STA 0x43 /* STA ECW value for video AC */
  791. #define EDCF_AC_VI_TXOP_STA 0x005e /* STA TXOP value for video AC */
  792. #define EDCF_AC_VO_ACI_STA 0x62 /* STA ACI value for audio AC */
  793. #define EDCF_AC_VO_ECW_STA 0x32 /* STA ECW value for audio AC */
  794. #define EDCF_AC_VO_TXOP_STA 0x002f /* STA TXOP value for audio AC */
  795. /* Default EDCF parameters that AP uses; WMM draft Table 14 */
  796. #define EDCF_AC_BE_ACI_AP 0x03 /* AP ACI value for best effort AC */
  797. #define EDCF_AC_BE_ECW_AP 0x64 /* AP ECW value for best effort AC */
  798. #define EDCF_AC_BE_TXOP_AP 0x0000 /* AP TXOP value for best effort AC */
  799. #define EDCF_AC_BK_ACI_AP 0x27 /* AP ACI value for background AC */
  800. #define EDCF_AC_BK_ECW_AP 0xA4 /* AP ECW value for background AC */
  801. #define EDCF_AC_BK_TXOP_AP 0x0000 /* AP TXOP value for background AC */
  802. #define EDCF_AC_VI_ACI_AP 0x41 /* AP ACI value for video AC */
  803. #define EDCF_AC_VI_ECW_AP 0x43 /* AP ECW value for video AC */
  804. #define EDCF_AC_VI_TXOP_AP 0x005e /* AP TXOP value for video AC */
  805. #define EDCF_AC_VO_ACI_AP 0x61 /* AP ACI value for audio AC */
  806. #define EDCF_AC_VO_ECW_AP 0x32 /* AP ECW value for audio AC */
  807. #define EDCF_AC_VO_TXOP_AP 0x002f /* AP TXOP value for audio AC */
  808. /** EDCA Parameter IE */
  809. BWL_PRE_PACKED_STRUCT struct edca_param_ie {
  810. uint8 qosinfo;
  811. uint8 rsvd;
  812. edcf_acparam_t acparam[AC_COUNT];
  813. } BWL_POST_PACKED_STRUCT;
  814. typedef struct edca_param_ie edca_param_ie_t;
  815. #define EDCA_PARAM_IE_LEN 18 /* EDCA Parameter IE length */
  816. /** QoS Capability IE */
  817. BWL_PRE_PACKED_STRUCT struct qos_cap_ie {
  818. uint8 qosinfo;
  819. } BWL_POST_PACKED_STRUCT;
  820. typedef struct qos_cap_ie qos_cap_ie_t;
  821. BWL_PRE_PACKED_STRUCT struct dot11_qbss_load_ie {
  822. uint8 id; /* 11, DOT11_MNG_QBSS_LOAD_ID */
  823. uint8 length;
  824. uint16 station_count; /* total number of STAs associated */
  825. uint8 channel_utilization; /* % of time, normalized to 255, QAP sensed medium busy */
  826. uint16 aac; /* available admission capacity */
  827. } BWL_POST_PACKED_STRUCT;
  828. typedef struct dot11_qbss_load_ie dot11_qbss_load_ie_t;
  829. #define BSS_LOAD_IE_SIZE 7 /* BSS load IE size */
  830. #define WLC_QBSS_LOAD_CHAN_FREE_MAX 0xff /* max for channel free score */
  831. /* Estimated Service Parameters (ESP) IE - 802.11-2016 9.4.2.174 */
  832. typedef BWL_PRE_PACKED_STRUCT struct dot11_esp_ie {
  833. uint8 id;
  834. uint8 length;
  835. uint8 id_ext;
  836. /* variable len info */
  837. uint8 esp_info_lists[];
  838. } BWL_POST_PACKED_STRUCT dot11_esp_ie_t;
  839. #define DOT11_ESP_IE_HDR_SIZE (OFFSETOF(dot11_esp_ie_t, esp_info_lists))
  840. /* ESP Information list - 802.11-2016 9.4.2.174 */
  841. typedef BWL_PRE_PACKED_STRUCT struct dot11_esp_ie_info_list {
  842. /* acess category, data format, ba win size */
  843. uint8 ac_df_baws;
  844. /* estimated air time fraction */
  845. uint8 eat_frac;
  846. /* data PPDU duration target (50us units) */
  847. uint8 ppdu_dur;
  848. } BWL_POST_PACKED_STRUCT dot11_esp_ie_info_list_t;
  849. #define DOT11_ESP_IE_INFO_LIST_SIZE (sizeof(dot11_esp_ie_info_list_t))
  850. #define DOT11_ESP_NBR_INFO_LISTS 4u /* max nbr of esp information lists */
  851. #define DOT11_ESP_INFO_LIST_AC_BK 0u /* access category of esp information list AC_BK */
  852. #define DOT11_ESP_INFO_LIST_AC_BE 1u /* access category of esp information list AC_BE */
  853. #define DOT11_ESP_INFO_LIST_AC_VI 2u /* access category of esp information list AC_VI */
  854. #define DOT11_ESP_INFO_LIST_AC_VO 3u /* access category of esp information list AC_VO */
  855. #define DOT11_ESP_INFO_LIST_DF_MASK 0x18 /* Data Format Mask */
  856. #define DOT11_ESP_INFO_LIST_BAWS_MASK 0xE0 /* BA window size mask */
  857. /* nom_msdu_size */
  858. #define FIXED_MSDU_SIZE 0x8000 /* MSDU size is fixed */
  859. #define MSDU_SIZE_MASK 0x7fff /* (Nominal or fixed) MSDU size */
  860. /* surplus_bandwidth */
  861. /* Represented as 3 bits of integer, binary point, 13 bits fraction */
  862. #define INTEGER_SHIFT 13 /* integer shift */
  863. #define FRACTION_MASK 0x1FFF /* fraction mask */
  864. /** Management Notification Frame */
  865. BWL_PRE_PACKED_STRUCT struct dot11_management_notification {
  866. uint8 category; /* DOT11_ACTION_NOTIFICATION */
  867. uint8 action;
  868. uint8 token;
  869. uint8 status;
  870. uint8 data[1]; /* Elements */
  871. } BWL_POST_PACKED_STRUCT;
  872. #define DOT11_MGMT_NOTIFICATION_LEN 4 /* Fixed length */
  873. /** Timeout Interval IE */
  874. BWL_PRE_PACKED_STRUCT struct ti_ie {
  875. uint8 ti_type;
  876. uint32 ti_val;
  877. } BWL_POST_PACKED_STRUCT;
  878. typedef struct ti_ie ti_ie_t;
  879. #define TI_TYPE_REASSOC_DEADLINE 1
  880. #define TI_TYPE_KEY_LIFETIME 2
  881. #ifndef CISCO_AIRONET_OUI
  882. #define CISCO_AIRONET_OUI "\x00\x40\x96" /* Cisco AIRONET OUI */
  883. #endif // endif
  884. /* QoS FastLane IE. */
  885. BWL_PRE_PACKED_STRUCT struct ccx_qfl_ie {
  886. uint8 id; /* 221, DOT11_MNG_VS_ID */
  887. uint8 length; /* 5 */
  888. uint8 oui[3]; /* 00:40:96 */
  889. uint8 type; /* 11 */
  890. uint8 data;
  891. } BWL_POST_PACKED_STRUCT;
  892. typedef struct ccx_qfl_ie ccx_qfl_ie_t;
  893. #define CCX_QFL_IE_TYPE 11
  894. #define CCX_QFL_ENABLE_SHIFT 5
  895. #define CCX_QFL_ENALBE (1 << CCX_QFL_ENABLE_SHIFT)
  896. /* WME Action Codes */
  897. #define WME_ADDTS_REQUEST 0 /* WME ADDTS request */
  898. #define WME_ADDTS_RESPONSE 1 /* WME ADDTS response */
  899. #define WME_DELTS_REQUEST 2 /* WME DELTS request */
  900. /* WME Setup Response Status Codes */
  901. #define WME_ADMISSION_ACCEPTED 0 /* WME admission accepted */
  902. #define WME_INVALID_PARAMETERS 1 /* WME invalide parameters */
  903. #define WME_ADMISSION_REFUSED 3 /* WME admission refused */
  904. /* Macro to take a pointer to a beacon or probe response
  905. * body and return the char* pointer to the SSID info element
  906. */
  907. #define BCN_PRB_SSID(body) ((char*)(body) + DOT11_BCN_PRB_LEN)
  908. /* Authentication frame payload constants */
  909. #define DOT11_OPEN_SYSTEM 0 /* d11 open authentication */
  910. #define DOT11_SHARED_KEY 1 /* d11 shared authentication */
  911. #define DOT11_FAST_BSS 2 /* d11 fast bss authentication */
  912. #define DOT11_SAE 3 /* d11 simultaneous authentication of equals */
  913. #define DOT11_FILS_SKEY 4 /* d11 fils shared key authentication w/o pfs */
  914. #define DOT11_FILS_SKEY_PFS 5 /* d11 fils shared key authentication w/ pfs */
  915. #define DOT11_FILS_PKEY 6 /* d11 fils public key authentication */
  916. #define DOT11_CHALLENGE_LEN 128 /* d11 challenge text length */
  917. /* Frame control macros */
  918. #define FC_PVER_MASK 0x3 /* PVER mask */
  919. #define FC_PVER_SHIFT 0 /* PVER shift */
  920. #define FC_TYPE_MASK 0xC /* type mask */
  921. #define FC_TYPE_SHIFT 2 /* type shift */
  922. #define FC_SUBTYPE_MASK 0xF0 /* subtype mask */
  923. #define FC_SUBTYPE_SHIFT 4 /* subtype shift */
  924. #define FC_TODS 0x100 /* to DS */
  925. #define FC_TODS_SHIFT 8 /* to DS shift */
  926. #define FC_FROMDS 0x200 /* from DS */
  927. #define FC_FROMDS_SHIFT 9 /* from DS shift */
  928. #define FC_MOREFRAG 0x400 /* more frag. */
  929. #define FC_MOREFRAG_SHIFT 10 /* more frag. shift */
  930. #define FC_RETRY 0x800 /* retry */
  931. #define FC_RETRY_SHIFT 11 /* retry shift */
  932. #define FC_PM 0x1000 /* PM */
  933. #define FC_PM_SHIFT 12 /* PM shift */
  934. #define FC_MOREDATA 0x2000 /* more data */
  935. #define FC_MOREDATA_SHIFT 13 /* more data shift */
  936. #define FC_WEP 0x4000 /* WEP */
  937. #define FC_WEP_SHIFT 14 /* WEP shift */
  938. #define FC_ORDER 0x8000 /* order */
  939. #define FC_ORDER_SHIFT 15 /* order shift */
  940. /* sequence control macros */
  941. #define SEQNUM_SHIFT 4 /* seq. number shift */
  942. #define SEQNUM_MAX 0x1000 /* max seqnum + 1 */
  943. #define FRAGNUM_MASK 0xF /* frag. number mask */
  944. /* Frame Control type/subtype defs */
  945. /* FC Types */
  946. #define FC_TYPE_MNG 0 /* management type */
  947. #define FC_TYPE_CTL 1 /* control type */
  948. #define FC_TYPE_DATA 2 /* data type */
  949. /* Management Subtypes */
  950. #define FC_SUBTYPE_ASSOC_REQ 0 /* assoc. request */
  951. #define FC_SUBTYPE_ASSOC_RESP 1 /* assoc. response */
  952. #define FC_SUBTYPE_REASSOC_REQ 2 /* reassoc. request */
  953. #define FC_SUBTYPE_REASSOC_RESP 3 /* reassoc. response */
  954. #define FC_SUBTYPE_PROBE_REQ 4 /* probe request */
  955. #define FC_SUBTYPE_PROBE_RESP 5 /* probe response */
  956. #define FC_SUBTYPE_BEACON 8 /* beacon */
  957. #define FC_SUBTYPE_ATIM 9 /* ATIM */
  958. #define FC_SUBTYPE_DISASSOC 10 /* disassoc. */
  959. #define FC_SUBTYPE_AUTH 11 /* authentication */
  960. #define FC_SUBTYPE_DEAUTH 12 /* de-authentication */
  961. #define FC_SUBTYPE_ACTION 13 /* action */
  962. #define FC_SUBTYPE_ACTION_NOACK 14 /* action no-ack */
  963. /* Control Subtypes */
  964. #define FC_SUBTYPE_TRIGGER 2 /* Trigger frame */
  965. #define FC_SUBTYPE_CTL_WRAPPER 7 /* Control Wrapper */
  966. #define FC_SUBTYPE_BLOCKACK_REQ 8 /* Block Ack Req */
  967. #define FC_SUBTYPE_BLOCKACK 9 /* Block Ack */
  968. #define FC_SUBTYPE_PS_POLL 10 /* PS poll */
  969. #define FC_SUBTYPE_RTS 11 /* RTS */
  970. #define FC_SUBTYPE_CTS 12 /* CTS */
  971. #define FC_SUBTYPE_ACK 13 /* ACK */
  972. #define FC_SUBTYPE_CF_END 14 /* CF-END */
  973. #define FC_SUBTYPE_CF_END_ACK 15 /* CF-END ACK */
  974. /* Data Subtypes */
  975. #define FC_SUBTYPE_DATA 0 /* Data */
  976. #define FC_SUBTYPE_DATA_CF_ACK 1 /* Data + CF-ACK */
  977. #define FC_SUBTYPE_DATA_CF_POLL 2 /* Data + CF-Poll */
  978. #define FC_SUBTYPE_DATA_CF_ACK_POLL 3 /* Data + CF-Ack + CF-Poll */
  979. #define FC_SUBTYPE_NULL 4 /* Null */
  980. #define FC_SUBTYPE_CF_ACK 5 /* CF-Ack */
  981. #define FC_SUBTYPE_CF_POLL 6 /* CF-Poll */
  982. #define FC_SUBTYPE_CF_ACK_POLL 7 /* CF-Ack + CF-Poll */
  983. #define FC_SUBTYPE_QOS_DATA 8 /* QoS Data */
  984. #define FC_SUBTYPE_QOS_DATA_CF_ACK 9 /* QoS Data + CF-Ack */
  985. #define FC_SUBTYPE_QOS_DATA_CF_POLL 10 /* QoS Data + CF-Poll */
  986. #define FC_SUBTYPE_QOS_DATA_CF_ACK_POLL 11 /* QoS Data + CF-Ack + CF-Poll */
  987. #define FC_SUBTYPE_QOS_NULL 12 /* QoS Null */
  988. #define FC_SUBTYPE_QOS_CF_POLL 14 /* QoS CF-Poll */
  989. #define FC_SUBTYPE_QOS_CF_ACK_POLL 15 /* QoS CF-Ack + CF-Poll */
  990. /* Data Subtype Groups */
  991. #define FC_SUBTYPE_ANY_QOS(s) (((s) & 8) != 0)
  992. #define FC_SUBTYPE_ANY_NULL(s) (((s) & 4) != 0)
  993. #define FC_SUBTYPE_ANY_CF_POLL(s) (((s) & 2) != 0)
  994. #define FC_SUBTYPE_ANY_CF_ACK(s) (((s) & 1) != 0)
  995. #define FC_SUBTYPE_ANY_PSPOLL(s) (((s) & 10) != 0)
  996. /* Type/Subtype Combos */
  997. #define FC_KIND_MASK (FC_TYPE_MASK | FC_SUBTYPE_MASK) /* FC kind mask */
  998. #define FC_KIND(t, s) (((t) << FC_TYPE_SHIFT) | ((s) << FC_SUBTYPE_SHIFT)) /* FC kind */
  999. #define FC_SUBTYPE(fc) (((fc) & FC_SUBTYPE_MASK) >> FC_SUBTYPE_SHIFT) /* Subtype from FC */
  1000. #define FC_TYPE(fc) (((fc) & FC_TYPE_MASK) >> FC_TYPE_SHIFT) /* Type from FC */
  1001. #define FC_ASSOC_REQ FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_ASSOC_REQ) /* assoc. request */
  1002. #define FC_ASSOC_RESP FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_ASSOC_RESP) /* assoc. response */
  1003. #define FC_REASSOC_REQ FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_REASSOC_REQ) /* reassoc. request */
  1004. #define FC_REASSOC_RESP FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_REASSOC_RESP) /* reassoc. response */
  1005. #define FC_PROBE_REQ FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_PROBE_REQ) /* probe request */
  1006. #define FC_PROBE_RESP FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_PROBE_RESP) /* probe response */
  1007. #define FC_BEACON FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_BEACON) /* beacon */
  1008. #define FC_ATIM FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_ATIM) /* ATIM */
  1009. #define FC_DISASSOC FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_DISASSOC) /* disassoc */
  1010. #define FC_AUTH FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_AUTH) /* authentication */
  1011. #define FC_DEAUTH FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_DEAUTH) /* deauthentication */
  1012. #define FC_ACTION FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_ACTION) /* action */
  1013. #define FC_ACTION_NOACK FC_KIND(FC_TYPE_MNG, FC_SUBTYPE_ACTION_NOACK) /* action no-ack */
  1014. #define FC_CTL_TRIGGER FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_TRIGGER) /* Trigger frame */
  1015. #define FC_CTL_WRAPPER FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_CTL_WRAPPER) /* Control Wrapper */
  1016. #define FC_BLOCKACK_REQ FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_BLOCKACK_REQ) /* Block Ack Req */
  1017. #define FC_BLOCKACK FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_BLOCKACK) /* Block Ack */
  1018. #define FC_PS_POLL FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_PS_POLL) /* PS poll */
  1019. #define FC_RTS FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_RTS) /* RTS */
  1020. #define FC_CTS FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_CTS) /* CTS */
  1021. #define FC_ACK FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_ACK) /* ACK */
  1022. #define FC_CF_END FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_CF_END) /* CF-END */
  1023. #define FC_CF_END_ACK FC_KIND(FC_TYPE_CTL, FC_SUBTYPE_CF_END_ACK) /* CF-END ACK */
  1024. #define FC_DATA FC_KIND(FC_TYPE_DATA, FC_SUBTYPE_DATA) /* data */
  1025. #define FC_NULL_DATA FC_KIND(FC_TYPE_DATA, FC_SUBTYPE_NULL) /* null data */
  1026. #define FC_DATA_CF_ACK FC_KIND(FC_TYPE_DATA, FC_SUBTYPE_DATA_CF_ACK) /* data CF ACK */
  1027. #define FC_QOS_DATA FC_KIND(FC_TYPE_DATA, FC_SUBTYPE_QOS_DATA) /* QoS data */
  1028. #define FC_QOS_NULL FC_KIND(FC_TYPE_DATA, FC_SUBTYPE_QOS_NULL) /* QoS null */
  1029. /* QoS Control Field */
  1030. /* 802.1D Priority */
  1031. #define QOS_PRIO_SHIFT 0 /* QoS priority shift */
  1032. #define QOS_PRIO_MASK 0x0007 /* QoS priority mask */
  1033. #define QOS_PRIO(qos) (((qos) & QOS_PRIO_MASK) >> QOS_PRIO_SHIFT) /* QoS priority */
  1034. /* Traffic Identifier */
  1035. #define QOS_TID_SHIFT 0 /* QoS TID shift */
  1036. #define QOS_TID_MASK 0x000f /* QoS TID mask */
  1037. #define QOS_TID(qos) (((qos) & QOS_TID_MASK) >> QOS_TID_SHIFT) /* QoS TID */
  1038. /* End of Service Period (U-APSD) */
  1039. #define QOS_EOSP_SHIFT 4 /* QoS End of Service Period shift */
  1040. #define QOS_EOSP_MASK 0x0010 /* QoS End of Service Period mask */
  1041. #define QOS_EOSP(qos) (((qos) & QOS_EOSP_MASK) >> QOS_EOSP_SHIFT) /* Qos EOSP */
  1042. /* Ack Policy */
  1043. #define QOS_ACK_NORMAL_ACK 0 /* Normal Ack */
  1044. #define QOS_ACK_NO_ACK 1 /* No Ack (eg mcast) */
  1045. #define QOS_ACK_NO_EXP_ACK 2 /* No Explicit Ack */
  1046. #define QOS_ACK_BLOCK_ACK 3 /* Block Ack */
  1047. #define QOS_ACK_SHIFT 5 /* QoS ACK shift */
  1048. #define QOS_ACK_MASK 0x0060 /* QoS ACK mask */
  1049. #define QOS_ACK(qos) (((qos) & QOS_ACK_MASK) >> QOS_ACK_SHIFT) /* QoS ACK */
  1050. /* A-MSDU flag */
  1051. #define QOS_AMSDU_SHIFT 7 /* AMSDU shift */
  1052. #define QOS_AMSDU_MASK 0x0080 /* AMSDU mask */
  1053. /* Management Frames */
  1054. /* Management Frame Constants */
  1055. /* Fixed fields */
  1056. #define DOT11_MNG_AUTH_ALGO_LEN 2 /* d11 management auth. algo. length */
  1057. #define DOT11_MNG_AUTH_SEQ_LEN 2 /* d11 management auth. seq. length */
  1058. #define DOT11_MNG_BEACON_INT_LEN 2 /* d11 management beacon interval length */
  1059. #define DOT11_MNG_CAP_LEN 2 /* d11 management cap. length */
  1060. #define DOT11_MNG_AP_ADDR_LEN 6 /* d11 management AP address length */
  1061. #define DOT11_MNG_LISTEN_INT_LEN 2 /* d11 management listen interval length */
  1062. #define DOT11_MNG_REASON_LEN 2 /* d11 management reason length */
  1063. #define DOT11_MNG_AID_LEN 2 /* d11 management AID length */
  1064. #define DOT11_MNG_STATUS_LEN 2 /* d11 management status length */
  1065. #define DOT11_MNG_TIMESTAMP_LEN 8 /* d11 management timestamp length */
  1066. /* DUR/ID field in assoc resp is 0xc000 | AID */
  1067. #define DOT11_AID_MASK 0x3fff /* d11 AID mask */
  1068. /* Reason Codes */
  1069. #define DOT11_RC_RESERVED 0 /* d11 RC reserved */
  1070. #define DOT11_RC_UNSPECIFIED 1 /* Unspecified reason */
  1071. #define DOT11_RC_AUTH_INVAL 2 /* Previous authentication no longer valid */
  1072. #define DOT11_RC_DEAUTH_LEAVING 3 /* Deauthenticated because sending station
  1073. * is leaving (or has left) IBSS or ESS
  1074. */
  1075. #define DOT11_RC_INACTIVITY 4 /* Disassociated due to inactivity */
  1076. #define DOT11_RC_BUSY 5 /* Disassociated because AP is unable to handle
  1077. * all currently associated stations
  1078. */
  1079. #define DOT11_RC_INVAL_CLASS_2 6 /* Class 2 frame received from
  1080. * nonauthenticated station
  1081. */
  1082. #define DOT11_RC_INVAL_CLASS_3 7 /* Class 3 frame received from
  1083. * nonassociated station
  1084. */
  1085. #define DOT11_RC_DISASSOC_LEAVING 8 /* Disassociated because sending station is
  1086. * leaving (or has left) BSS
  1087. */
  1088. #define DOT11_RC_NOT_AUTH 9 /* Station requesting (re)association is not
  1089. * authenticated with responding station
  1090. */
  1091. #define DOT11_RC_BAD_PC 10 /* Unacceptable power capability element */
  1092. #define DOT11_RC_BAD_CHANNELS 11 /* Unacceptable supported channels element */
  1093. /* 12 is unused by STA but could be used by AP/GO */
  1094. #define DOT11_RC_DISASSOC_BTM 12 /* Disassociated due to BSS Transition Magmt */
  1095. /* 32-39 are QSTA specific reasons added in 11e */
  1096. #define DOT11_RC_UNSPECIFIED_QOS 32 /* unspecified QoS-related reason */
  1097. #define DOT11_RC_INSUFFCIENT_BW 33 /* QAP lacks sufficient bandwidth */
  1098. #define DOT11_RC_EXCESSIVE_FRAMES 34 /* excessive number of frames need ack */
  1099. #define DOT11_RC_TX_OUTSIDE_TXOP 35 /* transmitting outside the limits of txop */
  1100. #define DOT11_RC_LEAVING_QBSS 36 /* QSTA is leaving the QBSS (or restting) */
  1101. #define DOT11_RC_BAD_MECHANISM 37 /* does not want to use the mechanism */
  1102. #define DOT11_RC_SETUP_NEEDED 38 /* mechanism needs a setup */
  1103. #define DOT11_RC_TIMEOUT 39 /* timeout */
  1104. #define DOT11_RC_MESH_PEERING_CANCELLED 52
  1105. #define DOT11_RC_MESH_MAX_PEERS 53
  1106. #define DOT11_RC_MESH_CONFIG_POLICY_VIOLN 54
  1107. #define DOT11_RC_MESH_CLOSE_RECVD 55
  1108. #define DOT11_RC_MESH_MAX_RETRIES 56
  1109. #define DOT11_RC_MESH_CONFIRM_TIMEOUT 57
  1110. #define DOT11_RC_MESH_INVALID_GTK 58
  1111. #define DOT11_RC_MESH_INCONSISTENT_PARAMS 59
  1112. #define DOT11_RC_MESH_INVALID_SEC_CAP 60
  1113. #define DOT11_RC_MESH_PATHERR_NOPROXYINFO 61
  1114. #define DOT11_RC_MESH_PATHERR_NOFWINFO 62
  1115. #define DOT11_RC_MESH_PATHERR_DSTUNREACH 63
  1116. #define DOT11_RC_MESH_MBSSMAC_EXISTS 64
  1117. #define DOT11_RC_MESH_CHANSWITCH_REGREQ 65
  1118. #define DOT11_RC_MESH_CHANSWITCH_UNSPEC 66
  1119. #define DOT11_RC_MAX 66 /* Reason codes > 66 are reserved */
  1120. #define DOT11_RC_TDLS_PEER_UNREACH 25
  1121. #define DOT11_RC_TDLS_DOWN_UNSPECIFIED 26
  1122. /* Status Codes */
  1123. #define DOT11_SC_SUCCESS 0 /* Successful */
  1124. #define DOT11_SC_FAILURE 1 /* Unspecified failure */
  1125. #define DOT11_SC_TDLS_WAKEUP_SCH_ALT 2 /* TDLS wakeup schedule rejected but alternative */
  1126. /* schedule provided */
  1127. #define DOT11_SC_TDLS_WAKEUP_SCH_REJ 3 /* TDLS wakeup schedule rejected */
  1128. #define DOT11_SC_TDLS_SEC_DISABLED 5 /* TDLS Security disabled */
  1129. #define DOT11_SC_LIFETIME_REJ 6 /* Unacceptable lifetime */
  1130. #define DOT11_SC_NOT_SAME_BSS 7 /* Not in same BSS */
  1131. #define DOT11_SC_CAP_MISMATCH 10 /* Cannot support all requested
  1132. * capabilities in the Capability
  1133. * Information field
  1134. */
  1135. #define DOT11_SC_REASSOC_FAIL 11 /* Reassociation denied due to inability
  1136. * to confirm that association exists
  1137. */
  1138. #define DOT11_SC_ASSOC_FAIL 12 /* Association denied due to reason
  1139. * outside the scope of this standard
  1140. */
  1141. #define DOT11_SC_AUTH_MISMATCH 13 /* Responding station does not support
  1142. * the specified authentication
  1143. * algorithm
  1144. */
  1145. #define DOT11_SC_AUTH_SEQ 14 /* Received an Authentication frame
  1146. * with authentication transaction
  1147. * sequence number out of expected
  1148. * sequence
  1149. */
  1150. #define DOT11_SC_AUTH_CHALLENGE_FAIL 15 /* Authentication rejected because of
  1151. * challenge failure
  1152. */
  1153. #define DOT11_SC_AUTH_TIMEOUT 16 /* Authentication rejected due to timeout
  1154. * waiting for next frame in sequence
  1155. */
  1156. #define DOT11_SC_ASSOC_BUSY_FAIL 17 /* Association denied because AP is
  1157. * unable to handle additional
  1158. * associated stations
  1159. */
  1160. #define DOT11_SC_ASSOC_RATE_MISMATCH 18 /* Association denied due to requesting
  1161. * station not supporting all of the
  1162. * data rates in the BSSBasicRateSet
  1163. * parameter
  1164. */
  1165. #define DOT11_SC_ASSOC_SHORT_REQUIRED 19 /* Association denied due to requesting
  1166. * station not supporting the Short
  1167. * Preamble option
  1168. */
  1169. #define DOT11_SC_ASSOC_PBCC_REQUIRED 20 /* Association denied due to requesting
  1170. * station not supporting the PBCC
  1171. * Modulation option
  1172. */
  1173. #define DOT11_SC_ASSOC_AGILITY_REQUIRED 21 /* Association denied due to requesting
  1174. * station not supporting the Channel
  1175. * Agility option
  1176. */
  1177. #define DOT11_SC_ASSOC_SPECTRUM_REQUIRED 22 /* Association denied because Spectrum
  1178. * Management capability is required.
  1179. */
  1180. #define DOT11_SC_ASSOC_BAD_POWER_CAP 23 /* Association denied because the info
  1181. * in the Power Cap element is
  1182. * unacceptable.
  1183. */
  1184. #define DOT11_SC_ASSOC_BAD_SUP_CHANNELS 24 /* Association denied because the info
  1185. * in the Supported Channel element is
  1186. * unacceptable
  1187. */
  1188. #define DOT11_SC_ASSOC_SHORTSLOT_REQUIRED 25 /* Association denied due to requesting
  1189. * station not supporting the Short Slot
  1190. * Time option
  1191. */
  1192. #define DOT11_SC_ASSOC_DSSSOFDM_REQUIRED 26 /* Association denied because requesting station
  1193. * does not support the DSSS-OFDM option
  1194. */
  1195. #define DOT11_SC_ASSOC_HT_REQUIRED 27 /* Association denied because the requesting
  1196. * station does not support HT features
  1197. */
  1198. #define DOT11_SC_ASSOC_R0KH_UNREACHABLE 28 /* Association denied due to AP
  1199. * being unable to reach the R0 Key Holder
  1200. */
  1201. #define DOT11_SC_ASSOC_TRY_LATER 30 /* Association denied temporarily, try again later
  1202. */
  1203. #define DOT11_SC_ASSOC_MFP_VIOLATION 31 /* Association denied due to Robust Management
  1204. * frame policy violation
  1205. */
  1206. #define DOT11_SC_DECLINED 37 /* request declined */
  1207. #define DOT11_SC_INVALID_PARAMS 38 /* One or more params have invalid values */
  1208. #define DOT11_SC_INVALID_PAIRWISE_CIPHER 42 /* invalid pairwise cipher */
  1209. #define DOT11_SC_INVALID_AKMP 43 /* Association denied due to invalid AKMP */
  1210. #define DOT11_SC_INVALID_RSNIE_CAP 45 /* invalid RSN IE capabilities */
  1211. #define DOT11_SC_DLS_NOT_ALLOWED 48 /* DLS is not allowed in the BSS by policy */
  1212. #define DOT11_SC_INVALID_PMKID 53 /* Association denied due to invalid PMKID */
  1213. #define DOT11_SC_INVALID_MDID 54 /* Association denied due to invalid MDID */
  1214. #define DOT11_SC_INVALID_FTIE 55 /* Association denied due to invalid FTIE */
  1215. #define DOT11_SC_ADV_PROTO_NOT_SUPPORTED 59 /* ad proto not supported */
  1216. #define DOT11_SC_NO_OUTSTAND_REQ 60 /* no outstanding req */
  1217. #define DOT11_SC_RSP_NOT_RX_FROM_SERVER 61 /* no response from server */
  1218. #define DOT11_SC_TIMEOUT 62 /* timeout */
  1219. #define DOT11_SC_QUERY_RSP_TOO_LARGE 63 /* query rsp too large */
  1220. #define DOT11_SC_SERVER_UNREACHABLE 65 /* server unreachable */
  1221. #define DOT11_SC_UNEXP_MSG 70 /* Unexpected message */
  1222. #define DOT11_SC_INVALID_SNONCE 71 /* Invalid SNonce */
  1223. #define DOT11_SC_INVALID_RSNIE 72 /* Invalid contents of RSNIE */
  1224. #define DOT11_SC_ANTICLOG_TOCKEN_REQUIRED 76 /* Anti-clogging tocken required */
  1225. #define DOT11_SC_INVALID_FINITE_CYCLIC_GRP 77 /* Invalid contents of RSNIE */
  1226. #define DOT11_SC_ASSOC_VHT_REQUIRED 104 /* Association denied because the requesting
  1227. * station does not support VHT features.
  1228. */
  1229. #define DOT11_SC_TRANSMIT_FAILURE 79 /* transmission failure */
  1230. /* Info Elts, length of INFORMATION portion of Info Elts */
  1231. #define DOT11_MNG_DS_PARAM_LEN 1 /* d11 management DS parameter length */
  1232. #define DOT11_MNG_IBSS_PARAM_LEN 2 /* d11 management IBSS parameter length */
  1233. /* TIM Info element has 3 bytes fixed info in INFORMATION field,
  1234. * followed by 1 to 251 bytes of Partial Virtual Bitmap
  1235. */
  1236. #define DOT11_MNG_TIM_FIXED_LEN 3 /* d11 management TIM fixed length */
  1237. #define DOT11_MNG_TIM_DTIM_COUNT 0 /* d11 management DTIM count */
  1238. #define DOT11_MNG_TIM_DTIM_PERIOD 1 /* d11 management DTIM period */
  1239. #define DOT11_MNG_TIM_BITMAP_CTL 2 /* d11 management TIM BITMAP control */
  1240. #define DOT11_MNG_TIM_PVB 3 /* d11 management TIM PVB */
  1241. /* TLV defines */
  1242. #define TLV_TAG_OFF 0 /* tag offset */
  1243. #define TLV_LEN_OFF 1 /* length offset */
  1244. #define TLV_HDR_LEN 2 /* header length */
  1245. #define TLV_BODY_OFF 2 /* body offset */
  1246. #define TLV_BODY_LEN_MAX 255 /* max body length */
  1247. /* Management Frame Information Element IDs */
  1248. #define DOT11_MNG_SSID_ID 0 /* d11 management SSID id */
  1249. #define DOT11_MNG_RATES_ID 1 /* d11 management rates id */
  1250. #define DOT11_MNG_FH_PARMS_ID 2 /* d11 management FH parameter id */
  1251. #define DOT11_MNG_DS_PARMS_ID 3 /* d11 management DS parameter id */
  1252. #define DOT11_MNG_CF_PARMS_ID 4 /* d11 management CF parameter id */
  1253. #define DOT11_MNG_TIM_ID 5 /* d11 management TIM id */
  1254. #define DOT11_MNG_IBSS_PARMS_ID 6 /* d11 management IBSS parameter id */
  1255. #define DOT11_MNG_COUNTRY_ID 7 /* d11 management country id */
  1256. #define DOT11_MNG_HOPPING_PARMS_ID 8 /* d11 management hopping parameter id */
  1257. #define DOT11_MNG_HOPPING_TABLE_ID 9 /* d11 management hopping table id */
  1258. #define DOT11_MNG_FTM_SYNC_INFO_ID 9 /* 11mc D4.3 */
  1259. #define DOT11_MNG_REQUEST_ID 10 /* d11 management request id */
  1260. #define DOT11_MNG_QBSS_LOAD_ID 11 /* d11 management QBSS Load id */
  1261. #define DOT11_MNG_EDCA_PARAM_ID 12 /* 11E EDCA Parameter id */
  1262. #define DOT11_MNG_TSPEC_ID 13 /* d11 management TSPEC id */
  1263. #define DOT11_MNG_TCLAS_ID 14 /* d11 management TCLAS id */
  1264. #define DOT11_MNG_CHALLENGE_ID 16 /* d11 management chanllenge id */
  1265. #define DOT11_MNG_PWR_CONSTRAINT_ID 32 /* 11H PowerConstraint */
  1266. #define DOT11_MNG_PWR_CAP_ID 33 /* 11H PowerCapability */
  1267. #define DOT11_MNG_TPC_REQUEST_ID 34 /* 11H TPC Request */
  1268. #define DOT11_MNG_TPC_REPORT_ID 35 /* 11H TPC Report */
  1269. #define DOT11_MNG_SUPP_CHANNELS_ID 36 /* 11H Supported Channels */
  1270. #define DOT11_MNG_CHANNEL_SWITCH_ID 37 /* 11H ChannelSwitch Announcement */
  1271. #define DOT11_MNG_MEASURE_REQUEST_ID 38 /* 11H MeasurementRequest */
  1272. #define DOT11_MNG_MEASURE_REPORT_ID 39 /* 11H MeasurementReport */
  1273. #define DOT11_MNG_QUIET_ID 40 /* 11H Quiet */
  1274. #define DOT11_MNG_IBSS_DFS_ID 41 /* 11H IBSS_DFS */
  1275. #define DOT11_MNG_ERP_ID 42 /* d11 management ERP id */
  1276. #define DOT11_MNG_TS_DELAY_ID 43 /* d11 management TS Delay id */
  1277. #define DOT11_MNG_TCLAS_PROC_ID 44 /* d11 management TCLAS processing id */
  1278. #define DOT11_MNG_HT_CAP 45 /* d11 mgmt HT cap id */
  1279. #define DOT11_MNG_QOS_CAP_ID 46 /* 11E QoS Capability id */
  1280. #define DOT11_MNG_NONERP_ID 47 /* d11 management NON-ERP id */
  1281. #define DOT11_MNG_RSN_ID 48 /* d11 management RSN id */
  1282. #define DOT11_MNG_EXT_RATES_ID 50 /* d11 management ext. rates id */
  1283. #define DOT11_MNG_AP_CHREP_ID 51 /* 11k AP Channel report id */
  1284. #define DOT11_MNG_NEIGHBOR_REP_ID 52 /* 11k & 11v Neighbor report id */
  1285. #define DOT11_MNG_RCPI_ID 53 /* 11k RCPI */
  1286. #define DOT11_MNG_MDIE_ID 54 /* 11r Mobility domain id */
  1287. #define DOT11_MNG_FTIE_ID 55 /* 11r Fast Bss Transition id */
  1288. #define DOT11_MNG_FT_TI_ID 56 /* 11r Timeout Interval id */
  1289. #define DOT11_MNG_RDE_ID 57 /* 11r RIC Data Element id */
  1290. #define DOT11_MNG_REGCLASS_ID 59 /* d11 management regulatory class id */
  1291. #define DOT11_MNG_EXT_CSA_ID 60 /* d11 Extended CSA */
  1292. #define DOT11_MNG_HT_ADD 61 /* d11 mgmt additional HT info */
  1293. #define DOT11_MNG_EXT_CHANNEL_OFFSET 62 /* d11 mgmt ext channel offset */
  1294. #define DOT11_MNG_BSS_AVR_ACCESS_DELAY_ID 63 /* 11k bss average access delay */
  1295. #define DOT11_MNG_ANTENNA_ID 64 /* 11k antenna id */
  1296. #define DOT11_MNG_RSNI_ID 65 /* 11k RSNI id */
  1297. #define DOT11_MNG_MEASUREMENT_PILOT_TX_ID 66 /* 11k measurement pilot tx info id */
  1298. #define DOT11_MNG_BSS_AVAL_ADMISSION_CAP_ID 67 /* 11k bss aval admission cap id */
  1299. #define DOT11_MNG_BSS_AC_ACCESS_DELAY_ID 68 /* 11k bss AC access delay id */
  1300. #define DOT11_MNG_WAPI_ID 68 /* d11 management WAPI id */
  1301. #define DOT11_MNG_TIME_ADVERTISE_ID 69 /* 11p time advertisement */
  1302. #define DOT11_MNG_RRM_CAP_ID 70 /* 11k radio measurement capability */
  1303. #define DOT11_MNG_MULTIPLE_BSSID_ID 71 /* 11k multiple BSSID id */
  1304. #define DOT11_MNG_HT_BSS_COEXINFO_ID 72 /* d11 mgmt OBSS Coexistence INFO */
  1305. #define DOT11_MNG_HT_BSS_CHANNEL_REPORT_ID 73 /* d11 mgmt OBSS Intolerant Channel list */
  1306. #define DOT11_MNG_HT_OBSS_ID 74 /* d11 mgmt OBSS HT info */
  1307. #define DOT11_MNG_MMIE_ID 76 /* d11 mgmt MIC IE */
  1308. #define DOT11_MNG_NONTRANS_BSSID_CAP_ID 83 /* 11k nontransmitted BSSID capability */
  1309. #define DOT11_MNG_MULTIPLE_BSSIDINDEX_ID 85 /* 11k multiple BSSID index */
  1310. #define DOT11_MNG_FMS_DESCR_ID 86 /* 11v FMS descriptor */
  1311. #define DOT11_MNG_FMS_REQ_ID 87 /* 11v FMS request id */
  1312. #define DOT11_MNG_FMS_RESP_ID 88 /* 11v FMS response id */
  1313. #define DOT11_MNG_BSS_MAX_IDLE_PERIOD_ID 90 /* 11v bss max idle id */
  1314. #define DOT11_MNG_TFS_REQUEST_ID 91 /* 11v tfs request id */
  1315. #define DOT11_MNG_TFS_RESPONSE_ID 92 /* 11v tfs response id */
  1316. #define DOT11_MNG_WNM_SLEEP_MODE_ID 93 /* 11v wnm-sleep mode id */
  1317. #define DOT11_MNG_TIMBC_REQ_ID 94 /* 11v TIM broadcast request id */
  1318. #define DOT11_MNG_TIMBC_RESP_ID 95 /* 11v TIM broadcast response id */
  1319. #define DOT11_MNG_CHANNEL_USAGE 97 /* 11v channel usage */
  1320. #define DOT11_MNG_TIME_ZONE_ID 98 /* 11v time zone */
  1321. #define DOT11_MNG_DMS_REQUEST_ID 99 /* 11v dms request id */
  1322. #define DOT11_MNG_DMS_RESPONSE_ID 100 /* 11v dms response id */
  1323. #define DOT11_MNG_LINK_IDENTIFIER_ID 101 /* 11z TDLS Link Identifier IE */
  1324. #define DOT11_MNG_WAKEUP_SCHEDULE_ID 102 /* 11z TDLS Wakeup Schedule IE */
  1325. #define DOT11_MNG_CHANNEL_SWITCH_TIMING_ID 104 /* 11z TDLS Channel Switch Timing IE */
  1326. #define DOT11_MNG_PTI_CONTROL_ID 105 /* 11z TDLS PTI Control IE */
  1327. #define DOT11_MNG_PU_BUFFER_STATUS_ID 106 /* 11z TDLS PU Buffer Status IE */
  1328. #define DOT11_MNG_INTERWORKING_ID 107 /* 11u interworking */
  1329. #define DOT11_MNG_ADVERTISEMENT_ID 108 /* 11u advertisement protocol */
  1330. #define DOT11_MNG_EXP_BW_REQ_ID 109 /* 11u expedited bandwith request */
  1331. #define DOT11_MNG_QOS_MAP_ID 110 /* 11u QoS map set */
  1332. #define DOT11_MNG_ROAM_CONSORT_ID 111 /* 11u roaming consortium */
  1333. #define DOT11_MNG_EMERGCY_ALERT_ID 112 /* 11u emergency alert identifier */
  1334. #define DOT11_MNG_MESH_CONFIG 113 /* Mesh Configuration */
  1335. #define DOT11_MNG_MESH_ID 114 /* Mesh ID */
  1336. #define DOT11_MNG_MESH_PEER_MGMT_ID 117 /* Mesh PEER MGMT IE */
  1337. #define DOT11_MNG_EXT_CAP_ID 127 /* d11 mgmt ext capability */
  1338. #define DOT11_MNG_EXT_PREQ_ID 130 /* Mesh PREQ IE */
  1339. #define DOT11_MNG_EXT_PREP_ID 131 /* Mesh PREP IE */
  1340. #define DOT11_MNG_EXT_PERR_ID 132 /* Mesh PERR IE */
  1341. #define DOT11_MNG_VHT_CAP_ID 191 /* d11 mgmt VHT cap id */
  1342. #define DOT11_MNG_VHT_OPERATION_ID 192 /* d11 mgmt VHT op id */
  1343. #define DOT11_MNG_EXT_BSSLOAD_ID 193 /* d11 mgmt VHT extended bss load id */
  1344. #define DOT11_MNG_WIDE_BW_CHANNEL_SWITCH_ID 194 /* Wide BW Channel Switch IE */
  1345. #define DOT11_MNG_VHT_TRANSMIT_POWER_ENVELOPE_ID 195 /* VHT transmit Power Envelope IE */
  1346. #define DOT11_MNG_CHANNEL_SWITCH_WRAPPER_ID 196 /* Channel Switch Wrapper IE */
  1347. #define DOT11_MNG_AID_ID 197 /* Association ID IE */
  1348. #define DOT11_MNG_OPER_MODE_NOTIF_ID 199 /* d11 mgmt VHT oper mode notif */
  1349. #define DOT11_MNG_RNR_ID 201
  1350. #define DOT11_MNG_FTM_PARAMS_ID 206
  1351. #define DOT11_MNG_TWT_ID 216 /* 11ah D5.0 */
  1352. #define DOT11_MNG_WPA_ID 221 /* d11 management WPA id */
  1353. #define DOT11_MNG_PROPR_ID 221
  1354. /* should start using this one instead of above two */
  1355. #define DOT11_MNG_VS_ID 221 /* d11 management Vendor Specific IE */
  1356. #define DOT11_MNG_MESH_CSP_ID 222 /* d11 Mesh Channel Switch Parameter */
  1357. #define DOT11_MNG_FILS_IND_ID 240 /* 11ai FILS Indication element */
  1358. #define DOT11_MNG_FRAGMENT_ID 242 /* IE's fragment ID */
  1359. /* The follwing ID extensions should be defined >= 255
  1360. * i.e. the values should include 255 (DOT11_MNG_ID_EXT_ID + ID Extension).
  1361. */
  1362. #define DOT11_MNG_ID_EXT_ID 255 /* Element ID Extension 11mc D4.3 */
  1363. #define EXT_MNG_OWE_DH_PARAM_ID 32u /* OWE DH Param ID - RFC 8110 */
  1364. #define DOT11_MNG_OWE_DH_PARAM_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_OWE_DH_PARAM_ID)
  1365. #define EXT_MNG_HE_CAP_ID 35u /* HE Capabilities, 11ax */
  1366. #define DOT11_MNG_HE_CAP_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_HE_CAP_ID)
  1367. #define EXT_MNG_HE_OP_ID 36u /* HE Operation IE, 11ax */
  1368. #define DOT11_MNG_HE_OP_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_HE_OP_ID)
  1369. #define EXT_MNG_UORA_ID 37u /* UORA Parameter Set */
  1370. #define DOT11_MNG_UORA_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_UORA_ID)
  1371. #define EXT_MNG_MU_EDCA_ID 38u /* MU EDCA Parameter Set */
  1372. #define DOT11_MNG_MU_EDCA_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_MU_EDCA_ID)
  1373. #define EXT_MNG_SRPS_ID 39u /* Spatial Reuse Parameter Set */
  1374. #define DOT11_MNG_SRPS_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_SRPS_ID)
  1375. #define EXT_MNG_BSSCOLOR_CHANGE_ID 42u /* BSS Color Change Announcement */
  1376. #define DOT11_MNG_BSSCOLOR_CHANGE_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_BSSCOLOR_CHANGE_ID)
  1377. /* FILS and OCE ext ids */
  1378. #define FILS_EXTID_MNG_REQ_PARAMS 2u /* FILS Request Parameters element */
  1379. #define DOT11_MNG_FILS_REQ_PARAMS (DOT11_MNG_ID_EXT_ID + FILS_EXTID_MNG_REQ_PARAMS)
  1380. #define FILS_EXTID_MNG_KEY_CONFIRMATION_ID 3u /* FILS Key Confirmation element */
  1381. #define DOT11_MNG_FILS_KEY_CONFIRMATION (DOT11_MNG_ID_EXT_ID +\
  1382. FILS_EXTID_MNG_KEY_CONFIRMATION_ID)
  1383. #define FILS_EXTID_MNG_SESSION_ID 4u /* FILS Session element */
  1384. #define DOT11_MNG_FILS_SESSION (DOT11_MNG_ID_EXT_ID + FILS_EXTID_MNG_SESSION_ID)
  1385. #define FILS_EXTID_MNG_HLP_CONTAINER_ID 5u /* FILS HLP Container element */
  1386. #define DOT11_MNG_FILS_HLP_CONTAINER (DOT11_MNG_ID_EXT_ID +\
  1387. FILS_EXTID_MNG_HLP_CONTAINER_ID)
  1388. #define FILS_EXTID_MNG_KEY_DELIVERY_ID 7u /* FILS Key Delivery element */
  1389. #define DOT11_MNG_FILS_KEY_DELIVERY (DOT11_MNG_ID_EXT_ID +\
  1390. FILS_EXTID_MNG_KEY_DELIVERY_ID)
  1391. #define FILS_EXTID_MNG_WRAPPED_DATA_ID 8u /* FILS Wrapped Data element */
  1392. #define DOT11_MNG_FILS_WRAPPED_DATA (DOT11_MNG_ID_EXT_ID +\
  1393. FILS_EXTID_MNG_WRAPPED_DATA_ID)
  1394. #define OCE_EXTID_MNG_ESP_ID 11u /* Estimated Service Parameters element */
  1395. #define DOT11_MNG_ESP (DOT11_MNG_ID_EXT_ID + OCE_EXTID_MNG_ESP_ID)
  1396. #define FILS_EXTID_MNG_NONCE_ID 13u /* FILS Nonce element */
  1397. #define DOT11_MNG_FILS_NONCE (DOT11_MNG_ID_EXT_ID + FILS_EXTID_MNG_NONCE_ID)
  1398. /* deprecated definitions, do not use, to be deleted later */
  1399. #define FILS_HLP_CONTAINER_EXT_ID FILS_EXTID_MNG_HLP_CONTAINER_ID
  1400. #define DOT11_ESP_EXT_ID OCE_EXTID_MNG_ESP_ID
  1401. #define FILS_REQ_PARAMS_EXT_ID FILS_EXTID_MNG_REQ_PARAMS
  1402. #define EXT_MNG_RAPS_ID 37u /* OFDMA Random Access Parameter Set */
  1403. #define DOT11_MNG_RAPS_ID (DOT11_MNG_ID_EXT_ID + EXT_MNG_RAPS_ID)
  1404. /* End of deprecated definitions */
  1405. #define DOT11_MNG_IE_ID_EXT_MATCH(_ie, _id) (\
  1406. ((_ie)->id == DOT11_MNG_ID_EXT_ID) && \
  1407. ((_ie)->len > 0) && \
  1408. ((_id) == ((uint8 *)(_ie) + TLV_HDR_LEN)[0]))
  1409. #define DOT11_MNG_IE_ID_EXT_INIT(_ie, _id, _len) do {\
  1410. (_ie)->id = DOT11_MNG_ID_EXT_ID; \
  1411. (_ie)->len = _len; \
  1412. (_ie)->id_ext = _id; \
  1413. } while (0)
  1414. /* Rate Defines */
  1415. /* Valid rates for the Supported Rates and Extended Supported Rates IEs.
  1416. * Encoding is the rate in 500kbps units, rouding up for fractional values.
  1417. * 802.11-2012, section 6.5.5.2, DATA_RATE parameter enumerates all the values.
  1418. * The rate values cover DSSS, HR/DSSS, ERP, and OFDM phy rates.
  1419. * The defines below do not cover the rates specific to 10MHz, {3, 4.5, 27},
  1420. * and 5MHz, {1.5, 2.25, 3, 4.5, 13.5}, which are not supported by Broadcom devices.
  1421. */
  1422. #define DOT11_RATE_1M 2 /* 1 Mbps in 500kbps units */
  1423. #define DOT11_RATE_2M 4 /* 2 Mbps in 500kbps units */
  1424. #define DOT11_RATE_5M5 11 /* 5.5 Mbps in 500kbps units */
  1425. #define DOT11_RATE_11M 22 /* 11 Mbps in 500kbps units */
  1426. #define DOT11_RATE_6M 12 /* 6 Mbps in 500kbps units */
  1427. #define DOT11_RATE_9M 18 /* 9 Mbps in 500kbps units */
  1428. #define DOT11_RATE_12M 24 /* 12 Mbps in 500kbps units */
  1429. #define DOT11_RATE_18M 36 /* 18 Mbps in 500kbps units */
  1430. #define DOT11_RATE_24M 48 /* 24 Mbps in 500kbps units */
  1431. #define DOT11_RATE_36M 72 /* 36 Mbps in 500kbps units */
  1432. #define DOT11_RATE_48M 96 /* 48 Mbps in 500kbps units */
  1433. #define DOT11_RATE_54M 108 /* 54 Mbps in 500kbps units */
  1434. #define DOT11_RATE_MAX 108 /* highest rate (54 Mbps) in 500kbps units */
  1435. /* Supported Rates and Extended Supported Rates IEs
  1436. * The supported rates octets are defined a the MSB indicatin a Basic Rate
  1437. * and bits 0-6 as the rate value
  1438. */
  1439. #define DOT11_RATE_BASIC 0x80 /* flag for a Basic Rate */
  1440. #define DOT11_RATE_MASK 0x7F /* mask for numeric part of rate */
  1441. /* BSS Membership Selector parameters
  1442. * 802.11-2016 (and 802.11ax-D1.1), Sec 9.4.2.3
  1443. * These selector values are advertised in Supported Rates and Extended Supported Rates IEs
  1444. * in the supported rates list with the Basic rate bit set.
  1445. * Constants below include the basic bit.
  1446. */
  1447. #define DOT11_BSS_MEMBERSHIP_HT 0xFF /* Basic 0x80 + 127, HT Required to join */
  1448. #define DOT11_BSS_MEMBERSHIP_VHT 0xFE /* Basic 0x80 + 126, VHT Required to join */
  1449. #define DOT11_BSS_MEMBERSHIP_HE 0xFD /* Basic 0x80 + 125, HE Required to join */
  1450. /* ERP info element bit values */
  1451. #define DOT11_MNG_ERP_LEN 1 /* ERP is currently 1 byte long */
  1452. #define DOT11_MNG_NONERP_PRESENT 0x01 /* NonERP (802.11b) STAs are present
  1453. *in the BSS
  1454. */
  1455. #define DOT11_MNG_USE_PROTECTION 0x02 /* Use protection mechanisms for
  1456. *ERP-OFDM frames
  1457. */
  1458. #define DOT11_MNG_BARKER_PREAMBLE 0x04 /* Short Preambles: 0 == allowed,
  1459. * 1 == not allowed
  1460. */
  1461. /* TS Delay element offset & size */
  1462. #define DOT11_MGN_TS_DELAY_LEN 4 /* length of TS DELAY IE */
  1463. #define TS_DELAY_FIELD_SIZE 4 /* TS DELAY field size */
  1464. /* Capability Information Field */
  1465. #define DOT11_CAP_ESS 0x0001 /* d11 cap. ESS */
  1466. #define DOT11_CAP_IBSS 0x0002 /* d11 cap. IBSS */
  1467. #define DOT11_CAP_POLLABLE 0x0004 /* d11 cap. pollable */
  1468. #define DOT11_CAP_POLL_RQ 0x0008 /* d11 cap. poll request */
  1469. #define DOT11_CAP_PRIVACY 0x0010 /* d11 cap. privacy */
  1470. #define DOT11_CAP_SHORT 0x0020 /* d11 cap. short */
  1471. #define DOT11_CAP_PBCC 0x0040 /* d11 cap. PBCC */
  1472. #define DOT11_CAP_AGILITY 0x0080 /* d11 cap. agility */
  1473. #define DOT11_CAP_SPECTRUM 0x0100 /* d11 cap. spectrum */
  1474. #define DOT11_CAP_QOS 0x0200 /* d11 cap. qos */
  1475. #define DOT11_CAP_SHORTSLOT 0x0400 /* d11 cap. shortslot */
  1476. #define DOT11_CAP_APSD 0x0800 /* d11 cap. apsd */
  1477. #define DOT11_CAP_RRM 0x1000 /* d11 cap. 11k radio measurement */
  1478. #define DOT11_CAP_CCK_OFDM 0x2000 /* d11 cap. CCK/OFDM */
  1479. #define DOT11_CAP_DELAY_BA 0x4000 /* d11 cap. delayed block ack */
  1480. #define DOT11_CAP_IMMEDIATE_BA 0x8000 /* d11 cap. immediate block ack */
  1481. /* Extended capabilities IE bitfields */
  1482. /* 20/40 BSS Coexistence Management support bit position */
  1483. #define DOT11_EXT_CAP_OBSS_COEX_MGMT 0
  1484. /* Extended Channel Switching support bit position */
  1485. #define DOT11_EXT_CAP_EXT_CHAN_SWITCHING 2
  1486. /* scheduled PSMP support bit position */
  1487. #define DOT11_EXT_CAP_SPSMP 6
  1488. /* Flexible Multicast Service */
  1489. #define DOT11_EXT_CAP_FMS 11
  1490. /* proxy ARP service support bit position */
  1491. #define DOT11_EXT_CAP_PROXY_ARP 12
  1492. /* Civic Location */
  1493. #define DOT11_EXT_CAP_CIVIC_LOC 14
  1494. /* Geospatial Location */
  1495. #define DOT11_EXT_CAP_LCI 15
  1496. /* Traffic Filter Service */
  1497. #define DOT11_EXT_CAP_TFS 16
  1498. /* WNM-Sleep Mode */
  1499. #define DOT11_EXT_CAP_WNM_SLEEP 17
  1500. /* TIM Broadcast service */
  1501. #define DOT11_EXT_CAP_TIMBC 18
  1502. /* BSS Transition Management support bit position */
  1503. #define DOT11_EXT_CAP_BSSTRANS_MGMT 19
  1504. /* Multiple BSSID support position */
  1505. #define DOT11_EXT_CAP_MULTIBSSID 22
  1506. /* Direct Multicast Service */
  1507. #define DOT11_EXT_CAP_DMS 26
  1508. /* Interworking support bit position */
  1509. #define DOT11_EXT_CAP_IW 31
  1510. /* QoS map support bit position */
  1511. #define DOT11_EXT_CAP_QOS_MAP 32
  1512. /* service Interval granularity bit position and mask */
  1513. #define DOT11_EXT_CAP_SI 41
  1514. #define DOT11_EXT_CAP_SI_MASK 0x0E
  1515. /* Location Identifier service */
  1516. #define DOT11_EXT_CAP_IDENT_LOC 44
  1517. /* WNM notification */
  1518. #define DOT11_EXT_CAP_WNM_NOTIF 46
  1519. /* Operating mode notification - VHT (11ac D3.0 - 8.4.2.29) */
  1520. #define DOT11_EXT_CAP_OPER_MODE_NOTIF 62
  1521. /* Fine timing measurement - D3.0 */
  1522. #define DOT11_EXT_CAP_FTM_RESPONDER 70
  1523. #define DOT11_EXT_CAP_FTM_INITIATOR 71 /* tentative 11mcd3.0 */
  1524. #define DOT11_EXT_CAP_FILS 72 /* FILS Capability */
  1525. /* TWT support */
  1526. #define DOT11_EXT_CAP_TWT_REQUESTER 77
  1527. #define DOT11_EXT_CAP_TWT_RESPONDER 78
  1528. #define DOT11_EXT_CAP_OBSS_NB_RU_OFDMA 79
  1529. #define DOT11_EXT_CAP_EMBSS_ADVERTISE 80
  1530. /* TODO: Update DOT11_EXT_CAP_MAX_IDX to reflect the highest offset.
  1531. * Note: DOT11_EXT_CAP_MAX_IDX must only be used in attach path.
  1532. * It will cause ROM invalidation otherwise.
  1533. */
  1534. #define DOT11_EXT_CAP_MAX_IDX 80
  1535. #define DOT11_EXT_CAP_MAX_BIT_IDX 95 /* !!!update this please!!! */
  1536. /* extended capability */
  1537. #ifndef DOT11_EXTCAP_LEN_MAX
  1538. #define DOT11_EXTCAP_LEN_MAX ((DOT11_EXT_CAP_MAX_BIT_IDX + 8) >> 3)
  1539. #endif // endif
  1540. BWL_PRE_PACKED_STRUCT struct dot11_extcap {
  1541. uint8 extcap[DOT11_EXTCAP_LEN_MAX];
  1542. } BWL_POST_PACKED_STRUCT;
  1543. typedef struct dot11_extcap dot11_extcap_t;
  1544. /* VHT Operating mode bit fields - (11ac D8.0/802.11-2016 - 9.4.1.53) */
  1545. #define DOT11_OPER_MODE_CHANNEL_WIDTH_SHIFT 0
  1546. #define DOT11_OPER_MODE_CHANNEL_WIDTH_MASK 0x3
  1547. #define DOT11_OPER_MODE_160_8080_BW_SHIFT 2
  1548. #define DOT11_OPER_MODE_160_8080_BW_MASK 0x04
  1549. #define DOT11_OPER_MODE_NOLDPC_SHIFT 3
  1550. #define DOT11_OPER_MODE_NOLDPC_MASK 0x08
  1551. #define DOT11_OPER_MODE_RXNSS_SHIFT 4
  1552. #define DOT11_OPER_MODE_RXNSS_MASK 0x70
  1553. #define DOT11_OPER_MODE_RXNSS_TYPE_SHIFT 7
  1554. #define DOT11_OPER_MODE_RXNSS_TYPE_MASK 0x80
  1555. #define DOT11_OPER_MODE(type, nss, chanw) (\
  1556. ((type) << DOT11_OPER_MODE_RXNSS_TYPE_SHIFT &\
  1557. DOT11_OPER_MODE_RXNSS_TYPE_MASK) |\
  1558. (((nss) - 1) << DOT11_OPER_MODE_RXNSS_SHIFT & DOT11_OPER_MODE_RXNSS_MASK) |\
  1559. ((chanw) << DOT11_OPER_MODE_CHANNEL_WIDTH_SHIFT &\
  1560. DOT11_OPER_MODE_CHANNEL_WIDTH_MASK))
  1561. #define DOT11_D8_OPER_MODE(type, nss, ldpc, bw160_8080, chanw) (\
  1562. ((type) << DOT11_OPER_MODE_RXNSS_TYPE_SHIFT &\
  1563. DOT11_OPER_MODE_RXNSS_TYPE_MASK) |\
  1564. (((nss) - 1) << DOT11_OPER_MODE_RXNSS_SHIFT & DOT11_OPER_MODE_RXNSS_MASK) |\
  1565. ((ldpc) << DOT11_OPER_MODE_NOLDPC_SHIFT & DOT11_OPER_MODE_NOLDPC_MASK) |\
  1566. ((bw160_8080) << DOT11_OPER_MODE_160_8080_BW_SHIFT &\
  1567. DOT11_OPER_MODE_160_8080_BW_MASK) |\
  1568. ((chanw) << DOT11_OPER_MODE_CHANNEL_WIDTH_SHIFT &\
  1569. DOT11_OPER_MODE_CHANNEL_WIDTH_MASK))
  1570. #define DOT11_OPER_MODE_CHANNEL_WIDTH(mode) \
  1571. (((mode) & DOT11_OPER_MODE_CHANNEL_WIDTH_MASK)\
  1572. >> DOT11_OPER_MODE_CHANNEL_WIDTH_SHIFT)
  1573. #define DOT11_OPER_MODE_160_8080(mode) \
  1574. (((mode) & DOT11_OPER_MODE_160_8080_BW_MASK)\
  1575. >> DOT11_OPER_MODE_160_8080_BW_SHIFT)
  1576. #define DOT11_OPER_MODE_RXNSS(mode) \
  1577. ((((mode) & DOT11_OPER_MODE_RXNSS_MASK) \
  1578. >> DOT11_OPER_MODE_RXNSS_SHIFT) + 1)
  1579. #define DOT11_OPER_MODE_RXNSS_TYPE(mode) \
  1580. (((mode) & DOT11_OPER_MODE_RXNSS_TYPE_MASK)\
  1581. >> DOT11_OPER_MODE_RXNSS_TYPE_SHIFT)
  1582. #define DOT11_OPER_MODE_20MHZ 0
  1583. #define DOT11_OPER_MODE_40MHZ 1
  1584. #define DOT11_OPER_MODE_80MHZ 2
  1585. #define DOT11_OPER_MODE_160MHZ 3
  1586. #define DOT11_OPER_MODE_8080MHZ 3
  1587. #define DOT11_OPER_MODE_1608080MHZ 1
  1588. #define DOT11_OPER_MODE_CHANNEL_WIDTH_20MHZ(mode) (\
  1589. ((mode) & DOT11_OPER_MODE_CHANNEL_WIDTH_MASK) == DOT11_OPER_MODE_20MHZ)
  1590. #define DOT11_OPER_MODE_CHANNEL_WIDTH_40MHZ(mode) (\
  1591. ((mode) & DOT11_OPER_MODE_CHANNEL_WIDTH_MASK) == DOT11_OPER_MODE_40MHZ)
  1592. #define DOT11_OPER_MODE_CHANNEL_WIDTH_80MHZ(mode) (\
  1593. ((mode) & DOT11_OPER_MODE_CHANNEL_WIDTH_MASK) == DOT11_OPER_MODE_80MHZ)
  1594. #define DOT11_OPER_MODE_CHANNEL_WIDTH_160MHZ(mode) (\
  1595. ((mode) & DOT11_OPER_MODE_160_8080_BW_MASK))
  1596. #define DOT11_OPER_MODE_CHANNEL_WIDTH_8080MHZ(mode) (\
  1597. ((mode) & DOT11_OPER_MODE_160_8080_BW_MASK))
  1598. /* Operating mode information element 802.11ac D3.0 - 8.4.2.168 */
  1599. BWL_PRE_PACKED_STRUCT struct dot11_oper_mode_notif_ie {
  1600. uint8 mode;
  1601. } BWL_POST_PACKED_STRUCT;
  1602. typedef struct dot11_oper_mode_notif_ie dot11_oper_mode_notif_ie_t;
  1603. #define DOT11_OPER_MODE_NOTIF_IE_LEN 1
  1604. /* Extended Capability Information Field */
  1605. #define DOT11_OBSS_COEX_MNG_SUPPORT 0x01 /* 20/40 BSS Coexistence Management support */
  1606. /*
  1607. * Action Frame Constants
  1608. */
  1609. #define DOT11_ACTION_HDR_LEN 2 /* action frame category + action field */
  1610. #define DOT11_ACTION_CAT_OFF 0 /* category offset */
  1611. #define DOT11_ACTION_ACT_OFF 1 /* action offset */
  1612. /* Action Category field (sec 8.4.1.11) */
  1613. #define DOT11_ACTION_CAT_ERR_MASK 0x80 /* category error mask */
  1614. #define DOT11_ACTION_CAT_MASK 0x7F /* category mask */
  1615. #define DOT11_ACTION_CAT_SPECT_MNG 0 /* category spectrum management */
  1616. #define DOT11_ACTION_CAT_QOS 1 /* category QoS */
  1617. #define DOT11_ACTION_CAT_DLS 2 /* category DLS */
  1618. #define DOT11_ACTION_CAT_BLOCKACK 3 /* category block ack */
  1619. #define DOT11_ACTION_CAT_PUBLIC 4 /* category public */
  1620. #define DOT11_ACTION_CAT_RRM 5 /* category radio measurements */
  1621. #define DOT11_ACTION_CAT_FBT 6 /* category fast bss transition */
  1622. #define DOT11_ACTION_CAT_HT 7 /* category for HT */
  1623. #define DOT11_ACTION_CAT_SA_QUERY 8 /* security association query */
  1624. #define DOT11_ACTION_CAT_PDPA 9 /* protected dual of public action */
  1625. #define DOT11_ACTION_CAT_WNM 10 /* category for WNM */
  1626. #define DOT11_ACTION_CAT_UWNM 11 /* category for Unprotected WNM */
  1627. #define DOT11_ACTION_CAT_MESH 13 /* category for Mesh */
  1628. #define DOT11_ACTION_CAT_SELFPROT 15 /* category for Mesh, self protected */
  1629. #define DOT11_ACTION_NOTIFICATION 17
  1630. #define DOT11_ACTION_CAT_VHT 21 /* VHT action */
  1631. #define DOT11_ACTION_CAT_S1G 22 /* S1G action */
  1632. #define DOT11_ACTION_CAT_HE 27 /* HE action frame */
  1633. #define DOT11_ACTION_CAT_FILS 26 /* FILS action frame */
  1634. #define DOT11_ACTION_CAT_VSP 126 /* protected vendor specific */
  1635. #define DOT11_ACTION_CAT_VS 127 /* category Vendor Specific */
  1636. /* Spectrum Management Action IDs (sec 7.4.1) */
  1637. #define DOT11_SM_ACTION_M_REQ 0 /* d11 action measurement request */
  1638. #define DOT11_SM_ACTION_M_REP 1 /* d11 action measurement response */
  1639. #define DOT11_SM_ACTION_TPC_REQ 2 /* d11 action TPC request */
  1640. #define DOT11_SM_ACTION_TPC_REP 3 /* d11 action TPC response */
  1641. #define DOT11_SM_ACTION_CHANNEL_SWITCH 4 /* d11 action channel switch */
  1642. #define DOT11_SM_ACTION_EXT_CSA 5 /* d11 extened CSA for 11n */
  1643. /* QoS action ids */
  1644. #define DOT11_QOS_ACTION_ADDTS_REQ 0 /* d11 action ADDTS request */
  1645. #define DOT11_QOS_ACTION_ADDTS_RESP 1 /* d11 action ADDTS response */
  1646. #define DOT11_QOS_ACTION_DELTS 2 /* d11 action DELTS */
  1647. #define DOT11_QOS_ACTION_SCHEDULE 3 /* d11 action schedule */
  1648. #define DOT11_QOS_ACTION_QOS_MAP 4 /* d11 action QOS map */
  1649. /* HT action ids */
  1650. #define DOT11_ACTION_ID_HT_CH_WIDTH 0 /* notify channel width action id */
  1651. #define DOT11_ACTION_ID_HT_MIMO_PS 1 /* mimo ps action id */
  1652. /* Public action ids */
  1653. #define DOT11_PUB_ACTION_BSS_COEX_MNG 0 /* 20/40 Coexistence Management action id */
  1654. #define DOT11_PUB_ACTION_CHANNEL_SWITCH 4 /* d11 action channel switch */
  1655. #define DOT11_PUB_ACTION_VENDOR_SPEC 9 /* Vendor specific */
  1656. #define DOT11_PUB_ACTION_GAS_CB_REQ 12 /* GAS Comeback Request */
  1657. #define DOT11_PUB_ACTION_FTM_REQ 32 /* FTM request */
  1658. #define DOT11_PUB_ACTION_FTM 33 /* FTM measurement */
  1659. #define DOT11_PUB_ACTION_FTM_REQ_TRIGGER_START 1u /* FTM request start trigger */
  1660. #define DOT11_PUB_ACTION_FTM_REQ_TRIGGER_STOP 0u /* FTM request stop trigger */
  1661. /* Block Ack action types */
  1662. #define DOT11_BA_ACTION_ADDBA_REQ 0 /* ADDBA Req action frame type */
  1663. #define DOT11_BA_ACTION_ADDBA_RESP 1 /* ADDBA Resp action frame type */
  1664. #define DOT11_BA_ACTION_DELBA 2 /* DELBA action frame type */
  1665. /* ADDBA action parameters */
  1666. #define DOT11_ADDBA_PARAM_AMSDU_SUP 0x0001 /* AMSDU supported under BA */
  1667. #define DOT11_ADDBA_PARAM_POLICY_MASK 0x0002 /* policy mask(ack vs delayed) */
  1668. #define DOT11_ADDBA_PARAM_POLICY_SHIFT 1 /* policy shift */
  1669. #define DOT11_ADDBA_PARAM_TID_MASK 0x003c /* tid mask */
  1670. #define DOT11_ADDBA_PARAM_TID_SHIFT 2 /* tid shift */
  1671. #define DOT11_ADDBA_PARAM_BSIZE_MASK 0xffc0 /* buffer size mask */
  1672. #define DOT11_ADDBA_PARAM_BSIZE_SHIFT 6 /* buffer size shift */
  1673. #define DOT11_ADDBA_POLICY_DELAYED 0 /* delayed BA policy */
  1674. #define DOT11_ADDBA_POLICY_IMMEDIATE 1 /* immediate BA policy */
  1675. /* Fast Transition action types */
  1676. #define DOT11_FT_ACTION_FT_RESERVED 0
  1677. #define DOT11_FT_ACTION_FT_REQ 1 /* FBT request - for over-the-DS FBT */
  1678. #define DOT11_FT_ACTION_FT_RES 2 /* FBT response - for over-the-DS FBT */
  1679. #define DOT11_FT_ACTION_FT_CON 3 /* FBT confirm - for OTDS with RRP */
  1680. #define DOT11_FT_ACTION_FT_ACK 4 /* FBT ack */
  1681. /* DLS action types */
  1682. #define DOT11_DLS_ACTION_REQ 0 /* DLS Request */
  1683. #define DOT11_DLS_ACTION_RESP 1 /* DLS Response */
  1684. #define DOT11_DLS_ACTION_TD 2 /* DLS Teardown */
  1685. /* Wireless Network Management (WNM) action types */
  1686. #define DOT11_WNM_ACTION_EVENT_REQ 0
  1687. #define DOT11_WNM_ACTION_EVENT_REP 1
  1688. #define DOT11_WNM_ACTION_DIAG_REQ 2
  1689. #define DOT11_WNM_ACTION_DIAG_REP 3
  1690. #define DOT11_WNM_ACTION_LOC_CFG_REQ 4
  1691. #define DOT11_WNM_ACTION_LOC_RFG_RESP 5
  1692. #define DOT11_WNM_ACTION_BSSTRANS_QUERY 6
  1693. #define DOT11_WNM_ACTION_BSSTRANS_REQ 7
  1694. #define DOT11_WNM_ACTION_BSSTRANS_RESP 8
  1695. #define DOT11_WNM_ACTION_FMS_REQ 9
  1696. #define DOT11_WNM_ACTION_FMS_RESP 10
  1697. #define DOT11_WNM_ACTION_COL_INTRFRNCE_REQ 11
  1698. #define DOT11_WNM_ACTION_COL_INTRFRNCE_REP 12
  1699. #define DOT11_WNM_ACTION_TFS_REQ 13
  1700. #define DOT11_WNM_ACTION_TFS_RESP 14
  1701. #define DOT11_WNM_ACTION_TFS_NOTIFY_REQ 15
  1702. #define DOT11_WNM_ACTION_WNM_SLEEP_REQ 16
  1703. #define DOT11_WNM_ACTION_WNM_SLEEP_RESP 17
  1704. #define DOT11_WNM_ACTION_TIMBC_REQ 18
  1705. #define DOT11_WNM_ACTION_TIMBC_RESP 19
  1706. #define DOT11_WNM_ACTION_QOS_TRFC_CAP_UPD 20
  1707. #define DOT11_WNM_ACTION_CHAN_USAGE_REQ 21
  1708. #define DOT11_WNM_ACTION_CHAN_USAGE_RESP 22
  1709. #define DOT11_WNM_ACTION_DMS_REQ 23
  1710. #define DOT11_WNM_ACTION_DMS_RESP 24
  1711. #define DOT11_WNM_ACTION_TMNG_MEASUR_REQ 25
  1712. #define DOT11_WNM_ACTION_NOTFCTN_REQ 26
  1713. #define DOT11_WNM_ACTION_NOTFCTN_RESP 27
  1714. #define DOT11_WNM_ACTION_TFS_NOTIFY_RESP 28
  1715. /* Unprotected Wireless Network Management (WNM) action types */
  1716. #define DOT11_UWNM_ACTION_TIM 0
  1717. #define DOT11_UWNM_ACTION_TIMING_MEASUREMENT 1
  1718. #define DOT11_MNG_COUNTRY_ID_LEN 3
  1719. /* VHT category action types - 802.11ac D3.0 - 8.5.23.1 */
  1720. #define DOT11_VHT_ACTION_CBF 0 /* Compressed Beamforming */
  1721. #define DOT11_VHT_ACTION_GID_MGMT 1 /* Group ID Management */
  1722. #define DOT11_VHT_ACTION_OPER_MODE_NOTIF 2 /* Operating mode notif'n */
  1723. /* FILS category action types - 802.11ai D11.0 - 9.6.8.1 */
  1724. #define DOT11_FILS_ACTION_DISCOVERY 34 /* FILS Discovery */
  1725. /** DLS Request frame header */
  1726. BWL_PRE_PACKED_STRUCT struct dot11_dls_req {
  1727. uint8 category; /* category of action frame (2) */
  1728. uint8 action; /* DLS action: req (0) */
  1729. struct ether_addr da; /* destination address */
  1730. struct ether_addr sa; /* source address */
  1731. uint16 cap; /* capability */
  1732. uint16 timeout; /* timeout value */
  1733. uint8 data[1]; /* IE:support rate, extend support rate, HT cap */
  1734. } BWL_POST_PACKED_STRUCT;
  1735. typedef struct dot11_dls_req dot11_dls_req_t;
  1736. #define DOT11_DLS_REQ_LEN 18 /* Fixed length */
  1737. /** DLS response frame header */
  1738. BWL_PRE_PACKED_STRUCT struct dot11_dls_resp {
  1739. uint8 category; /* category of action frame (2) */
  1740. uint8 action; /* DLS action: req (0) */
  1741. uint16 status; /* status code field */
  1742. struct ether_addr da; /* destination address */
  1743. struct ether_addr sa; /* source address */
  1744. uint8 data[1]; /* optional: capability, rate ... */
  1745. } BWL_POST_PACKED_STRUCT;
  1746. typedef struct dot11_dls_resp dot11_dls_resp_t;
  1747. #define DOT11_DLS_RESP_LEN 16 /* Fixed length */
  1748. /* ************* 802.11v related definitions. ************* */
  1749. /** BSS Management Transition Query frame header */
  1750. BWL_PRE_PACKED_STRUCT struct dot11_bsstrans_query {
  1751. uint8 category; /* category of action frame (10) */
  1752. uint8 action; /* WNM action: trans_query (6) */
  1753. uint8 token; /* dialog token */
  1754. uint8 reason; /* transition query reason */
  1755. uint8 data[1]; /* Elements */
  1756. } BWL_POST_PACKED_STRUCT;
  1757. typedef struct dot11_bsstrans_query dot11_bsstrans_query_t;
  1758. #define DOT11_BSSTRANS_QUERY_LEN 4 /* Fixed length */
  1759. /* BTM transition reason */
  1760. #define DOT11_BSSTRANS_REASON_UNSPECIFIED 0
  1761. #define DOT11_BSSTRANS_REASON_EXC_FRAME_LOSS 1
  1762. #define DOT11_BSSTRANS_REASON_EXC_TRAFFIC_DELAY 2
  1763. #define DOT11_BSSTRANS_REASON_INSUFF_QOS_CAPACITY 3
  1764. #define DOT11_BSSTRANS_REASON_FIRST_ASSOC 4
  1765. #define DOT11_BSSTRANS_REASON_LOAD_BALANCING 5
  1766. #define DOT11_BSSTRANS_REASON_BETTER_AP_FOUND 6
  1767. #define DOT11_BSSTRANS_REASON_DEAUTH_RX 7
  1768. #define DOT11_BSSTRANS_REASON_8021X_EAP_AUTH_FAIL 8
  1769. #define DOT11_BSSTRANS_REASON_4WAY_HANDSHK_FAIL 9
  1770. #define DOT11_BSSTRANS_REASON_MANY_REPLAYCNT_FAIL 10
  1771. #define DOT11_BSSTRANS_REASON_MANY_DATAMIC_FAIL 11
  1772. #define DOT11_BSSTRANS_REASON_EXCEED_MAX_RETRANS 12
  1773. #define DOT11_BSSTRANS_REASON_MANY_BCAST_DISASSOC_RX 13
  1774. #define DOT11_BSSTRANS_REASON_MANY_BCAST_DEAUTH_RX 14
  1775. #define DOT11_BSSTRANS_REASON_PREV_TRANSITION_FAIL 15
  1776. #define DOT11_BSSTRANS_REASON_LOW_RSSI 16
  1777. #define DOT11_BSSTRANS_REASON_ROAM_FROM_NON_80211 17
  1778. #define DOT11_BSSTRANS_REASON_RX_BTM_REQ 18
  1779. #define DOT11_BSSTRANS_REASON_PREF_LIST_INCLUDED 19
  1780. #define DOT11_BSSTRANS_REASON_LEAVING_ESS 20
  1781. /** BSS Management Transition Request frame header */
  1782. BWL_PRE_PACKED_STRUCT struct dot11_bsstrans_req {
  1783. uint8 category; /* category of action frame (10) */
  1784. uint8 action; /* WNM action: trans_req (7) */
  1785. uint8 token; /* dialog token */
  1786. uint8 reqmode; /* transition request mode */
  1787. uint16 disassoc_tmr; /* disassociation timer */
  1788. uint8 validity_intrvl; /* validity interval */
  1789. uint8 data[1]; /* optional: BSS term duration, ... */
  1790. /* ...session info URL, candidate list */
  1791. } BWL_POST_PACKED_STRUCT;
  1792. typedef struct dot11_bsstrans_req dot11_bsstrans_req_t;
  1793. #define DOT11_BSSTRANS_REQ_LEN 7 /* Fixed length */
  1794. #define DOT11_BSSTRANS_REQ_FIXED_LEN 7u /* Fixed length */
  1795. /* BSS Mgmt Transition Request Mode Field - 802.11v */
  1796. #define DOT11_BSSTRANS_REQMODE_PREF_LIST_INCL 0x01
  1797. #define DOT11_BSSTRANS_REQMODE_ABRIDGED 0x02
  1798. #define DOT11_BSSTRANS_REQMODE_DISASSOC_IMMINENT 0x04
  1799. #define DOT11_BSSTRANS_REQMODE_BSS_TERM_INCL 0x08
  1800. #define DOT11_BSSTRANS_REQMODE_ESS_DISASSOC_IMNT 0x10
  1801. /** BSS Management transition response frame header */
  1802. BWL_PRE_PACKED_STRUCT struct dot11_bsstrans_resp {
  1803. uint8 category; /* category of action frame (10) */
  1804. uint8 action; /* WNM action: trans_resp (8) */
  1805. uint8 token; /* dialog token */
  1806. uint8 status; /* transition status */
  1807. uint8 term_delay; /* validity interval */
  1808. uint8 data[1]; /* optional: BSSID target, candidate list */
  1809. } BWL_POST_PACKED_STRUCT;
  1810. typedef struct dot11_bsstrans_resp dot11_bsstrans_resp_t;
  1811. #define DOT11_BSSTRANS_RESP_LEN 5 /* Fixed length */
  1812. /* BSS Mgmt Transition Response Status Field */
  1813. #define DOT11_BSSTRANS_RESP_STATUS_ACCEPT 0
  1814. #define DOT11_BSSTRANS_RESP_STATUS_REJECT 1
  1815. #define DOT11_BSSTRANS_RESP_STATUS_REJ_INSUFF_BCN 2
  1816. #define DOT11_BSSTRANS_RESP_STATUS_REJ_INSUFF_CAP 3
  1817. #define DOT11_BSSTRANS_RESP_STATUS_REJ_TERM_UNDESIRED 4
  1818. #define DOT11_BSSTRANS_RESP_STATUS_REJ_TERM_DELAY_REQ 5
  1819. #define DOT11_BSSTRANS_RESP_STATUS_REJ_BSS_LIST_PROVIDED 6
  1820. #define DOT11_BSSTRANS_RESP_STATUS_REJ_NO_SUITABLE_BSS 7
  1821. #define DOT11_BSSTRANS_RESP_STATUS_REJ_LEAVING_ESS 8
  1822. /** BSS Max Idle Period element */
  1823. BWL_PRE_PACKED_STRUCT struct dot11_bss_max_idle_period_ie {
  1824. uint8 id; /* 90, DOT11_MNG_BSS_MAX_IDLE_PERIOD_ID */
  1825. uint8 len;
  1826. uint16 max_idle_period; /* in unit of 1000 TUs */
  1827. uint8 idle_opt;
  1828. } BWL_POST_PACKED_STRUCT;
  1829. typedef struct dot11_bss_max_idle_period_ie dot11_bss_max_idle_period_ie_t;
  1830. #define DOT11_BSS_MAX_IDLE_PERIOD_IE_LEN 3 /* bss max idle period IE size */
  1831. #define DOT11_BSS_MAX_IDLE_PERIOD_OPT_PROTECTED 1 /* BSS max idle option */
  1832. /** TIM Broadcast request element */
  1833. BWL_PRE_PACKED_STRUCT struct dot11_timbc_req_ie {
  1834. uint8 id; /* 94, DOT11_MNG_TIMBC_REQ_ID */
  1835. uint8 len;
  1836. uint8 interval; /* in unit of beacon interval */
  1837. } BWL_POST_PACKED_STRUCT;
  1838. typedef struct dot11_timbc_req_ie dot11_timbc_req_ie_t;
  1839. #define DOT11_TIMBC_REQ_IE_LEN 1 /* Fixed length */
  1840. /** TIM Broadcast request frame header */
  1841. BWL_PRE_PACKED_STRUCT struct dot11_timbc_req {
  1842. uint8 category; /* category of action frame (10) */
  1843. uint8 action; /* WNM action: DOT11_WNM_ACTION_TIMBC_REQ(18) */
  1844. uint8 token; /* dialog token */
  1845. uint8 data[1]; /* TIM broadcast request element */
  1846. } BWL_POST_PACKED_STRUCT;
  1847. typedef struct dot11_timbc_req dot11_timbc_req_t;
  1848. #define DOT11_TIMBC_REQ_LEN 3 /* Fixed length */
  1849. /** TIM Broadcast response element */
  1850. BWL_PRE_PACKED_STRUCT struct dot11_timbc_resp_ie {
  1851. uint8 id; /* 95, DOT11_MNG_TIM_BROADCAST_RESP_ID */
  1852. uint8 len;
  1853. uint8 status; /* status of add request */
  1854. uint8 interval; /* in unit of beacon interval */
  1855. int32 offset; /* in unit of ms */
  1856. uint16 high_rate; /* in unit of 0.5 Mb/s */
  1857. uint16 low_rate; /* in unit of 0.5 Mb/s */
  1858. } BWL_POST_PACKED_STRUCT;
  1859. typedef struct dot11_timbc_resp_ie dot11_timbc_resp_ie_t;
  1860. #define DOT11_TIMBC_DENY_RESP_IE_LEN 1 /* Deny. Fixed length */
  1861. #define DOT11_TIMBC_ACCEPT_RESP_IE_LEN 10 /* Accept. Fixed length */
  1862. #define DOT11_TIMBC_STATUS_ACCEPT 0
  1863. #define DOT11_TIMBC_STATUS_ACCEPT_TSTAMP 1
  1864. #define DOT11_TIMBC_STATUS_DENY 2
  1865. #define DOT11_TIMBC_STATUS_OVERRIDDEN 3
  1866. #define DOT11_TIMBC_STATUS_RESERVED 4
  1867. /** TIM Broadcast request frame header */
  1868. BWL_PRE_PACKED_STRUCT struct dot11_timbc_resp {
  1869. uint8 category; /* category of action frame (10) */
  1870. uint8 action; /* action: DOT11_WNM_ACTION_TIMBC_RESP(19) */
  1871. uint8 token; /* dialog token */
  1872. uint8 data[1]; /* TIM broadcast response element */
  1873. } BWL_POST_PACKED_STRUCT;
  1874. typedef struct dot11_timbc_resp dot11_timbc_resp_t;
  1875. #define DOT11_TIMBC_RESP_LEN 3 /* Fixed length */
  1876. /** TIM element */
  1877. BWL_PRE_PACKED_STRUCT struct dot11_tim_ie {
  1878. uint8 id; /* 5, DOT11_MNG_TIM_ID */
  1879. uint8 len; /* 4 - 255 */
  1880. uint8 dtim_count; /* DTIM decrementing counter */
  1881. uint8 dtim_period; /* DTIM period */
  1882. uint8 bitmap_control; /* AID 0 + bitmap offset */
  1883. uint8 pvb[1]; /* Partial Virtual Bitmap, variable length */
  1884. } BWL_POST_PACKED_STRUCT;
  1885. typedef struct dot11_tim_ie dot11_tim_ie_t;
  1886. #define DOT11_TIM_IE_FIXED_LEN 3 /* Fixed length, without id and len */
  1887. #define DOT11_TIM_IE_FIXED_TOTAL_LEN 5 /* Fixed length, with id and len */
  1888. /** TIM Broadcast frame header */
  1889. BWL_PRE_PACKED_STRUCT struct dot11_timbc {
  1890. uint8 category; /* category of action frame (11) */
  1891. uint8 action; /* action: TIM (0) */
  1892. uint8 check_beacon; /* need to check-beacon */
  1893. uint8 tsf[8]; /* Time Synchronization Function */
  1894. dot11_tim_ie_t tim_ie; /* TIM element */
  1895. } BWL_POST_PACKED_STRUCT;
  1896. typedef struct dot11_timbc dot11_timbc_t;
  1897. #define DOT11_TIMBC_HDR_LEN (sizeof(dot11_timbc_t) - sizeof(dot11_tim_ie_t))
  1898. #define DOT11_TIMBC_FIXED_LEN (sizeof(dot11_timbc_t) - 1) /* Fixed length */
  1899. #define DOT11_TIMBC_LEN 11 /* Fixed length */
  1900. /** TCLAS frame classifier type */
  1901. BWL_PRE_PACKED_STRUCT struct dot11_tclas_fc_hdr {
  1902. uint8 type;
  1903. uint8 mask;
  1904. uint8 data[1];
  1905. } BWL_POST_PACKED_STRUCT;
  1906. typedef struct dot11_tclas_fc_hdr dot11_tclas_fc_hdr_t;
  1907. #define DOT11_TCLAS_FC_HDR_LEN 2 /* Fixed length */
  1908. #define DOT11_TCLAS_MASK_0 0x1
  1909. #define DOT11_TCLAS_MASK_1 0x2
  1910. #define DOT11_TCLAS_MASK_2 0x4
  1911. #define DOT11_TCLAS_MASK_3 0x8
  1912. #define DOT11_TCLAS_MASK_4 0x10
  1913. #define DOT11_TCLAS_MASK_5 0x20
  1914. #define DOT11_TCLAS_MASK_6 0x40
  1915. #define DOT11_TCLAS_MASK_7 0x80
  1916. #define DOT11_TCLAS_FC_0_ETH 0
  1917. #define DOT11_TCLAS_FC_1_IP 1
  1918. #define DOT11_TCLAS_FC_2_8021Q 2
  1919. #define DOT11_TCLAS_FC_3_OFFSET 3
  1920. #define DOT11_TCLAS_FC_4_IP_HIGHER 4
  1921. #define DOT11_TCLAS_FC_5_8021D 5
  1922. /** TCLAS frame classifier type 0 parameters for Ethernet */
  1923. BWL_PRE_PACKED_STRUCT struct dot11_tclas_fc_0_eth {
  1924. uint8 type;
  1925. uint8 mask;
  1926. uint8 sa[ETHER_ADDR_LEN];
  1927. uint8 da[ETHER_ADDR_LEN];
  1928. uint16 eth_type;
  1929. } BWL_POST_PACKED_STRUCT;
  1930. typedef struct dot11_tclas_fc_0_eth dot11_tclas_fc_0_eth_t;
  1931. #define DOT11_TCLAS_FC_0_ETH_LEN 16
  1932. /** TCLAS frame classifier type 1 parameters for IPV4 */
  1933. BWL_PRE_PACKED_STRUCT struct dot11_tclas_fc_1_ipv4 {
  1934. uint8 type;
  1935. uint8 mask;
  1936. uint8 version;
  1937. uint32 src_ip;
  1938. uint32 dst_ip;
  1939. uint16 src_port;
  1940. uint16 dst_port;
  1941. uint8 dscp;
  1942. uint8 protocol;
  1943. uint8 reserved;
  1944. } BWL_POST_PACKED_STRUCT;
  1945. typedef struct dot11_tclas_fc_1_ipv4 dot11_tclas_fc_1_ipv4_t;
  1946. #define DOT11_TCLAS_FC_1_IPV4_LEN 18
  1947. /** TCLAS frame classifier type 2 parameters for 802.1Q */
  1948. BWL_PRE_PACKED_STRUCT struct dot11_tclas_fc_2_8021q {
  1949. uint8 type;
  1950. uint8 mask;
  1951. uint16 tci;
  1952. } BWL_POST_PACKED_STRUCT;
  1953. typedef struct dot11_tclas_fc_2_8021q dot11_tclas_fc_2_8021q_t;
  1954. #define DOT11_TCLAS_FC_2_8021Q_LEN 4
  1955. /** TCLAS frame classifier type 3 parameters for filter offset */
  1956. BWL_PRE_PACKED_STRUCT struct dot11_tclas_fc_3_filter {
  1957. uint8 type;
  1958. uint8 mask;
  1959. uint16 offset;
  1960. uint8 data[1];
  1961. } BWL_POST_PACKED_STRUCT;
  1962. typedef struct dot11_tclas_fc_3_filter dot11_tclas_fc_3_filter_t;
  1963. #define DOT11_TCLAS_FC_3_FILTER_LEN 4
  1964. /** TCLAS frame classifier type 4 parameters for IPV4 is the same as TCLAS type 1 */
  1965. typedef struct dot11_tclas_fc_1_ipv4 dot11_tclas_fc_4_ipv4_t;
  1966. #define DOT11_TCLAS_FC_4_IPV4_LEN DOT11_TCLAS_FC_1_IPV4_LEN
  1967. /** TCLAS frame classifier type 4 parameters for IPV6 */
  1968. BWL_PRE_PACKED_STRUCT struct dot11_tclas_fc_4_ipv6 {
  1969. uint8 type;
  1970. uint8 mask;
  1971. uint8 version;
  1972. uint8 saddr[16];
  1973. uint8 daddr[16];
  1974. uint16 src_port;
  1975. uint16 dst_port;
  1976. uint8 dscp;
  1977. uint8 nexthdr;
  1978. uint8 flow_lbl[3];
  1979. } BWL_POST_PACKED_STRUCT;
  1980. typedef struct dot11_tclas_fc_4_ipv6 dot11_tclas_fc_4_ipv6_t;
  1981. #define DOT11_TCLAS_FC_4_IPV6_LEN 44
  1982. /** TCLAS frame classifier type 5 parameters for 802.1D */
  1983. BWL_PRE_PACKED_STRUCT struct dot11_tclas_fc_5_8021d {
  1984. uint8 type;
  1985. uint8 mask;
  1986. uint8 pcp;
  1987. uint8 cfi;
  1988. uint16 vid;
  1989. } BWL_POST_PACKED_STRUCT;
  1990. typedef struct dot11_tclas_fc_5_8021d dot11_tclas_fc_5_8021d_t;
  1991. #define DOT11_TCLAS_FC_5_8021D_LEN 6
  1992. /** TCLAS frame classifier type parameters */
  1993. BWL_PRE_PACKED_STRUCT union dot11_tclas_fc {
  1994. uint8 data[1];
  1995. dot11_tclas_fc_hdr_t hdr;
  1996. dot11_tclas_fc_0_eth_t t0_eth;
  1997. dot11_tclas_fc_1_ipv4_t t1_ipv4;
  1998. dot11_tclas_fc_2_8021q_t t2_8021q;
  1999. dot11_tclas_fc_3_filter_t t3_filter;
  2000. dot11_tclas_fc_4_ipv4_t t4_ipv4;
  2001. dot11_tclas_fc_4_ipv6_t t4_ipv6;
  2002. dot11_tclas_fc_5_8021d_t t5_8021d;
  2003. } BWL_POST_PACKED_STRUCT;
  2004. typedef union dot11_tclas_fc dot11_tclas_fc_t;
  2005. #define DOT11_TCLAS_FC_MIN_LEN 4 /* Classifier Type 2 has the min size */
  2006. #define DOT11_TCLAS_FC_MAX_LEN 254
  2007. /** TCLAS element */
  2008. BWL_PRE_PACKED_STRUCT struct dot11_tclas_ie {
  2009. uint8 id; /* 14, DOT11_MNG_TCLAS_ID */
  2010. uint8 len;
  2011. uint8 user_priority;
  2012. dot11_tclas_fc_t fc;
  2013. } BWL_POST_PACKED_STRUCT;
  2014. typedef struct dot11_tclas_ie dot11_tclas_ie_t;
  2015. #define DOT11_TCLAS_IE_LEN 3u /* Fixed length, include id and len */
  2016. /** TCLAS processing element */
  2017. BWL_PRE_PACKED_STRUCT struct dot11_tclas_proc_ie {
  2018. uint8 id; /* 44, DOT11_MNG_TCLAS_PROC_ID */
  2019. uint8 len;
  2020. uint8 process;
  2021. } BWL_POST_PACKED_STRUCT;
  2022. typedef struct dot11_tclas_proc_ie dot11_tclas_proc_ie_t;
  2023. #define DOT11_TCLAS_PROC_IE_LEN 3 /* Fixed length, include id and len */
  2024. #define DOT11_TCLAS_PROC_LEN 1u /* Proc ie length is always 1 byte */
  2025. #define DOT11_TCLAS_PROC_MATCHALL 0 /* All high level element need to match */
  2026. #define DOT11_TCLAS_PROC_MATCHONE 1 /* One high level element need to match */
  2027. #define DOT11_TCLAS_PROC_NONMATCH 2 /* Non match to any high level element */
  2028. /* TSPEC element defined in 802.11 std section 8.4.2.32 - Not supported */
  2029. #define DOT11_TSPEC_IE_LEN 57 /* Fixed length */
  2030. /** TFS request element */
  2031. BWL_PRE_PACKED_STRUCT struct dot11_tfs_req_ie {
  2032. uint8 id; /* 91, DOT11_MNG_TFS_REQUEST_ID */
  2033. uint8 len;
  2034. uint8 tfs_id;
  2035. uint8 actcode;
  2036. uint8 data[1];
  2037. } BWL_POST_PACKED_STRUCT;
  2038. typedef struct dot11_tfs_req_ie dot11_tfs_req_ie_t;
  2039. #define DOT11_TFS_REQ_IE_LEN 2 /* Fixed length, without id and len */
  2040. /** TFS request action codes (bitfield) */
  2041. #define DOT11_TFS_ACTCODE_DELETE 1
  2042. #define DOT11_TFS_ACTCODE_NOTIFY 2
  2043. /** TFS request subelement IDs */
  2044. #define DOT11_TFS_REQ_TFS_SE_ID 1
  2045. #define DOT11_TFS_REQ_VENDOR_SE_ID 221
  2046. /** TFS subelement */
  2047. BWL_PRE_PACKED_STRUCT struct dot11_tfs_se {
  2048. uint8 sub_id;
  2049. uint8 len;
  2050. uint8 data[1]; /* TCLAS element(s) + optional TCLAS proc */
  2051. } BWL_POST_PACKED_STRUCT;
  2052. typedef struct dot11_tfs_se dot11_tfs_se_t;
  2053. /** TFS response element */
  2054. BWL_PRE_PACKED_STRUCT struct dot11_tfs_resp_ie {
  2055. uint8 id; /* 92, DOT11_MNG_TFS_RESPONSE_ID */
  2056. uint8 len;
  2057. uint8 tfs_id;
  2058. uint8 data[1];
  2059. } BWL_POST_PACKED_STRUCT;
  2060. typedef struct dot11_tfs_resp_ie dot11_tfs_resp_ie_t;
  2061. #define DOT11_TFS_RESP_IE_LEN 1u /* Fixed length, without id and len */
  2062. /** TFS response subelement IDs (same subelments, but different IDs than in TFS request */
  2063. #define DOT11_TFS_RESP_TFS_STATUS_SE_ID 1
  2064. #define DOT11_TFS_RESP_TFS_SE_ID 2
  2065. #define DOT11_TFS_RESP_VENDOR_SE_ID 221
  2066. /** TFS status subelement */
  2067. BWL_PRE_PACKED_STRUCT struct dot11_tfs_status_se {
  2068. uint8 sub_id; /* 92, DOT11_MNG_TFS_RESPONSE_ID */
  2069. uint8 len;
  2070. uint8 resp_st;
  2071. uint8 data[1]; /* Potential dot11_tfs_se_t included */
  2072. } BWL_POST_PACKED_STRUCT;
  2073. typedef struct dot11_tfs_status_se dot11_tfs_status_se_t;
  2074. #define DOT11_TFS_STATUS_SE_LEN 1 /* Fixed length, without id and len */
  2075. /* Following Definition should be merged to FMS_TFS macro below */
  2076. /* TFS Response status code. Identical to FMS Element status, without N/A */
  2077. #define DOT11_TFS_STATUS_ACCEPT 0
  2078. #define DOT11_TFS_STATUS_DENY_FORMAT 1
  2079. #define DOT11_TFS_STATUS_DENY_RESOURCE 2
  2080. #define DOT11_TFS_STATUS_DENY_POLICY 4
  2081. #define DOT11_TFS_STATUS_DENY_UNSPECIFIED 5
  2082. #define DOT11_TFS_STATUS_ALTPREF_POLICY 7
  2083. #define DOT11_TFS_STATUS_ALTPREF_TCLAS_UNSUPP 14
  2084. /* FMS Element Status and TFS Response Status Definition */
  2085. #define DOT11_FMS_TFS_STATUS_ACCEPT 0
  2086. #define DOT11_FMS_TFS_STATUS_DENY_FORMAT 1
  2087. #define DOT11_FMS_TFS_STATUS_DENY_RESOURCE 2
  2088. #define DOT11_FMS_TFS_STATUS_DENY_MULTIPLE_DI 3
  2089. #define DOT11_FMS_TFS_STATUS_DENY_POLICY 4
  2090. #define DOT11_FMS_TFS_STATUS_DENY_UNSPECIFIED 5
  2091. #define DOT11_FMS_TFS_STATUS_ALT_DIFF_DI 6
  2092. #define DOT11_FMS_TFS_STATUS_ALT_POLICY 7
  2093. #define DOT11_FMS_TFS_STATUS_ALT_CHANGE_DI 8
  2094. #define DOT11_FMS_TFS_STATUS_ALT_MCRATE 9
  2095. #define DOT11_FMS_TFS_STATUS_TERM_POLICY 10
  2096. #define DOT11_FMS_TFS_STATUS_TERM_RESOURCE 11
  2097. #define DOT11_FMS_TFS_STATUS_TERM_HIGHER_PRIO 12
  2098. #define DOT11_FMS_TFS_STATUS_ALT_CHANGE_MDI 13
  2099. #define DOT11_FMS_TFS_STATUS_ALT_TCLAS_UNSUPP 14
  2100. /** TFS Management Request frame header */
  2101. BWL_PRE_PACKED_STRUCT struct dot11_tfs_req {
  2102. uint8 category; /* category of action frame (10) */
  2103. uint8 action; /* WNM action: TFS request (13) */
  2104. uint8 token; /* dialog token */
  2105. uint8 data[1]; /* Elements */
  2106. } BWL_POST_PACKED_STRUCT;
  2107. typedef struct dot11_tfs_req dot11_tfs_req_t;
  2108. #define DOT11_TFS_REQ_LEN 3 /* Fixed length */
  2109. /** TFS Management Response frame header */
  2110. BWL_PRE_PACKED_STRUCT struct dot11_tfs_resp {
  2111. uint8 category; /* category of action frame (10) */
  2112. uint8 action; /* WNM action: TFS request (14) */
  2113. uint8 token; /* dialog token */
  2114. uint8 data[1]; /* Elements */
  2115. } BWL_POST_PACKED_STRUCT;
  2116. typedef struct dot11_tfs_resp dot11_tfs_resp_t;
  2117. #define DOT11_TFS_RESP_LEN 3 /* Fixed length */
  2118. /** TFS Management Notify frame request header */
  2119. BWL_PRE_PACKED_STRUCT struct dot11_tfs_notify_req {
  2120. uint8 category; /* category of action frame (10) */
  2121. uint8 action; /* WNM action: TFS notify request (15) */
  2122. uint8 tfs_id_cnt; /* TFS IDs count */
  2123. uint8 tfs_id[1]; /* Array of TFS IDs */
  2124. } BWL_POST_PACKED_STRUCT;
  2125. typedef struct dot11_tfs_notify_req dot11_tfs_notify_req_t;
  2126. #define DOT11_TFS_NOTIFY_REQ_LEN 3 /* Fixed length */
  2127. /** TFS Management Notify frame response header */
  2128. BWL_PRE_PACKED_STRUCT struct dot11_tfs_notify_resp {
  2129. uint8 category; /* category of action frame (10) */
  2130. uint8 action; /* WNM action: TFS notify response (28) */
  2131. uint8 tfs_id_cnt; /* TFS IDs count */
  2132. uint8 tfs_id[1]; /* Array of TFS IDs */
  2133. } BWL_POST_PACKED_STRUCT;
  2134. typedef struct dot11_tfs_notify_resp dot11_tfs_notify_resp_t;
  2135. #define DOT11_TFS_NOTIFY_RESP_LEN 3 /* Fixed length */
  2136. /** WNM-Sleep Management Request frame header */
  2137. BWL_PRE_PACKED_STRUCT struct dot11_wnm_sleep_req {
  2138. uint8 category; /* category of action frame (10) */
  2139. uint8 action; /* WNM action: wnm-sleep request (16) */
  2140. uint8 token; /* dialog token */
  2141. uint8 data[1]; /* Elements */
  2142. } BWL_POST_PACKED_STRUCT;
  2143. typedef struct dot11_wnm_sleep_req dot11_wnm_sleep_req_t;
  2144. #define DOT11_WNM_SLEEP_REQ_LEN 3 /* Fixed length */
  2145. /** WNM-Sleep Management Response frame header */
  2146. BWL_PRE_PACKED_STRUCT struct dot11_wnm_sleep_resp {
  2147. uint8 category; /* category of action frame (10) */
  2148. uint8 action; /* WNM action: wnm-sleep request (17) */
  2149. uint8 token; /* dialog token */
  2150. uint16 key_len; /* key data length */
  2151. uint8 data[1]; /* Elements */
  2152. } BWL_POST_PACKED_STRUCT;
  2153. typedef struct dot11_wnm_sleep_resp dot11_wnm_sleep_resp_t;
  2154. #define DOT11_WNM_SLEEP_RESP_LEN 5 /* Fixed length */
  2155. #define DOT11_WNM_SLEEP_SUBELEM_ID_GTK 0
  2156. #define DOT11_WNM_SLEEP_SUBELEM_ID_IGTK 1
  2157. BWL_PRE_PACKED_STRUCT struct dot11_wnm_sleep_subelem_gtk {
  2158. uint8 sub_id;
  2159. uint8 len;
  2160. uint16 key_info;
  2161. uint8 key_length;
  2162. uint8 rsc[8];
  2163. uint8 key[1];
  2164. } BWL_POST_PACKED_STRUCT;
  2165. typedef struct dot11_wnm_sleep_subelem_gtk dot11_wnm_sleep_subelem_gtk_t;
  2166. #define DOT11_WNM_SLEEP_SUBELEM_GTK_FIXED_LEN 11 /* without sub_id, len, and key */
  2167. #define DOT11_WNM_SLEEP_SUBELEM_GTK_MAX_LEN 43 /* without sub_id and len */
  2168. BWL_PRE_PACKED_STRUCT struct dot11_wnm_sleep_subelem_igtk {
  2169. uint8 sub_id;
  2170. uint8 len;
  2171. uint16 key_id;
  2172. uint8 pn[6];
  2173. uint8 key[16];
  2174. } BWL_POST_PACKED_STRUCT;
  2175. typedef struct dot11_wnm_sleep_subelem_igtk dot11_wnm_sleep_subelem_igtk_t;
  2176. #define DOT11_WNM_SLEEP_SUBELEM_IGTK_LEN 24 /* Fixed length */
  2177. BWL_PRE_PACKED_STRUCT struct dot11_wnm_sleep_ie {
  2178. uint8 id; /* 93, DOT11_MNG_WNM_SLEEP_MODE_ID */
  2179. uint8 len;
  2180. uint8 act_type;
  2181. uint8 resp_status;
  2182. uint16 interval;
  2183. } BWL_POST_PACKED_STRUCT;
  2184. typedef struct dot11_wnm_sleep_ie dot11_wnm_sleep_ie_t;
  2185. #define DOT11_WNM_SLEEP_IE_LEN 4 /* Fixed length */
  2186. #define DOT11_WNM_SLEEP_ACT_TYPE_ENTER 0
  2187. #define DOT11_WNM_SLEEP_ACT_TYPE_EXIT 1
  2188. #define DOT11_WNM_SLEEP_RESP_ACCEPT 0
  2189. #define DOT11_WNM_SLEEP_RESP_UPDATE 1
  2190. #define DOT11_WNM_SLEEP_RESP_DENY 2
  2191. #define DOT11_WNM_SLEEP_RESP_DENY_TEMP 3
  2192. #define DOT11_WNM_SLEEP_RESP_DENY_KEY 4
  2193. #define DOT11_WNM_SLEEP_RESP_DENY_INUSE 5
  2194. #define DOT11_WNM_SLEEP_RESP_LAST 6
  2195. /** DMS Management Request frame header */
  2196. BWL_PRE_PACKED_STRUCT struct dot11_dms_req {
  2197. uint8 category; /* category of action frame (10) */
  2198. uint8 action; /* WNM action: dms request (23) */
  2199. uint8 token; /* dialog token */
  2200. uint8 data[1]; /* Elements */
  2201. } BWL_POST_PACKED_STRUCT;
  2202. typedef struct dot11_dms_req dot11_dms_req_t;
  2203. #define DOT11_DMS_REQ_LEN 3 /* Fixed length */
  2204. /** DMS Management Response frame header */
  2205. BWL_PRE_PACKED_STRUCT struct dot11_dms_resp {
  2206. uint8 category; /* category of action frame (10) */
  2207. uint8 action; /* WNM action: dms request (24) */
  2208. uint8 token; /* dialog token */
  2209. uint8 data[1]; /* Elements */
  2210. } BWL_POST_PACKED_STRUCT;
  2211. typedef struct dot11_dms_resp dot11_dms_resp_t;
  2212. #define DOT11_DMS_RESP_LEN 3 /* Fixed length */
  2213. /** DMS request element */
  2214. BWL_PRE_PACKED_STRUCT struct dot11_dms_req_ie {
  2215. uint8 id; /* 99, DOT11_MNG_DMS_REQUEST_ID */
  2216. uint8 len;
  2217. uint8 data[1];
  2218. } BWL_POST_PACKED_STRUCT;
  2219. typedef struct dot11_dms_req_ie dot11_dms_req_ie_t;
  2220. #define DOT11_DMS_REQ_IE_LEN 2 /* Fixed length */
  2221. /** DMS response element */
  2222. BWL_PRE_PACKED_STRUCT struct dot11_dms_resp_ie {
  2223. uint8 id; /* 100, DOT11_MNG_DMS_RESPONSE_ID */
  2224. uint8 len;
  2225. uint8 data[1];
  2226. } BWL_POST_PACKED_STRUCT;
  2227. typedef struct dot11_dms_resp_ie dot11_dms_resp_ie_t;
  2228. #define DOT11_DMS_RESP_IE_LEN 2 /* Fixed length */
  2229. /** DMS request descriptor */
  2230. BWL_PRE_PACKED_STRUCT struct dot11_dms_req_desc {
  2231. uint8 dms_id;
  2232. uint8 len;
  2233. uint8 type;
  2234. uint8 data[1];
  2235. } BWL_POST_PACKED_STRUCT;
  2236. typedef struct dot11_dms_req_desc dot11_dms_req_desc_t;
  2237. #define DOT11_DMS_REQ_DESC_LEN 3 /* Fixed length */
  2238. #define DOT11_DMS_REQ_TYPE_ADD 0
  2239. #define DOT11_DMS_REQ_TYPE_REMOVE 1
  2240. #define DOT11_DMS_REQ_TYPE_CHANGE 2
  2241. /** DMS response status */
  2242. BWL_PRE_PACKED_STRUCT struct dot11_dms_resp_st {
  2243. uint8 dms_id;
  2244. uint8 len;
  2245. uint8 type;
  2246. uint16 lsc;
  2247. uint8 data[1];
  2248. } BWL_POST_PACKED_STRUCT;
  2249. typedef struct dot11_dms_resp_st dot11_dms_resp_st_t;
  2250. #define DOT11_DMS_RESP_STATUS_LEN 5 /* Fixed length */
  2251. #define DOT11_DMS_RESP_TYPE_ACCEPT 0
  2252. #define DOT11_DMS_RESP_TYPE_DENY 1
  2253. #define DOT11_DMS_RESP_TYPE_TERM 2
  2254. #define DOT11_DMS_RESP_LSC_UNSUPPORTED 0xFFFF
  2255. /** WNM-Notification Request frame header */
  2256. BWL_PRE_PACKED_STRUCT struct dot11_wnm_notif_req {
  2257. uint8 category; /* category of action frame (10) */
  2258. uint8 action; /* WNM action: Notification request (26) */
  2259. uint8 token; /* dialog token */
  2260. uint8 type; /* type */
  2261. uint8 data[1]; /* Sub-elements */
  2262. } BWL_POST_PACKED_STRUCT;
  2263. typedef struct dot11_wnm_notif_req dot11_wnm_notif_req_t;
  2264. #define DOT11_WNM_NOTIF_REQ_LEN 4 /* Fixed length */
  2265. /** FMS Management Request frame header */
  2266. BWL_PRE_PACKED_STRUCT struct dot11_fms_req {
  2267. uint8 category; /* category of action frame (10) */
  2268. uint8 action; /* WNM action: fms request (9) */
  2269. uint8 token; /* dialog token */
  2270. uint8 data[1]; /* Elements */
  2271. } BWL_POST_PACKED_STRUCT;
  2272. typedef struct dot11_fms_req dot11_fms_req_t;
  2273. #define DOT11_FMS_REQ_LEN 3 /* Fixed length */
  2274. /** FMS Management Response frame header */
  2275. BWL_PRE_PACKED_STRUCT struct dot11_fms_resp {
  2276. uint8 category; /* category of action frame (10) */
  2277. uint8 action; /* WNM action: fms request (10) */
  2278. uint8 token; /* dialog token */
  2279. uint8 data[1]; /* Elements */
  2280. } BWL_POST_PACKED_STRUCT;
  2281. typedef struct dot11_fms_resp dot11_fms_resp_t;
  2282. #define DOT11_FMS_RESP_LEN 3 /* Fixed length */
  2283. /** FMS Descriptor element */
  2284. BWL_PRE_PACKED_STRUCT struct dot11_fms_desc {
  2285. uint8 id;
  2286. uint8 len;
  2287. uint8 num_fms_cnt;
  2288. uint8 data[1];
  2289. } BWL_POST_PACKED_STRUCT;
  2290. typedef struct dot11_fms_desc dot11_fms_desc_t;
  2291. #define DOT11_FMS_DESC_LEN 1 /* Fixed length */
  2292. #define DOT11_FMS_CNTR_MAX 0x8
  2293. #define DOT11_FMS_CNTR_ID_MASK 0x7
  2294. #define DOT11_FMS_CNTR_ID_SHIFT 0x0
  2295. #define DOT11_FMS_CNTR_COUNT_MASK 0xf1
  2296. #define DOT11_FMS_CNTR_SHIFT 0x3
  2297. /** FMS request element */
  2298. BWL_PRE_PACKED_STRUCT struct dot11_fms_req_ie {
  2299. uint8 id;
  2300. uint8 len;
  2301. uint8 fms_token; /* token used to identify fms stream set */
  2302. uint8 data[1];
  2303. } BWL_POST_PACKED_STRUCT;
  2304. typedef struct dot11_fms_req_ie dot11_fms_req_ie_t;
  2305. #define DOT11_FMS_REQ_IE_FIX_LEN 1 /* Fixed length */
  2306. BWL_PRE_PACKED_STRUCT struct dot11_rate_id_field {
  2307. uint8 mask;
  2308. uint8 mcs_idx;
  2309. uint16 rate;
  2310. } BWL_POST_PACKED_STRUCT;
  2311. typedef struct dot11_rate_id_field dot11_rate_id_field_t;
  2312. #define DOT11_RATE_ID_FIELD_MCS_SEL_MASK 0x7
  2313. #define DOT11_RATE_ID_FIELD_MCS_SEL_OFFSET 0
  2314. #define DOT11_RATE_ID_FIELD_RATETYPE_MASK 0x18
  2315. #define DOT11_RATE_ID_FIELD_RATETYPE_OFFSET 3
  2316. #define DOT11_RATE_ID_FIELD_LEN sizeof(dot11_rate_id_field_t)
  2317. /** FMS request subelements */
  2318. BWL_PRE_PACKED_STRUCT struct dot11_fms_se {
  2319. uint8 sub_id;
  2320. uint8 len;
  2321. uint8 interval;
  2322. uint8 max_interval;
  2323. dot11_rate_id_field_t rate;
  2324. uint8 data[1];
  2325. } BWL_POST_PACKED_STRUCT;
  2326. typedef struct dot11_fms_se dot11_fms_se_t;
  2327. #define DOT11_FMS_REQ_SE_LEN 6 /* Fixed length */
  2328. #define DOT11_FMS_REQ_SE_ID_FMS 1 /* FMS subelement */
  2329. #define DOT11_FMS_REQ_SE_ID_VS 221 /* Vendor Specific subelement */
  2330. /** FMS response element */
  2331. BWL_PRE_PACKED_STRUCT struct dot11_fms_resp_ie {
  2332. uint8 id;
  2333. uint8 len;
  2334. uint8 fms_token;
  2335. uint8 data[1];
  2336. } BWL_POST_PACKED_STRUCT;
  2337. typedef struct dot11_fms_resp_ie dot11_fms_resp_ie_t;
  2338. #define DOT11_FMS_RESP_IE_FIX_LEN 1 /* Fixed length */
  2339. /* FMS status subelements */
  2340. #define DOT11_FMS_STATUS_SE_ID_FMS 1 /* FMS Status */
  2341. #define DOT11_FMS_STATUS_SE_ID_TCLAS 2 /* TCLAS Status */
  2342. #define DOT11_FMS_STATUS_SE_ID_VS 221 /* Vendor Specific subelement */
  2343. /** FMS status subelement */
  2344. BWL_PRE_PACKED_STRUCT struct dot11_fms_status_se {
  2345. uint8 sub_id;
  2346. uint8 len;
  2347. uint8 status;
  2348. uint8 interval;
  2349. uint8 max_interval;
  2350. uint8 fmsid;
  2351. uint8 counter;
  2352. dot11_rate_id_field_t rate;
  2353. uint8 mcast_addr[ETHER_ADDR_LEN];
  2354. } BWL_POST_PACKED_STRUCT;
  2355. typedef struct dot11_fms_status_se dot11_fms_status_se_t;
  2356. #define DOT11_FMS_STATUS_SE_LEN 15 /* Fixed length */
  2357. /** TCLAS status subelement */
  2358. BWL_PRE_PACKED_STRUCT struct dot11_tclas_status_se {
  2359. uint8 sub_id;
  2360. uint8 len;
  2361. uint8 fmsid;
  2362. uint8 data[1];
  2363. } BWL_POST_PACKED_STRUCT;
  2364. typedef struct dot11_tclas_status_se dot11_tclas_status_se_t;
  2365. #define DOT11_TCLAS_STATUS_SE_LEN 1 /* Fixed length */
  2366. BWL_PRE_PACKED_STRUCT struct dot11_addba_req {
  2367. uint8 category; /* category of action frame (3) */
  2368. uint8 action; /* action: addba req */
  2369. uint8 token; /* identifier */
  2370. uint16 addba_param_set; /* parameter set */
  2371. uint16 timeout; /* timeout in seconds */
  2372. uint16 start_seqnum; /* starting sequence number */
  2373. } BWL_POST_PACKED_STRUCT;
  2374. typedef struct dot11_addba_req dot11_addba_req_t;
  2375. #define DOT11_ADDBA_REQ_LEN 9 /* length of addba req frame */
  2376. BWL_PRE_PACKED_STRUCT struct dot11_addba_resp {
  2377. uint8 category; /* category of action frame (3) */
  2378. uint8 action; /* action: addba resp */
  2379. uint8 token; /* identifier */
  2380. uint16 status; /* status of add request */
  2381. uint16 addba_param_set; /* negotiated parameter set */
  2382. uint16 timeout; /* negotiated timeout in seconds */
  2383. } BWL_POST_PACKED_STRUCT;
  2384. typedef struct dot11_addba_resp dot11_addba_resp_t;
  2385. #define DOT11_ADDBA_RESP_LEN 9 /* length of addba resp frame */
  2386. /* DELBA action parameters */
  2387. #define DOT11_DELBA_PARAM_INIT_MASK 0x0800 /* initiator mask */
  2388. #define DOT11_DELBA_PARAM_INIT_SHIFT 11 /* initiator shift */
  2389. #define DOT11_DELBA_PARAM_TID_MASK 0xf000 /* tid mask */
  2390. #define DOT11_DELBA_PARAM_TID_SHIFT 12 /* tid shift */
  2391. BWL_PRE_PACKED_STRUCT struct dot11_delba {
  2392. uint8 category; /* category of action frame (3) */
  2393. uint8 action; /* action: addba req */
  2394. uint16 delba_param_set; /* paarmeter set */
  2395. uint16 reason; /* reason for dellba */
  2396. } BWL_POST_PACKED_STRUCT;
  2397. typedef struct dot11_delba dot11_delba_t;
  2398. #define DOT11_DELBA_LEN 6 /* length of delba frame */
  2399. /* SA Query action field value */
  2400. #define SA_QUERY_REQUEST 0
  2401. #define SA_QUERY_RESPONSE 1
  2402. /* ************* 802.11r related definitions. ************* */
  2403. /** Over-the-DS Fast Transition Request frame header */
  2404. BWL_PRE_PACKED_STRUCT struct dot11_ft_req {
  2405. uint8 category; /* category of action frame (6) */
  2406. uint8 action; /* action: ft req */
  2407. uint8 sta_addr[ETHER_ADDR_LEN];
  2408. uint8 tgt_ap_addr[ETHER_ADDR_LEN];
  2409. uint8 data[1]; /* Elements */
  2410. } BWL_POST_PACKED_STRUCT;
  2411. typedef struct dot11_ft_req dot11_ft_req_t;
  2412. #define DOT11_FT_REQ_FIXED_LEN 14
  2413. /** Over-the-DS Fast Transition Response frame header */
  2414. BWL_PRE_PACKED_STRUCT struct dot11_ft_res {
  2415. uint8 category; /* category of action frame (6) */
  2416. uint8 action; /* action: ft resp */
  2417. uint8 sta_addr[ETHER_ADDR_LEN];
  2418. uint8 tgt_ap_addr[ETHER_ADDR_LEN];
  2419. uint16 status; /* status code */
  2420. uint8 data[1]; /* Elements */
  2421. } BWL_POST_PACKED_STRUCT;
  2422. typedef struct dot11_ft_res dot11_ft_res_t;
  2423. #define DOT11_FT_RES_FIXED_LEN 16
  2424. /** RDE RIC Data Element. */
  2425. BWL_PRE_PACKED_STRUCT struct dot11_rde_ie {
  2426. uint8 id; /* 11r, DOT11_MNG_RDE_ID */
  2427. uint8 length;
  2428. uint8 rde_id; /* RDE identifier. */
  2429. uint8 rd_count; /* Resource Descriptor Count. */
  2430. uint16 status; /* Status Code. */
  2431. } BWL_POST_PACKED_STRUCT;
  2432. typedef struct dot11_rde_ie dot11_rde_ie_t;
  2433. /* 11r - Size of the RDE (RIC Data Element) IE, including TLV header. */
  2434. #define DOT11_MNG_RDE_IE_LEN sizeof(dot11_rde_ie_t)
  2435. /* ************* 802.11k related definitions. ************* */
  2436. /* Radio measurements enabled capability ie */
  2437. #define DOT11_RRM_CAP_LEN 5 /* length of rrm cap bitmap */
  2438. #define RCPI_IE_LEN 1
  2439. #define RSNI_IE_LEN 1
  2440. BWL_PRE_PACKED_STRUCT struct dot11_rrm_cap_ie {
  2441. uint8 cap[DOT11_RRM_CAP_LEN];
  2442. } BWL_POST_PACKED_STRUCT;
  2443. typedef struct dot11_rrm_cap_ie dot11_rrm_cap_ie_t;
  2444. /* Bitmap definitions for cap ie */
  2445. #define DOT11_RRM_CAP_LINK 0
  2446. #define DOT11_RRM_CAP_NEIGHBOR_REPORT 1
  2447. #define DOT11_RRM_CAP_PARALLEL 2
  2448. #define DOT11_RRM_CAP_REPEATED 3
  2449. #define DOT11_RRM_CAP_BCN_PASSIVE 4
  2450. #define DOT11_RRM_CAP_BCN_ACTIVE 5
  2451. #define DOT11_RRM_CAP_BCN_TABLE 6
  2452. #define DOT11_RRM_CAP_BCN_REP_COND 7
  2453. #define DOT11_RRM_CAP_FM 8
  2454. #define DOT11_RRM_CAP_CLM 9
  2455. #define DOT11_RRM_CAP_NHM 10
  2456. #define DOT11_RRM_CAP_SM 11
  2457. #define DOT11_RRM_CAP_LCIM 12
  2458. #define DOT11_RRM_CAP_LCIA 13
  2459. #define DOT11_RRM_CAP_TSCM 14
  2460. #define DOT11_RRM_CAP_TTSCM 15
  2461. #define DOT11_RRM_CAP_AP_CHANREP 16
  2462. #define DOT11_RRM_CAP_RMMIB 17
  2463. /* bit18-bit23, not used for RRM_IOVAR */
  2464. #define DOT11_RRM_CAP_MPC0 24
  2465. #define DOT11_RRM_CAP_MPC1 25
  2466. #define DOT11_RRM_CAP_MPC2 26
  2467. #define DOT11_RRM_CAP_MPTI 27
  2468. #define DOT11_RRM_CAP_NBRTSFO 28
  2469. #define DOT11_RRM_CAP_RCPI 29
  2470. #define DOT11_RRM_CAP_RSNI 30
  2471. #define DOT11_RRM_CAP_BSSAAD 31
  2472. #define DOT11_RRM_CAP_BSSAAC 32
  2473. #define DOT11_RRM_CAP_AI 33
  2474. #define DOT11_RRM_CAP_FTM_RANGE 34
  2475. #define DOT11_RRM_CAP_CIVIC_LOC 35
  2476. #define DOT11_RRM_CAP_IDENT_LOC 36
  2477. #define DOT11_RRM_CAP_LAST 36
  2478. #ifdef WL11K_ALL_MEAS
  2479. #define DOT11_RRM_CAP_LINK_ENAB (1 << DOT11_RRM_CAP_LINK)
  2480. #define DOT11_RRM_CAP_FM_ENAB (1 << (DOT11_RRM_CAP_FM - 8))
  2481. #define DOT11_RRM_CAP_CLM_ENAB (1 << (DOT11_RRM_CAP_CLM - 8))
  2482. #define DOT11_RRM_CAP_NHM_ENAB (1 << (DOT11_RRM_CAP_NHM - 8))
  2483. #define DOT11_RRM_CAP_SM_ENAB (1 << (DOT11_RRM_CAP_SM - 8))
  2484. #define DOT11_RRM_CAP_LCIM_ENAB (1 << (DOT11_RRM_CAP_LCIM - 8))
  2485. #define DOT11_RRM_CAP_TSCM_ENAB (1 << (DOT11_RRM_CAP_TSCM - 8))
  2486. #ifdef WL11K_AP
  2487. #define DOT11_RRM_CAP_MPC0_ENAB (1 << (DOT11_RRM_CAP_MPC0 - 24))
  2488. #define DOT11_RRM_CAP_MPC1_ENAB (1 << (DOT11_RRM_CAP_MPC1 - 24))
  2489. #define DOT11_RRM_CAP_MPC2_ENAB (1 << (DOT11_RRM_CAP_MPC2 - 24))
  2490. #define DOT11_RRM_CAP_MPTI_ENAB (1 << (DOT11_RRM_CAP_MPTI - 24))
  2491. #else
  2492. #define DOT11_RRM_CAP_MPC0_ENAB 0
  2493. #define DOT11_RRM_CAP_MPC1_ENAB 0
  2494. #define DOT11_RRM_CAP_MPC2_ENAB 0
  2495. #define DOT11_RRM_CAP_MPTI_ENAB 0
  2496. #endif /* WL11K_AP */
  2497. #define DOT11_RRM_CAP_CIVIC_LOC_ENAB (1 << (DOT11_RRM_CAP_CIVIC_LOC - 32))
  2498. #define DOT11_RRM_CAP_IDENT_LOC_ENAB (1 << (DOT11_RRM_CAP_IDENT_LOC - 32))
  2499. #else
  2500. #define DOT11_RRM_CAP_LINK_ENAB 0
  2501. #define DOT11_RRM_CAP_FM_ENAB 0
  2502. #define DOT11_RRM_CAP_CLM_ENAB 0
  2503. #define DOT11_RRM_CAP_NHM_ENAB 0
  2504. #define DOT11_RRM_CAP_SM_ENAB 0
  2505. #define DOT11_RRM_CAP_LCIM_ENAB 0
  2506. #define DOT11_RRM_CAP_TSCM_ENAB 0
  2507. #define DOT11_RRM_CAP_MPC0_ENAB 0
  2508. #define DOT11_RRM_CAP_MPC1_ENAB 0
  2509. #define DOT11_RRM_CAP_MPC2_ENAB 0
  2510. #define DOT11_RRM_CAP_MPTI_ENAB 0
  2511. #define DOT11_RRM_CAP_CIVIC_LOC_ENAB 0
  2512. #define DOT11_RRM_CAP_IDENT_LOC_ENAB 0
  2513. #endif /* WL11K_ALL_MEAS */
  2514. #ifdef WL11K_NBR_MEAS
  2515. #define DOT11_RRM_CAP_NEIGHBOR_REPORT_ENAB (1 << DOT11_RRM_CAP_NEIGHBOR_REPORT)
  2516. #else
  2517. #define DOT11_RRM_CAP_NEIGHBOR_REPORT_ENAB 0
  2518. #endif /* WL11K_NBR_MEAS */
  2519. #ifdef WL11K_BCN_MEAS
  2520. #define DOT11_RRM_CAP_BCN_PASSIVE_ENAB (1 << DOT11_RRM_CAP_BCN_PASSIVE)
  2521. #define DOT11_RRM_CAP_BCN_ACTIVE_ENAB (1 << DOT11_RRM_CAP_BCN_ACTIVE)
  2522. #else
  2523. #define DOT11_RRM_CAP_BCN_PASSIVE_ENAB 0
  2524. #define DOT11_RRM_CAP_BCN_ACTIVE_ENAB 0
  2525. #endif /* WL11K_BCN_MEAS */
  2526. #define DOT11_RRM_CAP_MPA_MASK 0x7
  2527. /* Operating Class (formerly "Regulatory Class") definitions */
  2528. #define DOT11_OP_CLASS_NONE 255
  2529. BWL_PRE_PACKED_STRUCT struct do11_ap_chrep {
  2530. uint8 id;
  2531. uint8 len;
  2532. uint8 reg;
  2533. uint8 chanlist[1];
  2534. } BWL_POST_PACKED_STRUCT;
  2535. typedef struct do11_ap_chrep dot11_ap_chrep_t;
  2536. /* Radio Measurements action ids */
  2537. #define DOT11_RM_ACTION_RM_REQ 0 /* Radio measurement request */
  2538. #define DOT11_RM_ACTION_RM_REP 1 /* Radio measurement report */
  2539. #define DOT11_RM_ACTION_LM_REQ 2 /* Link measurement request */
  2540. #define DOT11_RM_ACTION_LM_REP 3 /* Link measurement report */
  2541. #define DOT11_RM_ACTION_NR_REQ 4 /* Neighbor report request */
  2542. #define DOT11_RM_ACTION_NR_REP 5 /* Neighbor report response */
  2543. #define DOT11_PUB_ACTION_MP 7 /* Measurement Pilot public action id */
  2544. /** Generic radio measurement action frame header */
  2545. BWL_PRE_PACKED_STRUCT struct dot11_rm_action {
  2546. uint8 category; /* category of action frame (5) */
  2547. uint8 action; /* radio measurement action */
  2548. uint8 token; /* dialog token */
  2549. uint8 data[1];
  2550. } BWL_POST_PACKED_STRUCT;
  2551. typedef struct dot11_rm_action dot11_rm_action_t;
  2552. #define DOT11_RM_ACTION_LEN 3
  2553. BWL_PRE_PACKED_STRUCT struct dot11_rmreq {
  2554. uint8 category; /* category of action frame (5) */
  2555. uint8 action; /* radio measurement action */
  2556. uint8 token; /* dialog token */
  2557. uint16 reps; /* no. of repetitions */
  2558. uint8 data[1];
  2559. } BWL_POST_PACKED_STRUCT;
  2560. typedef struct dot11_rmreq dot11_rmreq_t;
  2561. #define DOT11_RMREQ_LEN 5
  2562. BWL_PRE_PACKED_STRUCT struct dot11_rm_ie {
  2563. uint8 id;
  2564. uint8 len;
  2565. uint8 token;
  2566. uint8 mode;
  2567. uint8 type;
  2568. } BWL_POST_PACKED_STRUCT;
  2569. typedef struct dot11_rm_ie dot11_rm_ie_t;
  2570. #define DOT11_RM_IE_LEN 5
  2571. /* Definitions for "mode" bits in rm req */
  2572. #define DOT11_RMREQ_MODE_PARALLEL 1
  2573. #define DOT11_RMREQ_MODE_ENABLE 2
  2574. #define DOT11_RMREQ_MODE_REQUEST 4
  2575. #define DOT11_RMREQ_MODE_REPORT 8
  2576. #define DOT11_RMREQ_MODE_DURMAND 0x10 /* Duration Mandatory */
  2577. /* Definitions for "mode" bits in rm rep */
  2578. #define DOT11_RMREP_MODE_LATE 1
  2579. #define DOT11_RMREP_MODE_INCAPABLE 2
  2580. #define DOT11_RMREP_MODE_REFUSED 4
  2581. BWL_PRE_PACKED_STRUCT struct dot11_rmreq_bcn {
  2582. uint8 id;
  2583. uint8 len;
  2584. uint8 token;
  2585. uint8 mode;
  2586. uint8 type;
  2587. uint8 reg;
  2588. uint8 channel;
  2589. uint16 interval;
  2590. uint16 duration;
  2591. uint8 bcn_mode;
  2592. struct ether_addr bssid;
  2593. } BWL_POST_PACKED_STRUCT;
  2594. typedef struct dot11_rmreq_bcn dot11_rmreq_bcn_t;
  2595. #define DOT11_RMREQ_BCN_LEN 18u
  2596. BWL_PRE_PACKED_STRUCT struct dot11_rmrep_bcn {
  2597. uint8 reg;
  2598. uint8 channel;
  2599. uint32 starttime[2];
  2600. uint16 duration;
  2601. uint8 frame_info;
  2602. uint8 rcpi;
  2603. uint8 rsni;
  2604. struct ether_addr bssid;
  2605. uint8 antenna_id;
  2606. uint32 parent_tsf;
  2607. } BWL_POST_PACKED_STRUCT;
  2608. typedef struct dot11_rmrep_bcn dot11_rmrep_bcn_t;
  2609. #define DOT11_RMREP_BCN_LEN 26
  2610. /* Beacon request measurement mode */
  2611. #define DOT11_RMREQ_BCN_PASSIVE 0
  2612. #define DOT11_RMREQ_BCN_ACTIVE 1
  2613. #define DOT11_RMREQ_BCN_TABLE 2
  2614. /* Sub-element IDs for Beacon Request */
  2615. #define DOT11_RMREQ_BCN_SSID_ID 0
  2616. #define DOT11_RMREQ_BCN_REPINFO_ID 1
  2617. #define DOT11_RMREQ_BCN_REPDET_ID 2
  2618. #define DOT11_RMREQ_BCN_REQUEST_ID 10
  2619. #define DOT11_RMREQ_BCN_APCHREP_ID DOT11_MNG_AP_CHREP_ID
  2620. #define DOT11_RMREQ_BCN_LAST_RPT_IND_REQ_ID 164
  2621. /* Reporting Detail element definition */
  2622. #define DOT11_RMREQ_BCN_REPDET_FIXED 0 /* Fixed length fields only */
  2623. #define DOT11_RMREQ_BCN_REPDET_REQUEST 1 /* + requested information elems */
  2624. #define DOT11_RMREQ_BCN_REPDET_ALL 2 /* All fields */
  2625. /* Reporting Information (reporting condition) element definition */
  2626. #define DOT11_RMREQ_BCN_REPINFO_LEN 2 /* Beacon Reporting Information length */
  2627. #define DOT11_RMREQ_BCN_REPCOND_DEFAULT 0 /* Report to be issued after each measurement */
  2628. /* Last Beacon Report Indication Request definition */
  2629. #define DOT11_RMREQ_BCN_LAST_RPT_IND_REQ_ENAB 1
  2630. BWL_PRE_PACKED_STRUCT struct dot11_rmrep_last_bcn_rpt_ind_req {
  2631. uint8 id; /* DOT11_RMREQ_BCN_LAST_RPT_IND_REQ_ID */
  2632. uint8 len; /* length of remaining fields */
  2633. uint8 data; /* data = 1 means last bcn rpt ind requested */
  2634. } BWL_POST_PACKED_STRUCT;
  2635. typedef struct dot11_rmrep_last_bcn_rpt_ind_req dot11_rmrep_last_bcn_rpt_ind_req_t;
  2636. /* Sub-element IDs for Beacon Report */
  2637. #define DOT11_RMREP_BCN_FRM_BODY 1
  2638. #define DOT11_RMREP_BCN_FRM_BODY_FRAG_ID 2
  2639. #define DOT11_RMREP_BCN_LAST_RPT_IND 164
  2640. #define DOT11_RMREP_BCN_FRM_BODY_LEN_MAX 224 /* 802.11k-2008 7.3.2.22.6 */
  2641. /* Refer IEEE P802.11-REVmd/D1.0 9.4.2.21.7 Beacon report */
  2642. BWL_PRE_PACKED_STRUCT struct dot11_rmrep_bcn_frm_body_fragmt_id {
  2643. uint8 id; /* DOT11_RMREP_BCN_FRM_BODY_FRAG_ID */
  2644. uint8 len; /* length of remaining fields */
  2645. /* More fragments(B15), fragment Id(B8-B14), Bcn rpt instance ID (B0 - B7) */
  2646. uint16 frag_info_rpt_id;
  2647. } BWL_POST_PACKED_STRUCT;
  2648. typedef struct dot11_rmrep_bcn_frm_body_fragmt_id dot11_rmrep_bcn_frm_body_fragmt_id_t;
  2649. BWL_PRE_PACKED_STRUCT struct dot11_rmrep_bcn_frm_body_frag_id {
  2650. uint8 id; /* DOT11_RMREP_BCN_FRM_BODY_FRAG_ID */
  2651. uint8 len; /* length of remaining fields */
  2652. uint8 bcn_rpt_id; /* Bcn rpt instance ID */
  2653. uint8 frag_info; /* fragment Id(7 bits) | More fragments(1 bit) */
  2654. } BWL_POST_PACKED_STRUCT;
  2655. typedef struct dot11_rmrep_bcn_frm_body_frag_id dot11_rmrep_bcn_frm_body_frag_id_t;
  2656. #define DOT11_RMREP_BCNRPT_FRAG_ID_DATA_LEN 2u
  2657. #define DOT11_RMREP_BCNRPT_FRAG_ID_SE_LEN sizeof(dot11_rmrep_bcn_frm_body_frag_id_t)
  2658. #define DOT11_RMREP_BCNRPT_FRAG_ID_NUM_SHIFT 1u
  2659. #define DOT11_RMREP_BCNRPT_FRAGMT_ID_SE_LEN sizeof(dot11_rmrep_bcn_frm_body_fragmt_id_t)
  2660. #define DOT11_RMREP_BCNRPT_BCN_RPT_ID_MASK 0x00FFu
  2661. #define DOT11_RMREP_BCNRPT_FRAGMT_ID_NUM_SHIFT 8u
  2662. #define DOT11_RMREP_BCNRPT_FRAGMT_ID_NUM_MASK 0x7F00u
  2663. #define DOT11_RMREP_BCNRPT_MORE_FRAG_SHIFT 15u
  2664. #define DOT11_RMREP_BCNRPT_MORE_FRAG_MASK 0x8000u
  2665. BWL_PRE_PACKED_STRUCT struct dot11_rmrep_last_bcn_rpt_ind {
  2666. uint8 id; /* DOT11_RMREP_BCN_LAST_RPT_IND */
  2667. uint8 len; /* length of remaining fields */
  2668. uint8 data; /* data = 1 is last bcn rpt */
  2669. } BWL_POST_PACKED_STRUCT;
  2670. typedef struct dot11_rmrep_last_bcn_rpt_ind dot11_rmrep_last_bcn_rpt_ind_t;
  2671. #define DOT11_RMREP_LAST_BCN_RPT_IND_DATA_LEN 1
  2672. #define DOT11_RMREP_LAST_BCN_RPT_IND_SE_LEN sizeof(dot11_rmrep_last_bcn_rpt_ind_t)
  2673. /* Sub-element IDs for Frame Report */
  2674. #define DOT11_RMREP_FRAME_COUNT_REPORT 1
  2675. /* Channel load request */
  2676. BWL_PRE_PACKED_STRUCT struct dot11_rmreq_chanload {
  2677. uint8 id;
  2678. uint8 len;
  2679. uint8 token;
  2680. uint8 mode;
  2681. uint8 type;
  2682. uint8 reg;
  2683. uint8 channel;
  2684. uint16 interval;
  2685. uint16 duration;
  2686. } BWL_POST_PACKED_STRUCT;
  2687. typedef struct dot11_rmreq_chanload dot11_rmreq_chanload_t;
  2688. #define DOT11_RMREQ_CHANLOAD_LEN 11
  2689. /** Channel load report */
  2690. BWL_PRE_PACKED_STRUCT struct dot11_rmrep_chanload {
  2691. uint8 reg;
  2692. uint8 channel;
  2693. uint32 starttime[2];
  2694. uint16 duration;
  2695. uint8 channel_load;
  2696. } BWL_POST_PACKED_STRUCT;
  2697. typedef struct dot11_rmrep_chanload dot11_rmrep_chanload_t;
  2698. #define DOT11_RMREP_CHANLOAD_LEN 13
  2699. /** Noise histogram request */
  2700. BWL_PRE_PACKED_STRUCT struct dot11_rmreq_noise {
  2701. uint8 id;
  2702. uint8 len;
  2703. uint8 token;
  2704. uint8 mode;
  2705. uint8 type;
  2706. uint8 reg;
  2707. uint8 channel;
  2708. uint16 interval;
  2709. uint16 duration;
  2710. } BWL_POST_PACKED_STRUCT;
  2711. typedef struct dot11_rmreq_noise dot11_rmreq_noise_t;
  2712. #define DOT11_RMREQ_NOISE_LEN 11
  2713. /** Noise histogram report */
  2714. BWL_PRE_PACKED_STRUCT struct dot11_rmrep_noise {
  2715. uint8 reg;
  2716. uint8 channel;
  2717. uint32 starttime[2];
  2718. uint16 duration;
  2719. uint8 antid;
  2720. uint8 anpi;
  2721. uint8 ipi0_dens;
  2722. uint8 ipi1_dens;
  2723. uint8 ipi2_dens;
  2724. uint8 ipi3_dens;
  2725. uint8 ipi4_dens;
  2726. uint8 ipi5_dens;
  2727. uint8 ipi6_dens;
  2728. uint8 ipi7_dens;
  2729. uint8 ipi8_dens;
  2730. uint8 ipi9_dens;
  2731. uint8 ipi10_dens;
  2732. } BWL_POST_PACKED_STRUCT;
  2733. typedef struct dot11_rmrep_noise dot11_rmrep_noise_t;
  2734. #define DOT11_RMREP_NOISE_LEN 25
  2735. /** Frame request */
  2736. BWL_PRE_PACKED_STRUCT struct dot11_rmreq_frame {
  2737. uint8 id;
  2738. uint8 len;
  2739. uint8 token;
  2740. uint8 mode;
  2741. uint8 type;
  2742. uint8 reg;
  2743. uint8 channel;
  2744. uint16 interval;
  2745. uint16 duration;
  2746. uint8 req_type;
  2747. struct ether_addr ta;
  2748. } BWL_POST_PACKED_STRUCT;
  2749. typedef struct dot11_rmreq_frame dot11_rmreq_frame_t;
  2750. #define DOT11_RMREQ_FRAME_LEN 18
  2751. /** Frame report */
  2752. BWL_PRE_PACKED_STRUCT struct dot11_rmrep_frame {
  2753. uint8 reg;
  2754. uint8 channel;
  2755. uint32 starttime[2];
  2756. uint16 duration;
  2757. } BWL_POST_PACKED_STRUCT;
  2758. typedef struct dot11_rmrep_frame dot11_rmrep_frame_t;
  2759. #define DOT11_RMREP_FRAME_LEN 12
  2760. /** Frame report entry */
  2761. BWL_PRE_PACKED_STRUCT struct dot11_rmrep_frmentry {
  2762. struct ether_addr ta;
  2763. struct ether_addr bssid;
  2764. uint8 phy_type;
  2765. uint8 avg_rcpi;
  2766. uint8 last_rsni;
  2767. uint8 last_rcpi;
  2768. uint8 ant_id;
  2769. uint16 frame_cnt;
  2770. } BWL_POST_PACKED_STRUCT;
  2771. typedef struct dot11_rmrep_frmentry dot11_rmrep_frmentry_t;
  2772. #define DOT11_RMREP_FRMENTRY_LEN 19
  2773. /** STA statistics request */
  2774. BWL_PRE_PACKED_STRUCT struct dot11_rmreq_stat {
  2775. uint8 id;
  2776. uint8 len;
  2777. uint8 token;
  2778. uint8 mode;
  2779. uint8 type;
  2780. struct ether_addr peer;
  2781. uint16 interval;
  2782. uint16 duration;
  2783. uint8 group_id;
  2784. } BWL_POST_PACKED_STRUCT;
  2785. typedef struct dot11_rmreq_stat dot11_rmreq_stat_t;
  2786. #define DOT11_RMREQ_STAT_LEN 16
  2787. /** STA statistics report */
  2788. BWL_PRE_PACKED_STRUCT struct dot11_rmrep_stat {
  2789. uint16 duration;
  2790. uint8 group_id;
  2791. } BWL_POST_PACKED_STRUCT;
  2792. typedef struct dot11_rmrep_stat dot11_rmrep_stat_t;
  2793. /* Statistics Group Report: Group IDs */
  2794. enum {
  2795. DOT11_RRM_STATS_GRP_ID_0 = 0,
  2796. DOT11_RRM_STATS_GRP_ID_1,
  2797. DOT11_RRM_STATS_GRP_ID_2,
  2798. DOT11_RRM_STATS_GRP_ID_3,
  2799. DOT11_RRM_STATS_GRP_ID_4,
  2800. DOT11_RRM_STATS_GRP_ID_5,
  2801. DOT11_RRM_STATS_GRP_ID_6,
  2802. DOT11_RRM_STATS_GRP_ID_7,
  2803. DOT11_RRM_STATS_GRP_ID_8,
  2804. DOT11_RRM_STATS_GRP_ID_9,
  2805. DOT11_RRM_STATS_GRP_ID_10,
  2806. DOT11_RRM_STATS_GRP_ID_11,
  2807. DOT11_RRM_STATS_GRP_ID_12,
  2808. DOT11_RRM_STATS_GRP_ID_13,
  2809. DOT11_RRM_STATS_GRP_ID_14,
  2810. DOT11_RRM_STATS_GRP_ID_15,
  2811. DOT11_RRM_STATS_GRP_ID_16
  2812. };
  2813. /* Statistics Group Report: Group Data length */
  2814. #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_0 28
  2815. typedef struct rrm_stat_group_0 {
  2816. uint32 txfrag;
  2817. uint32 txmulti;
  2818. uint32 txfail;
  2819. uint32 rxframe;
  2820. uint32 rxmulti;
  2821. uint32 rxbadfcs;
  2822. uint32 txframe;
  2823. } rrm_stat_group_0_t;
  2824. #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_1 24
  2825. typedef struct rrm_stat_group_1 {
  2826. uint32 txretry;
  2827. uint32 txretries;
  2828. uint32 rxdup;
  2829. uint32 txrts;
  2830. uint32 rtsfail;
  2831. uint32 ackfail;
  2832. } rrm_stat_group_1_t;
  2833. /* group 2-9 use same qos data structure (tid 0-7), total 52 bytes */
  2834. #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_2_9 52
  2835. typedef struct rrm_stat_group_qos {
  2836. uint32 txfrag;
  2837. uint32 txfail;
  2838. uint32 txretry;
  2839. uint32 txretries;
  2840. uint32 rxdup;
  2841. uint32 txrts;
  2842. uint32 rtsfail;
  2843. uint32 ackfail;
  2844. uint32 rxfrag;
  2845. uint32 txframe;
  2846. uint32 txdrop;
  2847. uint32 rxmpdu;
  2848. uint32 rxretries;
  2849. } rrm_stat_group_qos_t;
  2850. /* dot11BSSAverageAccessDelay Group (only available at an AP): 8 byte */
  2851. #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_10 8
  2852. typedef BWL_PRE_PACKED_STRUCT struct rrm_stat_group_10 {
  2853. uint8 apavgdelay;
  2854. uint8 avgdelaybe;
  2855. uint8 avgdelaybg;
  2856. uint8 avgdelayvi;
  2857. uint8 avgdelayvo;
  2858. uint16 stacount;
  2859. uint8 chanutil;
  2860. } BWL_POST_PACKED_STRUCT rrm_stat_group_10_t;
  2861. /* AMSDU, 40 bytes */
  2862. #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_11 40
  2863. typedef struct rrm_stat_group_11 {
  2864. uint32 txamsdu;
  2865. uint32 amsdufail;
  2866. uint32 amsduretry;
  2867. uint32 amsduretries;
  2868. uint32 txamsdubyte_h;
  2869. uint32 txamsdubyte_l;
  2870. uint32 amsduackfail;
  2871. uint32 rxamsdu;
  2872. uint32 rxamsdubyte_h;
  2873. uint32 rxamsdubyte_l;
  2874. } rrm_stat_group_11_t;
  2875. /* AMPDU, 36 bytes */
  2876. #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_12 36
  2877. typedef struct rrm_stat_group_12 {
  2878. uint32 txampdu;
  2879. uint32 txmpdu;
  2880. uint32 txampdubyte_h;
  2881. uint32 txampdubyte_l;
  2882. uint32 rxampdu;
  2883. uint32 rxmpdu;
  2884. uint32 rxampdubyte_h;
  2885. uint32 rxampdubyte_l;
  2886. uint32 ampducrcfail;
  2887. } rrm_stat_group_12_t;
  2888. /* BACK etc, 36 bytes */
  2889. #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_13 36
  2890. typedef struct rrm_stat_group_13 {
  2891. uint32 rximpbarfail;
  2892. uint32 rxexpbarfail;
  2893. uint32 chanwidthsw;
  2894. uint32 txframe20mhz;
  2895. uint32 txframe40mhz;
  2896. uint32 rxframe20mhz;
  2897. uint32 rxframe40mhz;
  2898. uint32 psmpgrantdur;
  2899. uint32 psmpuseddur;
  2900. } rrm_stat_group_13_t;
  2901. /* RD Dual CTS etc, 36 bytes */
  2902. #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_14 36
  2903. typedef struct rrm_stat_group_14 {
  2904. uint32 grantrdgused;
  2905. uint32 grantrdgunused;
  2906. uint32 txframeingrantrdg;
  2907. uint32 txbyteingrantrdg_h;
  2908. uint32 txbyteingrantrdg_l;
  2909. uint32 dualcts;
  2910. uint32 dualctsfail;
  2911. uint32 rtslsi;
  2912. uint32 rtslsifail;
  2913. } rrm_stat_group_14_t;
  2914. /* bf and STBC etc, 20 bytes */
  2915. #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_15 20
  2916. typedef struct rrm_stat_group_15 {
  2917. uint32 bfframe;
  2918. uint32 stbccts;
  2919. uint32 stbcctsfail;
  2920. uint32 nonstbccts;
  2921. uint32 nonstbcctsfail;
  2922. } rrm_stat_group_15_t;
  2923. /* RSNA, 28 bytes */
  2924. #define DOT11_RRM_STATS_RPT_LEN_GRP_ID_16 28
  2925. typedef struct rrm_stat_group_16 {
  2926. uint32 rsnacmacicverr;
  2927. uint32 rsnacmacreplay;
  2928. uint32 rsnarobustmgmtccmpreplay;
  2929. uint32 rsnatkipicverr;
  2930. uint32 rsnatkipicvreplay;
  2931. uint32 rsnaccmpdecrypterr;
  2932. uint32 rsnaccmpreplay;
  2933. } rrm_stat_group_16_t;
  2934. /* Transmit stream/category measurement request */
  2935. BWL_PRE_PACKED_STRUCT struct dot11_rmreq_tx_stream {
  2936. uint8 id;
  2937. uint8 len;
  2938. uint8 token;
  2939. uint8 mode;
  2940. uint8 type;
  2941. uint16 interval;
  2942. uint16 duration;
  2943. struct ether_addr peer;
  2944. uint8 traffic_id;
  2945. uint8 bin0_range;
  2946. } BWL_POST_PACKED_STRUCT;
  2947. typedef struct dot11_rmreq_tx_stream dot11_rmreq_tx_stream_t;
  2948. #define DOT11_RMREQ_TXSTREAM_LEN 17
  2949. /** Transmit stream/category measurement report */
  2950. BWL_PRE_PACKED_STRUCT struct dot11_rmrep_tx_stream {
  2951. uint32 starttime[2];
  2952. uint16 duration;
  2953. struct ether_addr peer;
  2954. uint8 traffic_id;
  2955. uint8 reason;
  2956. uint32 txmsdu_cnt;
  2957. uint32 msdu_discarded_cnt;
  2958. uint32 msdufailed_cnt;
  2959. uint32 msduretry_cnt;
  2960. uint32 cfpolls_lost_cnt;
  2961. uint32 avrqueue_delay;
  2962. uint32 avrtx_delay;
  2963. uint8 bin0_range;
  2964. uint32 bin0;
  2965. uint32 bin1;
  2966. uint32 bin2;
  2967. uint32 bin3;
  2968. uint32 bin4;
  2969. uint32 bin5;
  2970. } BWL_POST_PACKED_STRUCT;
  2971. typedef struct dot11_rmrep_tx_stream dot11_rmrep_tx_stream_t;
  2972. #define DOT11_RMREP_TXSTREAM_LEN 71
  2973. typedef struct rrm_tscm {
  2974. uint32 msdu_tx;
  2975. uint32 msdu_exp;
  2976. uint32 msdu_fail;
  2977. uint32 msdu_retries;
  2978. uint32 cfpolls_lost;
  2979. uint32 queue_delay;
  2980. uint32 tx_delay_sum;
  2981. uint32 tx_delay_cnt;
  2982. uint32 bin0_range_us;
  2983. uint32 bin0;
  2984. uint32 bin1;
  2985. uint32 bin2;
  2986. uint32 bin3;
  2987. uint32 bin4;
  2988. uint32 bin5;
  2989. } rrm_tscm_t;
  2990. enum {
  2991. DOT11_FTM_LOCATION_SUBJ_LOCAL = 0, /* Where am I? */
  2992. DOT11_FTM_LOCATION_SUBJ_REMOTE = 1, /* Where are you? */
  2993. DOT11_FTM_LOCATION_SUBJ_THIRDPARTY = 2 /* Where is he/she? */
  2994. };
  2995. BWL_PRE_PACKED_STRUCT struct dot11_rmreq_ftm_lci {
  2996. uint8 id;
  2997. uint8 len;
  2998. uint8 token;
  2999. uint8 mode;
  3000. uint8 type;
  3001. uint8 subj;
  3002. /* Following 3 fields are unused. Keep for ROM compatibility. */
  3003. uint8 lat_res;
  3004. uint8 lon_res;
  3005. uint8 alt_res;
  3006. /* optional sub-elements */
  3007. } BWL_POST_PACKED_STRUCT;
  3008. typedef struct dot11_rmreq_ftm_lci dot11_rmreq_ftm_lci_t;
  3009. #define DOT11_RMREQ_LCI_LEN 9
  3010. BWL_PRE_PACKED_STRUCT struct dot11_rmrep_ftm_lci {
  3011. uint8 id;
  3012. uint8 len;
  3013. uint8 token;
  3014. uint8 mode;
  3015. uint8 type;
  3016. uint8 lci_sub_id;
  3017. uint8 lci_sub_len;
  3018. /* optional LCI field */
  3019. /* optional sub-elements */
  3020. } BWL_POST_PACKED_STRUCT;
  3021. typedef struct dot11_rmrep_ftm_lci dot11_rmrep_ftm_lci_t;
  3022. #define DOT11_FTM_LCI_SUBELEM_ID 0
  3023. #define DOT11_FTM_LCI_SUBELEM_LEN 2
  3024. #define DOT11_FTM_LCI_FIELD_LEN 16
  3025. #define DOT11_FTM_LCI_UNKNOWN_LEN 2
  3026. BWL_PRE_PACKED_STRUCT struct dot11_rmreq_ftm_civic {
  3027. uint8 id;
  3028. uint8 len;
  3029. uint8 token;
  3030. uint8 mode;
  3031. uint8 type;
  3032. uint8 subj;
  3033. uint8 civloc_type;
  3034. uint8 siu; /* service interval units */
  3035. uint16 si; /* service interval */
  3036. /* optional sub-elements */
  3037. } BWL_POST_PACKED_STRUCT;
  3038. typedef struct dot11_rmreq_ftm_civic dot11_rmreq_ftm_civic_t;
  3039. #define DOT11_RMREQ_CIVIC_LEN 10
  3040. BWL_PRE_PACKED_STRUCT struct dot11_rmrep_ftm_civic {
  3041. uint8 id;
  3042. uint8 len;
  3043. uint8 token;
  3044. uint8 mode;
  3045. uint8 type;
  3046. uint8 civloc_type;
  3047. uint8 civloc_sub_id;
  3048. uint8 civloc_sub_len;
  3049. /* optional location civic field */
  3050. /* optional sub-elements */
  3051. } BWL_POST_PACKED_STRUCT;
  3052. typedef struct dot11_rmrep_ftm_civic dot11_rmrep_ftm_civic_t;
  3053. #define DOT11_FTM_CIVIC_LOC_TYPE_RFC4776 0
  3054. #define DOT11_FTM_CIVIC_SUBELEM_ID 0
  3055. #define DOT11_FTM_CIVIC_SUBELEM_LEN 2
  3056. #define DOT11_FTM_CIVIC_LOC_SI_NONE 0
  3057. #define DOT11_FTM_CIVIC_TYPE_LEN 1
  3058. #define DOT11_FTM_CIVIC_UNKNOWN_LEN 3
  3059. /* Location Identifier measurement request */
  3060. BWL_PRE_PACKED_STRUCT struct dot11_rmreq_locid {
  3061. uint8 id;
  3062. uint8 len;
  3063. uint8 token;
  3064. uint8 mode;
  3065. uint8 type;
  3066. uint8 subj;
  3067. uint8 siu;
  3068. uint16 si;
  3069. } BWL_POST_PACKED_STRUCT;
  3070. typedef struct dot11_rmreq_locid dot11_rmreq_locid_t;
  3071. #define DOT11_RMREQ_LOCID_LEN 9
  3072. /* Location Identifier measurement report */
  3073. BWL_PRE_PACKED_STRUCT struct dot11_rmrep_locid {
  3074. uint8 id;
  3075. uint8 len;
  3076. uint8 token;
  3077. uint8 mode;
  3078. uint8 type;
  3079. uint8 exp_tsf[8];
  3080. uint8 locid_sub_id;
  3081. uint8 locid_sub_len;
  3082. /* optional location identifier field */
  3083. /* optional sub-elements */
  3084. } BWL_POST_PACKED_STRUCT;
  3085. typedef struct dot11_rmrep_locid dot11_rmrep_locid_t;
  3086. #define DOT11_LOCID_UNKNOWN_LEN 10
  3087. #define DOT11_LOCID_SUBELEM_ID 0
  3088. BWL_PRE_PACKED_STRUCT struct dot11_ftm_range_subel {
  3089. uint8 id;
  3090. uint8 len;
  3091. uint16 max_age;
  3092. } BWL_POST_PACKED_STRUCT;
  3093. typedef struct dot11_ftm_range_subel dot11_ftm_range_subel_t;
  3094. #define DOT11_FTM_RANGE_SUBELEM_ID 4
  3095. #define DOT11_FTM_RANGE_SUBELEM_LEN 2
  3096. BWL_PRE_PACKED_STRUCT struct dot11_rmreq_ftm_range {
  3097. uint8 id;
  3098. uint8 len;
  3099. uint8 token;
  3100. uint8 mode;
  3101. uint8 type;
  3102. uint16 max_init_delay; /* maximum random initial delay */
  3103. uint8 min_ap_count;
  3104. uint8 data[1];
  3105. /* neighbor report sub-elements */
  3106. /* optional sub-elements */
  3107. } BWL_POST_PACKED_STRUCT;
  3108. typedef struct dot11_rmreq_ftm_range dot11_rmreq_ftm_range_t;
  3109. #define DOT11_RMREQ_FTM_RANGE_LEN 8
  3110. #define DOT11_FTM_RANGE_LEN 3
  3111. BWL_PRE_PACKED_STRUCT struct dot11_ftm_range_entry {
  3112. uint32 start_tsf; /* 4 lsb of tsf */
  3113. struct ether_addr bssid;
  3114. uint8 range[DOT11_FTM_RANGE_LEN];
  3115. uint8 max_err[DOT11_FTM_RANGE_LEN];
  3116. uint8 rsvd;
  3117. } BWL_POST_PACKED_STRUCT;
  3118. typedef struct dot11_ftm_range_entry dot11_ftm_range_entry_t;
  3119. #define DOT11_FTM_RANGE_ENTRY_MAX_COUNT 15
  3120. enum {
  3121. DOT11_FTM_RANGE_ERROR_AP_INCAPABLE = 2,
  3122. DOT11_FTM_RANGE_ERROR_AP_FAILED = 3,
  3123. DOT11_FTM_RANGE_ERROR_TX_FAILED = 8,
  3124. DOT11_FTM_RANGE_ERROR_MAX
  3125. };
  3126. BWL_PRE_PACKED_STRUCT struct dot11_ftm_range_error_entry {
  3127. uint32 start_tsf; /* 4 lsb of tsf */
  3128. struct ether_addr bssid;
  3129. uint8 code;
  3130. } BWL_POST_PACKED_STRUCT;
  3131. typedef struct dot11_ftm_range_error_entry dot11_ftm_range_error_entry_t;
  3132. #define DOT11_FTM_RANGE_ERROR_ENTRY_MAX_COUNT 11
  3133. BWL_PRE_PACKED_STRUCT struct dot11_rmrep_ftm_range {
  3134. uint8 id;
  3135. uint8 len;
  3136. uint8 token;
  3137. uint8 mode;
  3138. uint8 type;
  3139. uint8 entry_count;
  3140. uint8 data[2]; /* includes pad */
  3141. /*
  3142. dot11_ftm_range_entry_t entries[entry_count];
  3143. uint8 error_count;
  3144. dot11_ftm_error_entry_t errors[error_count];
  3145. */
  3146. } BWL_POST_PACKED_STRUCT;
  3147. typedef struct dot11_rmrep_ftm_range dot11_rmrep_ftm_range_t;
  3148. #define DOT11_FTM_RANGE_REP_MIN_LEN 6 /* No extra byte for error_count */
  3149. #define DOT11_FTM_RANGE_ENTRY_CNT_MAX 15
  3150. #define DOT11_FTM_RANGE_ERROR_CNT_MAX 11
  3151. #define DOT11_FTM_RANGE_REP_FIXED_LEN 1 /* No extra byte for error_count */
  3152. /** Measurement pause request */
  3153. BWL_PRE_PACKED_STRUCT struct dot11_rmreq_pause_time {
  3154. uint8 id;
  3155. uint8 len;
  3156. uint8 token;
  3157. uint8 mode;
  3158. uint8 type;
  3159. uint16 pause_time;
  3160. } BWL_POST_PACKED_STRUCT;
  3161. typedef struct dot11_rmreq_pause_time dot11_rmreq_pause_time_t;
  3162. #define DOT11_RMREQ_PAUSE_LEN 7
  3163. /* Neighbor Report subelements ID (11k & 11v) */
  3164. #define DOT11_NGBR_TSF_INFO_SE_ID 1
  3165. #define DOT11_NGBR_CCS_SE_ID 2
  3166. #define DOT11_NGBR_BSSTRANS_PREF_SE_ID 3
  3167. #define DOT11_NGBR_BSS_TERM_DUR_SE_ID 4
  3168. #define DOT11_NGBR_BEARING_SE_ID 5
  3169. #define DOT11_NGBR_WIDE_BW_CHAN_SE_ID 6
  3170. /** Neighbor Report, BSS Transition Candidate Preference subelement */
  3171. BWL_PRE_PACKED_STRUCT struct dot11_ngbr_bsstrans_pref_se {
  3172. uint8 sub_id;
  3173. uint8 len;
  3174. uint8 preference;
  3175. } BWL_POST_PACKED_STRUCT;
  3176. typedef struct dot11_ngbr_bsstrans_pref_se dot11_ngbr_bsstrans_pref_se_t;
  3177. #define DOT11_NGBR_BSSTRANS_PREF_SE_LEN 1
  3178. #define DOT11_NGBR_BSSTRANS_PREF_SE_IE_LEN 3
  3179. #define DOT11_NGBR_BSSTRANS_PREF_SE_HIGHEST 0xff
  3180. /** Neighbor Report, BSS Termination Duration subelement */
  3181. BWL_PRE_PACKED_STRUCT struct dot11_ngbr_bss_term_dur_se {
  3182. uint8 sub_id;
  3183. uint8 len;
  3184. uint8 tsf[8];
  3185. uint16 duration;
  3186. } BWL_POST_PACKED_STRUCT;
  3187. typedef struct dot11_ngbr_bss_term_dur_se dot11_ngbr_bss_term_dur_se_t;
  3188. #define DOT11_NGBR_BSS_TERM_DUR_SE_LEN 10
  3189. /* Neighbor Report BSSID Information Field */
  3190. #define DOT11_NGBR_BI_REACHABILTY_UNKN 0x0002
  3191. #define DOT11_NGBR_BI_REACHABILTY 0x0003
  3192. #define DOT11_NGBR_BI_SEC 0x0004
  3193. #define DOT11_NGBR_BI_KEY_SCOPE 0x0008
  3194. #define DOT11_NGBR_BI_CAP 0x03f0
  3195. #define DOT11_NGBR_BI_CAP_SPEC_MGMT 0x0010
  3196. #define DOT11_NGBR_BI_CAP_QOS 0x0020
  3197. #define DOT11_NGBR_BI_CAP_APSD 0x0040
  3198. #define DOT11_NGBR_BI_CAP_RDIO_MSMT 0x0080
  3199. #define DOT11_NGBR_BI_CAP_DEL_BA 0x0100
  3200. #define DOT11_NGBR_BI_CAP_IMM_BA 0x0200
  3201. #define DOT11_NGBR_BI_MOBILITY 0x0400
  3202. #define DOT11_NGBR_BI_HT 0x0800
  3203. #define DOT11_NGBR_BI_VHT 0x1000
  3204. #define DOT11_NGBR_BI_FTM 0x2000
  3205. /** Neighbor Report element (11k & 11v) */
  3206. BWL_PRE_PACKED_STRUCT struct dot11_neighbor_rep_ie {
  3207. uint8 id;
  3208. uint8 len;
  3209. struct ether_addr bssid;
  3210. uint32 bssid_info;
  3211. uint8 reg; /* Operating class */
  3212. uint8 channel;
  3213. uint8 phytype;
  3214. uint8 data[1]; /* Variable size subelements */
  3215. } BWL_POST_PACKED_STRUCT;
  3216. typedef struct dot11_neighbor_rep_ie dot11_neighbor_rep_ie_t;
  3217. #define DOT11_NEIGHBOR_REP_IE_FIXED_LEN 13u
  3218. /* MLME Enumerations */
  3219. #define DOT11_BSSTYPE_INFRASTRUCTURE 0 /* d11 infrastructure */
  3220. #define DOT11_BSSTYPE_INDEPENDENT 1 /* d11 independent */
  3221. #define DOT11_BSSTYPE_ANY 2 /* d11 any BSS type */
  3222. #define DOT11_BSSTYPE_MESH 3 /* d11 Mesh */
  3223. #define DOT11_SCANTYPE_ACTIVE 0 /* d11 scan active */
  3224. #define DOT11_SCANTYPE_PASSIVE 1 /* d11 scan passive */
  3225. /** Link Measurement */
  3226. BWL_PRE_PACKED_STRUCT struct dot11_lmreq {
  3227. uint8 category; /* category of action frame (5) */
  3228. uint8 action; /* radio measurement action */
  3229. uint8 token; /* dialog token */
  3230. uint8 txpwr; /* Transmit Power Used */
  3231. uint8 maxtxpwr; /* Max Transmit Power */
  3232. } BWL_POST_PACKED_STRUCT;
  3233. typedef struct dot11_lmreq dot11_lmreq_t;
  3234. #define DOT11_LMREQ_LEN 5
  3235. BWL_PRE_PACKED_STRUCT struct dot11_lmrep {
  3236. uint8 category; /* category of action frame (5) */
  3237. uint8 action; /* radio measurement action */
  3238. uint8 token; /* dialog token */
  3239. dot11_tpc_rep_t tpc; /* TPC element */
  3240. uint8 rxant; /* Receive Antenna ID */
  3241. uint8 txant; /* Transmit Antenna ID */
  3242. uint8 rcpi; /* RCPI */
  3243. uint8 rsni; /* RSNI */
  3244. } BWL_POST_PACKED_STRUCT;
  3245. typedef struct dot11_lmrep dot11_lmrep_t;
  3246. #define DOT11_LMREP_LEN 11
  3247. #define DOT11_MP_CAP_SPECTRUM 0x01 /* d11 cap. spectrum */
  3248. #define DOT11_MP_CAP_SHORTSLOT 0x02 /* d11 cap. shortslot */
  3249. /* Measurement Pilot */
  3250. BWL_PRE_PACKED_STRUCT struct dot11_mprep {
  3251. uint8 cap_info; /* Condensed capability Info. */
  3252. uint8 country[2]; /* Condensed country string */
  3253. uint8 opclass; /* Op. Class */
  3254. uint8 channel; /* Channel */
  3255. uint8 mp_interval; /* Measurement Pilot Interval */
  3256. } BWL_POST_PACKED_STRUCT;
  3257. typedef struct dot11_mprep dot11_mprep_t;
  3258. #define DOT11_MPREP_LEN 6
  3259. /* 802.11 BRCM "Compromise" Pre N constants */
  3260. #define PREN_PREAMBLE 24 /* green field preamble time */
  3261. #define PREN_MM_EXT 12 /* extra mixed mode preamble time */
  3262. #define PREN_PREAMBLE_EXT 4 /* extra preamble (multiply by unique_streams-1) */
  3263. /* 802.11N PHY constants */
  3264. #define RIFS_11N_TIME 2 /* NPHY RIFS time */
  3265. /* 802.11 HT PLCP format 802.11n-2009, sec 20.3.9.4.3
  3266. * HT-SIG is composed of two 24 bit parts, HT-SIG1 and HT-SIG2
  3267. */
  3268. /* HT-SIG1 */
  3269. #define HT_SIG1_MCS_MASK 0x00007F
  3270. #define HT_SIG1_CBW 0x000080
  3271. #define HT_SIG1_HT_LENGTH 0xFFFF00
  3272. /* HT-SIG2 */
  3273. #define HT_SIG2_SMOOTHING 0x000001
  3274. #define HT_SIG2_NOT_SOUNDING 0x000002
  3275. #define HT_SIG2_RESERVED 0x000004
  3276. #define HT_SIG2_AGGREGATION 0x000008
  3277. #define HT_SIG2_STBC_MASK 0x000030
  3278. #define HT_SIG2_STBC_SHIFT 4
  3279. #define HT_SIG2_FEC_CODING 0x000040
  3280. #define HT_SIG2_SHORT_GI 0x000080
  3281. #define HT_SIG2_ESS_MASK 0x000300
  3282. #define HT_SIG2_ESS_SHIFT 8
  3283. #define HT_SIG2_CRC 0x03FC00
  3284. #define HT_SIG2_TAIL 0x1C0000
  3285. /* HT Timing-related parameters (802.11-2012, sec 20.3.6) */
  3286. #define HT_T_LEG_PREAMBLE 16
  3287. #define HT_T_L_SIG 4
  3288. #define HT_T_SIG 8
  3289. #define HT_T_LTF1 4
  3290. #define HT_T_GF_LTF1 8
  3291. #define HT_T_LTFs 4
  3292. #define HT_T_STF 4
  3293. #define HT_T_GF_STF 8
  3294. #define HT_T_SYML 4
  3295. #define HT_N_SERVICE 16 /* bits in SERVICE field */
  3296. #define HT_N_TAIL 6 /* tail bits per BCC encoder */
  3297. /* 802.11 A PHY constants */
  3298. #define APHY_SLOT_TIME 9 /* APHY slot time */
  3299. #define APHY_SIFS_TIME 16 /* APHY SIFS time */
  3300. #define APHY_DIFS_TIME (APHY_SIFS_TIME + (2 * APHY_SLOT_TIME)) /* APHY DIFS time */
  3301. #define APHY_PREAMBLE_TIME 16 /* APHY preamble time */
  3302. #define APHY_SIGNAL_TIME 4 /* APHY signal time */
  3303. #define APHY_SYMBOL_TIME 4 /* APHY symbol time */
  3304. #define APHY_SERVICE_NBITS 16 /* APHY service nbits */
  3305. #define APHY_TAIL_NBITS 6 /* APHY tail nbits */
  3306. #define APHY_CWMIN 15 /* APHY cwmin */
  3307. #define APHY_PHYHDR_DUR 20 /* APHY PHY Header Duration */
  3308. /* 802.11 B PHY constants */
  3309. #define BPHY_SLOT_TIME 20 /* BPHY slot time */
  3310. #define BPHY_SIFS_TIME 10 /* BPHY SIFS time */
  3311. #define BPHY_DIFS_TIME 50 /* BPHY DIFS time */
  3312. #define BPHY_PLCP_TIME 192 /* BPHY PLCP time */
  3313. #define BPHY_PLCP_SHORT_TIME 96 /* BPHY PLCP short time */
  3314. #define BPHY_CWMIN 31 /* BPHY cwmin */
  3315. #define BPHY_SHORT_PHYHDR_DUR 96 /* BPHY Short PHY Header Duration */
  3316. #define BPHY_LONG_PHYHDR_DUR 192 /* BPHY Long PHY Header Duration */
  3317. /* 802.11 G constants */
  3318. #define DOT11_OFDM_SIGNAL_EXTENSION 6 /* d11 OFDM signal extension */
  3319. #define PHY_CWMAX 1023 /* PHY cwmax */
  3320. #define DOT11_MAXNUMFRAGS 16 /* max # fragments per MSDU */
  3321. /* 802.11 VHT constants */
  3322. typedef int vht_group_id_t;
  3323. /* for VHT-A1 */
  3324. /* SIG-A1 reserved bits */
  3325. #define VHT_SIGA1_CONST_MASK 0x800004
  3326. #define VHT_SIGA1_BW_MASK 0x000003
  3327. #define VHT_SIGA1_20MHZ_VAL 0x000000
  3328. #define VHT_SIGA1_40MHZ_VAL 0x000001
  3329. #define VHT_SIGA1_80MHZ_VAL 0x000002
  3330. #define VHT_SIGA1_160MHZ_VAL 0x000003
  3331. #define VHT_SIGA1_STBC 0x000008
  3332. #define VHT_SIGA1_GID_MASK 0x0003f0
  3333. #define VHT_SIGA1_GID_SHIFT 4
  3334. #define VHT_SIGA1_GID_TO_AP 0x00
  3335. #define VHT_SIGA1_GID_NOT_TO_AP 0x3f
  3336. #define VHT_SIGA1_GID_MAX_GID 0x3f
  3337. #define VHT_SIGA1_NSTS_SHIFT_MASK_USER0 0x001C00
  3338. #define VHT_SIGA1_NSTS_SHIFT 10
  3339. #define VHT_SIGA1_MAX_USERPOS 3
  3340. #define VHT_SIGA1_PARTIAL_AID_MASK 0x3fe000
  3341. #define VHT_SIGA1_PARTIAL_AID_SHIFT 13
  3342. #define VHT_SIGA1_TXOP_PS_NOT_ALLOWED 0x400000
  3343. /* for VHT-A2 */
  3344. #define VHT_SIGA2_GI_NONE 0x000000
  3345. #define VHT_SIGA2_GI_SHORT 0x000001
  3346. #define VHT_SIGA2_GI_W_MOD10 0x000002
  3347. #define VHT_SIGA2_CODING_LDPC 0x000004
  3348. #define VHT_SIGA2_LDPC_EXTRA_OFDM_SYM 0x000008
  3349. #define VHT_SIGA2_BEAMFORM_ENABLE 0x000100
  3350. #define VHT_SIGA2_MCS_SHIFT 4
  3351. #define VHT_SIGA2_B9_RESERVED 0x000200
  3352. #define VHT_SIGA2_TAIL_MASK 0xfc0000
  3353. #define VHT_SIGA2_TAIL_VALUE 0x000000
  3354. /* VHT Timing-related parameters (802.11ac D4.0, sec 22.3.6) */
  3355. #define VHT_T_LEG_PREAMBLE 16
  3356. #define VHT_T_L_SIG 4
  3357. #define VHT_T_SIG_A 8
  3358. #define VHT_T_LTF 4
  3359. #define VHT_T_STF 4
  3360. #define VHT_T_SIG_B 4
  3361. #define VHT_T_SYML 4
  3362. #define VHT_N_SERVICE 16 /* bits in SERVICE field */
  3363. #define VHT_N_TAIL 6 /* tail bits per BCC encoder */
  3364. /** dot11Counters Table - 802.11 spec., Annex D */
  3365. typedef struct d11cnt {
  3366. uint32 txfrag; /* dot11TransmittedFragmentCount */
  3367. uint32 txmulti; /* dot11MulticastTransmittedFrameCount */
  3368. uint32 txfail; /* dot11FailedCount */
  3369. uint32 txretry; /* dot11RetryCount */
  3370. uint32 txretrie; /* dot11MultipleRetryCount */
  3371. uint32 rxdup; /* dot11FrameduplicateCount */
  3372. uint32 txrts; /* dot11RTSSuccessCount */
  3373. uint32 txnocts; /* dot11RTSFailureCount */
  3374. uint32 txnoack; /* dot11ACKFailureCount */
  3375. uint32 rxfrag; /* dot11ReceivedFragmentCount */
  3376. uint32 rxmulti; /* dot11MulticastReceivedFrameCount */
  3377. uint32 rxcrc; /* dot11FCSErrorCount */
  3378. uint32 txfrmsnt; /* dot11TransmittedFrameCount */
  3379. uint32 rxundec; /* dot11WEPUndecryptableCount */
  3380. } d11cnt_t;
  3381. #define BRCM_PROP_OUI "\x00\x90\x4C"
  3382. #define BRCM_FTM_IE_TYPE 14
  3383. /* #define HT_CAP_IE_TYPE 51
  3384. * #define HT_ADD_IE_TYPE 52
  3385. * #define BRCM_EXTCH_IE_TYPE 53
  3386. * #define MEMBER_OF_BRCM_PROP_IE_TYPE 54
  3387. * #define BRCM_RELMACST_IE_TYPE 55
  3388. * #define BRCM_EVT_WL_BSS_INFO 64
  3389. * #define RWL_ACTION_WIFI_FRAG_TYPE 85
  3390. * #define BTC_INFO_BRCM_PROP_IE_TYPE 90
  3391. * #define ULB_BRCM_PROP_IE_TYPE 91
  3392. * #define SDB_BRCM_PROP_IE_TYPE 92
  3393. */
  3394. /* Action frame type for RWL */
  3395. #define RWL_WIFI_DEFAULT 0
  3396. #define RWL_WIFI_FIND_MY_PEER 9 /* Used while finding server */
  3397. #define RWL_WIFI_FOUND_PEER 10 /* Server response to the client */
  3398. #define RWL_ACTION_WIFI_FRAG_TYPE 85 /* Fragment indicator for receiver */
  3399. #define PROXD_AF_TYPE 11 /* Wifi proximity action frame type */
  3400. #define BRCM_RELMACST_AF_TYPE 12 /* RMC action frame type */
  3401. /* Action frame type for FTM Initiator Report */
  3402. #define BRCM_FTM_VS_AF_TYPE 14
  3403. enum {
  3404. BRCM_FTM_VS_INITIATOR_RPT_SUBTYPE = 1, /* FTM Initiator Report */
  3405. BRCM_FTM_VS_COLLECT_SUBTYPE = 2, /* FTM Collect debug protocol */
  3406. };
  3407. /*
  3408. * This BRCM_PROP_OUI types is intended for use in events to embed additional
  3409. * data, and would not be expected to appear on the air -- but having an IE
  3410. * format allows IE frame data with extra data in events in that allows for
  3411. * more flexible parsing.
  3412. */
  3413. #define BRCM_EVT_WL_BSS_INFO 64
  3414. /**
  3415. * Following is the generic structure for brcm_prop_ie (uses BRCM_PROP_OUI).
  3416. * DPT uses this format with type set to DPT_IE_TYPE
  3417. */
  3418. BWL_PRE_PACKED_STRUCT struct brcm_prop_ie_s {
  3419. uint8 id; /* IE ID, 221, DOT11_MNG_PROPR_ID */
  3420. uint8 len; /* IE length */
  3421. uint8 oui[3];
  3422. uint8 type; /* type of this IE */
  3423. uint16 cap; /* DPT capabilities */
  3424. } BWL_POST_PACKED_STRUCT;
  3425. typedef struct brcm_prop_ie_s brcm_prop_ie_t;
  3426. #define BRCM_PROP_IE_LEN 6 /* len of fixed part of brcm_prop ie */
  3427. #define DPT_IE_TYPE 2
  3428. #define BRCM_SYSCAP_IE_TYPE 3
  3429. #define WET_TUNNEL_IE_TYPE 3
  3430. /* brcm syscap_ie cap */
  3431. #define BRCM_SYSCAP_WET_TUNNEL 0x0100 /* Device with WET_TUNNEL support */
  3432. #define BRCM_OUI "\x00\x10\x18" /* Broadcom OUI */
  3433. /** BRCM info element */
  3434. BWL_PRE_PACKED_STRUCT struct brcm_ie {
  3435. uint8 id; /* IE ID, 221, DOT11_MNG_PROPR_ID */
  3436. uint8 len; /* IE length */
  3437. uint8 oui[3];
  3438. uint8 ver; /* type/ver of this IE */
  3439. uint8 assoc; /* # of assoc STAs */
  3440. uint8 flags; /* misc flags */
  3441. uint8 flags1; /* misc flags */
  3442. uint16 amsdu_mtu_pref; /* preferred A-MSDU MTU */
  3443. } BWL_POST_PACKED_STRUCT;
  3444. typedef struct brcm_ie brcm_ie_t;
  3445. #define BRCM_IE_LEN 11 /* BRCM IE length */
  3446. #define BRCM_IE_VER 2 /* BRCM IE version */
  3447. #define BRCM_IE_LEGACY_AES_VER 1 /* BRCM IE legacy AES version */
  3448. /* brcm_ie flags */
  3449. #define BRF_ABCAP 0x1 /* afterburner is obsolete, defined for backward compat */
  3450. #define BRF_ABRQRD 0x2 /* afterburner is obsolete, defined for backward compat */
  3451. #define BRF_LZWDS 0x4 /* lazy wds enabled */
  3452. #define BRF_BLOCKACK 0x8 /* BlockACK capable */
  3453. #define BRF_ABCOUNTER_MASK 0xf0 /* afterburner is obsolete, defined for backward compat */
  3454. #define BRF_PROP_11N_MCS 0x10 /* re-use afterburner bit */
  3455. #define BRF_MEDIA_CLIENT 0x20 /* re-use afterburner bit to indicate media client device */
  3456. #define GET_BRF_PROP_11N_MCS(brcm_ie) \
  3457. (!((brcm_ie)->flags & BRF_ABCAP) && ((brcm_ie)->flags & BRF_PROP_11N_MCS))
  3458. /* brcm_ie flags1 */
  3459. #define BRF1_AMSDU 0x1 /* A-MSDU capable */
  3460. #define BRF1_WNM 0x2 /* WNM capable */
  3461. #define BRF1_WMEPS 0x4 /* AP is capable of handling WME + PS w/o APSD */
  3462. #define BRF1_PSOFIX 0x8 /* AP has fixed PS mode out-of-order packets */
  3463. #define BRF1_RX_LARGE_AGG 0x10 /* device can rx large aggregates */
  3464. #define BRF1_RFAWARE_DCS 0x20 /* RFAWARE dynamic channel selection (DCS) */
  3465. #define BRF1_SOFTAP 0x40 /* Configure as Broadcom SOFTAP */
  3466. #define BRF1_DWDS 0x80 /* DWDS capable */
  3467. /** Vendor IE structure */
  3468. BWL_PRE_PACKED_STRUCT struct vndr_ie {
  3469. uchar id;
  3470. uchar len;
  3471. uchar oui [3];
  3472. uchar data [1]; /* Variable size data */
  3473. } BWL_POST_PACKED_STRUCT;
  3474. typedef struct vndr_ie vndr_ie_t;
  3475. #define VNDR_IE_HDR_LEN 2u /* id + len field */
  3476. #define VNDR_IE_MIN_LEN 3u /* size of the oui field */
  3477. #define VNDR_IE_FIXED_LEN (VNDR_IE_HDR_LEN + VNDR_IE_MIN_LEN)
  3478. #define VNDR_IE_MAX_LEN 255u /* vendor IE max length, without ID and len */
  3479. /** BRCM PROP DEVICE PRIMARY MAC ADDRESS IE */
  3480. BWL_PRE_PACKED_STRUCT struct member_of_brcm_prop_ie {
  3481. uchar id;
  3482. uchar len;
  3483. uchar oui[3];
  3484. uint8 type; /* type indicates what follows */
  3485. struct ether_addr ea; /* Device Primary MAC Adrress */
  3486. } BWL_POST_PACKED_STRUCT;
  3487. typedef struct member_of_brcm_prop_ie member_of_brcm_prop_ie_t;
  3488. #define MEMBER_OF_BRCM_PROP_IE_LEN 10 /* IE max length */
  3489. #define MEMBER_OF_BRCM_PROP_IE_HDRLEN (sizeof(member_of_brcm_prop_ie_t))
  3490. #define MEMBER_OF_BRCM_PROP_IE_TYPE 54
  3491. /** BRCM Reliable Multicast IE */
  3492. BWL_PRE_PACKED_STRUCT struct relmcast_brcm_prop_ie {
  3493. uint8 id;
  3494. uint8 len;
  3495. uint8 oui[3];
  3496. uint8 type; /* type indicates what follows */
  3497. struct ether_addr ea; /* The ack sender's MAC Adrress */
  3498. struct ether_addr mcast_ea; /* The multicast MAC address */
  3499. uint8 updtmo; /* time interval(second) for client to send null packet to report its rssi */
  3500. } BWL_POST_PACKED_STRUCT;
  3501. typedef struct relmcast_brcm_prop_ie relmcast_brcm_prop_ie_t;
  3502. /* IE length */
  3503. /* BRCM_PROP_IE_LEN = sizeof(relmcast_brcm_prop_ie_t)-((sizeof (id) + sizeof (len)))? */
  3504. #define RELMCAST_BRCM_PROP_IE_LEN (sizeof(relmcast_brcm_prop_ie_t)-(2*sizeof(uint8)))
  3505. #define RELMCAST_BRCM_PROP_IE_TYPE 55
  3506. /* BRCM BTC IE */
  3507. BWL_PRE_PACKED_STRUCT struct btc_brcm_prop_ie {
  3508. uint8 id;
  3509. uint8 len;
  3510. uint8 oui[3];
  3511. uint8 type; /* type inidicates what follows */
  3512. uint32 info;
  3513. } BWL_POST_PACKED_STRUCT;
  3514. typedef struct btc_brcm_prop_ie btc_brcm_prop_ie_t;
  3515. #define BTC_INFO_BRCM_PROP_IE_TYPE 90
  3516. #define BRCM_BTC_INFO_TYPE_LEN (sizeof(btc_brcm_prop_ie_t) - (2 * sizeof(uint8)))
  3517. /* ************* HT definitions. ************* */
  3518. #define MCSSET_LEN 16 /* 16-bits per 8-bit set to give 128-bits bitmap of MCS Index */
  3519. #define MAX_MCS_NUM (128) /* max mcs number = 128 */
  3520. #define BASIC_HT_MCS 0xFFu /* HT MCS supported rates */
  3521. BWL_PRE_PACKED_STRUCT struct ht_cap_ie {
  3522. uint16 cap;
  3523. uint8 params;
  3524. uint8 supp_mcs[MCSSET_LEN];
  3525. uint16 ext_htcap;
  3526. uint32 txbf_cap;
  3527. uint8 as_cap;
  3528. } BWL_POST_PACKED_STRUCT;
  3529. typedef struct ht_cap_ie ht_cap_ie_t;
  3530. BWL_PRE_PACKED_STRUCT struct dot11_ht_cap_ie {
  3531. uint8 id;
  3532. uint8 len;
  3533. ht_cap_ie_t ht_cap;
  3534. } BWL_POST_PACKED_STRUCT;
  3535. typedef struct dot11_ht_cap_ie dot11_ht_cap_ie_t;
  3536. /* CAP IE: HT 1.0 spec. simply stole a 802.11 IE, we use our prop. IE until this is resolved */
  3537. /* the capability IE is primarily used to convey this nodes abilities */
  3538. BWL_PRE_PACKED_STRUCT struct ht_prop_cap_ie {
  3539. uint8 id; /* IE ID, 221, DOT11_MNG_PROPR_ID */
  3540. uint8 len; /* IE length */
  3541. uint8 oui[3];
  3542. uint8 type; /* type indicates what follows */
  3543. ht_cap_ie_t cap_ie;
  3544. } BWL_POST_PACKED_STRUCT;
  3545. typedef struct ht_prop_cap_ie ht_prop_cap_ie_t;
  3546. #define HT_PROP_IE_OVERHEAD 4 /* overhead bytes for prop oui ie */
  3547. #define HT_CAP_IE_LEN 26 /* HT capability len (based on .11n d2.0) */
  3548. #define HT_CAP_IE_TYPE 51
  3549. #define HT_CAP_LDPC_CODING 0x0001 /* Support for rx of LDPC coded pkts */
  3550. #define HT_CAP_40MHZ 0x0002 /* FALSE:20Mhz, TRUE:20/40MHZ supported */
  3551. #define HT_CAP_MIMO_PS_MASK 0x000C /* Mimo PS mask */
  3552. #define HT_CAP_MIMO_PS_SHIFT 0x0002 /* Mimo PS shift */
  3553. #define HT_CAP_MIMO_PS_OFF 0x0003 /* Mimo PS, no restriction */
  3554. #define HT_CAP_MIMO_PS_RTS 0x0001 /* Mimo PS, send RTS/CTS around MIMO frames */
  3555. #define HT_CAP_MIMO_PS_ON 0x0000 /* Mimo PS, MIMO disallowed */
  3556. #define HT_CAP_GF 0x0010 /* Greenfield preamble support */
  3557. #define HT_CAP_SHORT_GI_20 0x0020 /* 20MHZ short guard interval support */
  3558. #define HT_CAP_SHORT_GI_40 0x0040 /* 40Mhz short guard interval support */
  3559. #define HT_CAP_TX_STBC 0x0080 /* Tx STBC support */
  3560. #define HT_CAP_RX_STBC_MASK 0x0300 /* Rx STBC mask */
  3561. #define HT_CAP_RX_STBC_SHIFT 8 /* Rx STBC shift */
  3562. #define HT_CAP_DELAYED_BA 0x0400 /* delayed BA support */
  3563. #define HT_CAP_MAX_AMSDU 0x0800 /* Max AMSDU size in bytes , 0=3839, 1=7935 */
  3564. #define HT_CAP_DSSS_CCK 0x1000 /* DSSS/CCK supported by the BSS */
  3565. #define HT_CAP_PSMP 0x2000 /* Power Save Multi Poll support */
  3566. #define HT_CAP_40MHZ_INTOLERANT 0x4000 /* 40MHz Intolerant */
  3567. #define HT_CAP_LSIG_TXOP 0x8000 /* L-SIG TXOP protection support */
  3568. #define HT_CAP_RX_STBC_NO 0x0 /* no rx STBC support */
  3569. #define HT_CAP_RX_STBC_ONE_STREAM 0x1 /* rx STBC support of 1 spatial stream */
  3570. #define HT_CAP_RX_STBC_TWO_STREAM 0x2 /* rx STBC support of 1-2 spatial streams */
  3571. #define HT_CAP_RX_STBC_THREE_STREAM 0x3 /* rx STBC support of 1-3 spatial streams */
  3572. #define HT_CAP_TXBF_CAP_IMPLICIT_TXBF_RX 0x1
  3573. #define HT_CAP_TXBF_CAP_NDP_RX 0x8
  3574. #define HT_CAP_TXBF_CAP_NDP_TX 0x10
  3575. #define HT_CAP_TXBF_CAP_EXPLICIT_CSI 0x100
  3576. #define HT_CAP_TXBF_CAP_EXPLICIT_NC_STEERING 0x200
  3577. #define HT_CAP_TXBF_CAP_EXPLICIT_C_STEERING 0x400
  3578. #define HT_CAP_TXBF_CAP_EXPLICIT_CSI_FB_MASK 0x1800
  3579. #define HT_CAP_TXBF_CAP_EXPLICIT_CSI_FB_SHIFT 11
  3580. #define HT_CAP_TXBF_CAP_EXPLICIT_NC_FB_MASK 0x6000
  3581. #define HT_CAP_TXBF_CAP_EXPLICIT_NC_FB_SHIFT 13
  3582. #define HT_CAP_TXBF_CAP_EXPLICIT_C_FB_MASK 0x18000
  3583. #define HT_CAP_TXBF_CAP_EXPLICIT_C_FB_SHIFT 15
  3584. #define HT_CAP_TXBF_CAP_CSI_BFR_ANT_SHIFT 19
  3585. #define HT_CAP_TXBF_CAP_NC_BFR_ANT_SHIFT 21
  3586. #define HT_CAP_TXBF_CAP_C_BFR_ANT_SHIFT 23
  3587. #define HT_CAP_TXBF_CAP_C_BFR_ANT_MASK 0x1800000
  3588. #define HT_CAP_TXBF_CAP_CHAN_ESTIM_SHIFT 27
  3589. #define HT_CAP_TXBF_CAP_CHAN_ESTIM_MASK 0x18000000
  3590. #define HT_CAP_TXBF_FB_TYPE_NONE 0
  3591. #define HT_CAP_TXBF_FB_TYPE_DELAYED 1
  3592. #define HT_CAP_TXBF_FB_TYPE_IMMEDIATE 2
  3593. #define HT_CAP_TXBF_FB_TYPE_BOTH 3
  3594. #define HT_CAP_TX_BF_CAP_EXPLICIT_CSI_FB_MASK 0x400
  3595. #define HT_CAP_TX_BF_CAP_EXPLICIT_CSI_FB_SHIFT 10
  3596. #define HT_CAP_TX_BF_CAP_EXPLICIT_COMPRESSED_FB_MASK 0x18000
  3597. #define HT_CAP_TX_BF_CAP_EXPLICIT_COMPRESSED_FB_SHIFT 15
  3598. #define HT_CAP_MCS_FLAGS_SUPP_BYTE 12 /* byte offset in HT Cap Supported MCS for various flags */
  3599. #define HT_CAP_MCS_RX_8TO15_BYTE_OFFSET 1
  3600. #define HT_CAP_MCS_FLAGS_TX_RX_UNEQUAL 0x02
  3601. #define HT_CAP_MCS_FLAGS_MAX_SPATIAL_STREAM_MASK 0x0C
  3602. #define VHT_MAX_MPDU 11454 /* max mpdu size for now (bytes) */
  3603. #define VHT_MPDU_MSDU_DELTA 56 /* Difference in spec - vht mpdu, amsdu len */
  3604. /* Max AMSDU len - per spec */
  3605. #define VHT_MAX_AMSDU (VHT_MAX_MPDU - VHT_MPDU_MSDU_DELTA)
  3606. #define HT_MAX_AMSDU 7935 /* max amsdu size (bytes) per the HT spec */
  3607. #define HT_MIN_AMSDU 3835 /* min amsdu size (bytes) per the HT spec */
  3608. #define HT_PARAMS_RX_FACTOR_MASK 0x03 /* ampdu rcv factor mask */
  3609. #define HT_PARAMS_DENSITY_MASK 0x1C /* ampdu density mask */
  3610. #define HT_PARAMS_DENSITY_SHIFT 2 /* ampdu density shift */
  3611. /* HT/AMPDU specific define */
  3612. #define AMPDU_MAX_MPDU_DENSITY 7 /* max mpdu density; in 1/4 usec units */
  3613. #define AMPDU_DENSITY_NONE 0 /* No density requirement */
  3614. #define AMPDU_DENSITY_1over4_US 1 /* 1/4 us density */
  3615. #define AMPDU_DENSITY_1over2_US 2 /* 1/2 us density */
  3616. #define AMPDU_DENSITY_1_US 3 /* 1 us density */
  3617. #define AMPDU_DENSITY_2_US 4 /* 2 us density */
  3618. #define AMPDU_DENSITY_4_US 5 /* 4 us density */
  3619. #define AMPDU_DENSITY_8_US 6 /* 8 us density */
  3620. #define AMPDU_DENSITY_16_US 7 /* 16 us density */
  3621. #define AMPDU_RX_FACTOR_8K 0 /* max rcv ampdu len (8kb) */
  3622. #define AMPDU_RX_FACTOR_16K 1 /* max rcv ampdu len (16kb) */
  3623. #define AMPDU_RX_FACTOR_32K 2 /* max rcv ampdu len (32kb) */
  3624. #define AMPDU_RX_FACTOR_64K 3 /* max rcv ampdu len (64kb) */
  3625. /* AMPDU RX factors for VHT rates */
  3626. #define AMPDU_RX_FACTOR_128K 4 /* max rcv ampdu len (128kb) */
  3627. #define AMPDU_RX_FACTOR_256K 5 /* max rcv ampdu len (256kb) */
  3628. #define AMPDU_RX_FACTOR_512K 6 /* max rcv ampdu len (512kb) */
  3629. #define AMPDU_RX_FACTOR_1024K 7 /* max rcv ampdu len (1024kb) */
  3630. #define AMPDU_RX_FACTOR_BASE 8*1024 /* ampdu factor base for rx len */
  3631. #define AMPDU_RX_FACTOR_BASE_PWR 13 /* ampdu factor base for rx len in power of 2 */
  3632. #define AMPDU_DELIMITER_LEN 4u /* length of ampdu delimiter */
  3633. #define AMPDU_DELIMITER_LEN_MAX 63 /* max length of ampdu delimiter(enforced in HW) */
  3634. #define HT_CAP_EXT_PCO 0x0001
  3635. #define HT_CAP_EXT_PCO_TTIME_MASK 0x0006
  3636. #define HT_CAP_EXT_PCO_TTIME_SHIFT 1
  3637. #define HT_CAP_EXT_MCS_FEEDBACK_MASK 0x0300
  3638. #define HT_CAP_EXT_MCS_FEEDBACK_SHIFT 8
  3639. #define HT_CAP_EXT_HTC 0x0400
  3640. #define HT_CAP_EXT_RD_RESP 0x0800
  3641. /** 'ht_add' is called 'HT Operation' information element in the 802.11 standard */
  3642. BWL_PRE_PACKED_STRUCT struct ht_add_ie {
  3643. uint8 ctl_ch; /* control channel number */
  3644. uint8 byte1; /* ext ch,rec. ch. width, RIFS support */
  3645. uint16 opmode; /* operation mode */
  3646. uint16 misc_bits; /* misc bits */
  3647. uint8 basic_mcs[MCSSET_LEN]; /* required MCS set */
  3648. } BWL_POST_PACKED_STRUCT;
  3649. typedef struct ht_add_ie ht_add_ie_t;
  3650. /* ADD IE: HT 1.0 spec. simply stole a 802.11 IE, we use our prop. IE until this is resolved */
  3651. /* the additional IE is primarily used to convey the current BSS configuration */
  3652. BWL_PRE_PACKED_STRUCT struct ht_prop_add_ie {
  3653. uint8 id; /* IE ID, 221, DOT11_MNG_PROPR_ID */
  3654. uint8 len; /* IE length */
  3655. uint8 oui[3];
  3656. uint8 type; /* indicates what follows */
  3657. ht_add_ie_t add_ie;
  3658. } BWL_POST_PACKED_STRUCT;
  3659. typedef struct ht_prop_add_ie ht_prop_add_ie_t;
  3660. #define HT_ADD_IE_LEN 22
  3661. #define HT_ADD_IE_TYPE 52
  3662. /* byte1 defn's */
  3663. #define HT_BW_ANY 0x04 /* set, STA can use 20 or 40MHz */
  3664. #define HT_RIFS_PERMITTED 0x08 /* RIFS allowed */
  3665. /* opmode defn's */
  3666. #define HT_OPMODE_MASK 0x0003 /* protection mode mask */
  3667. #define HT_OPMODE_SHIFT 0 /* protection mode shift */
  3668. #define HT_OPMODE_PURE 0x0000 /* protection mode PURE */
  3669. #define HT_OPMODE_OPTIONAL 0x0001 /* protection mode optional */
  3670. #define HT_OPMODE_HT20IN40 0x0002 /* protection mode 20MHz HT in 40MHz BSS */
  3671. #define HT_OPMODE_MIXED 0x0003 /* protection mode Mixed Mode */
  3672. #define HT_OPMODE_NONGF 0x0004 /* protection mode non-GF */
  3673. #define DOT11N_TXBURST 0x0008 /* Tx burst limit */
  3674. #define DOT11N_OBSS_NONHT 0x0010 /* OBSS Non-HT STA present */
  3675. #define HT_OPMODE_CCFS2_MASK 0x1fe0 /* Channel Center Frequency Segment 2 mask */
  3676. #define HT_OPMODE_CCFS2_SHIFT 5 /* Channel Center Frequency Segment 2 shift */
  3677. /* misc_bites defn's */
  3678. #define HT_BASIC_STBC_MCS 0x007f /* basic STBC MCS */
  3679. #define HT_DUAL_STBC_PROT 0x0080 /* Dual STBC Protection */
  3680. #define HT_SECOND_BCN 0x0100 /* Secondary beacon support */
  3681. #define HT_LSIG_TXOP 0x0200 /* L-SIG TXOP Protection full support */
  3682. #define HT_PCO_ACTIVE 0x0400 /* PCO active */
  3683. #define HT_PCO_PHASE 0x0800 /* PCO phase */
  3684. #define HT_DUALCTS_PROTECTION 0x0080 /* DUAL CTS protection needed */
  3685. /* Tx Burst Limits */
  3686. #define DOT11N_2G_TXBURST_LIMIT 6160 /* 2G band Tx burst limit per 802.11n Draft 1.10 (usec) */
  3687. #define DOT11N_5G_TXBURST_LIMIT 3080 /* 5G band Tx burst limit per 802.11n Draft 1.10 (usec) */
  3688. /* Macros for opmode */
  3689. #define GET_HT_OPMODE(add_ie) ((ltoh16_ua(&add_ie->opmode) & HT_OPMODE_MASK) \
  3690. >> HT_OPMODE_SHIFT)
  3691. #define HT_MIXEDMODE_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & HT_OPMODE_MASK) \
  3692. == HT_OPMODE_MIXED) /* mixed mode present */
  3693. #define HT_HT20_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & HT_OPMODE_MASK) \
  3694. == HT_OPMODE_HT20IN40) /* 20MHz HT present */
  3695. #define HT_OPTIONAL_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & HT_OPMODE_MASK) \
  3696. == HT_OPMODE_OPTIONAL) /* Optional protection present */
  3697. #define HT_USE_PROTECTION(add_ie) (HT_HT20_PRESENT((add_ie)) || \
  3698. HT_MIXEDMODE_PRESENT((add_ie))) /* use protection */
  3699. #define HT_NONGF_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & HT_OPMODE_NONGF) \
  3700. == HT_OPMODE_NONGF) /* non-GF present */
  3701. #define DOT11N_TXBURST_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & DOT11N_TXBURST) \
  3702. == DOT11N_TXBURST) /* Tx Burst present */
  3703. #define DOT11N_OBSS_NONHT_PRESENT(add_ie) ((ltoh16_ua(&add_ie->opmode) & DOT11N_OBSS_NONHT) \
  3704. == DOT11N_OBSS_NONHT) /* OBSS Non-HT present */
  3705. #define HT_OPMODE_CCFS2_GET(add_ie) ((ltoh16_ua(&(add_ie)->opmode) & HT_OPMODE_CCFS2_MASK) \
  3706. >> HT_OPMODE_CCFS2_SHIFT) /* get CCFS2 */
  3707. #define HT_OPMODE_CCFS2_SET(add_ie, ccfs2) do { /* set CCFS2 */ \
  3708. (add_ie)->opmode &= htol16(~HT_OPMODE_CCFS2_MASK); \
  3709. (add_ie)->opmode |= htol16(((ccfs2) << HT_OPMODE_CCFS2_SHIFT) & HT_OPMODE_CCFS2_MASK); \
  3710. } while (0)
  3711. /* Macros for HT MCS field access */
  3712. #define HT_CAP_MCS_BITMASK(supp_mcs) \
  3713. ((supp_mcs)[HT_CAP_MCS_RX_8TO15_BYTE_OFFSET])
  3714. #define HT_CAP_MCS_TX_RX_UNEQUAL(supp_mcs) \
  3715. ((supp_mcs)[HT_CAP_MCS_FLAGS_SUPP_BYTE] & HT_CAP_MCS_FLAGS_TX_RX_UNEQUAL)
  3716. #define HT_CAP_MCS_TX_STREAM_SUPPORT(supp_mcs) \
  3717. ((supp_mcs)[HT_CAP_MCS_FLAGS_SUPP_BYTE] & HT_CAP_MCS_FLAGS_MAX_SPATIAL_STREAM_MASK)
  3718. BWL_PRE_PACKED_STRUCT struct obss_params {
  3719. uint16 passive_dwell;
  3720. uint16 active_dwell;
  3721. uint16 bss_widthscan_interval;
  3722. uint16 passive_total;
  3723. uint16 active_total;
  3724. uint16 chanwidth_transition_dly;
  3725. uint16 activity_threshold;
  3726. } BWL_POST_PACKED_STRUCT;
  3727. typedef struct obss_params obss_params_t;
  3728. BWL_PRE_PACKED_STRUCT struct dot11_obss_ie {
  3729. uint8 id;
  3730. uint8 len;
  3731. obss_params_t obss_params;
  3732. } BWL_POST_PACKED_STRUCT;
  3733. typedef struct dot11_obss_ie dot11_obss_ie_t;
  3734. #define DOT11_OBSS_SCAN_IE_LEN sizeof(obss_params_t) /* HT OBSS len (based on 802.11n d3.0) */
  3735. /* HT control field */
  3736. #define HT_CTRL_LA_TRQ 0x00000002 /* sounding request */
  3737. #define HT_CTRL_LA_MAI 0x0000003C /* MCS request or antenna selection indication */
  3738. #define HT_CTRL_LA_MAI_SHIFT 2
  3739. #define HT_CTRL_LA_MAI_MRQ 0x00000004 /* MCS request */
  3740. #define HT_CTRL_LA_MAI_MSI 0x00000038 /* MCS request sequence identifier */
  3741. #define HT_CTRL_LA_MFSI 0x000001C0 /* MFB sequence identifier */
  3742. #define HT_CTRL_LA_MFSI_SHIFT 6
  3743. #define HT_CTRL_LA_MFB_ASELC 0x0000FE00 /* MCS feedback, antenna selection command/data */
  3744. #define HT_CTRL_LA_MFB_ASELC_SH 9
  3745. #define HT_CTRL_LA_ASELC_CMD 0x00000C00 /* ASEL command */
  3746. #define HT_CTRL_LA_ASELC_DATA 0x0000F000 /* ASEL data */
  3747. #define HT_CTRL_CAL_POS 0x00030000 /* Calibration position */
  3748. #define HT_CTRL_CAL_SEQ 0x000C0000 /* Calibration sequence */
  3749. #define HT_CTRL_CSI_STEERING 0x00C00000 /* CSI/Steering */
  3750. #define HT_CTRL_CSI_STEER_SHIFT 22
  3751. #define HT_CTRL_CSI_STEER_NFB 0 /* no fedback required */
  3752. #define HT_CTRL_CSI_STEER_CSI 1 /* CSI, H matrix */
  3753. #define HT_CTRL_CSI_STEER_NCOM 2 /* non-compressed beamforming */
  3754. #define HT_CTRL_CSI_STEER_COM 3 /* compressed beamforming */
  3755. #define HT_CTRL_NDP_ANNOUNCE 0x01000000 /* NDP announcement */
  3756. #define HT_CTRL_AC_CONSTRAINT 0x40000000 /* AC Constraint */
  3757. #define HT_CTRL_RDG_MOREPPDU 0x80000000 /* RDG/More PPDU */
  3758. /* ************* VHT definitions. ************* */
  3759. /**
  3760. * VHT Capabilites IE (sec 8.4.2.160)
  3761. */
  3762. BWL_PRE_PACKED_STRUCT struct vht_cap_ie {
  3763. uint32 vht_cap_info;
  3764. /* supported MCS set - 64 bit field */
  3765. uint16 rx_mcs_map;
  3766. uint16 rx_max_rate;
  3767. uint16 tx_mcs_map;
  3768. uint16 tx_max_rate;
  3769. } BWL_POST_PACKED_STRUCT;
  3770. typedef struct vht_cap_ie vht_cap_ie_t;
  3771. /* 4B cap_info + 8B supp_mcs */
  3772. #define VHT_CAP_IE_LEN 12
  3773. /* VHT Capabilities Info field - 32bit - in VHT Cap IE */
  3774. #define VHT_CAP_INFO_MAX_MPDU_LEN_MASK 0x00000003
  3775. #define VHT_CAP_INFO_SUPP_CHAN_WIDTH_MASK 0x0000000c
  3776. #define VHT_CAP_INFO_LDPC 0x00000010
  3777. #define VHT_CAP_INFO_SGI_80MHZ 0x00000020
  3778. #define VHT_CAP_INFO_SGI_160MHZ 0x00000040
  3779. #define VHT_CAP_INFO_TX_STBC 0x00000080
  3780. #define VHT_CAP_INFO_RX_STBC_MASK 0x00000700
  3781. #define VHT_CAP_INFO_RX_STBC_SHIFT 8
  3782. #define VHT_CAP_INFO_SU_BEAMFMR 0x00000800
  3783. #define VHT_CAP_INFO_SU_BEAMFMEE 0x00001000
  3784. #define VHT_CAP_INFO_NUM_BMFMR_ANT_MASK 0x0000e000
  3785. #define VHT_CAP_INFO_NUM_BMFMR_ANT_SHIFT 13
  3786. #define VHT_CAP_INFO_NUM_SOUNDING_DIM_MASK 0x00070000
  3787. #define VHT_CAP_INFO_NUM_SOUNDING_DIM_SHIFT 16
  3788. #define VHT_CAP_INFO_MU_BEAMFMR 0x00080000
  3789. #define VHT_CAP_INFO_MU_BEAMFMEE 0x00100000
  3790. #define VHT_CAP_INFO_TXOPPS 0x00200000
  3791. #define VHT_CAP_INFO_HTCVHT 0x00400000
  3792. #define VHT_CAP_INFO_AMPDU_MAXLEN_EXP_MASK 0x03800000
  3793. #define VHT_CAP_INFO_AMPDU_MAXLEN_EXP_SHIFT 23
  3794. #define VHT_CAP_INFO_LINK_ADAPT_CAP_MASK 0x0c000000
  3795. #define VHT_CAP_INFO_LINK_ADAPT_CAP_SHIFT 26
  3796. #define VHT_CAP_INFO_EXT_NSS_BW_SUP_MASK 0xc0000000
  3797. #define VHT_CAP_INFO_EXT_NSS_BW_SUP_SHIFT 30
  3798. /* get Extended NSS BW Support passing vht cap info */
  3799. #define VHT_CAP_EXT_NSS_BW_SUP(cap_info) \
  3800. (((cap_info) & VHT_CAP_INFO_EXT_NSS_BW_SUP_MASK) >> VHT_CAP_INFO_EXT_NSS_BW_SUP_SHIFT)
  3801. /* VHT CAP INFO extended NSS BW support - refer to IEEE 802.11 REVmc D8.0 Figure 9-559 */
  3802. #define VHT_CAP_INFO_EXT_NSS_BW_HALF_160 1 /* 160MHz at half NSS CAP */
  3803. #define VHT_CAP_INFO_EXT_NSS_BW_HALF_160_80P80 2 /* 160 & 80p80 MHz at half NSS CAP */
  3804. /* VHT Supported MCS Set - 64-bit - in VHT Cap IE */
  3805. #define VHT_CAP_SUPP_MCS_RX_HIGHEST_RATE_MASK 0x1fff
  3806. #define VHT_CAP_SUPP_MCS_RX_HIGHEST_RATE_SHIFT 0
  3807. #define VHT_CAP_SUPP_CHAN_WIDTH_SHIFT 5
  3808. #define VHT_CAP_SUPP_MCS_TX_HIGHEST_RATE_MASK 0x1fff
  3809. #define VHT_CAP_SUPP_MCS_TX_HIGHEST_RATE_SHIFT 0
  3810. /* defines for field(s) in vht_cap_ie->rx_max_rate */
  3811. #define VHT_CAP_MAX_NSTS_MASK 0xe000
  3812. #define VHT_CAP_MAX_NSTS_SHIFT 13
  3813. /* defines for field(s) in vht_cap_ie->tx_max_rate */
  3814. #define VHT_CAP_EXT_NSS_BW_CAP 0x2000
  3815. #define VHT_CAP_MCS_MAP_0_7 0
  3816. #define VHT_CAP_MCS_MAP_0_8 1
  3817. #define VHT_CAP_MCS_MAP_0_9 2
  3818. #define VHT_CAP_MCS_MAP_NONE 3
  3819. #define VHT_CAP_MCS_MAP_S 2 /* num bits for 1-stream */
  3820. #define VHT_CAP_MCS_MAP_M 0x3 /* mask for 1-stream */
  3821. /* assumes VHT_CAP_MCS_MAP_NONE is 3 and 2 bits are used for encoding */
  3822. #define VHT_CAP_MCS_MAP_NONE_ALL 0xffff
  3823. /* VHT rates bitmap */
  3824. #define VHT_CAP_MCS_0_7_RATEMAP 0x00ff
  3825. #define VHT_CAP_MCS_0_8_RATEMAP 0x01ff
  3826. #define VHT_CAP_MCS_0_9_RATEMAP 0x03ff
  3827. #define VHT_CAP_MCS_FULL_RATEMAP VHT_CAP_MCS_0_9_RATEMAP
  3828. #define VHT_PROP_MCS_MAP_10_11 0
  3829. #define VHT_PROP_MCS_MAP_UNUSED1 1
  3830. #define VHT_PROP_MCS_MAP_UNUSED2 2
  3831. #define VHT_PROP_MCS_MAP_NONE 3
  3832. #define VHT_PROP_MCS_MAP_NONE_ALL 0xffff
  3833. /* VHT prop rates bitmap */
  3834. #define VHT_PROP_MCS_10_11_RATEMAP 0x0c00
  3835. #define VHT_PROP_MCS_FULL_RATEMAP VHT_PROP_MCS_10_11_RATEMAP
  3836. #if !defined(VHT_CAP_MCS_MAP_0_9_NSS3)
  3837. /* mcsmap with MCS0-9 for Nss = 3 */
  3838. #define VHT_CAP_MCS_MAP_0_9_NSS3 \
  3839. ((VHT_CAP_MCS_MAP_0_9 << VHT_MCS_MAP_GET_SS_IDX(1)) | \
  3840. (VHT_CAP_MCS_MAP_0_9 << VHT_MCS_MAP_GET_SS_IDX(2)) | \
  3841. (VHT_CAP_MCS_MAP_0_9 << VHT_MCS_MAP_GET_SS_IDX(3)))
  3842. #endif /* !VHT_CAP_MCS_MAP_0_9_NSS3 */
  3843. #define VHT_CAP_MCS_MAP_NSS_MAX 8
  3844. /* get mcsmap with given mcs for given nss streams */
  3845. #define VHT_CAP_MCS_MAP_CREATE(mcsmap, nss, mcs) \
  3846. do { \
  3847. int i; \
  3848. for (i = 1; i <= nss; i++) { \
  3849. VHT_MCS_MAP_SET_MCS_PER_SS(i, mcs, mcsmap); \
  3850. } \
  3851. } while (0)
  3852. /* Map the mcs code to mcs bit map */
  3853. #define VHT_MCS_CODE_TO_MCS_MAP(mcs_code) \
  3854. ((mcs_code == VHT_CAP_MCS_MAP_0_7) ? VHT_CAP_MCS_0_7_RATEMAP : \
  3855. (mcs_code == VHT_CAP_MCS_MAP_0_8) ? VHT_CAP_MCS_0_8_RATEMAP : \
  3856. (mcs_code == VHT_CAP_MCS_MAP_0_9) ? VHT_CAP_MCS_0_9_RATEMAP : 0)
  3857. #define VHT_PROP_MCS_CODE_TO_PROP_MCS_MAP(mcs_code) \
  3858. ((mcs_code == VHT_PROP_MCS_MAP_10_11) ? VHT_PROP_MCS_10_11_RATEMAP : 0)
  3859. /* Map the mcs bit map to mcs code */
  3860. #define VHT_MCS_MAP_TO_MCS_CODE(mcs_map) \
  3861. ((mcs_map == VHT_CAP_MCS_0_7_RATEMAP) ? VHT_CAP_MCS_MAP_0_7 : \
  3862. (mcs_map == VHT_CAP_MCS_0_8_RATEMAP) ? VHT_CAP_MCS_MAP_0_8 : \
  3863. (mcs_map == VHT_CAP_MCS_0_9_RATEMAP) ? VHT_CAP_MCS_MAP_0_9 : VHT_CAP_MCS_MAP_NONE)
  3864. #define VHT_PROP_MCS_MAP_TO_PROP_MCS_CODE(mcs_map) \
  3865. (((mcs_map & 0xc00) == 0xc00) ? VHT_PROP_MCS_MAP_10_11 : VHT_PROP_MCS_MAP_NONE)
  3866. /** VHT Capabilities Supported Channel Width */
  3867. typedef enum vht_cap_chan_width {
  3868. VHT_CAP_CHAN_WIDTH_SUPPORT_MANDATORY = 0x00,
  3869. VHT_CAP_CHAN_WIDTH_SUPPORT_160 = 0x04,
  3870. VHT_CAP_CHAN_WIDTH_SUPPORT_160_8080 = 0x08
  3871. } vht_cap_chan_width_t;
  3872. /** VHT Capabilities Supported max MPDU LEN (sec 8.4.2.160.2) */
  3873. typedef enum vht_cap_max_mpdu_len {
  3874. VHT_CAP_MPDU_MAX_4K = 0x00,
  3875. VHT_CAP_MPDU_MAX_8K = 0x01,
  3876. VHT_CAP_MPDU_MAX_11K = 0x02
  3877. } vht_cap_max_mpdu_len_t;
  3878. /* Maximum MPDU Length byte counts for the VHT Capabilities advertised limits */
  3879. #define VHT_MPDU_LIMIT_4K 3895
  3880. #define VHT_MPDU_LIMIT_8K 7991
  3881. #define VHT_MPDU_LIMIT_11K 11454
  3882. /**
  3883. * VHT Operation IE (sec 8.4.2.161)
  3884. */
  3885. BWL_PRE_PACKED_STRUCT struct vht_op_ie {
  3886. uint8 chan_width;
  3887. uint8 chan1;
  3888. uint8 chan2;
  3889. uint16 supp_mcs; /* same def as above in vht cap */
  3890. } BWL_POST_PACKED_STRUCT;
  3891. typedef struct vht_op_ie vht_op_ie_t;
  3892. /* 3B VHT Op info + 2B Basic MCS */
  3893. #define VHT_OP_IE_LEN 5
  3894. typedef enum vht_op_chan_width {
  3895. VHT_OP_CHAN_WIDTH_20_40 = 0,
  3896. VHT_OP_CHAN_WIDTH_80 = 1,
  3897. VHT_OP_CHAN_WIDTH_160 = 2, /* deprecated - IEEE 802.11 REVmc D8.0 Table 11-25 */
  3898. VHT_OP_CHAN_WIDTH_80_80 = 3 /* deprecated - IEEE 802.11 REVmc D8.0 Table 11-25 */
  3899. } vht_op_chan_width_t;
  3900. #define VHT_OP_INFO_LEN 3
  3901. /* AID length */
  3902. #define AID_IE_LEN 2
  3903. /**
  3904. * BRCM vht features IE header
  3905. * The header if the fixed part of the IE
  3906. * On the 5GHz band this is the entire IE,
  3907. * on 2.4GHz the VHT IEs as defined in the 802.11ac
  3908. * specification follows
  3909. *
  3910. *
  3911. * VHT features rates bitmap.
  3912. * Bit0: 5G MCS 0-9 BW 160MHz
  3913. * Bit1: 5G MCS 0-9 support BW 80MHz
  3914. * Bit2: 5G MCS 0-9 support BW 20MHz
  3915. * Bit3: 2.4G MCS 0-9 support BW 20MHz
  3916. * Bits:4-7 Reserved for future use
  3917. *
  3918. */
  3919. #define VHT_FEATURES_IE_TYPE 0x4
  3920. BWL_PRE_PACKED_STRUCT struct vht_features_ie_hdr {
  3921. uint8 oui[3];
  3922. uint8 type; /* type of this IE = 4 */
  3923. uint8 rate_mask; /* VHT rate mask */
  3924. } BWL_POST_PACKED_STRUCT;
  3925. typedef struct vht_features_ie_hdr vht_features_ie_hdr_t;
  3926. /* Def for rx & tx basic mcs maps - ea ss num has 2 bits of info */
  3927. #define VHT_MCS_MAP_GET_SS_IDX(nss) (((nss)-1) * VHT_CAP_MCS_MAP_S)
  3928. #define VHT_MCS_MAP_GET_MCS_PER_SS(nss, mcsMap) \
  3929. (((mcsMap) >> VHT_MCS_MAP_GET_SS_IDX(nss)) & VHT_CAP_MCS_MAP_M)
  3930. #define VHT_MCS_MAP_SET_MCS_PER_SS(nss, numMcs, mcsMap) \
  3931. do { \
  3932. (mcsMap) &= (~(VHT_CAP_MCS_MAP_M << VHT_MCS_MAP_GET_SS_IDX(nss))); \
  3933. (mcsMap) |= (((numMcs) & VHT_CAP_MCS_MAP_M) << VHT_MCS_MAP_GET_SS_IDX(nss)); \
  3934. } while (0)
  3935. #define VHT_MCS_SS_SUPPORTED(nss, mcsMap) \
  3936. (VHT_MCS_MAP_GET_MCS_PER_SS((nss), (mcsMap)) != VHT_CAP_MCS_MAP_NONE)
  3937. /* Get the max ss supported from the mcs map */
  3938. #define VHT_MAX_SS_SUPPORTED(mcsMap) \
  3939. VHT_MCS_SS_SUPPORTED(8, mcsMap) ? 8 : \
  3940. VHT_MCS_SS_SUPPORTED(7, mcsMap) ? 7 : \
  3941. VHT_MCS_SS_SUPPORTED(6, mcsMap) ? 6 : \
  3942. VHT_MCS_SS_SUPPORTED(5, mcsMap) ? 5 : \
  3943. VHT_MCS_SS_SUPPORTED(4, mcsMap) ? 4 : \
  3944. VHT_MCS_SS_SUPPORTED(3, mcsMap) ? 3 : \
  3945. VHT_MCS_SS_SUPPORTED(2, mcsMap) ? 2 : \
  3946. VHT_MCS_SS_SUPPORTED(1, mcsMap) ? 1 : 0
  3947. #ifdef IBSS_RMC
  3948. /* customer's OUI */
  3949. #define RMC_PROP_OUI "\x00\x16\x32"
  3950. #endif // endif
  3951. /* ************* WPA definitions. ************* */
  3952. #define WPA_OUI "\x00\x50\xF2" /* WPA OUI */
  3953. #define WPA_OUI_LEN 3 /* WPA OUI length */
  3954. #define WPA_OUI_TYPE 1
  3955. #define WPA_VERSION 1 /* WPA version */
  3956. #define WPA_VERSION_LEN 2 /* WPA version length */
  3957. /* ************* WPA2 definitions. ************* */
  3958. #define WPA2_OUI "\x00\x0F\xAC" /* WPA2 OUI */
  3959. #define WPA2_OUI_LEN 3 /* WPA2 OUI length */
  3960. #define WPA2_VERSION 1 /* WPA2 version */
  3961. #define WPA2_VERSION_LEN 2 /* WAP2 version length */
  3962. #define MAX_RSNE_SUPPORTED_VERSION WPA2_VERSION /* Max supported version */
  3963. /* ************* WPS definitions. ************* */
  3964. #define WPS_OUI "\x00\x50\xF2" /* WPS OUI */
  3965. #define WPS_OUI_LEN 3 /* WPS OUI length */
  3966. #define WPS_OUI_TYPE 4
  3967. /* ************* TPC definitions. ************* */
  3968. #define TPC_OUI "\x00\x50\xF2" /* TPC OUI */
  3969. #define TPC_OUI_LEN 3 /* TPC OUI length */
  3970. #define TPC_OUI_TYPE 8
  3971. #define WFA_OUI_TYPE_TPC 8 /* deprecated */
  3972. /* ************* WFA definitions. ************* */
  3973. #define WFA_OUI "\x50\x6F\x9A" /* WFA OUI */
  3974. #define WFA_OUI_LEN 3 /* WFA OUI length */
  3975. #define WFA_OUI_TYPE_P2P 9
  3976. #ifdef WL_LEGACY_P2P
  3977. #define APPLE_OUI "\x00\x17\xF2" /* MACOSX OUI */
  3978. #define APPLE_OUI_LEN 3
  3979. #define APPLE_OUI_TYPE_P2P 5
  3980. #endif /* WL_LEGACY_P2P */
  3981. #ifndef WL_LEGACY_P2P
  3982. #define P2P_OUI WFA_OUI
  3983. #define P2P_OUI_LEN WFA_OUI_LEN
  3984. #define P2P_OUI_TYPE WFA_OUI_TYPE_P2P
  3985. #else
  3986. #define P2P_OUI APPLE_OUI
  3987. #define P2P_OUI_LEN APPLE_OUI_LEN
  3988. #define P2P_OUI_TYPE APPLE_OUI_TYPE_P2P
  3989. #endif /* !WL_LEGACY_P2P */
  3990. #ifdef WLTDLS
  3991. #define WFA_OUI_TYPE_TPQ 4 /* WFD Tunneled Probe ReQuest */
  3992. #define WFA_OUI_TYPE_TPS 5 /* WFD Tunneled Probe ReSponse */
  3993. #define WFA_OUI_TYPE_WFD 10
  3994. #endif /* WTDLS */
  3995. #define WFA_OUI_TYPE_HS20 0x10
  3996. #define WFA_OUI_TYPE_OSEN 0x12
  3997. #define WFA_OUI_TYPE_NAN 0x13
  3998. #define WFA_OUI_TYPE_MBO 0x16
  3999. #define WFA_OUI_TYPE_MBO_OCE 0x16
  4000. /* RSN authenticated key managment suite */
  4001. #define RSN_AKM_NONE 0 /* None (IBSS) */
  4002. #define RSN_AKM_UNSPECIFIED 1 /* Over 802.1x */
  4003. #define RSN_AKM_PSK 2 /* Pre-shared Key */
  4004. #define RSN_AKM_FBT_1X 3 /* Fast Bss transition using 802.1X */
  4005. #define RSN_AKM_FBT_PSK 4 /* Fast Bss transition using Pre-shared Key */
  4006. /* RSN_AKM_MFP_1X and RSN_AKM_MFP_PSK are not used any more
  4007. * Just kept here to avoid build issue in BISON/CARIBOU branch
  4008. */
  4009. #define RSN_AKM_MFP_1X 5 /* SHA256 key derivation, using 802.1X */
  4010. #define RSN_AKM_MFP_PSK 6 /* SHA256 key derivation, using Pre-shared Key */
  4011. #define RSN_AKM_SHA256_1X 5 /* SHA256 key derivation, using 802.1X */
  4012. #define RSN_AKM_SHA256_PSK 6 /* SHA256 key derivation, using Pre-shared Key */
  4013. #define RSN_AKM_TPK 7 /* TPK(TDLS Peer Key) handshake */
  4014. #define RSN_AKM_SAE_PSK 8 /* AKM for SAE with 4-way handshake */
  4015. #define RSN_AKM_SAE_FBT 9 /* AKM for SAE with FBT */
  4016. #define RSN_AKM_SUITEB_SHA256_1X 11 /* Suite B SHA256 */
  4017. #define RSN_AKM_SUITEB_SHA384_1X 12 /* Suite B-192 SHA384 */
  4018. #define RSN_AKM_FBT_SHA384_1X 13 /* FBT SHA384 */
  4019. #define RSN_AKM_FILS_SHA256 14 /* SHA256 key derivation, using FILS */
  4020. #define RSN_AKM_FILS_SHA384 15 /* SHA384 key derivation, using FILS */
  4021. #define RSN_AKM_FBT_SHA256_FILS 16
  4022. #define RSN_AKM_FBT_SHA384_FILS 17
  4023. #define RSN_AKM_OWE 18 /* RFC 8110 OWE */
  4024. #define RSN_AKM_FBT_SHA384_PSK 19
  4025. #define RSN_AKM_PSK_SHA384 20
  4026. /* OSEN authenticated key managment suite */
  4027. #define OSEN_AKM_UNSPECIFIED RSN_AKM_UNSPECIFIED /* Over 802.1x */
  4028. /* Key related defines */
  4029. #define DOT11_MAX_DEFAULT_KEYS 4 /* number of default keys */
  4030. #define DOT11_MAX_IGTK_KEYS 2
  4031. #define DOT11_MAX_KEY_SIZE 32 /* max size of any key */
  4032. #define DOT11_MAX_IV_SIZE 16 /* max size of any IV */
  4033. #define DOT11_EXT_IV_FLAG (1<<5) /* flag to indicate IV is > 4 bytes */
  4034. #define DOT11_WPA_KEY_RSC_LEN 8 /* WPA RSC key len */
  4035. #define WEP1_KEY_SIZE 5 /* max size of any WEP key */
  4036. #define WEP1_KEY_HEX_SIZE 10 /* size of WEP key in hex. */
  4037. #define WEP128_KEY_SIZE 13 /* max size of any WEP key */
  4038. #define WEP128_KEY_HEX_SIZE 26 /* size of WEP key in hex. */
  4039. #define TKIP_MIC_SIZE 8 /* size of TKIP MIC */
  4040. #define TKIP_EOM_SIZE 7 /* max size of TKIP EOM */
  4041. #define TKIP_EOM_FLAG 0x5a /* TKIP EOM flag byte */
  4042. #define TKIP_KEY_SIZE 32 /* size of any TKIP key, includs MIC keys */
  4043. #define TKIP_TK_SIZE 16
  4044. #define TKIP_MIC_KEY_SIZE 8
  4045. #define TKIP_MIC_AUTH_TX 16 /* offset to Authenticator MIC TX key */
  4046. #define TKIP_MIC_AUTH_RX 24 /* offset to Authenticator MIC RX key */
  4047. #define TKIP_MIC_SUP_RX TKIP_MIC_AUTH_TX /* offset to Supplicant MIC RX key */
  4048. #define TKIP_MIC_SUP_TX TKIP_MIC_AUTH_RX /* offset to Supplicant MIC TX key */
  4049. #define AES_KEY_SIZE 16 /* size of AES key */
  4050. #define AES_MIC_SIZE 8 /* size of AES MIC */
  4051. #define BIP_KEY_SIZE 16 /* size of BIP key */
  4052. #define BIP_MIC_SIZE 8 /* sizeof BIP MIC */
  4053. #define AES_GCM_MIC_SIZE 16 /* size of MIC for 128-bit GCM - .11adD9 */
  4054. #define AES256_KEY_SIZE 32 /* size of AES 256 key - .11acD5 */
  4055. #define AES256_MIC_SIZE 16 /* size of MIC for 256 bit keys, incl BIP */
  4056. /* WCN */
  4057. #define WCN_OUI "\x00\x50\xf2" /* WCN OUI */
  4058. #define WCN_TYPE 4 /* WCN type */
  4059. #ifdef BCMWAPI_WPI
  4060. #define SMS4_KEY_LEN 16
  4061. #define SMS4_WPI_CBC_MAC_LEN 16
  4062. #endif // endif
  4063. /* 802.11r protocol definitions */
  4064. /** Mobility Domain IE */
  4065. BWL_PRE_PACKED_STRUCT struct dot11_mdid_ie {
  4066. uint8 id;
  4067. uint8 len; /* DOT11_MDID_IE_DATA_LEN (3) */
  4068. uint16 mdid; /* Mobility Domain Id */
  4069. uint8 cap;
  4070. } BWL_POST_PACKED_STRUCT;
  4071. typedef struct dot11_mdid_ie dot11_mdid_ie_t;
  4072. /* length of data portion of Mobility Domain IE */
  4073. #define DOT11_MDID_IE_DATA_LEN 3
  4074. #define DOT11_MDID_LEN 2
  4075. #define FBT_MDID_CAP_OVERDS 0x01 /* Fast Bss transition over the DS support */
  4076. #define FBT_MDID_CAP_RRP 0x02 /* Resource request protocol support */
  4077. /* Fast Bss Transition IE */
  4078. #ifdef FT_IE_VER_V2
  4079. typedef BWL_PRE_PACKED_STRUCT struct dot11_ft_ie_v2 {
  4080. uint8 id;
  4081. uint8 len;
  4082. uint16 mic_control;
  4083. /* dynamic offset to following mic[], anonce[], snonce[] */
  4084. } BWL_POST_PACKED_STRUCT dot11_ft_ie_v2;
  4085. typedef struct dot11_ft_ie_v2 dot11_ft_ie_t;
  4086. #else
  4087. BWL_PRE_PACKED_STRUCT struct dot11_ft_ie {
  4088. uint8 id;
  4089. uint8 len; /* At least equal to DOT11_FT_IE_FIXED_LEN (82) */
  4090. uint16 mic_control; /* Mic Control */
  4091. uint8 mic[16];
  4092. uint8 anonce[32];
  4093. uint8 snonce[32];
  4094. /* Optional sub-elements follow */
  4095. } BWL_POST_PACKED_STRUCT;
  4096. typedef struct dot11_ft_ie dot11_ft_ie_t;
  4097. /* Fixed length of data portion of Fast BSS Transition IE. There could be
  4098. * optional parameters, which if present, could raise the FT IE length to 255.
  4099. */
  4100. #define DOT11_FT_IE_FIXED_LEN 82
  4101. #endif /* FT_IE_VER_V2 */
  4102. #ifdef FT_IE_VER_V2
  4103. #define DOT11_FT_IE_LEN(mic_len) (sizeof(dot11_ft_ie_v2) + mic_len + EAPOL_WPA_KEY_NONCE_LEN *2)
  4104. #define FT_IE_MIC(pos) ((uint8 *)pos + sizeof(dot11_ft_ie_v2))
  4105. #define FT_IE_ANONCE(pos, mic_len) ((uint8 *)pos + sizeof(dot11_ft_ie_v2) + mic_len)
  4106. #define FT_IE_SNONCE(pos, mic_len) ((uint8 *)pos + sizeof(dot11_ft_ie_v2) + mic_len + \
  4107. EAPOL_WPA_KEY_NONCE_LEN)
  4108. #else
  4109. #define DOT11_FT_IE_LEN(mic_len) sizeof(dot11_ft_ie)
  4110. #define FT_IE_MIC(pos) ((uint8 *)&pos->mic)
  4111. #define FT_IE_ANONCE(pos, mic_len) ((uint8 *)&pos->anonce)
  4112. #define FT_IE_SNONCE(pos, mic_len) ((uint8 *)&pos->snonce)
  4113. #endif /* FT_IE_VER_V2 */
  4114. #define TIE_TYPE_RESERVED 0
  4115. #define TIE_TYPE_REASSOC_DEADLINE 1
  4116. #define TIE_TYPE_KEY_LIEFTIME 2
  4117. #define TIE_TYPE_ASSOC_COMEBACK 3
  4118. BWL_PRE_PACKED_STRUCT struct dot11_timeout_ie {
  4119. uint8 id;
  4120. uint8 len;
  4121. uint8 type; /* timeout interval type */
  4122. uint32 value; /* timeout interval value */
  4123. } BWL_POST_PACKED_STRUCT;
  4124. typedef struct dot11_timeout_ie dot11_timeout_ie_t;
  4125. /** GTK ie */
  4126. BWL_PRE_PACKED_STRUCT struct dot11_gtk_ie {
  4127. uint8 id;
  4128. uint8 len;
  4129. uint16 key_info;
  4130. uint8 key_len;
  4131. uint8 rsc[8];
  4132. uint8 data[1];
  4133. } BWL_POST_PACKED_STRUCT;
  4134. typedef struct dot11_gtk_ie dot11_gtk_ie_t;
  4135. /** Management MIC ie */
  4136. BWL_PRE_PACKED_STRUCT struct mmic_ie {
  4137. uint8 id; /* IE ID: DOT11_MNG_MMIE_ID */
  4138. uint8 len; /* IE length */
  4139. uint16 key_id; /* key id */
  4140. uint8 ipn[6]; /* ipn */
  4141. uint8 mic[16]; /* mic */
  4142. } BWL_POST_PACKED_STRUCT;
  4143. typedef struct mmic_ie mmic_ie_t;
  4144. /* 802.11r-2008, 11A.10.3 - RRB frame format */
  4145. BWL_PRE_PACKED_STRUCT struct dot11_ft_rrb_frame {
  4146. uint8 frame_type; /* 1 for RRB */
  4147. uint8 packet_type; /* 0 for Request 1 for Response */
  4148. uint16 len;
  4149. uint8 cur_ap_addr[ETHER_ADDR_LEN];
  4150. uint8 data[1]; /* IEs Received/Sent in FT Action Req/Resp Frame */
  4151. } BWL_POST_PACKED_STRUCT;
  4152. typedef struct dot11_ft_rrb_frame dot11_ft_rrb_frame_t;
  4153. #define DOT11_FT_RRB_FIXED_LEN 10
  4154. #define DOT11_FT_REMOTE_FRAME_TYPE 1
  4155. #define DOT11_FT_PACKET_REQ 0
  4156. #define DOT11_FT_PACKET_RESP 1
  4157. #define BSSID_INVALID "\x00\x00\x00\x00\x00\x00"
  4158. #define BSSID_BROADCAST "\xFF\xFF\xFF\xFF\xFF\xFF"
  4159. #ifdef BCMWAPI_WAI
  4160. #define WAPI_IE_MIN_LEN 20 /* WAPI IE min length */
  4161. #define WAPI_VERSION 1 /* WAPI version */
  4162. #define WAPI_VERSION_LEN 2 /* WAPI version length */
  4163. #define WAPI_OUI "\x00\x14\x72" /* WAPI OUI */
  4164. #define WAPI_OUI_LEN DOT11_OUI_LEN /* WAPI OUI length */
  4165. #endif /* BCMWAPI_WAI */
  4166. /* ************* WMM Parameter definitions. ************* */
  4167. #define WMM_OUI "\x00\x50\xF2" /* WNN OUI */
  4168. #define WMM_OUI_LEN 3 /* WMM OUI length */
  4169. #define WMM_OUI_TYPE 2 /* WMM OUT type */
  4170. #define WMM_VERSION 1
  4171. #define WMM_VERSION_LEN 1
  4172. /* WMM OUI subtype */
  4173. #define WMM_OUI_SUBTYPE_PARAMETER 1
  4174. #define WMM_PARAMETER_IE_LEN 24
  4175. /** Link Identifier Element */
  4176. BWL_PRE_PACKED_STRUCT struct link_id_ie {
  4177. uint8 id;
  4178. uint8 len;
  4179. struct ether_addr bssid;
  4180. struct ether_addr tdls_init_mac;
  4181. struct ether_addr tdls_resp_mac;
  4182. } BWL_POST_PACKED_STRUCT;
  4183. typedef struct link_id_ie link_id_ie_t;
  4184. #define TDLS_LINK_ID_IE_LEN 18u
  4185. /** Link Wakeup Schedule Element */
  4186. BWL_PRE_PACKED_STRUCT struct wakeup_sch_ie {
  4187. uint8 id;
  4188. uint8 len;
  4189. uint32 offset; /* in ms between TSF0 and start of 1st Awake Window */
  4190. uint32 interval; /* in ms bwtween the start of 2 Awake Windows */
  4191. uint32 awake_win_slots; /* in backof slots, duration of Awake Window */
  4192. uint32 max_wake_win; /* in ms, max duration of Awake Window */
  4193. uint16 idle_cnt; /* number of consecutive Awake Windows */
  4194. } BWL_POST_PACKED_STRUCT;
  4195. typedef struct wakeup_sch_ie wakeup_sch_ie_t;
  4196. #define TDLS_WAKEUP_SCH_IE_LEN 18
  4197. /** Channel Switch Timing Element */
  4198. BWL_PRE_PACKED_STRUCT struct channel_switch_timing_ie {
  4199. uint8 id;
  4200. uint8 len;
  4201. uint16 switch_time; /* in ms, time to switch channels */
  4202. uint16 switch_timeout; /* in ms */
  4203. } BWL_POST_PACKED_STRUCT;
  4204. typedef struct channel_switch_timing_ie channel_switch_timing_ie_t;
  4205. #define TDLS_CHANNEL_SWITCH_TIMING_IE_LEN 4
  4206. /** PTI Control Element */
  4207. BWL_PRE_PACKED_STRUCT struct pti_control_ie {
  4208. uint8 id;
  4209. uint8 len;
  4210. uint8 tid;
  4211. uint16 seq_control;
  4212. } BWL_POST_PACKED_STRUCT;
  4213. typedef struct pti_control_ie pti_control_ie_t;
  4214. #define TDLS_PTI_CONTROL_IE_LEN 3
  4215. /** PU Buffer Status Element */
  4216. BWL_PRE_PACKED_STRUCT struct pu_buffer_status_ie {
  4217. uint8 id;
  4218. uint8 len;
  4219. uint8 status;
  4220. } BWL_POST_PACKED_STRUCT;
  4221. typedef struct pu_buffer_status_ie pu_buffer_status_ie_t;
  4222. #define TDLS_PU_BUFFER_STATUS_IE_LEN 1
  4223. #define TDLS_PU_BUFFER_STATUS_AC_BK 1
  4224. #define TDLS_PU_BUFFER_STATUS_AC_BE 2
  4225. #define TDLS_PU_BUFFER_STATUS_AC_VI 4
  4226. #define TDLS_PU_BUFFER_STATUS_AC_VO 8
  4227. /* TDLS Action Field Values */
  4228. #define TDLS_SETUP_REQ 0
  4229. #define TDLS_SETUP_RESP 1
  4230. #define TDLS_SETUP_CONFIRM 2
  4231. #define TDLS_TEARDOWN 3
  4232. #define TDLS_PEER_TRAFFIC_IND 4
  4233. #define TDLS_CHANNEL_SWITCH_REQ 5
  4234. #define TDLS_CHANNEL_SWITCH_RESP 6
  4235. #define TDLS_PEER_PSM_REQ 7
  4236. #define TDLS_PEER_PSM_RESP 8
  4237. #define TDLS_PEER_TRAFFIC_RESP 9
  4238. #define TDLS_DISCOVERY_REQ 10
  4239. /* 802.11z TDLS Public Action Frame action field */
  4240. #define TDLS_DISCOVERY_RESP 14
  4241. /* 802.11u GAS action frames */
  4242. #define GAS_REQUEST_ACTION_FRAME 10
  4243. #define GAS_RESPONSE_ACTION_FRAME 11
  4244. #define GAS_COMEBACK_REQUEST_ACTION_FRAME 12
  4245. #define GAS_COMEBACK_RESPONSE_ACTION_FRAME 13
  4246. /* FTM - fine timing measurement public action frames */
  4247. BWL_PRE_PACKED_STRUCT struct dot11_ftm_req {
  4248. uint8 category; /* category of action frame (4) */
  4249. uint8 action; /* public action (32) */
  4250. uint8 trigger; /* trigger/continue? */
  4251. /* optional lci, civic loc, ftm params */
  4252. } BWL_POST_PACKED_STRUCT;
  4253. typedef struct dot11_ftm_req dot11_ftm_req_t;
  4254. BWL_PRE_PACKED_STRUCT struct dot11_ftm {
  4255. uint8 category; /* category of action frame (4) */
  4256. uint8 action; /* public action (33) */
  4257. uint8 dialog; /* dialog token */
  4258. uint8 follow_up; /* follow up dialog token */
  4259. uint8 tod[6]; /* t1 - last depart timestamp */
  4260. uint8 toa[6]; /* t4 - last ack arrival timestamp */
  4261. uint8 tod_err[2]; /* t1 error */
  4262. uint8 toa_err[2]; /* t4 error */
  4263. /* optional lci report, civic loc report, ftm params */
  4264. } BWL_POST_PACKED_STRUCT;
  4265. typedef struct dot11_ftm dot11_ftm_t;
  4266. #define DOT11_FTM_ERR_NOT_CONT_OFFSET 1
  4267. #define DOT11_FTM_ERR_NOT_CONT_MASK 0x80
  4268. #define DOT11_FTM_ERR_NOT_CONT_SHIFT 7
  4269. #define DOT11_FTM_ERR_NOT_CONT(_err) (((_err)[DOT11_FTM_ERR_NOT_CONT_OFFSET] & \
  4270. DOT11_FTM_ERR_NOT_CONT_MASK) >> DOT11_FTM_ERR_NOT_CONT_SHIFT)
  4271. #define DOT11_FTM_ERR_SET_NOT_CONT(_err, _val) do {\
  4272. uint8 _err2 = (_err)[DOT11_FTM_ERR_NOT_CONT_OFFSET]; \
  4273. _err2 &= ~DOT11_FTM_ERR_NOT_CONT_MASK; \
  4274. _err2 |= ((_val) << DOT11_FTM_ERR_NOT_CONT_SHIFT) & DOT11_FTM_ERR_NOT_CONT_MASK; \
  4275. (_err)[DOT11_FTM_ERR_NOT_CONT_OFFSET] = _err2; \
  4276. } while (0)
  4277. #define DOT11_FTM_ERR_MAX_ERR_OFFSET 0
  4278. #define DOT11_FTM_ERR_MAX_ERR_MASK 0x7fff
  4279. #define DOT11_FTM_ERR_MAX_ERR_SHIFT 0
  4280. #define DOT11_FTM_ERR_MAX_ERR(_err) (((((_err)[1] & 0x7f) << 8) | (_err)[0]))
  4281. #define DOT11_FTM_ERR_SET_MAX_ERR(_err, _val) do {\
  4282. uint16 _val2; \
  4283. uint16 _not_cont; \
  4284. _val2 = (((_val) & DOT11_FTM_ERR_MAX_ERR_MASK) << DOT11_FTM_ERR_MAX_ERR_SHIFT); \
  4285. _val2 = (_val2 > 0x3fff) ? 0 : _val2; /* not expecting > 16ns error */ \
  4286. _not_cont = DOT11_FTM_ERR_NOT_CONT(_err); \
  4287. (_err)[0] = _val2 & 0xff; \
  4288. (_err)[1] = (_val2 >> 8) & 0xff; \
  4289. DOT11_FTM_ERR_SET_NOT_CONT(_err, _not_cont); \
  4290. } while (0)
  4291. #if defined(DOT11_FTM_ERR_ROM_COMPAT)
  4292. /* incorrect defs - here for ROM compatibiity */
  4293. #undef DOT11_FTM_ERR_NOT_CONT_OFFSET
  4294. #undef DOT11_FTM_ERR_NOT_CONT_MASK
  4295. #undef DOT11_FTM_ERR_NOT_CONT_SHIFT
  4296. #undef DOT11_FTM_ERR_NOT_CONT
  4297. #undef DOT11_FTM_ERR_SET_NOT_CONT
  4298. #define DOT11_FTM_ERR_NOT_CONT_OFFSET 0
  4299. #define DOT11_FTM_ERR_NOT_CONT_MASK 0x0001
  4300. #define DOT11_FTM_ERR_NOT_CONT_SHIFT 0
  4301. #define DOT11_FTM_ERR_NOT_CONT(_err) (((_err)[DOT11_FTM_ERR_NOT_CONT_OFFSET] & \
  4302. DOT11_FTM_ERR_NOT_CONT_MASK) >> DOT11_FTM_ERR_NOT_CONT_SHIFT)
  4303. #define DOT11_FTM_ERR_SET_NOT_CONT(_err, _val) do {\
  4304. uint8 _err2 = (_err)[DOT11_FTM_ERR_NOT_CONT_OFFSET]; \
  4305. _err2 &= ~DOT11_FTM_ERR_NOT_CONT_MASK; \
  4306. _err2 |= ((_val) << DOT11_FTM_ERR_NOT_CONT_SHIFT) & DOT11_FTM_ERR_NOT_CONT_MASK; \
  4307. (_err)[DOT11_FTM_ERR_NOT_CONT_OFFSET] = _err2; \
  4308. } while (0)
  4309. #undef DOT11_FTM_ERR_MAX_ERR_OFFSET
  4310. #undef DOT11_FTM_ERR_MAX_ERR_MASK
  4311. #undef DOT11_FTM_ERR_MAX_ERR_SHIFT
  4312. #undef DOT11_FTM_ERR_MAX_ERR
  4313. #undef DOT11_FTM_ERR_SET_MAX_ERR
  4314. #define DOT11_FTM_ERR_MAX_ERR_OFFSET 0
  4315. #define DOT11_FTM_ERR_MAX_ERR_MASK 0xfff7
  4316. #define DOT11_FTM_ERR_MAX_ERR_SHIFT 1
  4317. #define DOT11_FTM_ERR_MAX_ERR(_err) ((((_err)[1] << 7) | (_err)[0]) >> 1)
  4318. #define DOT11_FTM_ERR_SET_MAX_ERR(_err, _val) do {\
  4319. uint16 _val2; \
  4320. _val2 = (((_val) << DOT11_FTM_ERR_MAX_ERR_SHIFT) |\
  4321. ((_err)[DOT11_FTM_ERR_NOT_CONT_OFFSET] & DOT11_FTM_ERR_NOT_CONT_MASK)); \
  4322. (_err)[0] = _val2 & 0xff; \
  4323. (_err)[1] = _val2 >> 8 & 0xff; \
  4324. } while (0)
  4325. #endif /* DOT11_FTM_ERR_ROM_COMPAT */
  4326. BWL_PRE_PACKED_STRUCT struct dot11_ftm_params {
  4327. uint8 id; /* DOT11_MNG_FTM_PARAM_ID 8.4.2.166 11mcd2.6/2014 - revisit */
  4328. uint8 len;
  4329. uint8 info[9];
  4330. } BWL_POST_PACKED_STRUCT;
  4331. typedef struct dot11_ftm_params dot11_ftm_params_t;
  4332. #define DOT11_FTM_PARAMS_IE_LEN (sizeof(dot11_ftm_params_t) - 2)
  4333. #define FTM_PARAMS_FIELD(_p, _off, _mask, _shift) (((_p)->info[(_off)] & (_mask)) >> (_shift))
  4334. #define FTM_PARAMS_SET_FIELD(_p, _off, _mask, _shift, _val) do {\
  4335. uint8 _ptmp = (_p)->info[_off] & ~(_mask); \
  4336. (_p)->info[(_off)] = _ptmp | (((_val) << (_shift)) & (_mask)); \
  4337. } while (0)
  4338. #define FTM_PARAMS_STATUS_OFFSET 0
  4339. #define FTM_PARAMS_STATUS_MASK 0x03
  4340. #define FTM_PARAMS_STATUS_SHIFT 0
  4341. #define FTM_PARAMS_STATUS(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_STATUS_OFFSET, \
  4342. FTM_PARAMS_STATUS_MASK, FTM_PARAMS_STATUS_SHIFT)
  4343. #define FTM_PARAMS_SET_STATUS(_p, _status) FTM_PARAMS_SET_FIELD(_p, \
  4344. FTM_PARAMS_STATUS_OFFSET, FTM_PARAMS_STATUS_MASK, FTM_PARAMS_STATUS_SHIFT, _status)
  4345. #define FTM_PARAMS_VALUE_OFFSET 0
  4346. #define FTM_PARAMS_VALUE_MASK 0x7c
  4347. #define FTM_PARAMS_VALUE_SHIFT 2
  4348. #define FTM_PARAMS_VALUE(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_VALUE_OFFSET, \
  4349. FTM_PARAMS_VALUE_MASK, FTM_PARAMS_VALUE_SHIFT)
  4350. #define FTM_PARAMS_SET_VALUE(_p, _value) FTM_PARAMS_SET_FIELD(_p, \
  4351. FTM_PARAMS_VALUE_OFFSET, FTM_PARAMS_VALUE_MASK, FTM_PARAMS_VALUE_SHIFT, _value)
  4352. #define FTM_PARAMS_MAX_VALUE 32
  4353. #define FTM_PARAMS_NBURSTEXP_OFFSET 1
  4354. #define FTM_PARAMS_NBURSTEXP_MASK 0x0f
  4355. #define FTM_PARAMS_NBURSTEXP_SHIFT 0
  4356. #define FTM_PARAMS_NBURSTEXP(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_NBURSTEXP_OFFSET, \
  4357. FTM_PARAMS_NBURSTEXP_MASK, FTM_PARAMS_NBURSTEXP_SHIFT)
  4358. #define FTM_PARAMS_SET_NBURSTEXP(_p, _bexp) FTM_PARAMS_SET_FIELD(_p, \
  4359. FTM_PARAMS_NBURSTEXP_OFFSET, FTM_PARAMS_NBURSTEXP_MASK, FTM_PARAMS_NBURSTEXP_SHIFT, \
  4360. _bexp)
  4361. #define FTM_PARAMS_NBURST(_p) (1 << FTM_PARAMS_NBURSTEXP(_p))
  4362. enum {
  4363. FTM_PARAMS_NBURSTEXP_NOPREF = 15
  4364. };
  4365. enum {
  4366. FTM_PARAMS_BURSTTMO_NOPREF = 15
  4367. };
  4368. #define FTM_PARAMS_BURSTTMO_OFFSET 1
  4369. #define FTM_PARAMS_BURSTTMO_MASK 0xf0
  4370. #define FTM_PARAMS_BURSTTMO_SHIFT 4
  4371. #define FTM_PARAMS_BURSTTMO(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_BURSTTMO_OFFSET, \
  4372. FTM_PARAMS_BURSTTMO_MASK, FTM_PARAMS_BURSTTMO_SHIFT)
  4373. /* set timeout in params using _tmo where timeout = 2^(_tmo) * 250us */
  4374. #define FTM_PARAMS_SET_BURSTTMO(_p, _tmo) FTM_PARAMS_SET_FIELD(_p, \
  4375. FTM_PARAMS_BURSTTMO_OFFSET, FTM_PARAMS_BURSTTMO_MASK, FTM_PARAMS_BURSTTMO_SHIFT, (_tmo)+2)
  4376. #define FTM_PARAMS_BURSTTMO_USEC(_val) ((1 << ((_val)-2)) * 250)
  4377. #define FTM_PARAMS_BURSTTMO_VALID(_val) ((((_val) < 12 && (_val) > 1)) || \
  4378. (_val) == FTM_PARAMS_BURSTTMO_NOPREF)
  4379. #define FTM_PARAMS_BURSTTMO_MAX_MSEC 128 /* 2^9 * 250us */
  4380. #define FTM_PARAMS_BURSTTMO_MAX_USEC 128000 /* 2^9 * 250us */
  4381. #define FTM_PARAMS_MINDELTA_OFFSET 2
  4382. #define FTM_PARAMS_MINDELTA_USEC(_p) ((_p)->info[FTM_PARAMS_MINDELTA_OFFSET] * 100)
  4383. #define FTM_PARAMS_SET_MINDELTA_USEC(_p, _delta) do { \
  4384. (_p)->info[FTM_PARAMS_MINDELTA_OFFSET] = (_delta) / 100; \
  4385. } while (0)
  4386. enum {
  4387. FTM_PARAMS_MINDELTA_NOPREF = 0
  4388. };
  4389. #define FTM_PARAMS_PARTIAL_TSF(_p) ((_p)->info[4] << 8 | (_p)->info[3])
  4390. #define FTM_PARAMS_SET_PARTIAL_TSF(_p, _partial_tsf) do { \
  4391. (_p)->info[3] = (_partial_tsf) & 0xff; \
  4392. (_p)->info[4] = ((_partial_tsf) >> 8) & 0xff; \
  4393. } while (0)
  4394. #define FTM_PARAMS_PARTIAL_TSF_MASK 0x0000000003fffc00ULL
  4395. #define FTM_PARAMS_PARTIAL_TSF_SHIFT 10
  4396. #define FTM_PARAMS_PARTIAL_TSF_BIT_LEN 16
  4397. #define FTM_PARAMS_PARTIAL_TSF_MAX 0xffff
  4398. /* FTM can indicate upto 62k TUs forward and 1k TU backward */
  4399. #define FTM_PARAMS_TSF_FW_HI (63487 << 10) /* in micro sec */
  4400. #define FTM_PARAMS_TSF_BW_LOW (64512 << 10) /* in micro sec */
  4401. #define FTM_PARAMS_TSF_BW_HI (65535 << 10) /* in micro sec */
  4402. #define FTM_PARAMS_TSF_FW_MAX FTM_PARAMS_TSF_FW_HI
  4403. #define FTM_PARAMS_TSF_BW_MAX (FTM_PARAMS_TSF_BW_HI - FTM_PARAMS_TSF_BW_LOW)
  4404. #define FTM_PARAMS_PTSFNOPREF_OFFSET 5
  4405. #define FTM_PARAMS_PTSFNOPREF_MASK 0x1
  4406. #define FTM_PARAMS_PTSFNOPREF_SHIFT 0
  4407. #define FTM_PARAMS_PTSFNOPREF(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_PTSFNOPREF_OFFSET, \
  4408. FTM_PARAMS_PTSFNOPREF_MASK, FTM_PARAMS_PTSFNOPREF_SHIFT)
  4409. #define FTM_PARAMS_SET_PTSFNOPREF(_p, _nopref) FTM_PARAMS_SET_FIELD(_p, \
  4410. FTM_PARAMS_PTSFNOPREF_OFFSET, FTM_PARAMS_PTSFNOPREF_MASK, \
  4411. FTM_PARAMS_PTSFNOPREF_SHIFT, _nopref)
  4412. #define FTM_PARAMS_ASAP_OFFSET 5
  4413. #define FTM_PARAMS_ASAP_MASK 0x4
  4414. #define FTM_PARAMS_ASAP_SHIFT 2
  4415. #define FTM_PARAMS_ASAP(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_ASAP_OFFSET, \
  4416. FTM_PARAMS_ASAP_MASK, FTM_PARAMS_ASAP_SHIFT)
  4417. #define FTM_PARAMS_SET_ASAP(_p, _asap) FTM_PARAMS_SET_FIELD(_p, \
  4418. FTM_PARAMS_ASAP_OFFSET, FTM_PARAMS_ASAP_MASK, FTM_PARAMS_ASAP_SHIFT, _asap)
  4419. /* FTM1 - AKA ASAP Capable */
  4420. #define FTM_PARAMS_FTM1_OFFSET 5
  4421. #define FTM_PARAMS_FTM1_MASK 0x02
  4422. #define FTM_PARAMS_FTM1_SHIFT 1
  4423. #define FTM_PARAMS_FTM1(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_FTM1_OFFSET, \
  4424. FTM_PARAMS_FTM1_MASK, FTM_PARAMS_FTM1_SHIFT)
  4425. #define FTM_PARAMS_SET_FTM1(_p, _ftm1) FTM_PARAMS_SET_FIELD(_p, \
  4426. FTM_PARAMS_FTM1_OFFSET, FTM_PARAMS_FTM1_MASK, FTM_PARAMS_FTM1_SHIFT, _ftm1)
  4427. #define FTM_PARAMS_FTMS_PER_BURST_OFFSET 5
  4428. #define FTM_PARAMS_FTMS_PER_BURST_MASK 0xf8
  4429. #define FTM_PARAMS_FTMS_PER_BURST_SHIFT 3
  4430. #define FTM_PARAMS_FTMS_PER_BURST(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_FTMS_PER_BURST_OFFSET, \
  4431. FTM_PARAMS_FTMS_PER_BURST_MASK, FTM_PARAMS_FTMS_PER_BURST_SHIFT)
  4432. #define FTM_PARAMS_SET_FTMS_PER_BURST(_p, _nftms) FTM_PARAMS_SET_FIELD(_p, \
  4433. FTM_PARAMS_FTMS_PER_BURST_OFFSET, FTM_PARAMS_FTMS_PER_BURST_MASK, \
  4434. FTM_PARAMS_FTMS_PER_BURST_SHIFT, _nftms)
  4435. enum {
  4436. FTM_PARAMS_FTMS_PER_BURST_NOPREF = 0
  4437. };
  4438. #define FTM_PARAMS_CHAN_INFO_OFFSET 6
  4439. #define FTM_PARAMS_CHAN_INFO_MASK 0xfc
  4440. #define FTM_PARAMS_CHAN_INFO_SHIFT 2
  4441. #define FTM_PARAMS_CHAN_INFO(_p) FTM_PARAMS_FIELD(_p, FTM_PARAMS_CHAN_INFO_OFFSET, \
  4442. FTM_PARAMS_CHAN_INFO_MASK, FTM_PARAMS_CHAN_INFO_SHIFT)
  4443. #define FTM_PARAMS_SET_CHAN_INFO(_p, _ci) FTM_PARAMS_SET_FIELD(_p, \
  4444. FTM_PARAMS_CHAN_INFO_OFFSET, FTM_PARAMS_CHAN_INFO_MASK, FTM_PARAMS_CHAN_INFO_SHIFT, _ci)
  4445. /* burst period - units of 100ms */
  4446. #define FTM_PARAMS_BURST_PERIOD(_p) (((_p)->info[8] << 8) | (_p)->info[7])
  4447. #define FTM_PARAMS_SET_BURST_PERIOD(_p, _bp) do {\
  4448. (_p)->info[7] = (_bp) & 0xff; \
  4449. (_p)->info[8] = ((_bp) >> 8) & 0xff; \
  4450. } while (0)
  4451. #define FTM_PARAMS_BURST_PERIOD_MS(_p) (FTM_PARAMS_BURST_PERIOD(_p) * 100)
  4452. enum {
  4453. FTM_PARAMS_BURST_PERIOD_NOPREF = 0
  4454. };
  4455. /* FTM status values - last updated from 11mcD4.0 */
  4456. enum {
  4457. FTM_PARAMS_STATUS_RESERVED = 0,
  4458. FTM_PARAMS_STATUS_SUCCESSFUL = 1,
  4459. FTM_PARAMS_STATUS_INCAPABLE = 2,
  4460. FTM_PARAMS_STATUS_FAILED = 3,
  4461. /* Below are obsolte */
  4462. FTM_PARAMS_STATUS_OVERRIDDEN = 4,
  4463. FTM_PARAMS_STATUS_ASAP_INCAPABLE = 5,
  4464. FTM_PARAMS_STATUS_ASAP_FAILED = 6,
  4465. /* rest are reserved */
  4466. };
  4467. enum {
  4468. FTM_PARAMS_CHAN_INFO_NO_PREF = 0,
  4469. FTM_PARAMS_CHAN_INFO_RESERVE1 = 1,
  4470. FTM_PARAMS_CHAN_INFO_RESERVE2 = 2,
  4471. FTM_PARAMS_CHAN_INFO_RESERVE3 = 3,
  4472. FTM_PARAMS_CHAN_INFO_NON_HT_5 = 4,
  4473. FTM_PARAMS_CHAN_INFO_RESERVE5 = 5,
  4474. FTM_PARAMS_CHAN_INFO_NON_HT_10 = 6,
  4475. FTM_PARAMS_CHAN_INFO_RESERVE7 = 7,
  4476. FTM_PARAMS_CHAN_INFO_NON_HT_20 = 8, /* excludes 2.4G, and High rate DSSS */
  4477. FTM_PARAMS_CHAN_INFO_HT_MF_20 = 9,
  4478. FTM_PARAMS_CHAN_INFO_VHT_20 = 10,
  4479. FTM_PARAMS_CHAN_INFO_HT_MF_40 = 11,
  4480. FTM_PARAMS_CHAN_INFO_VHT_40 = 12,
  4481. FTM_PARAMS_CHAN_INFO_VHT_80 = 13,
  4482. FTM_PARAMS_CHAN_INFO_VHT_80_80 = 14,
  4483. FTM_PARAMS_CHAN_INFO_VHT_160_2_RFLOS = 15,
  4484. FTM_PARAMS_CHAN_INFO_VHT_160 = 16,
  4485. /* Reserved from 17 - 30 */
  4486. FTM_PARAMS_CHAN_INFO_DMG_2160 = 31,
  4487. /* Reserved from 32 - 63 */
  4488. FTM_PARAMS_CHAN_INFO_MAX = 63
  4489. };
  4490. /* tag_ID/length/value_buffer tuple */
  4491. typedef BWL_PRE_PACKED_STRUCT struct {
  4492. uint8 id;
  4493. uint8 len;
  4494. uint8 data[1];
  4495. } BWL_POST_PACKED_STRUCT ftm_vs_tlv_t;
  4496. BWL_PRE_PACKED_STRUCT struct dot11_ftm_vs_ie {
  4497. uint8 id; /* DOT11_MNG_VS_ID */
  4498. uint8 len; /* length following */
  4499. uint8 oui[3]; /* BRCM_PROP_OUI (or Customer) */
  4500. uint8 sub_type; /* BRCM_FTM_IE_TYPE (or Customer) */
  4501. uint8 version;
  4502. ftm_vs_tlv_t tlvs[1];
  4503. } BWL_POST_PACKED_STRUCT;
  4504. typedef struct dot11_ftm_vs_ie dot11_ftm_vs_ie_t;
  4505. /* same as payload of dot11_ftm_vs_ie.
  4506. * This definition helps in having struct access
  4507. * of pay load while building FTM VS IE from other modules(NAN)
  4508. */
  4509. BWL_PRE_PACKED_STRUCT struct dot11_ftm_vs_ie_pyld {
  4510. uint8 sub_type; /* BRCM_FTM_IE_TYPE (or Customer) */
  4511. uint8 version;
  4512. ftm_vs_tlv_t tlvs[1];
  4513. } BWL_POST_PACKED_STRUCT;
  4514. typedef struct dot11_ftm_vs_ie_pyld dot11_ftm_vs_ie_pyld_t;
  4515. /* ftm vs api version */
  4516. #define BCM_FTM_VS_PARAMS_VERSION 0x01
  4517. /* ftm vendor specific information tlv types */
  4518. enum {
  4519. FTM_VS_TLV_NONE = 0,
  4520. FTM_VS_TLV_REQ_PARAMS = 1, /* additional request params (in FTM_REQ) */
  4521. FTM_VS_TLV_MEAS_INFO = 2, /* measurement information (in FTM_MEAS) */
  4522. FTM_VS_TLV_SEC_PARAMS = 3, /* security parameters (in either) */
  4523. FTM_VS_TLV_SEQ_PARAMS = 4, /* toast parameters (FTM_REQ, BRCM proprietary) */
  4524. FTM_VS_TLV_MF_BUF = 5, /* multi frame buffer - may span ftm vs ie's */
  4525. FTM_VS_TLV_TIMING_PARAMS = 6, /* timing adjustments */
  4526. FTM_VS_TLV_MF_STATS_BUF = 7 /* multi frame statistics buffer */
  4527. /* add additional types above */
  4528. };
  4529. /* the following definitions are *DEPRECATED* and moved to implemenetion files. They
  4530. * are retained here because previous (May 2016) some branches use them
  4531. */
  4532. #define FTM_TPK_LEN 16
  4533. #define FTM_RI_RR_BUF_LEN 32
  4534. #define FTM_TPK_RI_RR_LEN 13
  4535. #define FTM_TPK_RI_RR_LEN_SECURE_2_0 28
  4536. #define FTM_TPK_DIGEST_LEN 32
  4537. #define FTM_TPK_BUFFER_LEN 128
  4538. #define FTM_TPK_RI_PHY_LEN 7
  4539. #define FTM_TPK_RR_PHY_LEN 7
  4540. #define FTM_TPK_DATA_BUFFER_LEN 88
  4541. #define FTM_TPK_LEN_SECURE_2_0 32
  4542. #define FTM_TPK_RI_PHY_LEN_SECURE_2_0 14
  4543. #define FTM_TPK_RR_PHY_LEN_SECURE_2_0 14
  4544. BWL_PRE_PACKED_STRUCT struct dot11_ftm_vs_params {
  4545. uint8 id; /* DOT11_MNG_VS_ID */
  4546. uint8 len;
  4547. uint8 oui[3]; /* Proprietary OUI, BRCM_PROP_OUI */
  4548. uint8 bcm_vs_id;
  4549. ftm_vs_tlv_t ftm_tpk_ri_rr[1]; /* ftm_TPK_ri_rr place holder */
  4550. } BWL_POST_PACKED_STRUCT;
  4551. typedef struct dot11_ftm_vs_params dot11_ftm_vs_tpk_ri_rr_params_t;
  4552. #define DOT11_FTM_VS_LEN (sizeof(dot11_ftm_vs_tpk_ri_rr_params_t) - TLV_HDR_LEN)
  4553. /* end *DEPRECATED* ftm definitions */
  4554. BWL_PRE_PACKED_STRUCT struct dot11_ftm_sync_info {
  4555. uint8 id; /* Extended - 255 11mc D4.3 */
  4556. uint8 len;
  4557. uint8 id_ext;
  4558. uint8 tsf_sync_info[4];
  4559. } BWL_POST_PACKED_STRUCT;
  4560. typedef struct dot11_ftm_sync_info dot11_ftm_sync_info_t;
  4561. /* ftm tsf sync info ie len - includes id ext */
  4562. #define DOT11_FTM_SYNC_INFO_IE_LEN (sizeof(dot11_ftm_sync_info_t) - TLV_HDR_LEN)
  4563. #define DOT11_FTM_IS_SYNC_INFO_IE(_ie) (\
  4564. DOT11_MNG_IE_ID_EXT_MATCH(_ie, DOT11_MNG_FTM_SYNC_INFO) && \
  4565. (_ie)->len == DOT11_FTM_SYNC_INFO_IE_LEN)
  4566. BWL_PRE_PACKED_STRUCT struct dot11_dh_param_ie {
  4567. uint8 id; /* OWE */
  4568. uint8 len;
  4569. uint8 ext_id; /* EXT_MNG_OWE_DH_PARAM_ID */
  4570. uint16 group;
  4571. uint8 pub_key[0];
  4572. } BWL_POST_PACKED_STRUCT;
  4573. typedef struct dot11_dh_param_ie dot11_dh_param_ie_t;
  4574. #define DOT11_DH_EXTID_OFFSET (OFFSETOF(dot11_dh_param_ie_t, ext_id))
  4575. #define DOT11_OWE_DH_PARAM_IE(_ie) (\
  4576. DOT11_MNG_IE_ID_EXT_MATCH(_ie, EXT_MNG_OWE_DH_PARAM_ID))
  4577. #define DOT11_MNG_OWE_IE_ID_EXT_INIT(_ie, _id, _len) do {\
  4578. (_ie)->id = DOT11_MNG_ID_EXT_ID; \
  4579. (_ie)->len = _len; \
  4580. (_ie)->ext_id = _id; \
  4581. } while (0)
  4582. /* 802.11u interworking access network options */
  4583. #define IW_ANT_MASK 0x0f
  4584. #define IW_INTERNET_MASK 0x10
  4585. #define IW_ASRA_MASK 0x20
  4586. #define IW_ESR_MASK 0x40
  4587. #define IW_UESA_MASK 0x80
  4588. /* 802.11u interworking access network type */
  4589. #define IW_ANT_PRIVATE_NETWORK 0
  4590. #define IW_ANT_PRIVATE_NETWORK_WITH_GUEST 1
  4591. #define IW_ANT_CHARGEABLE_PUBLIC_NETWORK 2
  4592. #define IW_ANT_FREE_PUBLIC_NETWORK 3
  4593. #define IW_ANT_PERSONAL_DEVICE_NETWORK 4
  4594. #define IW_ANT_EMERGENCY_SERVICES_NETWORK 5
  4595. #define IW_ANT_TEST_NETWORK 14
  4596. #define IW_ANT_WILDCARD_NETWORK 15
  4597. #define IW_ANT_LEN 1
  4598. #define IW_VENUE_LEN 2
  4599. #define IW_HESSID_LEN 6
  4600. #define IW_HESSID_OFF (IW_ANT_LEN + IW_VENUE_LEN)
  4601. #define IW_MAX_LEN (IW_ANT_LEN + IW_VENUE_LEN + IW_HESSID_LEN)
  4602. /* 802.11u advertisement protocol */
  4603. #define ADVP_ANQP_PROTOCOL_ID 0
  4604. #define ADVP_MIH_PROTOCOL_ID 1
  4605. /* 802.11u advertisement protocol masks */
  4606. #define ADVP_QRL_MASK 0x7f
  4607. #define ADVP_PAME_BI_MASK 0x80
  4608. /* 802.11u advertisement protocol values */
  4609. #define ADVP_QRL_REQUEST 0x00
  4610. #define ADVP_QRL_RESPONSE 0x7f
  4611. #define ADVP_PAME_BI_DEPENDENT 0x00
  4612. #define ADVP_PAME_BI_INDEPENDENT ADVP_PAME_BI_MASK
  4613. /* 802.11u ANQP information ID */
  4614. #define ANQP_ID_QUERY_LIST 256
  4615. #define ANQP_ID_CAPABILITY_LIST 257
  4616. #define ANQP_ID_VENUE_NAME_INFO 258
  4617. #define ANQP_ID_EMERGENCY_CALL_NUMBER_INFO 259
  4618. #define ANQP_ID_NETWORK_AUTHENTICATION_TYPE_INFO 260
  4619. #define ANQP_ID_ROAMING_CONSORTIUM_LIST 261
  4620. #define ANQP_ID_IP_ADDRESS_TYPE_AVAILABILITY_INFO 262
  4621. #define ANQP_ID_NAI_REALM_LIST 263
  4622. #define ANQP_ID_G3PP_CELLULAR_NETWORK_INFO 264
  4623. #define ANQP_ID_AP_GEOSPATIAL_LOCATION 265
  4624. #define ANQP_ID_AP_CIVIC_LOCATION 266
  4625. #define ANQP_ID_AP_LOCATION_PUBLIC_ID_URI 267
  4626. #define ANQP_ID_DOMAIN_NAME_LIST 268
  4627. #define ANQP_ID_EMERGENCY_ALERT_ID_URI 269
  4628. #define ANQP_ID_EMERGENCY_NAI 271
  4629. #define ANQP_ID_NEIGHBOR_REPORT 272
  4630. #define ANQP_ID_VENDOR_SPECIFIC_LIST 56797
  4631. /* 802.11u ANQP ID len */
  4632. #define ANQP_INFORMATION_ID_LEN 2
  4633. /* 802.11u ANQP OUI */
  4634. #define ANQP_OUI_SUBTYPE 9
  4635. /* 802.11u venue name */
  4636. #define VENUE_LANGUAGE_CODE_SIZE 3
  4637. #define VENUE_NAME_SIZE 255
  4638. /* 802.11u venue groups */
  4639. #define VENUE_UNSPECIFIED 0
  4640. #define VENUE_ASSEMBLY 1
  4641. #define VENUE_BUSINESS 2
  4642. #define VENUE_EDUCATIONAL 3
  4643. #define VENUE_FACTORY 4
  4644. #define VENUE_INSTITUTIONAL 5
  4645. #define VENUE_MERCANTILE 6
  4646. #define VENUE_RESIDENTIAL 7
  4647. #define VENUE_STORAGE 8
  4648. #define VENUE_UTILITY 9
  4649. #define VENUE_VEHICULAR 10
  4650. #define VENUE_OUTDOOR 11
  4651. /* 802.11u network authentication type indicator */
  4652. #define NATI_UNSPECIFIED -1
  4653. #define NATI_ACCEPTANCE_OF_TERMS_CONDITIONS 0
  4654. #define NATI_ONLINE_ENROLLMENT_SUPPORTED 1
  4655. #define NATI_HTTP_HTTPS_REDIRECTION 2
  4656. #define NATI_DNS_REDIRECTION 3
  4657. /* 802.11u IP address type availability - IPv6 */
  4658. #define IPA_IPV6_SHIFT 0
  4659. #define IPA_IPV6_MASK (0x03 << IPA_IPV6_SHIFT)
  4660. #define IPA_IPV6_NOT_AVAILABLE 0x00
  4661. #define IPA_IPV6_AVAILABLE 0x01
  4662. #define IPA_IPV6_UNKNOWN_AVAILABILITY 0x02
  4663. /* 802.11u IP address type availability - IPv4 */
  4664. #define IPA_IPV4_SHIFT 2
  4665. #define IPA_IPV4_MASK (0x3f << IPA_IPV4_SHIFT)
  4666. #define IPA_IPV4_NOT_AVAILABLE 0x00
  4667. #define IPA_IPV4_PUBLIC 0x01
  4668. #define IPA_IPV4_PORT_RESTRICT 0x02
  4669. #define IPA_IPV4_SINGLE_NAT 0x03
  4670. #define IPA_IPV4_DOUBLE_NAT 0x04
  4671. #define IPA_IPV4_PORT_RESTRICT_SINGLE_NAT 0x05
  4672. #define IPA_IPV4_PORT_RESTRICT_DOUBLE_NAT 0x06
  4673. #define IPA_IPV4_UNKNOWN_AVAILABILITY 0x07
  4674. /* 802.11u NAI realm encoding */
  4675. #define REALM_ENCODING_RFC4282 0
  4676. #define REALM_ENCODING_UTF8 1
  4677. /* 802.11u IANA EAP method type numbers */
  4678. #define REALM_EAP_TLS 13
  4679. #define REALM_EAP_LEAP 17
  4680. #define REALM_EAP_SIM 18
  4681. #define REALM_EAP_TTLS 21
  4682. #define REALM_EAP_AKA 23
  4683. #define REALM_EAP_PEAP 25
  4684. #define REALM_EAP_FAST 43
  4685. #define REALM_EAP_PSK 47
  4686. #define REALM_EAP_AKAP 50
  4687. #define REALM_EAP_EXPANDED 254
  4688. /* 802.11u authentication ID */
  4689. #define REALM_EXPANDED_EAP 1
  4690. #define REALM_NON_EAP_INNER_AUTHENTICATION 2
  4691. #define REALM_INNER_AUTHENTICATION_EAP 3
  4692. #define REALM_EXPANDED_INNER_EAP 4
  4693. #define REALM_CREDENTIAL 5
  4694. #define REALM_TUNNELED_EAP_CREDENTIAL 6
  4695. #define REALM_VENDOR_SPECIFIC_EAP 221
  4696. /* 802.11u non-EAP inner authentication type */
  4697. #define REALM_RESERVED_AUTH 0
  4698. #define REALM_PAP 1
  4699. #define REALM_CHAP 2
  4700. #define REALM_MSCHAP 3
  4701. #define REALM_MSCHAPV2 4
  4702. /* 802.11u credential type */
  4703. #define REALM_SIM 1
  4704. #define REALM_USIM 2
  4705. #define REALM_NFC 3
  4706. #define REALM_HARDWARE_TOKEN 4
  4707. #define REALM_SOFTOKEN 5
  4708. #define REALM_CERTIFICATE 6
  4709. #define REALM_USERNAME_PASSWORD 7
  4710. #define REALM_SERVER_SIDE 8
  4711. #define REALM_RESERVED_CRED 9
  4712. #define REALM_VENDOR_SPECIFIC_CRED 10
  4713. /* 802.11u 3GPP PLMN */
  4714. #define G3PP_GUD_VERSION 0
  4715. #define G3PP_PLMN_LIST_IE 0
  4716. /* AP Location Public ID Info encoding */
  4717. #define PUBLIC_ID_URI_FQDN_SE_ID 0
  4718. /* URI/FQDN Descriptor field values */
  4719. #define LOCATION_ENCODING_HELD 1
  4720. #define LOCATION_ENCODING_SUPL 2
  4721. #define URI_FQDN_SIZE 255
  4722. /** hotspot2.0 indication element (vendor specific) */
  4723. BWL_PRE_PACKED_STRUCT struct hs20_ie {
  4724. uint8 oui[3];
  4725. uint8 type;
  4726. uint8 config;
  4727. } BWL_POST_PACKED_STRUCT;
  4728. typedef struct hs20_ie hs20_ie_t;
  4729. #define HS20_IE_LEN 5 /* HS20 IE length */
  4730. /** IEEE 802.11 Annex E */
  4731. typedef enum {
  4732. DOT11_2GHZ_20MHZ_CLASS_12 = 81, /* Ch 1-11 */
  4733. DOT11_5GHZ_20MHZ_CLASS_1 = 115, /* Ch 36-48 */
  4734. DOT11_5GHZ_20MHZ_CLASS_2_DFS = 118, /* Ch 52-64 */
  4735. DOT11_5GHZ_20MHZ_CLASS_3 = 124, /* Ch 149-161 */
  4736. DOT11_5GHZ_20MHZ_CLASS_4_DFS = 121, /* Ch 100-140 */
  4737. DOT11_5GHZ_20MHZ_CLASS_5 = 125, /* Ch 149-165 */
  4738. DOT11_5GHZ_40MHZ_CLASS_22 = 116, /* Ch 36-44, lower */
  4739. DOT11_5GHZ_40MHZ_CLASS_23_DFS = 119, /* Ch 52-60, lower */
  4740. DOT11_5GHZ_40MHZ_CLASS_24_DFS = 122, /* Ch 100-132, lower */
  4741. DOT11_5GHZ_40MHZ_CLASS_25 = 126, /* Ch 149-157, lower */
  4742. DOT11_5GHZ_40MHZ_CLASS_27 = 117, /* Ch 40-48, upper */
  4743. DOT11_5GHZ_40MHZ_CLASS_28_DFS = 120, /* Ch 56-64, upper */
  4744. DOT11_5GHZ_40MHZ_CLASS_29_DFS = 123, /* Ch 104-136, upper */
  4745. DOT11_5GHZ_40MHZ_CLASS_30 = 127, /* Ch 153-161, upper */
  4746. DOT11_2GHZ_40MHZ_CLASS_32 = 83, /* Ch 1-7, lower */
  4747. DOT11_2GHZ_40MHZ_CLASS_33 = 84, /* Ch 5-11, upper */
  4748. } dot11_op_class_t;
  4749. /* QoS map */
  4750. #define QOS_MAP_FIXED_LENGTH (8 * 2) /* DSCP ranges fixed with 8 entries */
  4751. #define BCM_AIBSS_IE_TYPE 56
  4752. #define SSE_OUI "\x00\x00\xF0"
  4753. #define VENDOR_ENTERPRISE_STA_OUI_TYPE 0x22
  4754. #define MAX_VSIE_DISASSOC (1)
  4755. #define DISCO_VSIE_LEN 0x09u
  4756. /* This marks the end of a packed structure section. */
  4757. #include <packed_section_end.h>
  4758. #endif /* _802_11_H_ */