1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467 |
- // SPDX-License-Identifier: GPL-2.0+
- /*
- * Amlogic Meson-G12A Clock Controller Driver
- *
- * Copyright (c) 2016 Baylibre SAS.
- * Author: Michael Turquette <[email protected]>
- *
- * Copyright (c) 2018 Amlogic, inc.
- * Author: Qiufang Dai <[email protected]>
- * Author: Jian Hu <[email protected]>
- */
- #include <linux/clk-provider.h>
- #include <linux/init.h>
- #include <linux/of_device.h>
- #include <linux/platform_device.h>
- #include <linux/clk.h>
- #include <linux/module.h>
- #include "clk-mpll.h"
- #include "clk-pll.h"
- #include "clk-regmap.h"
- #include "clk-cpu-dyndiv.h"
- #include "vid-pll-div.h"
- #include "meson-eeclk.h"
- #include "g12a.h"
- static DEFINE_SPINLOCK(meson_clk_lock);
- static struct clk_regmap g12a_fixed_pll_dco = {
- .data = &(struct meson_clk_pll_data){
- .en = {
- .reg_off = HHI_FIX_PLL_CNTL0,
- .shift = 28,
- .width = 1,
- },
- .m = {
- .reg_off = HHI_FIX_PLL_CNTL0,
- .shift = 0,
- .width = 8,
- },
- .n = {
- .reg_off = HHI_FIX_PLL_CNTL0,
- .shift = 10,
- .width = 5,
- },
- .frac = {
- .reg_off = HHI_FIX_PLL_CNTL1,
- .shift = 0,
- .width = 17,
- },
- .l = {
- .reg_off = HHI_FIX_PLL_CNTL0,
- .shift = 31,
- .width = 1,
- },
- .rst = {
- .reg_off = HHI_FIX_PLL_CNTL0,
- .shift = 29,
- .width = 1,
- },
- },
- .hw.init = &(struct clk_init_data){
- .name = "fixed_pll_dco",
- .ops = &meson_clk_pll_ro_ops,
- .parent_data = &(const struct clk_parent_data) {
- .fw_name = "xtal",
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_fixed_pll = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_FIX_PLL_CNTL0,
- .shift = 16,
- .width = 2,
- .flags = CLK_DIVIDER_POWER_OF_TWO,
- },
- .hw.init = &(struct clk_init_data){
- .name = "fixed_pll",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_fixed_pll_dco.hw
- },
- .num_parents = 1,
- /*
- * This clock won't ever change at runtime so
- * CLK_SET_RATE_PARENT is not required
- */
- },
- };
- static const struct pll_mult_range g12a_sys_pll_mult_range = {
- .min = 128,
- .max = 250,
- };
- static struct clk_regmap g12a_sys_pll_dco = {
- .data = &(struct meson_clk_pll_data){
- .en = {
- .reg_off = HHI_SYS_PLL_CNTL0,
- .shift = 28,
- .width = 1,
- },
- .m = {
- .reg_off = HHI_SYS_PLL_CNTL0,
- .shift = 0,
- .width = 8,
- },
- .n = {
- .reg_off = HHI_SYS_PLL_CNTL0,
- .shift = 10,
- .width = 5,
- },
- .l = {
- .reg_off = HHI_SYS_PLL_CNTL0,
- .shift = 31,
- .width = 1,
- },
- .rst = {
- .reg_off = HHI_SYS_PLL_CNTL0,
- .shift = 29,
- .width = 1,
- },
- .range = &g12a_sys_pll_mult_range,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sys_pll_dco",
- .ops = &meson_clk_pll_ops,
- .parent_data = &(const struct clk_parent_data) {
- .fw_name = "xtal",
- },
- .num_parents = 1,
- /* This clock feeds the CPU, avoid disabling it */
- .flags = CLK_IS_CRITICAL,
- },
- };
- static struct clk_regmap g12a_sys_pll = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SYS_PLL_CNTL0,
- .shift = 16,
- .width = 3,
- .flags = CLK_DIVIDER_POWER_OF_TWO,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sys_pll",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_sys_pll_dco.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12b_sys1_pll_dco = {
- .data = &(struct meson_clk_pll_data){
- .en = {
- .reg_off = HHI_SYS1_PLL_CNTL0,
- .shift = 28,
- .width = 1,
- },
- .m = {
- .reg_off = HHI_SYS1_PLL_CNTL0,
- .shift = 0,
- .width = 8,
- },
- .n = {
- .reg_off = HHI_SYS1_PLL_CNTL0,
- .shift = 10,
- .width = 5,
- },
- .l = {
- .reg_off = HHI_SYS1_PLL_CNTL0,
- .shift = 31,
- .width = 1,
- },
- .rst = {
- .reg_off = HHI_SYS1_PLL_CNTL0,
- .shift = 29,
- .width = 1,
- },
- .range = &g12a_sys_pll_mult_range,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sys1_pll_dco",
- .ops = &meson_clk_pll_ops,
- .parent_data = &(const struct clk_parent_data) {
- .fw_name = "xtal",
- },
- .num_parents = 1,
- /* This clock feeds the CPU, avoid disabling it */
- .flags = CLK_IS_CRITICAL,
- },
- };
- static struct clk_regmap g12b_sys1_pll = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SYS1_PLL_CNTL0,
- .shift = 16,
- .width = 3,
- .flags = CLK_DIVIDER_POWER_OF_TWO,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sys1_pll",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_sys1_pll_dco.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_sys_pll_div16_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sys_pll_div16_en",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_sys_pll.hw },
- .num_parents = 1,
- /*
- * This clock is used to debug the sys_pll range
- * Linux should not change it at runtime
- */
- },
- };
- static struct clk_regmap g12b_sys1_pll_div16_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL1,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sys1_pll_div16_en",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_sys1_pll.hw
- },
- .num_parents = 1,
- /*
- * This clock is used to debug the sys_pll range
- * Linux should not change it at runtime
- */
- },
- };
- static struct clk_fixed_factor g12a_sys_pll_div16 = {
- .mult = 1,
- .div = 16,
- .hw.init = &(struct clk_init_data){
- .name = "sys_pll_div16",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_sys_pll_div16_en.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12b_sys1_pll_div16 = {
- .mult = 1,
- .div = 16,
- .hw.init = &(struct clk_init_data){
- .name = "sys1_pll_div16",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_sys1_pll_div16_en.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12a_fclk_div2_div = {
- .mult = 1,
- .div = 2,
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div2_div",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_fixed_pll.hw },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_fclk_div2 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_FIX_PLL_CNTL1,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div2",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_fclk_div2_div.hw
- },
- .num_parents = 1,
- /*
- * Similar to fclk_div3, it seems that this clock is used by
- * the resident firmware and is required by the platform to
- * operate correctly.
- * Until the following condition are met, we need this clock to
- * be marked as critical:
- * a) Mark the clock used by a firmware resource, if possible
- * b) CCF has a clock hand-off mechanism to make the sure the
- * clock stays on until the proper driver comes along
- */
- .flags = CLK_IS_CRITICAL,
- },
- };
- static struct clk_fixed_factor g12a_fclk_div3_div = {
- .mult = 1,
- .div = 3,
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div3_div",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_fixed_pll.hw },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_fclk_div3 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_FIX_PLL_CNTL1,
- .bit_idx = 20,
- },
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div3",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_fclk_div3_div.hw
- },
- .num_parents = 1,
- /*
- * This clock is used by the resident firmware and is required
- * by the platform to operate correctly.
- * Until the following condition are met, we need this clock to
- * be marked as critical:
- * a) Mark the clock used by a firmware resource, if possible
- * b) CCF has a clock hand-off mechanism to make the sure the
- * clock stays on until the proper driver comes along
- */
- .flags = CLK_IS_CRITICAL,
- },
- };
- /* Datasheet names this field as "premux0" */
- static struct clk_regmap g12a_cpu_clk_premux0 = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL0,
- .mask = 0x3,
- .shift = 0,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_dyn0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = (const struct clk_parent_data []) {
- { .fw_name = "xtal", },
- { .hw = &g12a_fclk_div2.hw },
- { .hw = &g12a_fclk_div3.hw },
- },
- .num_parents = 3,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* Datasheet names this field as "premux1" */
- static struct clk_regmap g12a_cpu_clk_premux1 = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL0,
- .mask = 0x3,
- .shift = 16,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_dyn1_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = (const struct clk_parent_data []) {
- { .fw_name = "xtal", },
- { .hw = &g12a_fclk_div2.hw },
- { .hw = &g12a_fclk_div3.hw },
- },
- .num_parents = 3,
- /* This sub-tree is used a parking clock */
- .flags = CLK_SET_RATE_NO_REPARENT
- },
- };
- /* Datasheet names this field as "mux0_divn_tcnt" */
- static struct clk_regmap g12a_cpu_clk_mux0_div = {
- .data = &(struct meson_clk_cpu_dyndiv_data){
- .div = {
- .reg_off = HHI_SYS_CPU_CLK_CNTL0,
- .shift = 4,
- .width = 6,
- },
- .dyn = {
- .reg_off = HHI_SYS_CPU_CLK_CNTL0,
- .shift = 26,
- .width = 1,
- },
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_dyn0_div",
- .ops = &meson_clk_cpu_dyndiv_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk_premux0.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* Datasheet names this field as "postmux0" */
- static struct clk_regmap g12a_cpu_clk_postmux0 = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL0,
- .mask = 0x1,
- .shift = 2,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_dyn0",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk_premux0.hw,
- &g12a_cpu_clk_mux0_div.hw,
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* Datasheet names this field as "Mux1_divn_tcnt" */
- static struct clk_regmap g12a_cpu_clk_mux1_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SYS_CPU_CLK_CNTL0,
- .shift = 20,
- .width = 6,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_dyn1_div",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk_premux1.hw
- },
- .num_parents = 1,
- },
- };
- /* Datasheet names this field as "postmux1" */
- static struct clk_regmap g12a_cpu_clk_postmux1 = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL0,
- .mask = 0x1,
- .shift = 18,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_dyn1",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk_premux1.hw,
- &g12a_cpu_clk_mux1_div.hw,
- },
- .num_parents = 2,
- /* This sub-tree is used a parking clock */
- .flags = CLK_SET_RATE_NO_REPARENT,
- },
- };
- /* Datasheet names this field as "Final_dyn_mux_sel" */
- static struct clk_regmap g12a_cpu_clk_dyn = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL0,
- .mask = 0x1,
- .shift = 10,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_dyn",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk_postmux0.hw,
- &g12a_cpu_clk_postmux1.hw,
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* Datasheet names this field as "Final_mux_sel" */
- static struct clk_regmap g12a_cpu_clk = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL0,
- .mask = 0x1,
- .shift = 11,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk_dyn.hw,
- &g12a_sys_pll.hw,
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* Datasheet names this field as "Final_mux_sel" */
- static struct clk_regmap g12b_cpu_clk = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL0,
- .mask = 0x1,
- .shift = 11,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk_dyn.hw,
- &g12b_sys1_pll.hw
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* Datasheet names this field as "premux0" */
- static struct clk_regmap g12b_cpub_clk_premux0 = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL,
- .mask = 0x3,
- .shift = 0,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_dyn0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = (const struct clk_parent_data []) {
- { .fw_name = "xtal", },
- { .hw = &g12a_fclk_div2.hw },
- { .hw = &g12a_fclk_div3.hw },
- },
- .num_parents = 3,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* Datasheet names this field as "mux0_divn_tcnt" */
- static struct clk_regmap g12b_cpub_clk_mux0_div = {
- .data = &(struct meson_clk_cpu_dyndiv_data){
- .div = {
- .reg_off = HHI_SYS_CPUB_CLK_CNTL,
- .shift = 4,
- .width = 6,
- },
- .dyn = {
- .reg_off = HHI_SYS_CPUB_CLK_CNTL,
- .shift = 26,
- .width = 1,
- },
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_dyn0_div",
- .ops = &meson_clk_cpu_dyndiv_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk_premux0.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* Datasheet names this field as "postmux0" */
- static struct clk_regmap g12b_cpub_clk_postmux0 = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL,
- .mask = 0x1,
- .shift = 2,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_dyn0",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk_premux0.hw,
- &g12b_cpub_clk_mux0_div.hw
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* Datasheet names this field as "premux1" */
- static struct clk_regmap g12b_cpub_clk_premux1 = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL,
- .mask = 0x3,
- .shift = 16,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_dyn1_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = (const struct clk_parent_data []) {
- { .fw_name = "xtal", },
- { .hw = &g12a_fclk_div2.hw },
- { .hw = &g12a_fclk_div3.hw },
- },
- .num_parents = 3,
- /* This sub-tree is used a parking clock */
- .flags = CLK_SET_RATE_NO_REPARENT,
- },
- };
- /* Datasheet names this field as "Mux1_divn_tcnt" */
- static struct clk_regmap g12b_cpub_clk_mux1_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL,
- .shift = 20,
- .width = 6,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_dyn1_div",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk_premux1.hw
- },
- .num_parents = 1,
- },
- };
- /* Datasheet names this field as "postmux1" */
- static struct clk_regmap g12b_cpub_clk_postmux1 = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL,
- .mask = 0x1,
- .shift = 18,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_dyn1",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk_premux1.hw,
- &g12b_cpub_clk_mux1_div.hw
- },
- .num_parents = 2,
- /* This sub-tree is used a parking clock */
- .flags = CLK_SET_RATE_NO_REPARENT,
- },
- };
- /* Datasheet names this field as "Final_dyn_mux_sel" */
- static struct clk_regmap g12b_cpub_clk_dyn = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL,
- .mask = 0x1,
- .shift = 10,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_dyn",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk_postmux0.hw,
- &g12b_cpub_clk_postmux1.hw
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* Datasheet names this field as "Final_mux_sel" */
- static struct clk_regmap g12b_cpub_clk = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL,
- .mask = 0x1,
- .shift = 11,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk_dyn.hw,
- &g12a_sys_pll.hw
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap sm1_gp1_pll;
- /* Datasheet names this field as "premux0" */
- static struct clk_regmap sm1_dsu_clk_premux0 = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL5,
- .mask = 0x3,
- .shift = 0,
- },
- .hw.init = &(struct clk_init_data){
- .name = "dsu_clk_dyn0_sel",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_data = (const struct clk_parent_data []) {
- { .fw_name = "xtal", },
- { .hw = &g12a_fclk_div2.hw },
- { .hw = &g12a_fclk_div3.hw },
- { .hw = &sm1_gp1_pll.hw },
- },
- .num_parents = 4,
- },
- };
- /* Datasheet names this field as "premux1" */
- static struct clk_regmap sm1_dsu_clk_premux1 = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL5,
- .mask = 0x3,
- .shift = 16,
- },
- .hw.init = &(struct clk_init_data){
- .name = "dsu_clk_dyn1_sel",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_data = (const struct clk_parent_data []) {
- { .fw_name = "xtal", },
- { .hw = &g12a_fclk_div2.hw },
- { .hw = &g12a_fclk_div3.hw },
- { .hw = &sm1_gp1_pll.hw },
- },
- .num_parents = 4,
- },
- };
- /* Datasheet names this field as "Mux0_divn_tcnt" */
- static struct clk_regmap sm1_dsu_clk_mux0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SYS_CPU_CLK_CNTL5,
- .shift = 4,
- .width = 6,
- },
- .hw.init = &(struct clk_init_data){
- .name = "dsu_clk_dyn0_div",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &sm1_dsu_clk_premux0.hw
- },
- .num_parents = 1,
- },
- };
- /* Datasheet names this field as "postmux0" */
- static struct clk_regmap sm1_dsu_clk_postmux0 = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL5,
- .mask = 0x1,
- .shift = 2,
- },
- .hw.init = &(struct clk_init_data){
- .name = "dsu_clk_dyn0",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &sm1_dsu_clk_premux0.hw,
- &sm1_dsu_clk_mux0_div.hw,
- },
- .num_parents = 2,
- },
- };
- /* Datasheet names this field as "Mux1_divn_tcnt" */
- static struct clk_regmap sm1_dsu_clk_mux1_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SYS_CPU_CLK_CNTL5,
- .shift = 20,
- .width = 6,
- },
- .hw.init = &(struct clk_init_data){
- .name = "dsu_clk_dyn1_div",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &sm1_dsu_clk_premux1.hw
- },
- .num_parents = 1,
- },
- };
- /* Datasheet names this field as "postmux1" */
- static struct clk_regmap sm1_dsu_clk_postmux1 = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL5,
- .mask = 0x1,
- .shift = 18,
- },
- .hw.init = &(struct clk_init_data){
- .name = "dsu_clk_dyn1",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &sm1_dsu_clk_premux1.hw,
- &sm1_dsu_clk_mux1_div.hw,
- },
- .num_parents = 2,
- },
- };
- /* Datasheet names this field as "Final_dyn_mux_sel" */
- static struct clk_regmap sm1_dsu_clk_dyn = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL5,
- .mask = 0x1,
- .shift = 10,
- },
- .hw.init = &(struct clk_init_data){
- .name = "dsu_clk_dyn",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &sm1_dsu_clk_postmux0.hw,
- &sm1_dsu_clk_postmux1.hw,
- },
- .num_parents = 2,
- },
- };
- /* Datasheet names this field as "Final_mux_sel" */
- static struct clk_regmap sm1_dsu_final_clk = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL5,
- .mask = 0x1,
- .shift = 11,
- },
- .hw.init = &(struct clk_init_data){
- .name = "dsu_clk_final",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &sm1_dsu_clk_dyn.hw,
- &g12a_sys_pll.hw,
- },
- .num_parents = 2,
- },
- };
- /* Datasheet names this field as "Cpu_clk_sync_mux_sel" bit 0 */
- static struct clk_regmap sm1_cpu1_clk = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL6,
- .mask = 0x1,
- .shift = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu1_clk",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk.hw,
- /* This CPU also have a dedicated clock tree */
- },
- .num_parents = 1,
- },
- };
- /* Datasheet names this field as "Cpu_clk_sync_mux_sel" bit 1 */
- static struct clk_regmap sm1_cpu2_clk = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL6,
- .mask = 0x1,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu2_clk",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk.hw,
- /* This CPU also have a dedicated clock tree */
- },
- .num_parents = 1,
- },
- };
- /* Datasheet names this field as "Cpu_clk_sync_mux_sel" bit 2 */
- static struct clk_regmap sm1_cpu3_clk = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL6,
- .mask = 0x1,
- .shift = 26,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu3_clk",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk.hw,
- /* This CPU also have a dedicated clock tree */
- },
- .num_parents = 1,
- },
- };
- /* Datasheet names this field as "Cpu_clk_sync_mux_sel" bit 4 */
- static struct clk_regmap sm1_dsu_clk = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL6,
- .mask = 0x1,
- .shift = 27,
- },
- .hw.init = &(struct clk_init_data){
- .name = "dsu_clk",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk.hw,
- &sm1_dsu_final_clk.hw,
- },
- .num_parents = 2,
- },
- };
- static int g12a_cpu_clk_mux_notifier_cb(struct notifier_block *nb,
- unsigned long event, void *data)
- {
- if (event == POST_RATE_CHANGE || event == PRE_RATE_CHANGE) {
- /* Wait for clock propagation before/after changing the mux */
- udelay(100);
- return NOTIFY_OK;
- }
- return NOTIFY_DONE;
- }
- static struct notifier_block g12a_cpu_clk_mux_nb = {
- .notifier_call = g12a_cpu_clk_mux_notifier_cb,
- };
- struct g12a_cpu_clk_postmux_nb_data {
- struct notifier_block nb;
- struct clk_hw *xtal;
- struct clk_hw *cpu_clk_dyn;
- struct clk_hw *cpu_clk_postmux0;
- struct clk_hw *cpu_clk_postmux1;
- struct clk_hw *cpu_clk_premux1;
- };
- static int g12a_cpu_clk_postmux_notifier_cb(struct notifier_block *nb,
- unsigned long event, void *data)
- {
- struct g12a_cpu_clk_postmux_nb_data *nb_data =
- container_of(nb, struct g12a_cpu_clk_postmux_nb_data, nb);
- switch (event) {
- case PRE_RATE_CHANGE:
- /*
- * This notifier means cpu_clk_postmux0 clock will be changed
- * to feed cpu_clk, this is the current path :
- * cpu_clk
- * \- cpu_clk_dyn
- * \- cpu_clk_postmux0
- * \- cpu_clk_muxX_div
- * \- cpu_clk_premux0
- * \- fclk_div3 or fclk_div2
- * OR
- * \- cpu_clk_premux0
- * \- fclk_div3 or fclk_div2
- */
- /* Setup cpu_clk_premux1 to xtal */
- clk_hw_set_parent(nb_data->cpu_clk_premux1,
- nb_data->xtal);
- /* Setup cpu_clk_postmux1 to bypass divider */
- clk_hw_set_parent(nb_data->cpu_clk_postmux1,
- nb_data->cpu_clk_premux1);
- /* Switch to parking clk on cpu_clk_postmux1 */
- clk_hw_set_parent(nb_data->cpu_clk_dyn,
- nb_data->cpu_clk_postmux1);
- /*
- * Now, cpu_clk is 24MHz in the current path :
- * cpu_clk
- * \- cpu_clk_dyn
- * \- cpu_clk_postmux1
- * \- cpu_clk_premux1
- * \- xtal
- */
- udelay(100);
- return NOTIFY_OK;
- case POST_RATE_CHANGE:
- /*
- * The cpu_clk_postmux0 has ben updated, now switch back
- * cpu_clk_dyn to cpu_clk_postmux0 and take the changes
- * in account.
- */
- /* Configure cpu_clk_dyn back to cpu_clk_postmux0 */
- clk_hw_set_parent(nb_data->cpu_clk_dyn,
- nb_data->cpu_clk_postmux0);
- /*
- * new path :
- * cpu_clk
- * \- cpu_clk_dyn
- * \- cpu_clk_postmux0
- * \- cpu_clk_muxX_div
- * \- cpu_clk_premux0
- * \- fclk_div3 or fclk_div2
- * OR
- * \- cpu_clk_premux0
- * \- fclk_div3 or fclk_div2
- */
- udelay(100);
- return NOTIFY_OK;
- default:
- return NOTIFY_DONE;
- }
- }
- static struct g12a_cpu_clk_postmux_nb_data g12a_cpu_clk_postmux0_nb_data = {
- .cpu_clk_dyn = &g12a_cpu_clk_dyn.hw,
- .cpu_clk_postmux0 = &g12a_cpu_clk_postmux0.hw,
- .cpu_clk_postmux1 = &g12a_cpu_clk_postmux1.hw,
- .cpu_clk_premux1 = &g12a_cpu_clk_premux1.hw,
- .nb.notifier_call = g12a_cpu_clk_postmux_notifier_cb,
- };
- static struct g12a_cpu_clk_postmux_nb_data g12b_cpub_clk_postmux0_nb_data = {
- .cpu_clk_dyn = &g12b_cpub_clk_dyn.hw,
- .cpu_clk_postmux0 = &g12b_cpub_clk_postmux0.hw,
- .cpu_clk_postmux1 = &g12b_cpub_clk_postmux1.hw,
- .cpu_clk_premux1 = &g12b_cpub_clk_premux1.hw,
- .nb.notifier_call = g12a_cpu_clk_postmux_notifier_cb,
- };
- struct g12a_sys_pll_nb_data {
- struct notifier_block nb;
- struct clk_hw *sys_pll;
- struct clk_hw *cpu_clk;
- struct clk_hw *cpu_clk_dyn;
- };
- static int g12a_sys_pll_notifier_cb(struct notifier_block *nb,
- unsigned long event, void *data)
- {
- struct g12a_sys_pll_nb_data *nb_data =
- container_of(nb, struct g12a_sys_pll_nb_data, nb);
- switch (event) {
- case PRE_RATE_CHANGE:
- /*
- * This notifier means sys_pll clock will be changed
- * to feed cpu_clk, this the current path :
- * cpu_clk
- * \- sys_pll
- * \- sys_pll_dco
- */
- /* Configure cpu_clk to use cpu_clk_dyn */
- clk_hw_set_parent(nb_data->cpu_clk,
- nb_data->cpu_clk_dyn);
- /*
- * Now, cpu_clk uses the dyn path
- * cpu_clk
- * \- cpu_clk_dyn
- * \- cpu_clk_dynX
- * \- cpu_clk_dynX_sel
- * \- cpu_clk_dynX_div
- * \- xtal/fclk_div2/fclk_div3
- * \- xtal/fclk_div2/fclk_div3
- */
- udelay(100);
- return NOTIFY_OK;
- case POST_RATE_CHANGE:
- /*
- * The sys_pll has ben updated, now switch back cpu_clk to
- * sys_pll
- */
- /* Configure cpu_clk to use sys_pll */
- clk_hw_set_parent(nb_data->cpu_clk,
- nb_data->sys_pll);
- udelay(100);
- /* new path :
- * cpu_clk
- * \- sys_pll
- * \- sys_pll_dco
- */
- return NOTIFY_OK;
- default:
- return NOTIFY_DONE;
- }
- }
- static struct g12a_sys_pll_nb_data g12a_sys_pll_nb_data = {
- .sys_pll = &g12a_sys_pll.hw,
- .cpu_clk = &g12a_cpu_clk.hw,
- .cpu_clk_dyn = &g12a_cpu_clk_dyn.hw,
- .nb.notifier_call = g12a_sys_pll_notifier_cb,
- };
- /* G12B first CPU cluster uses sys1_pll */
- static struct g12a_sys_pll_nb_data g12b_cpu_clk_sys1_pll_nb_data = {
- .sys_pll = &g12b_sys1_pll.hw,
- .cpu_clk = &g12b_cpu_clk.hw,
- .cpu_clk_dyn = &g12a_cpu_clk_dyn.hw,
- .nb.notifier_call = g12a_sys_pll_notifier_cb,
- };
- /* G12B second CPU cluster uses sys_pll */
- static struct g12a_sys_pll_nb_data g12b_cpub_clk_sys_pll_nb_data = {
- .sys_pll = &g12a_sys_pll.hw,
- .cpu_clk = &g12b_cpub_clk.hw,
- .cpu_clk_dyn = &g12b_cpub_clk_dyn.hw,
- .nb.notifier_call = g12a_sys_pll_notifier_cb,
- };
- static struct clk_regmap g12a_cpu_clk_div16_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .bit_idx = 1,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cpu_clk_div16_en",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk.hw
- },
- .num_parents = 1,
- /*
- * This clock is used to debug the cpu_clk range
- * Linux should not change it at runtime
- */
- },
- };
- static struct clk_regmap g12b_cpub_clk_div16_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL1,
- .bit_idx = 1,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cpub_clk_div16_en",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk.hw
- },
- .num_parents = 1,
- /*
- * This clock is used to debug the cpu_clk range
- * Linux should not change it at runtime
- */
- },
- };
- static struct clk_fixed_factor g12a_cpu_clk_div16 = {
- .mult = 1,
- .div = 16,
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_div16",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk_div16_en.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12b_cpub_clk_div16 = {
- .mult = 1,
- .div = 16,
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_div16",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk_div16_en.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_cpu_clk_apb_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .shift = 3,
- .width = 3,
- .flags = CLK_DIVIDER_POWER_OF_TWO,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_apb_div",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_cpu_clk.hw },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_cpu_clk_apb = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .bit_idx = 1,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cpu_clk_apb",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk_apb_div.hw
- },
- .num_parents = 1,
- /*
- * This clock is set by the ROM monitor code,
- * Linux should not change it at runtime
- */
- },
- };
- static struct clk_regmap g12a_cpu_clk_atb_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .shift = 6,
- .width = 3,
- .flags = CLK_DIVIDER_POWER_OF_TWO,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_atb_div",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_cpu_clk.hw },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_cpu_clk_atb = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .bit_idx = 17,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cpu_clk_atb",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk_atb_div.hw
- },
- .num_parents = 1,
- /*
- * This clock is set by the ROM monitor code,
- * Linux should not change it at runtime
- */
- },
- };
- static struct clk_regmap g12a_cpu_clk_axi_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .shift = 9,
- .width = 3,
- .flags = CLK_DIVIDER_POWER_OF_TWO,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_axi_div",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_cpu_clk.hw },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_cpu_clk_axi = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .bit_idx = 18,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cpu_clk_axi",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk_axi_div.hw
- },
- .num_parents = 1,
- /*
- * This clock is set by the ROM monitor code,
- * Linux should not change it at runtime
- */
- },
- };
- static struct clk_regmap g12a_cpu_clk_trace_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .shift = 20,
- .width = 3,
- .flags = CLK_DIVIDER_POWER_OF_TWO,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_trace_div",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_data = &(const struct clk_parent_data) {
- /*
- * Note:
- * G12A and G12B have different cpu_clks (with
- * different struct clk_hw). We fallback to the global
- * naming string mechanism so cpu_clk_trace_div picks
- * up the appropriate one.
- */
- .name = "cpu_clk",
- .index = -1,
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_cpu_clk_trace = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .bit_idx = 23,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cpu_clk_trace",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cpu_clk_trace_div.hw
- },
- .num_parents = 1,
- /*
- * This clock is set by the ROM monitor code,
- * Linux should not change it at runtime
- */
- },
- };
- static struct clk_fixed_factor g12b_cpub_clk_div2 = {
- .mult = 1,
- .div = 2,
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_div2",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12b_cpub_clk_div3 = {
- .mult = 1,
- .div = 3,
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_div3",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12b_cpub_clk_div4 = {
- .mult = 1,
- .div = 4,
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_div4",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12b_cpub_clk_div5 = {
- .mult = 1,
- .div = 5,
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_div5",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12b_cpub_clk_div6 = {
- .mult = 1,
- .div = 6,
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_div6",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12b_cpub_clk_div7 = {
- .mult = 1,
- .div = 7,
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_div7",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12b_cpub_clk_div8 = {
- .mult = 1,
- .div = 8,
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_div8",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk.hw
- },
- .num_parents = 1,
- },
- };
- static u32 mux_table_cpub[] = { 1, 2, 3, 4, 5, 6, 7 };
- static struct clk_regmap g12b_cpub_clk_apb_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL1,
- .mask = 7,
- .shift = 3,
- .table = mux_table_cpub,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_apb_sel",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk_div2.hw,
- &g12b_cpub_clk_div3.hw,
- &g12b_cpub_clk_div4.hw,
- &g12b_cpub_clk_div5.hw,
- &g12b_cpub_clk_div6.hw,
- &g12b_cpub_clk_div7.hw,
- &g12b_cpub_clk_div8.hw
- },
- .num_parents = 7,
- },
- };
- static struct clk_regmap g12b_cpub_clk_apb = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL1,
- .bit_idx = 16,
- .flags = CLK_GATE_SET_TO_DISABLE,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cpub_clk_apb",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk_apb_sel.hw
- },
- .num_parents = 1,
- /*
- * This clock is set by the ROM monitor code,
- * Linux should not change it at runtime
- */
- },
- };
- static struct clk_regmap g12b_cpub_clk_atb_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL1,
- .mask = 7,
- .shift = 6,
- .table = mux_table_cpub,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_atb_sel",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk_div2.hw,
- &g12b_cpub_clk_div3.hw,
- &g12b_cpub_clk_div4.hw,
- &g12b_cpub_clk_div5.hw,
- &g12b_cpub_clk_div6.hw,
- &g12b_cpub_clk_div7.hw,
- &g12b_cpub_clk_div8.hw
- },
- .num_parents = 7,
- },
- };
- static struct clk_regmap g12b_cpub_clk_atb = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL1,
- .bit_idx = 17,
- .flags = CLK_GATE_SET_TO_DISABLE,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cpub_clk_atb",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk_atb_sel.hw
- },
- .num_parents = 1,
- /*
- * This clock is set by the ROM monitor code,
- * Linux should not change it at runtime
- */
- },
- };
- static struct clk_regmap g12b_cpub_clk_axi_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL1,
- .mask = 7,
- .shift = 9,
- .table = mux_table_cpub,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_axi_sel",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk_div2.hw,
- &g12b_cpub_clk_div3.hw,
- &g12b_cpub_clk_div4.hw,
- &g12b_cpub_clk_div5.hw,
- &g12b_cpub_clk_div6.hw,
- &g12b_cpub_clk_div7.hw,
- &g12b_cpub_clk_div8.hw
- },
- .num_parents = 7,
- },
- };
- static struct clk_regmap g12b_cpub_clk_axi = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL1,
- .bit_idx = 18,
- .flags = CLK_GATE_SET_TO_DISABLE,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cpub_clk_axi",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk_axi_sel.hw
- },
- .num_parents = 1,
- /*
- * This clock is set by the ROM monitor code,
- * Linux should not change it at runtime
- */
- },
- };
- static struct clk_regmap g12b_cpub_clk_trace_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL1,
- .mask = 7,
- .shift = 20,
- .table = mux_table_cpub,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpub_clk_trace_sel",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk_div2.hw,
- &g12b_cpub_clk_div3.hw,
- &g12b_cpub_clk_div4.hw,
- &g12b_cpub_clk_div5.hw,
- &g12b_cpub_clk_div6.hw,
- &g12b_cpub_clk_div7.hw,
- &g12b_cpub_clk_div8.hw
- },
- .num_parents = 7,
- },
- };
- static struct clk_regmap g12b_cpub_clk_trace = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPUB_CLK_CNTL1,
- .bit_idx = 23,
- .flags = CLK_GATE_SET_TO_DISABLE,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cpub_clk_trace",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12b_cpub_clk_trace_sel.hw
- },
- .num_parents = 1,
- /*
- * This clock is set by the ROM monitor code,
- * Linux should not change it at runtime
- */
- },
- };
- static const struct pll_mult_range g12a_gp0_pll_mult_range = {
- .min = 125,
- .max = 255,
- };
- /*
- * Internal gp0 pll emulation configuration parameters
- */
- static const struct reg_sequence g12a_gp0_init_regs[] = {
- { .reg = HHI_GP0_PLL_CNTL1, .def = 0x00000000 },
- { .reg = HHI_GP0_PLL_CNTL2, .def = 0x00000000 },
- { .reg = HHI_GP0_PLL_CNTL3, .def = 0x48681c00 },
- { .reg = HHI_GP0_PLL_CNTL4, .def = 0x33771290 },
- { .reg = HHI_GP0_PLL_CNTL5, .def = 0x39272000 },
- { .reg = HHI_GP0_PLL_CNTL6, .def = 0x56540000 },
- };
- static struct clk_regmap g12a_gp0_pll_dco = {
- .data = &(struct meson_clk_pll_data){
- .en = {
- .reg_off = HHI_GP0_PLL_CNTL0,
- .shift = 28,
- .width = 1,
- },
- .m = {
- .reg_off = HHI_GP0_PLL_CNTL0,
- .shift = 0,
- .width = 8,
- },
- .n = {
- .reg_off = HHI_GP0_PLL_CNTL0,
- .shift = 10,
- .width = 5,
- },
- .frac = {
- .reg_off = HHI_GP0_PLL_CNTL1,
- .shift = 0,
- .width = 17,
- },
- .l = {
- .reg_off = HHI_GP0_PLL_CNTL0,
- .shift = 31,
- .width = 1,
- },
- .rst = {
- .reg_off = HHI_GP0_PLL_CNTL0,
- .shift = 29,
- .width = 1,
- },
- .range = &g12a_gp0_pll_mult_range,
- .init_regs = g12a_gp0_init_regs,
- .init_count = ARRAY_SIZE(g12a_gp0_init_regs),
- },
- .hw.init = &(struct clk_init_data){
- .name = "gp0_pll_dco",
- .ops = &meson_clk_pll_ops,
- .parent_data = &(const struct clk_parent_data) {
- .fw_name = "xtal",
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_gp0_pll = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_GP0_PLL_CNTL0,
- .shift = 16,
- .width = 3,
- .flags = (CLK_DIVIDER_POWER_OF_TWO |
- CLK_DIVIDER_ROUND_CLOSEST),
- },
- .hw.init = &(struct clk_init_data){
- .name = "gp0_pll",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_gp0_pll_dco.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap sm1_gp1_pll_dco = {
- .data = &(struct meson_clk_pll_data){
- .en = {
- .reg_off = HHI_GP1_PLL_CNTL0,
- .shift = 28,
- .width = 1,
- },
- .m = {
- .reg_off = HHI_GP1_PLL_CNTL0,
- .shift = 0,
- .width = 8,
- },
- .n = {
- .reg_off = HHI_GP1_PLL_CNTL0,
- .shift = 10,
- .width = 5,
- },
- .frac = {
- .reg_off = HHI_GP1_PLL_CNTL1,
- .shift = 0,
- .width = 17,
- },
- .l = {
- .reg_off = HHI_GP1_PLL_CNTL0,
- .shift = 31,
- .width = 1,
- },
- .rst = {
- .reg_off = HHI_GP1_PLL_CNTL0,
- .shift = 29,
- .width = 1,
- },
- },
- .hw.init = &(struct clk_init_data){
- .name = "gp1_pll_dco",
- .ops = &meson_clk_pll_ro_ops,
- .parent_data = &(const struct clk_parent_data) {
- .fw_name = "xtal",
- },
- .num_parents = 1,
- /* This clock feeds the DSU, avoid disabling it */
- .flags = CLK_IS_CRITICAL,
- },
- };
- static struct clk_regmap sm1_gp1_pll = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_GP1_PLL_CNTL0,
- .shift = 16,
- .width = 3,
- .flags = (CLK_DIVIDER_POWER_OF_TWO |
- CLK_DIVIDER_ROUND_CLOSEST),
- },
- .hw.init = &(struct clk_init_data){
- .name = "gp1_pll",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &sm1_gp1_pll_dco.hw
- },
- .num_parents = 1,
- },
- };
- /*
- * Internal hifi pll emulation configuration parameters
- */
- static const struct reg_sequence g12a_hifi_init_regs[] = {
- { .reg = HHI_HIFI_PLL_CNTL1, .def = 0x00000000 },
- { .reg = HHI_HIFI_PLL_CNTL2, .def = 0x00000000 },
- { .reg = HHI_HIFI_PLL_CNTL3, .def = 0x6a285c00 },
- { .reg = HHI_HIFI_PLL_CNTL4, .def = 0x65771290 },
- { .reg = HHI_HIFI_PLL_CNTL5, .def = 0x39272000 },
- { .reg = HHI_HIFI_PLL_CNTL6, .def = 0x56540000 },
- };
- static struct clk_regmap g12a_hifi_pll_dco = {
- .data = &(struct meson_clk_pll_data){
- .en = {
- .reg_off = HHI_HIFI_PLL_CNTL0,
- .shift = 28,
- .width = 1,
- },
- .m = {
- .reg_off = HHI_HIFI_PLL_CNTL0,
- .shift = 0,
- .width = 8,
- },
- .n = {
- .reg_off = HHI_HIFI_PLL_CNTL0,
- .shift = 10,
- .width = 5,
- },
- .frac = {
- .reg_off = HHI_HIFI_PLL_CNTL1,
- .shift = 0,
- .width = 17,
- },
- .l = {
- .reg_off = HHI_HIFI_PLL_CNTL0,
- .shift = 31,
- .width = 1,
- },
- .rst = {
- .reg_off = HHI_HIFI_PLL_CNTL0,
- .shift = 29,
- .width = 1,
- },
- .range = &g12a_gp0_pll_mult_range,
- .init_regs = g12a_hifi_init_regs,
- .init_count = ARRAY_SIZE(g12a_hifi_init_regs),
- .flags = CLK_MESON_PLL_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hifi_pll_dco",
- .ops = &meson_clk_pll_ops,
- .parent_data = &(const struct clk_parent_data) {
- .fw_name = "xtal",
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_hifi_pll = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_HIFI_PLL_CNTL0,
- .shift = 16,
- .width = 2,
- .flags = (CLK_DIVIDER_POWER_OF_TWO |
- CLK_DIVIDER_ROUND_CLOSEST),
- },
- .hw.init = &(struct clk_init_data){
- .name = "hifi_pll",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_hifi_pll_dco.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /*
- * The Meson G12A PCIE PLL is fined tuned to deliver a very precise
- * 100MHz reference clock for the PCIe Analog PHY, and thus requires
- * a strict register sequence to enable the PLL.
- */
- static const struct reg_sequence g12a_pcie_pll_init_regs[] = {
- { .reg = HHI_PCIE_PLL_CNTL0, .def = 0x20090496 },
- { .reg = HHI_PCIE_PLL_CNTL0, .def = 0x30090496 },
- { .reg = HHI_PCIE_PLL_CNTL1, .def = 0x00000000 },
- { .reg = HHI_PCIE_PLL_CNTL2, .def = 0x00001100 },
- { .reg = HHI_PCIE_PLL_CNTL3, .def = 0x10058e00 },
- { .reg = HHI_PCIE_PLL_CNTL4, .def = 0x000100c0 },
- { .reg = HHI_PCIE_PLL_CNTL5, .def = 0x68000048 },
- { .reg = HHI_PCIE_PLL_CNTL5, .def = 0x68000068, .delay_us = 20 },
- { .reg = HHI_PCIE_PLL_CNTL4, .def = 0x008100c0, .delay_us = 10 },
- { .reg = HHI_PCIE_PLL_CNTL0, .def = 0x34090496 },
- { .reg = HHI_PCIE_PLL_CNTL0, .def = 0x14090496, .delay_us = 10 },
- { .reg = HHI_PCIE_PLL_CNTL2, .def = 0x00001000 },
- };
- /* Keep a single entry table for recalc/round_rate() ops */
- static const struct pll_params_table g12a_pcie_pll_table[] = {
- PLL_PARAMS(150, 1),
- {0, 0},
- };
- static struct clk_regmap g12a_pcie_pll_dco = {
- .data = &(struct meson_clk_pll_data){
- .en = {
- .reg_off = HHI_PCIE_PLL_CNTL0,
- .shift = 28,
- .width = 1,
- },
- .m = {
- .reg_off = HHI_PCIE_PLL_CNTL0,
- .shift = 0,
- .width = 8,
- },
- .n = {
- .reg_off = HHI_PCIE_PLL_CNTL0,
- .shift = 10,
- .width = 5,
- },
- .frac = {
- .reg_off = HHI_PCIE_PLL_CNTL1,
- .shift = 0,
- .width = 12,
- },
- .l = {
- .reg_off = HHI_PCIE_PLL_CNTL0,
- .shift = 31,
- .width = 1,
- },
- .rst = {
- .reg_off = HHI_PCIE_PLL_CNTL0,
- .shift = 29,
- .width = 1,
- },
- .table = g12a_pcie_pll_table,
- .init_regs = g12a_pcie_pll_init_regs,
- .init_count = ARRAY_SIZE(g12a_pcie_pll_init_regs),
- },
- .hw.init = &(struct clk_init_data){
- .name = "pcie_pll_dco",
- .ops = &meson_clk_pcie_pll_ops,
- .parent_data = &(const struct clk_parent_data) {
- .fw_name = "xtal",
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12a_pcie_pll_dco_div2 = {
- .mult = 1,
- .div = 2,
- .hw.init = &(struct clk_init_data){
- .name = "pcie_pll_dco_div2",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_pcie_pll_dco.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_pcie_pll_od = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_PCIE_PLL_CNTL0,
- .shift = 16,
- .width = 5,
- .flags = CLK_DIVIDER_ROUND_CLOSEST |
- CLK_DIVIDER_ONE_BASED |
- CLK_DIVIDER_ALLOW_ZERO,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pcie_pll_od",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_pcie_pll_dco_div2.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor g12a_pcie_pll = {
- .mult = 1,
- .div = 2,
- .hw.init = &(struct clk_init_data){
- .name = "pcie_pll_pll",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_pcie_pll_od.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_hdmi_pll_dco = {
- .data = &(struct meson_clk_pll_data){
- .en = {
- .reg_off = HHI_HDMI_PLL_CNTL0,
- .shift = 28,
- .width = 1,
- },
- .m = {
- .reg_off = HHI_HDMI_PLL_CNTL0,
- .shift = 0,
- .width = 8,
- },
- .n = {
- .reg_off = HHI_HDMI_PLL_CNTL0,
- .shift = 10,
- .width = 5,
- },
- .frac = {
- .reg_off = HHI_HDMI_PLL_CNTL1,
- .shift = 0,
- .width = 16,
- },
- .l = {
- .reg_off = HHI_HDMI_PLL_CNTL0,
- .shift = 30,
- .width = 1,
- },
- .rst = {
- .reg_off = HHI_HDMI_PLL_CNTL0,
- .shift = 29,
- .width = 1,
- },
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_pll_dco",
- .ops = &meson_clk_pll_ro_ops,
- .parent_data = &(const struct clk_parent_data) {
- .fw_name = "xtal",
- },
- .num_parents = 1,
- /*
- * Display directly handle hdmi pll registers ATM, we need
- * NOCACHE to keep our view of the clock as accurate as possible
- */
- .flags = CLK_GET_RATE_NOCACHE,
- },
- };
- static struct clk_regmap g12a_hdmi_pll_od = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_HDMI_PLL_CNTL0,
- .shift = 16,
- .width = 2,
- .flags = CLK_DIVIDER_POWER_OF_TWO,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_pll_od",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_hdmi_pll_dco.hw
- },
- .num_parents = 1,
- .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_hdmi_pll_od2 = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_HDMI_PLL_CNTL0,
- .shift = 18,
- .width = 2,
- .flags = CLK_DIVIDER_POWER_OF_TWO,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_pll_od2",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_hdmi_pll_od.hw
- },
- .num_parents = 1,
- .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_hdmi_pll = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_HDMI_PLL_CNTL0,
- .shift = 20,
- .width = 2,
- .flags = CLK_DIVIDER_POWER_OF_TWO,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_pll",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_hdmi_pll_od2.hw
- },
- .num_parents = 1,
- .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor g12a_fclk_div4_div = {
- .mult = 1,
- .div = 4,
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div4_div",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_fixed_pll.hw },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_fclk_div4 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_FIX_PLL_CNTL1,
- .bit_idx = 21,
- },
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div4",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_fclk_div4_div.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12a_fclk_div5_div = {
- .mult = 1,
- .div = 5,
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div5_div",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_fixed_pll.hw },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_fclk_div5 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_FIX_PLL_CNTL1,
- .bit_idx = 22,
- },
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div5",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_fclk_div5_div.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12a_fclk_div7_div = {
- .mult = 1,
- .div = 7,
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div7_div",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_fixed_pll.hw },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_fclk_div7 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_FIX_PLL_CNTL1,
- .bit_idx = 23,
- },
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div7",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_fclk_div7_div.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12a_fclk_div2p5_div = {
- .mult = 1,
- .div = 5,
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div2p5_div",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_fixed_pll_dco.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_fclk_div2p5 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_FIX_PLL_CNTL1,
- .bit_idx = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div2p5",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_fclk_div2p5_div.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12a_mpll_50m_div = {
- .mult = 1,
- .div = 80,
- .hw.init = &(struct clk_init_data){
- .name = "mpll_50m_div",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_fixed_pll_dco.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_mpll_50m = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_FIX_PLL_CNTL3,
- .mask = 0x1,
- .shift = 5,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll_50m",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_data = (const struct clk_parent_data []) {
- { .fw_name = "xtal", },
- { .hw = &g12a_mpll_50m_div.hw },
- },
- .num_parents = 2,
- },
- };
- static struct clk_fixed_factor g12a_mpll_prediv = {
- .mult = 1,
- .div = 2,
- .hw.init = &(struct clk_init_data){
- .name = "mpll_prediv",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_fixed_pll_dco.hw
- },
- .num_parents = 1,
- },
- };
- static const struct reg_sequence g12a_mpll0_init_regs[] = {
- { .reg = HHI_MPLL_CNTL2, .def = 0x40000033 },
- };
- static struct clk_regmap g12a_mpll0_div = {
- .data = &(struct meson_clk_mpll_data){
- .sdm = {
- .reg_off = HHI_MPLL_CNTL1,
- .shift = 0,
- .width = 14,
- },
- .sdm_en = {
- .reg_off = HHI_MPLL_CNTL1,
- .shift = 30,
- .width = 1,
- },
- .n2 = {
- .reg_off = HHI_MPLL_CNTL1,
- .shift = 20,
- .width = 9,
- },
- .ssen = {
- .reg_off = HHI_MPLL_CNTL1,
- .shift = 29,
- .width = 1,
- },
- .lock = &meson_clk_lock,
- .init_regs = g12a_mpll0_init_regs,
- .init_count = ARRAY_SIZE(g12a_mpll0_init_regs),
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll0_div",
- .ops = &meson_clk_mpll_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_mpll_prediv.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_mpll0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MPLL_CNTL1,
- .bit_idx = 31,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_mpll0_div.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct reg_sequence g12a_mpll1_init_regs[] = {
- { .reg = HHI_MPLL_CNTL4, .def = 0x40000033 },
- };
- static struct clk_regmap g12a_mpll1_div = {
- .data = &(struct meson_clk_mpll_data){
- .sdm = {
- .reg_off = HHI_MPLL_CNTL3,
- .shift = 0,
- .width = 14,
- },
- .sdm_en = {
- .reg_off = HHI_MPLL_CNTL3,
- .shift = 30,
- .width = 1,
- },
- .n2 = {
- .reg_off = HHI_MPLL_CNTL3,
- .shift = 20,
- .width = 9,
- },
- .ssen = {
- .reg_off = HHI_MPLL_CNTL3,
- .shift = 29,
- .width = 1,
- },
- .lock = &meson_clk_lock,
- .init_regs = g12a_mpll1_init_regs,
- .init_count = ARRAY_SIZE(g12a_mpll1_init_regs),
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll1_div",
- .ops = &meson_clk_mpll_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_mpll_prediv.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_mpll1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MPLL_CNTL3,
- .bit_idx = 31,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_mpll1_div.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct reg_sequence g12a_mpll2_init_regs[] = {
- { .reg = HHI_MPLL_CNTL6, .def = 0x40000033 },
- };
- static struct clk_regmap g12a_mpll2_div = {
- .data = &(struct meson_clk_mpll_data){
- .sdm = {
- .reg_off = HHI_MPLL_CNTL5,
- .shift = 0,
- .width = 14,
- },
- .sdm_en = {
- .reg_off = HHI_MPLL_CNTL5,
- .shift = 30,
- .width = 1,
- },
- .n2 = {
- .reg_off = HHI_MPLL_CNTL5,
- .shift = 20,
- .width = 9,
- },
- .ssen = {
- .reg_off = HHI_MPLL_CNTL5,
- .shift = 29,
- .width = 1,
- },
- .lock = &meson_clk_lock,
- .init_regs = g12a_mpll2_init_regs,
- .init_count = ARRAY_SIZE(g12a_mpll2_init_regs),
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll2_div",
- .ops = &meson_clk_mpll_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_mpll_prediv.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_mpll2 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MPLL_CNTL5,
- .bit_idx = 31,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll2",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_mpll2_div.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct reg_sequence g12a_mpll3_init_regs[] = {
- { .reg = HHI_MPLL_CNTL8, .def = 0x40000033 },
- };
- static struct clk_regmap g12a_mpll3_div = {
- .data = &(struct meson_clk_mpll_data){
- .sdm = {
- .reg_off = HHI_MPLL_CNTL7,
- .shift = 0,
- .width = 14,
- },
- .sdm_en = {
- .reg_off = HHI_MPLL_CNTL7,
- .shift = 30,
- .width = 1,
- },
- .n2 = {
- .reg_off = HHI_MPLL_CNTL7,
- .shift = 20,
- .width = 9,
- },
- .ssen = {
- .reg_off = HHI_MPLL_CNTL7,
- .shift = 29,
- .width = 1,
- },
- .lock = &meson_clk_lock,
- .init_regs = g12a_mpll3_init_regs,
- .init_count = ARRAY_SIZE(g12a_mpll3_init_regs),
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll3_div",
- .ops = &meson_clk_mpll_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_mpll_prediv.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_mpll3 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MPLL_CNTL7,
- .bit_idx = 31,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll3",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_mpll3_div.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static u32 mux_table_clk81[] = { 0, 2, 3, 4, 5, 6, 7 };
- static const struct clk_parent_data clk81_parent_data[] = {
- { .fw_name = "xtal", },
- { .hw = &g12a_fclk_div7.hw },
- { .hw = &g12a_mpll1.hw },
- { .hw = &g12a_mpll2.hw },
- { .hw = &g12a_fclk_div4.hw },
- { .hw = &g12a_fclk_div3.hw },
- { .hw = &g12a_fclk_div5.hw },
- };
- static struct clk_regmap g12a_mpeg_clk_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_MPEG_CLK_CNTL,
- .mask = 0x7,
- .shift = 12,
- .table = mux_table_clk81,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpeg_clk_sel",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_data = clk81_parent_data,
- .num_parents = ARRAY_SIZE(clk81_parent_data),
- },
- };
- static struct clk_regmap g12a_mpeg_clk_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_MPEG_CLK_CNTL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpeg_clk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_mpeg_clk_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_clk81 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MPEG_CLK_CNTL,
- .bit_idx = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "clk81",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_mpeg_clk_div.hw
- },
- .num_parents = 1,
- .flags = (CLK_SET_RATE_PARENT | CLK_IS_CRITICAL),
- },
- };
- static const struct clk_parent_data g12a_sd_emmc_clk0_parent_data[] = {
- { .fw_name = "xtal", },
- { .hw = &g12a_fclk_div2.hw },
- { .hw = &g12a_fclk_div3.hw },
- { .hw = &g12a_fclk_div5.hw },
- { .hw = &g12a_fclk_div7.hw },
- /*
- * Following these parent clocks, we should also have had mpll2, mpll3
- * and gp0_pll but these clocks are too precious to be used here. All
- * the necessary rates for MMC and NAND operation can be acheived using
- * g12a_ee_core or fclk_div clocks
- */
- };
- /* SDIO clock */
- static struct clk_regmap g12a_sd_emmc_a_clk0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SD_EMMC_CLK_CNTL,
- .mask = 0x7,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sd_emmc_a_clk0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = g12a_sd_emmc_clk0_parent_data,
- .num_parents = ARRAY_SIZE(g12a_sd_emmc_clk0_parent_data),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_sd_emmc_a_clk0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SD_EMMC_CLK_CNTL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sd_emmc_a_clk0_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_sd_emmc_a_clk0_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_sd_emmc_a_clk0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SD_EMMC_CLK_CNTL,
- .bit_idx = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sd_emmc_a_clk0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_sd_emmc_a_clk0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* SDcard clock */
- static struct clk_regmap g12a_sd_emmc_b_clk0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SD_EMMC_CLK_CNTL,
- .mask = 0x7,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sd_emmc_b_clk0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = g12a_sd_emmc_clk0_parent_data,
- .num_parents = ARRAY_SIZE(g12a_sd_emmc_clk0_parent_data),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_sd_emmc_b_clk0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SD_EMMC_CLK_CNTL,
- .shift = 16,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sd_emmc_b_clk0_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_sd_emmc_b_clk0_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_sd_emmc_b_clk0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SD_EMMC_CLK_CNTL,
- .bit_idx = 23,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sd_emmc_b_clk0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_sd_emmc_b_clk0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* EMMC/NAND clock */
- static struct clk_regmap g12a_sd_emmc_c_clk0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_NAND_CLK_CNTL,
- .mask = 0x7,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sd_emmc_c_clk0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = g12a_sd_emmc_clk0_parent_data,
- .num_parents = ARRAY_SIZE(g12a_sd_emmc_clk0_parent_data),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_sd_emmc_c_clk0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_NAND_CLK_CNTL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sd_emmc_c_clk0_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_sd_emmc_c_clk0_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_sd_emmc_c_clk0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_NAND_CLK_CNTL,
- .bit_idx = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sd_emmc_c_clk0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_sd_emmc_c_clk0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* Video Clocks */
- static struct clk_regmap g12a_vid_pll_div = {
- .data = &(struct meson_vid_pll_div_data){
- .val = {
- .reg_off = HHI_VID_PLL_CLK_DIV,
- .shift = 0,
- .width = 15,
- },
- .sel = {
- .reg_off = HHI_VID_PLL_CLK_DIV,
- .shift = 16,
- .width = 2,
- },
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vid_pll_div",
- .ops = &meson_vid_pll_div_ro_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_hdmi_pll.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_GET_RATE_NOCACHE,
- },
- };
- static const struct clk_hw *g12a_vid_pll_parent_hws[] = {
- &g12a_vid_pll_div.hw,
- &g12a_hdmi_pll.hw,
- };
- static struct clk_regmap g12a_vid_pll_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VID_PLL_CLK_DIV,
- .mask = 0x1,
- .shift = 18,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vid_pll_sel",
- .ops = &clk_regmap_mux_ops,
- /*
- * bit 18 selects from 2 possible parents:
- * vid_pll_div or hdmi_pll
- */
- .parent_hws = g12a_vid_pll_parent_hws,
- .num_parents = ARRAY_SIZE(g12a_vid_pll_parent_hws),
- .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
- },
- };
- static struct clk_regmap g12a_vid_pll = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_PLL_CLK_DIV,
- .bit_idx = 19,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vid_pll",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vid_pll_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- /* VPU Clock */
- static const struct clk_hw *g12a_vpu_parent_hws[] = {
- &g12a_fclk_div3.hw,
- &g12a_fclk_div4.hw,
- &g12a_fclk_div5.hw,
- &g12a_fclk_div7.hw,
- &g12a_mpll1.hw,
- &g12a_vid_pll.hw,
- &g12a_hifi_pll.hw,
- &g12a_gp0_pll.hw,
- };
- static struct clk_regmap g12a_vpu_0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VPU_CLK_CNTL,
- .mask = 0x7,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = g12a_vpu_parent_hws,
- .num_parents = ARRAY_SIZE(g12a_vpu_parent_hws),
- .flags = CLK_SET_RATE_NO_REPARENT,
- },
- };
- static struct clk_regmap g12a_vpu_0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VPU_CLK_CNTL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_0_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vpu_0_sel.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_vpu_0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VPU_CLK_CNTL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vpu_0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vpu_0_div.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vpu_1_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VPU_CLK_CNTL,
- .mask = 0x7,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_1_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = g12a_vpu_parent_hws,
- .num_parents = ARRAY_SIZE(g12a_vpu_parent_hws),
- .flags = CLK_SET_RATE_NO_REPARENT,
- },
- };
- static struct clk_regmap g12a_vpu_1_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VPU_CLK_CNTL,
- .shift = 16,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_1_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vpu_1_sel.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_vpu_1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VPU_CLK_CNTL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vpu_1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vpu_1_div.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vpu = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VPU_CLK_CNTL,
- .mask = 1,
- .shift = 31,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu",
- .ops = &clk_regmap_mux_ops,
- /*
- * bit 31 selects from 2 possible parents:
- * vpu_0 or vpu_1
- */
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vpu_0.hw,
- &g12a_vpu_1.hw,
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_NO_REPARENT,
- },
- };
- /* VDEC clocks */
- static const struct clk_hw *g12a_vdec_parent_hws[] = {
- &g12a_fclk_div2p5.hw,
- &g12a_fclk_div3.hw,
- &g12a_fclk_div4.hw,
- &g12a_fclk_div5.hw,
- &g12a_fclk_div7.hw,
- &g12a_hifi_pll.hw,
- &g12a_gp0_pll.hw,
- };
- static struct clk_regmap g12a_vdec_1_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VDEC_CLK_CNTL,
- .mask = 0x7,
- .shift = 9,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_1_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = g12a_vdec_parent_hws,
- .num_parents = ARRAY_SIZE(g12a_vdec_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_vdec_1_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VDEC_CLK_CNTL,
- .shift = 0,
- .width = 7,
- .flags = CLK_DIVIDER_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_1_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vdec_1_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_vdec_1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VDEC_CLK_CNTL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vdec_1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vdec_1_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_vdec_hevcf_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VDEC2_CLK_CNTL,
- .mask = 0x7,
- .shift = 9,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_hevcf_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = g12a_vdec_parent_hws,
- .num_parents = ARRAY_SIZE(g12a_vdec_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_vdec_hevcf_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VDEC2_CLK_CNTL,
- .shift = 0,
- .width = 7,
- .flags = CLK_DIVIDER_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_hevcf_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vdec_hevcf_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_vdec_hevcf = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VDEC2_CLK_CNTL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vdec_hevcf",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vdec_hevcf_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_vdec_hevc_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VDEC2_CLK_CNTL,
- .mask = 0x7,
- .shift = 25,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_hevc_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = g12a_vdec_parent_hws,
- .num_parents = ARRAY_SIZE(g12a_vdec_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_vdec_hevc_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VDEC2_CLK_CNTL,
- .shift = 16,
- .width = 7,
- .flags = CLK_DIVIDER_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_hevc_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vdec_hevc_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_vdec_hevc = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VDEC2_CLK_CNTL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vdec_hevc",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vdec_hevc_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* VAPB Clock */
- static const struct clk_hw *g12a_vapb_parent_hws[] = {
- &g12a_fclk_div4.hw,
- &g12a_fclk_div3.hw,
- &g12a_fclk_div5.hw,
- &g12a_fclk_div7.hw,
- &g12a_mpll1.hw,
- &g12a_vid_pll.hw,
- &g12a_mpll2.hw,
- &g12a_fclk_div2p5.hw,
- };
- static struct clk_regmap g12a_vapb_0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VAPBCLK_CNTL,
- .mask = 0x3,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vapb_0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = g12a_vapb_parent_hws,
- .num_parents = ARRAY_SIZE(g12a_vapb_parent_hws),
- .flags = CLK_SET_RATE_NO_REPARENT,
- },
- };
- static struct clk_regmap g12a_vapb_0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VAPBCLK_CNTL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vapb_0_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vapb_0_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_vapb_0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VAPBCLK_CNTL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vapb_0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vapb_0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vapb_1_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VAPBCLK_CNTL,
- .mask = 0x3,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vapb_1_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = g12a_vapb_parent_hws,
- .num_parents = ARRAY_SIZE(g12a_vapb_parent_hws),
- .flags = CLK_SET_RATE_NO_REPARENT,
- },
- };
- static struct clk_regmap g12a_vapb_1_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VAPBCLK_CNTL,
- .shift = 16,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vapb_1_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vapb_1_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_vapb_1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VAPBCLK_CNTL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vapb_1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vapb_1_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vapb_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VAPBCLK_CNTL,
- .mask = 1,
- .shift = 31,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vapb_sel",
- .ops = &clk_regmap_mux_ops,
- /*
- * bit 31 selects from 2 possible parents:
- * vapb_0 or vapb_1
- */
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vapb_0.hw,
- &g12a_vapb_1.hw,
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_NO_REPARENT,
- },
- };
- static struct clk_regmap g12a_vapb = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VAPBCLK_CNTL,
- .bit_idx = 30,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vapb",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vapb_sel.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static const struct clk_hw *g12a_vclk_parent_hws[] = {
- &g12a_vid_pll.hw,
- &g12a_gp0_pll.hw,
- &g12a_hifi_pll.hw,
- &g12a_mpll1.hw,
- &g12a_fclk_div3.hw,
- &g12a_fclk_div4.hw,
- &g12a_fclk_div5.hw,
- &g12a_fclk_div7.hw,
- };
- static struct clk_regmap g12a_vclk_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VID_CLK_CNTL,
- .mask = 0x7,
- .shift = 16,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = g12a_vclk_parent_hws,
- .num_parents = ARRAY_SIZE(g12a_vclk_parent_hws),
- .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
- },
- };
- static struct clk_regmap g12a_vclk2_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VIID_CLK_CNTL,
- .mask = 0x7,
- .shift = 16,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = g12a_vclk_parent_hws,
- .num_parents = ARRAY_SIZE(g12a_vclk_parent_hws),
- .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
- },
- };
- static struct clk_regmap g12a_vclk_input = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_DIV,
- .bit_idx = 16,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk_input",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vclk_sel.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vclk2_input = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VIID_CLK_DIV,
- .bit_idx = 16,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk2_input",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vclk2_sel.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vclk_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VID_CLK_DIV,
- .shift = 0,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vclk_input.hw
- },
- .num_parents = 1,
- .flags = CLK_GET_RATE_NOCACHE,
- },
- };
- static struct clk_regmap g12a_vclk2_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VIID_CLK_DIV,
- .shift = 0,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vclk2_input.hw
- },
- .num_parents = 1,
- .flags = CLK_GET_RATE_NOCACHE,
- },
- };
- static struct clk_regmap g12a_vclk = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL,
- .bit_idx = 19,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vclk_div.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vclk2 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VIID_CLK_CNTL,
- .bit_idx = 19,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk2",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vclk2_div.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vclk_div1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL,
- .bit_idx = 0,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk_div1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vclk.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vclk_div2_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL,
- .bit_idx = 1,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk_div2_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vclk.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vclk_div4_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL,
- .bit_idx = 2,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk_div4_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vclk.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vclk_div6_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL,
- .bit_idx = 3,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk_div6_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vclk.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vclk_div12_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL,
- .bit_idx = 4,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk_div12_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vclk.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vclk2_div1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VIID_CLK_CNTL,
- .bit_idx = 0,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk2_div1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vclk2.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vclk2_div2_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VIID_CLK_CNTL,
- .bit_idx = 1,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk2_div2_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vclk2.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vclk2_div4_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VIID_CLK_CNTL,
- .bit_idx = 2,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk2_div4_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vclk2.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vclk2_div6_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VIID_CLK_CNTL,
- .bit_idx = 3,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk2_div6_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vclk2.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_vclk2_div12_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VIID_CLK_CNTL,
- .bit_idx = 4,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk2_div12_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_vclk2.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_fixed_factor g12a_vclk_div2 = {
- .mult = 1,
- .div = 2,
- .hw.init = &(struct clk_init_data){
- .name = "vclk_div2",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vclk_div2_en.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12a_vclk_div4 = {
- .mult = 1,
- .div = 4,
- .hw.init = &(struct clk_init_data){
- .name = "vclk_div4",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vclk_div4_en.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12a_vclk_div6 = {
- .mult = 1,
- .div = 6,
- .hw.init = &(struct clk_init_data){
- .name = "vclk_div6",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vclk_div6_en.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12a_vclk_div12 = {
- .mult = 1,
- .div = 12,
- .hw.init = &(struct clk_init_data){
- .name = "vclk_div12",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vclk_div12_en.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12a_vclk2_div2 = {
- .mult = 1,
- .div = 2,
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div2",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vclk2_div2_en.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12a_vclk2_div4 = {
- .mult = 1,
- .div = 4,
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div4",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vclk2_div4_en.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12a_vclk2_div6 = {
- .mult = 1,
- .div = 6,
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div6",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vclk2_div6_en.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor g12a_vclk2_div12 = {
- .mult = 1,
- .div = 12,
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div12",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_vclk2_div12_en.hw
- },
- .num_parents = 1,
- },
- };
- static u32 mux_table_cts_sel[] = { 0, 1, 2, 3, 4, 8, 9, 10, 11, 12 };
- static const struct clk_hw *g12a_cts_parent_hws[] = {
- &g12a_vclk_div1.hw,
- &g12a_vclk_div2.hw,
- &g12a_vclk_div4.hw,
- &g12a_vclk_div6.hw,
- &g12a_vclk_div12.hw,
- &g12a_vclk2_div1.hw,
- &g12a_vclk2_div2.hw,
- &g12a_vclk2_div4.hw,
- &g12a_vclk2_div6.hw,
- &g12a_vclk2_div12.hw,
- };
- static struct clk_regmap g12a_cts_enci_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VID_CLK_DIV,
- .mask = 0xf,
- .shift = 28,
- .table = mux_table_cts_sel,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_enci_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = g12a_cts_parent_hws,
- .num_parents = ARRAY_SIZE(g12a_cts_parent_hws),
- .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
- },
- };
- static struct clk_regmap g12a_cts_encp_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VID_CLK_DIV,
- .mask = 0xf,
- .shift = 20,
- .table = mux_table_cts_sel,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_encp_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = g12a_cts_parent_hws,
- .num_parents = ARRAY_SIZE(g12a_cts_parent_hws),
- .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
- },
- };
- static struct clk_regmap g12a_cts_vdac_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VIID_CLK_DIV,
- .mask = 0xf,
- .shift = 28,
- .table = mux_table_cts_sel,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_vdac_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = g12a_cts_parent_hws,
- .num_parents = ARRAY_SIZE(g12a_cts_parent_hws),
- .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
- },
- };
- /* TOFIX: add support for cts_tcon */
- static u32 mux_table_hdmi_tx_sel[] = { 0, 1, 2, 3, 4, 8, 9, 10, 11, 12 };
- static const struct clk_hw *g12a_cts_hdmi_tx_parent_hws[] = {
- &g12a_vclk_div1.hw,
- &g12a_vclk_div2.hw,
- &g12a_vclk_div4.hw,
- &g12a_vclk_div6.hw,
- &g12a_vclk_div12.hw,
- &g12a_vclk2_div1.hw,
- &g12a_vclk2_div2.hw,
- &g12a_vclk2_div4.hw,
- &g12a_vclk2_div6.hw,
- &g12a_vclk2_div12.hw,
- };
- static struct clk_regmap g12a_hdmi_tx_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_HDMI_CLK_CNTL,
- .mask = 0xf,
- .shift = 16,
- .table = mux_table_hdmi_tx_sel,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_tx_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = g12a_cts_hdmi_tx_parent_hws,
- .num_parents = ARRAY_SIZE(g12a_cts_hdmi_tx_parent_hws),
- .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
- },
- };
- static struct clk_regmap g12a_cts_enci = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL2,
- .bit_idx = 0,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cts_enci",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cts_enci_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_cts_encp = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL2,
- .bit_idx = 2,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cts_encp",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cts_encp_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_cts_vdac = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL2,
- .bit_idx = 4,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cts_vdac",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_cts_vdac_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- static struct clk_regmap g12a_hdmi_tx = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL2,
- .bit_idx = 5,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "hdmi_tx",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_hdmi_tx_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- /* MIPI DSI Host Clocks */
- static const struct clk_hw *g12a_mipi_dsi_pxclk_parent_hws[] = {
- &g12a_vid_pll.hw,
- &g12a_gp0_pll.hw,
- &g12a_hifi_pll.hw,
- &g12a_mpll1.hw,
- &g12a_fclk_div2.hw,
- &g12a_fclk_div2p5.hw,
- &g12a_fclk_div3.hw,
- &g12a_fclk_div7.hw,
- };
- static struct clk_regmap g12a_mipi_dsi_pxclk_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_MIPIDSI_PHY_CLK_CNTL,
- .mask = 0x7,
- .shift = 12,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mipi_dsi_pxclk_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = g12a_mipi_dsi_pxclk_parent_hws,
- .num_parents = ARRAY_SIZE(g12a_mipi_dsi_pxclk_parent_hws),
- .flags = CLK_SET_RATE_NO_REPARENT,
- },
- };
- static struct clk_regmap g12a_mipi_dsi_pxclk_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_MIPIDSI_PHY_CLK_CNTL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mipi_dsi_pxclk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_mipi_dsi_pxclk_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_mipi_dsi_pxclk = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MIPIDSI_PHY_CLK_CNTL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "mipi_dsi_pxclk",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_mipi_dsi_pxclk_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* HDMI Clocks */
- static const struct clk_parent_data g12a_hdmi_parent_data[] = {
- { .fw_name = "xtal", },
- { .hw = &g12a_fclk_div4.hw },
- { .hw = &g12a_fclk_div3.hw },
- { .hw = &g12a_fclk_div5.hw },
- };
- static struct clk_regmap g12a_hdmi_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_HDMI_CLK_CNTL,
- .mask = 0x3,
- .shift = 9,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = g12a_hdmi_parent_data,
- .num_parents = ARRAY_SIZE(g12a_hdmi_parent_data),
- .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
- },
- };
- static struct clk_regmap g12a_hdmi_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_HDMI_CLK_CNTL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_hdmi_sel.hw },
- .num_parents = 1,
- .flags = CLK_GET_RATE_NOCACHE,
- },
- };
- static struct clk_regmap g12a_hdmi = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_HDMI_CLK_CNTL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "hdmi",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &g12a_hdmi_div.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
- },
- };
- /*
- * The MALI IP is clocked by two identical clocks (mali_0 and mali_1)
- * muxed by a glitch-free switch. The CCF can manage this glitch-free
- * mux because it does top-to-bottom updates the each clock tree and
- * switches to the "inactive" one when CLK_SET_RATE_GATE is set.
- */
- static const struct clk_parent_data g12a_mali_0_1_parent_data[] = {
- { .fw_name = "xtal", },
- { .hw = &g12a_gp0_pll.hw },
- { .hw = &g12a_hifi_pll.hw },
- { .hw = &g12a_fclk_div2p5.hw },
- { .hw = &g12a_fclk_div3.hw },
- { .hw = &g12a_fclk_div4.hw },
- { .hw = &g12a_fclk_div5.hw },
- { .hw = &g12a_fclk_div7.hw },
- };
- static struct clk_regmap g12a_mali_0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_MALI_CLK_CNTL,
- .mask = 0x7,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mali_0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = g12a_mali_0_1_parent_data,
- .num_parents = 8,
- /*
- * Don't request the parent to change the rate because
- * all GPU frequencies can be derived from the fclk_*
- * clocks and one special GP0_PLL setting. This is
- * important because we need the MPLL clocks for audio.
- */
- .flags = 0,
- },
- };
- static struct clk_regmap g12a_mali_0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_MALI_CLK_CNTL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mali_0_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_mali_0_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_mali_0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MALI_CLK_CNTL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mali_0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_mali_0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_GATE | CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_mali_1_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_MALI_CLK_CNTL,
- .mask = 0x7,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mali_1_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = g12a_mali_0_1_parent_data,
- .num_parents = 8,
- /*
- * Don't request the parent to change the rate because
- * all GPU frequencies can be derived from the fclk_*
- * clocks and one special GP0_PLL setting. This is
- * important because we need the MPLL clocks for audio.
- */
- .flags = 0,
- },
- };
- static struct clk_regmap g12a_mali_1_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_MALI_CLK_CNTL,
- .shift = 16,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mali_1_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_mali_1_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_mali_1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MALI_CLK_CNTL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mali_1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_mali_1_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_GATE | CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_hw *g12a_mali_parent_hws[] = {
- &g12a_mali_0.hw,
- &g12a_mali_1.hw,
- };
- static struct clk_regmap g12a_mali = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_MALI_CLK_CNTL,
- .mask = 1,
- .shift = 31,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mali",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = g12a_mali_parent_hws,
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_ts_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_TS_CLK_CNTL,
- .shift = 0,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "ts_div",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_data = &(const struct clk_parent_data) {
- .fw_name = "xtal",
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap g12a_ts = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_TS_CLK_CNTL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "ts",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_ts_div.hw
- },
- .num_parents = 1,
- },
- };
- /* SPICC SCLK source clock */
- static const struct clk_parent_data spicc_sclk_parent_data[] = {
- { .fw_name = "xtal", },
- { .hw = &g12a_clk81.hw },
- { .hw = &g12a_fclk_div4.hw },
- { .hw = &g12a_fclk_div3.hw },
- { .hw = &g12a_fclk_div5.hw },
- { .hw = &g12a_fclk_div7.hw },
- };
- static struct clk_regmap g12a_spicc0_sclk_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SPICC_CLK_CNTL,
- .mask = 7,
- .shift = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "spicc0_sclk_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = spicc_sclk_parent_data,
- .num_parents = ARRAY_SIZE(spicc_sclk_parent_data),
- },
- };
- static struct clk_regmap g12a_spicc0_sclk_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SPICC_CLK_CNTL,
- .shift = 0,
- .width = 6,
- },
- .hw.init = &(struct clk_init_data){
- .name = "spicc0_sclk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_spicc0_sclk_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_spicc0_sclk = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SPICC_CLK_CNTL,
- .bit_idx = 6,
- },
- .hw.init = &(struct clk_init_data){
- .name = "spicc0_sclk",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_spicc0_sclk_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_spicc1_sclk_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SPICC_CLK_CNTL,
- .mask = 7,
- .shift = 23,
- },
- .hw.init = &(struct clk_init_data){
- .name = "spicc1_sclk_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = spicc_sclk_parent_data,
- .num_parents = ARRAY_SIZE(spicc_sclk_parent_data),
- },
- };
- static struct clk_regmap g12a_spicc1_sclk_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SPICC_CLK_CNTL,
- .shift = 16,
- .width = 6,
- },
- .hw.init = &(struct clk_init_data){
- .name = "spicc1_sclk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_spicc1_sclk_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap g12a_spicc1_sclk = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SPICC_CLK_CNTL,
- .bit_idx = 22,
- },
- .hw.init = &(struct clk_init_data){
- .name = "spicc1_sclk",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &g12a_spicc1_sclk_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* Neural Network Accelerator source clock */
- static const struct clk_parent_data nna_clk_parent_data[] = {
- { .fw_name = "xtal", },
- { .hw = &g12a_gp0_pll.hw, },
- { .hw = &g12a_hifi_pll.hw, },
- { .hw = &g12a_fclk_div2p5.hw, },
- { .hw = &g12a_fclk_div3.hw, },
- { .hw = &g12a_fclk_div4.hw, },
- { .hw = &g12a_fclk_div5.hw, },
- { .hw = &g12a_fclk_div7.hw },
- };
- static struct clk_regmap sm1_nna_axi_clk_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_NNA_CLK_CNTL,
- .mask = 7,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "nna_axi_clk_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = nna_clk_parent_data,
- .num_parents = ARRAY_SIZE(nna_clk_parent_data),
- },
- };
- static struct clk_regmap sm1_nna_axi_clk_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_NNA_CLK_CNTL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "nna_axi_clk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &sm1_nna_axi_clk_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap sm1_nna_axi_clk = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_NNA_CLK_CNTL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "nna_axi_clk",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &sm1_nna_axi_clk_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap sm1_nna_core_clk_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_NNA_CLK_CNTL,
- .mask = 7,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "nna_core_clk_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = nna_clk_parent_data,
- .num_parents = ARRAY_SIZE(nna_clk_parent_data),
- },
- };
- static struct clk_regmap sm1_nna_core_clk_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_NNA_CLK_CNTL,
- .shift = 16,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "nna_core_clk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &sm1_nna_core_clk_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap sm1_nna_core_clk = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_NNA_CLK_CNTL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "nna_core_clk",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &sm1_nna_core_clk_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- #define MESON_GATE(_name, _reg, _bit) \
- MESON_PCLK(_name, _reg, _bit, &g12a_clk81.hw)
- #define MESON_GATE_RO(_name, _reg, _bit) \
- MESON_PCLK_RO(_name, _reg, _bit, &g12a_clk81.hw)
- /* Everything Else (EE) domain gates */
- static MESON_GATE(g12a_ddr, HHI_GCLK_MPEG0, 0);
- static MESON_GATE(g12a_dos, HHI_GCLK_MPEG0, 1);
- static MESON_GATE(g12a_audio_locker, HHI_GCLK_MPEG0, 2);
- static MESON_GATE(g12a_mipi_dsi_host, HHI_GCLK_MPEG0, 3);
- static MESON_GATE(g12a_eth_phy, HHI_GCLK_MPEG0, 4);
- static MESON_GATE(g12a_isa, HHI_GCLK_MPEG0, 5);
- static MESON_GATE(g12a_pl301, HHI_GCLK_MPEG0, 6);
- static MESON_GATE(g12a_periphs, HHI_GCLK_MPEG0, 7);
- static MESON_GATE(g12a_spicc_0, HHI_GCLK_MPEG0, 8);
- static MESON_GATE(g12a_i2c, HHI_GCLK_MPEG0, 9);
- static MESON_GATE(g12a_sana, HHI_GCLK_MPEG0, 10);
- static MESON_GATE(g12a_sd, HHI_GCLK_MPEG0, 11);
- static MESON_GATE(g12a_rng0, HHI_GCLK_MPEG0, 12);
- static MESON_GATE(g12a_uart0, HHI_GCLK_MPEG0, 13);
- static MESON_GATE(g12a_spicc_1, HHI_GCLK_MPEG0, 14);
- static MESON_GATE(g12a_hiu_reg, HHI_GCLK_MPEG0, 19);
- static MESON_GATE(g12a_mipi_dsi_phy, HHI_GCLK_MPEG0, 20);
- static MESON_GATE(g12a_assist_misc, HHI_GCLK_MPEG0, 23);
- static MESON_GATE(g12a_emmc_a, HHI_GCLK_MPEG0, 4);
- static MESON_GATE(g12a_emmc_b, HHI_GCLK_MPEG0, 25);
- static MESON_GATE(g12a_emmc_c, HHI_GCLK_MPEG0, 26);
- static MESON_GATE(g12a_audio_codec, HHI_GCLK_MPEG0, 28);
- static MESON_GATE(g12a_audio, HHI_GCLK_MPEG1, 0);
- static MESON_GATE(g12a_eth_core, HHI_GCLK_MPEG1, 3);
- static MESON_GATE(g12a_demux, HHI_GCLK_MPEG1, 4);
- static MESON_GATE(g12a_audio_ififo, HHI_GCLK_MPEG1, 11);
- static MESON_GATE(g12a_adc, HHI_GCLK_MPEG1, 13);
- static MESON_GATE(g12a_uart1, HHI_GCLK_MPEG1, 16);
- static MESON_GATE(g12a_g2d, HHI_GCLK_MPEG1, 20);
- static MESON_GATE(g12a_reset, HHI_GCLK_MPEG1, 23);
- static MESON_GATE(g12a_pcie_comb, HHI_GCLK_MPEG1, 24);
- static MESON_GATE(g12a_parser, HHI_GCLK_MPEG1, 25);
- static MESON_GATE(g12a_usb_general, HHI_GCLK_MPEG1, 26);
- static MESON_GATE(g12a_pcie_phy, HHI_GCLK_MPEG1, 27);
- static MESON_GATE(g12a_ahb_arb0, HHI_GCLK_MPEG1, 29);
- static MESON_GATE(g12a_ahb_data_bus, HHI_GCLK_MPEG2, 1);
- static MESON_GATE(g12a_ahb_ctrl_bus, HHI_GCLK_MPEG2, 2);
- static MESON_GATE(g12a_htx_hdcp22, HHI_GCLK_MPEG2, 3);
- static MESON_GATE(g12a_htx_pclk, HHI_GCLK_MPEG2, 4);
- static MESON_GATE(g12a_bt656, HHI_GCLK_MPEG2, 6);
- static MESON_GATE(g12a_usb1_to_ddr, HHI_GCLK_MPEG2, 8);
- static MESON_GATE(g12a_mmc_pclk, HHI_GCLK_MPEG2, 11);
- static MESON_GATE(g12a_uart2, HHI_GCLK_MPEG2, 15);
- static MESON_GATE(g12a_vpu_intr, HHI_GCLK_MPEG2, 25);
- static MESON_GATE(g12a_gic, HHI_GCLK_MPEG2, 30);
- static MESON_GATE(g12a_vclk2_venci0, HHI_GCLK_OTHER, 1);
- static MESON_GATE(g12a_vclk2_venci1, HHI_GCLK_OTHER, 2);
- static MESON_GATE(g12a_vclk2_vencp0, HHI_GCLK_OTHER, 3);
- static MESON_GATE(g12a_vclk2_vencp1, HHI_GCLK_OTHER, 4);
- static MESON_GATE(g12a_vclk2_venct0, HHI_GCLK_OTHER, 5);
- static MESON_GATE(g12a_vclk2_venct1, HHI_GCLK_OTHER, 6);
- static MESON_GATE(g12a_vclk2_other, HHI_GCLK_OTHER, 7);
- static MESON_GATE(g12a_vclk2_enci, HHI_GCLK_OTHER, 8);
- static MESON_GATE(g12a_vclk2_encp, HHI_GCLK_OTHER, 9);
- static MESON_GATE(g12a_dac_clk, HHI_GCLK_OTHER, 10);
- static MESON_GATE(g12a_aoclk_gate, HHI_GCLK_OTHER, 14);
- static MESON_GATE(g12a_iec958_gate, HHI_GCLK_OTHER, 16);
- static MESON_GATE(g12a_enc480p, HHI_GCLK_OTHER, 20);
- static MESON_GATE(g12a_rng1, HHI_GCLK_OTHER, 21);
- static MESON_GATE(g12a_vclk2_enct, HHI_GCLK_OTHER, 22);
- static MESON_GATE(g12a_vclk2_encl, HHI_GCLK_OTHER, 23);
- static MESON_GATE(g12a_vclk2_venclmmc, HHI_GCLK_OTHER, 24);
- static MESON_GATE(g12a_vclk2_vencl, HHI_GCLK_OTHER, 25);
- static MESON_GATE(g12a_vclk2_other1, HHI_GCLK_OTHER, 26);
- static MESON_GATE_RO(g12a_dma, HHI_GCLK_OTHER2, 0);
- static MESON_GATE_RO(g12a_efuse, HHI_GCLK_OTHER2, 1);
- static MESON_GATE_RO(g12a_rom_boot, HHI_GCLK_OTHER2, 2);
- static MESON_GATE_RO(g12a_reset_sec, HHI_GCLK_OTHER2, 3);
- static MESON_GATE_RO(g12a_sec_ahb_apb3, HHI_GCLK_OTHER2, 4);
- /* Array of all clocks provided by this provider */
- static struct clk_hw_onecell_data g12a_hw_onecell_data = {
- .hws = {
- [CLKID_SYS_PLL] = &g12a_sys_pll.hw,
- [CLKID_FIXED_PLL] = &g12a_fixed_pll.hw,
- [CLKID_FCLK_DIV2] = &g12a_fclk_div2.hw,
- [CLKID_FCLK_DIV3] = &g12a_fclk_div3.hw,
- [CLKID_FCLK_DIV4] = &g12a_fclk_div4.hw,
- [CLKID_FCLK_DIV5] = &g12a_fclk_div5.hw,
- [CLKID_FCLK_DIV7] = &g12a_fclk_div7.hw,
- [CLKID_FCLK_DIV2P5] = &g12a_fclk_div2p5.hw,
- [CLKID_GP0_PLL] = &g12a_gp0_pll.hw,
- [CLKID_MPEG_SEL] = &g12a_mpeg_clk_sel.hw,
- [CLKID_MPEG_DIV] = &g12a_mpeg_clk_div.hw,
- [CLKID_CLK81] = &g12a_clk81.hw,
- [CLKID_MPLL0] = &g12a_mpll0.hw,
- [CLKID_MPLL1] = &g12a_mpll1.hw,
- [CLKID_MPLL2] = &g12a_mpll2.hw,
- [CLKID_MPLL3] = &g12a_mpll3.hw,
- [CLKID_DDR] = &g12a_ddr.hw,
- [CLKID_DOS] = &g12a_dos.hw,
- [CLKID_AUDIO_LOCKER] = &g12a_audio_locker.hw,
- [CLKID_MIPI_DSI_HOST] = &g12a_mipi_dsi_host.hw,
- [CLKID_ETH_PHY] = &g12a_eth_phy.hw,
- [CLKID_ISA] = &g12a_isa.hw,
- [CLKID_PL301] = &g12a_pl301.hw,
- [CLKID_PERIPHS] = &g12a_periphs.hw,
- [CLKID_SPICC0] = &g12a_spicc_0.hw,
- [CLKID_I2C] = &g12a_i2c.hw,
- [CLKID_SANA] = &g12a_sana.hw,
- [CLKID_SD] = &g12a_sd.hw,
- [CLKID_RNG0] = &g12a_rng0.hw,
- [CLKID_UART0] = &g12a_uart0.hw,
- [CLKID_SPICC1] = &g12a_spicc_1.hw,
- [CLKID_HIU_IFACE] = &g12a_hiu_reg.hw,
- [CLKID_MIPI_DSI_PHY] = &g12a_mipi_dsi_phy.hw,
- [CLKID_ASSIST_MISC] = &g12a_assist_misc.hw,
- [CLKID_SD_EMMC_A] = &g12a_emmc_a.hw,
- [CLKID_SD_EMMC_B] = &g12a_emmc_b.hw,
- [CLKID_SD_EMMC_C] = &g12a_emmc_c.hw,
- [CLKID_AUDIO_CODEC] = &g12a_audio_codec.hw,
- [CLKID_AUDIO] = &g12a_audio.hw,
- [CLKID_ETH] = &g12a_eth_core.hw,
- [CLKID_DEMUX] = &g12a_demux.hw,
- [CLKID_AUDIO_IFIFO] = &g12a_audio_ififo.hw,
- [CLKID_ADC] = &g12a_adc.hw,
- [CLKID_UART1] = &g12a_uart1.hw,
- [CLKID_G2D] = &g12a_g2d.hw,
- [CLKID_RESET] = &g12a_reset.hw,
- [CLKID_PCIE_COMB] = &g12a_pcie_comb.hw,
- [CLKID_PARSER] = &g12a_parser.hw,
- [CLKID_USB] = &g12a_usb_general.hw,
- [CLKID_PCIE_PHY] = &g12a_pcie_phy.hw,
- [CLKID_AHB_ARB0] = &g12a_ahb_arb0.hw,
- [CLKID_AHB_DATA_BUS] = &g12a_ahb_data_bus.hw,
- [CLKID_AHB_CTRL_BUS] = &g12a_ahb_ctrl_bus.hw,
- [CLKID_HTX_HDCP22] = &g12a_htx_hdcp22.hw,
- [CLKID_HTX_PCLK] = &g12a_htx_pclk.hw,
- [CLKID_BT656] = &g12a_bt656.hw,
- [CLKID_USB1_DDR_BRIDGE] = &g12a_usb1_to_ddr.hw,
- [CLKID_MMC_PCLK] = &g12a_mmc_pclk.hw,
- [CLKID_UART2] = &g12a_uart2.hw,
- [CLKID_VPU_INTR] = &g12a_vpu_intr.hw,
- [CLKID_GIC] = &g12a_gic.hw,
- [CLKID_SD_EMMC_A_CLK0_SEL] = &g12a_sd_emmc_a_clk0_sel.hw,
- [CLKID_SD_EMMC_A_CLK0_DIV] = &g12a_sd_emmc_a_clk0_div.hw,
- [CLKID_SD_EMMC_A_CLK0] = &g12a_sd_emmc_a_clk0.hw,
- [CLKID_SD_EMMC_B_CLK0_SEL] = &g12a_sd_emmc_b_clk0_sel.hw,
- [CLKID_SD_EMMC_B_CLK0_DIV] = &g12a_sd_emmc_b_clk0_div.hw,
- [CLKID_SD_EMMC_B_CLK0] = &g12a_sd_emmc_b_clk0.hw,
- [CLKID_SD_EMMC_C_CLK0_SEL] = &g12a_sd_emmc_c_clk0_sel.hw,
- [CLKID_SD_EMMC_C_CLK0_DIV] = &g12a_sd_emmc_c_clk0_div.hw,
- [CLKID_SD_EMMC_C_CLK0] = &g12a_sd_emmc_c_clk0.hw,
- [CLKID_MPLL0_DIV] = &g12a_mpll0_div.hw,
- [CLKID_MPLL1_DIV] = &g12a_mpll1_div.hw,
- [CLKID_MPLL2_DIV] = &g12a_mpll2_div.hw,
- [CLKID_MPLL3_DIV] = &g12a_mpll3_div.hw,
- [CLKID_FCLK_DIV2_DIV] = &g12a_fclk_div2_div.hw,
- [CLKID_FCLK_DIV3_DIV] = &g12a_fclk_div3_div.hw,
- [CLKID_FCLK_DIV4_DIV] = &g12a_fclk_div4_div.hw,
- [CLKID_FCLK_DIV5_DIV] = &g12a_fclk_div5_div.hw,
- [CLKID_FCLK_DIV7_DIV] = &g12a_fclk_div7_div.hw,
- [CLKID_FCLK_DIV2P5_DIV] = &g12a_fclk_div2p5_div.hw,
- [CLKID_HIFI_PLL] = &g12a_hifi_pll.hw,
- [CLKID_VCLK2_VENCI0] = &g12a_vclk2_venci0.hw,
- [CLKID_VCLK2_VENCI1] = &g12a_vclk2_venci1.hw,
- [CLKID_VCLK2_VENCP0] = &g12a_vclk2_vencp0.hw,
- [CLKID_VCLK2_VENCP1] = &g12a_vclk2_vencp1.hw,
- [CLKID_VCLK2_VENCT0] = &g12a_vclk2_venct0.hw,
- [CLKID_VCLK2_VENCT1] = &g12a_vclk2_venct1.hw,
- [CLKID_VCLK2_OTHER] = &g12a_vclk2_other.hw,
- [CLKID_VCLK2_ENCI] = &g12a_vclk2_enci.hw,
- [CLKID_VCLK2_ENCP] = &g12a_vclk2_encp.hw,
- [CLKID_DAC_CLK] = &g12a_dac_clk.hw,
- [CLKID_AOCLK] = &g12a_aoclk_gate.hw,
- [CLKID_IEC958] = &g12a_iec958_gate.hw,
- [CLKID_ENC480P] = &g12a_enc480p.hw,
- [CLKID_RNG1] = &g12a_rng1.hw,
- [CLKID_VCLK2_ENCT] = &g12a_vclk2_enct.hw,
- [CLKID_VCLK2_ENCL] = &g12a_vclk2_encl.hw,
- [CLKID_VCLK2_VENCLMMC] = &g12a_vclk2_venclmmc.hw,
- [CLKID_VCLK2_VENCL] = &g12a_vclk2_vencl.hw,
- [CLKID_VCLK2_OTHER1] = &g12a_vclk2_other1.hw,
- [CLKID_FIXED_PLL_DCO] = &g12a_fixed_pll_dco.hw,
- [CLKID_SYS_PLL_DCO] = &g12a_sys_pll_dco.hw,
- [CLKID_GP0_PLL_DCO] = &g12a_gp0_pll_dco.hw,
- [CLKID_HIFI_PLL_DCO] = &g12a_hifi_pll_dco.hw,
- [CLKID_DMA] = &g12a_dma.hw,
- [CLKID_EFUSE] = &g12a_efuse.hw,
- [CLKID_ROM_BOOT] = &g12a_rom_boot.hw,
- [CLKID_RESET_SEC] = &g12a_reset_sec.hw,
- [CLKID_SEC_AHB_APB3] = &g12a_sec_ahb_apb3.hw,
- [CLKID_MPLL_PREDIV] = &g12a_mpll_prediv.hw,
- [CLKID_VPU_0_SEL] = &g12a_vpu_0_sel.hw,
- [CLKID_VPU_0_DIV] = &g12a_vpu_0_div.hw,
- [CLKID_VPU_0] = &g12a_vpu_0.hw,
- [CLKID_VPU_1_SEL] = &g12a_vpu_1_sel.hw,
- [CLKID_VPU_1_DIV] = &g12a_vpu_1_div.hw,
- [CLKID_VPU_1] = &g12a_vpu_1.hw,
- [CLKID_VPU] = &g12a_vpu.hw,
- [CLKID_VAPB_0_SEL] = &g12a_vapb_0_sel.hw,
- [CLKID_VAPB_0_DIV] = &g12a_vapb_0_div.hw,
- [CLKID_VAPB_0] = &g12a_vapb_0.hw,
- [CLKID_VAPB_1_SEL] = &g12a_vapb_1_sel.hw,
- [CLKID_VAPB_1_DIV] = &g12a_vapb_1_div.hw,
- [CLKID_VAPB_1] = &g12a_vapb_1.hw,
- [CLKID_VAPB_SEL] = &g12a_vapb_sel.hw,
- [CLKID_VAPB] = &g12a_vapb.hw,
- [CLKID_HDMI_PLL_DCO] = &g12a_hdmi_pll_dco.hw,
- [CLKID_HDMI_PLL_OD] = &g12a_hdmi_pll_od.hw,
- [CLKID_HDMI_PLL_OD2] = &g12a_hdmi_pll_od2.hw,
- [CLKID_HDMI_PLL] = &g12a_hdmi_pll.hw,
- [CLKID_VID_PLL] = &g12a_vid_pll_div.hw,
- [CLKID_VID_PLL_SEL] = &g12a_vid_pll_sel.hw,
- [CLKID_VID_PLL_DIV] = &g12a_vid_pll.hw,
- [CLKID_VCLK_SEL] = &g12a_vclk_sel.hw,
- [CLKID_VCLK2_SEL] = &g12a_vclk2_sel.hw,
- [CLKID_VCLK_INPUT] = &g12a_vclk_input.hw,
- [CLKID_VCLK2_INPUT] = &g12a_vclk2_input.hw,
- [CLKID_VCLK_DIV] = &g12a_vclk_div.hw,
- [CLKID_VCLK2_DIV] = &g12a_vclk2_div.hw,
- [CLKID_VCLK] = &g12a_vclk.hw,
- [CLKID_VCLK2] = &g12a_vclk2.hw,
- [CLKID_VCLK_DIV1] = &g12a_vclk_div1.hw,
- [CLKID_VCLK_DIV2_EN] = &g12a_vclk_div2_en.hw,
- [CLKID_VCLK_DIV4_EN] = &g12a_vclk_div4_en.hw,
- [CLKID_VCLK_DIV6_EN] = &g12a_vclk_div6_en.hw,
- [CLKID_VCLK_DIV12_EN] = &g12a_vclk_div12_en.hw,
- [CLKID_VCLK2_DIV1] = &g12a_vclk2_div1.hw,
- [CLKID_VCLK2_DIV2_EN] = &g12a_vclk2_div2_en.hw,
- [CLKID_VCLK2_DIV4_EN] = &g12a_vclk2_div4_en.hw,
- [CLKID_VCLK2_DIV6_EN] = &g12a_vclk2_div6_en.hw,
- [CLKID_VCLK2_DIV12_EN] = &g12a_vclk2_div12_en.hw,
- [CLKID_VCLK_DIV2] = &g12a_vclk_div2.hw,
- [CLKID_VCLK_DIV4] = &g12a_vclk_div4.hw,
- [CLKID_VCLK_DIV6] = &g12a_vclk_div6.hw,
- [CLKID_VCLK_DIV12] = &g12a_vclk_div12.hw,
- [CLKID_VCLK2_DIV2] = &g12a_vclk2_div2.hw,
- [CLKID_VCLK2_DIV4] = &g12a_vclk2_div4.hw,
- [CLKID_VCLK2_DIV6] = &g12a_vclk2_div6.hw,
- [CLKID_VCLK2_DIV12] = &g12a_vclk2_div12.hw,
- [CLKID_CTS_ENCI_SEL] = &g12a_cts_enci_sel.hw,
- [CLKID_CTS_ENCP_SEL] = &g12a_cts_encp_sel.hw,
- [CLKID_CTS_VDAC_SEL] = &g12a_cts_vdac_sel.hw,
- [CLKID_HDMI_TX_SEL] = &g12a_hdmi_tx_sel.hw,
- [CLKID_CTS_ENCI] = &g12a_cts_enci.hw,
- [CLKID_CTS_ENCP] = &g12a_cts_encp.hw,
- [CLKID_CTS_VDAC] = &g12a_cts_vdac.hw,
- [CLKID_HDMI_TX] = &g12a_hdmi_tx.hw,
- [CLKID_HDMI_SEL] = &g12a_hdmi_sel.hw,
- [CLKID_HDMI_DIV] = &g12a_hdmi_div.hw,
- [CLKID_HDMI] = &g12a_hdmi.hw,
- [CLKID_MALI_0_SEL] = &g12a_mali_0_sel.hw,
- [CLKID_MALI_0_DIV] = &g12a_mali_0_div.hw,
- [CLKID_MALI_0] = &g12a_mali_0.hw,
- [CLKID_MALI_1_SEL] = &g12a_mali_1_sel.hw,
- [CLKID_MALI_1_DIV] = &g12a_mali_1_div.hw,
- [CLKID_MALI_1] = &g12a_mali_1.hw,
- [CLKID_MALI] = &g12a_mali.hw,
- [CLKID_MPLL_50M_DIV] = &g12a_mpll_50m_div.hw,
- [CLKID_MPLL_50M] = &g12a_mpll_50m.hw,
- [CLKID_SYS_PLL_DIV16_EN] = &g12a_sys_pll_div16_en.hw,
- [CLKID_SYS_PLL_DIV16] = &g12a_sys_pll_div16.hw,
- [CLKID_CPU_CLK_DYN0_SEL] = &g12a_cpu_clk_premux0.hw,
- [CLKID_CPU_CLK_DYN0_DIV] = &g12a_cpu_clk_mux0_div.hw,
- [CLKID_CPU_CLK_DYN0] = &g12a_cpu_clk_postmux0.hw,
- [CLKID_CPU_CLK_DYN1_SEL] = &g12a_cpu_clk_premux1.hw,
- [CLKID_CPU_CLK_DYN1_DIV] = &g12a_cpu_clk_mux1_div.hw,
- [CLKID_CPU_CLK_DYN1] = &g12a_cpu_clk_postmux1.hw,
- [CLKID_CPU_CLK_DYN] = &g12a_cpu_clk_dyn.hw,
- [CLKID_CPU_CLK] = &g12a_cpu_clk.hw,
- [CLKID_CPU_CLK_DIV16_EN] = &g12a_cpu_clk_div16_en.hw,
- [CLKID_CPU_CLK_DIV16] = &g12a_cpu_clk_div16.hw,
- [CLKID_CPU_CLK_APB_DIV] = &g12a_cpu_clk_apb_div.hw,
- [CLKID_CPU_CLK_APB] = &g12a_cpu_clk_apb.hw,
- [CLKID_CPU_CLK_ATB_DIV] = &g12a_cpu_clk_atb_div.hw,
- [CLKID_CPU_CLK_ATB] = &g12a_cpu_clk_atb.hw,
- [CLKID_CPU_CLK_AXI_DIV] = &g12a_cpu_clk_axi_div.hw,
- [CLKID_CPU_CLK_AXI] = &g12a_cpu_clk_axi.hw,
- [CLKID_CPU_CLK_TRACE_DIV] = &g12a_cpu_clk_trace_div.hw,
- [CLKID_CPU_CLK_TRACE] = &g12a_cpu_clk_trace.hw,
- [CLKID_PCIE_PLL_DCO] = &g12a_pcie_pll_dco.hw,
- [CLKID_PCIE_PLL_DCO_DIV2] = &g12a_pcie_pll_dco_div2.hw,
- [CLKID_PCIE_PLL_OD] = &g12a_pcie_pll_od.hw,
- [CLKID_PCIE_PLL] = &g12a_pcie_pll.hw,
- [CLKID_VDEC_1_SEL] = &g12a_vdec_1_sel.hw,
- [CLKID_VDEC_1_DIV] = &g12a_vdec_1_div.hw,
- [CLKID_VDEC_1] = &g12a_vdec_1.hw,
- [CLKID_VDEC_HEVC_SEL] = &g12a_vdec_hevc_sel.hw,
- [CLKID_VDEC_HEVC_DIV] = &g12a_vdec_hevc_div.hw,
- [CLKID_VDEC_HEVC] = &g12a_vdec_hevc.hw,
- [CLKID_VDEC_HEVCF_SEL] = &g12a_vdec_hevcf_sel.hw,
- [CLKID_VDEC_HEVCF_DIV] = &g12a_vdec_hevcf_div.hw,
- [CLKID_VDEC_HEVCF] = &g12a_vdec_hevcf.hw,
- [CLKID_TS_DIV] = &g12a_ts_div.hw,
- [CLKID_TS] = &g12a_ts.hw,
- [CLKID_SPICC0_SCLK_SEL] = &g12a_spicc0_sclk_sel.hw,
- [CLKID_SPICC0_SCLK_DIV] = &g12a_spicc0_sclk_div.hw,
- [CLKID_SPICC0_SCLK] = &g12a_spicc0_sclk.hw,
- [CLKID_SPICC1_SCLK_SEL] = &g12a_spicc1_sclk_sel.hw,
- [CLKID_SPICC1_SCLK_DIV] = &g12a_spicc1_sclk_div.hw,
- [CLKID_SPICC1_SCLK] = &g12a_spicc1_sclk.hw,
- [CLKID_MIPI_DSI_PXCLK_SEL] = &g12a_mipi_dsi_pxclk_sel.hw,
- [CLKID_MIPI_DSI_PXCLK_DIV] = &g12a_mipi_dsi_pxclk_div.hw,
- [CLKID_MIPI_DSI_PXCLK] = &g12a_mipi_dsi_pxclk.hw,
- [NR_CLKS] = NULL,
- },
- .num = NR_CLKS,
- };
- static struct clk_hw_onecell_data g12b_hw_onecell_data = {
- .hws = {
- [CLKID_SYS_PLL] = &g12a_sys_pll.hw,
- [CLKID_FIXED_PLL] = &g12a_fixed_pll.hw,
- [CLKID_FCLK_DIV2] = &g12a_fclk_div2.hw,
- [CLKID_FCLK_DIV3] = &g12a_fclk_div3.hw,
- [CLKID_FCLK_DIV4] = &g12a_fclk_div4.hw,
- [CLKID_FCLK_DIV5] = &g12a_fclk_div5.hw,
- [CLKID_FCLK_DIV7] = &g12a_fclk_div7.hw,
- [CLKID_FCLK_DIV2P5] = &g12a_fclk_div2p5.hw,
- [CLKID_GP0_PLL] = &g12a_gp0_pll.hw,
- [CLKID_MPEG_SEL] = &g12a_mpeg_clk_sel.hw,
- [CLKID_MPEG_DIV] = &g12a_mpeg_clk_div.hw,
- [CLKID_CLK81] = &g12a_clk81.hw,
- [CLKID_MPLL0] = &g12a_mpll0.hw,
- [CLKID_MPLL1] = &g12a_mpll1.hw,
- [CLKID_MPLL2] = &g12a_mpll2.hw,
- [CLKID_MPLL3] = &g12a_mpll3.hw,
- [CLKID_DDR] = &g12a_ddr.hw,
- [CLKID_DOS] = &g12a_dos.hw,
- [CLKID_AUDIO_LOCKER] = &g12a_audio_locker.hw,
- [CLKID_MIPI_DSI_HOST] = &g12a_mipi_dsi_host.hw,
- [CLKID_ETH_PHY] = &g12a_eth_phy.hw,
- [CLKID_ISA] = &g12a_isa.hw,
- [CLKID_PL301] = &g12a_pl301.hw,
- [CLKID_PERIPHS] = &g12a_periphs.hw,
- [CLKID_SPICC0] = &g12a_spicc_0.hw,
- [CLKID_I2C] = &g12a_i2c.hw,
- [CLKID_SANA] = &g12a_sana.hw,
- [CLKID_SD] = &g12a_sd.hw,
- [CLKID_RNG0] = &g12a_rng0.hw,
- [CLKID_UART0] = &g12a_uart0.hw,
- [CLKID_SPICC1] = &g12a_spicc_1.hw,
- [CLKID_HIU_IFACE] = &g12a_hiu_reg.hw,
- [CLKID_MIPI_DSI_PHY] = &g12a_mipi_dsi_phy.hw,
- [CLKID_ASSIST_MISC] = &g12a_assist_misc.hw,
- [CLKID_SD_EMMC_A] = &g12a_emmc_a.hw,
- [CLKID_SD_EMMC_B] = &g12a_emmc_b.hw,
- [CLKID_SD_EMMC_C] = &g12a_emmc_c.hw,
- [CLKID_AUDIO_CODEC] = &g12a_audio_codec.hw,
- [CLKID_AUDIO] = &g12a_audio.hw,
- [CLKID_ETH] = &g12a_eth_core.hw,
- [CLKID_DEMUX] = &g12a_demux.hw,
- [CLKID_AUDIO_IFIFO] = &g12a_audio_ififo.hw,
- [CLKID_ADC] = &g12a_adc.hw,
- [CLKID_UART1] = &g12a_uart1.hw,
- [CLKID_G2D] = &g12a_g2d.hw,
- [CLKID_RESET] = &g12a_reset.hw,
- [CLKID_PCIE_COMB] = &g12a_pcie_comb.hw,
- [CLKID_PARSER] = &g12a_parser.hw,
- [CLKID_USB] = &g12a_usb_general.hw,
- [CLKID_PCIE_PHY] = &g12a_pcie_phy.hw,
- [CLKID_AHB_ARB0] = &g12a_ahb_arb0.hw,
- [CLKID_AHB_DATA_BUS] = &g12a_ahb_data_bus.hw,
- [CLKID_AHB_CTRL_BUS] = &g12a_ahb_ctrl_bus.hw,
- [CLKID_HTX_HDCP22] = &g12a_htx_hdcp22.hw,
- [CLKID_HTX_PCLK] = &g12a_htx_pclk.hw,
- [CLKID_BT656] = &g12a_bt656.hw,
- [CLKID_USB1_DDR_BRIDGE] = &g12a_usb1_to_ddr.hw,
- [CLKID_MMC_PCLK] = &g12a_mmc_pclk.hw,
- [CLKID_UART2] = &g12a_uart2.hw,
- [CLKID_VPU_INTR] = &g12a_vpu_intr.hw,
- [CLKID_GIC] = &g12a_gic.hw,
- [CLKID_SD_EMMC_A_CLK0_SEL] = &g12a_sd_emmc_a_clk0_sel.hw,
- [CLKID_SD_EMMC_A_CLK0_DIV] = &g12a_sd_emmc_a_clk0_div.hw,
- [CLKID_SD_EMMC_A_CLK0] = &g12a_sd_emmc_a_clk0.hw,
- [CLKID_SD_EMMC_B_CLK0_SEL] = &g12a_sd_emmc_b_clk0_sel.hw,
- [CLKID_SD_EMMC_B_CLK0_DIV] = &g12a_sd_emmc_b_clk0_div.hw,
- [CLKID_SD_EMMC_B_CLK0] = &g12a_sd_emmc_b_clk0.hw,
- [CLKID_SD_EMMC_C_CLK0_SEL] = &g12a_sd_emmc_c_clk0_sel.hw,
- [CLKID_SD_EMMC_C_CLK0_DIV] = &g12a_sd_emmc_c_clk0_div.hw,
- [CLKID_SD_EMMC_C_CLK0] = &g12a_sd_emmc_c_clk0.hw,
- [CLKID_MPLL0_DIV] = &g12a_mpll0_div.hw,
- [CLKID_MPLL1_DIV] = &g12a_mpll1_div.hw,
- [CLKID_MPLL2_DIV] = &g12a_mpll2_div.hw,
- [CLKID_MPLL3_DIV] = &g12a_mpll3_div.hw,
- [CLKID_FCLK_DIV2_DIV] = &g12a_fclk_div2_div.hw,
- [CLKID_FCLK_DIV3_DIV] = &g12a_fclk_div3_div.hw,
- [CLKID_FCLK_DIV4_DIV] = &g12a_fclk_div4_div.hw,
- [CLKID_FCLK_DIV5_DIV] = &g12a_fclk_div5_div.hw,
- [CLKID_FCLK_DIV7_DIV] = &g12a_fclk_div7_div.hw,
- [CLKID_FCLK_DIV2P5_DIV] = &g12a_fclk_div2p5_div.hw,
- [CLKID_HIFI_PLL] = &g12a_hifi_pll.hw,
- [CLKID_VCLK2_VENCI0] = &g12a_vclk2_venci0.hw,
- [CLKID_VCLK2_VENCI1] = &g12a_vclk2_venci1.hw,
- [CLKID_VCLK2_VENCP0] = &g12a_vclk2_vencp0.hw,
- [CLKID_VCLK2_VENCP1] = &g12a_vclk2_vencp1.hw,
- [CLKID_VCLK2_VENCT0] = &g12a_vclk2_venct0.hw,
- [CLKID_VCLK2_VENCT1] = &g12a_vclk2_venct1.hw,
- [CLKID_VCLK2_OTHER] = &g12a_vclk2_other.hw,
- [CLKID_VCLK2_ENCI] = &g12a_vclk2_enci.hw,
- [CLKID_VCLK2_ENCP] = &g12a_vclk2_encp.hw,
- [CLKID_DAC_CLK] = &g12a_dac_clk.hw,
- [CLKID_AOCLK] = &g12a_aoclk_gate.hw,
- [CLKID_IEC958] = &g12a_iec958_gate.hw,
- [CLKID_ENC480P] = &g12a_enc480p.hw,
- [CLKID_RNG1] = &g12a_rng1.hw,
- [CLKID_VCLK2_ENCT] = &g12a_vclk2_enct.hw,
- [CLKID_VCLK2_ENCL] = &g12a_vclk2_encl.hw,
- [CLKID_VCLK2_VENCLMMC] = &g12a_vclk2_venclmmc.hw,
- [CLKID_VCLK2_VENCL] = &g12a_vclk2_vencl.hw,
- [CLKID_VCLK2_OTHER1] = &g12a_vclk2_other1.hw,
- [CLKID_FIXED_PLL_DCO] = &g12a_fixed_pll_dco.hw,
- [CLKID_SYS_PLL_DCO] = &g12a_sys_pll_dco.hw,
- [CLKID_GP0_PLL_DCO] = &g12a_gp0_pll_dco.hw,
- [CLKID_HIFI_PLL_DCO] = &g12a_hifi_pll_dco.hw,
- [CLKID_DMA] = &g12a_dma.hw,
- [CLKID_EFUSE] = &g12a_efuse.hw,
- [CLKID_ROM_BOOT] = &g12a_rom_boot.hw,
- [CLKID_RESET_SEC] = &g12a_reset_sec.hw,
- [CLKID_SEC_AHB_APB3] = &g12a_sec_ahb_apb3.hw,
- [CLKID_MPLL_PREDIV] = &g12a_mpll_prediv.hw,
- [CLKID_VPU_0_SEL] = &g12a_vpu_0_sel.hw,
- [CLKID_VPU_0_DIV] = &g12a_vpu_0_div.hw,
- [CLKID_VPU_0] = &g12a_vpu_0.hw,
- [CLKID_VPU_1_SEL] = &g12a_vpu_1_sel.hw,
- [CLKID_VPU_1_DIV] = &g12a_vpu_1_div.hw,
- [CLKID_VPU_1] = &g12a_vpu_1.hw,
- [CLKID_VPU] = &g12a_vpu.hw,
- [CLKID_VAPB_0_SEL] = &g12a_vapb_0_sel.hw,
- [CLKID_VAPB_0_DIV] = &g12a_vapb_0_div.hw,
- [CLKID_VAPB_0] = &g12a_vapb_0.hw,
- [CLKID_VAPB_1_SEL] = &g12a_vapb_1_sel.hw,
- [CLKID_VAPB_1_DIV] = &g12a_vapb_1_div.hw,
- [CLKID_VAPB_1] = &g12a_vapb_1.hw,
- [CLKID_VAPB_SEL] = &g12a_vapb_sel.hw,
- [CLKID_VAPB] = &g12a_vapb.hw,
- [CLKID_HDMI_PLL_DCO] = &g12a_hdmi_pll_dco.hw,
- [CLKID_HDMI_PLL_OD] = &g12a_hdmi_pll_od.hw,
- [CLKID_HDMI_PLL_OD2] = &g12a_hdmi_pll_od2.hw,
- [CLKID_HDMI_PLL] = &g12a_hdmi_pll.hw,
- [CLKID_VID_PLL] = &g12a_vid_pll_div.hw,
- [CLKID_VID_PLL_SEL] = &g12a_vid_pll_sel.hw,
- [CLKID_VID_PLL_DIV] = &g12a_vid_pll.hw,
- [CLKID_VCLK_SEL] = &g12a_vclk_sel.hw,
- [CLKID_VCLK2_SEL] = &g12a_vclk2_sel.hw,
- [CLKID_VCLK_INPUT] = &g12a_vclk_input.hw,
- [CLKID_VCLK2_INPUT] = &g12a_vclk2_input.hw,
- [CLKID_VCLK_DIV] = &g12a_vclk_div.hw,
- [CLKID_VCLK2_DIV] = &g12a_vclk2_div.hw,
- [CLKID_VCLK] = &g12a_vclk.hw,
- [CLKID_VCLK2] = &g12a_vclk2.hw,
- [CLKID_VCLK_DIV1] = &g12a_vclk_div1.hw,
- [CLKID_VCLK_DIV2_EN] = &g12a_vclk_div2_en.hw,
- [CLKID_VCLK_DIV4_EN] = &g12a_vclk_div4_en.hw,
- [CLKID_VCLK_DIV6_EN] = &g12a_vclk_div6_en.hw,
- [CLKID_VCLK_DIV12_EN] = &g12a_vclk_div12_en.hw,
- [CLKID_VCLK2_DIV1] = &g12a_vclk2_div1.hw,
- [CLKID_VCLK2_DIV2_EN] = &g12a_vclk2_div2_en.hw,
- [CLKID_VCLK2_DIV4_EN] = &g12a_vclk2_div4_en.hw,
- [CLKID_VCLK2_DIV6_EN] = &g12a_vclk2_div6_en.hw,
- [CLKID_VCLK2_DIV12_EN] = &g12a_vclk2_div12_en.hw,
- [CLKID_VCLK_DIV2] = &g12a_vclk_div2.hw,
- [CLKID_VCLK_DIV4] = &g12a_vclk_div4.hw,
- [CLKID_VCLK_DIV6] = &g12a_vclk_div6.hw,
- [CLKID_VCLK_DIV12] = &g12a_vclk_div12.hw,
- [CLKID_VCLK2_DIV2] = &g12a_vclk2_div2.hw,
- [CLKID_VCLK2_DIV4] = &g12a_vclk2_div4.hw,
- [CLKID_VCLK2_DIV6] = &g12a_vclk2_div6.hw,
- [CLKID_VCLK2_DIV12] = &g12a_vclk2_div12.hw,
- [CLKID_CTS_ENCI_SEL] = &g12a_cts_enci_sel.hw,
- [CLKID_CTS_ENCP_SEL] = &g12a_cts_encp_sel.hw,
- [CLKID_CTS_VDAC_SEL] = &g12a_cts_vdac_sel.hw,
- [CLKID_HDMI_TX_SEL] = &g12a_hdmi_tx_sel.hw,
- [CLKID_CTS_ENCI] = &g12a_cts_enci.hw,
- [CLKID_CTS_ENCP] = &g12a_cts_encp.hw,
- [CLKID_CTS_VDAC] = &g12a_cts_vdac.hw,
- [CLKID_HDMI_TX] = &g12a_hdmi_tx.hw,
- [CLKID_HDMI_SEL] = &g12a_hdmi_sel.hw,
- [CLKID_HDMI_DIV] = &g12a_hdmi_div.hw,
- [CLKID_HDMI] = &g12a_hdmi.hw,
- [CLKID_MALI_0_SEL] = &g12a_mali_0_sel.hw,
- [CLKID_MALI_0_DIV] = &g12a_mali_0_div.hw,
- [CLKID_MALI_0] = &g12a_mali_0.hw,
- [CLKID_MALI_1_SEL] = &g12a_mali_1_sel.hw,
- [CLKID_MALI_1_DIV] = &g12a_mali_1_div.hw,
- [CLKID_MALI_1] = &g12a_mali_1.hw,
- [CLKID_MALI] = &g12a_mali.hw,
- [CLKID_MPLL_50M_DIV] = &g12a_mpll_50m_div.hw,
- [CLKID_MPLL_50M] = &g12a_mpll_50m.hw,
- [CLKID_SYS_PLL_DIV16_EN] = &g12a_sys_pll_div16_en.hw,
- [CLKID_SYS_PLL_DIV16] = &g12a_sys_pll_div16.hw,
- [CLKID_CPU_CLK_DYN0_SEL] = &g12a_cpu_clk_premux0.hw,
- [CLKID_CPU_CLK_DYN0_DIV] = &g12a_cpu_clk_mux0_div.hw,
- [CLKID_CPU_CLK_DYN0] = &g12a_cpu_clk_postmux0.hw,
- [CLKID_CPU_CLK_DYN1_SEL] = &g12a_cpu_clk_premux1.hw,
- [CLKID_CPU_CLK_DYN1_DIV] = &g12a_cpu_clk_mux1_div.hw,
- [CLKID_CPU_CLK_DYN1] = &g12a_cpu_clk_postmux1.hw,
- [CLKID_CPU_CLK_DYN] = &g12a_cpu_clk_dyn.hw,
- [CLKID_CPU_CLK] = &g12b_cpu_clk.hw,
- [CLKID_CPU_CLK_DIV16_EN] = &g12a_cpu_clk_div16_en.hw,
- [CLKID_CPU_CLK_DIV16] = &g12a_cpu_clk_div16.hw,
- [CLKID_CPU_CLK_APB_DIV] = &g12a_cpu_clk_apb_div.hw,
- [CLKID_CPU_CLK_APB] = &g12a_cpu_clk_apb.hw,
- [CLKID_CPU_CLK_ATB_DIV] = &g12a_cpu_clk_atb_div.hw,
- [CLKID_CPU_CLK_ATB] = &g12a_cpu_clk_atb.hw,
- [CLKID_CPU_CLK_AXI_DIV] = &g12a_cpu_clk_axi_div.hw,
- [CLKID_CPU_CLK_AXI] = &g12a_cpu_clk_axi.hw,
- [CLKID_CPU_CLK_TRACE_DIV] = &g12a_cpu_clk_trace_div.hw,
- [CLKID_CPU_CLK_TRACE] = &g12a_cpu_clk_trace.hw,
- [CLKID_PCIE_PLL_DCO] = &g12a_pcie_pll_dco.hw,
- [CLKID_PCIE_PLL_DCO_DIV2] = &g12a_pcie_pll_dco_div2.hw,
- [CLKID_PCIE_PLL_OD] = &g12a_pcie_pll_od.hw,
- [CLKID_PCIE_PLL] = &g12a_pcie_pll.hw,
- [CLKID_VDEC_1_SEL] = &g12a_vdec_1_sel.hw,
- [CLKID_VDEC_1_DIV] = &g12a_vdec_1_div.hw,
- [CLKID_VDEC_1] = &g12a_vdec_1.hw,
- [CLKID_VDEC_HEVC_SEL] = &g12a_vdec_hevc_sel.hw,
- [CLKID_VDEC_HEVC_DIV] = &g12a_vdec_hevc_div.hw,
- [CLKID_VDEC_HEVC] = &g12a_vdec_hevc.hw,
- [CLKID_VDEC_HEVCF_SEL] = &g12a_vdec_hevcf_sel.hw,
- [CLKID_VDEC_HEVCF_DIV] = &g12a_vdec_hevcf_div.hw,
- [CLKID_VDEC_HEVCF] = &g12a_vdec_hevcf.hw,
- [CLKID_TS_DIV] = &g12a_ts_div.hw,
- [CLKID_TS] = &g12a_ts.hw,
- [CLKID_SYS1_PLL_DCO] = &g12b_sys1_pll_dco.hw,
- [CLKID_SYS1_PLL] = &g12b_sys1_pll.hw,
- [CLKID_SYS1_PLL_DIV16_EN] = &g12b_sys1_pll_div16_en.hw,
- [CLKID_SYS1_PLL_DIV16] = &g12b_sys1_pll_div16.hw,
- [CLKID_CPUB_CLK_DYN0_SEL] = &g12b_cpub_clk_premux0.hw,
- [CLKID_CPUB_CLK_DYN0_DIV] = &g12b_cpub_clk_mux0_div.hw,
- [CLKID_CPUB_CLK_DYN0] = &g12b_cpub_clk_postmux0.hw,
- [CLKID_CPUB_CLK_DYN1_SEL] = &g12b_cpub_clk_premux1.hw,
- [CLKID_CPUB_CLK_DYN1_DIV] = &g12b_cpub_clk_mux1_div.hw,
- [CLKID_CPUB_CLK_DYN1] = &g12b_cpub_clk_postmux1.hw,
- [CLKID_CPUB_CLK_DYN] = &g12b_cpub_clk_dyn.hw,
- [CLKID_CPUB_CLK] = &g12b_cpub_clk.hw,
- [CLKID_CPUB_CLK_DIV16_EN] = &g12b_cpub_clk_div16_en.hw,
- [CLKID_CPUB_CLK_DIV16] = &g12b_cpub_clk_div16.hw,
- [CLKID_CPUB_CLK_DIV2] = &g12b_cpub_clk_div2.hw,
- [CLKID_CPUB_CLK_DIV3] = &g12b_cpub_clk_div3.hw,
- [CLKID_CPUB_CLK_DIV4] = &g12b_cpub_clk_div4.hw,
- [CLKID_CPUB_CLK_DIV5] = &g12b_cpub_clk_div5.hw,
- [CLKID_CPUB_CLK_DIV6] = &g12b_cpub_clk_div6.hw,
- [CLKID_CPUB_CLK_DIV7] = &g12b_cpub_clk_div7.hw,
- [CLKID_CPUB_CLK_DIV8] = &g12b_cpub_clk_div8.hw,
- [CLKID_CPUB_CLK_APB_SEL] = &g12b_cpub_clk_apb_sel.hw,
- [CLKID_CPUB_CLK_APB] = &g12b_cpub_clk_apb.hw,
- [CLKID_CPUB_CLK_ATB_SEL] = &g12b_cpub_clk_atb_sel.hw,
- [CLKID_CPUB_CLK_ATB] = &g12b_cpub_clk_atb.hw,
- [CLKID_CPUB_CLK_AXI_SEL] = &g12b_cpub_clk_axi_sel.hw,
- [CLKID_CPUB_CLK_AXI] = &g12b_cpub_clk_axi.hw,
- [CLKID_CPUB_CLK_TRACE_SEL] = &g12b_cpub_clk_trace_sel.hw,
- [CLKID_CPUB_CLK_TRACE] = &g12b_cpub_clk_trace.hw,
- [CLKID_SPICC0_SCLK_SEL] = &g12a_spicc0_sclk_sel.hw,
- [CLKID_SPICC0_SCLK_DIV] = &g12a_spicc0_sclk_div.hw,
- [CLKID_SPICC0_SCLK] = &g12a_spicc0_sclk.hw,
- [CLKID_SPICC1_SCLK_SEL] = &g12a_spicc1_sclk_sel.hw,
- [CLKID_SPICC1_SCLK_DIV] = &g12a_spicc1_sclk_div.hw,
- [CLKID_SPICC1_SCLK] = &g12a_spicc1_sclk.hw,
- [CLKID_NNA_AXI_CLK_SEL] = &sm1_nna_axi_clk_sel.hw,
- [CLKID_NNA_AXI_CLK_DIV] = &sm1_nna_axi_clk_div.hw,
- [CLKID_NNA_AXI_CLK] = &sm1_nna_axi_clk.hw,
- [CLKID_NNA_CORE_CLK_SEL] = &sm1_nna_core_clk_sel.hw,
- [CLKID_NNA_CORE_CLK_DIV] = &sm1_nna_core_clk_div.hw,
- [CLKID_NNA_CORE_CLK] = &sm1_nna_core_clk.hw,
- [CLKID_MIPI_DSI_PXCLK_SEL] = &g12a_mipi_dsi_pxclk_sel.hw,
- [CLKID_MIPI_DSI_PXCLK_DIV] = &g12a_mipi_dsi_pxclk_div.hw,
- [CLKID_MIPI_DSI_PXCLK] = &g12a_mipi_dsi_pxclk.hw,
- [NR_CLKS] = NULL,
- },
- .num = NR_CLKS,
- };
- static struct clk_hw_onecell_data sm1_hw_onecell_data = {
- .hws = {
- [CLKID_SYS_PLL] = &g12a_sys_pll.hw,
- [CLKID_FIXED_PLL] = &g12a_fixed_pll.hw,
- [CLKID_FCLK_DIV2] = &g12a_fclk_div2.hw,
- [CLKID_FCLK_DIV3] = &g12a_fclk_div3.hw,
- [CLKID_FCLK_DIV4] = &g12a_fclk_div4.hw,
- [CLKID_FCLK_DIV5] = &g12a_fclk_div5.hw,
- [CLKID_FCLK_DIV7] = &g12a_fclk_div7.hw,
- [CLKID_FCLK_DIV2P5] = &g12a_fclk_div2p5.hw,
- [CLKID_GP0_PLL] = &g12a_gp0_pll.hw,
- [CLKID_MPEG_SEL] = &g12a_mpeg_clk_sel.hw,
- [CLKID_MPEG_DIV] = &g12a_mpeg_clk_div.hw,
- [CLKID_CLK81] = &g12a_clk81.hw,
- [CLKID_MPLL0] = &g12a_mpll0.hw,
- [CLKID_MPLL1] = &g12a_mpll1.hw,
- [CLKID_MPLL2] = &g12a_mpll2.hw,
- [CLKID_MPLL3] = &g12a_mpll3.hw,
- [CLKID_DDR] = &g12a_ddr.hw,
- [CLKID_DOS] = &g12a_dos.hw,
- [CLKID_AUDIO_LOCKER] = &g12a_audio_locker.hw,
- [CLKID_MIPI_DSI_HOST] = &g12a_mipi_dsi_host.hw,
- [CLKID_ETH_PHY] = &g12a_eth_phy.hw,
- [CLKID_ISA] = &g12a_isa.hw,
- [CLKID_PL301] = &g12a_pl301.hw,
- [CLKID_PERIPHS] = &g12a_periphs.hw,
- [CLKID_SPICC0] = &g12a_spicc_0.hw,
- [CLKID_I2C] = &g12a_i2c.hw,
- [CLKID_SANA] = &g12a_sana.hw,
- [CLKID_SD] = &g12a_sd.hw,
- [CLKID_RNG0] = &g12a_rng0.hw,
- [CLKID_UART0] = &g12a_uart0.hw,
- [CLKID_SPICC1] = &g12a_spicc_1.hw,
- [CLKID_HIU_IFACE] = &g12a_hiu_reg.hw,
- [CLKID_MIPI_DSI_PHY] = &g12a_mipi_dsi_phy.hw,
- [CLKID_ASSIST_MISC] = &g12a_assist_misc.hw,
- [CLKID_SD_EMMC_A] = &g12a_emmc_a.hw,
- [CLKID_SD_EMMC_B] = &g12a_emmc_b.hw,
- [CLKID_SD_EMMC_C] = &g12a_emmc_c.hw,
- [CLKID_AUDIO_CODEC] = &g12a_audio_codec.hw,
- [CLKID_AUDIO] = &g12a_audio.hw,
- [CLKID_ETH] = &g12a_eth_core.hw,
- [CLKID_DEMUX] = &g12a_demux.hw,
- [CLKID_AUDIO_IFIFO] = &g12a_audio_ififo.hw,
- [CLKID_ADC] = &g12a_adc.hw,
- [CLKID_UART1] = &g12a_uart1.hw,
- [CLKID_G2D] = &g12a_g2d.hw,
- [CLKID_RESET] = &g12a_reset.hw,
- [CLKID_PCIE_COMB] = &g12a_pcie_comb.hw,
- [CLKID_PARSER] = &g12a_parser.hw,
- [CLKID_USB] = &g12a_usb_general.hw,
- [CLKID_PCIE_PHY] = &g12a_pcie_phy.hw,
- [CLKID_AHB_ARB0] = &g12a_ahb_arb0.hw,
- [CLKID_AHB_DATA_BUS] = &g12a_ahb_data_bus.hw,
- [CLKID_AHB_CTRL_BUS] = &g12a_ahb_ctrl_bus.hw,
- [CLKID_HTX_HDCP22] = &g12a_htx_hdcp22.hw,
- [CLKID_HTX_PCLK] = &g12a_htx_pclk.hw,
- [CLKID_BT656] = &g12a_bt656.hw,
- [CLKID_USB1_DDR_BRIDGE] = &g12a_usb1_to_ddr.hw,
- [CLKID_MMC_PCLK] = &g12a_mmc_pclk.hw,
- [CLKID_UART2] = &g12a_uart2.hw,
- [CLKID_VPU_INTR] = &g12a_vpu_intr.hw,
- [CLKID_GIC] = &g12a_gic.hw,
- [CLKID_SD_EMMC_A_CLK0_SEL] = &g12a_sd_emmc_a_clk0_sel.hw,
- [CLKID_SD_EMMC_A_CLK0_DIV] = &g12a_sd_emmc_a_clk0_div.hw,
- [CLKID_SD_EMMC_A_CLK0] = &g12a_sd_emmc_a_clk0.hw,
- [CLKID_SD_EMMC_B_CLK0_SEL] = &g12a_sd_emmc_b_clk0_sel.hw,
- [CLKID_SD_EMMC_B_CLK0_DIV] = &g12a_sd_emmc_b_clk0_div.hw,
- [CLKID_SD_EMMC_B_CLK0] = &g12a_sd_emmc_b_clk0.hw,
- [CLKID_SD_EMMC_C_CLK0_SEL] = &g12a_sd_emmc_c_clk0_sel.hw,
- [CLKID_SD_EMMC_C_CLK0_DIV] = &g12a_sd_emmc_c_clk0_div.hw,
- [CLKID_SD_EMMC_C_CLK0] = &g12a_sd_emmc_c_clk0.hw,
- [CLKID_MPLL0_DIV] = &g12a_mpll0_div.hw,
- [CLKID_MPLL1_DIV] = &g12a_mpll1_div.hw,
- [CLKID_MPLL2_DIV] = &g12a_mpll2_div.hw,
- [CLKID_MPLL3_DIV] = &g12a_mpll3_div.hw,
- [CLKID_FCLK_DIV2_DIV] = &g12a_fclk_div2_div.hw,
- [CLKID_FCLK_DIV3_DIV] = &g12a_fclk_div3_div.hw,
- [CLKID_FCLK_DIV4_DIV] = &g12a_fclk_div4_div.hw,
- [CLKID_FCLK_DIV5_DIV] = &g12a_fclk_div5_div.hw,
- [CLKID_FCLK_DIV7_DIV] = &g12a_fclk_div7_div.hw,
- [CLKID_FCLK_DIV2P5_DIV] = &g12a_fclk_div2p5_div.hw,
- [CLKID_HIFI_PLL] = &g12a_hifi_pll.hw,
- [CLKID_VCLK2_VENCI0] = &g12a_vclk2_venci0.hw,
- [CLKID_VCLK2_VENCI1] = &g12a_vclk2_venci1.hw,
- [CLKID_VCLK2_VENCP0] = &g12a_vclk2_vencp0.hw,
- [CLKID_VCLK2_VENCP1] = &g12a_vclk2_vencp1.hw,
- [CLKID_VCLK2_VENCT0] = &g12a_vclk2_venct0.hw,
- [CLKID_VCLK2_VENCT1] = &g12a_vclk2_venct1.hw,
- [CLKID_VCLK2_OTHER] = &g12a_vclk2_other.hw,
- [CLKID_VCLK2_ENCI] = &g12a_vclk2_enci.hw,
- [CLKID_VCLK2_ENCP] = &g12a_vclk2_encp.hw,
- [CLKID_DAC_CLK] = &g12a_dac_clk.hw,
- [CLKID_AOCLK] = &g12a_aoclk_gate.hw,
- [CLKID_IEC958] = &g12a_iec958_gate.hw,
- [CLKID_ENC480P] = &g12a_enc480p.hw,
- [CLKID_RNG1] = &g12a_rng1.hw,
- [CLKID_VCLK2_ENCT] = &g12a_vclk2_enct.hw,
- [CLKID_VCLK2_ENCL] = &g12a_vclk2_encl.hw,
- [CLKID_VCLK2_VENCLMMC] = &g12a_vclk2_venclmmc.hw,
- [CLKID_VCLK2_VENCL] = &g12a_vclk2_vencl.hw,
- [CLKID_VCLK2_OTHER1] = &g12a_vclk2_other1.hw,
- [CLKID_FIXED_PLL_DCO] = &g12a_fixed_pll_dco.hw,
- [CLKID_SYS_PLL_DCO] = &g12a_sys_pll_dco.hw,
- [CLKID_GP0_PLL_DCO] = &g12a_gp0_pll_dco.hw,
- [CLKID_HIFI_PLL_DCO] = &g12a_hifi_pll_dco.hw,
- [CLKID_DMA] = &g12a_dma.hw,
- [CLKID_EFUSE] = &g12a_efuse.hw,
- [CLKID_ROM_BOOT] = &g12a_rom_boot.hw,
- [CLKID_RESET_SEC] = &g12a_reset_sec.hw,
- [CLKID_SEC_AHB_APB3] = &g12a_sec_ahb_apb3.hw,
- [CLKID_MPLL_PREDIV] = &g12a_mpll_prediv.hw,
- [CLKID_VPU_0_SEL] = &g12a_vpu_0_sel.hw,
- [CLKID_VPU_0_DIV] = &g12a_vpu_0_div.hw,
- [CLKID_VPU_0] = &g12a_vpu_0.hw,
- [CLKID_VPU_1_SEL] = &g12a_vpu_1_sel.hw,
- [CLKID_VPU_1_DIV] = &g12a_vpu_1_div.hw,
- [CLKID_VPU_1] = &g12a_vpu_1.hw,
- [CLKID_VPU] = &g12a_vpu.hw,
- [CLKID_VAPB_0_SEL] = &g12a_vapb_0_sel.hw,
- [CLKID_VAPB_0_DIV] = &g12a_vapb_0_div.hw,
- [CLKID_VAPB_0] = &g12a_vapb_0.hw,
- [CLKID_VAPB_1_SEL] = &g12a_vapb_1_sel.hw,
- [CLKID_VAPB_1_DIV] = &g12a_vapb_1_div.hw,
- [CLKID_VAPB_1] = &g12a_vapb_1.hw,
- [CLKID_VAPB_SEL] = &g12a_vapb_sel.hw,
- [CLKID_VAPB] = &g12a_vapb.hw,
- [CLKID_HDMI_PLL_DCO] = &g12a_hdmi_pll_dco.hw,
- [CLKID_HDMI_PLL_OD] = &g12a_hdmi_pll_od.hw,
- [CLKID_HDMI_PLL_OD2] = &g12a_hdmi_pll_od2.hw,
- [CLKID_HDMI_PLL] = &g12a_hdmi_pll.hw,
- [CLKID_VID_PLL] = &g12a_vid_pll_div.hw,
- [CLKID_VID_PLL_SEL] = &g12a_vid_pll_sel.hw,
- [CLKID_VID_PLL_DIV] = &g12a_vid_pll.hw,
- [CLKID_VCLK_SEL] = &g12a_vclk_sel.hw,
- [CLKID_VCLK2_SEL] = &g12a_vclk2_sel.hw,
- [CLKID_VCLK_INPUT] = &g12a_vclk_input.hw,
- [CLKID_VCLK2_INPUT] = &g12a_vclk2_input.hw,
- [CLKID_VCLK_DIV] = &g12a_vclk_div.hw,
- [CLKID_VCLK2_DIV] = &g12a_vclk2_div.hw,
- [CLKID_VCLK] = &g12a_vclk.hw,
- [CLKID_VCLK2] = &g12a_vclk2.hw,
- [CLKID_VCLK_DIV1] = &g12a_vclk_div1.hw,
- [CLKID_VCLK_DIV2_EN] = &g12a_vclk_div2_en.hw,
- [CLKID_VCLK_DIV4_EN] = &g12a_vclk_div4_en.hw,
- [CLKID_VCLK_DIV6_EN] = &g12a_vclk_div6_en.hw,
- [CLKID_VCLK_DIV12_EN] = &g12a_vclk_div12_en.hw,
- [CLKID_VCLK2_DIV1] = &g12a_vclk2_div1.hw,
- [CLKID_VCLK2_DIV2_EN] = &g12a_vclk2_div2_en.hw,
- [CLKID_VCLK2_DIV4_EN] = &g12a_vclk2_div4_en.hw,
- [CLKID_VCLK2_DIV6_EN] = &g12a_vclk2_div6_en.hw,
- [CLKID_VCLK2_DIV12_EN] = &g12a_vclk2_div12_en.hw,
- [CLKID_VCLK_DIV2] = &g12a_vclk_div2.hw,
- [CLKID_VCLK_DIV4] = &g12a_vclk_div4.hw,
- [CLKID_VCLK_DIV6] = &g12a_vclk_div6.hw,
- [CLKID_VCLK_DIV12] = &g12a_vclk_div12.hw,
- [CLKID_VCLK2_DIV2] = &g12a_vclk2_div2.hw,
- [CLKID_VCLK2_DIV4] = &g12a_vclk2_div4.hw,
- [CLKID_VCLK2_DIV6] = &g12a_vclk2_div6.hw,
- [CLKID_VCLK2_DIV12] = &g12a_vclk2_div12.hw,
- [CLKID_CTS_ENCI_SEL] = &g12a_cts_enci_sel.hw,
- [CLKID_CTS_ENCP_SEL] = &g12a_cts_encp_sel.hw,
- [CLKID_CTS_VDAC_SEL] = &g12a_cts_vdac_sel.hw,
- [CLKID_HDMI_TX_SEL] = &g12a_hdmi_tx_sel.hw,
- [CLKID_CTS_ENCI] = &g12a_cts_enci.hw,
- [CLKID_CTS_ENCP] = &g12a_cts_encp.hw,
- [CLKID_CTS_VDAC] = &g12a_cts_vdac.hw,
- [CLKID_HDMI_TX] = &g12a_hdmi_tx.hw,
- [CLKID_HDMI_SEL] = &g12a_hdmi_sel.hw,
- [CLKID_HDMI_DIV] = &g12a_hdmi_div.hw,
- [CLKID_HDMI] = &g12a_hdmi.hw,
- [CLKID_MALI_0_SEL] = &g12a_mali_0_sel.hw,
- [CLKID_MALI_0_DIV] = &g12a_mali_0_div.hw,
- [CLKID_MALI_0] = &g12a_mali_0.hw,
- [CLKID_MALI_1_SEL] = &g12a_mali_1_sel.hw,
- [CLKID_MALI_1_DIV] = &g12a_mali_1_div.hw,
- [CLKID_MALI_1] = &g12a_mali_1.hw,
- [CLKID_MALI] = &g12a_mali.hw,
- [CLKID_MPLL_50M_DIV] = &g12a_mpll_50m_div.hw,
- [CLKID_MPLL_50M] = &g12a_mpll_50m.hw,
- [CLKID_SYS_PLL_DIV16_EN] = &g12a_sys_pll_div16_en.hw,
- [CLKID_SYS_PLL_DIV16] = &g12a_sys_pll_div16.hw,
- [CLKID_CPU_CLK_DYN0_SEL] = &g12a_cpu_clk_premux0.hw,
- [CLKID_CPU_CLK_DYN0_DIV] = &g12a_cpu_clk_mux0_div.hw,
- [CLKID_CPU_CLK_DYN0] = &g12a_cpu_clk_postmux0.hw,
- [CLKID_CPU_CLK_DYN1_SEL] = &g12a_cpu_clk_premux1.hw,
- [CLKID_CPU_CLK_DYN1_DIV] = &g12a_cpu_clk_mux1_div.hw,
- [CLKID_CPU_CLK_DYN1] = &g12a_cpu_clk_postmux1.hw,
- [CLKID_CPU_CLK_DYN] = &g12a_cpu_clk_dyn.hw,
- [CLKID_CPU_CLK] = &g12a_cpu_clk.hw,
- [CLKID_CPU_CLK_DIV16_EN] = &g12a_cpu_clk_div16_en.hw,
- [CLKID_CPU_CLK_DIV16] = &g12a_cpu_clk_div16.hw,
- [CLKID_CPU_CLK_APB_DIV] = &g12a_cpu_clk_apb_div.hw,
- [CLKID_CPU_CLK_APB] = &g12a_cpu_clk_apb.hw,
- [CLKID_CPU_CLK_ATB_DIV] = &g12a_cpu_clk_atb_div.hw,
- [CLKID_CPU_CLK_ATB] = &g12a_cpu_clk_atb.hw,
- [CLKID_CPU_CLK_AXI_DIV] = &g12a_cpu_clk_axi_div.hw,
- [CLKID_CPU_CLK_AXI] = &g12a_cpu_clk_axi.hw,
- [CLKID_CPU_CLK_TRACE_DIV] = &g12a_cpu_clk_trace_div.hw,
- [CLKID_CPU_CLK_TRACE] = &g12a_cpu_clk_trace.hw,
- [CLKID_PCIE_PLL_DCO] = &g12a_pcie_pll_dco.hw,
- [CLKID_PCIE_PLL_DCO_DIV2] = &g12a_pcie_pll_dco_div2.hw,
- [CLKID_PCIE_PLL_OD] = &g12a_pcie_pll_od.hw,
- [CLKID_PCIE_PLL] = &g12a_pcie_pll.hw,
- [CLKID_VDEC_1_SEL] = &g12a_vdec_1_sel.hw,
- [CLKID_VDEC_1_DIV] = &g12a_vdec_1_div.hw,
- [CLKID_VDEC_1] = &g12a_vdec_1.hw,
- [CLKID_VDEC_HEVC_SEL] = &g12a_vdec_hevc_sel.hw,
- [CLKID_VDEC_HEVC_DIV] = &g12a_vdec_hevc_div.hw,
- [CLKID_VDEC_HEVC] = &g12a_vdec_hevc.hw,
- [CLKID_VDEC_HEVCF_SEL] = &g12a_vdec_hevcf_sel.hw,
- [CLKID_VDEC_HEVCF_DIV] = &g12a_vdec_hevcf_div.hw,
- [CLKID_VDEC_HEVCF] = &g12a_vdec_hevcf.hw,
- [CLKID_TS_DIV] = &g12a_ts_div.hw,
- [CLKID_TS] = &g12a_ts.hw,
- [CLKID_GP1_PLL_DCO] = &sm1_gp1_pll_dco.hw,
- [CLKID_GP1_PLL] = &sm1_gp1_pll.hw,
- [CLKID_DSU_CLK_DYN0_SEL] = &sm1_dsu_clk_premux0.hw,
- [CLKID_DSU_CLK_DYN0_DIV] = &sm1_dsu_clk_premux1.hw,
- [CLKID_DSU_CLK_DYN0] = &sm1_dsu_clk_mux0_div.hw,
- [CLKID_DSU_CLK_DYN1_SEL] = &sm1_dsu_clk_postmux0.hw,
- [CLKID_DSU_CLK_DYN1_DIV] = &sm1_dsu_clk_mux1_div.hw,
- [CLKID_DSU_CLK_DYN1] = &sm1_dsu_clk_postmux1.hw,
- [CLKID_DSU_CLK_DYN] = &sm1_dsu_clk_dyn.hw,
- [CLKID_DSU_CLK_FINAL] = &sm1_dsu_final_clk.hw,
- [CLKID_DSU_CLK] = &sm1_dsu_clk.hw,
- [CLKID_CPU1_CLK] = &sm1_cpu1_clk.hw,
- [CLKID_CPU2_CLK] = &sm1_cpu2_clk.hw,
- [CLKID_CPU3_CLK] = &sm1_cpu3_clk.hw,
- [CLKID_SPICC0_SCLK_SEL] = &g12a_spicc0_sclk_sel.hw,
- [CLKID_SPICC0_SCLK_DIV] = &g12a_spicc0_sclk_div.hw,
- [CLKID_SPICC0_SCLK] = &g12a_spicc0_sclk.hw,
- [CLKID_SPICC1_SCLK_SEL] = &g12a_spicc1_sclk_sel.hw,
- [CLKID_SPICC1_SCLK_DIV] = &g12a_spicc1_sclk_div.hw,
- [CLKID_SPICC1_SCLK] = &g12a_spicc1_sclk.hw,
- [CLKID_NNA_AXI_CLK_SEL] = &sm1_nna_axi_clk_sel.hw,
- [CLKID_NNA_AXI_CLK_DIV] = &sm1_nna_axi_clk_div.hw,
- [CLKID_NNA_AXI_CLK] = &sm1_nna_axi_clk.hw,
- [CLKID_NNA_CORE_CLK_SEL] = &sm1_nna_core_clk_sel.hw,
- [CLKID_NNA_CORE_CLK_DIV] = &sm1_nna_core_clk_div.hw,
- [CLKID_NNA_CORE_CLK] = &sm1_nna_core_clk.hw,
- [CLKID_MIPI_DSI_PXCLK_SEL] = &g12a_mipi_dsi_pxclk_sel.hw,
- [CLKID_MIPI_DSI_PXCLK_DIV] = &g12a_mipi_dsi_pxclk_div.hw,
- [CLKID_MIPI_DSI_PXCLK] = &g12a_mipi_dsi_pxclk.hw,
- [NR_CLKS] = NULL,
- },
- .num = NR_CLKS,
- };
- /* Convenience table to populate regmap in .probe */
- static struct clk_regmap *const g12a_clk_regmaps[] = {
- &g12a_clk81,
- &g12a_dos,
- &g12a_ddr,
- &g12a_audio_locker,
- &g12a_mipi_dsi_host,
- &g12a_eth_phy,
- &g12a_isa,
- &g12a_pl301,
- &g12a_periphs,
- &g12a_spicc_0,
- &g12a_i2c,
- &g12a_sana,
- &g12a_sd,
- &g12a_rng0,
- &g12a_uart0,
- &g12a_spicc_1,
- &g12a_hiu_reg,
- &g12a_mipi_dsi_phy,
- &g12a_assist_misc,
- &g12a_emmc_a,
- &g12a_emmc_b,
- &g12a_emmc_c,
- &g12a_audio_codec,
- &g12a_audio,
- &g12a_eth_core,
- &g12a_demux,
- &g12a_audio_ififo,
- &g12a_adc,
- &g12a_uart1,
- &g12a_g2d,
- &g12a_reset,
- &g12a_pcie_comb,
- &g12a_parser,
- &g12a_usb_general,
- &g12a_pcie_phy,
- &g12a_ahb_arb0,
- &g12a_ahb_data_bus,
- &g12a_ahb_ctrl_bus,
- &g12a_htx_hdcp22,
- &g12a_htx_pclk,
- &g12a_bt656,
- &g12a_usb1_to_ddr,
- &g12a_mmc_pclk,
- &g12a_uart2,
- &g12a_vpu_intr,
- &g12a_gic,
- &g12a_sd_emmc_a_clk0,
- &g12a_sd_emmc_b_clk0,
- &g12a_sd_emmc_c_clk0,
- &g12a_mpeg_clk_div,
- &g12a_sd_emmc_a_clk0_div,
- &g12a_sd_emmc_b_clk0_div,
- &g12a_sd_emmc_c_clk0_div,
- &g12a_mpeg_clk_sel,
- &g12a_sd_emmc_a_clk0_sel,
- &g12a_sd_emmc_b_clk0_sel,
- &g12a_sd_emmc_c_clk0_sel,
- &g12a_mpll0,
- &g12a_mpll1,
- &g12a_mpll2,
- &g12a_mpll3,
- &g12a_mpll0_div,
- &g12a_mpll1_div,
- &g12a_mpll2_div,
- &g12a_mpll3_div,
- &g12a_fixed_pll,
- &g12a_sys_pll,
- &g12a_gp0_pll,
- &g12a_hifi_pll,
- &g12a_vclk2_venci0,
- &g12a_vclk2_venci1,
- &g12a_vclk2_vencp0,
- &g12a_vclk2_vencp1,
- &g12a_vclk2_venct0,
- &g12a_vclk2_venct1,
- &g12a_vclk2_other,
- &g12a_vclk2_enci,
- &g12a_vclk2_encp,
- &g12a_dac_clk,
- &g12a_aoclk_gate,
- &g12a_iec958_gate,
- &g12a_enc480p,
- &g12a_rng1,
- &g12a_vclk2_enct,
- &g12a_vclk2_encl,
- &g12a_vclk2_venclmmc,
- &g12a_vclk2_vencl,
- &g12a_vclk2_other1,
- &g12a_fixed_pll_dco,
- &g12a_sys_pll_dco,
- &g12a_gp0_pll_dco,
- &g12a_hifi_pll_dco,
- &g12a_fclk_div2,
- &g12a_fclk_div3,
- &g12a_fclk_div4,
- &g12a_fclk_div5,
- &g12a_fclk_div7,
- &g12a_fclk_div2p5,
- &g12a_dma,
- &g12a_efuse,
- &g12a_rom_boot,
- &g12a_reset_sec,
- &g12a_sec_ahb_apb3,
- &g12a_vpu_0_sel,
- &g12a_vpu_0_div,
- &g12a_vpu_0,
- &g12a_vpu_1_sel,
- &g12a_vpu_1_div,
- &g12a_vpu_1,
- &g12a_vpu,
- &g12a_vapb_0_sel,
- &g12a_vapb_0_div,
- &g12a_vapb_0,
- &g12a_vapb_1_sel,
- &g12a_vapb_1_div,
- &g12a_vapb_1,
- &g12a_vapb_sel,
- &g12a_vapb,
- &g12a_hdmi_pll_dco,
- &g12a_hdmi_pll_od,
- &g12a_hdmi_pll_od2,
- &g12a_hdmi_pll,
- &g12a_vid_pll_div,
- &g12a_vid_pll_sel,
- &g12a_vid_pll,
- &g12a_vclk_sel,
- &g12a_vclk2_sel,
- &g12a_vclk_input,
- &g12a_vclk2_input,
- &g12a_vclk_div,
- &g12a_vclk2_div,
- &g12a_vclk,
- &g12a_vclk2,
- &g12a_vclk_div1,
- &g12a_vclk_div2_en,
- &g12a_vclk_div4_en,
- &g12a_vclk_div6_en,
- &g12a_vclk_div12_en,
- &g12a_vclk2_div1,
- &g12a_vclk2_div2_en,
- &g12a_vclk2_div4_en,
- &g12a_vclk2_div6_en,
- &g12a_vclk2_div12_en,
- &g12a_cts_enci_sel,
- &g12a_cts_encp_sel,
- &g12a_cts_vdac_sel,
- &g12a_hdmi_tx_sel,
- &g12a_cts_enci,
- &g12a_cts_encp,
- &g12a_cts_vdac,
- &g12a_hdmi_tx,
- &g12a_hdmi_sel,
- &g12a_hdmi_div,
- &g12a_hdmi,
- &g12a_mali_0_sel,
- &g12a_mali_0_div,
- &g12a_mali_0,
- &g12a_mali_1_sel,
- &g12a_mali_1_div,
- &g12a_mali_1,
- &g12a_mali,
- &g12a_mpll_50m,
- &g12a_sys_pll_div16_en,
- &g12a_cpu_clk_premux0,
- &g12a_cpu_clk_mux0_div,
- &g12a_cpu_clk_postmux0,
- &g12a_cpu_clk_premux1,
- &g12a_cpu_clk_mux1_div,
- &g12a_cpu_clk_postmux1,
- &g12a_cpu_clk_dyn,
- &g12a_cpu_clk,
- &g12a_cpu_clk_div16_en,
- &g12a_cpu_clk_apb_div,
- &g12a_cpu_clk_apb,
- &g12a_cpu_clk_atb_div,
- &g12a_cpu_clk_atb,
- &g12a_cpu_clk_axi_div,
- &g12a_cpu_clk_axi,
- &g12a_cpu_clk_trace_div,
- &g12a_cpu_clk_trace,
- &g12a_pcie_pll_od,
- &g12a_pcie_pll_dco,
- &g12a_vdec_1_sel,
- &g12a_vdec_1_div,
- &g12a_vdec_1,
- &g12a_vdec_hevc_sel,
- &g12a_vdec_hevc_div,
- &g12a_vdec_hevc,
- &g12a_vdec_hevcf_sel,
- &g12a_vdec_hevcf_div,
- &g12a_vdec_hevcf,
- &g12a_ts_div,
- &g12a_ts,
- &g12b_cpu_clk,
- &g12b_sys1_pll_dco,
- &g12b_sys1_pll,
- &g12b_sys1_pll_div16_en,
- &g12b_cpub_clk_premux0,
- &g12b_cpub_clk_mux0_div,
- &g12b_cpub_clk_postmux0,
- &g12b_cpub_clk_premux1,
- &g12b_cpub_clk_mux1_div,
- &g12b_cpub_clk_postmux1,
- &g12b_cpub_clk_dyn,
- &g12b_cpub_clk,
- &g12b_cpub_clk_div16_en,
- &g12b_cpub_clk_apb_sel,
- &g12b_cpub_clk_apb,
- &g12b_cpub_clk_atb_sel,
- &g12b_cpub_clk_atb,
- &g12b_cpub_clk_axi_sel,
- &g12b_cpub_clk_axi,
- &g12b_cpub_clk_trace_sel,
- &g12b_cpub_clk_trace,
- &sm1_gp1_pll_dco,
- &sm1_gp1_pll,
- &sm1_dsu_clk_premux0,
- &sm1_dsu_clk_premux1,
- &sm1_dsu_clk_mux0_div,
- &sm1_dsu_clk_postmux0,
- &sm1_dsu_clk_mux1_div,
- &sm1_dsu_clk_postmux1,
- &sm1_dsu_clk_dyn,
- &sm1_dsu_final_clk,
- &sm1_dsu_clk,
- &sm1_cpu1_clk,
- &sm1_cpu2_clk,
- &sm1_cpu3_clk,
- &g12a_spicc0_sclk_sel,
- &g12a_spicc0_sclk_div,
- &g12a_spicc0_sclk,
- &g12a_spicc1_sclk_sel,
- &g12a_spicc1_sclk_div,
- &g12a_spicc1_sclk,
- &sm1_nna_axi_clk_sel,
- &sm1_nna_axi_clk_div,
- &sm1_nna_axi_clk,
- &sm1_nna_core_clk_sel,
- &sm1_nna_core_clk_div,
- &sm1_nna_core_clk,
- &g12a_mipi_dsi_pxclk_sel,
- &g12a_mipi_dsi_pxclk_div,
- &g12a_mipi_dsi_pxclk,
- };
- static const struct reg_sequence g12a_init_regs[] = {
- { .reg = HHI_MPLL_CNTL0, .def = 0x00000543 },
- };
- #define DVFS_CON_ID "dvfs"
- static int meson_g12a_dvfs_setup_common(struct device *dev,
- struct clk_hw **hws)
- {
- struct clk *notifier_clk;
- struct clk_hw *xtal;
- int ret;
- xtal = clk_hw_get_parent_by_index(hws[CLKID_CPU_CLK_DYN1_SEL], 0);
- /* Setup clock notifier for cpu_clk_postmux0 */
- g12a_cpu_clk_postmux0_nb_data.xtal = xtal;
- notifier_clk = devm_clk_hw_get_clk(dev, &g12a_cpu_clk_postmux0.hw,
- DVFS_CON_ID);
- ret = devm_clk_notifier_register(dev, notifier_clk,
- &g12a_cpu_clk_postmux0_nb_data.nb);
- if (ret) {
- dev_err(dev, "failed to register the cpu_clk_postmux0 notifier\n");
- return ret;
- }
- /* Setup clock notifier for cpu_clk_dyn mux */
- notifier_clk = devm_clk_hw_get_clk(dev, &g12a_cpu_clk_dyn.hw,
- DVFS_CON_ID);
- ret = devm_clk_notifier_register(dev, notifier_clk,
- &g12a_cpu_clk_mux_nb);
- if (ret) {
- dev_err(dev, "failed to register the cpu_clk_dyn notifier\n");
- return ret;
- }
- return 0;
- }
- static int meson_g12b_dvfs_setup(struct platform_device *pdev)
- {
- struct clk_hw **hws = g12b_hw_onecell_data.hws;
- struct device *dev = &pdev->dev;
- struct clk *notifier_clk;
- struct clk_hw *xtal;
- int ret;
- ret = meson_g12a_dvfs_setup_common(dev, hws);
- if (ret)
- return ret;
- xtal = clk_hw_get_parent_by_index(hws[CLKID_CPU_CLK_DYN1_SEL], 0);
- /* Setup clock notifier for cpu_clk mux */
- notifier_clk = devm_clk_hw_get_clk(dev, &g12b_cpu_clk.hw,
- DVFS_CON_ID);
- ret = devm_clk_notifier_register(dev, notifier_clk,
- &g12a_cpu_clk_mux_nb);
- if (ret) {
- dev_err(dev, "failed to register the cpu_clk notifier\n");
- return ret;
- }
- /* Setup clock notifier for sys1_pll */
- notifier_clk = devm_clk_hw_get_clk(dev, &g12b_sys1_pll.hw,
- DVFS_CON_ID);
- ret = devm_clk_notifier_register(dev, notifier_clk,
- &g12b_cpu_clk_sys1_pll_nb_data.nb);
- if (ret) {
- dev_err(dev, "failed to register the sys1_pll notifier\n");
- return ret;
- }
- /* Add notifiers for the second CPU cluster */
- /* Setup clock notifier for cpub_clk_postmux0 */
- g12b_cpub_clk_postmux0_nb_data.xtal = xtal;
- notifier_clk = devm_clk_hw_get_clk(dev, &g12b_cpub_clk_postmux0.hw,
- DVFS_CON_ID);
- ret = devm_clk_notifier_register(dev, notifier_clk,
- &g12b_cpub_clk_postmux0_nb_data.nb);
- if (ret) {
- dev_err(dev, "failed to register the cpub_clk_postmux0 notifier\n");
- return ret;
- }
- /* Setup clock notifier for cpub_clk_dyn mux */
- notifier_clk = devm_clk_hw_get_clk(dev, &g12b_cpub_clk_dyn.hw, "dvfs");
- ret = devm_clk_notifier_register(dev, notifier_clk,
- &g12a_cpu_clk_mux_nb);
- if (ret) {
- dev_err(dev, "failed to register the cpub_clk_dyn notifier\n");
- return ret;
- }
- /* Setup clock notifier for cpub_clk mux */
- notifier_clk = devm_clk_hw_get_clk(dev, &g12b_cpub_clk.hw, DVFS_CON_ID);
- ret = devm_clk_notifier_register(dev, notifier_clk,
- &g12a_cpu_clk_mux_nb);
- if (ret) {
- dev_err(dev, "failed to register the cpub_clk notifier\n");
- return ret;
- }
- /* Setup clock notifier for sys_pll */
- notifier_clk = devm_clk_hw_get_clk(dev, &g12a_sys_pll.hw, DVFS_CON_ID);
- ret = devm_clk_notifier_register(dev, notifier_clk,
- &g12b_cpub_clk_sys_pll_nb_data.nb);
- if (ret) {
- dev_err(dev, "failed to register the sys_pll notifier\n");
- return ret;
- }
- return 0;
- }
- static int meson_g12a_dvfs_setup(struct platform_device *pdev)
- {
- struct clk_hw **hws = g12a_hw_onecell_data.hws;
- struct device *dev = &pdev->dev;
- struct clk *notifier_clk;
- int ret;
- ret = meson_g12a_dvfs_setup_common(dev, hws);
- if (ret)
- return ret;
- /* Setup clock notifier for cpu_clk mux */
- notifier_clk = devm_clk_hw_get_clk(dev, &g12a_cpu_clk.hw, DVFS_CON_ID);
- ret = devm_clk_notifier_register(dev, notifier_clk,
- &g12a_cpu_clk_mux_nb);
- if (ret) {
- dev_err(dev, "failed to register the cpu_clk notifier\n");
- return ret;
- }
- /* Setup clock notifier for sys_pll */
- notifier_clk = devm_clk_hw_get_clk(dev, &g12a_sys_pll.hw, DVFS_CON_ID);
- ret = devm_clk_notifier_register(dev, notifier_clk,
- &g12a_sys_pll_nb_data.nb);
- if (ret) {
- dev_err(dev, "failed to register the sys_pll notifier\n");
- return ret;
- }
- return 0;
- }
- struct meson_g12a_data {
- const struct meson_eeclkc_data eeclkc_data;
- int (*dvfs_setup)(struct platform_device *pdev);
- };
- static int meson_g12a_probe(struct platform_device *pdev)
- {
- const struct meson_eeclkc_data *eeclkc_data;
- const struct meson_g12a_data *g12a_data;
- int ret;
- eeclkc_data = of_device_get_match_data(&pdev->dev);
- if (!eeclkc_data)
- return -EINVAL;
- ret = meson_eeclkc_probe(pdev);
- if (ret)
- return ret;
- g12a_data = container_of(eeclkc_data, struct meson_g12a_data,
- eeclkc_data);
- if (g12a_data->dvfs_setup)
- return g12a_data->dvfs_setup(pdev);
- return 0;
- }
- static const struct meson_g12a_data g12a_clkc_data = {
- .eeclkc_data = {
- .regmap_clks = g12a_clk_regmaps,
- .regmap_clk_num = ARRAY_SIZE(g12a_clk_regmaps),
- .hw_onecell_data = &g12a_hw_onecell_data,
- .init_regs = g12a_init_regs,
- .init_count = ARRAY_SIZE(g12a_init_regs),
- },
- .dvfs_setup = meson_g12a_dvfs_setup,
- };
- static const struct meson_g12a_data g12b_clkc_data = {
- .eeclkc_data = {
- .regmap_clks = g12a_clk_regmaps,
- .regmap_clk_num = ARRAY_SIZE(g12a_clk_regmaps),
- .hw_onecell_data = &g12b_hw_onecell_data,
- },
- .dvfs_setup = meson_g12b_dvfs_setup,
- };
- static const struct meson_g12a_data sm1_clkc_data = {
- .eeclkc_data = {
- .regmap_clks = g12a_clk_regmaps,
- .regmap_clk_num = ARRAY_SIZE(g12a_clk_regmaps),
- .hw_onecell_data = &sm1_hw_onecell_data,
- },
- .dvfs_setup = meson_g12a_dvfs_setup,
- };
- static const struct of_device_id clkc_match_table[] = {
- {
- .compatible = "amlogic,g12a-clkc",
- .data = &g12a_clkc_data.eeclkc_data
- },
- {
- .compatible = "amlogic,g12b-clkc",
- .data = &g12b_clkc_data.eeclkc_data
- },
- {
- .compatible = "amlogic,sm1-clkc",
- .data = &sm1_clkc_data.eeclkc_data
- },
- {}
- };
- MODULE_DEVICE_TABLE(of, clkc_match_table);
- static struct platform_driver g12a_driver = {
- .probe = meson_g12a_probe,
- .driver = {
- .name = "g12a-clkc",
- .of_match_table = clkc_match_table,
- },
- };
- module_platform_driver(g12a_driver);
- MODULE_LICENSE("GPL v2");
|