spectrum_switchdev.c 115 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194
  1. // SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0
  2. /* Copyright (c) 2015-2018 Mellanox Technologies. All rights reserved */
  3. #include <linux/kernel.h>
  4. #include <linux/types.h>
  5. #include <linux/netdevice.h>
  6. #include <linux/etherdevice.h>
  7. #include <linux/slab.h>
  8. #include <linux/device.h>
  9. #include <linux/skbuff.h>
  10. #include <linux/if_vlan.h>
  11. #include <linux/if_bridge.h>
  12. #include <linux/workqueue.h>
  13. #include <linux/jiffies.h>
  14. #include <linux/rtnetlink.h>
  15. #include <linux/netlink.h>
  16. #include <net/switchdev.h>
  17. #include <net/vxlan.h>
  18. #include "spectrum_span.h"
  19. #include "spectrum_switchdev.h"
  20. #include "spectrum.h"
  21. #include "core.h"
  22. #include "reg.h"
  23. struct mlxsw_sp_bridge_ops;
  24. struct mlxsw_sp_bridge {
  25. struct mlxsw_sp *mlxsw_sp;
  26. struct {
  27. struct delayed_work dw;
  28. #define MLXSW_SP_DEFAULT_LEARNING_INTERVAL 100
  29. unsigned int interval; /* ms */
  30. } fdb_notify;
  31. #define MLXSW_SP_MIN_AGEING_TIME 10
  32. #define MLXSW_SP_MAX_AGEING_TIME 1000000
  33. #define MLXSW_SP_DEFAULT_AGEING_TIME 300
  34. u32 ageing_time;
  35. bool vlan_enabled_exists;
  36. struct list_head bridges_list;
  37. DECLARE_BITMAP(mids_bitmap, MLXSW_SP_MID_MAX);
  38. const struct mlxsw_sp_bridge_ops *bridge_8021q_ops;
  39. const struct mlxsw_sp_bridge_ops *bridge_8021d_ops;
  40. const struct mlxsw_sp_bridge_ops *bridge_8021ad_ops;
  41. };
  42. struct mlxsw_sp_bridge_device {
  43. struct net_device *dev;
  44. struct list_head list;
  45. struct list_head ports_list;
  46. struct list_head mdb_list;
  47. struct rhashtable mdb_ht;
  48. u8 vlan_enabled:1,
  49. multicast_enabled:1,
  50. mrouter:1;
  51. const struct mlxsw_sp_bridge_ops *ops;
  52. };
  53. struct mlxsw_sp_bridge_port {
  54. struct net_device *dev;
  55. struct mlxsw_sp_bridge_device *bridge_device;
  56. struct list_head list;
  57. struct list_head vlans_list;
  58. refcount_t ref_count;
  59. u8 stp_state;
  60. unsigned long flags;
  61. bool mrouter;
  62. bool lagged;
  63. union {
  64. u16 lag_id;
  65. u16 system_port;
  66. };
  67. };
  68. struct mlxsw_sp_bridge_vlan {
  69. struct list_head list;
  70. struct list_head port_vlan_list;
  71. u16 vid;
  72. };
  73. struct mlxsw_sp_bridge_ops {
  74. int (*port_join)(struct mlxsw_sp_bridge_device *bridge_device,
  75. struct mlxsw_sp_bridge_port *bridge_port,
  76. struct mlxsw_sp_port *mlxsw_sp_port,
  77. struct netlink_ext_ack *extack);
  78. void (*port_leave)(struct mlxsw_sp_bridge_device *bridge_device,
  79. struct mlxsw_sp_bridge_port *bridge_port,
  80. struct mlxsw_sp_port *mlxsw_sp_port);
  81. int (*vxlan_join)(struct mlxsw_sp_bridge_device *bridge_device,
  82. const struct net_device *vxlan_dev, u16 vid,
  83. struct netlink_ext_ack *extack);
  84. struct mlxsw_sp_fid *
  85. (*fid_get)(struct mlxsw_sp_bridge_device *bridge_device,
  86. u16 vid, struct netlink_ext_ack *extack);
  87. struct mlxsw_sp_fid *
  88. (*fid_lookup)(struct mlxsw_sp_bridge_device *bridge_device,
  89. u16 vid);
  90. u16 (*fid_vid)(struct mlxsw_sp_bridge_device *bridge_device,
  91. const struct mlxsw_sp_fid *fid);
  92. };
  93. struct mlxsw_sp_switchdev_ops {
  94. void (*init)(struct mlxsw_sp *mlxsw_sp);
  95. };
  96. struct mlxsw_sp_mdb_entry_key {
  97. unsigned char addr[ETH_ALEN];
  98. u16 fid;
  99. };
  100. struct mlxsw_sp_mdb_entry {
  101. struct list_head list;
  102. struct rhash_head ht_node;
  103. struct mlxsw_sp_mdb_entry_key key;
  104. u16 mid;
  105. struct list_head ports_list;
  106. u16 ports_count;
  107. };
  108. struct mlxsw_sp_mdb_entry_port {
  109. struct list_head list; /* Member of 'ports_list'. */
  110. u16 local_port;
  111. refcount_t refcount;
  112. bool mrouter;
  113. };
  114. static const struct rhashtable_params mlxsw_sp_mdb_ht_params = {
  115. .key_offset = offsetof(struct mlxsw_sp_mdb_entry, key),
  116. .head_offset = offsetof(struct mlxsw_sp_mdb_entry, ht_node),
  117. .key_len = sizeof(struct mlxsw_sp_mdb_entry_key),
  118. };
  119. static int
  120. mlxsw_sp_bridge_port_fdb_flush(struct mlxsw_sp *mlxsw_sp,
  121. struct mlxsw_sp_bridge_port *bridge_port,
  122. u16 fid_index);
  123. static void
  124. mlxsw_sp_bridge_port_mdb_flush(struct mlxsw_sp_port *mlxsw_sp_port,
  125. struct mlxsw_sp_bridge_port *bridge_port,
  126. u16 fid_index);
  127. static int
  128. mlxsw_sp_bridge_mdb_mc_enable_sync(struct mlxsw_sp *mlxsw_sp,
  129. struct mlxsw_sp_bridge_device
  130. *bridge_device, bool mc_enabled);
  131. static void
  132. mlxsw_sp_port_mrouter_update_mdb(struct mlxsw_sp_port *mlxsw_sp_port,
  133. struct mlxsw_sp_bridge_port *bridge_port,
  134. bool add);
  135. static struct mlxsw_sp_bridge_device *
  136. mlxsw_sp_bridge_device_find(const struct mlxsw_sp_bridge *bridge,
  137. const struct net_device *br_dev)
  138. {
  139. struct mlxsw_sp_bridge_device *bridge_device;
  140. list_for_each_entry(bridge_device, &bridge->bridges_list, list)
  141. if (bridge_device->dev == br_dev)
  142. return bridge_device;
  143. return NULL;
  144. }
  145. bool mlxsw_sp_bridge_device_is_offloaded(const struct mlxsw_sp *mlxsw_sp,
  146. const struct net_device *br_dev)
  147. {
  148. return !!mlxsw_sp_bridge_device_find(mlxsw_sp->bridge, br_dev);
  149. }
  150. static int mlxsw_sp_bridge_device_upper_rif_destroy(struct net_device *dev,
  151. struct netdev_nested_priv *priv)
  152. {
  153. struct mlxsw_sp *mlxsw_sp = priv->data;
  154. mlxsw_sp_rif_destroy_by_dev(mlxsw_sp, dev);
  155. return 0;
  156. }
  157. static void mlxsw_sp_bridge_device_rifs_destroy(struct mlxsw_sp *mlxsw_sp,
  158. struct net_device *dev)
  159. {
  160. struct netdev_nested_priv priv = {
  161. .data = (void *)mlxsw_sp,
  162. };
  163. mlxsw_sp_rif_destroy_by_dev(mlxsw_sp, dev);
  164. netdev_walk_all_upper_dev_rcu(dev,
  165. mlxsw_sp_bridge_device_upper_rif_destroy,
  166. &priv);
  167. }
  168. static int mlxsw_sp_bridge_device_vxlan_init(struct mlxsw_sp_bridge *bridge,
  169. struct net_device *br_dev,
  170. struct netlink_ext_ack *extack)
  171. {
  172. struct net_device *dev, *stop_dev;
  173. struct list_head *iter;
  174. int err;
  175. netdev_for_each_lower_dev(br_dev, dev, iter) {
  176. if (netif_is_vxlan(dev) && netif_running(dev)) {
  177. err = mlxsw_sp_bridge_vxlan_join(bridge->mlxsw_sp,
  178. br_dev, dev, 0,
  179. extack);
  180. if (err) {
  181. stop_dev = dev;
  182. goto err_vxlan_join;
  183. }
  184. }
  185. }
  186. return 0;
  187. err_vxlan_join:
  188. netdev_for_each_lower_dev(br_dev, dev, iter) {
  189. if (netif_is_vxlan(dev) && netif_running(dev)) {
  190. if (stop_dev == dev)
  191. break;
  192. mlxsw_sp_bridge_vxlan_leave(bridge->mlxsw_sp, dev);
  193. }
  194. }
  195. return err;
  196. }
  197. static void mlxsw_sp_bridge_device_vxlan_fini(struct mlxsw_sp_bridge *bridge,
  198. struct net_device *br_dev)
  199. {
  200. struct net_device *dev;
  201. struct list_head *iter;
  202. netdev_for_each_lower_dev(br_dev, dev, iter) {
  203. if (netif_is_vxlan(dev) && netif_running(dev))
  204. mlxsw_sp_bridge_vxlan_leave(bridge->mlxsw_sp, dev);
  205. }
  206. }
  207. static void mlxsw_sp_fdb_notify_work_schedule(struct mlxsw_sp *mlxsw_sp,
  208. bool no_delay)
  209. {
  210. struct mlxsw_sp_bridge *bridge = mlxsw_sp->bridge;
  211. unsigned int interval = no_delay ? 0 : bridge->fdb_notify.interval;
  212. mlxsw_core_schedule_dw(&bridge->fdb_notify.dw,
  213. msecs_to_jiffies(interval));
  214. }
  215. static struct mlxsw_sp_bridge_device *
  216. mlxsw_sp_bridge_device_create(struct mlxsw_sp_bridge *bridge,
  217. struct net_device *br_dev,
  218. struct netlink_ext_ack *extack)
  219. {
  220. struct device *dev = bridge->mlxsw_sp->bus_info->dev;
  221. struct mlxsw_sp_bridge_device *bridge_device;
  222. bool vlan_enabled = br_vlan_enabled(br_dev);
  223. int err;
  224. if (vlan_enabled && bridge->vlan_enabled_exists) {
  225. dev_err(dev, "Only one VLAN-aware bridge is supported\n");
  226. NL_SET_ERR_MSG_MOD(extack, "Only one VLAN-aware bridge is supported");
  227. return ERR_PTR(-EINVAL);
  228. }
  229. bridge_device = kzalloc_obj(*bridge_device);
  230. if (!bridge_device)
  231. return ERR_PTR(-ENOMEM);
  232. err = rhashtable_init(&bridge_device->mdb_ht, &mlxsw_sp_mdb_ht_params);
  233. if (err)
  234. goto err_mdb_rhashtable_init;
  235. bridge_device->dev = br_dev;
  236. bridge_device->vlan_enabled = vlan_enabled;
  237. bridge_device->multicast_enabled = br_multicast_enabled(br_dev);
  238. bridge_device->mrouter = br_multicast_router(br_dev);
  239. INIT_LIST_HEAD(&bridge_device->ports_list);
  240. if (vlan_enabled) {
  241. u16 proto;
  242. bridge->vlan_enabled_exists = true;
  243. br_vlan_get_proto(br_dev, &proto);
  244. if (proto == ETH_P_8021AD)
  245. bridge_device->ops = bridge->bridge_8021ad_ops;
  246. else
  247. bridge_device->ops = bridge->bridge_8021q_ops;
  248. } else {
  249. bridge_device->ops = bridge->bridge_8021d_ops;
  250. }
  251. INIT_LIST_HEAD(&bridge_device->mdb_list);
  252. if (list_empty(&bridge->bridges_list))
  253. mlxsw_sp_fdb_notify_work_schedule(bridge->mlxsw_sp, false);
  254. list_add(&bridge_device->list, &bridge->bridges_list);
  255. /* It is possible we already have VXLAN devices enslaved to the bridge.
  256. * In which case, we need to replay their configuration as if they were
  257. * just now enslaved to the bridge.
  258. */
  259. err = mlxsw_sp_bridge_device_vxlan_init(bridge, br_dev, extack);
  260. if (err)
  261. goto err_vxlan_init;
  262. return bridge_device;
  263. err_vxlan_init:
  264. list_del(&bridge_device->list);
  265. if (bridge_device->vlan_enabled)
  266. bridge->vlan_enabled_exists = false;
  267. rhashtable_destroy(&bridge_device->mdb_ht);
  268. err_mdb_rhashtable_init:
  269. kfree(bridge_device);
  270. return ERR_PTR(err);
  271. }
  272. static void
  273. mlxsw_sp_bridge_device_destroy(struct mlxsw_sp_bridge *bridge,
  274. struct mlxsw_sp_bridge_device *bridge_device)
  275. {
  276. mlxsw_sp_bridge_device_vxlan_fini(bridge, bridge_device->dev);
  277. mlxsw_sp_bridge_device_rifs_destroy(bridge->mlxsw_sp,
  278. bridge_device->dev);
  279. list_del(&bridge_device->list);
  280. if (list_empty(&bridge->bridges_list))
  281. cancel_delayed_work(&bridge->fdb_notify.dw);
  282. if (bridge_device->vlan_enabled)
  283. bridge->vlan_enabled_exists = false;
  284. WARN_ON(!list_empty(&bridge_device->ports_list));
  285. WARN_ON(!list_empty(&bridge_device->mdb_list));
  286. rhashtable_destroy(&bridge_device->mdb_ht);
  287. kfree(bridge_device);
  288. }
  289. static struct mlxsw_sp_bridge_device *
  290. mlxsw_sp_bridge_device_get(struct mlxsw_sp_bridge *bridge,
  291. struct net_device *br_dev,
  292. struct netlink_ext_ack *extack)
  293. {
  294. struct mlxsw_sp_bridge_device *bridge_device;
  295. bridge_device = mlxsw_sp_bridge_device_find(bridge, br_dev);
  296. if (bridge_device)
  297. return bridge_device;
  298. return mlxsw_sp_bridge_device_create(bridge, br_dev, extack);
  299. }
  300. static void
  301. mlxsw_sp_bridge_device_put(struct mlxsw_sp_bridge *bridge,
  302. struct mlxsw_sp_bridge_device *bridge_device)
  303. {
  304. if (list_empty(&bridge_device->ports_list))
  305. mlxsw_sp_bridge_device_destroy(bridge, bridge_device);
  306. }
  307. static struct mlxsw_sp_bridge_port *
  308. __mlxsw_sp_bridge_port_find(const struct mlxsw_sp_bridge_device *bridge_device,
  309. const struct net_device *brport_dev)
  310. {
  311. struct mlxsw_sp_bridge_port *bridge_port;
  312. list_for_each_entry(bridge_port, &bridge_device->ports_list, list) {
  313. if (bridge_port->dev == brport_dev)
  314. return bridge_port;
  315. }
  316. return NULL;
  317. }
  318. struct mlxsw_sp_bridge_port *
  319. mlxsw_sp_bridge_port_find(struct mlxsw_sp_bridge *bridge,
  320. struct net_device *brport_dev)
  321. {
  322. struct net_device *br_dev = netdev_master_upper_dev_get(brport_dev);
  323. struct mlxsw_sp_bridge_device *bridge_device;
  324. if (!br_dev)
  325. return NULL;
  326. bridge_device = mlxsw_sp_bridge_device_find(bridge, br_dev);
  327. if (!bridge_device)
  328. return NULL;
  329. return __mlxsw_sp_bridge_port_find(bridge_device, brport_dev);
  330. }
  331. static int mlxsw_sp_port_obj_add(struct net_device *dev, const void *ctx,
  332. const struct switchdev_obj *obj,
  333. struct netlink_ext_ack *extack);
  334. static int mlxsw_sp_port_obj_del(struct net_device *dev, const void *ctx,
  335. const struct switchdev_obj *obj);
  336. struct mlxsw_sp_bridge_port_replay_switchdev_objs {
  337. struct net_device *brport_dev;
  338. struct mlxsw_sp_port *mlxsw_sp_port;
  339. int done;
  340. };
  341. static int
  342. mlxsw_sp_bridge_port_replay_switchdev_objs(struct notifier_block *nb,
  343. unsigned long event, void *ptr)
  344. {
  345. struct net_device *dev = switchdev_notifier_info_to_dev(ptr);
  346. struct switchdev_notifier_port_obj_info *port_obj_info = ptr;
  347. struct netlink_ext_ack *extack = port_obj_info->info.extack;
  348. struct mlxsw_sp_bridge_port_replay_switchdev_objs *rso;
  349. int err = 0;
  350. rso = (void *)port_obj_info->info.ctx;
  351. if (event != SWITCHDEV_PORT_OBJ_ADD ||
  352. dev != rso->brport_dev)
  353. goto out;
  354. /* When a port is joining the bridge through a LAG, there likely are
  355. * VLANs configured on that LAG already. The replay will thus attempt to
  356. * have the given port-vlans join the corresponding FIDs. But the LAG
  357. * netdevice has already called the ndo_vlan_rx_add_vid NDO for its VLAN
  358. * memberships, back before CHANGEUPPER was distributed and netdevice
  359. * master set. So now before propagating the VLAN events further, we
  360. * first need to kill the corresponding VID at the mlxsw_sp_port.
  361. *
  362. * Note that this doesn't need to be rolled back on failure -- if the
  363. * replay fails, the enslavement is off, and the VIDs would be killed by
  364. * LAG anyway as part of its rollback.
  365. */
  366. if (port_obj_info->obj->id == SWITCHDEV_OBJ_ID_PORT_VLAN) {
  367. u16 vid = SWITCHDEV_OBJ_PORT_VLAN(port_obj_info->obj)->vid;
  368. err = mlxsw_sp_port_kill_vid(rso->mlxsw_sp_port->dev, 0, vid);
  369. if (err)
  370. goto out;
  371. }
  372. ++rso->done;
  373. err = mlxsw_sp_port_obj_add(rso->mlxsw_sp_port->dev, NULL,
  374. port_obj_info->obj, extack);
  375. out:
  376. return notifier_from_errno(err);
  377. }
  378. static struct notifier_block mlxsw_sp_bridge_port_replay_switchdev_objs_nb = {
  379. .notifier_call = mlxsw_sp_bridge_port_replay_switchdev_objs,
  380. };
  381. static int
  382. mlxsw_sp_bridge_port_unreplay_switchdev_objs(struct notifier_block *nb,
  383. unsigned long event, void *ptr)
  384. {
  385. struct net_device *dev = switchdev_notifier_info_to_dev(ptr);
  386. struct switchdev_notifier_port_obj_info *port_obj_info = ptr;
  387. struct mlxsw_sp_bridge_port_replay_switchdev_objs *rso;
  388. rso = (void *)port_obj_info->info.ctx;
  389. if (event != SWITCHDEV_PORT_OBJ_ADD ||
  390. dev != rso->brport_dev)
  391. return NOTIFY_DONE;
  392. if (!rso->done--)
  393. return NOTIFY_STOP;
  394. mlxsw_sp_port_obj_del(rso->mlxsw_sp_port->dev, NULL,
  395. port_obj_info->obj);
  396. return NOTIFY_DONE;
  397. }
  398. static struct notifier_block mlxsw_sp_bridge_port_unreplay_switchdev_objs_nb = {
  399. .notifier_call = mlxsw_sp_bridge_port_unreplay_switchdev_objs,
  400. };
  401. static struct mlxsw_sp_bridge_port *
  402. mlxsw_sp_bridge_port_create(struct mlxsw_sp_bridge_device *bridge_device,
  403. struct net_device *brport_dev,
  404. struct netlink_ext_ack *extack)
  405. {
  406. struct mlxsw_sp_bridge_port *bridge_port;
  407. struct mlxsw_sp_port *mlxsw_sp_port;
  408. int err;
  409. bridge_port = kzalloc_obj(*bridge_port);
  410. if (!bridge_port)
  411. return ERR_PTR(-ENOMEM);
  412. mlxsw_sp_port = mlxsw_sp_port_dev_lower_find(brport_dev);
  413. bridge_port->lagged = mlxsw_sp_port->lagged;
  414. if (bridge_port->lagged)
  415. bridge_port->lag_id = mlxsw_sp_port->lag_id;
  416. else
  417. bridge_port->system_port = mlxsw_sp_port->local_port;
  418. bridge_port->dev = brport_dev;
  419. bridge_port->bridge_device = bridge_device;
  420. bridge_port->stp_state = br_port_get_stp_state(brport_dev);
  421. bridge_port->flags = BR_LEARNING | BR_FLOOD | BR_LEARNING_SYNC |
  422. BR_MCAST_FLOOD;
  423. INIT_LIST_HEAD(&bridge_port->vlans_list);
  424. list_add(&bridge_port->list, &bridge_device->ports_list);
  425. refcount_set(&bridge_port->ref_count, 1);
  426. err = switchdev_bridge_port_offload(brport_dev, mlxsw_sp_port->dev,
  427. NULL, NULL, NULL, false, extack);
  428. if (err)
  429. goto err_switchdev_offload;
  430. return bridge_port;
  431. err_switchdev_offload:
  432. list_del(&bridge_port->list);
  433. kfree(bridge_port);
  434. return ERR_PTR(err);
  435. }
  436. static void
  437. mlxsw_sp_bridge_port_destroy(struct mlxsw_sp_bridge_port *bridge_port)
  438. {
  439. switchdev_bridge_port_unoffload(bridge_port->dev, NULL, NULL, NULL);
  440. list_del(&bridge_port->list);
  441. WARN_ON(!list_empty(&bridge_port->vlans_list));
  442. kfree(bridge_port);
  443. }
  444. static struct mlxsw_sp_bridge_port *
  445. mlxsw_sp_bridge_port_get(struct mlxsw_sp_bridge *bridge,
  446. struct net_device *brport_dev,
  447. struct netlink_ext_ack *extack)
  448. {
  449. struct net_device *br_dev = netdev_master_upper_dev_get(brport_dev);
  450. struct mlxsw_sp_bridge_device *bridge_device;
  451. struct mlxsw_sp_bridge_port *bridge_port;
  452. int err;
  453. bridge_port = mlxsw_sp_bridge_port_find(bridge, brport_dev);
  454. if (bridge_port) {
  455. refcount_inc(&bridge_port->ref_count);
  456. return bridge_port;
  457. }
  458. bridge_device = mlxsw_sp_bridge_device_get(bridge, br_dev, extack);
  459. if (IS_ERR(bridge_device))
  460. return ERR_CAST(bridge_device);
  461. bridge_port = mlxsw_sp_bridge_port_create(bridge_device, brport_dev,
  462. extack);
  463. if (IS_ERR(bridge_port)) {
  464. err = PTR_ERR(bridge_port);
  465. goto err_bridge_port_create;
  466. }
  467. return bridge_port;
  468. err_bridge_port_create:
  469. mlxsw_sp_bridge_device_put(bridge, bridge_device);
  470. return ERR_PTR(err);
  471. }
  472. static void mlxsw_sp_bridge_port_put(struct mlxsw_sp_bridge *bridge,
  473. struct mlxsw_sp_bridge_port *bridge_port)
  474. {
  475. struct mlxsw_sp_bridge_device *bridge_device;
  476. if (!refcount_dec_and_test(&bridge_port->ref_count))
  477. return;
  478. bridge_device = bridge_port->bridge_device;
  479. mlxsw_sp_bridge_port_destroy(bridge_port);
  480. mlxsw_sp_bridge_device_put(bridge, bridge_device);
  481. }
  482. static struct mlxsw_sp_port_vlan *
  483. mlxsw_sp_port_vlan_find_by_bridge(struct mlxsw_sp_port *mlxsw_sp_port,
  484. const struct mlxsw_sp_bridge_device *
  485. bridge_device,
  486. u16 vid)
  487. {
  488. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  489. list_for_each_entry(mlxsw_sp_port_vlan, &mlxsw_sp_port->vlans_list,
  490. list) {
  491. if (!mlxsw_sp_port_vlan->bridge_port)
  492. continue;
  493. if (mlxsw_sp_port_vlan->bridge_port->bridge_device !=
  494. bridge_device)
  495. continue;
  496. if (bridge_device->vlan_enabled &&
  497. mlxsw_sp_port_vlan->vid != vid)
  498. continue;
  499. return mlxsw_sp_port_vlan;
  500. }
  501. return NULL;
  502. }
  503. static struct mlxsw_sp_port_vlan*
  504. mlxsw_sp_port_vlan_find_by_fid(struct mlxsw_sp_port *mlxsw_sp_port,
  505. u16 fid_index)
  506. {
  507. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  508. list_for_each_entry(mlxsw_sp_port_vlan, &mlxsw_sp_port->vlans_list,
  509. list) {
  510. struct mlxsw_sp_fid *fid = mlxsw_sp_port_vlan->fid;
  511. if (fid && mlxsw_sp_fid_index(fid) == fid_index)
  512. return mlxsw_sp_port_vlan;
  513. }
  514. return NULL;
  515. }
  516. static struct mlxsw_sp_bridge_vlan *
  517. mlxsw_sp_bridge_vlan_find(const struct mlxsw_sp_bridge_port *bridge_port,
  518. u16 vid)
  519. {
  520. struct mlxsw_sp_bridge_vlan *bridge_vlan;
  521. list_for_each_entry(bridge_vlan, &bridge_port->vlans_list, list) {
  522. if (bridge_vlan->vid == vid)
  523. return bridge_vlan;
  524. }
  525. return NULL;
  526. }
  527. static struct mlxsw_sp_bridge_vlan *
  528. mlxsw_sp_bridge_vlan_create(struct mlxsw_sp_bridge_port *bridge_port, u16 vid)
  529. {
  530. struct mlxsw_sp_bridge_vlan *bridge_vlan;
  531. bridge_vlan = kzalloc_obj(*bridge_vlan);
  532. if (!bridge_vlan)
  533. return NULL;
  534. INIT_LIST_HEAD(&bridge_vlan->port_vlan_list);
  535. bridge_vlan->vid = vid;
  536. list_add(&bridge_vlan->list, &bridge_port->vlans_list);
  537. return bridge_vlan;
  538. }
  539. static void
  540. mlxsw_sp_bridge_vlan_destroy(struct mlxsw_sp_bridge_vlan *bridge_vlan)
  541. {
  542. list_del(&bridge_vlan->list);
  543. WARN_ON(!list_empty(&bridge_vlan->port_vlan_list));
  544. kfree(bridge_vlan);
  545. }
  546. static struct mlxsw_sp_bridge_vlan *
  547. mlxsw_sp_bridge_vlan_get(struct mlxsw_sp_bridge_port *bridge_port, u16 vid)
  548. {
  549. struct mlxsw_sp_bridge_vlan *bridge_vlan;
  550. bridge_vlan = mlxsw_sp_bridge_vlan_find(bridge_port, vid);
  551. if (bridge_vlan)
  552. return bridge_vlan;
  553. return mlxsw_sp_bridge_vlan_create(bridge_port, vid);
  554. }
  555. static void mlxsw_sp_bridge_vlan_put(struct mlxsw_sp_bridge_vlan *bridge_vlan)
  556. {
  557. if (list_empty(&bridge_vlan->port_vlan_list))
  558. mlxsw_sp_bridge_vlan_destroy(bridge_vlan);
  559. }
  560. static int
  561. mlxsw_sp_port_bridge_vlan_stp_set(struct mlxsw_sp_port *mlxsw_sp_port,
  562. struct mlxsw_sp_bridge_vlan *bridge_vlan,
  563. u8 state)
  564. {
  565. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  566. list_for_each_entry(mlxsw_sp_port_vlan, &bridge_vlan->port_vlan_list,
  567. bridge_vlan_node) {
  568. if (mlxsw_sp_port_vlan->mlxsw_sp_port != mlxsw_sp_port)
  569. continue;
  570. return mlxsw_sp_port_vid_stp_set(mlxsw_sp_port,
  571. bridge_vlan->vid, state);
  572. }
  573. return 0;
  574. }
  575. static int mlxsw_sp_port_attr_stp_state_set(struct mlxsw_sp_port *mlxsw_sp_port,
  576. struct net_device *orig_dev,
  577. u8 state)
  578. {
  579. struct mlxsw_sp_bridge_port *bridge_port;
  580. struct mlxsw_sp_bridge_vlan *bridge_vlan;
  581. int err;
  582. /* It's possible we failed to enslave the port, yet this
  583. * operation is executed due to it being deferred.
  584. */
  585. bridge_port = mlxsw_sp_bridge_port_find(mlxsw_sp_port->mlxsw_sp->bridge,
  586. orig_dev);
  587. if (!bridge_port)
  588. return 0;
  589. list_for_each_entry(bridge_vlan, &bridge_port->vlans_list, list) {
  590. err = mlxsw_sp_port_bridge_vlan_stp_set(mlxsw_sp_port,
  591. bridge_vlan, state);
  592. if (err)
  593. goto err_port_bridge_vlan_stp_set;
  594. }
  595. bridge_port->stp_state = state;
  596. return 0;
  597. err_port_bridge_vlan_stp_set:
  598. list_for_each_entry_continue_reverse(bridge_vlan,
  599. &bridge_port->vlans_list, list)
  600. mlxsw_sp_port_bridge_vlan_stp_set(mlxsw_sp_port, bridge_vlan,
  601. bridge_port->stp_state);
  602. return err;
  603. }
  604. static int
  605. mlxsw_sp_port_bridge_vlan_flood_set(struct mlxsw_sp_port *mlxsw_sp_port,
  606. struct mlxsw_sp_bridge_vlan *bridge_vlan,
  607. enum mlxsw_sp_flood_type packet_type,
  608. bool member)
  609. {
  610. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  611. list_for_each_entry(mlxsw_sp_port_vlan, &bridge_vlan->port_vlan_list,
  612. bridge_vlan_node) {
  613. if (mlxsw_sp_port_vlan->mlxsw_sp_port != mlxsw_sp_port)
  614. continue;
  615. return mlxsw_sp_fid_flood_set(mlxsw_sp_port_vlan->fid,
  616. packet_type,
  617. mlxsw_sp_port->local_port,
  618. member);
  619. }
  620. return 0;
  621. }
  622. static int
  623. mlxsw_sp_bridge_port_flood_table_set(struct mlxsw_sp_port *mlxsw_sp_port,
  624. struct mlxsw_sp_bridge_port *bridge_port,
  625. enum mlxsw_sp_flood_type packet_type,
  626. bool member)
  627. {
  628. struct mlxsw_sp_bridge_vlan *bridge_vlan;
  629. int err;
  630. list_for_each_entry(bridge_vlan, &bridge_port->vlans_list, list) {
  631. err = mlxsw_sp_port_bridge_vlan_flood_set(mlxsw_sp_port,
  632. bridge_vlan,
  633. packet_type,
  634. member);
  635. if (err)
  636. goto err_port_bridge_vlan_flood_set;
  637. }
  638. return 0;
  639. err_port_bridge_vlan_flood_set:
  640. list_for_each_entry_continue_reverse(bridge_vlan,
  641. &bridge_port->vlans_list, list)
  642. mlxsw_sp_port_bridge_vlan_flood_set(mlxsw_sp_port, bridge_vlan,
  643. packet_type, !member);
  644. return err;
  645. }
  646. static int
  647. mlxsw_sp_bridge_vlans_flood_set(struct mlxsw_sp_bridge_vlan *bridge_vlan,
  648. enum mlxsw_sp_flood_type packet_type,
  649. bool member)
  650. {
  651. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  652. int err;
  653. list_for_each_entry(mlxsw_sp_port_vlan, &bridge_vlan->port_vlan_list,
  654. bridge_vlan_node) {
  655. u16 local_port = mlxsw_sp_port_vlan->mlxsw_sp_port->local_port;
  656. err = mlxsw_sp_fid_flood_set(mlxsw_sp_port_vlan->fid,
  657. packet_type, local_port, member);
  658. if (err)
  659. goto err_fid_flood_set;
  660. }
  661. return 0;
  662. err_fid_flood_set:
  663. list_for_each_entry_continue_reverse(mlxsw_sp_port_vlan,
  664. &bridge_vlan->port_vlan_list,
  665. list) {
  666. u16 local_port = mlxsw_sp_port_vlan->mlxsw_sp_port->local_port;
  667. mlxsw_sp_fid_flood_set(mlxsw_sp_port_vlan->fid, packet_type,
  668. local_port, !member);
  669. }
  670. return err;
  671. }
  672. static int
  673. mlxsw_sp_bridge_ports_flood_table_set(struct mlxsw_sp_bridge_port *bridge_port,
  674. enum mlxsw_sp_flood_type packet_type,
  675. bool member)
  676. {
  677. struct mlxsw_sp_bridge_vlan *bridge_vlan;
  678. int err;
  679. list_for_each_entry(bridge_vlan, &bridge_port->vlans_list, list) {
  680. err = mlxsw_sp_bridge_vlans_flood_set(bridge_vlan, packet_type,
  681. member);
  682. if (err)
  683. goto err_bridge_vlans_flood_set;
  684. }
  685. return 0;
  686. err_bridge_vlans_flood_set:
  687. list_for_each_entry_continue_reverse(bridge_vlan,
  688. &bridge_port->vlans_list, list)
  689. mlxsw_sp_bridge_vlans_flood_set(bridge_vlan, packet_type,
  690. !member);
  691. return err;
  692. }
  693. static int
  694. mlxsw_sp_port_bridge_vlan_learning_set(struct mlxsw_sp_port *mlxsw_sp_port,
  695. struct mlxsw_sp_bridge_vlan *bridge_vlan,
  696. bool set)
  697. {
  698. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  699. u16 vid = bridge_vlan->vid;
  700. list_for_each_entry(mlxsw_sp_port_vlan, &bridge_vlan->port_vlan_list,
  701. bridge_vlan_node) {
  702. if (mlxsw_sp_port_vlan->mlxsw_sp_port != mlxsw_sp_port)
  703. continue;
  704. return mlxsw_sp_port_vid_learning_set(mlxsw_sp_port, vid, set);
  705. }
  706. return 0;
  707. }
  708. static int
  709. mlxsw_sp_bridge_port_learning_set(struct mlxsw_sp_port *mlxsw_sp_port,
  710. struct mlxsw_sp_bridge_port *bridge_port,
  711. bool set)
  712. {
  713. struct mlxsw_sp_bridge_vlan *bridge_vlan;
  714. int err;
  715. list_for_each_entry(bridge_vlan, &bridge_port->vlans_list, list) {
  716. err = mlxsw_sp_port_bridge_vlan_learning_set(mlxsw_sp_port,
  717. bridge_vlan, set);
  718. if (err)
  719. goto err_port_bridge_vlan_learning_set;
  720. }
  721. return 0;
  722. err_port_bridge_vlan_learning_set:
  723. list_for_each_entry_continue_reverse(bridge_vlan,
  724. &bridge_port->vlans_list, list)
  725. mlxsw_sp_port_bridge_vlan_learning_set(mlxsw_sp_port,
  726. bridge_vlan, !set);
  727. return err;
  728. }
  729. static int
  730. mlxsw_sp_port_attr_br_pre_flags_set(struct mlxsw_sp_port *mlxsw_sp_port,
  731. const struct net_device *orig_dev,
  732. struct switchdev_brport_flags flags,
  733. struct netlink_ext_ack *extack)
  734. {
  735. if (flags.mask & ~(BR_LEARNING | BR_FLOOD | BR_MCAST_FLOOD |
  736. BR_PORT_LOCKED | BR_PORT_MAB)) {
  737. NL_SET_ERR_MSG_MOD(extack, "Unsupported bridge port flag");
  738. return -EINVAL;
  739. }
  740. if ((flags.mask & BR_PORT_LOCKED) && is_vlan_dev(orig_dev)) {
  741. NL_SET_ERR_MSG_MOD(extack, "Locked flag cannot be set on a VLAN upper");
  742. return -EINVAL;
  743. }
  744. if ((flags.mask & BR_PORT_LOCKED) && vlan_uses_dev(orig_dev)) {
  745. NL_SET_ERR_MSG_MOD(extack, "Locked flag cannot be set on a bridge port that has VLAN uppers");
  746. return -EINVAL;
  747. }
  748. return 0;
  749. }
  750. static int mlxsw_sp_port_attr_br_flags_set(struct mlxsw_sp_port *mlxsw_sp_port,
  751. struct net_device *orig_dev,
  752. struct switchdev_brport_flags flags)
  753. {
  754. struct mlxsw_sp_bridge_port *bridge_port;
  755. int err;
  756. bridge_port = mlxsw_sp_bridge_port_find(mlxsw_sp_port->mlxsw_sp->bridge,
  757. orig_dev);
  758. if (!bridge_port)
  759. return 0;
  760. if (flags.mask & BR_FLOOD) {
  761. err = mlxsw_sp_bridge_port_flood_table_set(mlxsw_sp_port,
  762. bridge_port,
  763. MLXSW_SP_FLOOD_TYPE_UC,
  764. flags.val & BR_FLOOD);
  765. if (err)
  766. return err;
  767. }
  768. if (flags.mask & BR_LEARNING) {
  769. err = mlxsw_sp_bridge_port_learning_set(mlxsw_sp_port,
  770. bridge_port,
  771. flags.val & BR_LEARNING);
  772. if (err)
  773. return err;
  774. }
  775. if (flags.mask & BR_PORT_LOCKED) {
  776. err = mlxsw_sp_port_security_set(mlxsw_sp_port,
  777. flags.val & BR_PORT_LOCKED);
  778. if (err)
  779. return err;
  780. }
  781. if (bridge_port->bridge_device->multicast_enabled)
  782. goto out;
  783. if (flags.mask & BR_MCAST_FLOOD) {
  784. err = mlxsw_sp_bridge_port_flood_table_set(mlxsw_sp_port,
  785. bridge_port,
  786. MLXSW_SP_FLOOD_TYPE_MC,
  787. flags.val & BR_MCAST_FLOOD);
  788. if (err)
  789. return err;
  790. }
  791. out:
  792. memcpy(&bridge_port->flags, &flags.val, sizeof(flags.val));
  793. return 0;
  794. }
  795. static int mlxsw_sp_ageing_set(struct mlxsw_sp *mlxsw_sp, u32 ageing_time)
  796. {
  797. char sfdat_pl[MLXSW_REG_SFDAT_LEN];
  798. int err;
  799. mlxsw_reg_sfdat_pack(sfdat_pl, ageing_time);
  800. err = mlxsw_reg_write(mlxsw_sp->core, MLXSW_REG(sfdat), sfdat_pl);
  801. if (err)
  802. return err;
  803. mlxsw_sp->bridge->ageing_time = ageing_time;
  804. return 0;
  805. }
  806. static int mlxsw_sp_port_attr_br_ageing_set(struct mlxsw_sp_port *mlxsw_sp_port,
  807. unsigned long ageing_clock_t)
  808. {
  809. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_port->mlxsw_sp;
  810. unsigned long ageing_jiffies = clock_t_to_jiffies(ageing_clock_t);
  811. u32 ageing_time = jiffies_to_msecs(ageing_jiffies) / 1000;
  812. if (ageing_time < MLXSW_SP_MIN_AGEING_TIME ||
  813. ageing_time > MLXSW_SP_MAX_AGEING_TIME)
  814. return -ERANGE;
  815. return mlxsw_sp_ageing_set(mlxsw_sp, ageing_time);
  816. }
  817. static int mlxsw_sp_port_attr_br_vlan_set(struct mlxsw_sp_port *mlxsw_sp_port,
  818. struct net_device *orig_dev,
  819. bool vlan_enabled)
  820. {
  821. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_port->mlxsw_sp;
  822. struct mlxsw_sp_bridge_device *bridge_device;
  823. bridge_device = mlxsw_sp_bridge_device_find(mlxsw_sp->bridge, orig_dev);
  824. if (WARN_ON(!bridge_device))
  825. return -EINVAL;
  826. if (bridge_device->vlan_enabled == vlan_enabled)
  827. return 0;
  828. netdev_err(bridge_device->dev, "VLAN filtering can't be changed for existing bridge\n");
  829. return -EINVAL;
  830. }
  831. static int mlxsw_sp_port_attr_br_vlan_proto_set(struct mlxsw_sp_port *mlxsw_sp_port,
  832. struct net_device *orig_dev,
  833. u16 vlan_proto)
  834. {
  835. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_port->mlxsw_sp;
  836. struct mlxsw_sp_bridge_device *bridge_device;
  837. bridge_device = mlxsw_sp_bridge_device_find(mlxsw_sp->bridge, orig_dev);
  838. if (WARN_ON(!bridge_device))
  839. return -EINVAL;
  840. netdev_err(bridge_device->dev, "VLAN protocol can't be changed on existing bridge\n");
  841. return -EINVAL;
  842. }
  843. static int mlxsw_sp_port_attr_mrouter_set(struct mlxsw_sp_port *mlxsw_sp_port,
  844. struct net_device *orig_dev,
  845. bool is_port_mrouter)
  846. {
  847. struct mlxsw_sp_bridge_port *bridge_port;
  848. int err;
  849. bridge_port = mlxsw_sp_bridge_port_find(mlxsw_sp_port->mlxsw_sp->bridge,
  850. orig_dev);
  851. if (!bridge_port)
  852. return 0;
  853. mlxsw_sp_port_mrouter_update_mdb(mlxsw_sp_port, bridge_port,
  854. is_port_mrouter);
  855. if (!bridge_port->bridge_device->multicast_enabled)
  856. goto out;
  857. err = mlxsw_sp_bridge_port_flood_table_set(mlxsw_sp_port, bridge_port,
  858. MLXSW_SP_FLOOD_TYPE_MC,
  859. is_port_mrouter);
  860. if (err)
  861. return err;
  862. out:
  863. bridge_port->mrouter = is_port_mrouter;
  864. return 0;
  865. }
  866. static bool mlxsw_sp_mc_flood(const struct mlxsw_sp_bridge_port *bridge_port)
  867. {
  868. const struct mlxsw_sp_bridge_device *bridge_device;
  869. bridge_device = bridge_port->bridge_device;
  870. return bridge_device->multicast_enabled ? bridge_port->mrouter :
  871. bridge_port->flags & BR_MCAST_FLOOD;
  872. }
  873. static int mlxsw_sp_port_mc_disabled_set(struct mlxsw_sp_port *mlxsw_sp_port,
  874. struct net_device *orig_dev,
  875. bool mc_disabled)
  876. {
  877. enum mlxsw_sp_flood_type packet_type = MLXSW_SP_FLOOD_TYPE_MC;
  878. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_port->mlxsw_sp;
  879. struct mlxsw_sp_bridge_device *bridge_device;
  880. struct mlxsw_sp_bridge_port *bridge_port;
  881. int err;
  882. /* It's possible we failed to enslave the port, yet this
  883. * operation is executed due to it being deferred.
  884. */
  885. bridge_device = mlxsw_sp_bridge_device_find(mlxsw_sp->bridge, orig_dev);
  886. if (!bridge_device)
  887. return 0;
  888. if (bridge_device->multicast_enabled == !mc_disabled)
  889. return 0;
  890. bridge_device->multicast_enabled = !mc_disabled;
  891. err = mlxsw_sp_bridge_mdb_mc_enable_sync(mlxsw_sp, bridge_device,
  892. !mc_disabled);
  893. if (err)
  894. goto err_mc_enable_sync;
  895. list_for_each_entry(bridge_port, &bridge_device->ports_list, list) {
  896. bool member = mlxsw_sp_mc_flood(bridge_port);
  897. err = mlxsw_sp_bridge_ports_flood_table_set(bridge_port,
  898. packet_type,
  899. member);
  900. if (err)
  901. goto err_flood_table_set;
  902. }
  903. return 0;
  904. err_flood_table_set:
  905. list_for_each_entry_continue_reverse(bridge_port,
  906. &bridge_device->ports_list, list) {
  907. bool member = mlxsw_sp_mc_flood(bridge_port);
  908. mlxsw_sp_bridge_ports_flood_table_set(bridge_port, packet_type,
  909. !member);
  910. }
  911. mlxsw_sp_bridge_mdb_mc_enable_sync(mlxsw_sp, bridge_device,
  912. mc_disabled);
  913. err_mc_enable_sync:
  914. bridge_device->multicast_enabled = mc_disabled;
  915. return err;
  916. }
  917. static struct mlxsw_sp_mdb_entry_port *
  918. mlxsw_sp_mdb_entry_port_lookup(struct mlxsw_sp_mdb_entry *mdb_entry,
  919. u16 local_port)
  920. {
  921. struct mlxsw_sp_mdb_entry_port *mdb_entry_port;
  922. list_for_each_entry(mdb_entry_port, &mdb_entry->ports_list, list) {
  923. if (mdb_entry_port->local_port == local_port)
  924. return mdb_entry_port;
  925. }
  926. return NULL;
  927. }
  928. static struct mlxsw_sp_mdb_entry_port *
  929. mlxsw_sp_mdb_entry_port_get(struct mlxsw_sp *mlxsw_sp,
  930. struct mlxsw_sp_mdb_entry *mdb_entry,
  931. u16 local_port)
  932. {
  933. struct mlxsw_sp_mdb_entry_port *mdb_entry_port;
  934. int err;
  935. mdb_entry_port = mlxsw_sp_mdb_entry_port_lookup(mdb_entry, local_port);
  936. if (mdb_entry_port) {
  937. if (mdb_entry_port->mrouter &&
  938. refcount_read(&mdb_entry_port->refcount) == 1)
  939. mdb_entry->ports_count++;
  940. refcount_inc(&mdb_entry_port->refcount);
  941. return mdb_entry_port;
  942. }
  943. err = mlxsw_sp_pgt_entry_port_set(mlxsw_sp, mdb_entry->mid,
  944. mdb_entry->key.fid, local_port, true);
  945. if (err)
  946. return ERR_PTR(err);
  947. mdb_entry_port = kzalloc_obj(*mdb_entry_port);
  948. if (!mdb_entry_port) {
  949. err = -ENOMEM;
  950. goto err_mdb_entry_port_alloc;
  951. }
  952. mdb_entry_port->local_port = local_port;
  953. refcount_set(&mdb_entry_port->refcount, 1);
  954. list_add(&mdb_entry_port->list, &mdb_entry->ports_list);
  955. mdb_entry->ports_count++;
  956. return mdb_entry_port;
  957. err_mdb_entry_port_alloc:
  958. mlxsw_sp_pgt_entry_port_set(mlxsw_sp, mdb_entry->mid,
  959. mdb_entry->key.fid, local_port, false);
  960. return ERR_PTR(err);
  961. }
  962. static void
  963. mlxsw_sp_mdb_entry_port_put(struct mlxsw_sp *mlxsw_sp,
  964. struct mlxsw_sp_mdb_entry *mdb_entry,
  965. u16 local_port, bool force)
  966. {
  967. struct mlxsw_sp_mdb_entry_port *mdb_entry_port;
  968. mdb_entry_port = mlxsw_sp_mdb_entry_port_lookup(mdb_entry, local_port);
  969. if (!mdb_entry_port)
  970. return;
  971. if (!force && !refcount_dec_and_test(&mdb_entry_port->refcount)) {
  972. if (mdb_entry_port->mrouter &&
  973. refcount_read(&mdb_entry_port->refcount) == 1)
  974. mdb_entry->ports_count--;
  975. return;
  976. }
  977. mdb_entry->ports_count--;
  978. list_del(&mdb_entry_port->list);
  979. kfree(mdb_entry_port);
  980. mlxsw_sp_pgt_entry_port_set(mlxsw_sp, mdb_entry->mid,
  981. mdb_entry->key.fid, local_port, false);
  982. }
  983. static __always_unused struct mlxsw_sp_mdb_entry_port *
  984. mlxsw_sp_mdb_entry_mrouter_port_get(struct mlxsw_sp *mlxsw_sp,
  985. struct mlxsw_sp_mdb_entry *mdb_entry,
  986. u16 local_port)
  987. {
  988. struct mlxsw_sp_mdb_entry_port *mdb_entry_port;
  989. int err;
  990. mdb_entry_port = mlxsw_sp_mdb_entry_port_lookup(mdb_entry, local_port);
  991. if (mdb_entry_port) {
  992. if (!mdb_entry_port->mrouter)
  993. refcount_inc(&mdb_entry_port->refcount);
  994. return mdb_entry_port;
  995. }
  996. err = mlxsw_sp_pgt_entry_port_set(mlxsw_sp, mdb_entry->mid,
  997. mdb_entry->key.fid, local_port, true);
  998. if (err)
  999. return ERR_PTR(err);
  1000. mdb_entry_port = kzalloc_obj(*mdb_entry_port);
  1001. if (!mdb_entry_port) {
  1002. err = -ENOMEM;
  1003. goto err_mdb_entry_port_alloc;
  1004. }
  1005. mdb_entry_port->local_port = local_port;
  1006. refcount_set(&mdb_entry_port->refcount, 1);
  1007. mdb_entry_port->mrouter = true;
  1008. list_add(&mdb_entry_port->list, &mdb_entry->ports_list);
  1009. return mdb_entry_port;
  1010. err_mdb_entry_port_alloc:
  1011. mlxsw_sp_pgt_entry_port_set(mlxsw_sp, mdb_entry->mid,
  1012. mdb_entry->key.fid, local_port, false);
  1013. return ERR_PTR(err);
  1014. }
  1015. static __always_unused void
  1016. mlxsw_sp_mdb_entry_mrouter_port_put(struct mlxsw_sp *mlxsw_sp,
  1017. struct mlxsw_sp_mdb_entry *mdb_entry,
  1018. u16 local_port)
  1019. {
  1020. struct mlxsw_sp_mdb_entry_port *mdb_entry_port;
  1021. mdb_entry_port = mlxsw_sp_mdb_entry_port_lookup(mdb_entry, local_port);
  1022. if (!mdb_entry_port)
  1023. return;
  1024. if (!mdb_entry_port->mrouter)
  1025. return;
  1026. mdb_entry_port->mrouter = false;
  1027. if (!refcount_dec_and_test(&mdb_entry_port->refcount))
  1028. return;
  1029. list_del(&mdb_entry_port->list);
  1030. kfree(mdb_entry_port);
  1031. mlxsw_sp_pgt_entry_port_set(mlxsw_sp, mdb_entry->mid,
  1032. mdb_entry->key.fid, local_port, false);
  1033. }
  1034. static void
  1035. mlxsw_sp_bridge_mrouter_update_mdb(struct mlxsw_sp *mlxsw_sp,
  1036. struct mlxsw_sp_bridge_device *bridge_device,
  1037. bool add)
  1038. {
  1039. u16 local_port = mlxsw_sp_router_port(mlxsw_sp);
  1040. struct mlxsw_sp_mdb_entry *mdb_entry;
  1041. list_for_each_entry(mdb_entry, &bridge_device->mdb_list, list) {
  1042. if (add)
  1043. mlxsw_sp_mdb_entry_mrouter_port_get(mlxsw_sp, mdb_entry,
  1044. local_port);
  1045. else
  1046. mlxsw_sp_mdb_entry_mrouter_port_put(mlxsw_sp, mdb_entry,
  1047. local_port);
  1048. }
  1049. }
  1050. static int
  1051. mlxsw_sp_port_attr_br_mrouter_set(struct mlxsw_sp_port *mlxsw_sp_port,
  1052. struct net_device *orig_dev,
  1053. bool is_mrouter)
  1054. {
  1055. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_port->mlxsw_sp;
  1056. struct mlxsw_sp_bridge_device *bridge_device;
  1057. /* It's possible we failed to enslave the port, yet this
  1058. * operation is executed due to it being deferred.
  1059. */
  1060. bridge_device = mlxsw_sp_bridge_device_find(mlxsw_sp->bridge, orig_dev);
  1061. if (!bridge_device)
  1062. return 0;
  1063. if (bridge_device->mrouter != is_mrouter)
  1064. mlxsw_sp_bridge_mrouter_update_mdb(mlxsw_sp, bridge_device,
  1065. is_mrouter);
  1066. bridge_device->mrouter = is_mrouter;
  1067. return 0;
  1068. }
  1069. static int mlxsw_sp_port_attr_set(struct net_device *dev, const void *ctx,
  1070. const struct switchdev_attr *attr,
  1071. struct netlink_ext_ack *extack)
  1072. {
  1073. struct mlxsw_sp_port *mlxsw_sp_port = netdev_priv(dev);
  1074. int err;
  1075. switch (attr->id) {
  1076. case SWITCHDEV_ATTR_ID_PORT_STP_STATE:
  1077. err = mlxsw_sp_port_attr_stp_state_set(mlxsw_sp_port,
  1078. attr->orig_dev,
  1079. attr->u.stp_state);
  1080. break;
  1081. case SWITCHDEV_ATTR_ID_PORT_PRE_BRIDGE_FLAGS:
  1082. err = mlxsw_sp_port_attr_br_pre_flags_set(mlxsw_sp_port,
  1083. attr->orig_dev,
  1084. attr->u.brport_flags,
  1085. extack);
  1086. break;
  1087. case SWITCHDEV_ATTR_ID_PORT_BRIDGE_FLAGS:
  1088. err = mlxsw_sp_port_attr_br_flags_set(mlxsw_sp_port,
  1089. attr->orig_dev,
  1090. attr->u.brport_flags);
  1091. break;
  1092. case SWITCHDEV_ATTR_ID_BRIDGE_AGEING_TIME:
  1093. err = mlxsw_sp_port_attr_br_ageing_set(mlxsw_sp_port,
  1094. attr->u.ageing_time);
  1095. break;
  1096. case SWITCHDEV_ATTR_ID_BRIDGE_VLAN_FILTERING:
  1097. err = mlxsw_sp_port_attr_br_vlan_set(mlxsw_sp_port,
  1098. attr->orig_dev,
  1099. attr->u.vlan_filtering);
  1100. break;
  1101. case SWITCHDEV_ATTR_ID_BRIDGE_VLAN_PROTOCOL:
  1102. err = mlxsw_sp_port_attr_br_vlan_proto_set(mlxsw_sp_port,
  1103. attr->orig_dev,
  1104. attr->u.vlan_protocol);
  1105. break;
  1106. case SWITCHDEV_ATTR_ID_PORT_MROUTER:
  1107. err = mlxsw_sp_port_attr_mrouter_set(mlxsw_sp_port,
  1108. attr->orig_dev,
  1109. attr->u.mrouter);
  1110. break;
  1111. case SWITCHDEV_ATTR_ID_BRIDGE_MC_DISABLED:
  1112. err = mlxsw_sp_port_mc_disabled_set(mlxsw_sp_port,
  1113. attr->orig_dev,
  1114. attr->u.mc_disabled);
  1115. break;
  1116. case SWITCHDEV_ATTR_ID_BRIDGE_MROUTER:
  1117. err = mlxsw_sp_port_attr_br_mrouter_set(mlxsw_sp_port,
  1118. attr->orig_dev,
  1119. attr->u.mrouter);
  1120. break;
  1121. default:
  1122. err = -EOPNOTSUPP;
  1123. break;
  1124. }
  1125. mlxsw_sp_span_respin(mlxsw_sp_port->mlxsw_sp);
  1126. return err;
  1127. }
  1128. static int
  1129. mlxsw_sp_port_vlan_fid_join(struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan,
  1130. struct mlxsw_sp_bridge_port *bridge_port,
  1131. struct netlink_ext_ack *extack)
  1132. {
  1133. struct mlxsw_sp_port *mlxsw_sp_port = mlxsw_sp_port_vlan->mlxsw_sp_port;
  1134. struct mlxsw_sp_bridge_device *bridge_device;
  1135. u16 local_port = mlxsw_sp_port->local_port;
  1136. u16 vid = mlxsw_sp_port_vlan->vid;
  1137. struct mlxsw_sp_fid *fid;
  1138. int err;
  1139. bridge_device = bridge_port->bridge_device;
  1140. fid = bridge_device->ops->fid_get(bridge_device, vid, extack);
  1141. if (IS_ERR(fid))
  1142. return PTR_ERR(fid);
  1143. err = mlxsw_sp_fid_flood_set(fid, MLXSW_SP_FLOOD_TYPE_UC, local_port,
  1144. bridge_port->flags & BR_FLOOD);
  1145. if (err)
  1146. goto err_fid_uc_flood_set;
  1147. err = mlxsw_sp_fid_flood_set(fid, MLXSW_SP_FLOOD_TYPE_MC, local_port,
  1148. mlxsw_sp_mc_flood(bridge_port));
  1149. if (err)
  1150. goto err_fid_mc_flood_set;
  1151. err = mlxsw_sp_fid_flood_set(fid, MLXSW_SP_FLOOD_TYPE_BC, local_port,
  1152. true);
  1153. if (err)
  1154. goto err_fid_bc_flood_set;
  1155. err = mlxsw_sp_fid_port_vid_map(fid, mlxsw_sp_port, vid);
  1156. if (err)
  1157. goto err_fid_port_vid_map;
  1158. mlxsw_sp_port_vlan->fid = fid;
  1159. return 0;
  1160. err_fid_port_vid_map:
  1161. mlxsw_sp_fid_flood_set(fid, MLXSW_SP_FLOOD_TYPE_BC, local_port, false);
  1162. err_fid_bc_flood_set:
  1163. mlxsw_sp_fid_flood_set(fid, MLXSW_SP_FLOOD_TYPE_MC, local_port, false);
  1164. err_fid_mc_flood_set:
  1165. mlxsw_sp_fid_flood_set(fid, MLXSW_SP_FLOOD_TYPE_UC, local_port, false);
  1166. err_fid_uc_flood_set:
  1167. mlxsw_sp_fid_put(fid);
  1168. return err;
  1169. }
  1170. static void
  1171. mlxsw_sp_port_vlan_fid_leave(struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan)
  1172. {
  1173. struct mlxsw_sp_port *mlxsw_sp_port = mlxsw_sp_port_vlan->mlxsw_sp_port;
  1174. struct mlxsw_sp_fid *fid = mlxsw_sp_port_vlan->fid;
  1175. u16 local_port = mlxsw_sp_port->local_port;
  1176. u16 vid = mlxsw_sp_port_vlan->vid;
  1177. mlxsw_sp_port_vlan->fid = NULL;
  1178. mlxsw_sp_fid_port_vid_unmap(fid, mlxsw_sp_port, vid);
  1179. mlxsw_sp_fid_flood_set(fid, MLXSW_SP_FLOOD_TYPE_BC, local_port, false);
  1180. mlxsw_sp_fid_flood_set(fid, MLXSW_SP_FLOOD_TYPE_MC, local_port, false);
  1181. mlxsw_sp_fid_flood_set(fid, MLXSW_SP_FLOOD_TYPE_UC, local_port, false);
  1182. mlxsw_sp_fid_put(fid);
  1183. }
  1184. static u16
  1185. mlxsw_sp_port_pvid_determine(const struct mlxsw_sp_port *mlxsw_sp_port,
  1186. u16 vid, bool is_pvid)
  1187. {
  1188. if (is_pvid)
  1189. return vid;
  1190. else if (mlxsw_sp_port->pvid == vid)
  1191. return 0; /* Dis-allow untagged packets */
  1192. else
  1193. return mlxsw_sp_port->pvid;
  1194. }
  1195. static int
  1196. mlxsw_sp_port_vlan_bridge_join(struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan,
  1197. struct mlxsw_sp_bridge_port *bridge_port,
  1198. struct netlink_ext_ack *extack)
  1199. {
  1200. struct mlxsw_sp_port *mlxsw_sp_port = mlxsw_sp_port_vlan->mlxsw_sp_port;
  1201. struct mlxsw_sp_bridge_vlan *bridge_vlan;
  1202. u16 vid = mlxsw_sp_port_vlan->vid;
  1203. int err;
  1204. /* No need to continue if only VLAN flags were changed */
  1205. if (mlxsw_sp_port_vlan->bridge_port)
  1206. return 0;
  1207. err = mlxsw_sp_port_vlan_fid_join(mlxsw_sp_port_vlan, bridge_port,
  1208. extack);
  1209. if (err)
  1210. return err;
  1211. err = mlxsw_sp_port_vid_learning_set(mlxsw_sp_port, vid,
  1212. bridge_port->flags & BR_LEARNING);
  1213. if (err)
  1214. goto err_port_vid_learning_set;
  1215. err = mlxsw_sp_port_vid_stp_set(mlxsw_sp_port, vid,
  1216. bridge_port->stp_state);
  1217. if (err)
  1218. goto err_port_vid_stp_set;
  1219. bridge_vlan = mlxsw_sp_bridge_vlan_get(bridge_port, vid);
  1220. if (!bridge_vlan) {
  1221. err = -ENOMEM;
  1222. goto err_bridge_vlan_get;
  1223. }
  1224. list_add(&mlxsw_sp_port_vlan->bridge_vlan_node,
  1225. &bridge_vlan->port_vlan_list);
  1226. mlxsw_sp_bridge_port_get(mlxsw_sp_port->mlxsw_sp->bridge,
  1227. bridge_port->dev, extack);
  1228. mlxsw_sp_port_vlan->bridge_port = bridge_port;
  1229. return 0;
  1230. err_bridge_vlan_get:
  1231. mlxsw_sp_port_vid_stp_set(mlxsw_sp_port, vid, BR_STATE_DISABLED);
  1232. err_port_vid_stp_set:
  1233. mlxsw_sp_port_vid_learning_set(mlxsw_sp_port, vid, false);
  1234. err_port_vid_learning_set:
  1235. mlxsw_sp_port_vlan_fid_leave(mlxsw_sp_port_vlan);
  1236. return err;
  1237. }
  1238. void
  1239. mlxsw_sp_port_vlan_bridge_leave(struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan)
  1240. {
  1241. struct mlxsw_sp_port *mlxsw_sp_port = mlxsw_sp_port_vlan->mlxsw_sp_port;
  1242. struct mlxsw_sp_fid *fid = mlxsw_sp_port_vlan->fid;
  1243. struct mlxsw_sp_bridge_vlan *bridge_vlan;
  1244. struct mlxsw_sp_bridge_port *bridge_port;
  1245. u16 vid = mlxsw_sp_port_vlan->vid;
  1246. bool last_port;
  1247. if (WARN_ON(mlxsw_sp_fid_type(fid) != MLXSW_SP_FID_TYPE_8021Q &&
  1248. mlxsw_sp_fid_type(fid) != MLXSW_SP_FID_TYPE_8021D))
  1249. return;
  1250. bridge_port = mlxsw_sp_port_vlan->bridge_port;
  1251. bridge_vlan = mlxsw_sp_bridge_vlan_find(bridge_port, vid);
  1252. last_port = list_is_singular(&bridge_vlan->port_vlan_list);
  1253. list_del(&mlxsw_sp_port_vlan->bridge_vlan_node);
  1254. mlxsw_sp_bridge_vlan_put(bridge_vlan);
  1255. mlxsw_sp_port_vid_stp_set(mlxsw_sp_port, vid, BR_STATE_DISABLED);
  1256. mlxsw_sp_port_vid_learning_set(mlxsw_sp_port, vid, false);
  1257. if (last_port)
  1258. mlxsw_sp_bridge_port_fdb_flush(mlxsw_sp_port->mlxsw_sp,
  1259. bridge_port,
  1260. mlxsw_sp_fid_index(fid));
  1261. mlxsw_sp_bridge_port_mdb_flush(mlxsw_sp_port, bridge_port,
  1262. mlxsw_sp_fid_index(fid));
  1263. mlxsw_sp_port_vlan_fid_leave(mlxsw_sp_port_vlan);
  1264. mlxsw_sp_bridge_port_put(mlxsw_sp_port->mlxsw_sp->bridge, bridge_port);
  1265. mlxsw_sp_port_vlan->bridge_port = NULL;
  1266. }
  1267. static int
  1268. mlxsw_sp_bridge_port_vlan_add(struct mlxsw_sp_port *mlxsw_sp_port,
  1269. struct mlxsw_sp_bridge_port *bridge_port,
  1270. u16 vid, bool is_untagged, bool is_pvid,
  1271. struct netlink_ext_ack *extack)
  1272. {
  1273. u16 pvid = mlxsw_sp_port_pvid_determine(mlxsw_sp_port, vid, is_pvid);
  1274. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  1275. u16 old_pvid = mlxsw_sp_port->pvid;
  1276. u16 proto;
  1277. int err;
  1278. /* The only valid scenario in which a port-vlan already exists, is if
  1279. * the VLAN flags were changed and the port-vlan is associated with the
  1280. * correct bridge port
  1281. */
  1282. mlxsw_sp_port_vlan = mlxsw_sp_port_vlan_find_by_vid(mlxsw_sp_port, vid);
  1283. if (mlxsw_sp_port_vlan &&
  1284. mlxsw_sp_port_vlan->bridge_port != bridge_port)
  1285. return -EEXIST;
  1286. if (!mlxsw_sp_port_vlan) {
  1287. mlxsw_sp_port_vlan = mlxsw_sp_port_vlan_create(mlxsw_sp_port,
  1288. vid);
  1289. if (IS_ERR(mlxsw_sp_port_vlan))
  1290. return PTR_ERR(mlxsw_sp_port_vlan);
  1291. }
  1292. err = mlxsw_sp_port_vlan_set(mlxsw_sp_port, vid, vid, true,
  1293. is_untagged);
  1294. if (err)
  1295. goto err_port_vlan_set;
  1296. br_vlan_get_proto(bridge_port->bridge_device->dev, &proto);
  1297. err = mlxsw_sp_port_pvid_set(mlxsw_sp_port, pvid, proto);
  1298. if (err)
  1299. goto err_port_pvid_set;
  1300. err = mlxsw_sp_port_vlan_bridge_join(mlxsw_sp_port_vlan, bridge_port,
  1301. extack);
  1302. if (err)
  1303. goto err_port_vlan_bridge_join;
  1304. return 0;
  1305. err_port_vlan_bridge_join:
  1306. mlxsw_sp_port_pvid_set(mlxsw_sp_port, old_pvid, proto);
  1307. err_port_pvid_set:
  1308. mlxsw_sp_port_vlan_set(mlxsw_sp_port, vid, vid, false, false);
  1309. err_port_vlan_set:
  1310. mlxsw_sp_port_vlan_destroy(mlxsw_sp_port_vlan);
  1311. return err;
  1312. }
  1313. static int
  1314. mlxsw_sp_br_rif_pvid_change(struct mlxsw_sp *mlxsw_sp,
  1315. struct net_device *br_dev,
  1316. const struct switchdev_obj_port_vlan *vlan,
  1317. struct netlink_ext_ack *extack)
  1318. {
  1319. bool flag_pvid = vlan->flags & BRIDGE_VLAN_INFO_PVID;
  1320. return mlxsw_sp_router_bridge_vlan_add(mlxsw_sp, br_dev, vlan->vid,
  1321. flag_pvid, extack);
  1322. }
  1323. static int mlxsw_sp_port_vlans_add(struct mlxsw_sp_port *mlxsw_sp_port,
  1324. const struct switchdev_obj_port_vlan *vlan,
  1325. struct netlink_ext_ack *extack)
  1326. {
  1327. bool flag_untagged = vlan->flags & BRIDGE_VLAN_INFO_UNTAGGED;
  1328. bool flag_pvid = vlan->flags & BRIDGE_VLAN_INFO_PVID;
  1329. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_port->mlxsw_sp;
  1330. struct net_device *orig_dev = vlan->obj.orig_dev;
  1331. struct mlxsw_sp_bridge_port *bridge_port;
  1332. if (netif_is_bridge_master(orig_dev)) {
  1333. int err = 0;
  1334. if (br_vlan_enabled(orig_dev))
  1335. err = mlxsw_sp_br_rif_pvid_change(mlxsw_sp, orig_dev,
  1336. vlan, extack);
  1337. if (!err)
  1338. err = -EOPNOTSUPP;
  1339. return err;
  1340. }
  1341. bridge_port = mlxsw_sp_bridge_port_find(mlxsw_sp->bridge, orig_dev);
  1342. if (WARN_ON(!bridge_port))
  1343. return -EINVAL;
  1344. if (!bridge_port->bridge_device->vlan_enabled)
  1345. return 0;
  1346. return mlxsw_sp_bridge_port_vlan_add(mlxsw_sp_port, bridge_port,
  1347. vlan->vid, flag_untagged,
  1348. flag_pvid, extack);
  1349. }
  1350. static enum mlxsw_reg_sfdf_flush_type mlxsw_sp_fdb_flush_type(bool lagged)
  1351. {
  1352. return lagged ? MLXSW_REG_SFDF_FLUSH_PER_LAG_AND_FID :
  1353. MLXSW_REG_SFDF_FLUSH_PER_PORT_AND_FID;
  1354. }
  1355. static int
  1356. mlxsw_sp_bridge_port_fdb_flush(struct mlxsw_sp *mlxsw_sp,
  1357. struct mlxsw_sp_bridge_port *bridge_port,
  1358. u16 fid_index)
  1359. {
  1360. bool lagged = bridge_port->lagged;
  1361. char sfdf_pl[MLXSW_REG_SFDF_LEN];
  1362. u16 system_port;
  1363. system_port = lagged ? bridge_port->lag_id : bridge_port->system_port;
  1364. mlxsw_reg_sfdf_pack(sfdf_pl, mlxsw_sp_fdb_flush_type(lagged));
  1365. mlxsw_reg_sfdf_fid_set(sfdf_pl, fid_index);
  1366. mlxsw_reg_sfdf_port_fid_system_port_set(sfdf_pl, system_port);
  1367. return mlxsw_reg_write(mlxsw_sp->core, MLXSW_REG(sfdf), sfdf_pl);
  1368. }
  1369. static enum mlxsw_reg_sfd_rec_policy mlxsw_sp_sfd_rec_policy(bool dynamic)
  1370. {
  1371. return dynamic ? MLXSW_REG_SFD_REC_POLICY_DYNAMIC_ENTRY_INGRESS :
  1372. MLXSW_REG_SFD_REC_POLICY_DYNAMIC_ENTRY_MLAG;
  1373. }
  1374. static enum mlxsw_reg_sfd_op mlxsw_sp_sfd_op(bool adding)
  1375. {
  1376. return adding ? MLXSW_REG_SFD_OP_WRITE_EDIT :
  1377. MLXSW_REG_SFD_OP_WRITE_REMOVE;
  1378. }
  1379. static int
  1380. mlxsw_sp_port_fdb_tun_uc_op4(struct mlxsw_sp *mlxsw_sp, bool dynamic,
  1381. const char *mac, u16 fid, __be32 addr, bool adding)
  1382. {
  1383. char *sfd_pl;
  1384. u8 num_rec;
  1385. u32 uip;
  1386. int err;
  1387. sfd_pl = kmalloc(MLXSW_REG_SFD_LEN, GFP_KERNEL);
  1388. if (!sfd_pl)
  1389. return -ENOMEM;
  1390. uip = be32_to_cpu(addr);
  1391. mlxsw_reg_sfd_pack(sfd_pl, mlxsw_sp_sfd_op(adding), 0);
  1392. mlxsw_reg_sfd_uc_tunnel_pack4(sfd_pl, 0,
  1393. mlxsw_sp_sfd_rec_policy(dynamic), mac,
  1394. fid, MLXSW_REG_SFD_REC_ACTION_NOP, uip);
  1395. num_rec = mlxsw_reg_sfd_num_rec_get(sfd_pl);
  1396. err = mlxsw_reg_write(mlxsw_sp->core, MLXSW_REG(sfd), sfd_pl);
  1397. if (err)
  1398. goto out;
  1399. if (num_rec != mlxsw_reg_sfd_num_rec_get(sfd_pl))
  1400. err = -EBUSY;
  1401. out:
  1402. kfree(sfd_pl);
  1403. return err;
  1404. }
  1405. static int mlxsw_sp_port_fdb_tun_uc_op6_sfd_write(struct mlxsw_sp *mlxsw_sp,
  1406. const char *mac, u16 fid,
  1407. u32 kvdl_index, bool adding)
  1408. {
  1409. char *sfd_pl;
  1410. u8 num_rec;
  1411. int err;
  1412. sfd_pl = kmalloc(MLXSW_REG_SFD_LEN, GFP_KERNEL);
  1413. if (!sfd_pl)
  1414. return -ENOMEM;
  1415. mlxsw_reg_sfd_pack(sfd_pl, mlxsw_sp_sfd_op(adding), 0);
  1416. mlxsw_reg_sfd_uc_tunnel_pack6(sfd_pl, 0, mac, fid,
  1417. MLXSW_REG_SFD_REC_ACTION_NOP, kvdl_index);
  1418. num_rec = mlxsw_reg_sfd_num_rec_get(sfd_pl);
  1419. err = mlxsw_reg_write(mlxsw_sp->core, MLXSW_REG(sfd), sfd_pl);
  1420. if (err)
  1421. goto out;
  1422. if (num_rec != mlxsw_reg_sfd_num_rec_get(sfd_pl))
  1423. err = -EBUSY;
  1424. out:
  1425. kfree(sfd_pl);
  1426. return err;
  1427. }
  1428. static int mlxsw_sp_port_fdb_tun_uc_op6_add(struct mlxsw_sp *mlxsw_sp,
  1429. const char *mac, u16 fid,
  1430. const struct in6_addr *addr)
  1431. {
  1432. u32 kvdl_index;
  1433. int err;
  1434. err = mlxsw_sp_nve_ipv6_addr_kvdl_set(mlxsw_sp, addr, &kvdl_index);
  1435. if (err)
  1436. return err;
  1437. err = mlxsw_sp_port_fdb_tun_uc_op6_sfd_write(mlxsw_sp, mac, fid,
  1438. kvdl_index, true);
  1439. if (err)
  1440. goto err_sfd_write;
  1441. err = mlxsw_sp_nve_ipv6_addr_map_replace(mlxsw_sp, mac, fid, addr);
  1442. if (err)
  1443. /* Replace can fail only for creating new mapping, so removing
  1444. * the FDB entry in the error path is OK.
  1445. */
  1446. goto err_addr_replace;
  1447. return 0;
  1448. err_addr_replace:
  1449. mlxsw_sp_port_fdb_tun_uc_op6_sfd_write(mlxsw_sp, mac, fid, kvdl_index,
  1450. false);
  1451. err_sfd_write:
  1452. mlxsw_sp_nve_ipv6_addr_kvdl_unset(mlxsw_sp, addr);
  1453. return err;
  1454. }
  1455. static void mlxsw_sp_port_fdb_tun_uc_op6_del(struct mlxsw_sp *mlxsw_sp,
  1456. const char *mac, u16 fid,
  1457. const struct in6_addr *addr)
  1458. {
  1459. mlxsw_sp_nve_ipv6_addr_map_del(mlxsw_sp, mac, fid);
  1460. mlxsw_sp_port_fdb_tun_uc_op6_sfd_write(mlxsw_sp, mac, fid, 0, false);
  1461. mlxsw_sp_nve_ipv6_addr_kvdl_unset(mlxsw_sp, addr);
  1462. }
  1463. static int
  1464. mlxsw_sp_port_fdb_tun_uc_op6(struct mlxsw_sp *mlxsw_sp, const char *mac,
  1465. u16 fid, const struct in6_addr *addr, bool adding)
  1466. {
  1467. if (adding)
  1468. return mlxsw_sp_port_fdb_tun_uc_op6_add(mlxsw_sp, mac, fid,
  1469. addr);
  1470. mlxsw_sp_port_fdb_tun_uc_op6_del(mlxsw_sp, mac, fid, addr);
  1471. return 0;
  1472. }
  1473. static int mlxsw_sp_port_fdb_tunnel_uc_op(struct mlxsw_sp *mlxsw_sp,
  1474. const char *mac, u16 fid,
  1475. enum mlxsw_sp_l3proto proto,
  1476. const union mlxsw_sp_l3addr *addr,
  1477. bool adding, bool dynamic)
  1478. {
  1479. switch (proto) {
  1480. case MLXSW_SP_L3_PROTO_IPV4:
  1481. return mlxsw_sp_port_fdb_tun_uc_op4(mlxsw_sp, dynamic, mac, fid,
  1482. addr->addr4, adding);
  1483. case MLXSW_SP_L3_PROTO_IPV6:
  1484. return mlxsw_sp_port_fdb_tun_uc_op6(mlxsw_sp, mac, fid,
  1485. &addr->addr6, adding);
  1486. default:
  1487. WARN_ON(1);
  1488. return -EOPNOTSUPP;
  1489. }
  1490. }
  1491. static int __mlxsw_sp_port_fdb_uc_op(struct mlxsw_sp *mlxsw_sp, u16 local_port,
  1492. const char *mac, u16 fid, u16 vid,
  1493. bool adding,
  1494. enum mlxsw_reg_sfd_rec_action action,
  1495. enum mlxsw_reg_sfd_rec_policy policy)
  1496. {
  1497. char *sfd_pl;
  1498. u8 num_rec;
  1499. int err;
  1500. sfd_pl = kmalloc(MLXSW_REG_SFD_LEN, GFP_KERNEL);
  1501. if (!sfd_pl)
  1502. return -ENOMEM;
  1503. mlxsw_reg_sfd_pack(sfd_pl, mlxsw_sp_sfd_op(adding), 0);
  1504. mlxsw_reg_sfd_uc_pack(sfd_pl, 0, policy, mac, fid, vid, action,
  1505. local_port);
  1506. num_rec = mlxsw_reg_sfd_num_rec_get(sfd_pl);
  1507. err = mlxsw_reg_write(mlxsw_sp->core, MLXSW_REG(sfd), sfd_pl);
  1508. if (err)
  1509. goto out;
  1510. if (num_rec != mlxsw_reg_sfd_num_rec_get(sfd_pl))
  1511. err = -EBUSY;
  1512. out:
  1513. kfree(sfd_pl);
  1514. return err;
  1515. }
  1516. static int mlxsw_sp_port_fdb_uc_op(struct mlxsw_sp *mlxsw_sp, u16 local_port,
  1517. const char *mac, u16 fid, u16 vid,
  1518. bool adding, bool dynamic)
  1519. {
  1520. return __mlxsw_sp_port_fdb_uc_op(mlxsw_sp, local_port, mac, fid, vid,
  1521. adding, MLXSW_REG_SFD_REC_ACTION_NOP,
  1522. mlxsw_sp_sfd_rec_policy(dynamic));
  1523. }
  1524. int mlxsw_sp_rif_fdb_op(struct mlxsw_sp *mlxsw_sp, const char *mac, u16 fid,
  1525. bool adding)
  1526. {
  1527. return __mlxsw_sp_port_fdb_uc_op(mlxsw_sp, 0, mac, fid, 0, adding,
  1528. MLXSW_REG_SFD_REC_ACTION_FORWARD_IP_ROUTER,
  1529. MLXSW_REG_SFD_REC_POLICY_STATIC_ENTRY);
  1530. }
  1531. static int mlxsw_sp_port_fdb_uc_lag_op(struct mlxsw_sp *mlxsw_sp, u16 lag_id,
  1532. const char *mac, u16 fid, u16 lag_vid,
  1533. bool adding, bool dynamic)
  1534. {
  1535. char *sfd_pl;
  1536. u8 num_rec;
  1537. int err;
  1538. sfd_pl = kmalloc(MLXSW_REG_SFD_LEN, GFP_KERNEL);
  1539. if (!sfd_pl)
  1540. return -ENOMEM;
  1541. mlxsw_reg_sfd_pack(sfd_pl, mlxsw_sp_sfd_op(adding), 0);
  1542. mlxsw_reg_sfd_uc_lag_pack(sfd_pl, 0, mlxsw_sp_sfd_rec_policy(dynamic),
  1543. mac, fid, MLXSW_REG_SFD_REC_ACTION_NOP,
  1544. lag_vid, lag_id);
  1545. num_rec = mlxsw_reg_sfd_num_rec_get(sfd_pl);
  1546. err = mlxsw_reg_write(mlxsw_sp->core, MLXSW_REG(sfd), sfd_pl);
  1547. if (err)
  1548. goto out;
  1549. if (num_rec != mlxsw_reg_sfd_num_rec_get(sfd_pl))
  1550. err = -EBUSY;
  1551. out:
  1552. kfree(sfd_pl);
  1553. return err;
  1554. }
  1555. static int
  1556. mlxsw_sp_port_fdb_set(struct mlxsw_sp_port *mlxsw_sp_port,
  1557. struct switchdev_notifier_fdb_info *fdb_info, bool adding)
  1558. {
  1559. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_port->mlxsw_sp;
  1560. struct net_device *orig_dev = fdb_info->info.dev;
  1561. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  1562. struct mlxsw_sp_bridge_device *bridge_device;
  1563. struct mlxsw_sp_bridge_port *bridge_port;
  1564. u16 fid_index, vid;
  1565. bridge_port = mlxsw_sp_bridge_port_find(mlxsw_sp->bridge, orig_dev);
  1566. if (!bridge_port)
  1567. return -EINVAL;
  1568. bridge_device = bridge_port->bridge_device;
  1569. mlxsw_sp_port_vlan = mlxsw_sp_port_vlan_find_by_bridge(mlxsw_sp_port,
  1570. bridge_device,
  1571. fdb_info->vid);
  1572. if (!mlxsw_sp_port_vlan)
  1573. return 0;
  1574. fid_index = mlxsw_sp_fid_index(mlxsw_sp_port_vlan->fid);
  1575. vid = mlxsw_sp_port_vlan->vid;
  1576. if (!bridge_port->lagged)
  1577. return mlxsw_sp_port_fdb_uc_op(mlxsw_sp,
  1578. bridge_port->system_port,
  1579. fdb_info->addr, fid_index, vid,
  1580. adding, false);
  1581. else
  1582. return mlxsw_sp_port_fdb_uc_lag_op(mlxsw_sp,
  1583. bridge_port->lag_id,
  1584. fdb_info->addr, fid_index,
  1585. vid, adding, false);
  1586. }
  1587. static int mlxsw_sp_mdb_entry_write(struct mlxsw_sp *mlxsw_sp,
  1588. const struct mlxsw_sp_mdb_entry *mdb_entry,
  1589. bool adding)
  1590. {
  1591. char *sfd_pl;
  1592. u8 num_rec;
  1593. int err;
  1594. sfd_pl = kmalloc(MLXSW_REG_SFD_LEN, GFP_KERNEL);
  1595. if (!sfd_pl)
  1596. return -ENOMEM;
  1597. mlxsw_reg_sfd_pack(sfd_pl, mlxsw_sp_sfd_op(adding), 0);
  1598. mlxsw_reg_sfd_mc_pack(sfd_pl, 0, mdb_entry->key.addr,
  1599. mdb_entry->key.fid, MLXSW_REG_SFD_REC_ACTION_NOP,
  1600. mdb_entry->mid);
  1601. num_rec = mlxsw_reg_sfd_num_rec_get(sfd_pl);
  1602. err = mlxsw_reg_write(mlxsw_sp->core, MLXSW_REG(sfd), sfd_pl);
  1603. if (err)
  1604. goto out;
  1605. if (num_rec != mlxsw_reg_sfd_num_rec_get(sfd_pl))
  1606. err = -EBUSY;
  1607. out:
  1608. kfree(sfd_pl);
  1609. return err;
  1610. }
  1611. static void
  1612. mlxsw_sp_bridge_port_get_ports_bitmap(struct mlxsw_sp *mlxsw_sp,
  1613. struct mlxsw_sp_bridge_port *bridge_port,
  1614. struct mlxsw_sp_ports_bitmap *ports_bm)
  1615. {
  1616. struct mlxsw_sp_port *mlxsw_sp_port;
  1617. u64 max_lag_members, i;
  1618. int lag_id;
  1619. if (!bridge_port->lagged) {
  1620. set_bit(bridge_port->system_port, ports_bm->bitmap);
  1621. } else {
  1622. max_lag_members = MLXSW_CORE_RES_GET(mlxsw_sp->core,
  1623. MAX_LAG_MEMBERS);
  1624. lag_id = bridge_port->lag_id;
  1625. for (i = 0; i < max_lag_members; i++) {
  1626. mlxsw_sp_port = mlxsw_sp_port_lagged_get(mlxsw_sp,
  1627. lag_id, i);
  1628. if (mlxsw_sp_port)
  1629. set_bit(mlxsw_sp_port->local_port,
  1630. ports_bm->bitmap);
  1631. }
  1632. }
  1633. }
  1634. static void
  1635. mlxsw_sp_mc_get_mrouters_bitmap(struct mlxsw_sp_ports_bitmap *flood_bm,
  1636. struct mlxsw_sp_bridge_device *bridge_device,
  1637. struct mlxsw_sp *mlxsw_sp)
  1638. {
  1639. struct mlxsw_sp_bridge_port *bridge_port;
  1640. list_for_each_entry(bridge_port, &bridge_device->ports_list, list) {
  1641. if (bridge_port->mrouter) {
  1642. mlxsw_sp_bridge_port_get_ports_bitmap(mlxsw_sp,
  1643. bridge_port,
  1644. flood_bm);
  1645. }
  1646. }
  1647. }
  1648. static int mlxsw_sp_mc_mdb_mrouters_add(struct mlxsw_sp *mlxsw_sp,
  1649. struct mlxsw_sp_ports_bitmap *ports_bm,
  1650. struct mlxsw_sp_mdb_entry *mdb_entry)
  1651. {
  1652. struct mlxsw_sp_mdb_entry_port *mdb_entry_port;
  1653. unsigned int nbits = ports_bm->nbits;
  1654. int i;
  1655. for_each_set_bit(i, ports_bm->bitmap, nbits) {
  1656. mdb_entry_port = mlxsw_sp_mdb_entry_mrouter_port_get(mlxsw_sp,
  1657. mdb_entry,
  1658. i);
  1659. if (IS_ERR(mdb_entry_port)) {
  1660. nbits = i;
  1661. goto err_mrouter_port_get;
  1662. }
  1663. }
  1664. return 0;
  1665. err_mrouter_port_get:
  1666. for_each_set_bit(i, ports_bm->bitmap, nbits)
  1667. mlxsw_sp_mdb_entry_mrouter_port_put(mlxsw_sp, mdb_entry, i);
  1668. return PTR_ERR(mdb_entry_port);
  1669. }
  1670. static void mlxsw_sp_mc_mdb_mrouters_del(struct mlxsw_sp *mlxsw_sp,
  1671. struct mlxsw_sp_ports_bitmap *ports_bm,
  1672. struct mlxsw_sp_mdb_entry *mdb_entry)
  1673. {
  1674. int i;
  1675. for_each_set_bit(i, ports_bm->bitmap, ports_bm->nbits)
  1676. mlxsw_sp_mdb_entry_mrouter_port_put(mlxsw_sp, mdb_entry, i);
  1677. }
  1678. static int
  1679. mlxsw_sp_mc_mdb_mrouters_set(struct mlxsw_sp *mlxsw_sp,
  1680. struct mlxsw_sp_bridge_device *bridge_device,
  1681. struct mlxsw_sp_mdb_entry *mdb_entry, bool add)
  1682. {
  1683. struct mlxsw_sp_ports_bitmap ports_bm;
  1684. int err;
  1685. err = mlxsw_sp_port_bitmap_init(mlxsw_sp, &ports_bm);
  1686. if (err)
  1687. return err;
  1688. mlxsw_sp_mc_get_mrouters_bitmap(&ports_bm, bridge_device, mlxsw_sp);
  1689. if (add)
  1690. err = mlxsw_sp_mc_mdb_mrouters_add(mlxsw_sp, &ports_bm,
  1691. mdb_entry);
  1692. else
  1693. mlxsw_sp_mc_mdb_mrouters_del(mlxsw_sp, &ports_bm, mdb_entry);
  1694. mlxsw_sp_port_bitmap_fini(&ports_bm);
  1695. return err;
  1696. }
  1697. static struct mlxsw_sp_mdb_entry *
  1698. mlxsw_sp_mc_mdb_entry_init(struct mlxsw_sp *mlxsw_sp,
  1699. struct mlxsw_sp_bridge_device *bridge_device,
  1700. const unsigned char *addr, u16 fid, u16 local_port)
  1701. {
  1702. struct mlxsw_sp_mdb_entry_port *mdb_entry_port;
  1703. struct mlxsw_sp_mdb_entry *mdb_entry;
  1704. int err;
  1705. mdb_entry = kzalloc_obj(*mdb_entry);
  1706. if (!mdb_entry)
  1707. return ERR_PTR(-ENOMEM);
  1708. ether_addr_copy(mdb_entry->key.addr, addr);
  1709. mdb_entry->key.fid = fid;
  1710. err = mlxsw_sp_pgt_mid_alloc(mlxsw_sp, &mdb_entry->mid);
  1711. if (err)
  1712. goto err_pgt_mid_alloc;
  1713. INIT_LIST_HEAD(&mdb_entry->ports_list);
  1714. err = mlxsw_sp_mc_mdb_mrouters_set(mlxsw_sp, bridge_device, mdb_entry,
  1715. true);
  1716. if (err)
  1717. goto err_mdb_mrouters_set;
  1718. mdb_entry_port = mlxsw_sp_mdb_entry_port_get(mlxsw_sp, mdb_entry,
  1719. local_port);
  1720. if (IS_ERR(mdb_entry_port)) {
  1721. err = PTR_ERR(mdb_entry_port);
  1722. goto err_mdb_entry_port_get;
  1723. }
  1724. if (bridge_device->multicast_enabled) {
  1725. err = mlxsw_sp_mdb_entry_write(mlxsw_sp, mdb_entry, true);
  1726. if (err)
  1727. goto err_mdb_entry_write;
  1728. }
  1729. err = rhashtable_insert_fast(&bridge_device->mdb_ht,
  1730. &mdb_entry->ht_node,
  1731. mlxsw_sp_mdb_ht_params);
  1732. if (err)
  1733. goto err_rhashtable_insert;
  1734. list_add_tail(&mdb_entry->list, &bridge_device->mdb_list);
  1735. return mdb_entry;
  1736. err_rhashtable_insert:
  1737. if (bridge_device->multicast_enabled)
  1738. mlxsw_sp_mdb_entry_write(mlxsw_sp, mdb_entry, false);
  1739. err_mdb_entry_write:
  1740. mlxsw_sp_mdb_entry_port_put(mlxsw_sp, mdb_entry, local_port, false);
  1741. err_mdb_entry_port_get:
  1742. mlxsw_sp_mc_mdb_mrouters_set(mlxsw_sp, bridge_device, mdb_entry, false);
  1743. err_mdb_mrouters_set:
  1744. mlxsw_sp_pgt_mid_free(mlxsw_sp, mdb_entry->mid);
  1745. err_pgt_mid_alloc:
  1746. kfree(mdb_entry);
  1747. return ERR_PTR(err);
  1748. }
  1749. static void
  1750. mlxsw_sp_mc_mdb_entry_fini(struct mlxsw_sp *mlxsw_sp,
  1751. struct mlxsw_sp_mdb_entry *mdb_entry,
  1752. struct mlxsw_sp_bridge_device *bridge_device,
  1753. u16 local_port, bool force)
  1754. {
  1755. list_del(&mdb_entry->list);
  1756. rhashtable_remove_fast(&bridge_device->mdb_ht, &mdb_entry->ht_node,
  1757. mlxsw_sp_mdb_ht_params);
  1758. if (bridge_device->multicast_enabled)
  1759. mlxsw_sp_mdb_entry_write(mlxsw_sp, mdb_entry, false);
  1760. mlxsw_sp_mdb_entry_port_put(mlxsw_sp, mdb_entry, local_port, force);
  1761. mlxsw_sp_mc_mdb_mrouters_set(mlxsw_sp, bridge_device, mdb_entry, false);
  1762. WARN_ON(!list_empty(&mdb_entry->ports_list));
  1763. mlxsw_sp_pgt_mid_free(mlxsw_sp, mdb_entry->mid);
  1764. kfree(mdb_entry);
  1765. }
  1766. static struct mlxsw_sp_mdb_entry *
  1767. mlxsw_sp_mc_mdb_entry_get(struct mlxsw_sp *mlxsw_sp,
  1768. struct mlxsw_sp_bridge_device *bridge_device,
  1769. const unsigned char *addr, u16 fid, u16 local_port)
  1770. {
  1771. struct mlxsw_sp_mdb_entry_key key = {};
  1772. struct mlxsw_sp_mdb_entry *mdb_entry;
  1773. ether_addr_copy(key.addr, addr);
  1774. key.fid = fid;
  1775. mdb_entry = rhashtable_lookup_fast(&bridge_device->mdb_ht, &key,
  1776. mlxsw_sp_mdb_ht_params);
  1777. if (mdb_entry) {
  1778. struct mlxsw_sp_mdb_entry_port *mdb_entry_port;
  1779. mdb_entry_port = mlxsw_sp_mdb_entry_port_get(mlxsw_sp,
  1780. mdb_entry,
  1781. local_port);
  1782. if (IS_ERR(mdb_entry_port))
  1783. return ERR_CAST(mdb_entry_port);
  1784. return mdb_entry;
  1785. }
  1786. return mlxsw_sp_mc_mdb_entry_init(mlxsw_sp, bridge_device, addr, fid,
  1787. local_port);
  1788. }
  1789. static bool
  1790. mlxsw_sp_mc_mdb_entry_remove(struct mlxsw_sp_mdb_entry *mdb_entry,
  1791. struct mlxsw_sp_mdb_entry_port *removed_entry_port,
  1792. bool force)
  1793. {
  1794. if (mdb_entry->ports_count > 1)
  1795. return false;
  1796. if (force)
  1797. return true;
  1798. if (!removed_entry_port->mrouter &&
  1799. refcount_read(&removed_entry_port->refcount) > 1)
  1800. return false;
  1801. if (removed_entry_port->mrouter &&
  1802. refcount_read(&removed_entry_port->refcount) > 2)
  1803. return false;
  1804. return true;
  1805. }
  1806. static void
  1807. mlxsw_sp_mc_mdb_entry_put(struct mlxsw_sp *mlxsw_sp,
  1808. struct mlxsw_sp_bridge_device *bridge_device,
  1809. struct mlxsw_sp_mdb_entry *mdb_entry, u16 local_port,
  1810. bool force)
  1811. {
  1812. struct mlxsw_sp_mdb_entry_port *mdb_entry_port;
  1813. mdb_entry_port = mlxsw_sp_mdb_entry_port_lookup(mdb_entry, local_port);
  1814. if (!mdb_entry_port)
  1815. return;
  1816. /* Avoid a temporary situation in which the MDB entry points to an empty
  1817. * PGT entry, as otherwise packets will be temporarily dropped instead
  1818. * of being flooded. Instead, in this situation, call
  1819. * mlxsw_sp_mc_mdb_entry_fini(), which first deletes the MDB entry and
  1820. * then releases the PGT entry.
  1821. */
  1822. if (mlxsw_sp_mc_mdb_entry_remove(mdb_entry, mdb_entry_port, force))
  1823. mlxsw_sp_mc_mdb_entry_fini(mlxsw_sp, mdb_entry, bridge_device,
  1824. local_port, force);
  1825. else
  1826. mlxsw_sp_mdb_entry_port_put(mlxsw_sp, mdb_entry, local_port,
  1827. force);
  1828. }
  1829. static int mlxsw_sp_port_mdb_add(struct mlxsw_sp_port *mlxsw_sp_port,
  1830. const struct switchdev_obj_port_mdb *mdb)
  1831. {
  1832. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_port->mlxsw_sp;
  1833. struct net_device *orig_dev = mdb->obj.orig_dev;
  1834. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  1835. struct mlxsw_sp_bridge_device *bridge_device;
  1836. struct mlxsw_sp_bridge_port *bridge_port;
  1837. struct mlxsw_sp_mdb_entry *mdb_entry;
  1838. u16 fid_index;
  1839. bridge_port = mlxsw_sp_bridge_port_find(mlxsw_sp->bridge, orig_dev);
  1840. if (!bridge_port)
  1841. return 0;
  1842. bridge_device = bridge_port->bridge_device;
  1843. mlxsw_sp_port_vlan = mlxsw_sp_port_vlan_find_by_bridge(mlxsw_sp_port,
  1844. bridge_device,
  1845. mdb->vid);
  1846. if (!mlxsw_sp_port_vlan)
  1847. return 0;
  1848. fid_index = mlxsw_sp_fid_index(mlxsw_sp_port_vlan->fid);
  1849. mdb_entry = mlxsw_sp_mc_mdb_entry_get(mlxsw_sp, bridge_device,
  1850. mdb->addr, fid_index,
  1851. mlxsw_sp_port->local_port);
  1852. if (IS_ERR(mdb_entry))
  1853. return PTR_ERR(mdb_entry);
  1854. return 0;
  1855. }
  1856. static int
  1857. mlxsw_sp_bridge_mdb_mc_enable_sync(struct mlxsw_sp *mlxsw_sp,
  1858. struct mlxsw_sp_bridge_device *bridge_device,
  1859. bool mc_enabled)
  1860. {
  1861. struct mlxsw_sp_mdb_entry *mdb_entry;
  1862. int err;
  1863. list_for_each_entry(mdb_entry, &bridge_device->mdb_list, list) {
  1864. err = mlxsw_sp_mdb_entry_write(mlxsw_sp, mdb_entry, mc_enabled);
  1865. if (err)
  1866. goto err_mdb_entry_write;
  1867. }
  1868. return 0;
  1869. err_mdb_entry_write:
  1870. list_for_each_entry_continue_reverse(mdb_entry,
  1871. &bridge_device->mdb_list, list)
  1872. mlxsw_sp_mdb_entry_write(mlxsw_sp, mdb_entry, !mc_enabled);
  1873. return err;
  1874. }
  1875. static void
  1876. mlxsw_sp_port_mrouter_update_mdb(struct mlxsw_sp_port *mlxsw_sp_port,
  1877. struct mlxsw_sp_bridge_port *bridge_port,
  1878. bool add)
  1879. {
  1880. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_port->mlxsw_sp;
  1881. struct mlxsw_sp_bridge_device *bridge_device;
  1882. u16 local_port = mlxsw_sp_port->local_port;
  1883. struct mlxsw_sp_mdb_entry *mdb_entry;
  1884. bridge_device = bridge_port->bridge_device;
  1885. list_for_each_entry(mdb_entry, &bridge_device->mdb_list, list) {
  1886. if (add)
  1887. mlxsw_sp_mdb_entry_mrouter_port_get(mlxsw_sp, mdb_entry,
  1888. local_port);
  1889. else
  1890. mlxsw_sp_mdb_entry_mrouter_port_put(mlxsw_sp, mdb_entry,
  1891. local_port);
  1892. }
  1893. }
  1894. static int mlxsw_sp_port_obj_add(struct net_device *dev, const void *ctx,
  1895. const struct switchdev_obj *obj,
  1896. struct netlink_ext_ack *extack)
  1897. {
  1898. struct mlxsw_sp_port *mlxsw_sp_port = netdev_priv(dev);
  1899. const struct switchdev_obj_port_vlan *vlan;
  1900. int err = 0;
  1901. switch (obj->id) {
  1902. case SWITCHDEV_OBJ_ID_PORT_VLAN:
  1903. vlan = SWITCHDEV_OBJ_PORT_VLAN(obj);
  1904. err = mlxsw_sp_port_vlans_add(mlxsw_sp_port, vlan, extack);
  1905. /* The event is emitted before the changes are actually
  1906. * applied to the bridge. Therefore schedule the respin
  1907. * call for later, so that the respin logic sees the
  1908. * updated bridge state.
  1909. */
  1910. mlxsw_sp_span_respin(mlxsw_sp_port->mlxsw_sp);
  1911. break;
  1912. case SWITCHDEV_OBJ_ID_PORT_MDB:
  1913. err = mlxsw_sp_port_mdb_add(mlxsw_sp_port,
  1914. SWITCHDEV_OBJ_PORT_MDB(obj));
  1915. break;
  1916. default:
  1917. err = -EOPNOTSUPP;
  1918. break;
  1919. }
  1920. return err;
  1921. }
  1922. static void
  1923. mlxsw_sp_bridge_port_vlan_del(struct mlxsw_sp_port *mlxsw_sp_port,
  1924. struct mlxsw_sp_bridge_port *bridge_port, u16 vid)
  1925. {
  1926. u16 pvid = mlxsw_sp_port->pvid == vid ? 0 : mlxsw_sp_port->pvid;
  1927. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  1928. u16 proto;
  1929. mlxsw_sp_port_vlan = mlxsw_sp_port_vlan_find_by_vid(mlxsw_sp_port, vid);
  1930. if (WARN_ON(!mlxsw_sp_port_vlan))
  1931. return;
  1932. mlxsw_sp_port_vlan_bridge_leave(mlxsw_sp_port_vlan);
  1933. br_vlan_get_proto(bridge_port->bridge_device->dev, &proto);
  1934. mlxsw_sp_port_pvid_set(mlxsw_sp_port, pvid, proto);
  1935. mlxsw_sp_port_vlan_set(mlxsw_sp_port, vid, vid, false, false);
  1936. mlxsw_sp_port_vlan_destroy(mlxsw_sp_port_vlan);
  1937. }
  1938. static int mlxsw_sp_port_vlans_del(struct mlxsw_sp_port *mlxsw_sp_port,
  1939. const struct switchdev_obj_port_vlan *vlan)
  1940. {
  1941. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_port->mlxsw_sp;
  1942. struct net_device *orig_dev = vlan->obj.orig_dev;
  1943. struct mlxsw_sp_bridge_port *bridge_port;
  1944. if (netif_is_bridge_master(orig_dev))
  1945. return -EOPNOTSUPP;
  1946. bridge_port = mlxsw_sp_bridge_port_find(mlxsw_sp->bridge, orig_dev);
  1947. if (WARN_ON(!bridge_port))
  1948. return -EINVAL;
  1949. if (!bridge_port->bridge_device->vlan_enabled)
  1950. return 0;
  1951. mlxsw_sp_bridge_port_vlan_del(mlxsw_sp_port, bridge_port, vlan->vid);
  1952. return 0;
  1953. }
  1954. static int mlxsw_sp_port_mdb_del(struct mlxsw_sp_port *mlxsw_sp_port,
  1955. const struct switchdev_obj_port_mdb *mdb)
  1956. {
  1957. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_port->mlxsw_sp;
  1958. struct net_device *orig_dev = mdb->obj.orig_dev;
  1959. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  1960. struct mlxsw_sp_bridge_device *bridge_device;
  1961. struct net_device *dev = mlxsw_sp_port->dev;
  1962. struct mlxsw_sp_bridge_port *bridge_port;
  1963. struct mlxsw_sp_mdb_entry_key key = {};
  1964. struct mlxsw_sp_mdb_entry *mdb_entry;
  1965. u16 fid_index;
  1966. bridge_port = mlxsw_sp_bridge_port_find(mlxsw_sp->bridge, orig_dev);
  1967. if (!bridge_port)
  1968. return 0;
  1969. bridge_device = bridge_port->bridge_device;
  1970. mlxsw_sp_port_vlan = mlxsw_sp_port_vlan_find_by_bridge(mlxsw_sp_port,
  1971. bridge_device,
  1972. mdb->vid);
  1973. if (!mlxsw_sp_port_vlan)
  1974. return 0;
  1975. fid_index = mlxsw_sp_fid_index(mlxsw_sp_port_vlan->fid);
  1976. ether_addr_copy(key.addr, mdb->addr);
  1977. key.fid = fid_index;
  1978. mdb_entry = rhashtable_lookup_fast(&bridge_device->mdb_ht, &key,
  1979. mlxsw_sp_mdb_ht_params);
  1980. if (!mdb_entry) {
  1981. netdev_err(dev, "Unable to remove port from MC DB\n");
  1982. return -EINVAL;
  1983. }
  1984. mlxsw_sp_mc_mdb_entry_put(mlxsw_sp, bridge_device, mdb_entry,
  1985. mlxsw_sp_port->local_port, false);
  1986. return 0;
  1987. }
  1988. static void
  1989. mlxsw_sp_bridge_port_mdb_flush(struct mlxsw_sp_port *mlxsw_sp_port,
  1990. struct mlxsw_sp_bridge_port *bridge_port,
  1991. u16 fid_index)
  1992. {
  1993. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_port->mlxsw_sp;
  1994. struct mlxsw_sp_bridge_device *bridge_device;
  1995. struct mlxsw_sp_mdb_entry *mdb_entry, *tmp;
  1996. u16 local_port = mlxsw_sp_port->local_port;
  1997. bridge_device = bridge_port->bridge_device;
  1998. list_for_each_entry_safe(mdb_entry, tmp, &bridge_device->mdb_list,
  1999. list) {
  2000. if (mdb_entry->key.fid != fid_index)
  2001. continue;
  2002. if (bridge_port->mrouter)
  2003. mlxsw_sp_mdb_entry_mrouter_port_put(mlxsw_sp,
  2004. mdb_entry,
  2005. local_port);
  2006. mlxsw_sp_mc_mdb_entry_put(mlxsw_sp, bridge_device, mdb_entry,
  2007. local_port, true);
  2008. }
  2009. }
  2010. static int mlxsw_sp_port_obj_del(struct net_device *dev, const void *ctx,
  2011. const struct switchdev_obj *obj)
  2012. {
  2013. struct mlxsw_sp_port *mlxsw_sp_port = netdev_priv(dev);
  2014. int err = 0;
  2015. switch (obj->id) {
  2016. case SWITCHDEV_OBJ_ID_PORT_VLAN:
  2017. err = mlxsw_sp_port_vlans_del(mlxsw_sp_port,
  2018. SWITCHDEV_OBJ_PORT_VLAN(obj));
  2019. break;
  2020. case SWITCHDEV_OBJ_ID_PORT_MDB:
  2021. err = mlxsw_sp_port_mdb_del(mlxsw_sp_port,
  2022. SWITCHDEV_OBJ_PORT_MDB(obj));
  2023. break;
  2024. default:
  2025. err = -EOPNOTSUPP;
  2026. break;
  2027. }
  2028. mlxsw_sp_span_respin(mlxsw_sp_port->mlxsw_sp);
  2029. return err;
  2030. }
  2031. static struct mlxsw_sp_port *mlxsw_sp_lag_rep_port(struct mlxsw_sp *mlxsw_sp,
  2032. u16 lag_id)
  2033. {
  2034. struct mlxsw_sp_port *mlxsw_sp_port;
  2035. u64 max_lag_members;
  2036. int i;
  2037. max_lag_members = MLXSW_CORE_RES_GET(mlxsw_sp->core,
  2038. MAX_LAG_MEMBERS);
  2039. for (i = 0; i < max_lag_members; i++) {
  2040. mlxsw_sp_port = mlxsw_sp_port_lagged_get(mlxsw_sp, lag_id, i);
  2041. if (mlxsw_sp_port)
  2042. return mlxsw_sp_port;
  2043. }
  2044. return NULL;
  2045. }
  2046. static int
  2047. mlxsw_sp_bridge_port_replay(struct mlxsw_sp_bridge_port *bridge_port,
  2048. struct mlxsw_sp_port *mlxsw_sp_port,
  2049. struct netlink_ext_ack *extack)
  2050. {
  2051. struct mlxsw_sp_bridge_port_replay_switchdev_objs rso = {
  2052. .brport_dev = bridge_port->dev,
  2053. .mlxsw_sp_port = mlxsw_sp_port,
  2054. };
  2055. struct notifier_block *nb;
  2056. int err;
  2057. nb = &mlxsw_sp_bridge_port_replay_switchdev_objs_nb;
  2058. err = switchdev_bridge_port_replay(bridge_port->dev, mlxsw_sp_port->dev,
  2059. &rso, NULL, nb, extack);
  2060. if (err)
  2061. goto err_replay;
  2062. return 0;
  2063. err_replay:
  2064. nb = &mlxsw_sp_bridge_port_unreplay_switchdev_objs_nb;
  2065. switchdev_bridge_port_replay(bridge_port->dev, mlxsw_sp_port->dev,
  2066. &rso, NULL, nb, extack);
  2067. return err;
  2068. }
  2069. static int
  2070. mlxsw_sp_bridge_vlan_aware_port_join(struct mlxsw_sp_bridge_port *bridge_port,
  2071. struct mlxsw_sp_port *mlxsw_sp_port,
  2072. struct netlink_ext_ack *extack)
  2073. {
  2074. if (is_vlan_dev(bridge_port->dev)) {
  2075. NL_SET_ERR_MSG_MOD(extack, "Can not enslave a VLAN device to a VLAN-aware bridge");
  2076. return -EINVAL;
  2077. }
  2078. /* Port is no longer usable as a router interface */
  2079. if (mlxsw_sp_port->default_vlan->fid)
  2080. mlxsw_sp_port_vlan_router_leave(mlxsw_sp_port->default_vlan);
  2081. return mlxsw_sp_bridge_port_replay(bridge_port, mlxsw_sp_port, extack);
  2082. }
  2083. static int
  2084. mlxsw_sp_bridge_8021q_port_join(struct mlxsw_sp_bridge_device *bridge_device,
  2085. struct mlxsw_sp_bridge_port *bridge_port,
  2086. struct mlxsw_sp_port *mlxsw_sp_port,
  2087. struct netlink_ext_ack *extack)
  2088. {
  2089. return mlxsw_sp_bridge_vlan_aware_port_join(bridge_port, mlxsw_sp_port,
  2090. extack);
  2091. }
  2092. static void
  2093. mlxsw_sp_bridge_vlan_aware_port_leave(struct mlxsw_sp_port *mlxsw_sp_port)
  2094. {
  2095. /* Make sure untagged frames are allowed to ingress */
  2096. mlxsw_sp_port_pvid_set(mlxsw_sp_port, MLXSW_SP_DEFAULT_VID,
  2097. ETH_P_8021Q);
  2098. }
  2099. static void
  2100. mlxsw_sp_bridge_8021q_port_leave(struct mlxsw_sp_bridge_device *bridge_device,
  2101. struct mlxsw_sp_bridge_port *bridge_port,
  2102. struct mlxsw_sp_port *mlxsw_sp_port)
  2103. {
  2104. mlxsw_sp_bridge_vlan_aware_port_leave(mlxsw_sp_port);
  2105. }
  2106. static int
  2107. mlxsw_sp_bridge_vlan_aware_vxlan_join(struct mlxsw_sp_bridge_device *bridge_device,
  2108. const struct net_device *vxlan_dev,
  2109. u16 vid, u16 ethertype,
  2110. struct netlink_ext_ack *extack)
  2111. {
  2112. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_lower_get(bridge_device->dev);
  2113. struct vxlan_dev *vxlan = netdev_priv(vxlan_dev);
  2114. struct mlxsw_sp_nve_params params = {
  2115. .type = MLXSW_SP_NVE_TYPE_VXLAN,
  2116. .vni = vxlan->cfg.vni,
  2117. .dev = vxlan_dev,
  2118. .ethertype = ethertype,
  2119. };
  2120. struct mlxsw_sp_fid *fid;
  2121. int err;
  2122. /* If the VLAN is 0, we need to find the VLAN that is configured as
  2123. * PVID and egress untagged on the bridge port of the VxLAN device.
  2124. * It is possible no such VLAN exists
  2125. */
  2126. if (!vid) {
  2127. err = mlxsw_sp_vxlan_mapped_vid(vxlan_dev, &vid);
  2128. if (err || !vid)
  2129. return err;
  2130. }
  2131. fid = mlxsw_sp_fid_8021q_get(mlxsw_sp, vid);
  2132. if (IS_ERR(fid)) {
  2133. NL_SET_ERR_MSG_MOD(extack, "Failed to create 802.1Q FID");
  2134. return PTR_ERR(fid);
  2135. }
  2136. if (mlxsw_sp_fid_vni_is_set(fid)) {
  2137. NL_SET_ERR_MSG_MOD(extack, "VNI is already set on FID");
  2138. err = -EINVAL;
  2139. goto err_vni_exists;
  2140. }
  2141. err = mlxsw_sp_nve_fid_enable(mlxsw_sp, fid, &params, extack);
  2142. if (err)
  2143. goto err_nve_fid_enable;
  2144. return 0;
  2145. err_nve_fid_enable:
  2146. err_vni_exists:
  2147. mlxsw_sp_fid_put(fid);
  2148. return err;
  2149. }
  2150. static int
  2151. mlxsw_sp_bridge_8021q_vxlan_join(struct mlxsw_sp_bridge_device *bridge_device,
  2152. const struct net_device *vxlan_dev, u16 vid,
  2153. struct netlink_ext_ack *extack)
  2154. {
  2155. return mlxsw_sp_bridge_vlan_aware_vxlan_join(bridge_device, vxlan_dev,
  2156. vid, ETH_P_8021Q, extack);
  2157. }
  2158. static struct net_device *
  2159. mlxsw_sp_bridge_8021q_vxlan_dev_find(struct net_device *br_dev, u16 vid)
  2160. {
  2161. struct net_device *dev;
  2162. struct list_head *iter;
  2163. netdev_for_each_lower_dev(br_dev, dev, iter) {
  2164. u16 pvid;
  2165. int err;
  2166. if (!netif_is_vxlan(dev))
  2167. continue;
  2168. err = mlxsw_sp_vxlan_mapped_vid(dev, &pvid);
  2169. if (err || pvid != vid)
  2170. continue;
  2171. return dev;
  2172. }
  2173. return NULL;
  2174. }
  2175. static struct mlxsw_sp_fid *
  2176. mlxsw_sp_bridge_8021q_fid_get(struct mlxsw_sp_bridge_device *bridge_device,
  2177. u16 vid, struct netlink_ext_ack *extack)
  2178. {
  2179. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_lower_get(bridge_device->dev);
  2180. return mlxsw_sp_fid_8021q_get(mlxsw_sp, vid);
  2181. }
  2182. static struct mlxsw_sp_fid *
  2183. mlxsw_sp_bridge_8021q_fid_lookup(struct mlxsw_sp_bridge_device *bridge_device,
  2184. u16 vid)
  2185. {
  2186. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_lower_get(bridge_device->dev);
  2187. return mlxsw_sp_fid_8021q_lookup(mlxsw_sp, vid);
  2188. }
  2189. static u16
  2190. mlxsw_sp_bridge_8021q_fid_vid(struct mlxsw_sp_bridge_device *bridge_device,
  2191. const struct mlxsw_sp_fid *fid)
  2192. {
  2193. return mlxsw_sp_fid_8021q_vid(fid);
  2194. }
  2195. static const struct mlxsw_sp_bridge_ops mlxsw_sp_bridge_8021q_ops = {
  2196. .port_join = mlxsw_sp_bridge_8021q_port_join,
  2197. .port_leave = mlxsw_sp_bridge_8021q_port_leave,
  2198. .vxlan_join = mlxsw_sp_bridge_8021q_vxlan_join,
  2199. .fid_get = mlxsw_sp_bridge_8021q_fid_get,
  2200. .fid_lookup = mlxsw_sp_bridge_8021q_fid_lookup,
  2201. .fid_vid = mlxsw_sp_bridge_8021q_fid_vid,
  2202. };
  2203. static bool
  2204. mlxsw_sp_port_is_br_member(const struct mlxsw_sp_port *mlxsw_sp_port,
  2205. const struct net_device *br_dev)
  2206. {
  2207. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  2208. list_for_each_entry(mlxsw_sp_port_vlan, &mlxsw_sp_port->vlans_list,
  2209. list) {
  2210. if (mlxsw_sp_port_vlan->bridge_port &&
  2211. mlxsw_sp_port_vlan->bridge_port->bridge_device->dev ==
  2212. br_dev)
  2213. return true;
  2214. }
  2215. return false;
  2216. }
  2217. static int
  2218. mlxsw_sp_bridge_8021d_port_join(struct mlxsw_sp_bridge_device *bridge_device,
  2219. struct mlxsw_sp_bridge_port *bridge_port,
  2220. struct mlxsw_sp_port *mlxsw_sp_port,
  2221. struct netlink_ext_ack *extack)
  2222. {
  2223. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  2224. struct net_device *dev = bridge_port->dev;
  2225. u16 vid;
  2226. int err;
  2227. vid = is_vlan_dev(dev) ? vlan_dev_vlan_id(dev) : MLXSW_SP_DEFAULT_VID;
  2228. mlxsw_sp_port_vlan = mlxsw_sp_port_vlan_find_by_vid(mlxsw_sp_port, vid);
  2229. if (WARN_ON(!mlxsw_sp_port_vlan))
  2230. return -EINVAL;
  2231. if (mlxsw_sp_port_is_br_member(mlxsw_sp_port, bridge_device->dev)) {
  2232. NL_SET_ERR_MSG_MOD(extack, "Can not bridge VLAN uppers of the same port");
  2233. return -EINVAL;
  2234. }
  2235. /* Port is no longer usable as a router interface */
  2236. if (mlxsw_sp_port_vlan->fid)
  2237. mlxsw_sp_port_vlan_router_leave(mlxsw_sp_port_vlan);
  2238. err = mlxsw_sp_port_vlan_bridge_join(mlxsw_sp_port_vlan, bridge_port,
  2239. extack);
  2240. if (err)
  2241. return err;
  2242. err = mlxsw_sp_bridge_port_replay(bridge_port, mlxsw_sp_port, extack);
  2243. if (err)
  2244. goto err_replay;
  2245. return 0;
  2246. err_replay:
  2247. mlxsw_sp_port_vlan_bridge_leave(mlxsw_sp_port_vlan);
  2248. return err;
  2249. }
  2250. static void
  2251. mlxsw_sp_bridge_8021d_port_leave(struct mlxsw_sp_bridge_device *bridge_device,
  2252. struct mlxsw_sp_bridge_port *bridge_port,
  2253. struct mlxsw_sp_port *mlxsw_sp_port)
  2254. {
  2255. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  2256. struct net_device *dev = bridge_port->dev;
  2257. u16 vid;
  2258. vid = is_vlan_dev(dev) ? vlan_dev_vlan_id(dev) : MLXSW_SP_DEFAULT_VID;
  2259. mlxsw_sp_port_vlan = mlxsw_sp_port_vlan_find_by_vid(mlxsw_sp_port, vid);
  2260. if (!mlxsw_sp_port_vlan || !mlxsw_sp_port_vlan->bridge_port)
  2261. return;
  2262. mlxsw_sp_port_vlan_bridge_leave(mlxsw_sp_port_vlan);
  2263. }
  2264. static int
  2265. mlxsw_sp_bridge_8021d_vxlan_join(struct mlxsw_sp_bridge_device *bridge_device,
  2266. const struct net_device *vxlan_dev, u16 vid,
  2267. struct netlink_ext_ack *extack)
  2268. {
  2269. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_lower_get(bridge_device->dev);
  2270. struct vxlan_dev *vxlan = netdev_priv(vxlan_dev);
  2271. struct mlxsw_sp_nve_params params = {
  2272. .type = MLXSW_SP_NVE_TYPE_VXLAN,
  2273. .vni = vxlan->cfg.vni,
  2274. .dev = vxlan_dev,
  2275. .ethertype = ETH_P_8021Q,
  2276. };
  2277. struct mlxsw_sp_fid *fid;
  2278. int err;
  2279. fid = mlxsw_sp_fid_8021d_get(mlxsw_sp, bridge_device->dev->ifindex);
  2280. if (IS_ERR(fid)) {
  2281. NL_SET_ERR_MSG_MOD(extack, "Failed to create 802.1D FID");
  2282. return -EINVAL;
  2283. }
  2284. if (mlxsw_sp_fid_vni_is_set(fid)) {
  2285. NL_SET_ERR_MSG_MOD(extack, "VNI is already set on FID");
  2286. err = -EINVAL;
  2287. goto err_vni_exists;
  2288. }
  2289. err = mlxsw_sp_nve_fid_enable(mlxsw_sp, fid, &params, extack);
  2290. if (err)
  2291. goto err_nve_fid_enable;
  2292. return 0;
  2293. err_nve_fid_enable:
  2294. err_vni_exists:
  2295. mlxsw_sp_fid_put(fid);
  2296. return err;
  2297. }
  2298. static struct mlxsw_sp_fid *
  2299. mlxsw_sp_bridge_8021d_fid_get(struct mlxsw_sp_bridge_device *bridge_device,
  2300. u16 vid, struct netlink_ext_ack *extack)
  2301. {
  2302. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_lower_get(bridge_device->dev);
  2303. return mlxsw_sp_fid_8021d_get(mlxsw_sp, bridge_device->dev->ifindex);
  2304. }
  2305. static struct mlxsw_sp_fid *
  2306. mlxsw_sp_bridge_8021d_fid_lookup(struct mlxsw_sp_bridge_device *bridge_device,
  2307. u16 vid)
  2308. {
  2309. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_lower_get(bridge_device->dev);
  2310. /* The only valid VLAN for a VLAN-unaware bridge is 0 */
  2311. if (vid)
  2312. return NULL;
  2313. return mlxsw_sp_fid_8021d_lookup(mlxsw_sp, bridge_device->dev->ifindex);
  2314. }
  2315. static u16
  2316. mlxsw_sp_bridge_8021d_fid_vid(struct mlxsw_sp_bridge_device *bridge_device,
  2317. const struct mlxsw_sp_fid *fid)
  2318. {
  2319. return 0;
  2320. }
  2321. static const struct mlxsw_sp_bridge_ops mlxsw_sp_bridge_8021d_ops = {
  2322. .port_join = mlxsw_sp_bridge_8021d_port_join,
  2323. .port_leave = mlxsw_sp_bridge_8021d_port_leave,
  2324. .vxlan_join = mlxsw_sp_bridge_8021d_vxlan_join,
  2325. .fid_get = mlxsw_sp_bridge_8021d_fid_get,
  2326. .fid_lookup = mlxsw_sp_bridge_8021d_fid_lookup,
  2327. .fid_vid = mlxsw_sp_bridge_8021d_fid_vid,
  2328. };
  2329. static int
  2330. mlxsw_sp_bridge_8021ad_port_join(struct mlxsw_sp_bridge_device *bridge_device,
  2331. struct mlxsw_sp_bridge_port *bridge_port,
  2332. struct mlxsw_sp_port *mlxsw_sp_port,
  2333. struct netlink_ext_ack *extack)
  2334. {
  2335. int err;
  2336. err = mlxsw_sp_port_vlan_classification_set(mlxsw_sp_port, true, false);
  2337. if (err)
  2338. return err;
  2339. err = mlxsw_sp_bridge_vlan_aware_port_join(bridge_port, mlxsw_sp_port,
  2340. extack);
  2341. if (err)
  2342. goto err_bridge_vlan_aware_port_join;
  2343. return 0;
  2344. err_bridge_vlan_aware_port_join:
  2345. mlxsw_sp_port_vlan_classification_set(mlxsw_sp_port, false, true);
  2346. return err;
  2347. }
  2348. static void
  2349. mlxsw_sp_bridge_8021ad_port_leave(struct mlxsw_sp_bridge_device *bridge_device,
  2350. struct mlxsw_sp_bridge_port *bridge_port,
  2351. struct mlxsw_sp_port *mlxsw_sp_port)
  2352. {
  2353. mlxsw_sp_bridge_vlan_aware_port_leave(mlxsw_sp_port);
  2354. mlxsw_sp_port_vlan_classification_set(mlxsw_sp_port, false, true);
  2355. }
  2356. static int
  2357. mlxsw_sp_bridge_8021ad_vxlan_join(struct mlxsw_sp_bridge_device *bridge_device,
  2358. const struct net_device *vxlan_dev, u16 vid,
  2359. struct netlink_ext_ack *extack)
  2360. {
  2361. return mlxsw_sp_bridge_vlan_aware_vxlan_join(bridge_device, vxlan_dev,
  2362. vid, ETH_P_8021AD, extack);
  2363. }
  2364. static const struct mlxsw_sp_bridge_ops mlxsw_sp1_bridge_8021ad_ops = {
  2365. .port_join = mlxsw_sp_bridge_8021ad_port_join,
  2366. .port_leave = mlxsw_sp_bridge_8021ad_port_leave,
  2367. .vxlan_join = mlxsw_sp_bridge_8021ad_vxlan_join,
  2368. .fid_get = mlxsw_sp_bridge_8021q_fid_get,
  2369. .fid_lookup = mlxsw_sp_bridge_8021q_fid_lookup,
  2370. .fid_vid = mlxsw_sp_bridge_8021q_fid_vid,
  2371. };
  2372. static int
  2373. mlxsw_sp2_bridge_8021ad_port_join(struct mlxsw_sp_bridge_device *bridge_device,
  2374. struct mlxsw_sp_bridge_port *bridge_port,
  2375. struct mlxsw_sp_port *mlxsw_sp_port,
  2376. struct netlink_ext_ack *extack)
  2377. {
  2378. int err;
  2379. /* The EtherType of decapsulated packets is determined at the egress
  2380. * port to allow 802.1d and 802.1ad bridges with VXLAN devices to
  2381. * co-exist.
  2382. */
  2383. err = mlxsw_sp_port_egress_ethtype_set(mlxsw_sp_port, ETH_P_8021AD);
  2384. if (err)
  2385. return err;
  2386. err = mlxsw_sp_bridge_8021ad_port_join(bridge_device, bridge_port,
  2387. mlxsw_sp_port, extack);
  2388. if (err)
  2389. goto err_bridge_8021ad_port_join;
  2390. return 0;
  2391. err_bridge_8021ad_port_join:
  2392. mlxsw_sp_port_egress_ethtype_set(mlxsw_sp_port, ETH_P_8021Q);
  2393. return err;
  2394. }
  2395. static void
  2396. mlxsw_sp2_bridge_8021ad_port_leave(struct mlxsw_sp_bridge_device *bridge_device,
  2397. struct mlxsw_sp_bridge_port *bridge_port,
  2398. struct mlxsw_sp_port *mlxsw_sp_port)
  2399. {
  2400. mlxsw_sp_bridge_8021ad_port_leave(bridge_device, bridge_port,
  2401. mlxsw_sp_port);
  2402. mlxsw_sp_port_egress_ethtype_set(mlxsw_sp_port, ETH_P_8021Q);
  2403. }
  2404. static const struct mlxsw_sp_bridge_ops mlxsw_sp2_bridge_8021ad_ops = {
  2405. .port_join = mlxsw_sp2_bridge_8021ad_port_join,
  2406. .port_leave = mlxsw_sp2_bridge_8021ad_port_leave,
  2407. .vxlan_join = mlxsw_sp_bridge_8021ad_vxlan_join,
  2408. .fid_get = mlxsw_sp_bridge_8021q_fid_get,
  2409. .fid_lookup = mlxsw_sp_bridge_8021q_fid_lookup,
  2410. .fid_vid = mlxsw_sp_bridge_8021q_fid_vid,
  2411. };
  2412. int mlxsw_sp_port_bridge_join(struct mlxsw_sp_port *mlxsw_sp_port,
  2413. struct net_device *brport_dev,
  2414. struct net_device *br_dev,
  2415. struct netlink_ext_ack *extack)
  2416. {
  2417. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_port->mlxsw_sp;
  2418. struct mlxsw_sp_bridge_device *bridge_device;
  2419. struct mlxsw_sp_bridge_port *bridge_port;
  2420. int err;
  2421. bridge_port = mlxsw_sp_bridge_port_get(mlxsw_sp->bridge, brport_dev,
  2422. extack);
  2423. if (IS_ERR(bridge_port))
  2424. return PTR_ERR(bridge_port);
  2425. bridge_device = bridge_port->bridge_device;
  2426. err = bridge_device->ops->port_join(bridge_device, bridge_port,
  2427. mlxsw_sp_port, extack);
  2428. if (err)
  2429. goto err_port_join;
  2430. err = mlxsw_sp_netdevice_enslavement_replay(mlxsw_sp, br_dev, extack);
  2431. if (err)
  2432. goto err_replay;
  2433. return 0;
  2434. err_replay:
  2435. bridge_device->ops->port_leave(bridge_device, bridge_port,
  2436. mlxsw_sp_port);
  2437. err_port_join:
  2438. mlxsw_sp_bridge_port_put(mlxsw_sp->bridge, bridge_port);
  2439. return err;
  2440. }
  2441. void mlxsw_sp_port_bridge_leave(struct mlxsw_sp_port *mlxsw_sp_port,
  2442. struct net_device *brport_dev,
  2443. struct net_device *br_dev)
  2444. {
  2445. struct mlxsw_sp *mlxsw_sp = mlxsw_sp_port->mlxsw_sp;
  2446. struct mlxsw_sp_bridge_device *bridge_device;
  2447. struct mlxsw_sp_bridge_port *bridge_port;
  2448. bridge_device = mlxsw_sp_bridge_device_find(mlxsw_sp->bridge, br_dev);
  2449. if (!bridge_device)
  2450. return;
  2451. bridge_port = __mlxsw_sp_bridge_port_find(bridge_device, brport_dev);
  2452. if (!bridge_port)
  2453. return;
  2454. bridge_device->ops->port_leave(bridge_device, bridge_port,
  2455. mlxsw_sp_port);
  2456. mlxsw_sp_port_security_set(mlxsw_sp_port, false);
  2457. mlxsw_sp_bridge_port_put(mlxsw_sp->bridge, bridge_port);
  2458. }
  2459. static void __mlxsw_sp_bridge_vxlan_leave(struct mlxsw_sp *mlxsw_sp,
  2460. const struct net_device *vxlan_dev)
  2461. {
  2462. struct vxlan_dev *vxlan = netdev_priv(vxlan_dev);
  2463. struct mlxsw_sp_fid *fid;
  2464. /* If the VxLAN device is down, then the FID does not have a VNI */
  2465. fid = mlxsw_sp_fid_lookup_by_vni(mlxsw_sp, vxlan->cfg.vni);
  2466. if (!fid)
  2467. return;
  2468. mlxsw_sp_nve_fid_disable(mlxsw_sp, fid);
  2469. /* Drop both the reference we just took during lookup and the reference
  2470. * the VXLAN device took.
  2471. */
  2472. mlxsw_sp_fid_put(fid);
  2473. mlxsw_sp_fid_put(fid);
  2474. }
  2475. int mlxsw_sp_bridge_vxlan_join(struct mlxsw_sp *mlxsw_sp,
  2476. const struct net_device *br_dev,
  2477. struct net_device *vxlan_dev, u16 vid,
  2478. struct netlink_ext_ack *extack)
  2479. {
  2480. struct mlxsw_sp_bridge_device *bridge_device;
  2481. struct mlxsw_sp_port *mlxsw_sp_port;
  2482. int err;
  2483. bridge_device = mlxsw_sp_bridge_device_find(mlxsw_sp->bridge, br_dev);
  2484. if (WARN_ON(!bridge_device))
  2485. return -EINVAL;
  2486. mlxsw_sp_port = mlxsw_sp_port_dev_lower_find(bridge_device->dev);
  2487. if (!mlxsw_sp_port)
  2488. return -EINVAL;
  2489. err = bridge_device->ops->vxlan_join(bridge_device, vxlan_dev, vid,
  2490. extack);
  2491. if (err)
  2492. return err;
  2493. err = switchdev_bridge_port_offload(vxlan_dev, mlxsw_sp_port->dev,
  2494. NULL, NULL, NULL, false, extack);
  2495. if (err)
  2496. goto err_bridge_port_offload;
  2497. return 0;
  2498. err_bridge_port_offload:
  2499. __mlxsw_sp_bridge_vxlan_leave(mlxsw_sp, vxlan_dev);
  2500. return err;
  2501. }
  2502. void mlxsw_sp_bridge_vxlan_leave(struct mlxsw_sp *mlxsw_sp,
  2503. struct net_device *vxlan_dev)
  2504. {
  2505. switchdev_bridge_port_unoffload(vxlan_dev, NULL, NULL, NULL);
  2506. __mlxsw_sp_bridge_vxlan_leave(mlxsw_sp, vxlan_dev);
  2507. }
  2508. static void
  2509. mlxsw_sp_switchdev_vxlan_addr_convert(const union vxlan_addr *vxlan_addr,
  2510. enum mlxsw_sp_l3proto *proto,
  2511. union mlxsw_sp_l3addr *addr)
  2512. {
  2513. if (vxlan_addr->sa.sa_family == AF_INET) {
  2514. addr->addr4 = vxlan_addr->sin.sin_addr.s_addr;
  2515. *proto = MLXSW_SP_L3_PROTO_IPV4;
  2516. } else {
  2517. addr->addr6 = vxlan_addr->sin6.sin6_addr;
  2518. *proto = MLXSW_SP_L3_PROTO_IPV6;
  2519. }
  2520. }
  2521. static void
  2522. mlxsw_sp_switchdev_addr_vxlan_convert(enum mlxsw_sp_l3proto proto,
  2523. const union mlxsw_sp_l3addr *addr,
  2524. union vxlan_addr *vxlan_addr)
  2525. {
  2526. switch (proto) {
  2527. case MLXSW_SP_L3_PROTO_IPV4:
  2528. vxlan_addr->sa.sa_family = AF_INET;
  2529. vxlan_addr->sin.sin_addr.s_addr = addr->addr4;
  2530. break;
  2531. case MLXSW_SP_L3_PROTO_IPV6:
  2532. vxlan_addr->sa.sa_family = AF_INET6;
  2533. vxlan_addr->sin6.sin6_addr = addr->addr6;
  2534. break;
  2535. }
  2536. }
  2537. static void mlxsw_sp_fdb_vxlan_call_notifiers(struct net_device *dev,
  2538. const char *mac,
  2539. enum mlxsw_sp_l3proto proto,
  2540. union mlxsw_sp_l3addr *addr,
  2541. __be32 vni, bool adding)
  2542. {
  2543. struct switchdev_notifier_vxlan_fdb_info info;
  2544. struct vxlan_dev *vxlan = netdev_priv(dev);
  2545. enum switchdev_notifier_type type;
  2546. type = adding ? SWITCHDEV_VXLAN_FDB_ADD_TO_BRIDGE :
  2547. SWITCHDEV_VXLAN_FDB_DEL_TO_BRIDGE;
  2548. mlxsw_sp_switchdev_addr_vxlan_convert(proto, addr, &info.remote_ip);
  2549. info.remote_port = vxlan->cfg.dst_port;
  2550. info.remote_vni = vni;
  2551. info.remote_ifindex = 0;
  2552. ether_addr_copy(info.eth_addr, mac);
  2553. info.vni = vni;
  2554. info.offloaded = adding;
  2555. call_switchdev_notifiers(type, dev, &info.info, NULL);
  2556. }
  2557. static void mlxsw_sp_fdb_nve_call_notifiers(struct net_device *dev,
  2558. const char *mac,
  2559. enum mlxsw_sp_l3proto proto,
  2560. union mlxsw_sp_l3addr *addr,
  2561. __be32 vni,
  2562. bool adding)
  2563. {
  2564. if (netif_is_vxlan(dev))
  2565. mlxsw_sp_fdb_vxlan_call_notifiers(dev, mac, proto, addr, vni,
  2566. adding);
  2567. }
  2568. static void
  2569. mlxsw_sp_fdb_call_notifiers(enum switchdev_notifier_type type,
  2570. const char *mac, u16 vid,
  2571. struct net_device *dev, bool offloaded, bool locked)
  2572. {
  2573. struct switchdev_notifier_fdb_info info = {};
  2574. info.addr = mac;
  2575. info.vid = vid;
  2576. info.offloaded = offloaded;
  2577. info.locked = locked;
  2578. call_switchdev_notifiers(type, dev, &info.info, NULL);
  2579. }
  2580. static void mlxsw_sp_fdb_notify_mac_process(struct mlxsw_sp *mlxsw_sp,
  2581. char *sfn_pl, int rec_index,
  2582. bool adding)
  2583. {
  2584. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  2585. struct mlxsw_sp_bridge_device *bridge_device;
  2586. struct mlxsw_sp_bridge_port *bridge_port;
  2587. struct mlxsw_sp_port *mlxsw_sp_port;
  2588. u16 local_port, vid, fid, evid = 0;
  2589. enum switchdev_notifier_type type;
  2590. char mac[ETH_ALEN];
  2591. bool do_notification = true;
  2592. int err;
  2593. mlxsw_reg_sfn_mac_unpack(sfn_pl, rec_index, mac, &fid, &local_port);
  2594. if (WARN_ON_ONCE(!mlxsw_sp_local_port_is_valid(mlxsw_sp, local_port)))
  2595. return;
  2596. mlxsw_sp_port = mlxsw_sp->ports[local_port];
  2597. if (!mlxsw_sp_port) {
  2598. dev_err_ratelimited(mlxsw_sp->bus_info->dev, "Incorrect local port in FDB notification\n");
  2599. goto just_remove;
  2600. }
  2601. mlxsw_sp_port_vlan = mlxsw_sp_port_vlan_find_by_fid(mlxsw_sp_port, fid);
  2602. if (!mlxsw_sp_port_vlan) {
  2603. netdev_err(mlxsw_sp_port->dev, "Failed to find a matching {Port, VID} following FDB notification\n");
  2604. goto just_remove;
  2605. }
  2606. bridge_port = mlxsw_sp_port_vlan->bridge_port;
  2607. if (!bridge_port) {
  2608. netdev_err(mlxsw_sp_port->dev, "{Port, VID} not associated with a bridge\n");
  2609. goto just_remove;
  2610. }
  2611. bridge_device = bridge_port->bridge_device;
  2612. vid = bridge_device->vlan_enabled ? mlxsw_sp_port_vlan->vid : 0;
  2613. evid = mlxsw_sp_port_vlan->vid;
  2614. if (adding && mlxsw_sp_port->security) {
  2615. mlxsw_sp_fdb_call_notifiers(SWITCHDEV_FDB_ADD_TO_BRIDGE, mac,
  2616. vid, bridge_port->dev, false, true);
  2617. return;
  2618. }
  2619. do_fdb_op:
  2620. err = mlxsw_sp_port_fdb_uc_op(mlxsw_sp, local_port, mac, fid, evid,
  2621. adding, true);
  2622. if (err) {
  2623. dev_err_ratelimited(mlxsw_sp->bus_info->dev, "Failed to set FDB entry\n");
  2624. return;
  2625. }
  2626. if (!do_notification)
  2627. return;
  2628. type = adding ? SWITCHDEV_FDB_ADD_TO_BRIDGE : SWITCHDEV_FDB_DEL_TO_BRIDGE;
  2629. mlxsw_sp_fdb_call_notifiers(type, mac, vid, bridge_port->dev, adding,
  2630. false);
  2631. return;
  2632. just_remove:
  2633. adding = false;
  2634. do_notification = false;
  2635. goto do_fdb_op;
  2636. }
  2637. static void mlxsw_sp_fdb_notify_mac_lag_process(struct mlxsw_sp *mlxsw_sp,
  2638. char *sfn_pl, int rec_index,
  2639. bool adding)
  2640. {
  2641. struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
  2642. struct mlxsw_sp_bridge_device *bridge_device;
  2643. struct mlxsw_sp_bridge_port *bridge_port;
  2644. struct mlxsw_sp_port *mlxsw_sp_port;
  2645. enum switchdev_notifier_type type;
  2646. char mac[ETH_ALEN];
  2647. u16 lag_vid = 0;
  2648. u16 lag_id;
  2649. u16 vid, fid;
  2650. bool do_notification = true;
  2651. int err;
  2652. mlxsw_reg_sfn_mac_lag_unpack(sfn_pl, rec_index, mac, &fid, &lag_id);
  2653. mlxsw_sp_port = mlxsw_sp_lag_rep_port(mlxsw_sp, lag_id);
  2654. if (!mlxsw_sp_port) {
  2655. dev_err_ratelimited(mlxsw_sp->bus_info->dev, "Cannot find port representor for LAG\n");
  2656. goto just_remove;
  2657. }
  2658. mlxsw_sp_port_vlan = mlxsw_sp_port_vlan_find_by_fid(mlxsw_sp_port, fid);
  2659. if (!mlxsw_sp_port_vlan) {
  2660. netdev_err(mlxsw_sp_port->dev, "Failed to find a matching {Port, VID} following FDB notification\n");
  2661. goto just_remove;
  2662. }
  2663. bridge_port = mlxsw_sp_port_vlan->bridge_port;
  2664. if (!bridge_port) {
  2665. netdev_err(mlxsw_sp_port->dev, "{Port, VID} not associated with a bridge\n");
  2666. goto just_remove;
  2667. }
  2668. bridge_device = bridge_port->bridge_device;
  2669. vid = bridge_device->vlan_enabled ? mlxsw_sp_port_vlan->vid : 0;
  2670. lag_vid = mlxsw_sp_port_vlan->vid;
  2671. if (adding && mlxsw_sp_port->security) {
  2672. mlxsw_sp_fdb_call_notifiers(SWITCHDEV_FDB_ADD_TO_BRIDGE, mac,
  2673. vid, bridge_port->dev, false, true);
  2674. return;
  2675. }
  2676. do_fdb_op:
  2677. err = mlxsw_sp_port_fdb_uc_lag_op(mlxsw_sp, lag_id, mac, fid, lag_vid,
  2678. adding, true);
  2679. if (err) {
  2680. dev_err_ratelimited(mlxsw_sp->bus_info->dev, "Failed to set FDB entry\n");
  2681. return;
  2682. }
  2683. if (!do_notification)
  2684. return;
  2685. type = adding ? SWITCHDEV_FDB_ADD_TO_BRIDGE : SWITCHDEV_FDB_DEL_TO_BRIDGE;
  2686. mlxsw_sp_fdb_call_notifiers(type, mac, vid, bridge_port->dev, adding,
  2687. false);
  2688. return;
  2689. just_remove:
  2690. adding = false;
  2691. do_notification = false;
  2692. goto do_fdb_op;
  2693. }
  2694. static int
  2695. __mlxsw_sp_fdb_notify_mac_uc_tunnel_process(struct mlxsw_sp *mlxsw_sp,
  2696. const struct mlxsw_sp_fid *fid,
  2697. bool adding,
  2698. struct net_device **nve_dev,
  2699. u16 *p_vid, __be32 *p_vni)
  2700. {
  2701. struct mlxsw_sp_bridge_device *bridge_device;
  2702. struct net_device *br_dev, *dev;
  2703. int nve_ifindex;
  2704. int err;
  2705. err = mlxsw_sp_fid_nve_ifindex(fid, &nve_ifindex);
  2706. if (err)
  2707. return err;
  2708. err = mlxsw_sp_fid_vni(fid, p_vni);
  2709. if (err)
  2710. return err;
  2711. dev = __dev_get_by_index(mlxsw_sp_net(mlxsw_sp), nve_ifindex);
  2712. if (!dev)
  2713. return -EINVAL;
  2714. *nve_dev = dev;
  2715. if (!netif_running(dev))
  2716. return -EINVAL;
  2717. if (adding && !br_port_flag_is_set(dev, BR_LEARNING))
  2718. return -EINVAL;
  2719. if (adding && netif_is_vxlan(dev)) {
  2720. struct vxlan_dev *vxlan = netdev_priv(dev);
  2721. if (!(vxlan->cfg.flags & VXLAN_F_LEARN))
  2722. return -EINVAL;
  2723. }
  2724. br_dev = netdev_master_upper_dev_get(dev);
  2725. if (!br_dev)
  2726. return -EINVAL;
  2727. bridge_device = mlxsw_sp_bridge_device_find(mlxsw_sp->bridge, br_dev);
  2728. if (!bridge_device)
  2729. return -EINVAL;
  2730. *p_vid = bridge_device->ops->fid_vid(bridge_device, fid);
  2731. return 0;
  2732. }
  2733. static void mlxsw_sp_fdb_notify_mac_uc_tunnel_process(struct mlxsw_sp *mlxsw_sp,
  2734. char *sfn_pl,
  2735. int rec_index,
  2736. bool adding)
  2737. {
  2738. enum mlxsw_reg_sfn_uc_tunnel_protocol sfn_proto;
  2739. enum switchdev_notifier_type type;
  2740. struct net_device *nve_dev;
  2741. union mlxsw_sp_l3addr addr;
  2742. struct mlxsw_sp_fid *fid;
  2743. char mac[ETH_ALEN];
  2744. u16 fid_index, vid;
  2745. __be32 vni;
  2746. u32 uip;
  2747. int err;
  2748. mlxsw_reg_sfn_uc_tunnel_unpack(sfn_pl, rec_index, mac, &fid_index,
  2749. &uip, &sfn_proto);
  2750. fid = mlxsw_sp_fid_lookup_by_index(mlxsw_sp, fid_index);
  2751. if (!fid)
  2752. goto err_fid_lookup;
  2753. err = mlxsw_sp_nve_learned_ip_resolve(mlxsw_sp, uip,
  2754. (enum mlxsw_sp_l3proto) sfn_proto,
  2755. &addr);
  2756. if (err)
  2757. goto err_ip_resolve;
  2758. err = __mlxsw_sp_fdb_notify_mac_uc_tunnel_process(mlxsw_sp, fid, adding,
  2759. &nve_dev, &vid, &vni);
  2760. if (err)
  2761. goto err_fdb_process;
  2762. err = mlxsw_sp_port_fdb_tunnel_uc_op(mlxsw_sp, mac, fid_index,
  2763. (enum mlxsw_sp_l3proto) sfn_proto,
  2764. &addr, adding, true);
  2765. if (err)
  2766. goto err_fdb_op;
  2767. mlxsw_sp_fdb_nve_call_notifiers(nve_dev, mac,
  2768. (enum mlxsw_sp_l3proto) sfn_proto,
  2769. &addr, vni, adding);
  2770. type = adding ? SWITCHDEV_FDB_ADD_TO_BRIDGE :
  2771. SWITCHDEV_FDB_DEL_TO_BRIDGE;
  2772. mlxsw_sp_fdb_call_notifiers(type, mac, vid, nve_dev, adding, false);
  2773. mlxsw_sp_fid_put(fid);
  2774. return;
  2775. err_fdb_op:
  2776. err_fdb_process:
  2777. err_ip_resolve:
  2778. mlxsw_sp_fid_put(fid);
  2779. err_fid_lookup:
  2780. /* Remove an FDB entry in case we cannot process it. Otherwise the
  2781. * device will keep sending the same notification over and over again.
  2782. */
  2783. mlxsw_sp_port_fdb_tunnel_uc_op(mlxsw_sp, mac, fid_index,
  2784. (enum mlxsw_sp_l3proto) sfn_proto, &addr,
  2785. false, true);
  2786. }
  2787. static void mlxsw_sp_fdb_notify_rec_process(struct mlxsw_sp *mlxsw_sp,
  2788. char *sfn_pl, int rec_index)
  2789. {
  2790. switch (mlxsw_reg_sfn_rec_type_get(sfn_pl, rec_index)) {
  2791. case MLXSW_REG_SFN_REC_TYPE_LEARNED_MAC:
  2792. mlxsw_sp_fdb_notify_mac_process(mlxsw_sp, sfn_pl,
  2793. rec_index, true);
  2794. break;
  2795. case MLXSW_REG_SFN_REC_TYPE_AGED_OUT_MAC:
  2796. mlxsw_sp_fdb_notify_mac_process(mlxsw_sp, sfn_pl,
  2797. rec_index, false);
  2798. break;
  2799. case MLXSW_REG_SFN_REC_TYPE_LEARNED_MAC_LAG:
  2800. mlxsw_sp_fdb_notify_mac_lag_process(mlxsw_sp, sfn_pl,
  2801. rec_index, true);
  2802. break;
  2803. case MLXSW_REG_SFN_REC_TYPE_AGED_OUT_MAC_LAG:
  2804. mlxsw_sp_fdb_notify_mac_lag_process(mlxsw_sp, sfn_pl,
  2805. rec_index, false);
  2806. break;
  2807. case MLXSW_REG_SFN_REC_TYPE_LEARNED_UNICAST_TUNNEL:
  2808. mlxsw_sp_fdb_notify_mac_uc_tunnel_process(mlxsw_sp, sfn_pl,
  2809. rec_index, true);
  2810. break;
  2811. case MLXSW_REG_SFN_REC_TYPE_AGED_OUT_UNICAST_TUNNEL:
  2812. mlxsw_sp_fdb_notify_mac_uc_tunnel_process(mlxsw_sp, sfn_pl,
  2813. rec_index, false);
  2814. break;
  2815. }
  2816. }
  2817. #define MLXSW_SP_FDB_SFN_QUERIES_PER_SESSION 10
  2818. static void mlxsw_sp_fdb_notify_work(struct work_struct *work)
  2819. {
  2820. struct mlxsw_sp_bridge *bridge;
  2821. struct mlxsw_sp *mlxsw_sp;
  2822. bool reschedule = false;
  2823. char *sfn_pl;
  2824. int queries;
  2825. u8 num_rec;
  2826. int i;
  2827. int err;
  2828. sfn_pl = kmalloc(MLXSW_REG_SFN_LEN, GFP_KERNEL);
  2829. if (!sfn_pl)
  2830. return;
  2831. bridge = container_of(work, struct mlxsw_sp_bridge, fdb_notify.dw.work);
  2832. mlxsw_sp = bridge->mlxsw_sp;
  2833. rtnl_lock();
  2834. if (list_empty(&bridge->bridges_list))
  2835. goto out;
  2836. reschedule = true;
  2837. queries = MLXSW_SP_FDB_SFN_QUERIES_PER_SESSION;
  2838. while (queries > 0) {
  2839. mlxsw_reg_sfn_pack(sfn_pl);
  2840. err = mlxsw_reg_query(mlxsw_sp->core, MLXSW_REG(sfn), sfn_pl);
  2841. if (err) {
  2842. dev_err_ratelimited(mlxsw_sp->bus_info->dev, "Failed to get FDB notifications\n");
  2843. goto out;
  2844. }
  2845. num_rec = mlxsw_reg_sfn_num_rec_get(sfn_pl);
  2846. for (i = 0; i < num_rec; i++)
  2847. mlxsw_sp_fdb_notify_rec_process(mlxsw_sp, sfn_pl, i);
  2848. if (num_rec != MLXSW_REG_SFN_REC_MAX_COUNT)
  2849. goto out;
  2850. queries--;
  2851. }
  2852. out:
  2853. rtnl_unlock();
  2854. kfree(sfn_pl);
  2855. if (!reschedule)
  2856. return;
  2857. mlxsw_sp_fdb_notify_work_schedule(mlxsw_sp, !queries);
  2858. }
  2859. struct mlxsw_sp_switchdev_event_work {
  2860. struct work_struct work;
  2861. netdevice_tracker dev_tracker;
  2862. union {
  2863. struct switchdev_notifier_fdb_info fdb_info;
  2864. struct switchdev_notifier_vxlan_fdb_info vxlan_fdb_info;
  2865. };
  2866. struct net_device *dev;
  2867. unsigned long event;
  2868. };
  2869. static void
  2870. mlxsw_sp_switchdev_bridge_vxlan_fdb_event(struct mlxsw_sp *mlxsw_sp,
  2871. struct mlxsw_sp_switchdev_event_work *
  2872. switchdev_work,
  2873. struct mlxsw_sp_fid *fid, __be32 vni)
  2874. {
  2875. struct switchdev_notifier_vxlan_fdb_info vxlan_fdb_info;
  2876. struct switchdev_notifier_fdb_info *fdb_info;
  2877. struct net_device *dev = switchdev_work->dev;
  2878. enum mlxsw_sp_l3proto proto;
  2879. union mlxsw_sp_l3addr addr;
  2880. int err;
  2881. fdb_info = &switchdev_work->fdb_info;
  2882. err = vxlan_fdb_find_uc(dev, fdb_info->addr, vni, &vxlan_fdb_info);
  2883. if (err)
  2884. return;
  2885. mlxsw_sp_switchdev_vxlan_addr_convert(&vxlan_fdb_info.remote_ip,
  2886. &proto, &addr);
  2887. switch (switchdev_work->event) {
  2888. case SWITCHDEV_FDB_ADD_TO_DEVICE:
  2889. err = mlxsw_sp_port_fdb_tunnel_uc_op(mlxsw_sp,
  2890. vxlan_fdb_info.eth_addr,
  2891. mlxsw_sp_fid_index(fid),
  2892. proto, &addr, true, false);
  2893. if (err)
  2894. return;
  2895. vxlan_fdb_info.offloaded = true;
  2896. call_switchdev_notifiers(SWITCHDEV_VXLAN_FDB_OFFLOADED, dev,
  2897. &vxlan_fdb_info.info, NULL);
  2898. mlxsw_sp_fdb_call_notifiers(SWITCHDEV_FDB_OFFLOADED,
  2899. vxlan_fdb_info.eth_addr,
  2900. fdb_info->vid, dev, true, false);
  2901. break;
  2902. case SWITCHDEV_FDB_DEL_TO_DEVICE:
  2903. err = mlxsw_sp_port_fdb_tunnel_uc_op(mlxsw_sp,
  2904. vxlan_fdb_info.eth_addr,
  2905. mlxsw_sp_fid_index(fid),
  2906. proto, &addr, false,
  2907. false);
  2908. vxlan_fdb_info.offloaded = false;
  2909. call_switchdev_notifiers(SWITCHDEV_VXLAN_FDB_OFFLOADED, dev,
  2910. &vxlan_fdb_info.info, NULL);
  2911. break;
  2912. }
  2913. }
  2914. static void
  2915. mlxsw_sp_switchdev_bridge_nve_fdb_event(struct mlxsw_sp_switchdev_event_work *
  2916. switchdev_work)
  2917. {
  2918. struct mlxsw_sp_bridge_device *bridge_device;
  2919. struct net_device *dev = switchdev_work->dev;
  2920. struct net_device *br_dev;
  2921. struct mlxsw_sp *mlxsw_sp;
  2922. struct mlxsw_sp_fid *fid;
  2923. __be32 vni;
  2924. int err;
  2925. if (switchdev_work->event != SWITCHDEV_FDB_ADD_TO_DEVICE &&
  2926. switchdev_work->event != SWITCHDEV_FDB_DEL_TO_DEVICE)
  2927. return;
  2928. if (switchdev_work->event == SWITCHDEV_FDB_ADD_TO_DEVICE &&
  2929. (!switchdev_work->fdb_info.added_by_user ||
  2930. switchdev_work->fdb_info.is_local))
  2931. return;
  2932. if (!netif_running(dev))
  2933. return;
  2934. br_dev = netdev_master_upper_dev_get(dev);
  2935. if (!br_dev)
  2936. return;
  2937. if (!netif_is_bridge_master(br_dev))
  2938. return;
  2939. mlxsw_sp = mlxsw_sp_lower_get(br_dev);
  2940. if (!mlxsw_sp)
  2941. return;
  2942. bridge_device = mlxsw_sp_bridge_device_find(mlxsw_sp->bridge, br_dev);
  2943. if (!bridge_device)
  2944. return;
  2945. fid = bridge_device->ops->fid_lookup(bridge_device,
  2946. switchdev_work->fdb_info.vid);
  2947. if (!fid)
  2948. return;
  2949. err = mlxsw_sp_fid_vni(fid, &vni);
  2950. if (err)
  2951. goto out;
  2952. mlxsw_sp_switchdev_bridge_vxlan_fdb_event(mlxsw_sp, switchdev_work, fid,
  2953. vni);
  2954. out:
  2955. mlxsw_sp_fid_put(fid);
  2956. }
  2957. static void mlxsw_sp_switchdev_bridge_fdb_event_work(struct work_struct *work)
  2958. {
  2959. struct mlxsw_sp_switchdev_event_work *switchdev_work =
  2960. container_of(work, struct mlxsw_sp_switchdev_event_work, work);
  2961. struct net_device *dev = switchdev_work->dev;
  2962. struct switchdev_notifier_fdb_info *fdb_info;
  2963. struct mlxsw_sp_port *mlxsw_sp_port;
  2964. int err;
  2965. rtnl_lock();
  2966. if (netif_is_vxlan(dev)) {
  2967. mlxsw_sp_switchdev_bridge_nve_fdb_event(switchdev_work);
  2968. goto out;
  2969. }
  2970. mlxsw_sp_port = mlxsw_sp_port_dev_lower_find(dev);
  2971. if (!mlxsw_sp_port)
  2972. goto out;
  2973. switch (switchdev_work->event) {
  2974. case SWITCHDEV_FDB_ADD_TO_DEVICE:
  2975. fdb_info = &switchdev_work->fdb_info;
  2976. if (!fdb_info->added_by_user || fdb_info->is_local)
  2977. break;
  2978. err = mlxsw_sp_port_fdb_set(mlxsw_sp_port, fdb_info, true);
  2979. if (err)
  2980. break;
  2981. mlxsw_sp_fdb_call_notifiers(SWITCHDEV_FDB_OFFLOADED,
  2982. fdb_info->addr,
  2983. fdb_info->vid, dev, true, false);
  2984. break;
  2985. case SWITCHDEV_FDB_DEL_TO_DEVICE:
  2986. fdb_info = &switchdev_work->fdb_info;
  2987. mlxsw_sp_port_fdb_set(mlxsw_sp_port, fdb_info, false);
  2988. break;
  2989. case SWITCHDEV_FDB_ADD_TO_BRIDGE:
  2990. case SWITCHDEV_FDB_DEL_TO_BRIDGE:
  2991. /* These events are only used to potentially update an existing
  2992. * SPAN mirror.
  2993. */
  2994. break;
  2995. }
  2996. mlxsw_sp_span_respin(mlxsw_sp_port->mlxsw_sp);
  2997. out:
  2998. rtnl_unlock();
  2999. kfree(switchdev_work->fdb_info.addr);
  3000. netdev_put(dev, &switchdev_work->dev_tracker);
  3001. kfree(switchdev_work);
  3002. }
  3003. static void
  3004. mlxsw_sp_switchdev_vxlan_fdb_add(struct mlxsw_sp *mlxsw_sp,
  3005. struct mlxsw_sp_switchdev_event_work *
  3006. switchdev_work)
  3007. {
  3008. struct switchdev_notifier_vxlan_fdb_info *vxlan_fdb_info;
  3009. struct mlxsw_sp_bridge_device *bridge_device;
  3010. struct net_device *dev = switchdev_work->dev;
  3011. enum mlxsw_sp_l3proto proto;
  3012. union mlxsw_sp_l3addr addr;
  3013. struct net_device *br_dev;
  3014. struct mlxsw_sp_fid *fid;
  3015. u16 vid;
  3016. int err;
  3017. vxlan_fdb_info = &switchdev_work->vxlan_fdb_info;
  3018. br_dev = netdev_master_upper_dev_get(dev);
  3019. bridge_device = mlxsw_sp_bridge_device_find(mlxsw_sp->bridge, br_dev);
  3020. if (!bridge_device)
  3021. return;
  3022. fid = mlxsw_sp_fid_lookup_by_vni(mlxsw_sp, vxlan_fdb_info->vni);
  3023. if (!fid)
  3024. return;
  3025. mlxsw_sp_switchdev_vxlan_addr_convert(&vxlan_fdb_info->remote_ip,
  3026. &proto, &addr);
  3027. if (is_zero_ether_addr(vxlan_fdb_info->eth_addr)) {
  3028. err = mlxsw_sp_nve_flood_ip_add(mlxsw_sp, fid, proto, &addr);
  3029. if (err) {
  3030. mlxsw_sp_fid_put(fid);
  3031. return;
  3032. }
  3033. vxlan_fdb_info->offloaded = true;
  3034. call_switchdev_notifiers(SWITCHDEV_VXLAN_FDB_OFFLOADED, dev,
  3035. &vxlan_fdb_info->info, NULL);
  3036. mlxsw_sp_fid_put(fid);
  3037. return;
  3038. }
  3039. /* The device has a single FDB table, whereas Linux has two - one
  3040. * in the bridge driver and another in the VxLAN driver. We only
  3041. * program an entry to the device if the MAC points to the VxLAN
  3042. * device in the bridge's FDB table
  3043. */
  3044. vid = bridge_device->ops->fid_vid(bridge_device, fid);
  3045. if (br_fdb_find_port(br_dev, vxlan_fdb_info->eth_addr, vid) != dev)
  3046. goto err_br_fdb_find;
  3047. err = mlxsw_sp_port_fdb_tunnel_uc_op(mlxsw_sp, vxlan_fdb_info->eth_addr,
  3048. mlxsw_sp_fid_index(fid), proto,
  3049. &addr, true, false);
  3050. if (err)
  3051. goto err_fdb_tunnel_uc_op;
  3052. vxlan_fdb_info->offloaded = true;
  3053. call_switchdev_notifiers(SWITCHDEV_VXLAN_FDB_OFFLOADED, dev,
  3054. &vxlan_fdb_info->info, NULL);
  3055. mlxsw_sp_fdb_call_notifiers(SWITCHDEV_FDB_OFFLOADED,
  3056. vxlan_fdb_info->eth_addr, vid, dev, true,
  3057. false);
  3058. mlxsw_sp_fid_put(fid);
  3059. return;
  3060. err_fdb_tunnel_uc_op:
  3061. err_br_fdb_find:
  3062. mlxsw_sp_fid_put(fid);
  3063. }
  3064. static void
  3065. mlxsw_sp_switchdev_vxlan_fdb_del(struct mlxsw_sp *mlxsw_sp,
  3066. struct mlxsw_sp_switchdev_event_work *
  3067. switchdev_work)
  3068. {
  3069. struct switchdev_notifier_vxlan_fdb_info *vxlan_fdb_info;
  3070. struct mlxsw_sp_bridge_device *bridge_device;
  3071. struct net_device *dev = switchdev_work->dev;
  3072. struct net_device *br_dev = netdev_master_upper_dev_get(dev);
  3073. enum mlxsw_sp_l3proto proto;
  3074. union mlxsw_sp_l3addr addr;
  3075. struct mlxsw_sp_fid *fid;
  3076. u16 vid;
  3077. vxlan_fdb_info = &switchdev_work->vxlan_fdb_info;
  3078. if (!vxlan_fdb_info->offloaded)
  3079. return;
  3080. bridge_device = mlxsw_sp_bridge_device_find(mlxsw_sp->bridge, br_dev);
  3081. if (!bridge_device)
  3082. return;
  3083. fid = mlxsw_sp_fid_lookup_by_vni(mlxsw_sp, vxlan_fdb_info->vni);
  3084. if (!fid)
  3085. return;
  3086. mlxsw_sp_switchdev_vxlan_addr_convert(&vxlan_fdb_info->remote_ip,
  3087. &proto, &addr);
  3088. if (is_zero_ether_addr(vxlan_fdb_info->eth_addr)) {
  3089. mlxsw_sp_nve_flood_ip_del(mlxsw_sp, fid, proto, &addr);
  3090. mlxsw_sp_fid_put(fid);
  3091. return;
  3092. }
  3093. mlxsw_sp_port_fdb_tunnel_uc_op(mlxsw_sp, vxlan_fdb_info->eth_addr,
  3094. mlxsw_sp_fid_index(fid), proto, &addr,
  3095. false, false);
  3096. vid = bridge_device->ops->fid_vid(bridge_device, fid);
  3097. mlxsw_sp_fdb_call_notifiers(SWITCHDEV_FDB_OFFLOADED,
  3098. vxlan_fdb_info->eth_addr, vid, dev, false,
  3099. false);
  3100. mlxsw_sp_fid_put(fid);
  3101. }
  3102. static void mlxsw_sp_switchdev_vxlan_fdb_event_work(struct work_struct *work)
  3103. {
  3104. struct mlxsw_sp_switchdev_event_work *switchdev_work =
  3105. container_of(work, struct mlxsw_sp_switchdev_event_work, work);
  3106. struct net_device *dev = switchdev_work->dev;
  3107. struct mlxsw_sp *mlxsw_sp;
  3108. struct net_device *br_dev;
  3109. rtnl_lock();
  3110. if (!netif_running(dev))
  3111. goto out;
  3112. br_dev = netdev_master_upper_dev_get(dev);
  3113. if (!br_dev)
  3114. goto out;
  3115. if (!netif_is_bridge_master(br_dev))
  3116. goto out;
  3117. mlxsw_sp = mlxsw_sp_lower_get(br_dev);
  3118. if (!mlxsw_sp)
  3119. goto out;
  3120. switch (switchdev_work->event) {
  3121. case SWITCHDEV_VXLAN_FDB_ADD_TO_DEVICE:
  3122. mlxsw_sp_switchdev_vxlan_fdb_add(mlxsw_sp, switchdev_work);
  3123. break;
  3124. case SWITCHDEV_VXLAN_FDB_DEL_TO_DEVICE:
  3125. mlxsw_sp_switchdev_vxlan_fdb_del(mlxsw_sp, switchdev_work);
  3126. break;
  3127. }
  3128. out:
  3129. rtnl_unlock();
  3130. netdev_put(dev, &switchdev_work->dev_tracker);
  3131. kfree(switchdev_work);
  3132. }
  3133. static int
  3134. mlxsw_sp_switchdev_vxlan_work_prepare(struct mlxsw_sp_switchdev_event_work *
  3135. switchdev_work,
  3136. struct switchdev_notifier_info *info)
  3137. {
  3138. struct vxlan_dev *vxlan = netdev_priv(switchdev_work->dev);
  3139. struct switchdev_notifier_vxlan_fdb_info *vxlan_fdb_info;
  3140. struct vxlan_config *cfg = &vxlan->cfg;
  3141. struct netlink_ext_ack *extack;
  3142. extack = switchdev_notifier_info_to_extack(info);
  3143. vxlan_fdb_info = container_of(info,
  3144. struct switchdev_notifier_vxlan_fdb_info,
  3145. info);
  3146. if (vxlan_fdb_info->remote_port != cfg->dst_port) {
  3147. NL_SET_ERR_MSG_MOD(extack, "VxLAN: FDB: Non-default remote port is not supported");
  3148. return -EOPNOTSUPP;
  3149. }
  3150. if (vxlan_fdb_info->remote_vni != cfg->vni ||
  3151. vxlan_fdb_info->vni != cfg->vni) {
  3152. NL_SET_ERR_MSG_MOD(extack, "VxLAN: FDB: Non-default VNI is not supported");
  3153. return -EOPNOTSUPP;
  3154. }
  3155. if (vxlan_fdb_info->remote_ifindex) {
  3156. NL_SET_ERR_MSG_MOD(extack, "VxLAN: FDB: Local interface is not supported");
  3157. return -EOPNOTSUPP;
  3158. }
  3159. if (is_multicast_ether_addr(vxlan_fdb_info->eth_addr)) {
  3160. NL_SET_ERR_MSG_MOD(extack, "VxLAN: FDB: Multicast MAC addresses not supported");
  3161. return -EOPNOTSUPP;
  3162. }
  3163. if (vxlan_addr_multicast(&vxlan_fdb_info->remote_ip)) {
  3164. NL_SET_ERR_MSG_MOD(extack, "VxLAN: FDB: Multicast destination IP is not supported");
  3165. return -EOPNOTSUPP;
  3166. }
  3167. switchdev_work->vxlan_fdb_info = *vxlan_fdb_info;
  3168. return 0;
  3169. }
  3170. /* Called under rcu_read_lock() */
  3171. static int mlxsw_sp_switchdev_event(struct notifier_block *unused,
  3172. unsigned long event, void *ptr)
  3173. {
  3174. struct net_device *dev = switchdev_notifier_info_to_dev(ptr);
  3175. struct mlxsw_sp_switchdev_event_work *switchdev_work;
  3176. struct switchdev_notifier_fdb_info *fdb_info;
  3177. struct switchdev_notifier_info *info = ptr;
  3178. struct net_device *br_dev;
  3179. int err;
  3180. if (event == SWITCHDEV_PORT_ATTR_SET) {
  3181. err = switchdev_handle_port_attr_set(dev, ptr,
  3182. mlxsw_sp_port_dev_check,
  3183. mlxsw_sp_port_attr_set);
  3184. return notifier_from_errno(err);
  3185. }
  3186. /* Tunnel devices are not our uppers, so check their master instead */
  3187. br_dev = netdev_master_upper_dev_get_rcu(dev);
  3188. if (!br_dev)
  3189. return NOTIFY_DONE;
  3190. if (!netif_is_bridge_master(br_dev))
  3191. return NOTIFY_DONE;
  3192. if (!mlxsw_sp_port_dev_lower_find_rcu(br_dev))
  3193. return NOTIFY_DONE;
  3194. switchdev_work = kzalloc_obj(*switchdev_work, GFP_ATOMIC);
  3195. if (!switchdev_work)
  3196. return NOTIFY_BAD;
  3197. switchdev_work->dev = dev;
  3198. switchdev_work->event = event;
  3199. switch (event) {
  3200. case SWITCHDEV_FDB_ADD_TO_DEVICE:
  3201. case SWITCHDEV_FDB_DEL_TO_DEVICE:
  3202. case SWITCHDEV_FDB_ADD_TO_BRIDGE:
  3203. case SWITCHDEV_FDB_DEL_TO_BRIDGE:
  3204. fdb_info = container_of(info,
  3205. struct switchdev_notifier_fdb_info,
  3206. info);
  3207. INIT_WORK(&switchdev_work->work,
  3208. mlxsw_sp_switchdev_bridge_fdb_event_work);
  3209. memcpy(&switchdev_work->fdb_info, ptr,
  3210. sizeof(switchdev_work->fdb_info));
  3211. switchdev_work->fdb_info.addr = kzalloc(ETH_ALEN, GFP_ATOMIC);
  3212. if (!switchdev_work->fdb_info.addr)
  3213. goto err_addr_alloc;
  3214. ether_addr_copy((u8 *)switchdev_work->fdb_info.addr,
  3215. fdb_info->addr);
  3216. /* Take a reference on the device. This can be either
  3217. * upper device containig mlxsw_sp_port or just a
  3218. * mlxsw_sp_port
  3219. */
  3220. netdev_hold(dev, &switchdev_work->dev_tracker, GFP_ATOMIC);
  3221. break;
  3222. case SWITCHDEV_VXLAN_FDB_ADD_TO_DEVICE:
  3223. case SWITCHDEV_VXLAN_FDB_DEL_TO_DEVICE:
  3224. INIT_WORK(&switchdev_work->work,
  3225. mlxsw_sp_switchdev_vxlan_fdb_event_work);
  3226. err = mlxsw_sp_switchdev_vxlan_work_prepare(switchdev_work,
  3227. info);
  3228. if (err)
  3229. goto err_vxlan_work_prepare;
  3230. netdev_hold(dev, &switchdev_work->dev_tracker, GFP_ATOMIC);
  3231. break;
  3232. default:
  3233. kfree(switchdev_work);
  3234. return NOTIFY_DONE;
  3235. }
  3236. mlxsw_core_schedule_work(&switchdev_work->work);
  3237. return NOTIFY_DONE;
  3238. err_vxlan_work_prepare:
  3239. err_addr_alloc:
  3240. kfree(switchdev_work);
  3241. return NOTIFY_BAD;
  3242. }
  3243. struct notifier_block mlxsw_sp_switchdev_notifier = {
  3244. .notifier_call = mlxsw_sp_switchdev_event,
  3245. };
  3246. static int
  3247. mlxsw_sp_switchdev_vxlan_vlan_add(struct mlxsw_sp *mlxsw_sp,
  3248. struct mlxsw_sp_bridge_device *bridge_device,
  3249. const struct net_device *vxlan_dev, u16 vid,
  3250. bool flag_untagged, bool flag_pvid,
  3251. struct netlink_ext_ack *extack)
  3252. {
  3253. struct vxlan_dev *vxlan = netdev_priv(vxlan_dev);
  3254. __be32 vni = vxlan->cfg.vni;
  3255. struct mlxsw_sp_fid *fid;
  3256. u16 old_vid;
  3257. int err;
  3258. /* We cannot have the same VLAN as PVID and egress untagged on multiple
  3259. * VxLAN devices. Note that we get this notification before the VLAN is
  3260. * actually added to the bridge's database, so it is not possible for
  3261. * the lookup function to return 'vxlan_dev'
  3262. */
  3263. if (flag_untagged && flag_pvid &&
  3264. mlxsw_sp_bridge_8021q_vxlan_dev_find(bridge_device->dev, vid)) {
  3265. NL_SET_ERR_MSG_MOD(extack, "VLAN already mapped to a different VNI");
  3266. return -EINVAL;
  3267. }
  3268. if (!netif_running(vxlan_dev))
  3269. return 0;
  3270. /* First case: FID is not associated with this VNI, but the new VLAN
  3271. * is both PVID and egress untagged. Need to enable NVE on the FID, if
  3272. * it exists
  3273. */
  3274. fid = mlxsw_sp_fid_lookup_by_vni(mlxsw_sp, vni);
  3275. if (!fid) {
  3276. if (!flag_untagged || !flag_pvid)
  3277. return 0;
  3278. return bridge_device->ops->vxlan_join(bridge_device, vxlan_dev,
  3279. vid, extack);
  3280. }
  3281. /* Second case: FID is associated with the VNI and the VLAN associated
  3282. * with the FID is the same as the notified VLAN. This means the flags
  3283. * (PVID / egress untagged) were toggled and that NVE should be
  3284. * disabled on the FID
  3285. */
  3286. old_vid = mlxsw_sp_fid_8021q_vid(fid);
  3287. if (vid == old_vid) {
  3288. if (WARN_ON(flag_untagged && flag_pvid)) {
  3289. mlxsw_sp_fid_put(fid);
  3290. return -EINVAL;
  3291. }
  3292. __mlxsw_sp_bridge_vxlan_leave(mlxsw_sp, vxlan_dev);
  3293. mlxsw_sp_fid_put(fid);
  3294. return 0;
  3295. }
  3296. /* Third case: A new VLAN was configured on the VxLAN device, but this
  3297. * VLAN is not PVID, so there is nothing to do.
  3298. */
  3299. if (!flag_pvid) {
  3300. mlxsw_sp_fid_put(fid);
  3301. return 0;
  3302. }
  3303. /* Fourth case: Thew new VLAN is PVID, which means the VLAN currently
  3304. * mapped to the VNI should be unmapped
  3305. */
  3306. __mlxsw_sp_bridge_vxlan_leave(mlxsw_sp, vxlan_dev);
  3307. mlxsw_sp_fid_put(fid);
  3308. /* Fifth case: The new VLAN is also egress untagged, which means the
  3309. * VLAN needs to be mapped to the VNI
  3310. */
  3311. if (!flag_untagged)
  3312. return 0;
  3313. err = bridge_device->ops->vxlan_join(bridge_device, vxlan_dev, vid, extack);
  3314. if (err)
  3315. goto err_vxlan_join;
  3316. return 0;
  3317. err_vxlan_join:
  3318. bridge_device->ops->vxlan_join(bridge_device, vxlan_dev, old_vid, NULL);
  3319. return err;
  3320. }
  3321. static void
  3322. mlxsw_sp_switchdev_vxlan_vlan_del(struct mlxsw_sp *mlxsw_sp,
  3323. struct mlxsw_sp_bridge_device *bridge_device,
  3324. const struct net_device *vxlan_dev, u16 vid)
  3325. {
  3326. struct vxlan_dev *vxlan = netdev_priv(vxlan_dev);
  3327. __be32 vni = vxlan->cfg.vni;
  3328. struct mlxsw_sp_fid *fid;
  3329. if (!netif_running(vxlan_dev))
  3330. return;
  3331. fid = mlxsw_sp_fid_lookup_by_vni(mlxsw_sp, vni);
  3332. if (!fid)
  3333. return;
  3334. /* A different VLAN than the one mapped to the VNI is deleted */
  3335. if (mlxsw_sp_fid_8021q_vid(fid) != vid)
  3336. goto out;
  3337. __mlxsw_sp_bridge_vxlan_leave(mlxsw_sp, vxlan_dev);
  3338. out:
  3339. mlxsw_sp_fid_put(fid);
  3340. }
  3341. static int
  3342. mlxsw_sp_switchdev_vxlan_vlans_add(struct net_device *vxlan_dev,
  3343. struct switchdev_notifier_port_obj_info *
  3344. port_obj_info)
  3345. {
  3346. struct switchdev_obj_port_vlan *vlan =
  3347. SWITCHDEV_OBJ_PORT_VLAN(port_obj_info->obj);
  3348. bool flag_untagged = vlan->flags & BRIDGE_VLAN_INFO_UNTAGGED;
  3349. bool flag_pvid = vlan->flags & BRIDGE_VLAN_INFO_PVID;
  3350. struct mlxsw_sp_bridge_device *bridge_device;
  3351. struct netlink_ext_ack *extack;
  3352. struct mlxsw_sp *mlxsw_sp;
  3353. struct net_device *br_dev;
  3354. extack = switchdev_notifier_info_to_extack(&port_obj_info->info);
  3355. br_dev = netdev_master_upper_dev_get(vxlan_dev);
  3356. if (!br_dev)
  3357. return 0;
  3358. mlxsw_sp = mlxsw_sp_lower_get(br_dev);
  3359. if (!mlxsw_sp)
  3360. return 0;
  3361. port_obj_info->handled = true;
  3362. bridge_device = mlxsw_sp_bridge_device_find(mlxsw_sp->bridge, br_dev);
  3363. if (!bridge_device)
  3364. return -EINVAL;
  3365. if (!bridge_device->vlan_enabled)
  3366. return 0;
  3367. return mlxsw_sp_switchdev_vxlan_vlan_add(mlxsw_sp, bridge_device,
  3368. vxlan_dev, vlan->vid,
  3369. flag_untagged,
  3370. flag_pvid, extack);
  3371. }
  3372. static void
  3373. mlxsw_sp_switchdev_vxlan_vlans_del(struct net_device *vxlan_dev,
  3374. struct switchdev_notifier_port_obj_info *
  3375. port_obj_info)
  3376. {
  3377. struct switchdev_obj_port_vlan *vlan =
  3378. SWITCHDEV_OBJ_PORT_VLAN(port_obj_info->obj);
  3379. struct mlxsw_sp_bridge_device *bridge_device;
  3380. struct mlxsw_sp *mlxsw_sp;
  3381. struct net_device *br_dev;
  3382. br_dev = netdev_master_upper_dev_get(vxlan_dev);
  3383. if (!br_dev)
  3384. return;
  3385. mlxsw_sp = mlxsw_sp_lower_get(br_dev);
  3386. if (!mlxsw_sp)
  3387. return;
  3388. port_obj_info->handled = true;
  3389. bridge_device = mlxsw_sp_bridge_device_find(mlxsw_sp->bridge, br_dev);
  3390. if (!bridge_device)
  3391. return;
  3392. if (!bridge_device->vlan_enabled)
  3393. return;
  3394. mlxsw_sp_switchdev_vxlan_vlan_del(mlxsw_sp, bridge_device, vxlan_dev,
  3395. vlan->vid);
  3396. }
  3397. static int
  3398. mlxsw_sp_switchdev_handle_vxlan_obj_add(struct net_device *vxlan_dev,
  3399. struct switchdev_notifier_port_obj_info *
  3400. port_obj_info)
  3401. {
  3402. int err = 0;
  3403. switch (port_obj_info->obj->id) {
  3404. case SWITCHDEV_OBJ_ID_PORT_VLAN:
  3405. err = mlxsw_sp_switchdev_vxlan_vlans_add(vxlan_dev,
  3406. port_obj_info);
  3407. break;
  3408. default:
  3409. break;
  3410. }
  3411. return err;
  3412. }
  3413. static void
  3414. mlxsw_sp_switchdev_handle_vxlan_obj_del(struct net_device *vxlan_dev,
  3415. struct switchdev_notifier_port_obj_info *
  3416. port_obj_info)
  3417. {
  3418. switch (port_obj_info->obj->id) {
  3419. case SWITCHDEV_OBJ_ID_PORT_VLAN:
  3420. mlxsw_sp_switchdev_vxlan_vlans_del(vxlan_dev, port_obj_info);
  3421. break;
  3422. default:
  3423. break;
  3424. }
  3425. }
  3426. static int mlxsw_sp_switchdev_blocking_event(struct notifier_block *unused,
  3427. unsigned long event, void *ptr)
  3428. {
  3429. struct net_device *dev = switchdev_notifier_info_to_dev(ptr);
  3430. int err = 0;
  3431. switch (event) {
  3432. case SWITCHDEV_PORT_OBJ_ADD:
  3433. if (netif_is_vxlan(dev))
  3434. err = mlxsw_sp_switchdev_handle_vxlan_obj_add(dev, ptr);
  3435. else
  3436. err = switchdev_handle_port_obj_add(dev, ptr,
  3437. mlxsw_sp_port_dev_check,
  3438. mlxsw_sp_port_obj_add);
  3439. return notifier_from_errno(err);
  3440. case SWITCHDEV_PORT_OBJ_DEL:
  3441. if (netif_is_vxlan(dev))
  3442. mlxsw_sp_switchdev_handle_vxlan_obj_del(dev, ptr);
  3443. else
  3444. err = switchdev_handle_port_obj_del(dev, ptr,
  3445. mlxsw_sp_port_dev_check,
  3446. mlxsw_sp_port_obj_del);
  3447. return notifier_from_errno(err);
  3448. case SWITCHDEV_PORT_ATTR_SET:
  3449. err = switchdev_handle_port_attr_set(dev, ptr,
  3450. mlxsw_sp_port_dev_check,
  3451. mlxsw_sp_port_attr_set);
  3452. return notifier_from_errno(err);
  3453. }
  3454. return NOTIFY_DONE;
  3455. }
  3456. static struct notifier_block mlxsw_sp_switchdev_blocking_notifier = {
  3457. .notifier_call = mlxsw_sp_switchdev_blocking_event,
  3458. };
  3459. u8
  3460. mlxsw_sp_bridge_port_stp_state(struct mlxsw_sp_bridge_port *bridge_port)
  3461. {
  3462. return bridge_port->stp_state;
  3463. }
  3464. static int mlxsw_sp_fdb_init(struct mlxsw_sp *mlxsw_sp)
  3465. {
  3466. struct mlxsw_sp_bridge *bridge = mlxsw_sp->bridge;
  3467. struct notifier_block *nb;
  3468. int err;
  3469. err = mlxsw_sp_ageing_set(mlxsw_sp, MLXSW_SP_DEFAULT_AGEING_TIME);
  3470. if (err) {
  3471. dev_err(mlxsw_sp->bus_info->dev, "Failed to set default ageing time\n");
  3472. return err;
  3473. }
  3474. err = register_switchdev_notifier(&mlxsw_sp_switchdev_notifier);
  3475. if (err) {
  3476. dev_err(mlxsw_sp->bus_info->dev, "Failed to register switchdev notifier\n");
  3477. return err;
  3478. }
  3479. nb = &mlxsw_sp_switchdev_blocking_notifier;
  3480. err = register_switchdev_blocking_notifier(nb);
  3481. if (err) {
  3482. dev_err(mlxsw_sp->bus_info->dev, "Failed to register switchdev blocking notifier\n");
  3483. goto err_register_switchdev_blocking_notifier;
  3484. }
  3485. INIT_DELAYED_WORK(&bridge->fdb_notify.dw, mlxsw_sp_fdb_notify_work);
  3486. bridge->fdb_notify.interval = MLXSW_SP_DEFAULT_LEARNING_INTERVAL;
  3487. return 0;
  3488. err_register_switchdev_blocking_notifier:
  3489. unregister_switchdev_notifier(&mlxsw_sp_switchdev_notifier);
  3490. return err;
  3491. }
  3492. static void mlxsw_sp_fdb_fini(struct mlxsw_sp *mlxsw_sp)
  3493. {
  3494. struct notifier_block *nb;
  3495. cancel_delayed_work_sync(&mlxsw_sp->bridge->fdb_notify.dw);
  3496. nb = &mlxsw_sp_switchdev_blocking_notifier;
  3497. unregister_switchdev_blocking_notifier(nb);
  3498. unregister_switchdev_notifier(&mlxsw_sp_switchdev_notifier);
  3499. }
  3500. static void mlxsw_sp1_switchdev_init(struct mlxsw_sp *mlxsw_sp)
  3501. {
  3502. mlxsw_sp->bridge->bridge_8021ad_ops = &mlxsw_sp1_bridge_8021ad_ops;
  3503. }
  3504. const struct mlxsw_sp_switchdev_ops mlxsw_sp1_switchdev_ops = {
  3505. .init = mlxsw_sp1_switchdev_init,
  3506. };
  3507. static void mlxsw_sp2_switchdev_init(struct mlxsw_sp *mlxsw_sp)
  3508. {
  3509. mlxsw_sp->bridge->bridge_8021ad_ops = &mlxsw_sp2_bridge_8021ad_ops;
  3510. }
  3511. const struct mlxsw_sp_switchdev_ops mlxsw_sp2_switchdev_ops = {
  3512. .init = mlxsw_sp2_switchdev_init,
  3513. };
  3514. int mlxsw_sp_switchdev_init(struct mlxsw_sp *mlxsw_sp)
  3515. {
  3516. struct mlxsw_sp_bridge *bridge;
  3517. bridge = kzalloc_obj(*mlxsw_sp->bridge);
  3518. if (!bridge)
  3519. return -ENOMEM;
  3520. mlxsw_sp->bridge = bridge;
  3521. bridge->mlxsw_sp = mlxsw_sp;
  3522. INIT_LIST_HEAD(&mlxsw_sp->bridge->bridges_list);
  3523. bridge->bridge_8021q_ops = &mlxsw_sp_bridge_8021q_ops;
  3524. bridge->bridge_8021d_ops = &mlxsw_sp_bridge_8021d_ops;
  3525. mlxsw_sp->switchdev_ops->init(mlxsw_sp);
  3526. return mlxsw_sp_fdb_init(mlxsw_sp);
  3527. }
  3528. void mlxsw_sp_switchdev_fini(struct mlxsw_sp *mlxsw_sp)
  3529. {
  3530. mlxsw_sp_fdb_fini(mlxsw_sp);
  3531. WARN_ON(!list_empty(&mlxsw_sp->bridge->bridges_list));
  3532. kfree(mlxsw_sp->bridge);
  3533. }