mlx-platform.c 151 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385
  1. // SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0
  2. /*
  3. * Mellanox platform driver
  4. *
  5. * Copyright (C) 2016-2018 Mellanox Technologies
  6. * Copyright (C) 2016-2018 Vadim Pasternak <[email protected]>
  7. */
  8. #include <linux/device.h>
  9. #include <linux/dmi.h>
  10. #include <linux/i2c.h>
  11. #include <linux/i2c-mux.h>
  12. #include <linux/io.h>
  13. #include <linux/module.h>
  14. #include <linux/platform_device.h>
  15. #include <linux/platform_data/i2c-mux-reg.h>
  16. #include <linux/platform_data/mlxreg.h>
  17. #include <linux/regmap.h>
  18. #define MLX_PLAT_DEVICE_NAME "mlxplat"
  19. /* LPC bus IO offsets */
  20. #define MLXPLAT_CPLD_LPC_I2C_BASE_ADRR 0x2000
  21. #define MLXPLAT_CPLD_LPC_REG_BASE_ADRR 0x2500
  22. #define MLXPLAT_CPLD_LPC_REG_CPLD1_VER_OFFSET 0x00
  23. #define MLXPLAT_CPLD_LPC_REG_CPLD2_VER_OFFSET 0x01
  24. #define MLXPLAT_CPLD_LPC_REG_CPLD3_VER_OFFSET 0x02
  25. #define MLXPLAT_CPLD_LPC_REG_CPLD4_VER_OFFSET 0x03
  26. #define MLXPLAT_CPLD_LPC_REG_CPLD1_PN_OFFSET 0x04
  27. #define MLXPLAT_CPLD_LPC_REG_CPLD1_PN1_OFFSET 0x05
  28. #define MLXPLAT_CPLD_LPC_REG_CPLD2_PN_OFFSET 0x06
  29. #define MLXPLAT_CPLD_LPC_REG_CPLD2_PN1_OFFSET 0x07
  30. #define MLXPLAT_CPLD_LPC_REG_CPLD3_PN_OFFSET 0x08
  31. #define MLXPLAT_CPLD_LPC_REG_CPLD3_PN1_OFFSET 0x09
  32. #define MLXPLAT_CPLD_LPC_REG_CPLD4_PN_OFFSET 0x0a
  33. #define MLXPLAT_CPLD_LPC_REG_CPLD4_PN1_OFFSET 0x0b
  34. #define MLXPLAT_CPLD_LPC_REG_RESET_GP2_OFFSET 0x19
  35. #define MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET 0x1c
  36. #define MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET 0x1d
  37. #define MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET 0x1e
  38. #define MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET 0x1f
  39. #define MLXPLAT_CPLD_LPC_REG_LED1_OFFSET 0x20
  40. #define MLXPLAT_CPLD_LPC_REG_LED2_OFFSET 0x21
  41. #define MLXPLAT_CPLD_LPC_REG_LED3_OFFSET 0x22
  42. #define MLXPLAT_CPLD_LPC_REG_LED4_OFFSET 0x23
  43. #define MLXPLAT_CPLD_LPC_REG_LED5_OFFSET 0x24
  44. #define MLXPLAT_CPLD_LPC_REG_LED6_OFFSET 0x25
  45. #define MLXPLAT_CPLD_LPC_REG_LED7_OFFSET 0x26
  46. #define MLXPLAT_CPLD_LPC_REG_FAN_DIRECTION 0x2a
  47. #define MLXPLAT_CPLD_LPC_REG_GP0_RO_OFFSET 0x2b
  48. #define MLXPLAT_CPLD_LPC_REG_GPCOM0_OFFSET 0x2d
  49. #define MLXPLAT_CPLD_LPC_REG_GP0_OFFSET 0x2e
  50. #define MLXPLAT_CPLD_LPC_REG_GP_RST_OFFSET 0x2f
  51. #define MLXPLAT_CPLD_LPC_REG_GP1_OFFSET 0x30
  52. #define MLXPLAT_CPLD_LPC_REG_WP1_OFFSET 0x31
  53. #define MLXPLAT_CPLD_LPC_REG_GP2_OFFSET 0x32
  54. #define MLXPLAT_CPLD_LPC_REG_WP2_OFFSET 0x33
  55. #define MLXPLAT_CPLD_LPC_REG_FIELD_UPGRADE 0x34
  56. #define MLXPLAT_CPLD_LPC_SAFE_BIOS_OFFSET 0x35
  57. #define MLXPLAT_CPLD_LPC_SAFE_BIOS_WP_OFFSET 0x36
  58. #define MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET 0x37
  59. #define MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET 0x3a
  60. #define MLXPLAT_CPLD_LPC_REG_AGGR_MASK_OFFSET 0x3b
  61. #define MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET 0x40
  62. #define MLXPLAT_CPLD_LPC_REG_AGGRLO_MASK_OFFSET 0x41
  63. #define MLXPLAT_CPLD_LPC_REG_AGGRCO_OFFSET 0x42
  64. #define MLXPLAT_CPLD_LPC_REG_AGGRCO_MASK_OFFSET 0x43
  65. #define MLXPLAT_CPLD_LPC_REG_AGGRCX_OFFSET 0x44
  66. #define MLXPLAT_CPLD_LPC_REG_AGGRCX_MASK_OFFSET 0x45
  67. #define MLXPLAT_CPLD_LPC_REG_GWP_OFFSET 0x4a
  68. #define MLXPLAT_CPLD_LPC_REG_GWP_EVENT_OFFSET 0x4b
  69. #define MLXPLAT_CPLD_LPC_REG_GWP_MASK_OFFSET 0x4c
  70. #define MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET 0x50
  71. #define MLXPLAT_CPLD_LPC_REG_ASIC_EVENT_OFFSET 0x51
  72. #define MLXPLAT_CPLD_LPC_REG_ASIC_MASK_OFFSET 0x52
  73. #define MLXPLAT_CPLD_LPC_REG_ASIC2_HEALTH_OFFSET 0x53
  74. #define MLXPLAT_CPLD_LPC_REG_ASIC2_EVENT_OFFSET 0x54
  75. #define MLXPLAT_CPLD_LPC_REG_ASIC2_MASK_OFFSET 0x55
  76. #define MLXPLAT_CPLD_LPC_REG_AGGRLC_OFFSET 0x56
  77. #define MLXPLAT_CPLD_LPC_REG_AGGRLC_MASK_OFFSET 0x57
  78. #define MLXPLAT_CPLD_LPC_REG_PSU_OFFSET 0x58
  79. #define MLXPLAT_CPLD_LPC_REG_PSU_EVENT_OFFSET 0x59
  80. #define MLXPLAT_CPLD_LPC_REG_PSU_MASK_OFFSET 0x5a
  81. #define MLXPLAT_CPLD_LPC_REG_PWR_OFFSET 0x64
  82. #define MLXPLAT_CPLD_LPC_REG_PWR_EVENT_OFFSET 0x65
  83. #define MLXPLAT_CPLD_LPC_REG_PWR_MASK_OFFSET 0x66
  84. #define MLXPLAT_CPLD_LPC_REG_LC_IN_OFFSET 0x70
  85. #define MLXPLAT_CPLD_LPC_REG_LC_IN_EVENT_OFFSET 0x71
  86. #define MLXPLAT_CPLD_LPC_REG_LC_IN_MASK_OFFSET 0x72
  87. #define MLXPLAT_CPLD_LPC_REG_FAN_OFFSET 0x88
  88. #define MLXPLAT_CPLD_LPC_REG_FAN_EVENT_OFFSET 0x89
  89. #define MLXPLAT_CPLD_LPC_REG_FAN_MASK_OFFSET 0x8a
  90. #define MLXPLAT_CPLD_LPC_REG_LC_VR_OFFSET 0x9a
  91. #define MLXPLAT_CPLD_LPC_REG_LC_VR_EVENT_OFFSET 0x9b
  92. #define MLXPLAT_CPLD_LPC_REG_LC_VR_MASK_OFFSET 0x9c
  93. #define MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET 0x9d
  94. #define MLXPLAT_CPLD_LPC_REG_LC_PG_EVENT_OFFSET 0x9e
  95. #define MLXPLAT_CPLD_LPC_REG_LC_PG_MASK_OFFSET 0x9f
  96. #define MLXPLAT_CPLD_LPC_REG_LC_RD_OFFSET 0xa0
  97. #define MLXPLAT_CPLD_LPC_REG_LC_RD_EVENT_OFFSET 0xa1
  98. #define MLXPLAT_CPLD_LPC_REG_LC_RD_MASK_OFFSET 0xa2
  99. #define MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET 0xa3
  100. #define MLXPLAT_CPLD_LPC_REG_LC_SN_EVENT_OFFSET 0xa4
  101. #define MLXPLAT_CPLD_LPC_REG_LC_SN_MASK_OFFSET 0xa5
  102. #define MLXPLAT_CPLD_LPC_REG_LC_OK_OFFSET 0xa6
  103. #define MLXPLAT_CPLD_LPC_REG_LC_OK_EVENT_OFFSET 0xa7
  104. #define MLXPLAT_CPLD_LPC_REG_LC_OK_MASK_OFFSET 0xa8
  105. #define MLXPLAT_CPLD_LPC_REG_LC_SD_OFFSET 0xa9
  106. #define MLXPLAT_CPLD_LPC_REG_LC_SD_EVENT_OFFSET 0xaa
  107. #define MLXPLAT_CPLD_LPC_REG_LC_SD_MASK_OFFSET 0xab
  108. #define MLXPLAT_CPLD_LPC_REG_LC_PWR_ON 0xb2
  109. #define MLXPLAT_CPLD_LPC_REG_WD_CLEAR_OFFSET 0xc7
  110. #define MLXPLAT_CPLD_LPC_REG_WD_CLEAR_WP_OFFSET 0xc8
  111. #define MLXPLAT_CPLD_LPC_REG_WD1_TMR_OFFSET 0xc9
  112. #define MLXPLAT_CPLD_LPC_REG_WD1_ACT_OFFSET 0xcb
  113. #define MLXPLAT_CPLD_LPC_REG_WD2_TMR_OFFSET 0xcd
  114. #define MLXPLAT_CPLD_LPC_REG_WD2_TLEFT_OFFSET 0xce
  115. #define MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET 0xcf
  116. #define MLXPLAT_CPLD_LPC_REG_WD3_TMR_OFFSET 0xd1
  117. #define MLXPLAT_CPLD_LPC_REG_WD3_TLEFT_OFFSET 0xd2
  118. #define MLXPLAT_CPLD_LPC_REG_WD3_ACT_OFFSET 0xd3
  119. #define MLXPLAT_CPLD_LPC_REG_CPLD1_MVER_OFFSET 0xde
  120. #define MLXPLAT_CPLD_LPC_REG_CPLD2_MVER_OFFSET 0xdf
  121. #define MLXPLAT_CPLD_LPC_REG_CPLD3_MVER_OFFSET 0xe0
  122. #define MLXPLAT_CPLD_LPC_REG_CPLD4_MVER_OFFSET 0xe1
  123. #define MLXPLAT_CPLD_LPC_REG_UFM_VERSION_OFFSET 0xe2
  124. #define MLXPLAT_CPLD_LPC_REG_PWM1_OFFSET 0xe3
  125. #define MLXPLAT_CPLD_LPC_REG_TACHO1_OFFSET 0xe4
  126. #define MLXPLAT_CPLD_LPC_REG_TACHO2_OFFSET 0xe5
  127. #define MLXPLAT_CPLD_LPC_REG_TACHO3_OFFSET 0xe6
  128. #define MLXPLAT_CPLD_LPC_REG_TACHO4_OFFSET 0xe7
  129. #define MLXPLAT_CPLD_LPC_REG_TACHO5_OFFSET 0xe8
  130. #define MLXPLAT_CPLD_LPC_REG_TACHO6_OFFSET 0xe9
  131. #define MLXPLAT_CPLD_LPC_REG_PWM2_OFFSET 0xea
  132. #define MLXPLAT_CPLD_LPC_REG_TACHO7_OFFSET 0xeb
  133. #define MLXPLAT_CPLD_LPC_REG_TACHO8_OFFSET 0xec
  134. #define MLXPLAT_CPLD_LPC_REG_TACHO9_OFFSET 0xed
  135. #define MLXPLAT_CPLD_LPC_REG_TACHO10_OFFSET 0xee
  136. #define MLXPLAT_CPLD_LPC_REG_TACHO11_OFFSET 0xef
  137. #define MLXPLAT_CPLD_LPC_REG_TACHO12_OFFSET 0xf0
  138. #define MLXPLAT_CPLD_LPC_REG_TACHO13_OFFSET 0xf1
  139. #define MLXPLAT_CPLD_LPC_REG_TACHO14_OFFSET 0xf2
  140. #define MLXPLAT_CPLD_LPC_REG_PWM3_OFFSET 0xf3
  141. #define MLXPLAT_CPLD_LPC_REG_PWM4_OFFSET 0xf4
  142. #define MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET 0xf5
  143. #define MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET 0xf6
  144. #define MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET 0xf7
  145. #define MLXPLAT_CPLD_LPC_REG_TACHO_SPEED_OFFSET 0xf8
  146. #define MLXPLAT_CPLD_LPC_REG_PSU_I2C_CAP_OFFSET 0xf9
  147. #define MLXPLAT_CPLD_LPC_REG_SLOT_QTY_OFFSET 0xfa
  148. #define MLXPLAT_CPLD_LPC_REG_CONFIG1_OFFSET 0xfb
  149. #define MLXPLAT_CPLD_LPC_REG_CONFIG2_OFFSET 0xfc
  150. #define MLXPLAT_CPLD_LPC_REG_CONFIG3_OFFSET 0xfd
  151. #define MLXPLAT_CPLD_LPC_IO_RANGE 0x100
  152. #define MLXPLAT_CPLD_LPC_I2C_CH1_OFF 0xdb
  153. #define MLXPLAT_CPLD_LPC_I2C_CH2_OFF 0xda
  154. #define MLXPLAT_CPLD_LPC_I2C_CH3_OFF 0xdc
  155. #define MLXPLAT_CPLD_LPC_I2C_CH4_OFF 0xdd
  156. #define MLXPLAT_CPLD_LPC_PIO_OFFSET 0x10000UL
  157. #define MLXPLAT_CPLD_LPC_REG1 ((MLXPLAT_CPLD_LPC_REG_BASE_ADRR + \
  158. MLXPLAT_CPLD_LPC_I2C_CH1_OFF) | \
  159. MLXPLAT_CPLD_LPC_PIO_OFFSET)
  160. #define MLXPLAT_CPLD_LPC_REG2 ((MLXPLAT_CPLD_LPC_REG_BASE_ADRR + \
  161. MLXPLAT_CPLD_LPC_I2C_CH2_OFF) | \
  162. MLXPLAT_CPLD_LPC_PIO_OFFSET)
  163. #define MLXPLAT_CPLD_LPC_REG3 ((MLXPLAT_CPLD_LPC_REG_BASE_ADRR + \
  164. MLXPLAT_CPLD_LPC_I2C_CH3_OFF) | \
  165. MLXPLAT_CPLD_LPC_PIO_OFFSET)
  166. #define MLXPLAT_CPLD_LPC_REG4 ((MLXPLAT_CPLD_LPC_REG_BASE_ADRR + \
  167. MLXPLAT_CPLD_LPC_I2C_CH4_OFF) | \
  168. MLXPLAT_CPLD_LPC_PIO_OFFSET)
  169. /* Masks for aggregation, psu, pwr and fan event in CPLD related registers. */
  170. #define MLXPLAT_CPLD_AGGR_ASIC_MASK_DEF 0x04
  171. #define MLXPLAT_CPLD_AGGR_PSU_MASK_DEF 0x08
  172. #define MLXPLAT_CPLD_AGGR_PWR_MASK_DEF 0x08
  173. #define MLXPLAT_CPLD_AGGR_FAN_MASK_DEF 0x40
  174. #define MLXPLAT_CPLD_AGGR_MASK_DEF (MLXPLAT_CPLD_AGGR_ASIC_MASK_DEF | \
  175. MLXPLAT_CPLD_AGGR_PSU_MASK_DEF | \
  176. MLXPLAT_CPLD_AGGR_FAN_MASK_DEF)
  177. #define MLXPLAT_CPLD_AGGR_ASIC_MASK_NG 0x01
  178. #define MLXPLAT_CPLD_AGGR_MASK_NG_DEF 0x04
  179. #define MLXPLAT_CPLD_AGGR_MASK_COMEX BIT(0)
  180. #define MLXPLAT_CPLD_AGGR_MASK_LC BIT(3)
  181. #define MLXPLAT_CPLD_AGGR_MASK_MODULAR (MLXPLAT_CPLD_AGGR_MASK_NG_DEF | \
  182. MLXPLAT_CPLD_AGGR_MASK_COMEX | \
  183. MLXPLAT_CPLD_AGGR_MASK_LC)
  184. #define MLXPLAT_CPLD_AGGR_MASK_LC_PRSNT BIT(0)
  185. #define MLXPLAT_CPLD_AGGR_MASK_LC_RDY BIT(1)
  186. #define MLXPLAT_CPLD_AGGR_MASK_LC_PG BIT(2)
  187. #define MLXPLAT_CPLD_AGGR_MASK_LC_SCRD BIT(3)
  188. #define MLXPLAT_CPLD_AGGR_MASK_LC_SYNC BIT(4)
  189. #define MLXPLAT_CPLD_AGGR_MASK_LC_ACT BIT(5)
  190. #define MLXPLAT_CPLD_AGGR_MASK_LC_SDWN BIT(6)
  191. #define MLXPLAT_CPLD_AGGR_MASK_LC_LOW (MLXPLAT_CPLD_AGGR_MASK_LC_PRSNT | \
  192. MLXPLAT_CPLD_AGGR_MASK_LC_RDY | \
  193. MLXPLAT_CPLD_AGGR_MASK_LC_PG | \
  194. MLXPLAT_CPLD_AGGR_MASK_LC_SCRD | \
  195. MLXPLAT_CPLD_AGGR_MASK_LC_SYNC | \
  196. MLXPLAT_CPLD_AGGR_MASK_LC_ACT | \
  197. MLXPLAT_CPLD_AGGR_MASK_LC_SDWN)
  198. #define MLXPLAT_CPLD_LOW_AGGR_MASK_LOW 0xc1
  199. #define MLXPLAT_CPLD_LOW_AGGR_MASK_ASIC2 BIT(2)
  200. #define MLXPLAT_CPLD_LOW_AGGR_MASK_I2C BIT(6)
  201. #define MLXPLAT_CPLD_PSU_MASK GENMASK(1, 0)
  202. #define MLXPLAT_CPLD_PWR_MASK GENMASK(1, 0)
  203. #define MLXPLAT_CPLD_PSU_EXT_MASK GENMASK(3, 0)
  204. #define MLXPLAT_CPLD_PWR_EXT_MASK GENMASK(3, 0)
  205. #define MLXPLAT_CPLD_FAN_MASK GENMASK(3, 0)
  206. #define MLXPLAT_CPLD_ASIC_MASK GENMASK(1, 0)
  207. #define MLXPLAT_CPLD_FAN_NG_MASK GENMASK(6, 0)
  208. #define MLXPLAT_CPLD_LED_LO_NIBBLE_MASK GENMASK(7, 4)
  209. #define MLXPLAT_CPLD_LED_HI_NIBBLE_MASK GENMASK(3, 0)
  210. #define MLXPLAT_CPLD_VOLTREG_UPD_MASK GENMASK(5, 4)
  211. #define MLXPLAT_CPLD_GWP_MASK GENMASK(0, 0)
  212. #define MLXPLAT_CPLD_I2C_CAP_BIT 0x04
  213. #define MLXPLAT_CPLD_I2C_CAP_MASK GENMASK(5, MLXPLAT_CPLD_I2C_CAP_BIT)
  214. /* Masks for aggregation for comex carriers */
  215. #define MLXPLAT_CPLD_AGGR_MASK_CARRIER BIT(1)
  216. #define MLXPLAT_CPLD_AGGR_MASK_CARR_DEF (MLXPLAT_CPLD_AGGR_ASIC_MASK_DEF | \
  217. MLXPLAT_CPLD_AGGR_MASK_CARRIER)
  218. #define MLXPLAT_CPLD_LOW_AGGRCX_MASK 0xc1
  219. /* Masks for aggregation for modular systems */
  220. #define MLXPLAT_CPLD_LPC_LC_MASK GENMASK(7, 0)
  221. /* Default I2C parent bus number */
  222. #define MLXPLAT_CPLD_PHYS_ADAPTER_DEF_NR 1
  223. /* Maximum number of possible physical buses equipped on system */
  224. #define MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM 16
  225. #define MLXPLAT_CPLD_MAX_PHYS_EXT_ADAPTER_NUM 24
  226. /* Number of channels in group */
  227. #define MLXPLAT_CPLD_GRP_CHNL_NUM 8
  228. /* Start channel numbers */
  229. #define MLXPLAT_CPLD_CH1 2
  230. #define MLXPLAT_CPLD_CH2 10
  231. #define MLXPLAT_CPLD_CH3 18
  232. #define MLXPLAT_CPLD_CH2_ETH_MODULAR 3
  233. #define MLXPLAT_CPLD_CH3_ETH_MODULAR 43
  234. #define MLXPLAT_CPLD_CH4_ETH_MODULAR 51
  235. /* Number of LPC attached MUX platform devices */
  236. #define MLXPLAT_CPLD_LPC_MUX_DEVS 4
  237. /* Hotplug devices adapter numbers */
  238. #define MLXPLAT_CPLD_NR_NONE -1
  239. #define MLXPLAT_CPLD_PSU_DEFAULT_NR 10
  240. #define MLXPLAT_CPLD_PSU_MSNXXXX_NR 4
  241. #define MLXPLAT_CPLD_FAN1_DEFAULT_NR 11
  242. #define MLXPLAT_CPLD_FAN2_DEFAULT_NR 12
  243. #define MLXPLAT_CPLD_FAN3_DEFAULT_NR 13
  244. #define MLXPLAT_CPLD_FAN4_DEFAULT_NR 14
  245. #define MLXPLAT_CPLD_NR_ASIC 3
  246. #define MLXPLAT_CPLD_NR_LC_BASE 34
  247. #define MLXPLAT_CPLD_NR_LC_SET(nr) (MLXPLAT_CPLD_NR_LC_BASE + (nr))
  248. #define MLXPLAT_CPLD_LC_ADDR 0x32
  249. /* Masks and default values for watchdogs */
  250. #define MLXPLAT_CPLD_WD1_CLEAR_MASK GENMASK(7, 1)
  251. #define MLXPLAT_CPLD_WD2_CLEAR_MASK (GENMASK(7, 0) & ~BIT(1))
  252. #define MLXPLAT_CPLD_WD_TYPE1_TO_MASK GENMASK(7, 4)
  253. #define MLXPLAT_CPLD_WD_TYPE2_TO_MASK 0
  254. #define MLXPLAT_CPLD_WD_RESET_ACT_MASK GENMASK(7, 1)
  255. #define MLXPLAT_CPLD_WD_FAN_ACT_MASK (GENMASK(7, 0) & ~BIT(4))
  256. #define MLXPLAT_CPLD_WD_COUNT_ACT_MASK (GENMASK(7, 0) & ~BIT(7))
  257. #define MLXPLAT_CPLD_WD_CPBLTY_MASK (GENMASK(7, 0) & ~BIT(6))
  258. #define MLXPLAT_CPLD_WD_DFLT_TIMEOUT 30
  259. #define MLXPLAT_CPLD_WD3_DFLT_TIMEOUT 600
  260. #define MLXPLAT_CPLD_WD_MAX_DEVS 2
  261. #define MLXPLAT_CPLD_LPC_SYSIRQ 17
  262. /* Minimum power required for turning on Ethernet modular system (WATT) */
  263. #define MLXPLAT_CPLD_ETH_MODULAR_PWR_MIN 50
  264. /* mlxplat_priv - platform private data
  265. * @pdev_i2c - i2c controller platform device
  266. * @pdev_mux - array of mux platform devices
  267. * @pdev_hotplug - hotplug platform devices
  268. * @pdev_led - led platform devices
  269. * @pdev_io_regs - register access platform devices
  270. * @pdev_fan - FAN platform devices
  271. * @pdev_wd - array of watchdog platform devices
  272. * @regmap: device register map
  273. */
  274. struct mlxplat_priv {
  275. struct platform_device *pdev_i2c;
  276. struct platform_device *pdev_mux[MLXPLAT_CPLD_LPC_MUX_DEVS];
  277. struct platform_device *pdev_hotplug;
  278. struct platform_device *pdev_led;
  279. struct platform_device *pdev_io_regs;
  280. struct platform_device *pdev_fan;
  281. struct platform_device *pdev_wd[MLXPLAT_CPLD_WD_MAX_DEVS];
  282. void *regmap;
  283. };
  284. /* Regions for LPC I2C controller and LPC base register space */
  285. static const struct resource mlxplat_lpc_resources[] = {
  286. [0] = DEFINE_RES_NAMED(MLXPLAT_CPLD_LPC_I2C_BASE_ADRR,
  287. MLXPLAT_CPLD_LPC_IO_RANGE,
  288. "mlxplat_cpld_lpc_i2c_ctrl", IORESOURCE_IO),
  289. [1] = DEFINE_RES_NAMED(MLXPLAT_CPLD_LPC_REG_BASE_ADRR,
  290. MLXPLAT_CPLD_LPC_IO_RANGE,
  291. "mlxplat_cpld_lpc_regs",
  292. IORESOURCE_IO),
  293. };
  294. /* Platform i2c next generation systems data */
  295. static struct mlxreg_core_data mlxplat_mlxcpld_i2c_ng_items_data[] = {
  296. {
  297. .reg = MLXPLAT_CPLD_LPC_REG_PSU_I2C_CAP_OFFSET,
  298. .mask = MLXPLAT_CPLD_I2C_CAP_MASK,
  299. .bit = MLXPLAT_CPLD_I2C_CAP_BIT,
  300. },
  301. };
  302. static struct mlxreg_core_item mlxplat_mlxcpld_i2c_ng_items[] = {
  303. {
  304. .data = mlxplat_mlxcpld_i2c_ng_items_data,
  305. },
  306. };
  307. /* Platform next generation systems i2c data */
  308. static struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_i2c_ng_data = {
  309. .items = mlxplat_mlxcpld_i2c_ng_items,
  310. .cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET,
  311. .mask = MLXPLAT_CPLD_AGGR_MASK_COMEX,
  312. .cell_low = MLXPLAT_CPLD_LPC_REG_AGGRCO_OFFSET,
  313. .mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_I2C,
  314. };
  315. /* Platform default channels */
  316. static const int mlxplat_default_channels[][MLXPLAT_CPLD_GRP_CHNL_NUM] = {
  317. {
  318. MLXPLAT_CPLD_CH1, MLXPLAT_CPLD_CH1 + 1, MLXPLAT_CPLD_CH1 + 2,
  319. MLXPLAT_CPLD_CH1 + 3, MLXPLAT_CPLD_CH1 + 4, MLXPLAT_CPLD_CH1 +
  320. 5, MLXPLAT_CPLD_CH1 + 6, MLXPLAT_CPLD_CH1 + 7
  321. },
  322. {
  323. MLXPLAT_CPLD_CH2, MLXPLAT_CPLD_CH2 + 1, MLXPLAT_CPLD_CH2 + 2,
  324. MLXPLAT_CPLD_CH2 + 3, MLXPLAT_CPLD_CH2 + 4, MLXPLAT_CPLD_CH2 +
  325. 5, MLXPLAT_CPLD_CH2 + 6, MLXPLAT_CPLD_CH2 + 7
  326. },
  327. };
  328. /* Platform channels for MSN21xx system family */
  329. static const int mlxplat_msn21xx_channels[] = { 1, 2, 3, 4, 5, 6, 7, 8 };
  330. /* Platform mux data */
  331. static struct i2c_mux_reg_platform_data mlxplat_default_mux_data[] = {
  332. {
  333. .parent = 1,
  334. .base_nr = MLXPLAT_CPLD_CH1,
  335. .write_only = 1,
  336. .reg = (void __iomem *)MLXPLAT_CPLD_LPC_REG1,
  337. .reg_size = 1,
  338. .idle_in_use = 1,
  339. },
  340. {
  341. .parent = 1,
  342. .base_nr = MLXPLAT_CPLD_CH2,
  343. .write_only = 1,
  344. .reg = (void __iomem *)MLXPLAT_CPLD_LPC_REG2,
  345. .reg_size = 1,
  346. .idle_in_use = 1,
  347. },
  348. };
  349. /* Platform mux configuration variables */
  350. static int mlxplat_max_adap_num;
  351. static int mlxplat_mux_num;
  352. static struct i2c_mux_reg_platform_data *mlxplat_mux_data;
  353. /* Platform extended mux data */
  354. static struct i2c_mux_reg_platform_data mlxplat_extended_mux_data[] = {
  355. {
  356. .parent = 1,
  357. .base_nr = MLXPLAT_CPLD_CH1,
  358. .write_only = 1,
  359. .reg = (void __iomem *)MLXPLAT_CPLD_LPC_REG1,
  360. .reg_size = 1,
  361. .idle_in_use = 1,
  362. },
  363. {
  364. .parent = 1,
  365. .base_nr = MLXPLAT_CPLD_CH2,
  366. .write_only = 1,
  367. .reg = (void __iomem *)MLXPLAT_CPLD_LPC_REG3,
  368. .reg_size = 1,
  369. .idle_in_use = 1,
  370. },
  371. {
  372. .parent = 1,
  373. .base_nr = MLXPLAT_CPLD_CH3,
  374. .write_only = 1,
  375. .reg = (void __iomem *)MLXPLAT_CPLD_LPC_REG2,
  376. .reg_size = 1,
  377. .idle_in_use = 1,
  378. },
  379. };
  380. /* Platform channels for modular system family */
  381. static const int mlxplat_modular_upper_channel[] = { 1 };
  382. static const int mlxplat_modular_channels[] = {
  383. 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20,
  384. 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37,
  385. 38, 39, 40
  386. };
  387. /* Platform modular mux data */
  388. static struct i2c_mux_reg_platform_data mlxplat_modular_mux_data[] = {
  389. {
  390. .parent = 1,
  391. .base_nr = MLXPLAT_CPLD_CH1,
  392. .write_only = 1,
  393. .reg = (void __iomem *)MLXPLAT_CPLD_LPC_REG4,
  394. .reg_size = 1,
  395. .idle_in_use = 1,
  396. .values = mlxplat_modular_upper_channel,
  397. .n_values = ARRAY_SIZE(mlxplat_modular_upper_channel),
  398. },
  399. {
  400. .parent = 1,
  401. .base_nr = MLXPLAT_CPLD_CH2_ETH_MODULAR,
  402. .write_only = 1,
  403. .reg = (void __iomem *)MLXPLAT_CPLD_LPC_REG1,
  404. .reg_size = 1,
  405. .idle_in_use = 1,
  406. .values = mlxplat_modular_channels,
  407. .n_values = ARRAY_SIZE(mlxplat_modular_channels),
  408. },
  409. {
  410. .parent = MLXPLAT_CPLD_CH1,
  411. .base_nr = MLXPLAT_CPLD_CH3_ETH_MODULAR,
  412. .write_only = 1,
  413. .reg = (void __iomem *)MLXPLAT_CPLD_LPC_REG3,
  414. .reg_size = 1,
  415. .idle_in_use = 1,
  416. .values = mlxplat_msn21xx_channels,
  417. .n_values = ARRAY_SIZE(mlxplat_msn21xx_channels),
  418. },
  419. {
  420. .parent = 1,
  421. .base_nr = MLXPLAT_CPLD_CH4_ETH_MODULAR,
  422. .write_only = 1,
  423. .reg = (void __iomem *)MLXPLAT_CPLD_LPC_REG2,
  424. .reg_size = 1,
  425. .idle_in_use = 1,
  426. .values = mlxplat_msn21xx_channels,
  427. .n_values = ARRAY_SIZE(mlxplat_msn21xx_channels),
  428. },
  429. };
  430. /* Platform hotplug devices */
  431. static struct i2c_board_info mlxplat_mlxcpld_pwr[] = {
  432. {
  433. I2C_BOARD_INFO("dps460", 0x59),
  434. },
  435. {
  436. I2C_BOARD_INFO("dps460", 0x58),
  437. },
  438. };
  439. static struct i2c_board_info mlxplat_mlxcpld_ext_pwr[] = {
  440. {
  441. I2C_BOARD_INFO("dps460", 0x5b),
  442. },
  443. {
  444. I2C_BOARD_INFO("dps460", 0x5a),
  445. },
  446. };
  447. static struct i2c_board_info mlxplat_mlxcpld_fan[] = {
  448. {
  449. I2C_BOARD_INFO("24c32", 0x50),
  450. },
  451. {
  452. I2C_BOARD_INFO("24c32", 0x50),
  453. },
  454. {
  455. I2C_BOARD_INFO("24c32", 0x50),
  456. },
  457. {
  458. I2C_BOARD_INFO("24c32", 0x50),
  459. },
  460. };
  461. /* Platform hotplug comex carrier system family data */
  462. static struct mlxreg_core_data mlxplat_mlxcpld_comex_psu_items_data[] = {
  463. {
  464. .label = "psu1",
  465. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  466. .mask = BIT(0),
  467. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  468. },
  469. {
  470. .label = "psu2",
  471. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  472. .mask = BIT(1),
  473. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  474. },
  475. };
  476. /* Platform hotplug default data */
  477. static struct mlxreg_core_data mlxplat_mlxcpld_default_psu_items_data[] = {
  478. {
  479. .label = "psu1",
  480. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  481. .mask = BIT(0),
  482. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  483. },
  484. {
  485. .label = "psu2",
  486. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  487. .mask = BIT(1),
  488. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  489. },
  490. };
  491. static struct mlxreg_core_data mlxplat_mlxcpld_default_pwr_items_data[] = {
  492. {
  493. .label = "pwr1",
  494. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  495. .mask = BIT(0),
  496. .hpdev.brdinfo = &mlxplat_mlxcpld_pwr[0],
  497. .hpdev.nr = MLXPLAT_CPLD_PSU_DEFAULT_NR,
  498. },
  499. {
  500. .label = "pwr2",
  501. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  502. .mask = BIT(1),
  503. .hpdev.brdinfo = &mlxplat_mlxcpld_pwr[1],
  504. .hpdev.nr = MLXPLAT_CPLD_PSU_DEFAULT_NR,
  505. },
  506. };
  507. static struct mlxreg_core_data mlxplat_mlxcpld_default_pwr_wc_items_data[] = {
  508. {
  509. .label = "pwr1",
  510. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  511. .mask = BIT(0),
  512. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  513. },
  514. {
  515. .label = "pwr2",
  516. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  517. .mask = BIT(1),
  518. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  519. },
  520. };
  521. static struct mlxreg_core_data mlxplat_mlxcpld_default_fan_items_data[] = {
  522. {
  523. .label = "fan1",
  524. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  525. .mask = BIT(0),
  526. .hpdev.brdinfo = &mlxplat_mlxcpld_fan[0],
  527. .hpdev.nr = MLXPLAT_CPLD_FAN1_DEFAULT_NR,
  528. },
  529. {
  530. .label = "fan2",
  531. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  532. .mask = BIT(1),
  533. .hpdev.brdinfo = &mlxplat_mlxcpld_fan[1],
  534. .hpdev.nr = MLXPLAT_CPLD_FAN2_DEFAULT_NR,
  535. },
  536. {
  537. .label = "fan3",
  538. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  539. .mask = BIT(2),
  540. .hpdev.brdinfo = &mlxplat_mlxcpld_fan[2],
  541. .hpdev.nr = MLXPLAT_CPLD_FAN3_DEFAULT_NR,
  542. },
  543. {
  544. .label = "fan4",
  545. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  546. .mask = BIT(3),
  547. .hpdev.brdinfo = &mlxplat_mlxcpld_fan[3],
  548. .hpdev.nr = MLXPLAT_CPLD_FAN4_DEFAULT_NR,
  549. },
  550. };
  551. static struct mlxreg_core_data mlxplat_mlxcpld_default_asic_items_data[] = {
  552. {
  553. .label = "asic1",
  554. .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET,
  555. .mask = MLXPLAT_CPLD_ASIC_MASK,
  556. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  557. },
  558. };
  559. static struct mlxreg_core_data mlxplat_mlxcpld_default_asic2_items_data[] = {
  560. {
  561. .label = "asic2",
  562. .reg = MLXPLAT_CPLD_LPC_REG_ASIC2_HEALTH_OFFSET,
  563. .mask = MLXPLAT_CPLD_ASIC_MASK,
  564. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  565. },
  566. };
  567. static struct mlxreg_core_item mlxplat_mlxcpld_default_items[] = {
  568. {
  569. .data = mlxplat_mlxcpld_default_psu_items_data,
  570. .aggr_mask = MLXPLAT_CPLD_AGGR_PSU_MASK_DEF,
  571. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  572. .mask = MLXPLAT_CPLD_PSU_MASK,
  573. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_psu_items_data),
  574. .inversed = 1,
  575. .health = false,
  576. },
  577. {
  578. .data = mlxplat_mlxcpld_default_pwr_items_data,
  579. .aggr_mask = MLXPLAT_CPLD_AGGR_PWR_MASK_DEF,
  580. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  581. .mask = MLXPLAT_CPLD_PWR_MASK,
  582. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_pwr_items_data),
  583. .inversed = 0,
  584. .health = false,
  585. },
  586. {
  587. .data = mlxplat_mlxcpld_default_fan_items_data,
  588. .aggr_mask = MLXPLAT_CPLD_AGGR_FAN_MASK_DEF,
  589. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  590. .mask = MLXPLAT_CPLD_FAN_MASK,
  591. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_fan_items_data),
  592. .inversed = 1,
  593. .health = false,
  594. },
  595. {
  596. .data = mlxplat_mlxcpld_default_asic_items_data,
  597. .aggr_mask = MLXPLAT_CPLD_AGGR_ASIC_MASK_DEF,
  598. .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET,
  599. .mask = MLXPLAT_CPLD_ASIC_MASK,
  600. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_asic_items_data),
  601. .inversed = 0,
  602. .health = true,
  603. },
  604. };
  605. static struct mlxreg_core_item mlxplat_mlxcpld_comex_items[] = {
  606. {
  607. .data = mlxplat_mlxcpld_comex_psu_items_data,
  608. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_CARRIER,
  609. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  610. .mask = MLXPLAT_CPLD_PSU_MASK,
  611. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_psu_items_data),
  612. .inversed = 1,
  613. .health = false,
  614. },
  615. {
  616. .data = mlxplat_mlxcpld_default_pwr_items_data,
  617. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_CARRIER,
  618. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  619. .mask = MLXPLAT_CPLD_PWR_MASK,
  620. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_pwr_items_data),
  621. .inversed = 0,
  622. .health = false,
  623. },
  624. {
  625. .data = mlxplat_mlxcpld_default_fan_items_data,
  626. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_CARRIER,
  627. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  628. .mask = MLXPLAT_CPLD_FAN_MASK,
  629. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_fan_items_data),
  630. .inversed = 1,
  631. .health = false,
  632. },
  633. {
  634. .data = mlxplat_mlxcpld_default_asic_items_data,
  635. .aggr_mask = MLXPLAT_CPLD_AGGR_ASIC_MASK_DEF,
  636. .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET,
  637. .mask = MLXPLAT_CPLD_ASIC_MASK,
  638. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_asic_items_data),
  639. .inversed = 0,
  640. .health = true,
  641. },
  642. };
  643. static
  644. struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_default_data = {
  645. .items = mlxplat_mlxcpld_default_items,
  646. .counter = ARRAY_SIZE(mlxplat_mlxcpld_default_items),
  647. .cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET,
  648. .mask = MLXPLAT_CPLD_AGGR_MASK_DEF,
  649. .cell_low = MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET,
  650. .mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW,
  651. };
  652. static struct mlxreg_core_item mlxplat_mlxcpld_default_wc_items[] = {
  653. {
  654. .data = mlxplat_mlxcpld_comex_psu_items_data,
  655. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_CARRIER,
  656. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  657. .mask = MLXPLAT_CPLD_PSU_MASK,
  658. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_psu_items_data),
  659. .inversed = 1,
  660. .health = false,
  661. },
  662. {
  663. .data = mlxplat_mlxcpld_default_pwr_wc_items_data,
  664. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_CARRIER,
  665. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  666. .mask = MLXPLAT_CPLD_PWR_MASK,
  667. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_pwr_items_data),
  668. .inversed = 0,
  669. .health = false,
  670. },
  671. {
  672. .data = mlxplat_mlxcpld_default_asic_items_data,
  673. .aggr_mask = MLXPLAT_CPLD_AGGR_ASIC_MASK_DEF,
  674. .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET,
  675. .mask = MLXPLAT_CPLD_ASIC_MASK,
  676. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_asic_items_data),
  677. .inversed = 0,
  678. .health = true,
  679. },
  680. };
  681. static
  682. struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_default_wc_data = {
  683. .items = mlxplat_mlxcpld_default_wc_items,
  684. .counter = ARRAY_SIZE(mlxplat_mlxcpld_default_wc_items),
  685. .cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET,
  686. .mask = MLXPLAT_CPLD_AGGR_MASK_DEF,
  687. .cell_low = MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET,
  688. .mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW,
  689. };
  690. static
  691. struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_comex_data = {
  692. .items = mlxplat_mlxcpld_comex_items,
  693. .counter = ARRAY_SIZE(mlxplat_mlxcpld_comex_items),
  694. .cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET,
  695. .mask = MLXPLAT_CPLD_AGGR_MASK_CARR_DEF,
  696. .cell_low = MLXPLAT_CPLD_LPC_REG_AGGRCX_OFFSET,
  697. .mask_low = MLXPLAT_CPLD_LOW_AGGRCX_MASK,
  698. };
  699. static struct mlxreg_core_data mlxplat_mlxcpld_msn21xx_pwr_items_data[] = {
  700. {
  701. .label = "pwr1",
  702. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  703. .mask = BIT(0),
  704. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  705. },
  706. {
  707. .label = "pwr2",
  708. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  709. .mask = BIT(1),
  710. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  711. },
  712. };
  713. /* Platform hotplug MSN21xx system family data */
  714. static struct mlxreg_core_item mlxplat_mlxcpld_msn21xx_items[] = {
  715. {
  716. .data = mlxplat_mlxcpld_msn21xx_pwr_items_data,
  717. .aggr_mask = MLXPLAT_CPLD_AGGR_PWR_MASK_DEF,
  718. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  719. .mask = MLXPLAT_CPLD_PWR_MASK,
  720. .count = ARRAY_SIZE(mlxplat_mlxcpld_msn21xx_pwr_items_data),
  721. .inversed = 0,
  722. .health = false,
  723. },
  724. {
  725. .data = mlxplat_mlxcpld_default_asic_items_data,
  726. .aggr_mask = MLXPLAT_CPLD_AGGR_ASIC_MASK_DEF,
  727. .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET,
  728. .mask = MLXPLAT_CPLD_ASIC_MASK,
  729. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_asic_items_data),
  730. .inversed = 0,
  731. .health = true,
  732. },
  733. };
  734. static
  735. struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_msn21xx_data = {
  736. .items = mlxplat_mlxcpld_msn21xx_items,
  737. .counter = ARRAY_SIZE(mlxplat_mlxcpld_msn21xx_items),
  738. .cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET,
  739. .mask = MLXPLAT_CPLD_AGGR_MASK_DEF,
  740. .cell_low = MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET,
  741. .mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW,
  742. };
  743. /* Platform hotplug msn274x system family data */
  744. static struct mlxreg_core_data mlxplat_mlxcpld_msn274x_psu_items_data[] = {
  745. {
  746. .label = "psu1",
  747. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  748. .mask = BIT(0),
  749. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  750. },
  751. {
  752. .label = "psu2",
  753. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  754. .mask = BIT(1),
  755. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  756. },
  757. };
  758. static struct mlxreg_core_data mlxplat_mlxcpld_default_ng_pwr_items_data[] = {
  759. {
  760. .label = "pwr1",
  761. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  762. .mask = BIT(0),
  763. .hpdev.brdinfo = &mlxplat_mlxcpld_pwr[0],
  764. .hpdev.nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR,
  765. },
  766. {
  767. .label = "pwr2",
  768. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  769. .mask = BIT(1),
  770. .hpdev.brdinfo = &mlxplat_mlxcpld_pwr[1],
  771. .hpdev.nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR,
  772. },
  773. };
  774. static struct mlxreg_core_data mlxplat_mlxcpld_msn274x_fan_items_data[] = {
  775. {
  776. .label = "fan1",
  777. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  778. .mask = BIT(0),
  779. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  780. },
  781. {
  782. .label = "fan2",
  783. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  784. .mask = BIT(1),
  785. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  786. },
  787. {
  788. .label = "fan3",
  789. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  790. .mask = BIT(2),
  791. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  792. },
  793. {
  794. .label = "fan4",
  795. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  796. .mask = BIT(3),
  797. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  798. },
  799. };
  800. static struct mlxreg_core_item mlxplat_mlxcpld_msn274x_items[] = {
  801. {
  802. .data = mlxplat_mlxcpld_msn274x_psu_items_data,
  803. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  804. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  805. .mask = MLXPLAT_CPLD_PSU_MASK,
  806. .count = ARRAY_SIZE(mlxplat_mlxcpld_msn274x_psu_items_data),
  807. .inversed = 1,
  808. .health = false,
  809. },
  810. {
  811. .data = mlxplat_mlxcpld_default_ng_pwr_items_data,
  812. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  813. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  814. .mask = MLXPLAT_CPLD_PWR_MASK,
  815. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_ng_pwr_items_data),
  816. .inversed = 0,
  817. .health = false,
  818. },
  819. {
  820. .data = mlxplat_mlxcpld_msn274x_fan_items_data,
  821. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  822. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  823. .mask = MLXPLAT_CPLD_FAN_MASK,
  824. .count = ARRAY_SIZE(mlxplat_mlxcpld_msn274x_fan_items_data),
  825. .inversed = 1,
  826. .health = false,
  827. },
  828. {
  829. .data = mlxplat_mlxcpld_default_asic_items_data,
  830. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  831. .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET,
  832. .mask = MLXPLAT_CPLD_ASIC_MASK,
  833. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_asic_items_data),
  834. .inversed = 0,
  835. .health = true,
  836. },
  837. };
  838. static
  839. struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_msn274x_data = {
  840. .items = mlxplat_mlxcpld_msn274x_items,
  841. .counter = ARRAY_SIZE(mlxplat_mlxcpld_msn274x_items),
  842. .cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET,
  843. .mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  844. .cell_low = MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET,
  845. .mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW,
  846. };
  847. /* Platform hotplug MSN201x system family data */
  848. static struct mlxreg_core_data mlxplat_mlxcpld_msn201x_pwr_items_data[] = {
  849. {
  850. .label = "pwr1",
  851. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  852. .mask = BIT(0),
  853. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  854. },
  855. {
  856. .label = "pwr2",
  857. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  858. .mask = BIT(1),
  859. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  860. },
  861. };
  862. static struct mlxreg_core_item mlxplat_mlxcpld_msn201x_items[] = {
  863. {
  864. .data = mlxplat_mlxcpld_msn201x_pwr_items_data,
  865. .aggr_mask = MLXPLAT_CPLD_AGGR_PWR_MASK_DEF,
  866. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  867. .mask = MLXPLAT_CPLD_PWR_MASK,
  868. .count = ARRAY_SIZE(mlxplat_mlxcpld_msn201x_pwr_items_data),
  869. .inversed = 0,
  870. .health = false,
  871. },
  872. {
  873. .data = mlxplat_mlxcpld_default_asic_items_data,
  874. .aggr_mask = MLXPLAT_CPLD_AGGR_ASIC_MASK_DEF,
  875. .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET,
  876. .mask = MLXPLAT_CPLD_ASIC_MASK,
  877. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_asic_items_data),
  878. .inversed = 0,
  879. .health = true,
  880. },
  881. };
  882. static
  883. struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_msn201x_data = {
  884. .items = mlxplat_mlxcpld_msn201x_items,
  885. .counter = ARRAY_SIZE(mlxplat_mlxcpld_msn201x_items),
  886. .cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET,
  887. .mask = MLXPLAT_CPLD_AGGR_MASK_DEF,
  888. .cell_low = MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET,
  889. .mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW,
  890. };
  891. /* Platform hotplug next generation system family data */
  892. static struct mlxreg_core_data mlxplat_mlxcpld_default_ng_psu_items_data[] = {
  893. {
  894. .label = "psu1",
  895. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  896. .mask = BIT(0),
  897. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  898. },
  899. {
  900. .label = "psu2",
  901. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  902. .mask = BIT(1),
  903. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  904. },
  905. };
  906. static struct mlxreg_core_data mlxplat_mlxcpld_default_ng_fan_items_data[] = {
  907. {
  908. .label = "fan1",
  909. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  910. .mask = BIT(0),
  911. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  912. .bit = BIT(0),
  913. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  914. },
  915. {
  916. .label = "fan2",
  917. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  918. .mask = BIT(1),
  919. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  920. .bit = BIT(1),
  921. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  922. },
  923. {
  924. .label = "fan3",
  925. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  926. .mask = BIT(2),
  927. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  928. .bit = BIT(2),
  929. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  930. },
  931. {
  932. .label = "fan4",
  933. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  934. .mask = BIT(3),
  935. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  936. .bit = BIT(3),
  937. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  938. },
  939. {
  940. .label = "fan5",
  941. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  942. .mask = BIT(4),
  943. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  944. .bit = BIT(4),
  945. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  946. },
  947. {
  948. .label = "fan6",
  949. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  950. .mask = BIT(5),
  951. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  952. .bit = BIT(5),
  953. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  954. },
  955. {
  956. .label = "fan7",
  957. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  958. .mask = BIT(6),
  959. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  960. .bit = BIT(6),
  961. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  962. },
  963. };
  964. static struct mlxreg_core_item mlxplat_mlxcpld_default_ng_items[] = {
  965. {
  966. .data = mlxplat_mlxcpld_default_ng_psu_items_data,
  967. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  968. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  969. .mask = MLXPLAT_CPLD_PSU_MASK,
  970. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_ng_psu_items_data),
  971. .inversed = 1,
  972. .health = false,
  973. },
  974. {
  975. .data = mlxplat_mlxcpld_default_ng_pwr_items_data,
  976. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  977. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  978. .mask = MLXPLAT_CPLD_PWR_MASK,
  979. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_ng_pwr_items_data),
  980. .inversed = 0,
  981. .health = false,
  982. },
  983. {
  984. .data = mlxplat_mlxcpld_default_ng_fan_items_data,
  985. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  986. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  987. .mask = MLXPLAT_CPLD_FAN_NG_MASK,
  988. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_ng_fan_items_data),
  989. .inversed = 1,
  990. .health = false,
  991. },
  992. {
  993. .data = mlxplat_mlxcpld_default_asic_items_data,
  994. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  995. .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET,
  996. .mask = MLXPLAT_CPLD_ASIC_MASK,
  997. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_asic_items_data),
  998. .inversed = 0,
  999. .health = true,
  1000. },
  1001. };
  1002. static
  1003. struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_default_ng_data = {
  1004. .items = mlxplat_mlxcpld_default_ng_items,
  1005. .counter = ARRAY_SIZE(mlxplat_mlxcpld_default_ng_items),
  1006. .cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET,
  1007. .mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF | MLXPLAT_CPLD_AGGR_MASK_COMEX,
  1008. .cell_low = MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET,
  1009. .mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW,
  1010. };
  1011. /* Platform hotplug extended system family data */
  1012. static struct mlxreg_core_data mlxplat_mlxcpld_ext_psu_items_data[] = {
  1013. {
  1014. .label = "psu1",
  1015. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  1016. .mask = BIT(0),
  1017. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  1018. },
  1019. {
  1020. .label = "psu2",
  1021. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  1022. .mask = BIT(1),
  1023. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  1024. },
  1025. {
  1026. .label = "psu3",
  1027. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  1028. .mask = BIT(2),
  1029. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  1030. },
  1031. {
  1032. .label = "psu4",
  1033. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  1034. .mask = BIT(3),
  1035. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  1036. },
  1037. };
  1038. static struct mlxreg_core_data mlxplat_mlxcpld_ext_pwr_items_data[] = {
  1039. {
  1040. .label = "pwr1",
  1041. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  1042. .mask = BIT(0),
  1043. .hpdev.brdinfo = &mlxplat_mlxcpld_pwr[0],
  1044. .hpdev.nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR,
  1045. },
  1046. {
  1047. .label = "pwr2",
  1048. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  1049. .mask = BIT(1),
  1050. .hpdev.brdinfo = &mlxplat_mlxcpld_pwr[1],
  1051. .hpdev.nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR,
  1052. },
  1053. {
  1054. .label = "pwr3",
  1055. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  1056. .mask = BIT(2),
  1057. .hpdev.brdinfo = &mlxplat_mlxcpld_ext_pwr[0],
  1058. .hpdev.nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR,
  1059. },
  1060. {
  1061. .label = "pwr4",
  1062. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  1063. .mask = BIT(3),
  1064. .hpdev.brdinfo = &mlxplat_mlxcpld_ext_pwr[1],
  1065. .hpdev.nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR,
  1066. },
  1067. };
  1068. static struct mlxreg_core_item mlxplat_mlxcpld_ext_items[] = {
  1069. {
  1070. .data = mlxplat_mlxcpld_ext_psu_items_data,
  1071. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  1072. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  1073. .mask = MLXPLAT_CPLD_PSU_EXT_MASK,
  1074. .capability = MLXPLAT_CPLD_LPC_REG_PSU_I2C_CAP_OFFSET,
  1075. .count = ARRAY_SIZE(mlxplat_mlxcpld_ext_psu_items_data),
  1076. .inversed = 1,
  1077. .health = false,
  1078. },
  1079. {
  1080. .data = mlxplat_mlxcpld_ext_pwr_items_data,
  1081. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  1082. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  1083. .mask = MLXPLAT_CPLD_PWR_EXT_MASK,
  1084. .capability = MLXPLAT_CPLD_LPC_REG_PSU_I2C_CAP_OFFSET,
  1085. .count = ARRAY_SIZE(mlxplat_mlxcpld_ext_pwr_items_data),
  1086. .inversed = 0,
  1087. .health = false,
  1088. },
  1089. {
  1090. .data = mlxplat_mlxcpld_default_ng_fan_items_data,
  1091. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  1092. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  1093. .mask = MLXPLAT_CPLD_FAN_NG_MASK,
  1094. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_ng_fan_items_data),
  1095. .inversed = 1,
  1096. .health = false,
  1097. },
  1098. {
  1099. .data = mlxplat_mlxcpld_default_asic_items_data,
  1100. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  1101. .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET,
  1102. .mask = MLXPLAT_CPLD_ASIC_MASK,
  1103. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_asic_items_data),
  1104. .inversed = 0,
  1105. .health = true,
  1106. },
  1107. {
  1108. .data = mlxplat_mlxcpld_default_asic2_items_data,
  1109. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  1110. .reg = MLXPLAT_CPLD_LPC_REG_ASIC2_HEALTH_OFFSET,
  1111. .mask = MLXPLAT_CPLD_ASIC_MASK,
  1112. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_asic2_items_data),
  1113. .inversed = 0,
  1114. .health = true,
  1115. }
  1116. };
  1117. static
  1118. struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_ext_data = {
  1119. .items = mlxplat_mlxcpld_ext_items,
  1120. .counter = ARRAY_SIZE(mlxplat_mlxcpld_ext_items),
  1121. .cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET,
  1122. .mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF | MLXPLAT_CPLD_AGGR_MASK_COMEX,
  1123. .cell_low = MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET,
  1124. .mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW | MLXPLAT_CPLD_LOW_AGGR_MASK_ASIC2,
  1125. };
  1126. static struct mlxreg_core_data mlxplat_mlxcpld_modular_pwr_items_data[] = {
  1127. {
  1128. .label = "pwr1",
  1129. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  1130. .mask = BIT(0),
  1131. .hpdev.brdinfo = &mlxplat_mlxcpld_pwr[0],
  1132. .hpdev.nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR,
  1133. },
  1134. {
  1135. .label = "pwr2",
  1136. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  1137. .mask = BIT(1),
  1138. .hpdev.brdinfo = &mlxplat_mlxcpld_pwr[1],
  1139. .hpdev.nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR,
  1140. },
  1141. {
  1142. .label = "pwr3",
  1143. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  1144. .mask = BIT(2),
  1145. .hpdev.brdinfo = &mlxplat_mlxcpld_ext_pwr[0],
  1146. .hpdev.nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR,
  1147. },
  1148. {
  1149. .label = "pwr4",
  1150. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  1151. .mask = BIT(3),
  1152. .hpdev.brdinfo = &mlxplat_mlxcpld_ext_pwr[1],
  1153. .hpdev.nr = MLXPLAT_CPLD_PSU_MSNXXXX_NR,
  1154. },
  1155. };
  1156. static
  1157. struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_lc_act = {
  1158. .irq = MLXPLAT_CPLD_LPC_SYSIRQ,
  1159. };
  1160. static struct mlxreg_core_data mlxplat_mlxcpld_modular_asic_items_data[] = {
  1161. {
  1162. .label = "asic1",
  1163. .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET,
  1164. .mask = MLXPLAT_CPLD_ASIC_MASK,
  1165. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  1166. },
  1167. };
  1168. static struct i2c_board_info mlxplat_mlxcpld_lc_i2c_dev[] = {
  1169. {
  1170. I2C_BOARD_INFO("mlxreg-lc", MLXPLAT_CPLD_LC_ADDR),
  1171. .platform_data = &mlxplat_mlxcpld_lc_act,
  1172. },
  1173. {
  1174. I2C_BOARD_INFO("mlxreg-lc", MLXPLAT_CPLD_LC_ADDR),
  1175. .platform_data = &mlxplat_mlxcpld_lc_act,
  1176. },
  1177. {
  1178. I2C_BOARD_INFO("mlxreg-lc", MLXPLAT_CPLD_LC_ADDR),
  1179. .platform_data = &mlxplat_mlxcpld_lc_act,
  1180. },
  1181. {
  1182. I2C_BOARD_INFO("mlxreg-lc", MLXPLAT_CPLD_LC_ADDR),
  1183. .platform_data = &mlxplat_mlxcpld_lc_act,
  1184. },
  1185. {
  1186. I2C_BOARD_INFO("mlxreg-lc", MLXPLAT_CPLD_LC_ADDR),
  1187. .platform_data = &mlxplat_mlxcpld_lc_act,
  1188. },
  1189. {
  1190. I2C_BOARD_INFO("mlxreg-lc", MLXPLAT_CPLD_LC_ADDR),
  1191. .platform_data = &mlxplat_mlxcpld_lc_act,
  1192. },
  1193. {
  1194. I2C_BOARD_INFO("mlxreg-lc", MLXPLAT_CPLD_LC_ADDR),
  1195. .platform_data = &mlxplat_mlxcpld_lc_act,
  1196. },
  1197. {
  1198. I2C_BOARD_INFO("mlxreg-lc", MLXPLAT_CPLD_LC_ADDR),
  1199. .platform_data = &mlxplat_mlxcpld_lc_act,
  1200. },
  1201. };
  1202. static struct mlxreg_core_hotplug_notifier mlxplat_mlxcpld_modular_lc_notifier[] = {
  1203. {
  1204. .identity = "lc1",
  1205. },
  1206. {
  1207. .identity = "lc2",
  1208. },
  1209. {
  1210. .identity = "lc3",
  1211. },
  1212. {
  1213. .identity = "lc4",
  1214. },
  1215. {
  1216. .identity = "lc5",
  1217. },
  1218. {
  1219. .identity = "lc6",
  1220. },
  1221. {
  1222. .identity = "lc7",
  1223. },
  1224. {
  1225. .identity = "lc8",
  1226. },
  1227. };
  1228. static struct mlxreg_core_data mlxplat_mlxcpld_modular_lc_pr_items_data[] = {
  1229. {
  1230. .label = "lc1_present",
  1231. .reg = MLXPLAT_CPLD_LPC_REG_LC_IN_OFFSET,
  1232. .mask = BIT(0),
  1233. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[0],
  1234. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(0),
  1235. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1236. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[0],
  1237. .slot = 1,
  1238. },
  1239. {
  1240. .label = "lc2_present",
  1241. .reg = MLXPLAT_CPLD_LPC_REG_LC_IN_OFFSET,
  1242. .mask = BIT(1),
  1243. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[1],
  1244. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(1),
  1245. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1246. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[1],
  1247. .slot = 2,
  1248. },
  1249. {
  1250. .label = "lc3_present",
  1251. .reg = MLXPLAT_CPLD_LPC_REG_LC_IN_OFFSET,
  1252. .mask = BIT(2),
  1253. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[2],
  1254. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(2),
  1255. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1256. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[2],
  1257. .slot = 3,
  1258. },
  1259. {
  1260. .label = "lc4_present",
  1261. .reg = MLXPLAT_CPLD_LPC_REG_LC_IN_OFFSET,
  1262. .mask = BIT(3),
  1263. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[3],
  1264. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(3),
  1265. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1266. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[3],
  1267. .slot = 4,
  1268. },
  1269. {
  1270. .label = "lc5_present",
  1271. .reg = MLXPLAT_CPLD_LPC_REG_LC_IN_OFFSET,
  1272. .mask = BIT(4),
  1273. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[4],
  1274. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(4),
  1275. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1276. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[4],
  1277. .slot = 5,
  1278. },
  1279. {
  1280. .label = "lc6_present",
  1281. .reg = MLXPLAT_CPLD_LPC_REG_LC_IN_OFFSET,
  1282. .mask = BIT(5),
  1283. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[5],
  1284. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(5),
  1285. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1286. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[5],
  1287. .slot = 6,
  1288. },
  1289. {
  1290. .label = "lc7_present",
  1291. .reg = MLXPLAT_CPLD_LPC_REG_LC_IN_OFFSET,
  1292. .mask = BIT(6),
  1293. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[6],
  1294. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(6),
  1295. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1296. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[6],
  1297. .slot = 7,
  1298. },
  1299. {
  1300. .label = "lc8_present",
  1301. .reg = MLXPLAT_CPLD_LPC_REG_LC_IN_OFFSET,
  1302. .mask = BIT(7),
  1303. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[7],
  1304. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(7),
  1305. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1306. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[7],
  1307. .slot = 8,
  1308. },
  1309. };
  1310. static struct mlxreg_core_data mlxplat_mlxcpld_modular_lc_ver_items_data[] = {
  1311. {
  1312. .label = "lc1_verified",
  1313. .reg = MLXPLAT_CPLD_LPC_REG_LC_VR_OFFSET,
  1314. .mask = BIT(0),
  1315. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1316. .reg_sync = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1317. .reg_pwr = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  1318. .reg_ena = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  1319. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[0],
  1320. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(0),
  1321. .hpdev.action = MLXREG_HOTPLUG_DEVICE_PLATFORM_ACTION,
  1322. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[0],
  1323. .slot = 1,
  1324. },
  1325. {
  1326. .label = "lc2_verified",
  1327. .reg = MLXPLAT_CPLD_LPC_REG_LC_VR_OFFSET,
  1328. .mask = BIT(1),
  1329. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1330. .reg_sync = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1331. .reg_pwr = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  1332. .reg_ena = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  1333. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[1],
  1334. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(1),
  1335. .hpdev.action = MLXREG_HOTPLUG_DEVICE_PLATFORM_ACTION,
  1336. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[1],
  1337. .slot = 2,
  1338. },
  1339. {
  1340. .label = "lc3_verified",
  1341. .reg = MLXPLAT_CPLD_LPC_REG_LC_VR_OFFSET,
  1342. .mask = BIT(2),
  1343. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1344. .reg_sync = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1345. .reg_pwr = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  1346. .reg_ena = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  1347. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[2],
  1348. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(2),
  1349. .hpdev.action = MLXREG_HOTPLUG_DEVICE_PLATFORM_ACTION,
  1350. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[2],
  1351. .slot = 3,
  1352. },
  1353. {
  1354. .label = "lc4_verified",
  1355. .reg = MLXPLAT_CPLD_LPC_REG_LC_VR_OFFSET,
  1356. .mask = BIT(3),
  1357. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1358. .reg_sync = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1359. .reg_pwr = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  1360. .reg_ena = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  1361. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[3],
  1362. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(3),
  1363. .hpdev.action = MLXREG_HOTPLUG_DEVICE_PLATFORM_ACTION,
  1364. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[3],
  1365. .slot = 4,
  1366. },
  1367. {
  1368. .label = "lc5_verified",
  1369. .reg = MLXPLAT_CPLD_LPC_REG_LC_VR_OFFSET,
  1370. .mask = BIT(4),
  1371. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1372. .reg_sync = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1373. .reg_pwr = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  1374. .reg_ena = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  1375. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[4],
  1376. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(4),
  1377. .hpdev.action = MLXREG_HOTPLUG_DEVICE_PLATFORM_ACTION,
  1378. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[4],
  1379. .slot = 5,
  1380. },
  1381. {
  1382. .label = "lc6_verified",
  1383. .reg = MLXPLAT_CPLD_LPC_REG_LC_VR_OFFSET,
  1384. .mask = BIT(5),
  1385. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1386. .reg_sync = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1387. .reg_pwr = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  1388. .reg_ena = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  1389. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[5],
  1390. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(5),
  1391. .hpdev.action = MLXREG_HOTPLUG_DEVICE_PLATFORM_ACTION,
  1392. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[5],
  1393. .slot = 6,
  1394. },
  1395. {
  1396. .label = "lc7_verified",
  1397. .reg = MLXPLAT_CPLD_LPC_REG_LC_VR_OFFSET,
  1398. .mask = BIT(6),
  1399. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1400. .reg_sync = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1401. .reg_pwr = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  1402. .reg_ena = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  1403. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[6],
  1404. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(6),
  1405. .hpdev.action = MLXREG_HOTPLUG_DEVICE_PLATFORM_ACTION,
  1406. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[6],
  1407. .slot = 7,
  1408. },
  1409. {
  1410. .label = "lc8_verified",
  1411. .reg = MLXPLAT_CPLD_LPC_REG_LC_VR_OFFSET,
  1412. .mask = BIT(7),
  1413. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1414. .reg_sync = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1415. .reg_pwr = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  1416. .reg_ena = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  1417. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[7],
  1418. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(7),
  1419. .hpdev.action = MLXREG_HOTPLUG_DEVICE_PLATFORM_ACTION,
  1420. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[7],
  1421. .slot = 8,
  1422. },
  1423. };
  1424. static struct mlxreg_core_data mlxplat_mlxcpld_modular_lc_pg_data[] = {
  1425. {
  1426. .label = "lc1_powered",
  1427. .reg = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1428. .mask = BIT(0),
  1429. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[0],
  1430. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(0),
  1431. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1432. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[0],
  1433. .slot = 1,
  1434. },
  1435. {
  1436. .label = "lc2_powered",
  1437. .reg = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1438. .mask = BIT(1),
  1439. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[1],
  1440. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(1),
  1441. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1442. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[1],
  1443. .slot = 2,
  1444. },
  1445. {
  1446. .label = "lc3_powered",
  1447. .reg = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1448. .mask = BIT(2),
  1449. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[2],
  1450. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(2),
  1451. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1452. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[2],
  1453. .slot = 3,
  1454. },
  1455. {
  1456. .label = "lc4_powered",
  1457. .reg = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1458. .mask = BIT(3),
  1459. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[3],
  1460. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(3),
  1461. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1462. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[3],
  1463. .slot = 4,
  1464. },
  1465. {
  1466. .label = "lc5_powered",
  1467. .reg = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1468. .mask = BIT(4),
  1469. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[4],
  1470. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(4),
  1471. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1472. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[4],
  1473. .slot = 5,
  1474. },
  1475. {
  1476. .label = "lc6_powered",
  1477. .reg = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1478. .mask = BIT(5),
  1479. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[5],
  1480. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(5),
  1481. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1482. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[5],
  1483. .slot = 6,
  1484. },
  1485. {
  1486. .label = "lc7_powered",
  1487. .reg = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1488. .mask = BIT(6),
  1489. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[6],
  1490. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(6),
  1491. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1492. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[6],
  1493. .slot = 7,
  1494. },
  1495. {
  1496. .label = "lc8_powered",
  1497. .reg = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1498. .mask = BIT(7),
  1499. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[7],
  1500. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(7),
  1501. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1502. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[7],
  1503. .slot = 8,
  1504. },
  1505. };
  1506. static struct mlxreg_core_data mlxplat_mlxcpld_modular_lc_ready_data[] = {
  1507. {
  1508. .label = "lc1_ready",
  1509. .reg = MLXPLAT_CPLD_LPC_REG_LC_RD_OFFSET,
  1510. .mask = BIT(0),
  1511. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[0],
  1512. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(0),
  1513. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1514. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[0],
  1515. .slot = 1,
  1516. },
  1517. {
  1518. .label = "lc2_ready",
  1519. .reg = MLXPLAT_CPLD_LPC_REG_LC_RD_OFFSET,
  1520. .mask = BIT(1),
  1521. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[1],
  1522. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(1),
  1523. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1524. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[1],
  1525. .slot = 2,
  1526. },
  1527. {
  1528. .label = "lc3_ready",
  1529. .reg = MLXPLAT_CPLD_LPC_REG_LC_RD_OFFSET,
  1530. .mask = BIT(2),
  1531. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[2],
  1532. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(2),
  1533. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1534. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[2],
  1535. .slot = 3,
  1536. },
  1537. {
  1538. .label = "lc4_ready",
  1539. .reg = MLXPLAT_CPLD_LPC_REG_LC_RD_OFFSET,
  1540. .mask = BIT(3),
  1541. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[3],
  1542. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(3),
  1543. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1544. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[3],
  1545. .slot = 4,
  1546. },
  1547. {
  1548. .label = "lc5_ready",
  1549. .reg = MLXPLAT_CPLD_LPC_REG_LC_RD_OFFSET,
  1550. .mask = BIT(4),
  1551. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[4],
  1552. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(4),
  1553. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1554. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[4],
  1555. .slot = 5,
  1556. },
  1557. {
  1558. .label = "lc6_ready",
  1559. .reg = MLXPLAT_CPLD_LPC_REG_LC_RD_OFFSET,
  1560. .mask = BIT(5),
  1561. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[5],
  1562. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(5),
  1563. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1564. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[5],
  1565. .slot = 6,
  1566. },
  1567. {
  1568. .label = "lc7_ready",
  1569. .reg = MLXPLAT_CPLD_LPC_REG_LC_RD_OFFSET,
  1570. .mask = BIT(6),
  1571. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[6],
  1572. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(6),
  1573. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1574. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[6],
  1575. .slot = 7,
  1576. },
  1577. {
  1578. .label = "lc8_ready",
  1579. .reg = MLXPLAT_CPLD_LPC_REG_LC_RD_OFFSET,
  1580. .mask = BIT(7),
  1581. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[7],
  1582. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(7),
  1583. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1584. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[7],
  1585. .slot = 8,
  1586. },
  1587. };
  1588. static struct mlxreg_core_data mlxplat_mlxcpld_modular_lc_synced_data[] = {
  1589. {
  1590. .label = "lc1_synced",
  1591. .reg = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1592. .mask = BIT(0),
  1593. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[0],
  1594. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(0),
  1595. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1596. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[0],
  1597. .slot = 1,
  1598. },
  1599. {
  1600. .label = "lc2_synced",
  1601. .reg = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1602. .mask = BIT(1),
  1603. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[1],
  1604. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(1),
  1605. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1606. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[1],
  1607. .slot = 2,
  1608. },
  1609. {
  1610. .label = "lc3_synced",
  1611. .reg = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1612. .mask = BIT(2),
  1613. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[2],
  1614. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(2),
  1615. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1616. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[2],
  1617. .slot = 3,
  1618. },
  1619. {
  1620. .label = "lc4_synced",
  1621. .reg = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1622. .mask = BIT(3),
  1623. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[3],
  1624. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(3),
  1625. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1626. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[3],
  1627. .slot = 4,
  1628. },
  1629. {
  1630. .label = "lc5_synced",
  1631. .reg = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1632. .mask = BIT(4),
  1633. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[4],
  1634. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(4),
  1635. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1636. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[4],
  1637. .slot = 5,
  1638. },
  1639. {
  1640. .label = "lc6_synced",
  1641. .reg = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1642. .mask = BIT(5),
  1643. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[5],
  1644. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(5),
  1645. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1646. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[5],
  1647. .slot = 6,
  1648. },
  1649. {
  1650. .label = "lc7_synced",
  1651. .reg = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1652. .mask = BIT(6),
  1653. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[6],
  1654. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(6),
  1655. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1656. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[6],
  1657. .slot = 7,
  1658. },
  1659. {
  1660. .label = "lc8_synced",
  1661. .reg = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1662. .mask = BIT(7),
  1663. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[7],
  1664. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(7),
  1665. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1666. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[7],
  1667. .slot = 8,
  1668. },
  1669. };
  1670. static struct mlxreg_core_data mlxplat_mlxcpld_modular_lc_act_data[] = {
  1671. {
  1672. .label = "lc1_active",
  1673. .reg = MLXPLAT_CPLD_LPC_REG_LC_OK_OFFSET,
  1674. .mask = BIT(0),
  1675. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[0],
  1676. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(0),
  1677. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1678. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[0],
  1679. .slot = 1,
  1680. },
  1681. {
  1682. .label = "lc2_active",
  1683. .reg = MLXPLAT_CPLD_LPC_REG_LC_OK_OFFSET,
  1684. .mask = BIT(1),
  1685. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[1],
  1686. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(1),
  1687. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1688. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[1],
  1689. .slot = 2,
  1690. },
  1691. {
  1692. .label = "lc3_active",
  1693. .reg = MLXPLAT_CPLD_LPC_REG_LC_OK_OFFSET,
  1694. .mask = BIT(2),
  1695. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[2],
  1696. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(2),
  1697. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1698. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[2],
  1699. .slot = 3,
  1700. },
  1701. {
  1702. .label = "lc4_active",
  1703. .reg = MLXPLAT_CPLD_LPC_REG_LC_OK_OFFSET,
  1704. .mask = BIT(3),
  1705. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[3],
  1706. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(3),
  1707. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1708. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[3],
  1709. .slot = 4,
  1710. },
  1711. {
  1712. .label = "lc5_active",
  1713. .reg = MLXPLAT_CPLD_LPC_REG_LC_OK_OFFSET,
  1714. .mask = BIT(4),
  1715. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[4],
  1716. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(4),
  1717. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1718. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[4],
  1719. .slot = 5,
  1720. },
  1721. {
  1722. .label = "lc6_active",
  1723. .reg = MLXPLAT_CPLD_LPC_REG_LC_OK_OFFSET,
  1724. .mask = BIT(5),
  1725. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[5],
  1726. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(5),
  1727. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1728. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[5],
  1729. .slot = 6,
  1730. },
  1731. {
  1732. .label = "lc7_active",
  1733. .reg = MLXPLAT_CPLD_LPC_REG_LC_OK_OFFSET,
  1734. .mask = BIT(6),
  1735. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[6],
  1736. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(6),
  1737. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1738. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[6],
  1739. .slot = 7,
  1740. },
  1741. {
  1742. .label = "lc8_active",
  1743. .reg = MLXPLAT_CPLD_LPC_REG_LC_OK_OFFSET,
  1744. .mask = BIT(7),
  1745. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[7],
  1746. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(7),
  1747. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1748. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[7],
  1749. .slot = 8,
  1750. },
  1751. };
  1752. static struct mlxreg_core_data mlxplat_mlxcpld_modular_lc_sd_data[] = {
  1753. {
  1754. .label = "lc1_shutdown",
  1755. .reg = MLXPLAT_CPLD_LPC_REG_LC_SD_OFFSET,
  1756. .mask = BIT(0),
  1757. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[0],
  1758. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(0),
  1759. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1760. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[0],
  1761. .slot = 1,
  1762. },
  1763. {
  1764. .label = "lc2_shutdown",
  1765. .reg = MLXPLAT_CPLD_LPC_REG_LC_SD_OFFSET,
  1766. .mask = BIT(1),
  1767. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[1],
  1768. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(1),
  1769. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1770. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[1],
  1771. .slot = 2,
  1772. },
  1773. {
  1774. .label = "lc3_shutdown",
  1775. .reg = MLXPLAT_CPLD_LPC_REG_LC_SD_OFFSET,
  1776. .mask = BIT(2),
  1777. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[2],
  1778. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(2),
  1779. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1780. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[2],
  1781. .slot = 3,
  1782. },
  1783. {
  1784. .label = "lc4_shutdown",
  1785. .reg = MLXPLAT_CPLD_LPC_REG_LC_SD_OFFSET,
  1786. .mask = BIT(3),
  1787. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[3],
  1788. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(3),
  1789. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1790. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[3],
  1791. .slot = 4,
  1792. },
  1793. {
  1794. .label = "lc5_shutdown",
  1795. .reg = MLXPLAT_CPLD_LPC_REG_LC_SD_OFFSET,
  1796. .mask = BIT(4),
  1797. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[4],
  1798. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(4),
  1799. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1800. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[4],
  1801. .slot = 5,
  1802. },
  1803. {
  1804. .label = "lc6_shutdown",
  1805. .reg = MLXPLAT_CPLD_LPC_REG_LC_SD_OFFSET,
  1806. .mask = BIT(5),
  1807. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[5],
  1808. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(5),
  1809. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1810. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[5],
  1811. .slot = 6,
  1812. },
  1813. {
  1814. .label = "lc7_shutdown",
  1815. .reg = MLXPLAT_CPLD_LPC_REG_LC_SD_OFFSET,
  1816. .mask = BIT(6),
  1817. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[6],
  1818. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(6),
  1819. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1820. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[6],
  1821. .slot = 7,
  1822. },
  1823. {
  1824. .label = "lc8_shutdown",
  1825. .reg = MLXPLAT_CPLD_LPC_REG_LC_SD_OFFSET,
  1826. .mask = BIT(7),
  1827. .hpdev.brdinfo = &mlxplat_mlxcpld_lc_i2c_dev[7],
  1828. .hpdev.nr = MLXPLAT_CPLD_NR_LC_SET(7),
  1829. .hpdev.action = MLXREG_HOTPLUG_DEVICE_NO_ACTION,
  1830. .hpdev.notifier = &mlxplat_mlxcpld_modular_lc_notifier[7],
  1831. .slot = 8,
  1832. },
  1833. };
  1834. static struct mlxreg_core_item mlxplat_mlxcpld_modular_items[] = {
  1835. {
  1836. .data = mlxplat_mlxcpld_ext_psu_items_data,
  1837. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  1838. .reg = MLXPLAT_CPLD_LPC_REG_PSU_OFFSET,
  1839. .mask = MLXPLAT_CPLD_PSU_EXT_MASK,
  1840. .capability = MLXPLAT_CPLD_LPC_REG_PSU_I2C_CAP_OFFSET,
  1841. .count = ARRAY_SIZE(mlxplat_mlxcpld_ext_psu_items_data),
  1842. .inversed = 1,
  1843. .health = false,
  1844. },
  1845. {
  1846. .data = mlxplat_mlxcpld_modular_pwr_items_data,
  1847. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  1848. .reg = MLXPLAT_CPLD_LPC_REG_PWR_OFFSET,
  1849. .mask = MLXPLAT_CPLD_PWR_EXT_MASK,
  1850. .capability = MLXPLAT_CPLD_LPC_REG_PSU_I2C_CAP_OFFSET,
  1851. .count = ARRAY_SIZE(mlxplat_mlxcpld_ext_pwr_items_data),
  1852. .inversed = 0,
  1853. .health = false,
  1854. },
  1855. {
  1856. .data = mlxplat_mlxcpld_default_ng_fan_items_data,
  1857. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  1858. .reg = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  1859. .mask = MLXPLAT_CPLD_FAN_NG_MASK,
  1860. .count = ARRAY_SIZE(mlxplat_mlxcpld_default_ng_fan_items_data),
  1861. .inversed = 1,
  1862. .health = false,
  1863. },
  1864. {
  1865. .data = mlxplat_mlxcpld_modular_asic_items_data,
  1866. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  1867. .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET,
  1868. .mask = MLXPLAT_CPLD_ASIC_MASK,
  1869. .count = ARRAY_SIZE(mlxplat_mlxcpld_modular_asic_items_data),
  1870. .inversed = 0,
  1871. .health = true,
  1872. },
  1873. {
  1874. .data = mlxplat_mlxcpld_modular_lc_pr_items_data,
  1875. .kind = MLXREG_HOTPLUG_LC_PRESENT,
  1876. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_LC,
  1877. .reg = MLXPLAT_CPLD_LPC_REG_LC_IN_OFFSET,
  1878. .mask = MLXPLAT_CPLD_LPC_LC_MASK,
  1879. .count = ARRAY_SIZE(mlxplat_mlxcpld_modular_lc_pr_items_data),
  1880. .inversed = 1,
  1881. .health = false,
  1882. },
  1883. {
  1884. .data = mlxplat_mlxcpld_modular_lc_ver_items_data,
  1885. .kind = MLXREG_HOTPLUG_LC_VERIFIED,
  1886. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_LC,
  1887. .reg = MLXPLAT_CPLD_LPC_REG_LC_VR_OFFSET,
  1888. .mask = MLXPLAT_CPLD_LPC_LC_MASK,
  1889. .count = ARRAY_SIZE(mlxplat_mlxcpld_modular_lc_ver_items_data),
  1890. .inversed = 0,
  1891. .health = false,
  1892. },
  1893. {
  1894. .data = mlxplat_mlxcpld_modular_lc_pg_data,
  1895. .kind = MLXREG_HOTPLUG_LC_POWERED,
  1896. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_LC,
  1897. .reg = MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET,
  1898. .mask = MLXPLAT_CPLD_LPC_LC_MASK,
  1899. .count = ARRAY_SIZE(mlxplat_mlxcpld_modular_lc_pg_data),
  1900. .inversed = 0,
  1901. .health = false,
  1902. },
  1903. {
  1904. .data = mlxplat_mlxcpld_modular_lc_ready_data,
  1905. .kind = MLXREG_HOTPLUG_LC_READY,
  1906. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_LC,
  1907. .reg = MLXPLAT_CPLD_LPC_REG_LC_RD_OFFSET,
  1908. .mask = MLXPLAT_CPLD_LPC_LC_MASK,
  1909. .count = ARRAY_SIZE(mlxplat_mlxcpld_modular_lc_ready_data),
  1910. .inversed = 0,
  1911. .health = false,
  1912. },
  1913. {
  1914. .data = mlxplat_mlxcpld_modular_lc_synced_data,
  1915. .kind = MLXREG_HOTPLUG_LC_SYNCED,
  1916. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_LC,
  1917. .reg = MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET,
  1918. .mask = MLXPLAT_CPLD_LPC_LC_MASK,
  1919. .count = ARRAY_SIZE(mlxplat_mlxcpld_modular_lc_synced_data),
  1920. .inversed = 0,
  1921. .health = false,
  1922. },
  1923. {
  1924. .data = mlxplat_mlxcpld_modular_lc_act_data,
  1925. .kind = MLXREG_HOTPLUG_LC_ACTIVE,
  1926. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_LC,
  1927. .reg = MLXPLAT_CPLD_LPC_REG_LC_OK_OFFSET,
  1928. .mask = MLXPLAT_CPLD_LPC_LC_MASK,
  1929. .count = ARRAY_SIZE(mlxplat_mlxcpld_modular_lc_act_data),
  1930. .inversed = 0,
  1931. .health = false,
  1932. },
  1933. {
  1934. .data = mlxplat_mlxcpld_modular_lc_sd_data,
  1935. .kind = MLXREG_HOTPLUG_LC_THERMAL,
  1936. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_LC,
  1937. .reg = MLXPLAT_CPLD_LPC_REG_LC_SD_OFFSET,
  1938. .mask = MLXPLAT_CPLD_LPC_LC_MASK,
  1939. .count = ARRAY_SIZE(mlxplat_mlxcpld_modular_lc_sd_data),
  1940. .inversed = 0,
  1941. .health = false,
  1942. },
  1943. };
  1944. static
  1945. struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_modular_data = {
  1946. .items = mlxplat_mlxcpld_modular_items,
  1947. .counter = ARRAY_SIZE(mlxplat_mlxcpld_modular_items),
  1948. .cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET,
  1949. .mask = MLXPLAT_CPLD_AGGR_MASK_MODULAR,
  1950. .cell_low = MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET,
  1951. .mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW,
  1952. };
  1953. /* Platform hotplug for NVLink blade systems family data */
  1954. static struct mlxreg_core_data mlxplat_mlxcpld_global_wp_items_data[] = {
  1955. {
  1956. .label = "global_wp_grant",
  1957. .reg = MLXPLAT_CPLD_LPC_REG_GWP_OFFSET,
  1958. .mask = MLXPLAT_CPLD_GWP_MASK,
  1959. .hpdev.nr = MLXPLAT_CPLD_NR_NONE,
  1960. },
  1961. };
  1962. static struct mlxreg_core_item mlxplat_mlxcpld_nvlink_blade_items[] = {
  1963. {
  1964. .data = mlxplat_mlxcpld_global_wp_items_data,
  1965. .aggr_mask = MLXPLAT_CPLD_AGGR_MASK_NG_DEF,
  1966. .reg = MLXPLAT_CPLD_LPC_REG_GWP_OFFSET,
  1967. .mask = MLXPLAT_CPLD_GWP_MASK,
  1968. .count = ARRAY_SIZE(mlxplat_mlxcpld_global_wp_items_data),
  1969. .inversed = 0,
  1970. .health = false,
  1971. },
  1972. };
  1973. static
  1974. struct mlxreg_core_hotplug_platform_data mlxplat_mlxcpld_nvlink_blade_data = {
  1975. .items = mlxplat_mlxcpld_nvlink_blade_items,
  1976. .counter = ARRAY_SIZE(mlxplat_mlxcpld_nvlink_blade_items),
  1977. .cell = MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET,
  1978. .mask = MLXPLAT_CPLD_AGGR_MASK_COMEX,
  1979. .cell_low = MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET,
  1980. .mask_low = MLXPLAT_CPLD_LOW_AGGR_MASK_LOW,
  1981. };
  1982. /* Platform led default data */
  1983. static struct mlxreg_core_data mlxplat_mlxcpld_default_led_data[] = {
  1984. {
  1985. .label = "status:green",
  1986. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  1987. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  1988. },
  1989. {
  1990. .label = "status:red",
  1991. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  1992. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK
  1993. },
  1994. {
  1995. .label = "psu:green",
  1996. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  1997. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  1998. },
  1999. {
  2000. .label = "psu:red",
  2001. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2002. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2003. },
  2004. {
  2005. .label = "fan1:green",
  2006. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2007. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2008. },
  2009. {
  2010. .label = "fan1:red",
  2011. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2012. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2013. },
  2014. {
  2015. .label = "fan2:green",
  2016. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2017. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2018. },
  2019. {
  2020. .label = "fan2:red",
  2021. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2022. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2023. },
  2024. {
  2025. .label = "fan3:green",
  2026. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2027. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2028. },
  2029. {
  2030. .label = "fan3:red",
  2031. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2032. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2033. },
  2034. {
  2035. .label = "fan4:green",
  2036. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2037. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2038. },
  2039. {
  2040. .label = "fan4:red",
  2041. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2042. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2043. },
  2044. };
  2045. static struct mlxreg_core_platform_data mlxplat_default_led_data = {
  2046. .data = mlxplat_mlxcpld_default_led_data,
  2047. .counter = ARRAY_SIZE(mlxplat_mlxcpld_default_led_data),
  2048. };
  2049. /* Platform led default data for water cooling */
  2050. static struct mlxreg_core_data mlxplat_mlxcpld_default_led_wc_data[] = {
  2051. {
  2052. .label = "status:green",
  2053. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2054. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2055. },
  2056. {
  2057. .label = "status:red",
  2058. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2059. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK
  2060. },
  2061. {
  2062. .label = "psu:green",
  2063. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2064. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2065. },
  2066. {
  2067. .label = "psu:red",
  2068. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2069. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2070. },
  2071. };
  2072. static struct mlxreg_core_platform_data mlxplat_default_led_wc_data = {
  2073. .data = mlxplat_mlxcpld_default_led_wc_data,
  2074. .counter = ARRAY_SIZE(mlxplat_mlxcpld_default_led_wc_data),
  2075. };
  2076. /* Platform led default data for water cooling Ethernet switch blade */
  2077. static struct mlxreg_core_data mlxplat_mlxcpld_default_led_eth_wc_blade_data[] = {
  2078. {
  2079. .label = "status:green",
  2080. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2081. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2082. },
  2083. {
  2084. .label = "status:red",
  2085. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2086. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK
  2087. },
  2088. };
  2089. static struct mlxreg_core_platform_data mlxplat_default_led_eth_wc_blade_data = {
  2090. .data = mlxplat_mlxcpld_default_led_eth_wc_blade_data,
  2091. .counter = ARRAY_SIZE(mlxplat_mlxcpld_default_led_eth_wc_blade_data),
  2092. };
  2093. /* Platform led MSN21xx system family data */
  2094. static struct mlxreg_core_data mlxplat_mlxcpld_msn21xx_led_data[] = {
  2095. {
  2096. .label = "status:green",
  2097. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2098. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2099. },
  2100. {
  2101. .label = "status:red",
  2102. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2103. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK
  2104. },
  2105. {
  2106. .label = "fan:green",
  2107. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2108. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2109. },
  2110. {
  2111. .label = "fan:red",
  2112. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2113. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2114. },
  2115. {
  2116. .label = "psu1:green",
  2117. .reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET,
  2118. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2119. },
  2120. {
  2121. .label = "psu1:red",
  2122. .reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET,
  2123. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2124. },
  2125. {
  2126. .label = "psu2:green",
  2127. .reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET,
  2128. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2129. },
  2130. {
  2131. .label = "psu2:red",
  2132. .reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET,
  2133. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2134. },
  2135. {
  2136. .label = "uid:blue",
  2137. .reg = MLXPLAT_CPLD_LPC_REG_LED5_OFFSET,
  2138. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2139. },
  2140. };
  2141. static struct mlxreg_core_platform_data mlxplat_msn21xx_led_data = {
  2142. .data = mlxplat_mlxcpld_msn21xx_led_data,
  2143. .counter = ARRAY_SIZE(mlxplat_mlxcpld_msn21xx_led_data),
  2144. };
  2145. /* Platform led for default data for 200GbE systems */
  2146. static struct mlxreg_core_data mlxplat_mlxcpld_default_ng_led_data[] = {
  2147. {
  2148. .label = "status:green",
  2149. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2150. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2151. },
  2152. {
  2153. .label = "status:orange",
  2154. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2155. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK
  2156. },
  2157. {
  2158. .label = "psu:green",
  2159. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2160. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2161. },
  2162. {
  2163. .label = "psu:orange",
  2164. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2165. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2166. },
  2167. {
  2168. .label = "fan1:green",
  2169. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2170. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2171. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2172. .bit = BIT(0),
  2173. },
  2174. {
  2175. .label = "fan1:orange",
  2176. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2177. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2178. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2179. .bit = BIT(0),
  2180. },
  2181. {
  2182. .label = "fan2:green",
  2183. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2184. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2185. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2186. .bit = BIT(1),
  2187. },
  2188. {
  2189. .label = "fan2:orange",
  2190. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2191. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2192. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2193. .bit = BIT(1),
  2194. },
  2195. {
  2196. .label = "fan3:green",
  2197. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2198. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2199. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2200. .bit = BIT(2),
  2201. },
  2202. {
  2203. .label = "fan3:orange",
  2204. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2205. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2206. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2207. .bit = BIT(2),
  2208. },
  2209. {
  2210. .label = "fan4:green",
  2211. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2212. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2213. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2214. .bit = BIT(3),
  2215. },
  2216. {
  2217. .label = "fan4:orange",
  2218. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2219. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2220. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2221. .bit = BIT(3),
  2222. },
  2223. {
  2224. .label = "fan5:green",
  2225. .reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET,
  2226. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2227. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2228. .bit = BIT(4),
  2229. },
  2230. {
  2231. .label = "fan5:orange",
  2232. .reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET,
  2233. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2234. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2235. .bit = BIT(4),
  2236. },
  2237. {
  2238. .label = "fan6:green",
  2239. .reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET,
  2240. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2241. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2242. .bit = BIT(5),
  2243. },
  2244. {
  2245. .label = "fan6:orange",
  2246. .reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET,
  2247. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2248. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2249. .bit = BIT(5),
  2250. },
  2251. {
  2252. .label = "fan7:green",
  2253. .reg = MLXPLAT_CPLD_LPC_REG_LED6_OFFSET,
  2254. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2255. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2256. .bit = BIT(6),
  2257. },
  2258. {
  2259. .label = "fan7:orange",
  2260. .reg = MLXPLAT_CPLD_LPC_REG_LED6_OFFSET,
  2261. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2262. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2263. .bit = BIT(6),
  2264. },
  2265. {
  2266. .label = "uid:blue",
  2267. .reg = MLXPLAT_CPLD_LPC_REG_LED5_OFFSET,
  2268. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2269. },
  2270. };
  2271. static struct mlxreg_core_platform_data mlxplat_default_ng_led_data = {
  2272. .data = mlxplat_mlxcpld_default_ng_led_data,
  2273. .counter = ARRAY_SIZE(mlxplat_mlxcpld_default_ng_led_data),
  2274. };
  2275. /* Platform led for Comex based 100GbE systems */
  2276. static struct mlxreg_core_data mlxplat_mlxcpld_comex_100G_led_data[] = {
  2277. {
  2278. .label = "status:green",
  2279. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2280. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2281. },
  2282. {
  2283. .label = "status:red",
  2284. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2285. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK
  2286. },
  2287. {
  2288. .label = "psu:green",
  2289. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2290. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2291. },
  2292. {
  2293. .label = "psu:red",
  2294. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2295. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2296. },
  2297. {
  2298. .label = "fan1:green",
  2299. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2300. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2301. },
  2302. {
  2303. .label = "fan1:red",
  2304. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2305. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2306. },
  2307. {
  2308. .label = "fan2:green",
  2309. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2310. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2311. },
  2312. {
  2313. .label = "fan2:red",
  2314. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2315. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2316. },
  2317. {
  2318. .label = "fan3:green",
  2319. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2320. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2321. },
  2322. {
  2323. .label = "fan3:red",
  2324. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2325. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2326. },
  2327. {
  2328. .label = "fan4:green",
  2329. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2330. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2331. },
  2332. {
  2333. .label = "fan4:red",
  2334. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2335. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2336. },
  2337. {
  2338. .label = "uid:blue",
  2339. .reg = MLXPLAT_CPLD_LPC_REG_LED5_OFFSET,
  2340. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2341. },
  2342. };
  2343. static struct mlxreg_core_platform_data mlxplat_comex_100G_led_data = {
  2344. .data = mlxplat_mlxcpld_comex_100G_led_data,
  2345. .counter = ARRAY_SIZE(mlxplat_mlxcpld_comex_100G_led_data),
  2346. };
  2347. /* Platform led for data for modular systems */
  2348. static struct mlxreg_core_data mlxplat_mlxcpld_modular_led_data[] = {
  2349. {
  2350. .label = "status:green",
  2351. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2352. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2353. },
  2354. {
  2355. .label = "status:orange",
  2356. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2357. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK
  2358. },
  2359. {
  2360. .label = "psu:green",
  2361. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2362. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2363. },
  2364. {
  2365. .label = "psu:orange",
  2366. .reg = MLXPLAT_CPLD_LPC_REG_LED1_OFFSET,
  2367. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2368. },
  2369. {
  2370. .label = "fan1:green",
  2371. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2372. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2373. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2374. .bit = BIT(0),
  2375. },
  2376. {
  2377. .label = "fan1:orange",
  2378. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2379. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2380. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2381. .bit = BIT(0),
  2382. },
  2383. {
  2384. .label = "fan2:green",
  2385. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2386. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2387. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2388. .bit = BIT(1),
  2389. },
  2390. {
  2391. .label = "fan2:orange",
  2392. .reg = MLXPLAT_CPLD_LPC_REG_LED2_OFFSET,
  2393. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2394. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2395. .bit = BIT(1),
  2396. },
  2397. {
  2398. .label = "fan3:green",
  2399. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2400. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2401. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2402. .bit = BIT(2),
  2403. },
  2404. {
  2405. .label = "fan3:orange",
  2406. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2407. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2408. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2409. .bit = BIT(2),
  2410. },
  2411. {
  2412. .label = "fan4:green",
  2413. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2414. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2415. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2416. .bit = BIT(3),
  2417. },
  2418. {
  2419. .label = "fan4:orange",
  2420. .reg = MLXPLAT_CPLD_LPC_REG_LED3_OFFSET,
  2421. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2422. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2423. .bit = BIT(3),
  2424. },
  2425. {
  2426. .label = "fan5:green",
  2427. .reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET,
  2428. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2429. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2430. .bit = BIT(4),
  2431. },
  2432. {
  2433. .label = "fan5:orange",
  2434. .reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET,
  2435. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2436. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2437. .bit = BIT(4),
  2438. },
  2439. {
  2440. .label = "fan6:green",
  2441. .reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET,
  2442. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2443. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2444. .bit = BIT(5),
  2445. },
  2446. {
  2447. .label = "fan6:orange",
  2448. .reg = MLXPLAT_CPLD_LPC_REG_LED4_OFFSET,
  2449. .mask = MLXPLAT_CPLD_LED_HI_NIBBLE_MASK,
  2450. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2451. .bit = BIT(5),
  2452. },
  2453. {
  2454. .label = "fan7:green",
  2455. .reg = MLXPLAT_CPLD_LPC_REG_LED6_OFFSET,
  2456. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2457. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2458. .bit = BIT(6),
  2459. },
  2460. {
  2461. .label = "fan7:orange",
  2462. .reg = MLXPLAT_CPLD_LPC_REG_LED6_OFFSET,
  2463. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2464. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  2465. .bit = BIT(6),
  2466. },
  2467. {
  2468. .label = "uid:blue",
  2469. .reg = MLXPLAT_CPLD_LPC_REG_LED5_OFFSET,
  2470. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2471. },
  2472. {
  2473. .label = "fan_front:green",
  2474. .reg = MLXPLAT_CPLD_LPC_REG_LED6_OFFSET,
  2475. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2476. },
  2477. {
  2478. .label = "fan_front:orange",
  2479. .reg = MLXPLAT_CPLD_LPC_REG_LED6_OFFSET,
  2480. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2481. },
  2482. {
  2483. .label = "mgmt:green",
  2484. .reg = MLXPLAT_CPLD_LPC_REG_LED7_OFFSET,
  2485. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2486. },
  2487. {
  2488. .label = "mgmt:orange",
  2489. .reg = MLXPLAT_CPLD_LPC_REG_LED7_OFFSET,
  2490. .mask = MLXPLAT_CPLD_LED_LO_NIBBLE_MASK,
  2491. },
  2492. };
  2493. static struct mlxreg_core_platform_data mlxplat_modular_led_data = {
  2494. .data = mlxplat_mlxcpld_modular_led_data,
  2495. .counter = ARRAY_SIZE(mlxplat_mlxcpld_modular_led_data),
  2496. };
  2497. /* Platform register access default */
  2498. static struct mlxreg_core_data mlxplat_mlxcpld_default_regs_io_data[] = {
  2499. {
  2500. .label = "cpld1_version",
  2501. .reg = MLXPLAT_CPLD_LPC_REG_CPLD1_VER_OFFSET,
  2502. .bit = GENMASK(7, 0),
  2503. .mode = 0444,
  2504. },
  2505. {
  2506. .label = "cpld2_version",
  2507. .reg = MLXPLAT_CPLD_LPC_REG_CPLD2_VER_OFFSET,
  2508. .bit = GENMASK(7, 0),
  2509. .mode = 0444,
  2510. },
  2511. {
  2512. .label = "cpld1_pn",
  2513. .reg = MLXPLAT_CPLD_LPC_REG_CPLD1_PN_OFFSET,
  2514. .bit = GENMASK(15, 0),
  2515. .mode = 0444,
  2516. .regnum = 2,
  2517. },
  2518. {
  2519. .label = "cpld2_pn",
  2520. .reg = MLXPLAT_CPLD_LPC_REG_CPLD2_PN_OFFSET,
  2521. .bit = GENMASK(15, 0),
  2522. .mode = 0444,
  2523. .regnum = 2,
  2524. },
  2525. {
  2526. .label = "cpld1_version_min",
  2527. .reg = MLXPLAT_CPLD_LPC_REG_CPLD1_MVER_OFFSET,
  2528. .bit = GENMASK(7, 0),
  2529. .mode = 0444,
  2530. },
  2531. {
  2532. .label = "cpld2_version_min",
  2533. .reg = MLXPLAT_CPLD_LPC_REG_CPLD2_MVER_OFFSET,
  2534. .bit = GENMASK(7, 0),
  2535. .mode = 0444,
  2536. },
  2537. {
  2538. .label = "reset_long_pb",
  2539. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2540. .mask = GENMASK(7, 0) & ~BIT(0),
  2541. .mode = 0444,
  2542. },
  2543. {
  2544. .label = "reset_short_pb",
  2545. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2546. .mask = GENMASK(7, 0) & ~BIT(1),
  2547. .mode = 0444,
  2548. },
  2549. {
  2550. .label = "reset_aux_pwr_or_ref",
  2551. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2552. .mask = GENMASK(7, 0) & ~BIT(2),
  2553. .mode = 0444,
  2554. },
  2555. {
  2556. .label = "reset_main_pwr_fail",
  2557. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2558. .mask = GENMASK(7, 0) & ~BIT(3),
  2559. .mode = 0444,
  2560. },
  2561. {
  2562. .label = "reset_sw_reset",
  2563. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2564. .mask = GENMASK(7, 0) & ~BIT(4),
  2565. .mode = 0444,
  2566. },
  2567. {
  2568. .label = "reset_fw_reset",
  2569. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2570. .mask = GENMASK(7, 0) & ~BIT(5),
  2571. .mode = 0444,
  2572. },
  2573. {
  2574. .label = "reset_hotswap_or_wd",
  2575. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2576. .mask = GENMASK(7, 0) & ~BIT(6),
  2577. .mode = 0444,
  2578. },
  2579. {
  2580. .label = "reset_asic_thermal",
  2581. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2582. .mask = GENMASK(7, 0) & ~BIT(7),
  2583. .mode = 0444,
  2584. },
  2585. {
  2586. .label = "psu1_on",
  2587. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  2588. .mask = GENMASK(7, 0) & ~BIT(0),
  2589. .mode = 0200,
  2590. },
  2591. {
  2592. .label = "psu2_on",
  2593. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  2594. .mask = GENMASK(7, 0) & ~BIT(1),
  2595. .mode = 0200,
  2596. },
  2597. {
  2598. .label = "pwr_cycle",
  2599. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  2600. .mask = GENMASK(7, 0) & ~BIT(2),
  2601. .mode = 0200,
  2602. },
  2603. {
  2604. .label = "pwr_down",
  2605. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  2606. .mask = GENMASK(7, 0) & ~BIT(3),
  2607. .mode = 0200,
  2608. },
  2609. {
  2610. .label = "select_iio",
  2611. .reg = MLXPLAT_CPLD_LPC_REG_GP2_OFFSET,
  2612. .mask = GENMASK(7, 0) & ~BIT(6),
  2613. .mode = 0644,
  2614. },
  2615. {
  2616. .label = "asic_health",
  2617. .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET,
  2618. .mask = MLXPLAT_CPLD_ASIC_MASK,
  2619. .bit = 1,
  2620. .mode = 0444,
  2621. },
  2622. };
  2623. static struct mlxreg_core_platform_data mlxplat_default_regs_io_data = {
  2624. .data = mlxplat_mlxcpld_default_regs_io_data,
  2625. .counter = ARRAY_SIZE(mlxplat_mlxcpld_default_regs_io_data),
  2626. };
  2627. /* Platform register access MSN21xx, MSN201x, MSN274x systems families data */
  2628. static struct mlxreg_core_data mlxplat_mlxcpld_msn21xx_regs_io_data[] = {
  2629. {
  2630. .label = "cpld1_version",
  2631. .reg = MLXPLAT_CPLD_LPC_REG_CPLD1_VER_OFFSET,
  2632. .bit = GENMASK(7, 0),
  2633. .mode = 0444,
  2634. },
  2635. {
  2636. .label = "cpld2_version",
  2637. .reg = MLXPLAT_CPLD_LPC_REG_CPLD2_VER_OFFSET,
  2638. .bit = GENMASK(7, 0),
  2639. .mode = 0444,
  2640. },
  2641. {
  2642. .label = "cpld1_pn",
  2643. .reg = MLXPLAT_CPLD_LPC_REG_CPLD1_PN_OFFSET,
  2644. .bit = GENMASK(15, 0),
  2645. .mode = 0444,
  2646. .regnum = 2,
  2647. },
  2648. {
  2649. .label = "cpld2_pn",
  2650. .reg = MLXPLAT_CPLD_LPC_REG_CPLD2_PN_OFFSET,
  2651. .bit = GENMASK(15, 0),
  2652. .mode = 0444,
  2653. .regnum = 2,
  2654. },
  2655. {
  2656. .label = "cpld1_version_min",
  2657. .reg = MLXPLAT_CPLD_LPC_REG_CPLD1_MVER_OFFSET,
  2658. .bit = GENMASK(7, 0),
  2659. .mode = 0444,
  2660. },
  2661. {
  2662. .label = "cpld2_version_min",
  2663. .reg = MLXPLAT_CPLD_LPC_REG_CPLD2_MVER_OFFSET,
  2664. .bit = GENMASK(7, 0),
  2665. .mode = 0444,
  2666. },
  2667. {
  2668. .label = "reset_long_pb",
  2669. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2670. .mask = GENMASK(7, 0) & ~BIT(0),
  2671. .mode = 0444,
  2672. },
  2673. {
  2674. .label = "reset_short_pb",
  2675. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2676. .mask = GENMASK(7, 0) & ~BIT(1),
  2677. .mode = 0444,
  2678. },
  2679. {
  2680. .label = "reset_aux_pwr_or_ref",
  2681. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2682. .mask = GENMASK(7, 0) & ~BIT(2),
  2683. .mode = 0444,
  2684. },
  2685. {
  2686. .label = "reset_sw_reset",
  2687. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2688. .mask = GENMASK(7, 0) & ~BIT(3),
  2689. .mode = 0444,
  2690. },
  2691. {
  2692. .label = "reset_main_pwr_fail",
  2693. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2694. .mask = GENMASK(7, 0) & ~BIT(4),
  2695. .mode = 0444,
  2696. },
  2697. {
  2698. .label = "reset_asic_thermal",
  2699. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2700. .mask = GENMASK(7, 0) & ~BIT(5),
  2701. .mode = 0444,
  2702. },
  2703. {
  2704. .label = "reset_hotswap_or_halt",
  2705. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2706. .mask = GENMASK(7, 0) & ~BIT(6),
  2707. .mode = 0444,
  2708. },
  2709. {
  2710. .label = "reset_sff_wd",
  2711. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET,
  2712. .mask = GENMASK(7, 0) & ~BIT(6),
  2713. .mode = 0444,
  2714. },
  2715. {
  2716. .label = "psu1_on",
  2717. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  2718. .mask = GENMASK(7, 0) & ~BIT(0),
  2719. .mode = 0200,
  2720. },
  2721. {
  2722. .label = "psu2_on",
  2723. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  2724. .mask = GENMASK(7, 0) & ~BIT(1),
  2725. .mode = 0200,
  2726. },
  2727. {
  2728. .label = "pwr_cycle",
  2729. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  2730. .mask = GENMASK(7, 0) & ~BIT(2),
  2731. .mode = 0200,
  2732. },
  2733. {
  2734. .label = "pwr_down",
  2735. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  2736. .mask = GENMASK(7, 0) & ~BIT(3),
  2737. .mode = 0200,
  2738. },
  2739. {
  2740. .label = "select_iio",
  2741. .reg = MLXPLAT_CPLD_LPC_REG_GP2_OFFSET,
  2742. .mask = GENMASK(7, 0) & ~BIT(6),
  2743. .mode = 0644,
  2744. },
  2745. {
  2746. .label = "asic_health",
  2747. .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET,
  2748. .mask = MLXPLAT_CPLD_ASIC_MASK,
  2749. .bit = 1,
  2750. .mode = 0444,
  2751. },
  2752. };
  2753. static struct mlxreg_core_platform_data mlxplat_msn21xx_regs_io_data = {
  2754. .data = mlxplat_mlxcpld_msn21xx_regs_io_data,
  2755. .counter = ARRAY_SIZE(mlxplat_mlxcpld_msn21xx_regs_io_data),
  2756. };
  2757. /* Platform register access for next generation systems families data */
  2758. static struct mlxreg_core_data mlxplat_mlxcpld_default_ng_regs_io_data[] = {
  2759. {
  2760. .label = "cpld1_version",
  2761. .reg = MLXPLAT_CPLD_LPC_REG_CPLD1_VER_OFFSET,
  2762. .bit = GENMASK(7, 0),
  2763. .mode = 0444,
  2764. },
  2765. {
  2766. .label = "cpld2_version",
  2767. .reg = MLXPLAT_CPLD_LPC_REG_CPLD2_VER_OFFSET,
  2768. .bit = GENMASK(7, 0),
  2769. .mode = 0444,
  2770. },
  2771. {
  2772. .label = "cpld3_version",
  2773. .reg = MLXPLAT_CPLD_LPC_REG_CPLD3_VER_OFFSET,
  2774. .bit = GENMASK(7, 0),
  2775. .mode = 0444,
  2776. },
  2777. {
  2778. .label = "cpld4_version",
  2779. .reg = MLXPLAT_CPLD_LPC_REG_CPLD4_VER_OFFSET,
  2780. .bit = GENMASK(7, 0),
  2781. .mode = 0444,
  2782. },
  2783. {
  2784. .label = "cpld1_pn",
  2785. .reg = MLXPLAT_CPLD_LPC_REG_CPLD1_PN_OFFSET,
  2786. .bit = GENMASK(15, 0),
  2787. .mode = 0444,
  2788. .regnum = 2,
  2789. },
  2790. {
  2791. .label = "cpld2_pn",
  2792. .reg = MLXPLAT_CPLD_LPC_REG_CPLD2_PN_OFFSET,
  2793. .bit = GENMASK(15, 0),
  2794. .mode = 0444,
  2795. .regnum = 2,
  2796. },
  2797. {
  2798. .label = "cpld3_pn",
  2799. .reg = MLXPLAT_CPLD_LPC_REG_CPLD3_PN_OFFSET,
  2800. .bit = GENMASK(15, 0),
  2801. .mode = 0444,
  2802. .regnum = 2,
  2803. },
  2804. {
  2805. .label = "cpld4_pn",
  2806. .reg = MLXPLAT_CPLD_LPC_REG_CPLD4_PN_OFFSET,
  2807. .bit = GENMASK(15, 0),
  2808. .mode = 0444,
  2809. .regnum = 2,
  2810. },
  2811. {
  2812. .label = "cpld1_version_min",
  2813. .reg = MLXPLAT_CPLD_LPC_REG_CPLD1_MVER_OFFSET,
  2814. .bit = GENMASK(7, 0),
  2815. .mode = 0444,
  2816. },
  2817. {
  2818. .label = "cpld2_version_min",
  2819. .reg = MLXPLAT_CPLD_LPC_REG_CPLD2_MVER_OFFSET,
  2820. .bit = GENMASK(7, 0),
  2821. .mode = 0444,
  2822. },
  2823. {
  2824. .label = "cpld3_version_min",
  2825. .reg = MLXPLAT_CPLD_LPC_REG_CPLD3_MVER_OFFSET,
  2826. .bit = GENMASK(7, 0),
  2827. .mode = 0444,
  2828. },
  2829. {
  2830. .label = "cpld4_version_min",
  2831. .reg = MLXPLAT_CPLD_LPC_REG_CPLD4_MVER_OFFSET,
  2832. .bit = GENMASK(7, 0),
  2833. .mode = 0444,
  2834. },
  2835. {
  2836. .label = "asic_reset",
  2837. .reg = MLXPLAT_CPLD_LPC_REG_RESET_GP2_OFFSET,
  2838. .mask = GENMASK(7, 0) & ~BIT(3),
  2839. .mode = 0200,
  2840. },
  2841. {
  2842. .label = "asic2_reset",
  2843. .reg = MLXPLAT_CPLD_LPC_REG_RESET_GP2_OFFSET,
  2844. .mask = GENMASK(7, 0) & ~BIT(2),
  2845. .mode = 0200,
  2846. },
  2847. {
  2848. .label = "reset_long_pb",
  2849. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2850. .mask = GENMASK(7, 0) & ~BIT(0),
  2851. .mode = 0444,
  2852. },
  2853. {
  2854. .label = "reset_short_pb",
  2855. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2856. .mask = GENMASK(7, 0) & ~BIT(1),
  2857. .mode = 0444,
  2858. },
  2859. {
  2860. .label = "reset_aux_pwr_or_ref",
  2861. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2862. .mask = GENMASK(7, 0) & ~BIT(2),
  2863. .mode = 0444,
  2864. },
  2865. {
  2866. .label = "reset_from_comex",
  2867. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2868. .mask = GENMASK(7, 0) & ~BIT(4),
  2869. .mode = 0444,
  2870. },
  2871. {
  2872. .label = "reset_from_asic",
  2873. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2874. .mask = GENMASK(7, 0) & ~BIT(5),
  2875. .mode = 0444,
  2876. },
  2877. {
  2878. .label = "reset_swb_wd",
  2879. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2880. .mask = GENMASK(7, 0) & ~BIT(6),
  2881. .mode = 0444,
  2882. },
  2883. {
  2884. .label = "reset_asic_thermal",
  2885. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  2886. .mask = GENMASK(7, 0) & ~BIT(7),
  2887. .mode = 0444,
  2888. },
  2889. {
  2890. .label = "reset_comex_pwr_fail",
  2891. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET,
  2892. .mask = GENMASK(7, 0) & ~BIT(3),
  2893. .mode = 0444,
  2894. },
  2895. {
  2896. .label = "reset_platform",
  2897. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET,
  2898. .mask = GENMASK(7, 0) & ~BIT(4),
  2899. .mode = 0444,
  2900. },
  2901. {
  2902. .label = "reset_soc",
  2903. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET,
  2904. .mask = GENMASK(7, 0) & ~BIT(5),
  2905. .mode = 0444,
  2906. },
  2907. {
  2908. .label = "reset_comex_wd",
  2909. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET,
  2910. .mask = GENMASK(7, 0) & ~BIT(6),
  2911. .mode = 0444,
  2912. },
  2913. {
  2914. .label = "reset_voltmon_upgrade_fail",
  2915. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  2916. .mask = GENMASK(7, 0) & ~BIT(0),
  2917. .mode = 0444,
  2918. },
  2919. {
  2920. .label = "reset_system",
  2921. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  2922. .mask = GENMASK(7, 0) & ~BIT(1),
  2923. .mode = 0444,
  2924. },
  2925. {
  2926. .label = "reset_sw_pwr_off",
  2927. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  2928. .mask = GENMASK(7, 0) & ~BIT(2),
  2929. .mode = 0444,
  2930. },
  2931. {
  2932. .label = "reset_comex_thermal",
  2933. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  2934. .mask = GENMASK(7, 0) & ~BIT(3),
  2935. .mode = 0444,
  2936. },
  2937. {
  2938. .label = "reset_reload_bios",
  2939. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  2940. .mask = GENMASK(7, 0) & ~BIT(5),
  2941. .mode = 0444,
  2942. },
  2943. {
  2944. .label = "reset_ac_pwr_fail",
  2945. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  2946. .mask = GENMASK(7, 0) & ~BIT(6),
  2947. .mode = 0444,
  2948. },
  2949. {
  2950. .label = "psu1_on",
  2951. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  2952. .mask = GENMASK(7, 0) & ~BIT(0),
  2953. .mode = 0200,
  2954. },
  2955. {
  2956. .label = "psu2_on",
  2957. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  2958. .mask = GENMASK(7, 0) & ~BIT(1),
  2959. .mode = 0200,
  2960. },
  2961. {
  2962. .label = "pwr_cycle",
  2963. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  2964. .mask = GENMASK(7, 0) & ~BIT(2),
  2965. .mode = 0200,
  2966. },
  2967. {
  2968. .label = "pwr_down",
  2969. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  2970. .mask = GENMASK(7, 0) & ~BIT(3),
  2971. .mode = 0200,
  2972. },
  2973. {
  2974. .label = "jtag_enable",
  2975. .reg = MLXPLAT_CPLD_LPC_REG_GP2_OFFSET,
  2976. .mask = GENMASK(7, 0) & ~BIT(4),
  2977. .mode = 0644,
  2978. },
  2979. {
  2980. .label = "asic_health",
  2981. .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET,
  2982. .mask = MLXPLAT_CPLD_ASIC_MASK,
  2983. .bit = 1,
  2984. .mode = 0444,
  2985. },
  2986. {
  2987. .label = "asic2_health",
  2988. .reg = MLXPLAT_CPLD_LPC_REG_ASIC2_HEALTH_OFFSET,
  2989. .mask = MLXPLAT_CPLD_ASIC_MASK,
  2990. .bit = 1,
  2991. .mode = 0444,
  2992. },
  2993. {
  2994. .label = "fan_dir",
  2995. .reg = MLXPLAT_CPLD_LPC_REG_FAN_DIRECTION,
  2996. .bit = GENMASK(7, 0),
  2997. .mode = 0444,
  2998. },
  2999. {
  3000. .label = "bios_safe_mode",
  3001. .reg = MLXPLAT_CPLD_LPC_REG_GPCOM0_OFFSET,
  3002. .mask = GENMASK(7, 0) & ~BIT(4),
  3003. .mode = 0444,
  3004. },
  3005. {
  3006. .label = "bios_active_image",
  3007. .reg = MLXPLAT_CPLD_LPC_REG_GPCOM0_OFFSET,
  3008. .mask = GENMASK(7, 0) & ~BIT(5),
  3009. .mode = 0444,
  3010. },
  3011. {
  3012. .label = "bios_auth_fail",
  3013. .reg = MLXPLAT_CPLD_LPC_REG_GPCOM0_OFFSET,
  3014. .mask = GENMASK(7, 0) & ~BIT(6),
  3015. .mode = 0444,
  3016. },
  3017. {
  3018. .label = "bios_upgrade_fail",
  3019. .reg = MLXPLAT_CPLD_LPC_REG_GPCOM0_OFFSET,
  3020. .mask = GENMASK(7, 0) & ~BIT(7),
  3021. .mode = 0444,
  3022. },
  3023. {
  3024. .label = "voltreg_update_status",
  3025. .reg = MLXPLAT_CPLD_LPC_REG_GP0_RO_OFFSET,
  3026. .mask = MLXPLAT_CPLD_VOLTREG_UPD_MASK,
  3027. .bit = 5,
  3028. .mode = 0444,
  3029. },
  3030. {
  3031. .label = "vpd_wp",
  3032. .reg = MLXPLAT_CPLD_LPC_REG_GP0_OFFSET,
  3033. .mask = GENMASK(7, 0) & ~BIT(3),
  3034. .mode = 0644,
  3035. },
  3036. {
  3037. .label = "pcie_asic_reset_dis",
  3038. .reg = MLXPLAT_CPLD_LPC_REG_GP0_OFFSET,
  3039. .mask = GENMASK(7, 0) & ~BIT(4),
  3040. .mode = 0644,
  3041. },
  3042. {
  3043. .label = "config1",
  3044. .reg = MLXPLAT_CPLD_LPC_REG_CONFIG1_OFFSET,
  3045. .bit = GENMASK(7, 0),
  3046. .mode = 0444,
  3047. },
  3048. {
  3049. .label = "config2",
  3050. .reg = MLXPLAT_CPLD_LPC_REG_CONFIG2_OFFSET,
  3051. .bit = GENMASK(7, 0),
  3052. .mode = 0444,
  3053. },
  3054. {
  3055. .label = "config3",
  3056. .reg = MLXPLAT_CPLD_LPC_REG_CONFIG3_OFFSET,
  3057. .bit = GENMASK(7, 0),
  3058. .mode = 0444,
  3059. },
  3060. {
  3061. .label = "ufm_version",
  3062. .reg = MLXPLAT_CPLD_LPC_REG_UFM_VERSION_OFFSET,
  3063. .bit = GENMASK(7, 0),
  3064. .mode = 0444,
  3065. },
  3066. };
  3067. static struct mlxreg_core_platform_data mlxplat_default_ng_regs_io_data = {
  3068. .data = mlxplat_mlxcpld_default_ng_regs_io_data,
  3069. .counter = ARRAY_SIZE(mlxplat_mlxcpld_default_ng_regs_io_data),
  3070. };
  3071. /* Platform register access for modular systems families data */
  3072. static struct mlxreg_core_data mlxplat_mlxcpld_modular_regs_io_data[] = {
  3073. {
  3074. .label = "cpld1_version",
  3075. .reg = MLXPLAT_CPLD_LPC_REG_CPLD1_VER_OFFSET,
  3076. .bit = GENMASK(7, 0),
  3077. .mode = 0444,
  3078. },
  3079. {
  3080. .label = "cpld2_version",
  3081. .reg = MLXPLAT_CPLD_LPC_REG_CPLD2_VER_OFFSET,
  3082. .bit = GENMASK(7, 0),
  3083. .mode = 0444,
  3084. },
  3085. {
  3086. .label = "cpld3_version",
  3087. .reg = MLXPLAT_CPLD_LPC_REG_CPLD3_VER_OFFSET,
  3088. .bit = GENMASK(7, 0),
  3089. .mode = 0444,
  3090. },
  3091. {
  3092. .label = "cpld4_version",
  3093. .reg = MLXPLAT_CPLD_LPC_REG_CPLD4_VER_OFFSET,
  3094. .bit = GENMASK(7, 0),
  3095. .mode = 0444,
  3096. },
  3097. {
  3098. .label = "cpld1_pn",
  3099. .reg = MLXPLAT_CPLD_LPC_REG_CPLD1_PN_OFFSET,
  3100. .bit = GENMASK(15, 0),
  3101. .mode = 0444,
  3102. .regnum = 2,
  3103. },
  3104. {
  3105. .label = "cpld2_pn",
  3106. .reg = MLXPLAT_CPLD_LPC_REG_CPLD2_PN_OFFSET,
  3107. .bit = GENMASK(15, 0),
  3108. .mode = 0444,
  3109. .regnum = 2,
  3110. },
  3111. {
  3112. .label = "cpld3_pn",
  3113. .reg = MLXPLAT_CPLD_LPC_REG_CPLD3_PN_OFFSET,
  3114. .bit = GENMASK(15, 0),
  3115. .mode = 0444,
  3116. .regnum = 2,
  3117. },
  3118. {
  3119. .label = "cpld4_pn",
  3120. .reg = MLXPLAT_CPLD_LPC_REG_CPLD4_PN_OFFSET,
  3121. .bit = GENMASK(15, 0),
  3122. .mode = 0444,
  3123. .regnum = 2,
  3124. },
  3125. {
  3126. .label = "cpld1_version_min",
  3127. .reg = MLXPLAT_CPLD_LPC_REG_CPLD1_MVER_OFFSET,
  3128. .bit = GENMASK(7, 0),
  3129. .mode = 0444,
  3130. },
  3131. {
  3132. .label = "cpld2_version_min",
  3133. .reg = MLXPLAT_CPLD_LPC_REG_CPLD2_MVER_OFFSET,
  3134. .bit = GENMASK(7, 0),
  3135. .mode = 0444,
  3136. },
  3137. {
  3138. .label = "cpld3_version_min",
  3139. .reg = MLXPLAT_CPLD_LPC_REG_CPLD3_MVER_OFFSET,
  3140. .bit = GENMASK(7, 0),
  3141. .mode = 0444,
  3142. },
  3143. {
  3144. .label = "cpld4_version_min",
  3145. .reg = MLXPLAT_CPLD_LPC_REG_CPLD4_MVER_OFFSET,
  3146. .bit = GENMASK(7, 0),
  3147. .mode = 0444,
  3148. },
  3149. {
  3150. .label = "lc1_enable",
  3151. .reg = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  3152. .mask = GENMASK(7, 0) & ~BIT(0),
  3153. .mode = 0644,
  3154. },
  3155. {
  3156. .label = "lc2_enable",
  3157. .reg = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  3158. .mask = GENMASK(7, 0) & ~BIT(1),
  3159. .mode = 0644,
  3160. },
  3161. {
  3162. .label = "lc3_enable",
  3163. .reg = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  3164. .mask = GENMASK(7, 0) & ~BIT(2),
  3165. .mode = 0644,
  3166. },
  3167. {
  3168. .label = "lc4_enable",
  3169. .reg = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  3170. .mask = GENMASK(7, 0) & ~BIT(3),
  3171. .mode = 0644,
  3172. },
  3173. {
  3174. .label = "lc5_enable",
  3175. .reg = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  3176. .mask = GENMASK(7, 0) & ~BIT(4),
  3177. .mode = 0644,
  3178. },
  3179. {
  3180. .label = "lc6_enable",
  3181. .reg = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  3182. .mask = GENMASK(7, 0) & ~BIT(5),
  3183. .mode = 0644,
  3184. },
  3185. {
  3186. .label = "lc7_enable",
  3187. .reg = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  3188. .mask = GENMASK(7, 0) & ~BIT(6),
  3189. .mode = 0644,
  3190. },
  3191. {
  3192. .label = "lc8_enable",
  3193. .reg = MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET,
  3194. .mask = GENMASK(7, 0) & ~BIT(7),
  3195. .mode = 0644,
  3196. },
  3197. {
  3198. .label = "reset_long_pb",
  3199. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  3200. .mask = GENMASK(7, 0) & ~BIT(0),
  3201. .mode = 0444,
  3202. },
  3203. {
  3204. .label = "reset_short_pb",
  3205. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  3206. .mask = GENMASK(7, 0) & ~BIT(1),
  3207. .mode = 0444,
  3208. },
  3209. {
  3210. .label = "reset_aux_pwr_or_fu",
  3211. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  3212. .mask = GENMASK(7, 0) & ~BIT(2),
  3213. .mode = 0444,
  3214. },
  3215. {
  3216. .label = "reset_mgmt_dc_dc_pwr_fail",
  3217. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  3218. .mask = GENMASK(7, 0) & ~BIT(3),
  3219. .mode = 0444,
  3220. },
  3221. {
  3222. .label = "reset_sys_comex_bios",
  3223. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  3224. .mask = GENMASK(7, 0) & ~BIT(5),
  3225. .mode = 0444,
  3226. },
  3227. {
  3228. .label = "reset_sw_reset",
  3229. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET,
  3230. .mask = GENMASK(7, 0) & ~BIT(0),
  3231. .mode = 0444,
  3232. },
  3233. {
  3234. .label = "reset_aux_pwr_or_reload",
  3235. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET,
  3236. .mask = GENMASK(7, 0) & ~BIT(2),
  3237. .mode = 0444,
  3238. },
  3239. {
  3240. .label = "reset_comex_pwr_fail",
  3241. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET,
  3242. .mask = GENMASK(7, 0) & ~BIT(3),
  3243. .mode = 0444,
  3244. },
  3245. {
  3246. .label = "reset_platform",
  3247. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET,
  3248. .mask = GENMASK(7, 0) & ~BIT(4),
  3249. .mode = 0444,
  3250. },
  3251. {
  3252. .label = "reset_soc",
  3253. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET,
  3254. .mask = GENMASK(7, 0) & ~BIT(5),
  3255. .mode = 0444,
  3256. },
  3257. {
  3258. .label = "reset_pwr_off_from_carrier",
  3259. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET,
  3260. .mask = GENMASK(7, 0) & ~BIT(7),
  3261. .mode = 0444,
  3262. },
  3263. {
  3264. .label = "reset_swb_wd",
  3265. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  3266. .mask = GENMASK(7, 0) & ~BIT(0),
  3267. .mode = 0444,
  3268. },
  3269. {
  3270. .label = "reset_swb_aux_pwr_or_fu",
  3271. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  3272. .mask = GENMASK(7, 0) & ~BIT(2),
  3273. .mode = 0444,
  3274. },
  3275. {
  3276. .label = "reset_swb_dc_dc_pwr_fail",
  3277. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  3278. .mask = GENMASK(7, 0) & ~BIT(3),
  3279. .mode = 0444,
  3280. },
  3281. {
  3282. .label = "reset_swb_12v_fail",
  3283. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  3284. .mask = GENMASK(7, 0) & ~BIT(4),
  3285. .mode = 0444,
  3286. },
  3287. {
  3288. .label = "reset_system",
  3289. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  3290. .mask = GENMASK(7, 0) & ~BIT(5),
  3291. .mode = 0444,
  3292. },
  3293. {
  3294. .label = "reset_thermal_spc_or_pciesw",
  3295. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  3296. .mask = GENMASK(7, 0) & ~BIT(7),
  3297. .mode = 0444,
  3298. },
  3299. {
  3300. .label = "bios_safe_mode",
  3301. .reg = MLXPLAT_CPLD_LPC_REG_GPCOM0_OFFSET,
  3302. .mask = GENMASK(7, 0) & ~BIT(4),
  3303. .mode = 0444,
  3304. },
  3305. {
  3306. .label = "bios_active_image",
  3307. .reg = MLXPLAT_CPLD_LPC_REG_GPCOM0_OFFSET,
  3308. .mask = GENMASK(7, 0) & ~BIT(5),
  3309. .mode = 0444,
  3310. },
  3311. {
  3312. .label = "bios_auth_fail",
  3313. .reg = MLXPLAT_CPLD_LPC_REG_GPCOM0_OFFSET,
  3314. .mask = GENMASK(7, 0) & ~BIT(6),
  3315. .mode = 0444,
  3316. },
  3317. {
  3318. .label = "bios_upgrade_fail",
  3319. .reg = MLXPLAT_CPLD_LPC_REG_GPCOM0_OFFSET,
  3320. .mask = GENMASK(7, 0) & ~BIT(7),
  3321. .mode = 0444,
  3322. },
  3323. {
  3324. .label = "voltreg_update_status",
  3325. .reg = MLXPLAT_CPLD_LPC_REG_GP0_RO_OFFSET,
  3326. .mask = MLXPLAT_CPLD_VOLTREG_UPD_MASK,
  3327. .bit = 5,
  3328. .mode = 0444,
  3329. },
  3330. {
  3331. .label = "vpd_wp",
  3332. .reg = MLXPLAT_CPLD_LPC_REG_GP0_OFFSET,
  3333. .mask = GENMASK(7, 0) & ~BIT(3),
  3334. .mode = 0644,
  3335. },
  3336. {
  3337. .label = "pcie_asic_reset_dis",
  3338. .reg = MLXPLAT_CPLD_LPC_REG_GP0_OFFSET,
  3339. .mask = GENMASK(7, 0) & ~BIT(4),
  3340. .mode = 0644,
  3341. },
  3342. {
  3343. .label = "shutdown_unlock",
  3344. .reg = MLXPLAT_CPLD_LPC_REG_GP0_OFFSET,
  3345. .mask = GENMASK(7, 0) & ~BIT(5),
  3346. .mode = 0644,
  3347. },
  3348. {
  3349. .label = "lc1_rst_mask",
  3350. .reg = MLXPLAT_CPLD_LPC_REG_GP_RST_OFFSET,
  3351. .mask = GENMASK(7, 0) & ~BIT(0),
  3352. .mode = 0200,
  3353. },
  3354. {
  3355. .label = "lc2_rst_mask",
  3356. .reg = MLXPLAT_CPLD_LPC_REG_GP_RST_OFFSET,
  3357. .mask = GENMASK(7, 0) & ~BIT(1),
  3358. .mode = 0200,
  3359. },
  3360. {
  3361. .label = "lc3_rst_mask",
  3362. .reg = MLXPLAT_CPLD_LPC_REG_GP_RST_OFFSET,
  3363. .mask = GENMASK(7, 0) & ~BIT(2),
  3364. .mode = 0200,
  3365. },
  3366. {
  3367. .label = "lc4_rst_mask",
  3368. .reg = MLXPLAT_CPLD_LPC_REG_GP_RST_OFFSET,
  3369. .mask = GENMASK(7, 0) & ~BIT(3),
  3370. .mode = 0200,
  3371. },
  3372. {
  3373. .label = "lc5_rst_mask",
  3374. .reg = MLXPLAT_CPLD_LPC_REG_GP_RST_OFFSET,
  3375. .mask = GENMASK(7, 0) & ~BIT(4),
  3376. .mode = 0200,
  3377. },
  3378. {
  3379. .label = "lc6_rst_mask",
  3380. .reg = MLXPLAT_CPLD_LPC_REG_GP_RST_OFFSET,
  3381. .mask = GENMASK(7, 0) & ~BIT(5),
  3382. .mode = 0200,
  3383. },
  3384. {
  3385. .label = "lc7_rst_mask",
  3386. .reg = MLXPLAT_CPLD_LPC_REG_GP_RST_OFFSET,
  3387. .mask = GENMASK(7, 0) & ~BIT(6),
  3388. .mode = 0200,
  3389. },
  3390. {
  3391. .label = "lc8_rst_mask",
  3392. .reg = MLXPLAT_CPLD_LPC_REG_GP_RST_OFFSET,
  3393. .mask = GENMASK(7, 0) & ~BIT(7),
  3394. .mode = 0200,
  3395. },
  3396. {
  3397. .label = "psu1_on",
  3398. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  3399. .mask = GENMASK(7, 0) & ~BIT(0),
  3400. .mode = 0200,
  3401. },
  3402. {
  3403. .label = "psu2_on",
  3404. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  3405. .mask = GENMASK(7, 0) & ~BIT(1),
  3406. .mode = 0200,
  3407. },
  3408. {
  3409. .label = "pwr_cycle",
  3410. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  3411. .mask = GENMASK(7, 0) & ~BIT(2),
  3412. .mode = 0200,
  3413. },
  3414. {
  3415. .label = "pwr_down",
  3416. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  3417. .mask = GENMASK(7, 0) & ~BIT(3),
  3418. .mode = 0200,
  3419. },
  3420. {
  3421. .label = "psu3_on",
  3422. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  3423. .mask = GENMASK(7, 0) & ~BIT(4),
  3424. .mode = 0200,
  3425. },
  3426. {
  3427. .label = "psu4_on",
  3428. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  3429. .mask = GENMASK(7, 0) & ~BIT(5),
  3430. .mode = 0200,
  3431. },
  3432. {
  3433. .label = "auto_power_mode",
  3434. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  3435. .mask = GENMASK(7, 0) & ~BIT(6),
  3436. .mode = 0644,
  3437. },
  3438. {
  3439. .label = "pm_mgmt_en",
  3440. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  3441. .mask = GENMASK(7, 0) & ~BIT(7),
  3442. .mode = 0644,
  3443. },
  3444. {
  3445. .label = "jtag_enable",
  3446. .reg = MLXPLAT_CPLD_LPC_REG_FIELD_UPGRADE,
  3447. .mask = GENMASK(3, 0),
  3448. .bit = 1,
  3449. .mode = 0644,
  3450. },
  3451. {
  3452. .label = "safe_bios_dis",
  3453. .reg = MLXPLAT_CPLD_LPC_SAFE_BIOS_OFFSET,
  3454. .mask = GENMASK(7, 0) & ~BIT(5),
  3455. .mode = 0644,
  3456. },
  3457. {
  3458. .label = "safe_bios_dis_wp",
  3459. .reg = MLXPLAT_CPLD_LPC_SAFE_BIOS_WP_OFFSET,
  3460. .mask = GENMASK(7, 0) & ~BIT(5),
  3461. .mode = 0644,
  3462. },
  3463. {
  3464. .label = "asic_health",
  3465. .reg = MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET,
  3466. .mask = MLXPLAT_CPLD_ASIC_MASK,
  3467. .bit = 1,
  3468. .mode = 0444,
  3469. },
  3470. {
  3471. .label = "fan_dir",
  3472. .reg = MLXPLAT_CPLD_LPC_REG_FAN_DIRECTION,
  3473. .bit = GENMASK(7, 0),
  3474. .mode = 0444,
  3475. },
  3476. {
  3477. .label = "lc1_pwr",
  3478. .reg = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  3479. .mask = GENMASK(7, 0) & ~BIT(0),
  3480. .mode = 0644,
  3481. },
  3482. {
  3483. .label = "lc2_pwr",
  3484. .reg = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  3485. .mask = GENMASK(7, 0) & ~BIT(1),
  3486. .mode = 0644,
  3487. },
  3488. {
  3489. .label = "lc3_pwr",
  3490. .reg = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  3491. .mask = GENMASK(7, 0) & ~BIT(2),
  3492. .mode = 0644,
  3493. },
  3494. {
  3495. .label = "lc4_pwr",
  3496. .reg = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  3497. .mask = GENMASK(7, 0) & ~BIT(3),
  3498. .mode = 0644,
  3499. },
  3500. {
  3501. .label = "lc5_pwr",
  3502. .reg = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  3503. .mask = GENMASK(7, 0) & ~BIT(4),
  3504. .mode = 0644,
  3505. },
  3506. {
  3507. .label = "lc6_pwr",
  3508. .reg = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  3509. .mask = GENMASK(7, 0) & ~BIT(5),
  3510. .mode = 0644,
  3511. },
  3512. {
  3513. .label = "lc7_pwr",
  3514. .reg = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  3515. .mask = GENMASK(7, 0) & ~BIT(6),
  3516. .mode = 0644,
  3517. },
  3518. {
  3519. .label = "lc8_pwr",
  3520. .reg = MLXPLAT_CPLD_LPC_REG_LC_PWR_ON,
  3521. .mask = GENMASK(7, 0) & ~BIT(7),
  3522. .mode = 0644,
  3523. },
  3524. {
  3525. .label = "config1",
  3526. .reg = MLXPLAT_CPLD_LPC_REG_CONFIG1_OFFSET,
  3527. .bit = GENMASK(7, 0),
  3528. .mode = 0444,
  3529. },
  3530. {
  3531. .label = "config2",
  3532. .reg = MLXPLAT_CPLD_LPC_REG_CONFIG2_OFFSET,
  3533. .bit = GENMASK(7, 0),
  3534. .mode = 0444,
  3535. },
  3536. {
  3537. .label = "config3",
  3538. .reg = MLXPLAT_CPLD_LPC_REG_CONFIG3_OFFSET,
  3539. .bit = GENMASK(7, 0),
  3540. .mode = 0444,
  3541. },
  3542. {
  3543. .label = "ufm_version",
  3544. .reg = MLXPLAT_CPLD_LPC_REG_UFM_VERSION_OFFSET,
  3545. .bit = GENMASK(7, 0),
  3546. .mode = 0444,
  3547. },
  3548. };
  3549. static struct mlxreg_core_platform_data mlxplat_modular_regs_io_data = {
  3550. .data = mlxplat_mlxcpld_modular_regs_io_data,
  3551. .counter = ARRAY_SIZE(mlxplat_mlxcpld_modular_regs_io_data),
  3552. };
  3553. /* Platform register access for NVLink blade systems family data */
  3554. static struct mlxreg_core_data mlxplat_mlxcpld_nvlink_blade_regs_io_data[] = {
  3555. {
  3556. .label = "cpld1_version",
  3557. .reg = MLXPLAT_CPLD_LPC_REG_CPLD1_VER_OFFSET,
  3558. .bit = GENMASK(7, 0),
  3559. .mode = 0444,
  3560. },
  3561. {
  3562. .label = "cpld1_pn",
  3563. .reg = MLXPLAT_CPLD_LPC_REG_CPLD1_PN_OFFSET,
  3564. .bit = GENMASK(15, 0),
  3565. .mode = 0444,
  3566. .regnum = 2,
  3567. },
  3568. {
  3569. .label = "cpld1_version_min",
  3570. .reg = MLXPLAT_CPLD_LPC_REG_CPLD1_MVER_OFFSET,
  3571. .bit = GENMASK(7, 0),
  3572. .mode = 0444,
  3573. },
  3574. {
  3575. .label = "reset_aux_pwr_or_ref",
  3576. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  3577. .mask = GENMASK(7, 0) & ~BIT(2),
  3578. .mode = 0444,
  3579. },
  3580. {
  3581. .label = "reset_from_comex",
  3582. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  3583. .mask = GENMASK(7, 0) & ~BIT(4),
  3584. .mode = 0444,
  3585. },
  3586. {
  3587. .label = "reset_comex_pwr_fail",
  3588. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET,
  3589. .mask = GENMASK(7, 0) & ~BIT(3),
  3590. .mode = 0444,
  3591. },
  3592. {
  3593. .label = "reset_platform",
  3594. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET,
  3595. .mask = GENMASK(7, 0) & ~BIT(4),
  3596. .mode = 0444,
  3597. },
  3598. {
  3599. .label = "reset_soc",
  3600. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET,
  3601. .mask = GENMASK(7, 0) & ~BIT(5),
  3602. .mode = 0444,
  3603. },
  3604. {
  3605. .label = "reset_comex_wd",
  3606. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET,
  3607. .mask = GENMASK(7, 0) & ~BIT(6),
  3608. .mode = 0444,
  3609. },
  3610. {
  3611. .label = "reset_voltmon_upgrade_fail",
  3612. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  3613. .mask = GENMASK(7, 0) & ~BIT(0),
  3614. .mode = 0444,
  3615. },
  3616. {
  3617. .label = "reset_system",
  3618. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  3619. .mask = GENMASK(7, 0) & ~BIT(1),
  3620. .mode = 0444,
  3621. },
  3622. {
  3623. .label = "reset_sw_pwr_off",
  3624. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  3625. .mask = GENMASK(7, 0) & ~BIT(2),
  3626. .mode = 0444,
  3627. },
  3628. {
  3629. .label = "reset_comex_thermal",
  3630. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  3631. .mask = GENMASK(7, 0) & ~BIT(3),
  3632. .mode = 0444,
  3633. },
  3634. {
  3635. .label = "reset_reload_bios",
  3636. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  3637. .mask = GENMASK(7, 0) & ~BIT(5),
  3638. .mode = 0444,
  3639. },
  3640. {
  3641. .label = "reset_ac_pwr_fail",
  3642. .reg = MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET,
  3643. .mask = GENMASK(7, 0) & ~BIT(6),
  3644. .mode = 0444,
  3645. },
  3646. {
  3647. .label = "pwr_cycle",
  3648. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  3649. .mask = GENMASK(7, 0) & ~BIT(2),
  3650. .mode = 0200,
  3651. },
  3652. {
  3653. .label = "pwr_down",
  3654. .reg = MLXPLAT_CPLD_LPC_REG_GP1_OFFSET,
  3655. .mask = GENMASK(7, 0) & ~BIT(3),
  3656. .mode = 0200,
  3657. },
  3658. {
  3659. .label = "global_wp_request",
  3660. .reg = MLXPLAT_CPLD_LPC_REG_GP2_OFFSET,
  3661. .mask = GENMASK(7, 0) & ~BIT(0),
  3662. .mode = 0644,
  3663. },
  3664. {
  3665. .label = "jtag_enable",
  3666. .reg = MLXPLAT_CPLD_LPC_REG_GP2_OFFSET,
  3667. .mask = GENMASK(7, 0) & ~BIT(4),
  3668. .mode = 0644,
  3669. },
  3670. {
  3671. .label = "comm_chnl_ready",
  3672. .reg = MLXPLAT_CPLD_LPC_REG_GP2_OFFSET,
  3673. .mask = GENMASK(7, 0) & ~BIT(6),
  3674. .mode = 0200,
  3675. },
  3676. {
  3677. .label = "bios_safe_mode",
  3678. .reg = MLXPLAT_CPLD_LPC_REG_GPCOM0_OFFSET,
  3679. .mask = GENMASK(7, 0) & ~BIT(4),
  3680. .mode = 0444,
  3681. },
  3682. {
  3683. .label = "bios_active_image",
  3684. .reg = MLXPLAT_CPLD_LPC_REG_GPCOM0_OFFSET,
  3685. .mask = GENMASK(7, 0) & ~BIT(5),
  3686. .mode = 0444,
  3687. },
  3688. {
  3689. .label = "bios_auth_fail",
  3690. .reg = MLXPLAT_CPLD_LPC_REG_GPCOM0_OFFSET,
  3691. .mask = GENMASK(7, 0) & ~BIT(6),
  3692. .mode = 0444,
  3693. },
  3694. {
  3695. .label = "bios_upgrade_fail",
  3696. .reg = MLXPLAT_CPLD_LPC_REG_GPCOM0_OFFSET,
  3697. .mask = GENMASK(7, 0) & ~BIT(7),
  3698. .mode = 0444,
  3699. },
  3700. {
  3701. .label = "voltreg_update_status",
  3702. .reg = MLXPLAT_CPLD_LPC_REG_GP0_RO_OFFSET,
  3703. .mask = MLXPLAT_CPLD_VOLTREG_UPD_MASK,
  3704. .bit = 5,
  3705. .mode = 0444,
  3706. },
  3707. {
  3708. .label = "vpd_wp",
  3709. .reg = MLXPLAT_CPLD_LPC_REG_GP0_OFFSET,
  3710. .mask = GENMASK(7, 0) & ~BIT(3),
  3711. .mode = 0644,
  3712. },
  3713. {
  3714. .label = "pcie_asic_reset_dis",
  3715. .reg = MLXPLAT_CPLD_LPC_REG_GP0_OFFSET,
  3716. .mask = GENMASK(7, 0) & ~BIT(4),
  3717. .mode = 0644,
  3718. },
  3719. {
  3720. .label = "global_wp_response",
  3721. .reg = MLXPLAT_CPLD_LPC_REG_GWP_OFFSET,
  3722. .mask = GENMASK(7, 0) & ~BIT(0),
  3723. .mode = 0444,
  3724. },
  3725. {
  3726. .label = "config1",
  3727. .reg = MLXPLAT_CPLD_LPC_REG_CONFIG1_OFFSET,
  3728. .bit = GENMASK(7, 0),
  3729. .mode = 0444,
  3730. },
  3731. {
  3732. .label = "config2",
  3733. .reg = MLXPLAT_CPLD_LPC_REG_CONFIG2_OFFSET,
  3734. .bit = GENMASK(7, 0),
  3735. .mode = 0444,
  3736. },
  3737. {
  3738. .label = "config3",
  3739. .reg = MLXPLAT_CPLD_LPC_REG_CONFIG3_OFFSET,
  3740. .bit = GENMASK(7, 0),
  3741. .mode = 0444,
  3742. },
  3743. {
  3744. .label = "ufm_version",
  3745. .reg = MLXPLAT_CPLD_LPC_REG_UFM_VERSION_OFFSET,
  3746. .bit = GENMASK(7, 0),
  3747. .mode = 0444,
  3748. },
  3749. };
  3750. static struct mlxreg_core_platform_data mlxplat_nvlink_blade_regs_io_data = {
  3751. .data = mlxplat_mlxcpld_nvlink_blade_regs_io_data,
  3752. .counter = ARRAY_SIZE(mlxplat_mlxcpld_nvlink_blade_regs_io_data),
  3753. };
  3754. /* Platform FAN default */
  3755. static struct mlxreg_core_data mlxplat_mlxcpld_default_fan_data[] = {
  3756. {
  3757. .label = "pwm1",
  3758. .reg = MLXPLAT_CPLD_LPC_REG_PWM1_OFFSET,
  3759. },
  3760. {
  3761. .label = "pwm2",
  3762. .reg = MLXPLAT_CPLD_LPC_REG_PWM2_OFFSET,
  3763. },
  3764. {
  3765. .label = "pwm3",
  3766. .reg = MLXPLAT_CPLD_LPC_REG_PWM3_OFFSET,
  3767. },
  3768. {
  3769. .label = "pwm4",
  3770. .reg = MLXPLAT_CPLD_LPC_REG_PWM4_OFFSET,
  3771. },
  3772. {
  3773. .label = "tacho1",
  3774. .reg = MLXPLAT_CPLD_LPC_REG_TACHO1_OFFSET,
  3775. .mask = GENMASK(7, 0),
  3776. .capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET,
  3777. .bit = BIT(0),
  3778. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  3779. },
  3780. {
  3781. .label = "tacho2",
  3782. .reg = MLXPLAT_CPLD_LPC_REG_TACHO2_OFFSET,
  3783. .mask = GENMASK(7, 0),
  3784. .capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET,
  3785. .bit = BIT(1),
  3786. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  3787. },
  3788. {
  3789. .label = "tacho3",
  3790. .reg = MLXPLAT_CPLD_LPC_REG_TACHO3_OFFSET,
  3791. .mask = GENMASK(7, 0),
  3792. .capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET,
  3793. .bit = BIT(2),
  3794. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  3795. },
  3796. {
  3797. .label = "tacho4",
  3798. .reg = MLXPLAT_CPLD_LPC_REG_TACHO4_OFFSET,
  3799. .mask = GENMASK(7, 0),
  3800. .capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET,
  3801. .bit = BIT(3),
  3802. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  3803. },
  3804. {
  3805. .label = "tacho5",
  3806. .reg = MLXPLAT_CPLD_LPC_REG_TACHO5_OFFSET,
  3807. .mask = GENMASK(7, 0),
  3808. .capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET,
  3809. .bit = BIT(4),
  3810. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  3811. },
  3812. {
  3813. .label = "tacho6",
  3814. .reg = MLXPLAT_CPLD_LPC_REG_TACHO6_OFFSET,
  3815. .mask = GENMASK(7, 0),
  3816. .capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET,
  3817. .bit = BIT(5),
  3818. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  3819. },
  3820. {
  3821. .label = "tacho7",
  3822. .reg = MLXPLAT_CPLD_LPC_REG_TACHO7_OFFSET,
  3823. .mask = GENMASK(7, 0),
  3824. .capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET,
  3825. .bit = BIT(6),
  3826. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  3827. },
  3828. {
  3829. .label = "tacho8",
  3830. .reg = MLXPLAT_CPLD_LPC_REG_TACHO8_OFFSET,
  3831. .mask = GENMASK(7, 0),
  3832. .capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET,
  3833. .bit = BIT(7),
  3834. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  3835. },
  3836. {
  3837. .label = "tacho9",
  3838. .reg = MLXPLAT_CPLD_LPC_REG_TACHO9_OFFSET,
  3839. .mask = GENMASK(7, 0),
  3840. .capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET,
  3841. .bit = BIT(0),
  3842. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  3843. },
  3844. {
  3845. .label = "tacho10",
  3846. .reg = MLXPLAT_CPLD_LPC_REG_TACHO10_OFFSET,
  3847. .mask = GENMASK(7, 0),
  3848. .capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET,
  3849. .bit = BIT(1),
  3850. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  3851. },
  3852. {
  3853. .label = "tacho11",
  3854. .reg = MLXPLAT_CPLD_LPC_REG_TACHO11_OFFSET,
  3855. .mask = GENMASK(7, 0),
  3856. .capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET,
  3857. .bit = BIT(2),
  3858. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  3859. },
  3860. {
  3861. .label = "tacho12",
  3862. .reg = MLXPLAT_CPLD_LPC_REG_TACHO12_OFFSET,
  3863. .mask = GENMASK(7, 0),
  3864. .capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET,
  3865. .bit = BIT(3),
  3866. .reg_prsnt = MLXPLAT_CPLD_LPC_REG_FAN_OFFSET,
  3867. },
  3868. {
  3869. .label = "tacho13",
  3870. .reg = MLXPLAT_CPLD_LPC_REG_TACHO13_OFFSET,
  3871. .mask = GENMASK(7, 0),
  3872. .capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET,
  3873. .bit = BIT(4),
  3874. },
  3875. {
  3876. .label = "tacho14",
  3877. .reg = MLXPLAT_CPLD_LPC_REG_TACHO14_OFFSET,
  3878. .mask = GENMASK(7, 0),
  3879. .capability = MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET,
  3880. .bit = BIT(5),
  3881. },
  3882. {
  3883. .label = "conf",
  3884. .capability = MLXPLAT_CPLD_LPC_REG_TACHO_SPEED_OFFSET,
  3885. },
  3886. };
  3887. static struct mlxreg_core_platform_data mlxplat_default_fan_data = {
  3888. .data = mlxplat_mlxcpld_default_fan_data,
  3889. .counter = ARRAY_SIZE(mlxplat_mlxcpld_default_fan_data),
  3890. .capability = MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET,
  3891. };
  3892. /* Watchdog type1: hardware implementation version1
  3893. * (MSN2700, MSN2410, MSN2740, MSN2100 and MSN2140 systems).
  3894. */
  3895. static struct mlxreg_core_data mlxplat_mlxcpld_wd_main_regs_type1[] = {
  3896. {
  3897. .label = "action",
  3898. .reg = MLXPLAT_CPLD_LPC_REG_WD1_ACT_OFFSET,
  3899. .mask = MLXPLAT_CPLD_WD_RESET_ACT_MASK,
  3900. .bit = 0,
  3901. },
  3902. {
  3903. .label = "timeout",
  3904. .reg = MLXPLAT_CPLD_LPC_REG_WD1_TMR_OFFSET,
  3905. .mask = MLXPLAT_CPLD_WD_TYPE1_TO_MASK,
  3906. .health_cntr = MLXPLAT_CPLD_WD_DFLT_TIMEOUT,
  3907. },
  3908. {
  3909. .label = "ping",
  3910. .reg = MLXPLAT_CPLD_LPC_REG_WD_CLEAR_OFFSET,
  3911. .mask = MLXPLAT_CPLD_WD1_CLEAR_MASK,
  3912. .bit = 0,
  3913. },
  3914. {
  3915. .label = "reset",
  3916. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  3917. .mask = GENMASK(7, 0) & ~BIT(6),
  3918. .bit = 6,
  3919. },
  3920. };
  3921. static struct mlxreg_core_data mlxplat_mlxcpld_wd_aux_regs_type1[] = {
  3922. {
  3923. .label = "action",
  3924. .reg = MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET,
  3925. .mask = MLXPLAT_CPLD_WD_FAN_ACT_MASK,
  3926. .bit = 4,
  3927. },
  3928. {
  3929. .label = "timeout",
  3930. .reg = MLXPLAT_CPLD_LPC_REG_WD2_TMR_OFFSET,
  3931. .mask = MLXPLAT_CPLD_WD_TYPE1_TO_MASK,
  3932. .health_cntr = MLXPLAT_CPLD_WD_DFLT_TIMEOUT,
  3933. },
  3934. {
  3935. .label = "ping",
  3936. .reg = MLXPLAT_CPLD_LPC_REG_WD_CLEAR_OFFSET,
  3937. .mask = MLXPLAT_CPLD_WD1_CLEAR_MASK,
  3938. .bit = 1,
  3939. },
  3940. };
  3941. static struct mlxreg_core_platform_data mlxplat_mlxcpld_wd_set_type1[] = {
  3942. {
  3943. .data = mlxplat_mlxcpld_wd_main_regs_type1,
  3944. .counter = ARRAY_SIZE(mlxplat_mlxcpld_wd_main_regs_type1),
  3945. .version = MLX_WDT_TYPE1,
  3946. .identity = "mlx-wdt-main",
  3947. },
  3948. {
  3949. .data = mlxplat_mlxcpld_wd_aux_regs_type1,
  3950. .counter = ARRAY_SIZE(mlxplat_mlxcpld_wd_aux_regs_type1),
  3951. .version = MLX_WDT_TYPE1,
  3952. .identity = "mlx-wdt-aux",
  3953. },
  3954. };
  3955. /* Watchdog type2: hardware implementation version 2
  3956. * (all systems except (MSN2700, MSN2410, MSN2740, MSN2100 and MSN2140).
  3957. */
  3958. static struct mlxreg_core_data mlxplat_mlxcpld_wd_main_regs_type2[] = {
  3959. {
  3960. .label = "action",
  3961. .reg = MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET,
  3962. .mask = MLXPLAT_CPLD_WD_RESET_ACT_MASK,
  3963. .bit = 0,
  3964. },
  3965. {
  3966. .label = "timeout",
  3967. .reg = MLXPLAT_CPLD_LPC_REG_WD2_TMR_OFFSET,
  3968. .mask = MLXPLAT_CPLD_WD_TYPE2_TO_MASK,
  3969. .health_cntr = MLXPLAT_CPLD_WD_DFLT_TIMEOUT,
  3970. },
  3971. {
  3972. .label = "timeleft",
  3973. .reg = MLXPLAT_CPLD_LPC_REG_WD2_TLEFT_OFFSET,
  3974. .mask = MLXPLAT_CPLD_WD_TYPE2_TO_MASK,
  3975. },
  3976. {
  3977. .label = "ping",
  3978. .reg = MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET,
  3979. .mask = MLXPLAT_CPLD_WD_RESET_ACT_MASK,
  3980. .bit = 0,
  3981. },
  3982. {
  3983. .label = "reset",
  3984. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  3985. .mask = GENMASK(7, 0) & ~BIT(6),
  3986. .bit = 6,
  3987. },
  3988. };
  3989. static struct mlxreg_core_data mlxplat_mlxcpld_wd_aux_regs_type2[] = {
  3990. {
  3991. .label = "action",
  3992. .reg = MLXPLAT_CPLD_LPC_REG_WD3_ACT_OFFSET,
  3993. .mask = MLXPLAT_CPLD_WD_FAN_ACT_MASK,
  3994. .bit = 4,
  3995. },
  3996. {
  3997. .label = "timeout",
  3998. .reg = MLXPLAT_CPLD_LPC_REG_WD3_TMR_OFFSET,
  3999. .mask = MLXPLAT_CPLD_WD_TYPE2_TO_MASK,
  4000. .health_cntr = MLXPLAT_CPLD_WD_DFLT_TIMEOUT,
  4001. },
  4002. {
  4003. .label = "timeleft",
  4004. .reg = MLXPLAT_CPLD_LPC_REG_WD3_TLEFT_OFFSET,
  4005. .mask = MLXPLAT_CPLD_WD_TYPE2_TO_MASK,
  4006. },
  4007. {
  4008. .label = "ping",
  4009. .reg = MLXPLAT_CPLD_LPC_REG_WD3_ACT_OFFSET,
  4010. .mask = MLXPLAT_CPLD_WD_FAN_ACT_MASK,
  4011. .bit = 4,
  4012. },
  4013. };
  4014. static struct mlxreg_core_platform_data mlxplat_mlxcpld_wd_set_type2[] = {
  4015. {
  4016. .data = mlxplat_mlxcpld_wd_main_regs_type2,
  4017. .counter = ARRAY_SIZE(mlxplat_mlxcpld_wd_main_regs_type2),
  4018. .version = MLX_WDT_TYPE2,
  4019. .identity = "mlx-wdt-main",
  4020. },
  4021. {
  4022. .data = mlxplat_mlxcpld_wd_aux_regs_type2,
  4023. .counter = ARRAY_SIZE(mlxplat_mlxcpld_wd_aux_regs_type2),
  4024. .version = MLX_WDT_TYPE2,
  4025. .identity = "mlx-wdt-aux",
  4026. },
  4027. };
  4028. /* Watchdog type3: hardware implementation version 3
  4029. * Can be on all systems. It's differentiated by WD capability bit.
  4030. * Old systems (MSN2700, MSN2410, MSN2740, MSN2100 and MSN2140)
  4031. * still have only one main watchdog.
  4032. */
  4033. static struct mlxreg_core_data mlxplat_mlxcpld_wd_main_regs_type3[] = {
  4034. {
  4035. .label = "action",
  4036. .reg = MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET,
  4037. .mask = MLXPLAT_CPLD_WD_RESET_ACT_MASK,
  4038. .bit = 0,
  4039. },
  4040. {
  4041. .label = "timeout",
  4042. .reg = MLXPLAT_CPLD_LPC_REG_WD2_TMR_OFFSET,
  4043. .mask = MLXPLAT_CPLD_WD_TYPE2_TO_MASK,
  4044. .health_cntr = MLXPLAT_CPLD_WD3_DFLT_TIMEOUT,
  4045. },
  4046. {
  4047. .label = "timeleft",
  4048. .reg = MLXPLAT_CPLD_LPC_REG_WD2_TMR_OFFSET,
  4049. .mask = MLXPLAT_CPLD_WD_TYPE2_TO_MASK,
  4050. },
  4051. {
  4052. .label = "ping",
  4053. .reg = MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET,
  4054. .mask = MLXPLAT_CPLD_WD_RESET_ACT_MASK,
  4055. .bit = 0,
  4056. },
  4057. {
  4058. .label = "reset",
  4059. .reg = MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET,
  4060. .mask = GENMASK(7, 0) & ~BIT(6),
  4061. .bit = 6,
  4062. },
  4063. };
  4064. static struct mlxreg_core_data mlxplat_mlxcpld_wd_aux_regs_type3[] = {
  4065. {
  4066. .label = "action",
  4067. .reg = MLXPLAT_CPLD_LPC_REG_WD3_ACT_OFFSET,
  4068. .mask = MLXPLAT_CPLD_WD_FAN_ACT_MASK,
  4069. .bit = 4,
  4070. },
  4071. {
  4072. .label = "timeout",
  4073. .reg = MLXPLAT_CPLD_LPC_REG_WD3_TMR_OFFSET,
  4074. .mask = MLXPLAT_CPLD_WD_TYPE2_TO_MASK,
  4075. .health_cntr = MLXPLAT_CPLD_WD3_DFLT_TIMEOUT,
  4076. },
  4077. {
  4078. .label = "timeleft",
  4079. .reg = MLXPLAT_CPLD_LPC_REG_WD3_TMR_OFFSET,
  4080. .mask = MLXPLAT_CPLD_WD_TYPE2_TO_MASK,
  4081. },
  4082. {
  4083. .label = "ping",
  4084. .reg = MLXPLAT_CPLD_LPC_REG_WD3_ACT_OFFSET,
  4085. .mask = MLXPLAT_CPLD_WD_FAN_ACT_MASK,
  4086. .bit = 4,
  4087. },
  4088. };
  4089. static struct mlxreg_core_platform_data mlxplat_mlxcpld_wd_set_type3[] = {
  4090. {
  4091. .data = mlxplat_mlxcpld_wd_main_regs_type3,
  4092. .counter = ARRAY_SIZE(mlxplat_mlxcpld_wd_main_regs_type3),
  4093. .version = MLX_WDT_TYPE3,
  4094. .identity = "mlx-wdt-main",
  4095. },
  4096. {
  4097. .data = mlxplat_mlxcpld_wd_aux_regs_type3,
  4098. .counter = ARRAY_SIZE(mlxplat_mlxcpld_wd_aux_regs_type3),
  4099. .version = MLX_WDT_TYPE3,
  4100. .identity = "mlx-wdt-aux",
  4101. },
  4102. };
  4103. static bool mlxplat_mlxcpld_writeable_reg(struct device *dev, unsigned int reg)
  4104. {
  4105. switch (reg) {
  4106. case MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET:
  4107. case MLXPLAT_CPLD_LPC_REG_LED1_OFFSET:
  4108. case MLXPLAT_CPLD_LPC_REG_LED2_OFFSET:
  4109. case MLXPLAT_CPLD_LPC_REG_LED3_OFFSET:
  4110. case MLXPLAT_CPLD_LPC_REG_LED4_OFFSET:
  4111. case MLXPLAT_CPLD_LPC_REG_LED5_OFFSET:
  4112. case MLXPLAT_CPLD_LPC_REG_LED6_OFFSET:
  4113. case MLXPLAT_CPLD_LPC_REG_LED7_OFFSET:
  4114. case MLXPLAT_CPLD_LPC_REG_GP0_OFFSET:
  4115. case MLXPLAT_CPLD_LPC_REG_GP_RST_OFFSET:
  4116. case MLXPLAT_CPLD_LPC_REG_GP1_OFFSET:
  4117. case MLXPLAT_CPLD_LPC_REG_WP1_OFFSET:
  4118. case MLXPLAT_CPLD_LPC_REG_GP2_OFFSET:
  4119. case MLXPLAT_CPLD_LPC_REG_WP2_OFFSET:
  4120. case MLXPLAT_CPLD_LPC_REG_FIELD_UPGRADE:
  4121. case MLXPLAT_CPLD_LPC_SAFE_BIOS_OFFSET:
  4122. case MLXPLAT_CPLD_LPC_SAFE_BIOS_WP_OFFSET:
  4123. case MLXPLAT_CPLD_LPC_REG_AGGR_MASK_OFFSET:
  4124. case MLXPLAT_CPLD_LPC_REG_AGGRLO_MASK_OFFSET:
  4125. case MLXPLAT_CPLD_LPC_REG_AGGRCO_MASK_OFFSET:
  4126. case MLXPLAT_CPLD_LPC_REG_AGGRCX_MASK_OFFSET:
  4127. case MLXPLAT_CPLD_LPC_REG_GWP_EVENT_OFFSET:
  4128. case MLXPLAT_CPLD_LPC_REG_GWP_MASK_OFFSET:
  4129. case MLXPLAT_CPLD_LPC_REG_ASIC_EVENT_OFFSET:
  4130. case MLXPLAT_CPLD_LPC_REG_ASIC_MASK_OFFSET:
  4131. case MLXPLAT_CPLD_LPC_REG_ASIC2_EVENT_OFFSET:
  4132. case MLXPLAT_CPLD_LPC_REG_ASIC2_MASK_OFFSET:
  4133. case MLXPLAT_CPLD_LPC_REG_PSU_EVENT_OFFSET:
  4134. case MLXPLAT_CPLD_LPC_REG_PSU_MASK_OFFSET:
  4135. case MLXPLAT_CPLD_LPC_REG_PWR_EVENT_OFFSET:
  4136. case MLXPLAT_CPLD_LPC_REG_PWR_MASK_OFFSET:
  4137. case MLXPLAT_CPLD_LPC_REG_FAN_EVENT_OFFSET:
  4138. case MLXPLAT_CPLD_LPC_REG_FAN_MASK_OFFSET:
  4139. case MLXPLAT_CPLD_LPC_REG_AGGRLC_MASK_OFFSET:
  4140. case MLXPLAT_CPLD_LPC_REG_LC_IN_EVENT_OFFSET:
  4141. case MLXPLAT_CPLD_LPC_REG_LC_IN_MASK_OFFSET:
  4142. case MLXPLAT_CPLD_LPC_REG_LC_VR_EVENT_OFFSET:
  4143. case MLXPLAT_CPLD_LPC_REG_LC_VR_MASK_OFFSET:
  4144. case MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET:
  4145. case MLXPLAT_CPLD_LPC_REG_LC_PG_EVENT_OFFSET:
  4146. case MLXPLAT_CPLD_LPC_REG_LC_PG_MASK_OFFSET:
  4147. case MLXPLAT_CPLD_LPC_REG_LC_RD_EVENT_OFFSET:
  4148. case MLXPLAT_CPLD_LPC_REG_LC_RD_MASK_OFFSET:
  4149. case MLXPLAT_CPLD_LPC_REG_LC_OK_EVENT_OFFSET:
  4150. case MLXPLAT_CPLD_LPC_REG_LC_OK_MASK_OFFSET:
  4151. case MLXPLAT_CPLD_LPC_REG_LC_SN_EVENT_OFFSET:
  4152. case MLXPLAT_CPLD_LPC_REG_LC_SN_MASK_OFFSET:
  4153. case MLXPLAT_CPLD_LPC_REG_LC_SD_EVENT_OFFSET:
  4154. case MLXPLAT_CPLD_LPC_REG_LC_SD_MASK_OFFSET:
  4155. case MLXPLAT_CPLD_LPC_REG_LC_PWR_ON:
  4156. case MLXPLAT_CPLD_LPC_REG_WD_CLEAR_OFFSET:
  4157. case MLXPLAT_CPLD_LPC_REG_WD_CLEAR_WP_OFFSET:
  4158. case MLXPLAT_CPLD_LPC_REG_WD1_TMR_OFFSET:
  4159. case MLXPLAT_CPLD_LPC_REG_WD1_ACT_OFFSET:
  4160. case MLXPLAT_CPLD_LPC_REG_WD2_TMR_OFFSET:
  4161. case MLXPLAT_CPLD_LPC_REG_WD2_TLEFT_OFFSET:
  4162. case MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET:
  4163. case MLXPLAT_CPLD_LPC_REG_WD3_TMR_OFFSET:
  4164. case MLXPLAT_CPLD_LPC_REG_WD3_TLEFT_OFFSET:
  4165. case MLXPLAT_CPLD_LPC_REG_WD3_ACT_OFFSET:
  4166. case MLXPLAT_CPLD_LPC_REG_PWM1_OFFSET:
  4167. case MLXPLAT_CPLD_LPC_REG_PWM2_OFFSET:
  4168. case MLXPLAT_CPLD_LPC_REG_PWM3_OFFSET:
  4169. case MLXPLAT_CPLD_LPC_REG_PWM4_OFFSET:
  4170. case MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET:
  4171. return true;
  4172. }
  4173. return false;
  4174. }
  4175. static bool mlxplat_mlxcpld_readable_reg(struct device *dev, unsigned int reg)
  4176. {
  4177. switch (reg) {
  4178. case MLXPLAT_CPLD_LPC_REG_CPLD1_VER_OFFSET:
  4179. case MLXPLAT_CPLD_LPC_REG_CPLD2_VER_OFFSET:
  4180. case MLXPLAT_CPLD_LPC_REG_CPLD3_VER_OFFSET:
  4181. case MLXPLAT_CPLD_LPC_REG_CPLD4_VER_OFFSET:
  4182. case MLXPLAT_CPLD_LPC_REG_CPLD1_PN_OFFSET:
  4183. case MLXPLAT_CPLD_LPC_REG_CPLD1_PN1_OFFSET:
  4184. case MLXPLAT_CPLD_LPC_REG_CPLD2_PN_OFFSET:
  4185. case MLXPLAT_CPLD_LPC_REG_CPLD2_PN1_OFFSET:
  4186. case MLXPLAT_CPLD_LPC_REG_CPLD3_PN_OFFSET:
  4187. case MLXPLAT_CPLD_LPC_REG_CPLD3_PN1_OFFSET:
  4188. case MLXPLAT_CPLD_LPC_REG_CPLD4_PN_OFFSET:
  4189. case MLXPLAT_CPLD_LPC_REG_CPLD4_PN1_OFFSET:
  4190. case MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET:
  4191. case MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET:
  4192. case MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET:
  4193. case MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET:
  4194. case MLXPLAT_CPLD_LPC_REG_LED1_OFFSET:
  4195. case MLXPLAT_CPLD_LPC_REG_LED2_OFFSET:
  4196. case MLXPLAT_CPLD_LPC_REG_LED3_OFFSET:
  4197. case MLXPLAT_CPLD_LPC_REG_LED4_OFFSET:
  4198. case MLXPLAT_CPLD_LPC_REG_LED5_OFFSET:
  4199. case MLXPLAT_CPLD_LPC_REG_LED6_OFFSET:
  4200. case MLXPLAT_CPLD_LPC_REG_LED7_OFFSET:
  4201. case MLXPLAT_CPLD_LPC_REG_FAN_DIRECTION:
  4202. case MLXPLAT_CPLD_LPC_REG_GP0_RO_OFFSET:
  4203. case MLXPLAT_CPLD_LPC_REG_GPCOM0_OFFSET:
  4204. case MLXPLAT_CPLD_LPC_REG_GP0_OFFSET:
  4205. case MLXPLAT_CPLD_LPC_REG_GP_RST_OFFSET:
  4206. case MLXPLAT_CPLD_LPC_REG_GP1_OFFSET:
  4207. case MLXPLAT_CPLD_LPC_REG_WP1_OFFSET:
  4208. case MLXPLAT_CPLD_LPC_REG_GP2_OFFSET:
  4209. case MLXPLAT_CPLD_LPC_REG_WP2_OFFSET:
  4210. case MLXPLAT_CPLD_LPC_REG_FIELD_UPGRADE:
  4211. case MLXPLAT_CPLD_LPC_SAFE_BIOS_OFFSET:
  4212. case MLXPLAT_CPLD_LPC_SAFE_BIOS_WP_OFFSET:
  4213. case MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET:
  4214. case MLXPLAT_CPLD_LPC_REG_AGGR_MASK_OFFSET:
  4215. case MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET:
  4216. case MLXPLAT_CPLD_LPC_REG_AGGRLO_MASK_OFFSET:
  4217. case MLXPLAT_CPLD_LPC_REG_AGGRCO_OFFSET:
  4218. case MLXPLAT_CPLD_LPC_REG_AGGRCO_MASK_OFFSET:
  4219. case MLXPLAT_CPLD_LPC_REG_AGGRCX_OFFSET:
  4220. case MLXPLAT_CPLD_LPC_REG_AGGRCX_MASK_OFFSET:
  4221. case MLXPLAT_CPLD_LPC_REG_GWP_OFFSET:
  4222. case MLXPLAT_CPLD_LPC_REG_GWP_EVENT_OFFSET:
  4223. case MLXPLAT_CPLD_LPC_REG_GWP_MASK_OFFSET:
  4224. case MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET:
  4225. case MLXPLAT_CPLD_LPC_REG_ASIC_EVENT_OFFSET:
  4226. case MLXPLAT_CPLD_LPC_REG_ASIC_MASK_OFFSET:
  4227. case MLXPLAT_CPLD_LPC_REG_ASIC2_HEALTH_OFFSET:
  4228. case MLXPLAT_CPLD_LPC_REG_ASIC2_EVENT_OFFSET:
  4229. case MLXPLAT_CPLD_LPC_REG_ASIC2_MASK_OFFSET:
  4230. case MLXPLAT_CPLD_LPC_REG_PSU_OFFSET:
  4231. case MLXPLAT_CPLD_LPC_REG_PSU_EVENT_OFFSET:
  4232. case MLXPLAT_CPLD_LPC_REG_PSU_MASK_OFFSET:
  4233. case MLXPLAT_CPLD_LPC_REG_PWR_OFFSET:
  4234. case MLXPLAT_CPLD_LPC_REG_PWR_EVENT_OFFSET:
  4235. case MLXPLAT_CPLD_LPC_REG_PWR_MASK_OFFSET:
  4236. case MLXPLAT_CPLD_LPC_REG_FAN_OFFSET:
  4237. case MLXPLAT_CPLD_LPC_REG_FAN_EVENT_OFFSET:
  4238. case MLXPLAT_CPLD_LPC_REG_FAN_MASK_OFFSET:
  4239. case MLXPLAT_CPLD_LPC_REG_AGGRLC_OFFSET:
  4240. case MLXPLAT_CPLD_LPC_REG_AGGRLC_MASK_OFFSET:
  4241. case MLXPLAT_CPLD_LPC_REG_LC_IN_OFFSET:
  4242. case MLXPLAT_CPLD_LPC_REG_LC_IN_EVENT_OFFSET:
  4243. case MLXPLAT_CPLD_LPC_REG_LC_IN_MASK_OFFSET:
  4244. case MLXPLAT_CPLD_LPC_REG_LC_VR_OFFSET:
  4245. case MLXPLAT_CPLD_LPC_REG_LC_VR_EVENT_OFFSET:
  4246. case MLXPLAT_CPLD_LPC_REG_LC_VR_MASK_OFFSET:
  4247. case MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET:
  4248. case MLXPLAT_CPLD_LPC_REG_LC_PG_EVENT_OFFSET:
  4249. case MLXPLAT_CPLD_LPC_REG_LC_PG_MASK_OFFSET:
  4250. case MLXPLAT_CPLD_LPC_REG_LC_RD_OFFSET:
  4251. case MLXPLAT_CPLD_LPC_REG_LC_RD_EVENT_OFFSET:
  4252. case MLXPLAT_CPLD_LPC_REG_LC_RD_MASK_OFFSET:
  4253. case MLXPLAT_CPLD_LPC_REG_LC_OK_OFFSET:
  4254. case MLXPLAT_CPLD_LPC_REG_LC_OK_EVENT_OFFSET:
  4255. case MLXPLAT_CPLD_LPC_REG_LC_OK_MASK_OFFSET:
  4256. case MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET:
  4257. case MLXPLAT_CPLD_LPC_REG_LC_SN_EVENT_OFFSET:
  4258. case MLXPLAT_CPLD_LPC_REG_LC_SN_MASK_OFFSET:
  4259. case MLXPLAT_CPLD_LPC_REG_LC_SD_OFFSET:
  4260. case MLXPLAT_CPLD_LPC_REG_LC_SD_EVENT_OFFSET:
  4261. case MLXPLAT_CPLD_LPC_REG_LC_SD_MASK_OFFSET:
  4262. case MLXPLAT_CPLD_LPC_REG_LC_PWR_ON:
  4263. case MLXPLAT_CPLD_LPC_REG_WD_CLEAR_OFFSET:
  4264. case MLXPLAT_CPLD_LPC_REG_WD_CLEAR_WP_OFFSET:
  4265. case MLXPLAT_CPLD_LPC_REG_WD1_TMR_OFFSET:
  4266. case MLXPLAT_CPLD_LPC_REG_WD1_ACT_OFFSET:
  4267. case MLXPLAT_CPLD_LPC_REG_WD2_TMR_OFFSET:
  4268. case MLXPLAT_CPLD_LPC_REG_WD2_TLEFT_OFFSET:
  4269. case MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET:
  4270. case MLXPLAT_CPLD_LPC_REG_WD3_TMR_OFFSET:
  4271. case MLXPLAT_CPLD_LPC_REG_WD3_TLEFT_OFFSET:
  4272. case MLXPLAT_CPLD_LPC_REG_WD3_ACT_OFFSET:
  4273. case MLXPLAT_CPLD_LPC_REG_CPLD1_MVER_OFFSET:
  4274. case MLXPLAT_CPLD_LPC_REG_CPLD2_MVER_OFFSET:
  4275. case MLXPLAT_CPLD_LPC_REG_CPLD3_MVER_OFFSET:
  4276. case MLXPLAT_CPLD_LPC_REG_CPLD4_MVER_OFFSET:
  4277. case MLXPLAT_CPLD_LPC_REG_PWM1_OFFSET:
  4278. case MLXPLAT_CPLD_LPC_REG_PWM2_OFFSET:
  4279. case MLXPLAT_CPLD_LPC_REG_PWM3_OFFSET:
  4280. case MLXPLAT_CPLD_LPC_REG_PWM4_OFFSET:
  4281. case MLXPLAT_CPLD_LPC_REG_TACHO1_OFFSET:
  4282. case MLXPLAT_CPLD_LPC_REG_TACHO2_OFFSET:
  4283. case MLXPLAT_CPLD_LPC_REG_TACHO3_OFFSET:
  4284. case MLXPLAT_CPLD_LPC_REG_TACHO4_OFFSET:
  4285. case MLXPLAT_CPLD_LPC_REG_TACHO5_OFFSET:
  4286. case MLXPLAT_CPLD_LPC_REG_TACHO6_OFFSET:
  4287. case MLXPLAT_CPLD_LPC_REG_TACHO7_OFFSET:
  4288. case MLXPLAT_CPLD_LPC_REG_TACHO8_OFFSET:
  4289. case MLXPLAT_CPLD_LPC_REG_TACHO9_OFFSET:
  4290. case MLXPLAT_CPLD_LPC_REG_TACHO10_OFFSET:
  4291. case MLXPLAT_CPLD_LPC_REG_TACHO11_OFFSET:
  4292. case MLXPLAT_CPLD_LPC_REG_TACHO12_OFFSET:
  4293. case MLXPLAT_CPLD_LPC_REG_TACHO13_OFFSET:
  4294. case MLXPLAT_CPLD_LPC_REG_TACHO14_OFFSET:
  4295. case MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET:
  4296. case MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET:
  4297. case MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET:
  4298. case MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET:
  4299. case MLXPLAT_CPLD_LPC_REG_TACHO_SPEED_OFFSET:
  4300. case MLXPLAT_CPLD_LPC_REG_PSU_I2C_CAP_OFFSET:
  4301. case MLXPLAT_CPLD_LPC_REG_SLOT_QTY_OFFSET:
  4302. case MLXPLAT_CPLD_LPC_REG_CONFIG1_OFFSET:
  4303. case MLXPLAT_CPLD_LPC_REG_CONFIG2_OFFSET:
  4304. case MLXPLAT_CPLD_LPC_REG_CONFIG3_OFFSET:
  4305. case MLXPLAT_CPLD_LPC_REG_UFM_VERSION_OFFSET:
  4306. return true;
  4307. }
  4308. return false;
  4309. }
  4310. static bool mlxplat_mlxcpld_volatile_reg(struct device *dev, unsigned int reg)
  4311. {
  4312. switch (reg) {
  4313. case MLXPLAT_CPLD_LPC_REG_CPLD1_VER_OFFSET:
  4314. case MLXPLAT_CPLD_LPC_REG_CPLD2_VER_OFFSET:
  4315. case MLXPLAT_CPLD_LPC_REG_CPLD3_VER_OFFSET:
  4316. case MLXPLAT_CPLD_LPC_REG_CPLD4_VER_OFFSET:
  4317. case MLXPLAT_CPLD_LPC_REG_CPLD1_PN_OFFSET:
  4318. case MLXPLAT_CPLD_LPC_REG_CPLD1_PN1_OFFSET:
  4319. case MLXPLAT_CPLD_LPC_REG_CPLD2_PN_OFFSET:
  4320. case MLXPLAT_CPLD_LPC_REG_CPLD2_PN1_OFFSET:
  4321. case MLXPLAT_CPLD_LPC_REG_CPLD3_PN_OFFSET:
  4322. case MLXPLAT_CPLD_LPC_REG_CPLD3_PN1_OFFSET:
  4323. case MLXPLAT_CPLD_LPC_REG_CPLD4_PN_OFFSET:
  4324. case MLXPLAT_CPLD_LPC_REG_CPLD4_PN1_OFFSET:
  4325. case MLXPLAT_CPLD_LPC_REG_RESET_GP4_OFFSET:
  4326. case MLXPLAT_CPLD_LPC_REG_RESET_CAUSE_OFFSET:
  4327. case MLXPLAT_CPLD_LPC_REG_RST_CAUSE1_OFFSET:
  4328. case MLXPLAT_CPLD_LPC_REG_RST_CAUSE2_OFFSET:
  4329. case MLXPLAT_CPLD_LPC_REG_LED1_OFFSET:
  4330. case MLXPLAT_CPLD_LPC_REG_LED2_OFFSET:
  4331. case MLXPLAT_CPLD_LPC_REG_LED3_OFFSET:
  4332. case MLXPLAT_CPLD_LPC_REG_LED4_OFFSET:
  4333. case MLXPLAT_CPLD_LPC_REG_LED5_OFFSET:
  4334. case MLXPLAT_CPLD_LPC_REG_LED6_OFFSET:
  4335. case MLXPLAT_CPLD_LPC_REG_LED7_OFFSET:
  4336. case MLXPLAT_CPLD_LPC_REG_FAN_DIRECTION:
  4337. case MLXPLAT_CPLD_LPC_REG_GP0_RO_OFFSET:
  4338. case MLXPLAT_CPLD_LPC_REG_GPCOM0_OFFSET:
  4339. case MLXPLAT_CPLD_LPC_REG_GP0_OFFSET:
  4340. case MLXPLAT_CPLD_LPC_REG_GP_RST_OFFSET:
  4341. case MLXPLAT_CPLD_LPC_REG_GP1_OFFSET:
  4342. case MLXPLAT_CPLD_LPC_REG_GP2_OFFSET:
  4343. case MLXPLAT_CPLD_LPC_REG_FIELD_UPGRADE:
  4344. case MLXPLAT_CPLD_LPC_SAFE_BIOS_OFFSET:
  4345. case MLXPLAT_CPLD_LPC_SAFE_BIOS_WP_OFFSET:
  4346. case MLXPLAT_CPLD_LPC_REG_AGGR_OFFSET:
  4347. case MLXPLAT_CPLD_LPC_REG_AGGR_MASK_OFFSET:
  4348. case MLXPLAT_CPLD_LPC_REG_AGGRLO_OFFSET:
  4349. case MLXPLAT_CPLD_LPC_REG_AGGRLO_MASK_OFFSET:
  4350. case MLXPLAT_CPLD_LPC_REG_AGGRCO_OFFSET:
  4351. case MLXPLAT_CPLD_LPC_REG_AGGRCO_MASK_OFFSET:
  4352. case MLXPLAT_CPLD_LPC_REG_AGGRCX_OFFSET:
  4353. case MLXPLAT_CPLD_LPC_REG_AGGRCX_MASK_OFFSET:
  4354. case MLXPLAT_CPLD_LPC_REG_GWP_OFFSET:
  4355. case MLXPLAT_CPLD_LPC_REG_GWP_EVENT_OFFSET:
  4356. case MLXPLAT_CPLD_LPC_REG_GWP_MASK_OFFSET:
  4357. case MLXPLAT_CPLD_LPC_REG_ASIC_HEALTH_OFFSET:
  4358. case MLXPLAT_CPLD_LPC_REG_ASIC_EVENT_OFFSET:
  4359. case MLXPLAT_CPLD_LPC_REG_ASIC_MASK_OFFSET:
  4360. case MLXPLAT_CPLD_LPC_REG_ASIC2_HEALTH_OFFSET:
  4361. case MLXPLAT_CPLD_LPC_REG_ASIC2_EVENT_OFFSET:
  4362. case MLXPLAT_CPLD_LPC_REG_ASIC2_MASK_OFFSET:
  4363. case MLXPLAT_CPLD_LPC_REG_PSU_OFFSET:
  4364. case MLXPLAT_CPLD_LPC_REG_PSU_EVENT_OFFSET:
  4365. case MLXPLAT_CPLD_LPC_REG_PSU_MASK_OFFSET:
  4366. case MLXPLAT_CPLD_LPC_REG_PWR_OFFSET:
  4367. case MLXPLAT_CPLD_LPC_REG_PWR_EVENT_OFFSET:
  4368. case MLXPLAT_CPLD_LPC_REG_PWR_MASK_OFFSET:
  4369. case MLXPLAT_CPLD_LPC_REG_FAN_OFFSET:
  4370. case MLXPLAT_CPLD_LPC_REG_FAN_EVENT_OFFSET:
  4371. case MLXPLAT_CPLD_LPC_REG_FAN_MASK_OFFSET:
  4372. case MLXPLAT_CPLD_LPC_REG_AGGRLC_OFFSET:
  4373. case MLXPLAT_CPLD_LPC_REG_AGGRLC_MASK_OFFSET:
  4374. case MLXPLAT_CPLD_LPC_REG_LC_IN_OFFSET:
  4375. case MLXPLAT_CPLD_LPC_REG_LC_IN_EVENT_OFFSET:
  4376. case MLXPLAT_CPLD_LPC_REG_LC_IN_MASK_OFFSET:
  4377. case MLXPLAT_CPLD_LPC_REG_LC_VR_OFFSET:
  4378. case MLXPLAT_CPLD_LPC_REG_LC_VR_EVENT_OFFSET:
  4379. case MLXPLAT_CPLD_LPC_REG_LC_VR_MASK_OFFSET:
  4380. case MLXPLAT_CPLD_LPC_REG_LC_PG_OFFSET:
  4381. case MLXPLAT_CPLD_LPC_REG_LC_PG_EVENT_OFFSET:
  4382. case MLXPLAT_CPLD_LPC_REG_LC_PG_MASK_OFFSET:
  4383. case MLXPLAT_CPLD_LPC_REG_LC_RD_OFFSET:
  4384. case MLXPLAT_CPLD_LPC_REG_LC_RD_EVENT_OFFSET:
  4385. case MLXPLAT_CPLD_LPC_REG_LC_RD_MASK_OFFSET:
  4386. case MLXPLAT_CPLD_LPC_REG_LC_OK_OFFSET:
  4387. case MLXPLAT_CPLD_LPC_REG_LC_OK_EVENT_OFFSET:
  4388. case MLXPLAT_CPLD_LPC_REG_LC_OK_MASK_OFFSET:
  4389. case MLXPLAT_CPLD_LPC_REG_LC_SN_OFFSET:
  4390. case MLXPLAT_CPLD_LPC_REG_LC_SN_EVENT_OFFSET:
  4391. case MLXPLAT_CPLD_LPC_REG_LC_SN_MASK_OFFSET:
  4392. case MLXPLAT_CPLD_LPC_REG_LC_SD_OFFSET:
  4393. case MLXPLAT_CPLD_LPC_REG_LC_SD_EVENT_OFFSET:
  4394. case MLXPLAT_CPLD_LPC_REG_LC_SD_MASK_OFFSET:
  4395. case MLXPLAT_CPLD_LPC_REG_LC_PWR_ON:
  4396. case MLXPLAT_CPLD_LPC_REG_WD2_TMR_OFFSET:
  4397. case MLXPLAT_CPLD_LPC_REG_WD2_TLEFT_OFFSET:
  4398. case MLXPLAT_CPLD_LPC_REG_WD3_TMR_OFFSET:
  4399. case MLXPLAT_CPLD_LPC_REG_WD3_TLEFT_OFFSET:
  4400. case MLXPLAT_CPLD_LPC_REG_CPLD1_MVER_OFFSET:
  4401. case MLXPLAT_CPLD_LPC_REG_CPLD2_MVER_OFFSET:
  4402. case MLXPLAT_CPLD_LPC_REG_CPLD3_MVER_OFFSET:
  4403. case MLXPLAT_CPLD_LPC_REG_CPLD4_MVER_OFFSET:
  4404. case MLXPLAT_CPLD_LPC_REG_PWM1_OFFSET:
  4405. case MLXPLAT_CPLD_LPC_REG_PWM2_OFFSET:
  4406. case MLXPLAT_CPLD_LPC_REG_PWM3_OFFSET:
  4407. case MLXPLAT_CPLD_LPC_REG_PWM4_OFFSET:
  4408. case MLXPLAT_CPLD_LPC_REG_TACHO1_OFFSET:
  4409. case MLXPLAT_CPLD_LPC_REG_TACHO2_OFFSET:
  4410. case MLXPLAT_CPLD_LPC_REG_TACHO3_OFFSET:
  4411. case MLXPLAT_CPLD_LPC_REG_TACHO4_OFFSET:
  4412. case MLXPLAT_CPLD_LPC_REG_TACHO5_OFFSET:
  4413. case MLXPLAT_CPLD_LPC_REG_TACHO6_OFFSET:
  4414. case MLXPLAT_CPLD_LPC_REG_TACHO7_OFFSET:
  4415. case MLXPLAT_CPLD_LPC_REG_TACHO8_OFFSET:
  4416. case MLXPLAT_CPLD_LPC_REG_TACHO9_OFFSET:
  4417. case MLXPLAT_CPLD_LPC_REG_TACHO10_OFFSET:
  4418. case MLXPLAT_CPLD_LPC_REG_TACHO11_OFFSET:
  4419. case MLXPLAT_CPLD_LPC_REG_TACHO12_OFFSET:
  4420. case MLXPLAT_CPLD_LPC_REG_TACHO13_OFFSET:
  4421. case MLXPLAT_CPLD_LPC_REG_TACHO14_OFFSET:
  4422. case MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET:
  4423. case MLXPLAT_CPLD_LPC_REG_FAN_CAP1_OFFSET:
  4424. case MLXPLAT_CPLD_LPC_REG_FAN_CAP2_OFFSET:
  4425. case MLXPLAT_CPLD_LPC_REG_FAN_DRW_CAP_OFFSET:
  4426. case MLXPLAT_CPLD_LPC_REG_TACHO_SPEED_OFFSET:
  4427. case MLXPLAT_CPLD_LPC_REG_PSU_I2C_CAP_OFFSET:
  4428. case MLXPLAT_CPLD_LPC_REG_SLOT_QTY_OFFSET:
  4429. case MLXPLAT_CPLD_LPC_REG_CONFIG1_OFFSET:
  4430. case MLXPLAT_CPLD_LPC_REG_CONFIG2_OFFSET:
  4431. case MLXPLAT_CPLD_LPC_REG_CONFIG3_OFFSET:
  4432. case MLXPLAT_CPLD_LPC_REG_UFM_VERSION_OFFSET:
  4433. return true;
  4434. }
  4435. return false;
  4436. }
  4437. static const struct reg_default mlxplat_mlxcpld_regmap_default[] = {
  4438. { MLXPLAT_CPLD_LPC_REG_WP1_OFFSET, 0x00 },
  4439. { MLXPLAT_CPLD_LPC_REG_WP2_OFFSET, 0x00 },
  4440. { MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET, 0x00 },
  4441. { MLXPLAT_CPLD_LPC_REG_WD_CLEAR_WP_OFFSET, 0x00 },
  4442. };
  4443. static const struct reg_default mlxplat_mlxcpld_regmap_ng[] = {
  4444. { MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET, 0x00 },
  4445. { MLXPLAT_CPLD_LPC_REG_WD_CLEAR_WP_OFFSET, 0x00 },
  4446. };
  4447. static const struct reg_default mlxplat_mlxcpld_regmap_comex_default[] = {
  4448. { MLXPLAT_CPLD_LPC_REG_AGGRCX_MASK_OFFSET,
  4449. MLXPLAT_CPLD_LOW_AGGRCX_MASK },
  4450. { MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET, 0x00 },
  4451. };
  4452. static const struct reg_default mlxplat_mlxcpld_regmap_ng400[] = {
  4453. { MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET, 0x00 },
  4454. { MLXPLAT_CPLD_LPC_REG_WD1_ACT_OFFSET, 0x00 },
  4455. { MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET, 0x00 },
  4456. { MLXPLAT_CPLD_LPC_REG_WD3_ACT_OFFSET, 0x00 },
  4457. };
  4458. static const struct reg_default mlxplat_mlxcpld_regmap_eth_modular[] = {
  4459. { MLXPLAT_CPLD_LPC_REG_GP2_OFFSET, 0x61 },
  4460. { MLXPLAT_CPLD_LPC_REG_PWM_CONTROL_OFFSET, 0x00 },
  4461. { MLXPLAT_CPLD_LPC_REG_PWM2_OFFSET, 0x00 },
  4462. { MLXPLAT_CPLD_LPC_REG_PWM3_OFFSET, 0x00 },
  4463. { MLXPLAT_CPLD_LPC_REG_PWM4_OFFSET, 0x00 },
  4464. { MLXPLAT_CPLD_LPC_REG_WD1_ACT_OFFSET, 0x00 },
  4465. { MLXPLAT_CPLD_LPC_REG_WD2_ACT_OFFSET, 0x00 },
  4466. { MLXPLAT_CPLD_LPC_REG_WD3_ACT_OFFSET, 0x00 },
  4467. { MLXPLAT_CPLD_LPC_REG_AGGRLC_MASK_OFFSET,
  4468. MLXPLAT_CPLD_AGGR_MASK_LC_LOW },
  4469. };
  4470. struct mlxplat_mlxcpld_regmap_context {
  4471. void __iomem *base;
  4472. };
  4473. static struct mlxplat_mlxcpld_regmap_context mlxplat_mlxcpld_regmap_ctx;
  4474. static int
  4475. mlxplat_mlxcpld_reg_read(void *context, unsigned int reg, unsigned int *val)
  4476. {
  4477. struct mlxplat_mlxcpld_regmap_context *ctx = context;
  4478. *val = ioread8(ctx->base + reg);
  4479. return 0;
  4480. }
  4481. static int
  4482. mlxplat_mlxcpld_reg_write(void *context, unsigned int reg, unsigned int val)
  4483. {
  4484. struct mlxplat_mlxcpld_regmap_context *ctx = context;
  4485. iowrite8(val, ctx->base + reg);
  4486. return 0;
  4487. }
  4488. static const struct regmap_config mlxplat_mlxcpld_regmap_config = {
  4489. .reg_bits = 8,
  4490. .val_bits = 8,
  4491. .max_register = 255,
  4492. .cache_type = REGCACHE_FLAT,
  4493. .writeable_reg = mlxplat_mlxcpld_writeable_reg,
  4494. .readable_reg = mlxplat_mlxcpld_readable_reg,
  4495. .volatile_reg = mlxplat_mlxcpld_volatile_reg,
  4496. .reg_defaults = mlxplat_mlxcpld_regmap_default,
  4497. .num_reg_defaults = ARRAY_SIZE(mlxplat_mlxcpld_regmap_default),
  4498. .reg_read = mlxplat_mlxcpld_reg_read,
  4499. .reg_write = mlxplat_mlxcpld_reg_write,
  4500. };
  4501. static const struct regmap_config mlxplat_mlxcpld_regmap_config_ng = {
  4502. .reg_bits = 8,
  4503. .val_bits = 8,
  4504. .max_register = 255,
  4505. .cache_type = REGCACHE_FLAT,
  4506. .writeable_reg = mlxplat_mlxcpld_writeable_reg,
  4507. .readable_reg = mlxplat_mlxcpld_readable_reg,
  4508. .volatile_reg = mlxplat_mlxcpld_volatile_reg,
  4509. .reg_defaults = mlxplat_mlxcpld_regmap_ng,
  4510. .num_reg_defaults = ARRAY_SIZE(mlxplat_mlxcpld_regmap_ng),
  4511. .reg_read = mlxplat_mlxcpld_reg_read,
  4512. .reg_write = mlxplat_mlxcpld_reg_write,
  4513. };
  4514. static const struct regmap_config mlxplat_mlxcpld_regmap_config_comex = {
  4515. .reg_bits = 8,
  4516. .val_bits = 8,
  4517. .max_register = 255,
  4518. .cache_type = REGCACHE_FLAT,
  4519. .writeable_reg = mlxplat_mlxcpld_writeable_reg,
  4520. .readable_reg = mlxplat_mlxcpld_readable_reg,
  4521. .volatile_reg = mlxplat_mlxcpld_volatile_reg,
  4522. .reg_defaults = mlxplat_mlxcpld_regmap_comex_default,
  4523. .num_reg_defaults = ARRAY_SIZE(mlxplat_mlxcpld_regmap_comex_default),
  4524. .reg_read = mlxplat_mlxcpld_reg_read,
  4525. .reg_write = mlxplat_mlxcpld_reg_write,
  4526. };
  4527. static const struct regmap_config mlxplat_mlxcpld_regmap_config_ng400 = {
  4528. .reg_bits = 8,
  4529. .val_bits = 8,
  4530. .max_register = 255,
  4531. .cache_type = REGCACHE_FLAT,
  4532. .writeable_reg = mlxplat_mlxcpld_writeable_reg,
  4533. .readable_reg = mlxplat_mlxcpld_readable_reg,
  4534. .volatile_reg = mlxplat_mlxcpld_volatile_reg,
  4535. .reg_defaults = mlxplat_mlxcpld_regmap_ng400,
  4536. .num_reg_defaults = ARRAY_SIZE(mlxplat_mlxcpld_regmap_ng400),
  4537. .reg_read = mlxplat_mlxcpld_reg_read,
  4538. .reg_write = mlxplat_mlxcpld_reg_write,
  4539. };
  4540. static const struct regmap_config mlxplat_mlxcpld_regmap_config_eth_modular = {
  4541. .reg_bits = 8,
  4542. .val_bits = 8,
  4543. .max_register = 255,
  4544. .cache_type = REGCACHE_FLAT,
  4545. .writeable_reg = mlxplat_mlxcpld_writeable_reg,
  4546. .readable_reg = mlxplat_mlxcpld_readable_reg,
  4547. .volatile_reg = mlxplat_mlxcpld_volatile_reg,
  4548. .reg_defaults = mlxplat_mlxcpld_regmap_eth_modular,
  4549. .num_reg_defaults = ARRAY_SIZE(mlxplat_mlxcpld_regmap_eth_modular),
  4550. .reg_read = mlxplat_mlxcpld_reg_read,
  4551. .reg_write = mlxplat_mlxcpld_reg_write,
  4552. };
  4553. static struct resource mlxplat_mlxcpld_resources[] = {
  4554. [0] = DEFINE_RES_IRQ_NAMED(MLXPLAT_CPLD_LPC_SYSIRQ, "mlxreg-hotplug"),
  4555. };
  4556. static struct platform_device *mlxplat_dev;
  4557. static struct mlxreg_core_hotplug_platform_data *mlxplat_i2c;
  4558. static struct mlxreg_core_hotplug_platform_data *mlxplat_hotplug;
  4559. static struct mlxreg_core_platform_data *mlxplat_led;
  4560. static struct mlxreg_core_platform_data *mlxplat_regs_io;
  4561. static struct mlxreg_core_platform_data *mlxplat_fan;
  4562. static struct mlxreg_core_platform_data
  4563. *mlxplat_wd_data[MLXPLAT_CPLD_WD_MAX_DEVS];
  4564. static const struct regmap_config *mlxplat_regmap_config;
  4565. static int __init mlxplat_dmi_default_matched(const struct dmi_system_id *dmi)
  4566. {
  4567. int i;
  4568. mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM;
  4569. mlxplat_mux_num = ARRAY_SIZE(mlxplat_default_mux_data);
  4570. mlxplat_mux_data = mlxplat_default_mux_data;
  4571. for (i = 0; i < mlxplat_mux_num; i++) {
  4572. mlxplat_mux_data[i].values = mlxplat_default_channels[i];
  4573. mlxplat_mux_data[i].n_values =
  4574. ARRAY_SIZE(mlxplat_default_channels[i]);
  4575. }
  4576. mlxplat_hotplug = &mlxplat_mlxcpld_default_data;
  4577. mlxplat_hotplug->deferred_nr =
  4578. mlxplat_default_channels[i - 1][MLXPLAT_CPLD_GRP_CHNL_NUM - 1];
  4579. mlxplat_led = &mlxplat_default_led_data;
  4580. mlxplat_regs_io = &mlxplat_default_regs_io_data;
  4581. mlxplat_wd_data[0] = &mlxplat_mlxcpld_wd_set_type1[0];
  4582. return 1;
  4583. }
  4584. static int __init mlxplat_dmi_default_wc_matched(const struct dmi_system_id *dmi)
  4585. {
  4586. int i;
  4587. mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM;
  4588. mlxplat_mux_num = ARRAY_SIZE(mlxplat_default_mux_data);
  4589. mlxplat_mux_data = mlxplat_default_mux_data;
  4590. for (i = 0; i < mlxplat_mux_num; i++) {
  4591. mlxplat_mux_data[i].values = mlxplat_default_channels[i];
  4592. mlxplat_mux_data[i].n_values =
  4593. ARRAY_SIZE(mlxplat_default_channels[i]);
  4594. }
  4595. mlxplat_hotplug = &mlxplat_mlxcpld_default_wc_data;
  4596. mlxplat_hotplug->deferred_nr =
  4597. mlxplat_default_channels[i - 1][MLXPLAT_CPLD_GRP_CHNL_NUM - 1];
  4598. mlxplat_led = &mlxplat_default_led_wc_data;
  4599. mlxplat_regs_io = &mlxplat_default_regs_io_data;
  4600. mlxplat_wd_data[0] = &mlxplat_mlxcpld_wd_set_type1[0];
  4601. return 1;
  4602. }
  4603. static int __init mlxplat_dmi_default_eth_wc_blade_matched(const struct dmi_system_id *dmi)
  4604. {
  4605. int i;
  4606. mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM;
  4607. mlxplat_mux_num = ARRAY_SIZE(mlxplat_default_mux_data);
  4608. mlxplat_mux_data = mlxplat_default_mux_data;
  4609. for (i = 0; i < mlxplat_mux_num; i++) {
  4610. mlxplat_mux_data[i].values = mlxplat_msn21xx_channels;
  4611. mlxplat_mux_data[i].n_values =
  4612. ARRAY_SIZE(mlxplat_msn21xx_channels);
  4613. }
  4614. mlxplat_hotplug = &mlxplat_mlxcpld_default_wc_data;
  4615. mlxplat_hotplug->deferred_nr =
  4616. mlxplat_msn21xx_channels[MLXPLAT_CPLD_GRP_CHNL_NUM - 1];
  4617. mlxplat_led = &mlxplat_default_led_eth_wc_blade_data;
  4618. mlxplat_regs_io = &mlxplat_default_ng_regs_io_data;
  4619. for (i = 0; i < ARRAY_SIZE(mlxplat_mlxcpld_wd_set_type2); i++)
  4620. mlxplat_wd_data[i] = &mlxplat_mlxcpld_wd_set_type2[i];
  4621. mlxplat_i2c = &mlxplat_mlxcpld_i2c_ng_data;
  4622. mlxplat_regmap_config = &mlxplat_mlxcpld_regmap_config_ng;
  4623. return 1;
  4624. }
  4625. static int __init mlxplat_dmi_msn21xx_matched(const struct dmi_system_id *dmi)
  4626. {
  4627. int i;
  4628. mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM;
  4629. mlxplat_mux_num = ARRAY_SIZE(mlxplat_default_mux_data);
  4630. mlxplat_mux_data = mlxplat_default_mux_data;
  4631. for (i = 0; i < mlxplat_mux_num; i++) {
  4632. mlxplat_mux_data[i].values = mlxplat_msn21xx_channels;
  4633. mlxplat_mux_data[i].n_values =
  4634. ARRAY_SIZE(mlxplat_msn21xx_channels);
  4635. }
  4636. mlxplat_hotplug = &mlxplat_mlxcpld_msn21xx_data;
  4637. mlxplat_hotplug->deferred_nr =
  4638. mlxplat_msn21xx_channels[MLXPLAT_CPLD_GRP_CHNL_NUM - 1];
  4639. mlxplat_led = &mlxplat_msn21xx_led_data;
  4640. mlxplat_regs_io = &mlxplat_msn21xx_regs_io_data;
  4641. mlxplat_wd_data[0] = &mlxplat_mlxcpld_wd_set_type1[0];
  4642. return 1;
  4643. }
  4644. static int __init mlxplat_dmi_msn274x_matched(const struct dmi_system_id *dmi)
  4645. {
  4646. int i;
  4647. mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM;
  4648. mlxplat_mux_num = ARRAY_SIZE(mlxplat_default_mux_data);
  4649. mlxplat_mux_data = mlxplat_default_mux_data;
  4650. for (i = 0; i < mlxplat_mux_num; i++) {
  4651. mlxplat_mux_data[i].values = mlxplat_msn21xx_channels;
  4652. mlxplat_mux_data[i].n_values =
  4653. ARRAY_SIZE(mlxplat_msn21xx_channels);
  4654. }
  4655. mlxplat_hotplug = &mlxplat_mlxcpld_msn274x_data;
  4656. mlxplat_hotplug->deferred_nr =
  4657. mlxplat_msn21xx_channels[MLXPLAT_CPLD_GRP_CHNL_NUM - 1];
  4658. mlxplat_led = &mlxplat_default_led_data;
  4659. mlxplat_regs_io = &mlxplat_msn21xx_regs_io_data;
  4660. mlxplat_wd_data[0] = &mlxplat_mlxcpld_wd_set_type1[0];
  4661. return 1;
  4662. }
  4663. static int __init mlxplat_dmi_msn201x_matched(const struct dmi_system_id *dmi)
  4664. {
  4665. int i;
  4666. mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM;
  4667. mlxplat_mux_num = ARRAY_SIZE(mlxplat_default_mux_data);
  4668. mlxplat_mux_data = mlxplat_default_mux_data;
  4669. for (i = 0; i < mlxplat_mux_num; i++) {
  4670. mlxplat_mux_data[i].values = mlxplat_msn21xx_channels;
  4671. mlxplat_mux_data[i].n_values =
  4672. ARRAY_SIZE(mlxplat_msn21xx_channels);
  4673. }
  4674. mlxplat_hotplug = &mlxplat_mlxcpld_msn201x_data;
  4675. mlxplat_hotplug->deferred_nr =
  4676. mlxplat_default_channels[i - 1][MLXPLAT_CPLD_GRP_CHNL_NUM - 1];
  4677. mlxplat_led = &mlxplat_msn21xx_led_data;
  4678. mlxplat_regs_io = &mlxplat_msn21xx_regs_io_data;
  4679. mlxplat_wd_data[0] = &mlxplat_mlxcpld_wd_set_type1[0];
  4680. return 1;
  4681. }
  4682. static int __init mlxplat_dmi_qmb7xx_matched(const struct dmi_system_id *dmi)
  4683. {
  4684. int i;
  4685. mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM;
  4686. mlxplat_mux_num = ARRAY_SIZE(mlxplat_default_mux_data);
  4687. mlxplat_mux_data = mlxplat_default_mux_data;
  4688. for (i = 0; i < mlxplat_mux_num; i++) {
  4689. mlxplat_mux_data[i].values = mlxplat_msn21xx_channels;
  4690. mlxplat_mux_data[i].n_values =
  4691. ARRAY_SIZE(mlxplat_msn21xx_channels);
  4692. }
  4693. mlxplat_hotplug = &mlxplat_mlxcpld_default_ng_data;
  4694. mlxplat_hotplug->deferred_nr =
  4695. mlxplat_msn21xx_channels[MLXPLAT_CPLD_GRP_CHNL_NUM - 1];
  4696. mlxplat_led = &mlxplat_default_ng_led_data;
  4697. mlxplat_regs_io = &mlxplat_default_ng_regs_io_data;
  4698. mlxplat_fan = &mlxplat_default_fan_data;
  4699. for (i = 0; i < ARRAY_SIZE(mlxplat_mlxcpld_wd_set_type2); i++)
  4700. mlxplat_wd_data[i] = &mlxplat_mlxcpld_wd_set_type2[i];
  4701. mlxplat_i2c = &mlxplat_mlxcpld_i2c_ng_data;
  4702. mlxplat_regmap_config = &mlxplat_mlxcpld_regmap_config_ng;
  4703. return 1;
  4704. }
  4705. static int __init mlxplat_dmi_comex_matched(const struct dmi_system_id *dmi)
  4706. {
  4707. int i;
  4708. mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_EXT_ADAPTER_NUM;
  4709. mlxplat_mux_num = ARRAY_SIZE(mlxplat_extended_mux_data);
  4710. mlxplat_mux_data = mlxplat_extended_mux_data;
  4711. for (i = 0; i < mlxplat_mux_num; i++) {
  4712. mlxplat_mux_data[i].values = mlxplat_msn21xx_channels;
  4713. mlxplat_mux_data[i].n_values =
  4714. ARRAY_SIZE(mlxplat_msn21xx_channels);
  4715. }
  4716. mlxplat_hotplug = &mlxplat_mlxcpld_comex_data;
  4717. mlxplat_hotplug->deferred_nr = MLXPLAT_CPLD_MAX_PHYS_EXT_ADAPTER_NUM;
  4718. mlxplat_led = &mlxplat_comex_100G_led_data;
  4719. mlxplat_regs_io = &mlxplat_default_ng_regs_io_data;
  4720. mlxplat_fan = &mlxplat_default_fan_data;
  4721. for (i = 0; i < ARRAY_SIZE(mlxplat_mlxcpld_wd_set_type2); i++)
  4722. mlxplat_wd_data[i] = &mlxplat_mlxcpld_wd_set_type2[i];
  4723. mlxplat_regmap_config = &mlxplat_mlxcpld_regmap_config_comex;
  4724. return 1;
  4725. }
  4726. static int __init mlxplat_dmi_ng400_matched(const struct dmi_system_id *dmi)
  4727. {
  4728. int i;
  4729. mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM;
  4730. mlxplat_mux_num = ARRAY_SIZE(mlxplat_default_mux_data);
  4731. mlxplat_mux_data = mlxplat_default_mux_data;
  4732. for (i = 0; i < mlxplat_mux_num; i++) {
  4733. mlxplat_mux_data[i].values = mlxplat_msn21xx_channels;
  4734. mlxplat_mux_data[i].n_values =
  4735. ARRAY_SIZE(mlxplat_msn21xx_channels);
  4736. }
  4737. mlxplat_hotplug = &mlxplat_mlxcpld_ext_data;
  4738. mlxplat_hotplug->deferred_nr =
  4739. mlxplat_msn21xx_channels[MLXPLAT_CPLD_GRP_CHNL_NUM - 1];
  4740. mlxplat_led = &mlxplat_default_ng_led_data;
  4741. mlxplat_regs_io = &mlxplat_default_ng_regs_io_data;
  4742. mlxplat_fan = &mlxplat_default_fan_data;
  4743. for (i = 0; i < ARRAY_SIZE(mlxplat_mlxcpld_wd_set_type2); i++)
  4744. mlxplat_wd_data[i] = &mlxplat_mlxcpld_wd_set_type2[i];
  4745. mlxplat_i2c = &mlxplat_mlxcpld_i2c_ng_data;
  4746. mlxplat_regmap_config = &mlxplat_mlxcpld_regmap_config_ng400;
  4747. return 1;
  4748. }
  4749. static int __init mlxplat_dmi_modular_matched(const struct dmi_system_id *dmi)
  4750. {
  4751. int i;
  4752. mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM;
  4753. mlxplat_mux_num = ARRAY_SIZE(mlxplat_modular_mux_data);
  4754. mlxplat_mux_data = mlxplat_modular_mux_data;
  4755. mlxplat_hotplug = &mlxplat_mlxcpld_modular_data;
  4756. mlxplat_hotplug->deferred_nr = MLXPLAT_CPLD_CH4_ETH_MODULAR;
  4757. mlxplat_led = &mlxplat_modular_led_data;
  4758. mlxplat_regs_io = &mlxplat_modular_regs_io_data;
  4759. mlxplat_fan = &mlxplat_default_fan_data;
  4760. for (i = 0; i < ARRAY_SIZE(mlxplat_mlxcpld_wd_set_type2); i++)
  4761. mlxplat_wd_data[i] = &mlxplat_mlxcpld_wd_set_type2[i];
  4762. mlxplat_i2c = &mlxplat_mlxcpld_i2c_ng_data;
  4763. mlxplat_regmap_config = &mlxplat_mlxcpld_regmap_config_eth_modular;
  4764. return 1;
  4765. }
  4766. static int __init mlxplat_dmi_nvlink_blade_matched(const struct dmi_system_id *dmi)
  4767. {
  4768. int i;
  4769. mlxplat_max_adap_num = MLXPLAT_CPLD_MAX_PHYS_ADAPTER_NUM;
  4770. mlxplat_mux_num = ARRAY_SIZE(mlxplat_default_mux_data);
  4771. mlxplat_mux_data = mlxplat_default_mux_data;
  4772. mlxplat_hotplug = &mlxplat_mlxcpld_nvlink_blade_data;
  4773. mlxplat_hotplug->deferred_nr =
  4774. mlxplat_msn21xx_channels[MLXPLAT_CPLD_GRP_CHNL_NUM - 1];
  4775. for (i = 0; i < mlxplat_mux_num; i++) {
  4776. mlxplat_mux_data[i].values = mlxplat_msn21xx_channels;
  4777. mlxplat_mux_data[i].n_values =
  4778. ARRAY_SIZE(mlxplat_msn21xx_channels);
  4779. }
  4780. mlxplat_regs_io = &mlxplat_nvlink_blade_regs_io_data;
  4781. mlxplat_i2c = &mlxplat_mlxcpld_i2c_ng_data;
  4782. mlxplat_regmap_config = &mlxplat_mlxcpld_regmap_config_ng400;
  4783. return 1;
  4784. }
  4785. static const struct dmi_system_id mlxplat_dmi_table[] __initconst = {
  4786. {
  4787. .callback = mlxplat_dmi_default_wc_matched,
  4788. .matches = {
  4789. DMI_MATCH(DMI_BOARD_NAME, "VMOD0001"),
  4790. DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "HI138"),
  4791. },
  4792. },
  4793. {
  4794. .callback = mlxplat_dmi_default_matched,
  4795. .matches = {
  4796. DMI_MATCH(DMI_BOARD_NAME, "VMOD0001"),
  4797. },
  4798. },
  4799. {
  4800. .callback = mlxplat_dmi_msn21xx_matched,
  4801. .matches = {
  4802. DMI_MATCH(DMI_BOARD_NAME, "VMOD0002"),
  4803. },
  4804. },
  4805. {
  4806. .callback = mlxplat_dmi_msn274x_matched,
  4807. .matches = {
  4808. DMI_MATCH(DMI_BOARD_NAME, "VMOD0003"),
  4809. },
  4810. },
  4811. {
  4812. .callback = mlxplat_dmi_msn201x_matched,
  4813. .matches = {
  4814. DMI_MATCH(DMI_BOARD_NAME, "VMOD0004"),
  4815. },
  4816. },
  4817. {
  4818. .callback = mlxplat_dmi_default_eth_wc_blade_matched,
  4819. .matches = {
  4820. DMI_MATCH(DMI_BOARD_NAME, "VMOD0005"),
  4821. DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "HI139"),
  4822. },
  4823. },
  4824. {
  4825. .callback = mlxplat_dmi_qmb7xx_matched,
  4826. .matches = {
  4827. DMI_MATCH(DMI_BOARD_NAME, "VMOD0005"),
  4828. },
  4829. },
  4830. {
  4831. .callback = mlxplat_dmi_qmb7xx_matched,
  4832. .matches = {
  4833. DMI_MATCH(DMI_BOARD_NAME, "VMOD0007"),
  4834. },
  4835. },
  4836. {
  4837. .callback = mlxplat_dmi_comex_matched,
  4838. .matches = {
  4839. DMI_MATCH(DMI_BOARD_NAME, "VMOD0009"),
  4840. },
  4841. },
  4842. {
  4843. .callback = mlxplat_dmi_ng400_matched,
  4844. .matches = {
  4845. DMI_MATCH(DMI_BOARD_NAME, "VMOD0010"),
  4846. },
  4847. },
  4848. {
  4849. .callback = mlxplat_dmi_modular_matched,
  4850. .matches = {
  4851. DMI_MATCH(DMI_BOARD_NAME, "VMOD0011"),
  4852. },
  4853. },
  4854. {
  4855. .callback = mlxplat_dmi_nvlink_blade_matched,
  4856. .matches = {
  4857. DMI_MATCH(DMI_BOARD_NAME, "VMOD0015"),
  4858. },
  4859. },
  4860. {
  4861. .callback = mlxplat_dmi_msn274x_matched,
  4862. .matches = {
  4863. DMI_MATCH(DMI_BOARD_VENDOR, "Mellanox Technologies"),
  4864. DMI_MATCH(DMI_PRODUCT_NAME, "MSN274"),
  4865. },
  4866. },
  4867. {
  4868. .callback = mlxplat_dmi_default_matched,
  4869. .matches = {
  4870. DMI_MATCH(DMI_BOARD_VENDOR, "Mellanox Technologies"),
  4871. DMI_MATCH(DMI_PRODUCT_NAME, "MSN24"),
  4872. },
  4873. },
  4874. {
  4875. .callback = mlxplat_dmi_default_matched,
  4876. .matches = {
  4877. DMI_MATCH(DMI_BOARD_VENDOR, "Mellanox Technologies"),
  4878. DMI_MATCH(DMI_PRODUCT_NAME, "MSN27"),
  4879. },
  4880. },
  4881. {
  4882. .callback = mlxplat_dmi_default_matched,
  4883. .matches = {
  4884. DMI_MATCH(DMI_BOARD_VENDOR, "Mellanox Technologies"),
  4885. DMI_MATCH(DMI_PRODUCT_NAME, "MSB"),
  4886. },
  4887. },
  4888. {
  4889. .callback = mlxplat_dmi_default_matched,
  4890. .matches = {
  4891. DMI_MATCH(DMI_BOARD_VENDOR, "Mellanox Technologies"),
  4892. DMI_MATCH(DMI_PRODUCT_NAME, "MSX"),
  4893. },
  4894. },
  4895. {
  4896. .callback = mlxplat_dmi_msn21xx_matched,
  4897. .matches = {
  4898. DMI_MATCH(DMI_BOARD_VENDOR, "Mellanox Technologies"),
  4899. DMI_MATCH(DMI_PRODUCT_NAME, "MSN21"),
  4900. },
  4901. },
  4902. {
  4903. .callback = mlxplat_dmi_msn201x_matched,
  4904. .matches = {
  4905. DMI_MATCH(DMI_BOARD_VENDOR, "Mellanox Technologies"),
  4906. DMI_MATCH(DMI_PRODUCT_NAME, "MSN201"),
  4907. },
  4908. },
  4909. {
  4910. .callback = mlxplat_dmi_qmb7xx_matched,
  4911. .matches = {
  4912. DMI_MATCH(DMI_BOARD_VENDOR, "Mellanox Technologies"),
  4913. DMI_MATCH(DMI_PRODUCT_NAME, "MQM87"),
  4914. },
  4915. },
  4916. {
  4917. .callback = mlxplat_dmi_qmb7xx_matched,
  4918. .matches = {
  4919. DMI_MATCH(DMI_BOARD_VENDOR, "Mellanox Technologies"),
  4920. DMI_MATCH(DMI_PRODUCT_NAME, "MSN37"),
  4921. },
  4922. },
  4923. {
  4924. .callback = mlxplat_dmi_qmb7xx_matched,
  4925. .matches = {
  4926. DMI_MATCH(DMI_BOARD_VENDOR, "Mellanox Technologies"),
  4927. DMI_MATCH(DMI_PRODUCT_NAME, "MSN34"),
  4928. },
  4929. },
  4930. {
  4931. .callback = mlxplat_dmi_qmb7xx_matched,
  4932. .matches = {
  4933. DMI_MATCH(DMI_BOARD_VENDOR, "Mellanox Technologies"),
  4934. DMI_MATCH(DMI_PRODUCT_NAME, "MSN38"),
  4935. },
  4936. },
  4937. { }
  4938. };
  4939. MODULE_DEVICE_TABLE(dmi, mlxplat_dmi_table);
  4940. static int mlxplat_mlxcpld_verify_bus_topology(int *nr)
  4941. {
  4942. struct i2c_adapter *search_adap;
  4943. int shift, i;
  4944. /* Scan adapters from expected id to verify it is free. */
  4945. *nr = MLXPLAT_CPLD_PHYS_ADAPTER_DEF_NR;
  4946. for (i = MLXPLAT_CPLD_PHYS_ADAPTER_DEF_NR; i <
  4947. mlxplat_max_adap_num; i++) {
  4948. search_adap = i2c_get_adapter(i);
  4949. if (search_adap) {
  4950. i2c_put_adapter(search_adap);
  4951. continue;
  4952. }
  4953. /* Return if expected parent adapter is free. */
  4954. if (i == MLXPLAT_CPLD_PHYS_ADAPTER_DEF_NR)
  4955. return 0;
  4956. break;
  4957. }
  4958. /* Return with error if free id for adapter is not found. */
  4959. if (i == mlxplat_max_adap_num)
  4960. return -ENODEV;
  4961. /* Shift adapter ids, since expected parent adapter is not free. */
  4962. *nr = i;
  4963. for (i = 0; i < mlxplat_mux_num; i++) {
  4964. shift = *nr - mlxplat_mux_data[i].parent;
  4965. mlxplat_mux_data[i].parent = *nr;
  4966. mlxplat_mux_data[i].base_nr += shift;
  4967. if (shift > 0)
  4968. mlxplat_hotplug->shift_nr = shift;
  4969. }
  4970. return 0;
  4971. }
  4972. static int mlxplat_mlxcpld_check_wd_capability(void *regmap)
  4973. {
  4974. u32 regval;
  4975. int i, rc;
  4976. rc = regmap_read(regmap, MLXPLAT_CPLD_LPC_REG_PSU_I2C_CAP_OFFSET,
  4977. &regval);
  4978. if (rc)
  4979. return rc;
  4980. if (!(regval & ~MLXPLAT_CPLD_WD_CPBLTY_MASK)) {
  4981. for (i = 0; i < ARRAY_SIZE(mlxplat_mlxcpld_wd_set_type3); i++) {
  4982. if (mlxplat_wd_data[i])
  4983. mlxplat_wd_data[i] =
  4984. &mlxplat_mlxcpld_wd_set_type3[i];
  4985. }
  4986. }
  4987. return 0;
  4988. }
  4989. static int __init mlxplat_init(void)
  4990. {
  4991. struct mlxplat_priv *priv;
  4992. int i, j, nr, err;
  4993. if (!dmi_check_system(mlxplat_dmi_table))
  4994. return -ENODEV;
  4995. mlxplat_dev = platform_device_register_simple(MLX_PLAT_DEVICE_NAME, PLATFORM_DEVID_NONE,
  4996. mlxplat_lpc_resources,
  4997. ARRAY_SIZE(mlxplat_lpc_resources));
  4998. if (IS_ERR(mlxplat_dev))
  4999. return PTR_ERR(mlxplat_dev);
  5000. priv = devm_kzalloc(&mlxplat_dev->dev, sizeof(struct mlxplat_priv),
  5001. GFP_KERNEL);
  5002. if (!priv) {
  5003. err = -ENOMEM;
  5004. goto fail_alloc;
  5005. }
  5006. platform_set_drvdata(mlxplat_dev, priv);
  5007. mlxplat_mlxcpld_regmap_ctx.base = devm_ioport_map(&mlxplat_dev->dev,
  5008. mlxplat_lpc_resources[1].start, 1);
  5009. if (!mlxplat_mlxcpld_regmap_ctx.base) {
  5010. err = -ENOMEM;
  5011. goto fail_alloc;
  5012. }
  5013. if (!mlxplat_regmap_config)
  5014. mlxplat_regmap_config = &mlxplat_mlxcpld_regmap_config;
  5015. priv->regmap = devm_regmap_init(&mlxplat_dev->dev, NULL,
  5016. &mlxplat_mlxcpld_regmap_ctx,
  5017. mlxplat_regmap_config);
  5018. if (IS_ERR(priv->regmap)) {
  5019. err = PTR_ERR(priv->regmap);
  5020. goto fail_alloc;
  5021. }
  5022. err = mlxplat_mlxcpld_verify_bus_topology(&nr);
  5023. if (nr < 0)
  5024. goto fail_alloc;
  5025. nr = (nr == mlxplat_max_adap_num) ? -1 : nr;
  5026. if (mlxplat_i2c)
  5027. mlxplat_i2c->regmap = priv->regmap;
  5028. priv->pdev_i2c = platform_device_register_resndata(&mlxplat_dev->dev, "i2c_mlxcpld",
  5029. nr, mlxplat_mlxcpld_resources,
  5030. ARRAY_SIZE(mlxplat_mlxcpld_resources),
  5031. mlxplat_i2c, sizeof(*mlxplat_i2c));
  5032. if (IS_ERR(priv->pdev_i2c)) {
  5033. err = PTR_ERR(priv->pdev_i2c);
  5034. goto fail_alloc;
  5035. }
  5036. for (i = 0; i < mlxplat_mux_num; i++) {
  5037. priv->pdev_mux[i] = platform_device_register_resndata(&priv->pdev_i2c->dev,
  5038. "i2c-mux-reg", i, NULL, 0,
  5039. &mlxplat_mux_data[i],
  5040. sizeof(mlxplat_mux_data[i]));
  5041. if (IS_ERR(priv->pdev_mux[i])) {
  5042. err = PTR_ERR(priv->pdev_mux[i]);
  5043. goto fail_platform_mux_register;
  5044. }
  5045. }
  5046. /* Add hotplug driver */
  5047. if (mlxplat_hotplug) {
  5048. mlxplat_hotplug->regmap = priv->regmap;
  5049. priv->pdev_hotplug =
  5050. platform_device_register_resndata(&mlxplat_dev->dev,
  5051. "mlxreg-hotplug", PLATFORM_DEVID_NONE,
  5052. mlxplat_mlxcpld_resources,
  5053. ARRAY_SIZE(mlxplat_mlxcpld_resources),
  5054. mlxplat_hotplug, sizeof(*mlxplat_hotplug));
  5055. if (IS_ERR(priv->pdev_hotplug)) {
  5056. err = PTR_ERR(priv->pdev_hotplug);
  5057. goto fail_platform_mux_register;
  5058. }
  5059. }
  5060. /* Set default registers. */
  5061. for (j = 0; j < mlxplat_regmap_config->num_reg_defaults; j++) {
  5062. err = regmap_write(priv->regmap,
  5063. mlxplat_regmap_config->reg_defaults[j].reg,
  5064. mlxplat_regmap_config->reg_defaults[j].def);
  5065. if (err)
  5066. goto fail_platform_mux_register;
  5067. }
  5068. /* Add LED driver. */
  5069. if (mlxplat_led) {
  5070. mlxplat_led->regmap = priv->regmap;
  5071. priv->pdev_led =
  5072. platform_device_register_resndata(&mlxplat_dev->dev, "leds-mlxreg",
  5073. PLATFORM_DEVID_NONE, NULL, 0, mlxplat_led,
  5074. sizeof(*mlxplat_led));
  5075. if (IS_ERR(priv->pdev_led)) {
  5076. err = PTR_ERR(priv->pdev_led);
  5077. goto fail_platform_hotplug_register;
  5078. }
  5079. }
  5080. /* Add registers io access driver. */
  5081. if (mlxplat_regs_io) {
  5082. mlxplat_regs_io->regmap = priv->regmap;
  5083. priv->pdev_io_regs = platform_device_register_resndata(&mlxplat_dev->dev,
  5084. "mlxreg-io",
  5085. PLATFORM_DEVID_NONE, NULL,
  5086. 0, mlxplat_regs_io,
  5087. sizeof(*mlxplat_regs_io));
  5088. if (IS_ERR(priv->pdev_io_regs)) {
  5089. err = PTR_ERR(priv->pdev_io_regs);
  5090. goto fail_platform_led_register;
  5091. }
  5092. }
  5093. /* Add FAN driver. */
  5094. if (mlxplat_fan) {
  5095. mlxplat_fan->regmap = priv->regmap;
  5096. priv->pdev_fan = platform_device_register_resndata(&mlxplat_dev->dev, "mlxreg-fan",
  5097. PLATFORM_DEVID_NONE, NULL, 0,
  5098. mlxplat_fan,
  5099. sizeof(*mlxplat_fan));
  5100. if (IS_ERR(priv->pdev_fan)) {
  5101. err = PTR_ERR(priv->pdev_fan);
  5102. goto fail_platform_io_regs_register;
  5103. }
  5104. }
  5105. /* Add WD drivers. */
  5106. err = mlxplat_mlxcpld_check_wd_capability(priv->regmap);
  5107. if (err)
  5108. goto fail_platform_wd_register;
  5109. for (j = 0; j < MLXPLAT_CPLD_WD_MAX_DEVS; j++) {
  5110. if (mlxplat_wd_data[j]) {
  5111. mlxplat_wd_data[j]->regmap = priv->regmap;
  5112. priv->pdev_wd[j] =
  5113. platform_device_register_resndata(&mlxplat_dev->dev, "mlx-wdt", j,
  5114. NULL, 0, mlxplat_wd_data[j],
  5115. sizeof(*mlxplat_wd_data[j]));
  5116. if (IS_ERR(priv->pdev_wd[j])) {
  5117. err = PTR_ERR(priv->pdev_wd[j]);
  5118. goto fail_platform_wd_register;
  5119. }
  5120. }
  5121. }
  5122. /* Sync registers with hardware. */
  5123. regcache_mark_dirty(priv->regmap);
  5124. err = regcache_sync(priv->regmap);
  5125. if (err)
  5126. goto fail_platform_wd_register;
  5127. return 0;
  5128. fail_platform_wd_register:
  5129. while (--j >= 0)
  5130. platform_device_unregister(priv->pdev_wd[j]);
  5131. if (mlxplat_fan)
  5132. platform_device_unregister(priv->pdev_fan);
  5133. fail_platform_io_regs_register:
  5134. if (mlxplat_regs_io)
  5135. platform_device_unregister(priv->pdev_io_regs);
  5136. fail_platform_led_register:
  5137. if (mlxplat_led)
  5138. platform_device_unregister(priv->pdev_led);
  5139. fail_platform_hotplug_register:
  5140. if (mlxplat_hotplug)
  5141. platform_device_unregister(priv->pdev_hotplug);
  5142. fail_platform_mux_register:
  5143. while (--i >= 0)
  5144. platform_device_unregister(priv->pdev_mux[i]);
  5145. platform_device_unregister(priv->pdev_i2c);
  5146. fail_alloc:
  5147. platform_device_unregister(mlxplat_dev);
  5148. return err;
  5149. }
  5150. module_init(mlxplat_init);
  5151. static void __exit mlxplat_exit(void)
  5152. {
  5153. struct mlxplat_priv *priv = platform_get_drvdata(mlxplat_dev);
  5154. int i;
  5155. for (i = MLXPLAT_CPLD_WD_MAX_DEVS - 1; i >= 0 ; i--)
  5156. platform_device_unregister(priv->pdev_wd[i]);
  5157. if (priv->pdev_fan)
  5158. platform_device_unregister(priv->pdev_fan);
  5159. if (priv->pdev_io_regs)
  5160. platform_device_unregister(priv->pdev_io_regs);
  5161. if (priv->pdev_led)
  5162. platform_device_unregister(priv->pdev_led);
  5163. if (priv->pdev_hotplug)
  5164. platform_device_unregister(priv->pdev_hotplug);
  5165. for (i = mlxplat_mux_num - 1; i >= 0 ; i--)
  5166. platform_device_unregister(priv->pdev_mux[i]);
  5167. platform_device_unregister(priv->pdev_i2c);
  5168. platform_device_unregister(mlxplat_dev);
  5169. }
  5170. module_exit(mlxplat_exit);
  5171. MODULE_AUTHOR("Vadim Pasternak ([email protected])");
  5172. MODULE_DESCRIPTION("Mellanox platform driver");
  5173. MODULE_LICENSE("Dual BSD/GPL");