123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885 |
- // SPDX-License-Identifier: GPL-2.0
- /*
- * Copyright (c) 2015 Endless Mobile, Inc.
- * Author: Carlo Caione <[email protected]>
- *
- * Copyright (c) 2016 BayLibre, Inc.
- * Michael Turquette <[email protected]>
- */
- #include <linux/clk.h>
- #include <linux/clk-provider.h>
- #include <linux/init.h>
- #include <linux/mfd/syscon.h>
- #include <linux/of_address.h>
- #include <linux/reset-controller.h>
- #include <linux/slab.h>
- #include <linux/regmap.h>
- #include "meson8b.h"
- #include "clk-regmap.h"
- #include "clk-pll.h"
- #include "clk-mpll.h"
- static DEFINE_SPINLOCK(meson_clk_lock);
- struct meson8b_clk_reset {
- struct reset_controller_dev reset;
- struct regmap *regmap;
- };
- static const struct pll_params_table sys_pll_params_table[] = {
- PLL_PARAMS(50, 1),
- PLL_PARAMS(51, 1),
- PLL_PARAMS(52, 1),
- PLL_PARAMS(53, 1),
- PLL_PARAMS(54, 1),
- PLL_PARAMS(55, 1),
- PLL_PARAMS(56, 1),
- PLL_PARAMS(57, 1),
- PLL_PARAMS(58, 1),
- PLL_PARAMS(59, 1),
- PLL_PARAMS(60, 1),
- PLL_PARAMS(61, 1),
- PLL_PARAMS(62, 1),
- PLL_PARAMS(63, 1),
- PLL_PARAMS(64, 1),
- PLL_PARAMS(65, 1),
- PLL_PARAMS(66, 1),
- PLL_PARAMS(67, 1),
- PLL_PARAMS(68, 1),
- PLL_PARAMS(84, 1),
- { /* sentinel */ },
- };
- static struct clk_regmap meson8b_fixed_pll_dco = {
- .data = &(struct meson_clk_pll_data){
- .en = {
- .reg_off = HHI_MPLL_CNTL,
- .shift = 30,
- .width = 1,
- },
- .m = {
- .reg_off = HHI_MPLL_CNTL,
- .shift = 0,
- .width = 9,
- },
- .n = {
- .reg_off = HHI_MPLL_CNTL,
- .shift = 9,
- .width = 5,
- },
- .frac = {
- .reg_off = HHI_MPLL_CNTL2,
- .shift = 0,
- .width = 12,
- },
- .l = {
- .reg_off = HHI_MPLL_CNTL,
- .shift = 31,
- .width = 1,
- },
- .rst = {
- .reg_off = HHI_MPLL_CNTL,
- .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",
- .name = "xtal",
- .index = -1,
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap meson8b_fixed_pll = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_MPLL_CNTL,
- .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 *[]) {
- &meson8b_fixed_pll_dco.hw
- },
- .num_parents = 1,
- /*
- * This clock won't ever change at runtime so
- * CLK_SET_RATE_PARENT is not required
- */
- },
- };
- static struct clk_fixed_factor hdmi_pll_dco_in = {
- .mult = 2,
- .div = 1,
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_pll_dco_in",
- .ops = &clk_fixed_factor_ops,
- .parent_data = &(const struct clk_parent_data) {
- .fw_name = "xtal",
- .index = -1,
- },
- .num_parents = 1,
- },
- };
- /*
- * Taken from the vendor driver for the 2970/2975MHz (both only differ in the
- * FRAC part in HHI_VID_PLL_CNTL2) where these values are identical for Meson8,
- * Meson8b and Meson8m2. This doubles the input (or output - it's not clear
- * which one but the result is the same) clock. The vendor driver additionally
- * has the following comment about: "optimise HPLL VCO 2.97GHz performance".
- */
- static const struct reg_sequence meson8b_hdmi_pll_init_regs[] = {
- { .reg = HHI_VID_PLL_CNTL2, .def = 0x69c84000 },
- { .reg = HHI_VID_PLL_CNTL3, .def = 0x8a46c023 },
- { .reg = HHI_VID_PLL_CNTL4, .def = 0x4123b100 },
- { .reg = HHI_VID_PLL_CNTL5, .def = 0x00012385 },
- { .reg = HHI_VID2_PLL_CNTL2, .def = 0x0430a800 },
- };
- static const struct pll_params_table hdmi_pll_params_table[] = {
- PLL_PARAMS(40, 1),
- PLL_PARAMS(42, 1),
- PLL_PARAMS(44, 1),
- PLL_PARAMS(45, 1),
- PLL_PARAMS(49, 1),
- PLL_PARAMS(52, 1),
- PLL_PARAMS(54, 1),
- PLL_PARAMS(56, 1),
- PLL_PARAMS(59, 1),
- PLL_PARAMS(60, 1),
- PLL_PARAMS(61, 1),
- PLL_PARAMS(62, 1),
- PLL_PARAMS(64, 1),
- PLL_PARAMS(66, 1),
- PLL_PARAMS(68, 1),
- PLL_PARAMS(71, 1),
- PLL_PARAMS(82, 1),
- { /* sentinel */ }
- };
- static struct clk_regmap meson8b_hdmi_pll_dco = {
- .data = &(struct meson_clk_pll_data){
- .en = {
- .reg_off = HHI_VID_PLL_CNTL,
- .shift = 30,
- .width = 1,
- },
- .m = {
- .reg_off = HHI_VID_PLL_CNTL,
- .shift = 0,
- .width = 9,
- },
- .n = {
- .reg_off = HHI_VID_PLL_CNTL,
- .shift = 10,
- .width = 5,
- },
- .frac = {
- .reg_off = HHI_VID_PLL_CNTL2,
- .shift = 0,
- .width = 12,
- },
- .l = {
- .reg_off = HHI_VID_PLL_CNTL,
- .shift = 31,
- .width = 1,
- },
- .rst = {
- .reg_off = HHI_VID_PLL_CNTL,
- .shift = 29,
- .width = 1,
- },
- .table = hdmi_pll_params_table,
- .init_regs = meson8b_hdmi_pll_init_regs,
- .init_count = ARRAY_SIZE(meson8b_hdmi_pll_init_regs),
- },
- .hw.init = &(struct clk_init_data){
- /* sometimes also called "HPLL" or "HPLL PLL" */
- .name = "hdmi_pll_dco",
- .ops = &meson_clk_pll_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &hdmi_pll_dco_in.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap meson8b_hdmi_pll_lvds_out = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VID_PLL_CNTL,
- .shift = 16,
- .width = 2,
- .flags = CLK_DIVIDER_POWER_OF_TWO,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_pll_lvds_out",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_hdmi_pll_dco.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_hdmi_pll_hdmi_out = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VID_PLL_CNTL,
- .shift = 18,
- .width = 2,
- .flags = CLK_DIVIDER_POWER_OF_TWO,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_pll_hdmi_out",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_hdmi_pll_dco.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_sys_pll_dco = {
- .data = &(struct meson_clk_pll_data){
- .en = {
- .reg_off = HHI_SYS_PLL_CNTL,
- .shift = 30,
- .width = 1,
- },
- .m = {
- .reg_off = HHI_SYS_PLL_CNTL,
- .shift = 0,
- .width = 9,
- },
- .n = {
- .reg_off = HHI_SYS_PLL_CNTL,
- .shift = 9,
- .width = 5,
- },
- .l = {
- .reg_off = HHI_SYS_PLL_CNTL,
- .shift = 31,
- .width = 1,
- },
- .rst = {
- .reg_off = HHI_SYS_PLL_CNTL,
- .shift = 29,
- .width = 1,
- },
- .table = sys_pll_params_table,
- },
- .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",
- .name = "xtal",
- .index = -1,
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap meson8b_sys_pll = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SYS_PLL_CNTL,
- .shift = 16,
- .width = 2,
- .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 *[]) {
- &meson8b_sys_pll_dco.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor meson8b_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 *[]) {
- &meson8b_fixed_pll.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap meson8b_fclk_div2 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MPLL_CNTL6,
- .bit_idx = 27,
- },
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div2",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_fclk_div2_div.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor meson8b_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 *[]) {
- &meson8b_fixed_pll.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap meson8b_fclk_div3 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MPLL_CNTL6,
- .bit_idx = 28,
- },
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div3",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_fclk_div3_div.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor meson8b_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 *[]) {
- &meson8b_fixed_pll.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap meson8b_fclk_div4 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MPLL_CNTL6,
- .bit_idx = 29,
- },
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div4",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_fclk_div4_div.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor meson8b_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 *[]) {
- &meson8b_fixed_pll.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap meson8b_fclk_div5 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MPLL_CNTL6,
- .bit_idx = 30,
- },
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div5",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_fclk_div5_div.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor meson8b_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 *[]) {
- &meson8b_fixed_pll.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap meson8b_fclk_div7 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MPLL_CNTL6,
- .bit_idx = 31,
- },
- .hw.init = &(struct clk_init_data){
- .name = "fclk_div7",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_fclk_div7_div.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap meson8b_mpll_prediv = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_MPLL_CNTL5,
- .shift = 12,
- .width = 1,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll_prediv",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_fixed_pll.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap meson8b_mpll0_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 = 15,
- .width = 1,
- },
- .n2 = {
- .reg_off = HHI_MPLL_CNTL7,
- .shift = 16,
- .width = 9,
- },
- .ssen = {
- .reg_off = HHI_MPLL_CNTL,
- .shift = 25,
- .width = 1,
- },
- .lock = &meson_clk_lock,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll0_div",
- .ops = &meson_clk_mpll_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_mpll_prediv.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap meson8b_mpll0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MPLL_CNTL7,
- .bit_idx = 14,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_mpll0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_mpll1_div = {
- .data = &(struct meson_clk_mpll_data){
- .sdm = {
- .reg_off = HHI_MPLL_CNTL8,
- .shift = 0,
- .width = 14,
- },
- .sdm_en = {
- .reg_off = HHI_MPLL_CNTL8,
- .shift = 15,
- .width = 1,
- },
- .n2 = {
- .reg_off = HHI_MPLL_CNTL8,
- .shift = 16,
- .width = 9,
- },
- .lock = &meson_clk_lock,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll1_div",
- .ops = &meson_clk_mpll_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_mpll_prediv.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap meson8b_mpll1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MPLL_CNTL8,
- .bit_idx = 14,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_mpll1_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_mpll2_div = {
- .data = &(struct meson_clk_mpll_data){
- .sdm = {
- .reg_off = HHI_MPLL_CNTL9,
- .shift = 0,
- .width = 14,
- },
- .sdm_en = {
- .reg_off = HHI_MPLL_CNTL9,
- .shift = 15,
- .width = 1,
- },
- .n2 = {
- .reg_off = HHI_MPLL_CNTL9,
- .shift = 16,
- .width = 9,
- },
- .lock = &meson_clk_lock,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll2_div",
- .ops = &meson_clk_mpll_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_mpll_prediv.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap meson8b_mpll2 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_MPLL_CNTL9,
- .bit_idx = 14,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mpll2",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_mpll2_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static u32 mux_table_clk81[] = { 6, 5, 7 };
- static struct clk_regmap meson8b_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,
- /*
- * FIXME bits 14:12 selects from 8 possible parents:
- * xtal, 1'b0 (wtf), fclk_div7, mpll_clkout1, mpll_clkout2,
- * fclk_div4, fclk_div3, fclk_div5
- */
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_fclk_div3.hw,
- &meson8b_fclk_div4.hw,
- &meson8b_fclk_div5.hw,
- },
- .num_parents = 3,
- },
- };
- static struct clk_regmap meson8b_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_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_mpeg_clk_sel.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap meson8b_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 *[]) {
- &meson8b_mpeg_clk_div.hw
- },
- .num_parents = 1,
- .flags = CLK_IS_CRITICAL,
- },
- };
- static struct clk_regmap meson8b_cpu_in_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL0,
- .mask = 0x1,
- .shift = 0,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_in_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = (const struct clk_parent_data[]) {
- { .fw_name = "xtal", .name = "xtal", .index = -1, },
- { .hw = &meson8b_sys_pll.hw, },
- },
- .num_parents = 2,
- .flags = (CLK_SET_RATE_PARENT |
- CLK_SET_RATE_NO_REPARENT),
- },
- };
- static struct clk_fixed_factor meson8b_cpu_in_div2 = {
- .mult = 1,
- .div = 2,
- .hw.init = &(struct clk_init_data){
- .name = "cpu_in_div2",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cpu_in_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor meson8b_cpu_in_div3 = {
- .mult = 1,
- .div = 3,
- .hw.init = &(struct clk_init_data){
- .name = "cpu_in_div3",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cpu_in_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_div_table cpu_scale_table[] = {
- { .val = 1, .div = 4 },
- { .val = 2, .div = 6 },
- { .val = 3, .div = 8 },
- { .val = 4, .div = 10 },
- { .val = 5, .div = 12 },
- { .val = 6, .div = 14 },
- { .val = 7, .div = 16 },
- { .val = 8, .div = 18 },
- { /* sentinel */ },
- };
- static struct clk_regmap meson8b_cpu_scale_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .shift = 20,
- .width = 10,
- .table = cpu_scale_table,
- .flags = CLK_DIVIDER_ALLOW_ZERO,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_scale_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cpu_in_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static u32 mux_table_cpu_scale_out_sel[] = { 0, 1, 3 };
- static struct clk_regmap meson8b_cpu_scale_out_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL0,
- .mask = 0x3,
- .shift = 2,
- .table = mux_table_cpu_scale_out_sel,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_scale_out_sel",
- .ops = &clk_regmap_mux_ops,
- /*
- * NOTE: We are skipping the parent with value 0x2 (which is
- * meson8b_cpu_in_div3) because it results in a duty cycle of
- * 33% which makes the system unstable and can result in a
- * lockup of the whole system.
- */
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cpu_in_sel.hw,
- &meson8b_cpu_in_div2.hw,
- &meson8b_cpu_scale_div.hw,
- },
- .num_parents = 3,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_cpu_clk = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL0,
- .mask = 0x1,
- .shift = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk",
- .ops = &clk_regmap_mux_ops,
- .parent_data = (const struct clk_parent_data[]) {
- { .fw_name = "xtal", .name = "xtal", .index = -1, },
- { .hw = &meson8b_cpu_scale_out_sel.hw, },
- },
- .num_parents = 2,
- .flags = (CLK_SET_RATE_PARENT |
- CLK_SET_RATE_NO_REPARENT |
- CLK_IS_CRITICAL),
- },
- };
- static struct clk_regmap meson8b_nand_clk_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_NAND_CLK_CNTL,
- .mask = 0x7,
- .shift = 9,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "nand_clk_sel",
- .ops = &clk_regmap_mux_ops,
- /* FIXME all other parents are unknown: */
- .parent_data = (const struct clk_parent_data[]) {
- { .hw = &meson8b_fclk_div4.hw, },
- { .hw = &meson8b_fclk_div3.hw, },
- { .hw = &meson8b_fclk_div5.hw, },
- { .hw = &meson8b_fclk_div7.hw, },
- { .fw_name = "xtal", .name = "xtal", .index = -1, },
- },
- .num_parents = 5,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_nand_clk_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_NAND_CLK_CNTL,
- .shift = 0,
- .width = 7,
- .flags = CLK_DIVIDER_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "nand_clk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_nand_clk_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_nand_clk_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_NAND_CLK_CNTL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "nand_clk_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_nand_clk_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor meson8b_cpu_clk_div2 = {
- .mult = 1,
- .div = 2,
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_div2",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cpu_clk.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor meson8b_cpu_clk_div3 = {
- .mult = 1,
- .div = 3,
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_div3",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cpu_clk.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor meson8b_cpu_clk_div4 = {
- .mult = 1,
- .div = 4,
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_div4",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cpu_clk.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor meson8b_cpu_clk_div5 = {
- .mult = 1,
- .div = 5,
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_div5",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cpu_clk.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor meson8b_cpu_clk_div6 = {
- .mult = 1,
- .div = 6,
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_div6",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cpu_clk.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor meson8b_cpu_clk_div7 = {
- .mult = 1,
- .div = 7,
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_div7",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cpu_clk.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor meson8b_cpu_clk_div8 = {
- .mult = 1,
- .div = 8,
- .hw.init = &(struct clk_init_data){
- .name = "cpu_clk_div8",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cpu_clk.hw
- },
- .num_parents = 1,
- },
- };
- static u32 mux_table_apb[] = { 1, 2, 3, 4, 5, 6, 7 };
- static struct clk_regmap meson8b_apb_clk_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .mask = 0x7,
- .shift = 3,
- .table = mux_table_apb,
- },
- .hw.init = &(struct clk_init_data){
- .name = "apb_clk_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cpu_clk_div2.hw,
- &meson8b_cpu_clk_div3.hw,
- &meson8b_cpu_clk_div4.hw,
- &meson8b_cpu_clk_div5.hw,
- &meson8b_cpu_clk_div6.hw,
- &meson8b_cpu_clk_div7.hw,
- &meson8b_cpu_clk_div8.hw,
- },
- .num_parents = 7,
- },
- };
- static struct clk_regmap meson8b_apb_clk_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .bit_idx = 16,
- .flags = CLK_GATE_SET_TO_DISABLE,
- },
- .hw.init = &(struct clk_init_data){
- .name = "apb_clk_dis",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_apb_clk_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_periph_clk_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .mask = 0x7,
- .shift = 6,
- },
- .hw.init = &(struct clk_init_data){
- .name = "periph_clk_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cpu_clk_div2.hw,
- &meson8b_cpu_clk_div3.hw,
- &meson8b_cpu_clk_div4.hw,
- &meson8b_cpu_clk_div5.hw,
- &meson8b_cpu_clk_div6.hw,
- &meson8b_cpu_clk_div7.hw,
- &meson8b_cpu_clk_div8.hw,
- },
- .num_parents = 7,
- },
- };
- static struct clk_regmap meson8b_periph_clk_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .bit_idx = 17,
- .flags = CLK_GATE_SET_TO_DISABLE,
- },
- .hw.init = &(struct clk_init_data){
- .name = "periph_clk_dis",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_periph_clk_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static u32 mux_table_axi[] = { 1, 2, 3, 4, 5, 6, 7 };
- static struct clk_regmap meson8b_axi_clk_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .mask = 0x7,
- .shift = 9,
- .table = mux_table_axi,
- },
- .hw.init = &(struct clk_init_data){
- .name = "axi_clk_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cpu_clk_div2.hw,
- &meson8b_cpu_clk_div3.hw,
- &meson8b_cpu_clk_div4.hw,
- &meson8b_cpu_clk_div5.hw,
- &meson8b_cpu_clk_div6.hw,
- &meson8b_cpu_clk_div7.hw,
- &meson8b_cpu_clk_div8.hw,
- },
- .num_parents = 7,
- },
- };
- static struct clk_regmap meson8b_axi_clk_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .bit_idx = 18,
- .flags = CLK_GATE_SET_TO_DISABLE,
- },
- .hw.init = &(struct clk_init_data){
- .name = "axi_clk_dis",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_axi_clk_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_l2_dram_clk_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .mask = 0x7,
- .shift = 12,
- },
- .hw.init = &(struct clk_init_data){
- .name = "l2_dram_clk_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cpu_clk_div2.hw,
- &meson8b_cpu_clk_div3.hw,
- &meson8b_cpu_clk_div4.hw,
- &meson8b_cpu_clk_div5.hw,
- &meson8b_cpu_clk_div6.hw,
- &meson8b_cpu_clk_div7.hw,
- &meson8b_cpu_clk_div8.hw,
- },
- .num_parents = 7,
- },
- };
- static struct clk_regmap meson8b_l2_dram_clk_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_SYS_CPU_CLK_CNTL1,
- .bit_idx = 19,
- .flags = CLK_GATE_SET_TO_DISABLE,
- },
- .hw.init = &(struct clk_init_data){
- .name = "l2_dram_clk_dis",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_l2_dram_clk_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* also called LVDS_CLK_EN */
- static struct clk_regmap meson8b_vid_pll_lvds_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_DIVIDER_CNTL,
- .bit_idx = 11,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vid_pll_lvds_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_hdmi_pll_lvds_out.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vid_pll_in_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VID_DIVIDER_CNTL,
- .mask = 0x1,
- .shift = 15,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vid_pll_in_sel",
- .ops = &clk_regmap_mux_ops,
- /*
- * TODO: depending on the SoC there is also a second parent:
- * Meson8: unknown
- * Meson8b: hdmi_pll_dco
- * Meson8m2: vid2_pll
- */
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vid_pll_lvds_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vid_pll_in_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_DIVIDER_CNTL,
- .bit_idx = 16,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vid_pll_in_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vid_pll_in_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vid_pll_pre_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VID_DIVIDER_CNTL,
- .shift = 4,
- .width = 3,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vid_pll_pre_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vid_pll_in_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vid_pll_post_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VID_DIVIDER_CNTL,
- .shift = 12,
- .width = 3,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vid_pll_post_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vid_pll_pre_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vid_pll = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VID_DIVIDER_CNTL,
- .mask = 0x3,
- .shift = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vid_pll",
- .ops = &clk_regmap_mux_ops,
- /* TODO: parent 0x2 is vid_pll_pre_div_mult7_div2 */
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vid_pll_pre_div.hw,
- &meson8b_vid_pll_post_div.hw,
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vid_pll_final_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VID_CLK_DIV,
- .shift = 0,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vid_pll_final_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vid_pll.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_hw *meson8b_vclk_mux_parent_hws[] = {
- &meson8b_vid_pll_final_div.hw,
- &meson8b_fclk_div4.hw,
- &meson8b_fclk_div3.hw,
- &meson8b_fclk_div5.hw,
- &meson8b_vid_pll_final_div.hw,
- &meson8b_fclk_div7.hw,
- &meson8b_mpll1.hw,
- };
- static struct clk_regmap meson8b_vclk_in_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VID_CLK_CNTL,
- .mask = 0x7,
- .shift = 16,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk_in_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_vclk_mux_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_vclk_mux_parent_hws),
- .flags = CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
- },
- };
- static struct clk_regmap meson8b_vclk_in_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_DIV,
- .bit_idx = 16,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk_in_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk_in_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vclk_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL,
- .bit_idx = 19,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk_in_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vclk_div1_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL,
- .bit_idx = 0,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk_div1_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor meson8b_vclk_div2_div = {
- .mult = 1,
- .div = 2,
- .hw.init = &(struct clk_init_data){
- .name = "vclk_div2",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- }
- };
- static struct clk_regmap meson8b_vclk_div2_div_gate = {
- .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 *[]) {
- &meson8b_vclk_div2_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor meson8b_vclk_div4_div = {
- .mult = 1,
- .div = 4,
- .hw.init = &(struct clk_init_data){
- .name = "vclk_div4",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- }
- };
- static struct clk_regmap meson8b_vclk_div4_div_gate = {
- .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 *[]) {
- &meson8b_vclk_div4_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor meson8b_vclk_div6_div = {
- .mult = 1,
- .div = 6,
- .hw.init = &(struct clk_init_data){
- .name = "vclk_div6",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- }
- };
- static struct clk_regmap meson8b_vclk_div6_div_gate = {
- .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 *[]) {
- &meson8b_vclk_div6_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor meson8b_vclk_div12_div = {
- .mult = 1,
- .div = 12,
- .hw.init = &(struct clk_init_data){
- .name = "vclk_div12",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- }
- };
- static struct clk_regmap meson8b_vclk_div12_div_gate = {
- .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 *[]) {
- &meson8b_vclk_div12_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vclk2_in_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VIID_CLK_CNTL,
- .mask = 0x7,
- .shift = 16,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_in_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_vclk_mux_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_vclk_mux_parent_hws),
- .flags = CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
- },
- };
- static struct clk_regmap meson8b_vclk2_clk_in_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VIID_CLK_DIV,
- .bit_idx = 16,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_in_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk2_in_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vclk2_clk_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VIID_CLK_DIV,
- .bit_idx = 19,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk2_clk_in_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vclk2_div1_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VIID_CLK_DIV,
- .bit_idx = 0,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div1_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk2_clk_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor meson8b_vclk2_div2_div = {
- .mult = 1,
- .div = 2,
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div2",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk2_clk_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- }
- };
- static struct clk_regmap meson8b_vclk2_div2_div_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VIID_CLK_DIV,
- .bit_idx = 1,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div2_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk2_div2_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor meson8b_vclk2_div4_div = {
- .mult = 1,
- .div = 4,
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div4",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk2_clk_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- }
- };
- static struct clk_regmap meson8b_vclk2_div4_div_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VIID_CLK_DIV,
- .bit_idx = 2,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div4_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk2_div4_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor meson8b_vclk2_div6_div = {
- .mult = 1,
- .div = 6,
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div6",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk2_clk_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- }
- };
- static struct clk_regmap meson8b_vclk2_div6_div_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VIID_CLK_DIV,
- .bit_idx = 3,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div6_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk2_div6_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor meson8b_vclk2_div12_div = {
- .mult = 1,
- .div = 12,
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div12",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk2_clk_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- }
- };
- static struct clk_regmap meson8b_vclk2_div12_div_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VIID_CLK_DIV,
- .bit_idx = 4,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div12_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vclk2_div12_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_hw *meson8b_vclk_enc_mux_parent_hws[] = {
- &meson8b_vclk_div1_gate.hw,
- &meson8b_vclk_div2_div_gate.hw,
- &meson8b_vclk_div4_div_gate.hw,
- &meson8b_vclk_div6_div_gate.hw,
- &meson8b_vclk_div12_div_gate.hw,
- };
- static struct clk_regmap meson8b_cts_enct_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VID_CLK_DIV,
- .mask = 0xf,
- .shift = 20,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_enct_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_vclk_enc_mux_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_vclk_enc_mux_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_cts_enct = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL2,
- .bit_idx = 1,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_enct",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cts_enct_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_cts_encp_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VID_CLK_DIV,
- .mask = 0xf,
- .shift = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_encp_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_vclk_enc_mux_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_vclk_enc_mux_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_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 *[]) {
- &meson8b_cts_encp_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_cts_enci_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VID_CLK_DIV,
- .mask = 0xf,
- .shift = 28,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_enci_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_vclk_enc_mux_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_vclk_enc_mux_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_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 *[]) {
- &meson8b_cts_enci_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_hdmi_tx_pixel_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_HDMI_CLK_CNTL,
- .mask = 0xf,
- .shift = 16,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_tx_pixel_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_vclk_enc_mux_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_vclk_enc_mux_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_hdmi_tx_pixel = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL2,
- .bit_idx = 5,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_tx_pixel",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_hdmi_tx_pixel_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_hw *meson8b_vclk2_enc_mux_parent_hws[] = {
- &meson8b_vclk2_div1_gate.hw,
- &meson8b_vclk2_div2_div_gate.hw,
- &meson8b_vclk2_div4_div_gate.hw,
- &meson8b_vclk2_div6_div_gate.hw,
- &meson8b_vclk2_div12_div_gate.hw,
- };
- static struct clk_regmap meson8b_cts_encl_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VIID_CLK_DIV,
- .mask = 0xf,
- .shift = 12,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_encl_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_vclk2_enc_mux_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_vclk2_enc_mux_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_cts_encl = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL2,
- .bit_idx = 3,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_encl",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cts_encl_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_cts_vdac0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VIID_CLK_DIV,
- .mask = 0xf,
- .shift = 28,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_vdac0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_vclk2_enc_mux_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_vclk2_enc_mux_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_cts_vdac0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VID_CLK_CNTL2,
- .bit_idx = 4,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_vdac0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cts_vdac0_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_hdmi_sys_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_sys_sel",
- .ops = &clk_regmap_mux_ops,
- /* FIXME: all other parents are unknown */
- .parent_data = &(const struct clk_parent_data) {
- .fw_name = "xtal",
- .name = "xtal",
- .index = -1,
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_NO_REPARENT,
- },
- };
- static struct clk_regmap meson8b_hdmi_sys_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_HDMI_CLK_CNTL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_sys_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_hdmi_sys_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_hdmi_sys = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_HDMI_CLK_CNTL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "hdmi_sys",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_hdmi_sys_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /*
- * The MALI IP is clocked by two identical clocks (mali_0 and mali_1)
- * muxed by a glitch-free switch on Meson8b and Meson8m2. The CCF can
- * actually 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.
- * Meson8 only has mali_0 and no glitch-free mux.
- */
- static const struct clk_parent_data meson8b_mali_0_1_parent_data[] = {
- { .fw_name = "xtal", .name = "xtal", .index = -1, },
- { .hw = &meson8b_mpll2.hw, },
- { .hw = &meson8b_mpll1.hw, },
- { .hw = &meson8b_fclk_div7.hw, },
- { .hw = &meson8b_fclk_div4.hw, },
- { .hw = &meson8b_fclk_div3.hw, },
- { .hw = &meson8b_fclk_div5.hw, },
- };
- static u32 meson8b_mali_0_1_mux_table[] = { 0, 2, 3, 4, 5, 6, 7 };
- static struct clk_regmap meson8b_mali_0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_MALI_CLK_CNTL,
- .mask = 0x7,
- .shift = 9,
- .table = meson8b_mali_0_1_mux_table,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mali_0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = meson8b_mali_0_1_parent_data,
- .num_parents = ARRAY_SIZE(meson8b_mali_0_1_parent_data),
- /*
- * Don't propagate rate changes up because the only changeable
- * parents are mpll1 and mpll2 but we need those for audio and
- * RGMII (Ethernet). We don't want to change the audio or
- * Ethernet clocks when setting the GPU frequency.
- */
- .flags = 0,
- },
- };
- static struct clk_regmap meson8b_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 *[]) {
- &meson8b_mali_0_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_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 *[]) {
- &meson8b_mali_0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_GATE | CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_mali_1_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_MALI_CLK_CNTL,
- .mask = 0x7,
- .shift = 25,
- .table = meson8b_mali_0_1_mux_table,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mali_1_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = meson8b_mali_0_1_parent_data,
- .num_parents = ARRAY_SIZE(meson8b_mali_0_1_parent_data),
- /*
- * Don't propagate rate changes up because the only changeable
- * parents are mpll1 and mpll2 but we need those for audio and
- * RGMII (Ethernet). We don't want to change the audio or
- * Ethernet clocks when setting the GPU frequency.
- */
- .flags = 0,
- },
- };
- static struct clk_regmap meson8b_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 *[]) {
- &meson8b_mali_1_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_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 *[]) {
- &meson8b_mali_1_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_GATE | CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_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 = (const struct clk_hw *[]) {
- &meson8b_mali_0.hw,
- &meson8b_mali_1.hw,
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct reg_sequence meson8m2_gp_pll_init_regs[] = {
- { .reg = HHI_GP_PLL_CNTL2, .def = 0x59c88000 },
- { .reg = HHI_GP_PLL_CNTL3, .def = 0xca463823 },
- { .reg = HHI_GP_PLL_CNTL4, .def = 0x0286a027 },
- { .reg = HHI_GP_PLL_CNTL5, .def = 0x00003000 },
- };
- static const struct pll_params_table meson8m2_gp_pll_params_table[] = {
- PLL_PARAMS(182, 3),
- { /* sentinel */ },
- };
- static struct clk_regmap meson8m2_gp_pll_dco = {
- .data = &(struct meson_clk_pll_data){
- .en = {
- .reg_off = HHI_GP_PLL_CNTL,
- .shift = 30,
- .width = 1,
- },
- .m = {
- .reg_off = HHI_GP_PLL_CNTL,
- .shift = 0,
- .width = 9,
- },
- .n = {
- .reg_off = HHI_GP_PLL_CNTL,
- .shift = 9,
- .width = 5,
- },
- .l = {
- .reg_off = HHI_GP_PLL_CNTL,
- .shift = 31,
- .width = 1,
- },
- .rst = {
- .reg_off = HHI_GP_PLL_CNTL,
- .shift = 29,
- .width = 1,
- },
- .table = meson8m2_gp_pll_params_table,
- .init_regs = meson8m2_gp_pll_init_regs,
- .init_count = ARRAY_SIZE(meson8m2_gp_pll_init_regs),
- },
- .hw.init = &(struct clk_init_data){
- .name = "gp_pll_dco",
- .ops = &meson_clk_pll_ops,
- .parent_data = &(const struct clk_parent_data) {
- .fw_name = "xtal",
- .name = "xtal",
- .index = -1,
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap meson8m2_gp_pll = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_GP_PLL_CNTL,
- .shift = 16,
- .width = 2,
- .flags = CLK_DIVIDER_POWER_OF_TWO,
- },
- .hw.init = &(struct clk_init_data){
- .name = "gp_pll",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8m2_gp_pll_dco.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_hw *meson8b_vpu_0_1_parent_hws[] = {
- &meson8b_fclk_div4.hw,
- &meson8b_fclk_div3.hw,
- &meson8b_fclk_div5.hw,
- &meson8b_fclk_div7.hw,
- };
- static const struct clk_hw *mmeson8m2_vpu_0_1_parent_hws[] = {
- &meson8b_fclk_div4.hw,
- &meson8b_fclk_div3.hw,
- &meson8b_fclk_div5.hw,
- &meson8m2_gp_pll.hw,
- };
- static struct clk_regmap meson8b_vpu_0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VPU_CLK_CNTL,
- .mask = 0x3,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_vpu_0_1_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_vpu_0_1_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8m2_vpu_0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VPU_CLK_CNTL,
- .mask = 0x3,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = mmeson8m2_vpu_0_1_parent_hws,
- .num_parents = ARRAY_SIZE(mmeson8m2_vpu_0_1_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_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_data = &(const struct clk_parent_data) {
- /*
- * Note:
- * meson8b and meson8m2 have different vpu_0_sels (with
- * different struct clk_hw). We fallback to the global
- * naming string mechanism so vpu_0_div picks up the
- * appropriate one.
- */
- .name = "vpu_0_sel",
- .index = -1,
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_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 *[]) {
- &meson8b_vpu_0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_GATE | CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vpu_1_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VPU_CLK_CNTL,
- .mask = 0x3,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_1_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_vpu_0_1_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_vpu_0_1_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8m2_vpu_1_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VPU_CLK_CNTL,
- .mask = 0x3,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_1_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = mmeson8m2_vpu_0_1_parent_hws,
- .num_parents = ARRAY_SIZE(mmeson8m2_vpu_0_1_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_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_data = &(const struct clk_parent_data) {
- /*
- * Note:
- * meson8b and meson8m2 have different vpu_1_sels (with
- * different struct clk_hw). We fallback to the global
- * naming string mechanism so vpu_1_div picks up the
- * appropriate one.
- */
- .name = "vpu_1_sel",
- .index = -1,
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_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 *[]) {
- &meson8b_vpu_1_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_GATE | CLK_SET_RATE_PARENT,
- },
- };
- /*
- * The VPU clock has two identical clock trees (vpu_0 and vpu_1)
- * muxed by a glitch-free switch on Meson8b and Meson8m2. The CCF can
- * actually 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.
- * Meson8 only has vpu_0 and no glitch-free mux.
- */
- static struct clk_regmap meson8b_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,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vpu_0.hw,
- &meson8b_vpu_1.hw,
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_hw *meson8b_vdec_parent_hws[] = {
- &meson8b_fclk_div4.hw,
- &meson8b_fclk_div3.hw,
- &meson8b_fclk_div5.hw,
- &meson8b_fclk_div7.hw,
- &meson8b_mpll2.hw,
- &meson8b_mpll1.hw,
- };
- static struct clk_regmap meson8b_vdec_1_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VDEC_CLK_CNTL,
- .mask = 0x3,
- .shift = 9,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_1_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_vdec_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_vdec_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vdec_1_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_1_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vdec_1_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vdec_1_1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VDEC_CLK_CNTL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vdec_1_1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vdec_1_1_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vdec_1_2_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VDEC3_CLK_CNTL,
- .shift = 0,
- .width = 7,
- .flags = CLK_DIVIDER_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_1_2_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vdec_1_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vdec_1_2 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VDEC3_CLK_CNTL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vdec_1_2",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vdec_1_2_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vdec_1 = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VDEC3_CLK_CNTL,
- .mask = 0x1,
- .shift = 15,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_1",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vdec_1_1.hw,
- &meson8b_vdec_1_2.hw,
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vdec_hcodec_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VDEC_CLK_CNTL,
- .mask = 0x3,
- .shift = 25,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_hcodec_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_vdec_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_vdec_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vdec_hcodec_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_VDEC_CLK_CNTL,
- .shift = 16,
- .width = 7,
- .flags = CLK_DIVIDER_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_hcodec_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vdec_hcodec_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vdec_hcodec = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VDEC_CLK_CNTL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vdec_hcodec",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vdec_hcodec_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vdec_2_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VDEC2_CLK_CNTL,
- .mask = 0x3,
- .shift = 9,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_2_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_vdec_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_vdec_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vdec_2_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_2_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vdec_2_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vdec_2 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VDEC2_CLK_CNTL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vdec_2",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vdec_2_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vdec_hevc_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VDEC2_CLK_CNTL,
- .mask = 0x3,
- .shift = 25,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_hevc_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_vdec_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_vdec_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_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 *[]) {
- &meson8b_vdec_hevc_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vdec_hevc_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_VDEC2_CLK_CNTL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vdec_hevc_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vdec_hevc_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_vdec_hevc = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_VDEC2_CLK_CNTL,
- .mask = 0x1,
- .shift = 31,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_hevc",
- .ops = &clk_regmap_mux_ops,
- /* TODO: The second parent is currently unknown */
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_vdec_hevc_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* TODO: the clock at index 0 is "DDR_PLL" which we don't support yet */
- static const struct clk_hw *meson8b_cts_amclk_parent_hws[] = {
- &meson8b_mpll0.hw,
- &meson8b_mpll1.hw,
- &meson8b_mpll2.hw
- };
- static u32 meson8b_cts_amclk_mux_table[] = { 1, 2, 3 };
- static struct clk_regmap meson8b_cts_amclk_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_AUD_CLK_CNTL,
- .mask = 0x3,
- .shift = 9,
- .table = meson8b_cts_amclk_mux_table,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_amclk_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_cts_amclk_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_cts_amclk_parent_hws),
- },
- };
- static struct clk_regmap meson8b_cts_amclk_div = {
- .data = &(struct clk_regmap_div_data) {
- .offset = HHI_AUD_CLK_CNTL,
- .shift = 0,
- .width = 8,
- .flags = CLK_DIVIDER_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_amclk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cts_amclk_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_cts_amclk = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_AUD_CLK_CNTL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_amclk",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cts_amclk_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* TODO: the clock at index 0 is "DDR_PLL" which we don't support yet */
- static const struct clk_hw *meson8b_cts_mclk_i958_parent_hws[] = {
- &meson8b_mpll0.hw,
- &meson8b_mpll1.hw,
- &meson8b_mpll2.hw
- };
- static u32 meson8b_cts_mclk_i958_mux_table[] = { 1, 2, 3 };
- static struct clk_regmap meson8b_cts_mclk_i958_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_AUD_CLK_CNTL2,
- .mask = 0x3,
- .shift = 25,
- .table = meson8b_cts_mclk_i958_mux_table,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cts_mclk_i958_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = meson8b_cts_mclk_i958_parent_hws,
- .num_parents = ARRAY_SIZE(meson8b_cts_mclk_i958_parent_hws),
- },
- };
- static struct clk_regmap meson8b_cts_mclk_i958_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = HHI_AUD_CLK_CNTL2,
- .shift = 16,
- .width = 8,
- .flags = CLK_DIVIDER_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cts_mclk_i958_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cts_mclk_i958_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_cts_mclk_i958 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = HHI_AUD_CLK_CNTL2,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_mclk_i958",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cts_mclk_i958_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap meson8b_cts_i958 = {
- .data = &(struct clk_regmap_mux_data){
- .offset = HHI_AUD_CLK_CNTL2,
- .mask = 0x1,
- .shift = 27,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_i958",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &meson8b_cts_amclk.hw,
- &meson8b_cts_mclk_i958.hw
- },
- .num_parents = 2,
- /*
- * The parent is specific to origin of the audio data. Let the
- * consumer choose the appropriate parent.
- */
- .flags = CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
- },
- };
- #define MESON_GATE(_name, _reg, _bit) \
- MESON_PCLK(_name, _reg, _bit, &meson8b_clk81.hw)
- /* Everything Else (EE) domain gates */
- static MESON_GATE(meson8b_ddr, HHI_GCLK_MPEG0, 0);
- static MESON_GATE(meson8b_dos, HHI_GCLK_MPEG0, 1);
- static MESON_GATE(meson8b_isa, HHI_GCLK_MPEG0, 5);
- static MESON_GATE(meson8b_pl301, HHI_GCLK_MPEG0, 6);
- static MESON_GATE(meson8b_periphs, HHI_GCLK_MPEG0, 7);
- static MESON_GATE(meson8b_spicc, HHI_GCLK_MPEG0, 8);
- static MESON_GATE(meson8b_i2c, HHI_GCLK_MPEG0, 9);
- static MESON_GATE(meson8b_sar_adc, HHI_GCLK_MPEG0, 10);
- static MESON_GATE(meson8b_smart_card, HHI_GCLK_MPEG0, 11);
- static MESON_GATE(meson8b_rng0, HHI_GCLK_MPEG0, 12);
- static MESON_GATE(meson8b_uart0, HHI_GCLK_MPEG0, 13);
- static MESON_GATE(meson8b_sdhc, HHI_GCLK_MPEG0, 14);
- static MESON_GATE(meson8b_stream, HHI_GCLK_MPEG0, 15);
- static MESON_GATE(meson8b_async_fifo, HHI_GCLK_MPEG0, 16);
- static MESON_GATE(meson8b_sdio, HHI_GCLK_MPEG0, 17);
- static MESON_GATE(meson8b_abuf, HHI_GCLK_MPEG0, 18);
- static MESON_GATE(meson8b_hiu_iface, HHI_GCLK_MPEG0, 19);
- static MESON_GATE(meson8b_assist_misc, HHI_GCLK_MPEG0, 23);
- static MESON_GATE(meson8b_spi, HHI_GCLK_MPEG0, 30);
- static MESON_GATE(meson8b_i2s_spdif, HHI_GCLK_MPEG1, 2);
- static MESON_GATE(meson8b_eth, HHI_GCLK_MPEG1, 3);
- static MESON_GATE(meson8b_demux, HHI_GCLK_MPEG1, 4);
- static MESON_GATE(meson8b_blkmv, HHI_GCLK_MPEG1, 14);
- static MESON_GATE(meson8b_aiu, HHI_GCLK_MPEG1, 15);
- static MESON_GATE(meson8b_uart1, HHI_GCLK_MPEG1, 16);
- static MESON_GATE(meson8b_g2d, HHI_GCLK_MPEG1, 20);
- static MESON_GATE(meson8b_usb0, HHI_GCLK_MPEG1, 21);
- static MESON_GATE(meson8b_usb1, HHI_GCLK_MPEG1, 22);
- static MESON_GATE(meson8b_reset, HHI_GCLK_MPEG1, 23);
- static MESON_GATE(meson8b_nand, HHI_GCLK_MPEG1, 24);
- static MESON_GATE(meson8b_dos_parser, HHI_GCLK_MPEG1, 25);
- static MESON_GATE(meson8b_usb, HHI_GCLK_MPEG1, 26);
- static MESON_GATE(meson8b_vdin1, HHI_GCLK_MPEG1, 28);
- static MESON_GATE(meson8b_ahb_arb0, HHI_GCLK_MPEG1, 29);
- static MESON_GATE(meson8b_efuse, HHI_GCLK_MPEG1, 30);
- static MESON_GATE(meson8b_boot_rom, HHI_GCLK_MPEG1, 31);
- static MESON_GATE(meson8b_ahb_data_bus, HHI_GCLK_MPEG2, 1);
- static MESON_GATE(meson8b_ahb_ctrl_bus, HHI_GCLK_MPEG2, 2);
- static MESON_GATE(meson8b_hdmi_intr_sync, HHI_GCLK_MPEG2, 3);
- static MESON_GATE(meson8b_hdmi_pclk, HHI_GCLK_MPEG2, 4);
- static MESON_GATE(meson8b_usb1_ddr_bridge, HHI_GCLK_MPEG2, 8);
- static MESON_GATE(meson8b_usb0_ddr_bridge, HHI_GCLK_MPEG2, 9);
- static MESON_GATE(meson8b_mmc_pclk, HHI_GCLK_MPEG2, 11);
- static MESON_GATE(meson8b_dvin, HHI_GCLK_MPEG2, 12);
- static MESON_GATE(meson8b_uart2, HHI_GCLK_MPEG2, 15);
- static MESON_GATE(meson8b_sana, HHI_GCLK_MPEG2, 22);
- static MESON_GATE(meson8b_vpu_intr, HHI_GCLK_MPEG2, 25);
- static MESON_GATE(meson8b_sec_ahb_ahb3_bridge, HHI_GCLK_MPEG2, 26);
- static MESON_GATE(meson8b_clk81_a9, HHI_GCLK_MPEG2, 29);
- static MESON_GATE(meson8b_vclk2_venci0, HHI_GCLK_OTHER, 1);
- static MESON_GATE(meson8b_vclk2_venci1, HHI_GCLK_OTHER, 2);
- static MESON_GATE(meson8b_vclk2_vencp0, HHI_GCLK_OTHER, 3);
- static MESON_GATE(meson8b_vclk2_vencp1, HHI_GCLK_OTHER, 4);
- static MESON_GATE(meson8b_gclk_venci_int, HHI_GCLK_OTHER, 8);
- static MESON_GATE(meson8b_gclk_vencp_int, HHI_GCLK_OTHER, 9);
- static MESON_GATE(meson8b_dac_clk, HHI_GCLK_OTHER, 10);
- static MESON_GATE(meson8b_aoclk_gate, HHI_GCLK_OTHER, 14);
- static MESON_GATE(meson8b_iec958_gate, HHI_GCLK_OTHER, 16);
- static MESON_GATE(meson8b_enc480p, HHI_GCLK_OTHER, 20);
- static MESON_GATE(meson8b_rng1, HHI_GCLK_OTHER, 21);
- static MESON_GATE(meson8b_gclk_vencl_int, HHI_GCLK_OTHER, 22);
- static MESON_GATE(meson8b_vclk2_venclmcc, HHI_GCLK_OTHER, 24);
- static MESON_GATE(meson8b_vclk2_vencl, HHI_GCLK_OTHER, 25);
- static MESON_GATE(meson8b_vclk2_other, HHI_GCLK_OTHER, 26);
- static MESON_GATE(meson8b_edp, HHI_GCLK_OTHER, 31);
- /* AIU gates */
- #define MESON_AIU_GLUE_GATE(_name, _reg, _bit) \
- MESON_PCLK(_name, _reg, _bit, &meson8b_aiu_glue.hw)
- static MESON_PCLK(meson8b_aiu_glue, HHI_GCLK_MPEG1, 6, &meson8b_aiu.hw);
- static MESON_AIU_GLUE_GATE(meson8b_iec958, HHI_GCLK_MPEG1, 7);
- static MESON_AIU_GLUE_GATE(meson8b_i2s_out, HHI_GCLK_MPEG1, 8);
- static MESON_AIU_GLUE_GATE(meson8b_amclk, HHI_GCLK_MPEG1, 9);
- static MESON_AIU_GLUE_GATE(meson8b_aififo2, HHI_GCLK_MPEG1, 10);
- static MESON_AIU_GLUE_GATE(meson8b_mixer, HHI_GCLK_MPEG1, 11);
- static MESON_AIU_GLUE_GATE(meson8b_mixer_iface, HHI_GCLK_MPEG1, 12);
- static MESON_AIU_GLUE_GATE(meson8b_adc, HHI_GCLK_MPEG1, 13);
- /* Always On (AO) domain gates */
- static MESON_GATE(meson8b_ao_media_cpu, HHI_GCLK_AO, 0);
- static MESON_GATE(meson8b_ao_ahb_sram, HHI_GCLK_AO, 1);
- static MESON_GATE(meson8b_ao_ahb_bus, HHI_GCLK_AO, 2);
- static MESON_GATE(meson8b_ao_iface, HHI_GCLK_AO, 3);
- static struct clk_hw_onecell_data meson8_hw_onecell_data = {
- .hws = {
- [CLKID_PLL_FIXED] = &meson8b_fixed_pll.hw,
- [CLKID_PLL_VID] = &meson8b_vid_pll.hw,
- [CLKID_PLL_SYS] = &meson8b_sys_pll.hw,
- [CLKID_FCLK_DIV2] = &meson8b_fclk_div2.hw,
- [CLKID_FCLK_DIV3] = &meson8b_fclk_div3.hw,
- [CLKID_FCLK_DIV4] = &meson8b_fclk_div4.hw,
- [CLKID_FCLK_DIV5] = &meson8b_fclk_div5.hw,
- [CLKID_FCLK_DIV7] = &meson8b_fclk_div7.hw,
- [CLKID_CPUCLK] = &meson8b_cpu_clk.hw,
- [CLKID_MPEG_SEL] = &meson8b_mpeg_clk_sel.hw,
- [CLKID_MPEG_DIV] = &meson8b_mpeg_clk_div.hw,
- [CLKID_CLK81] = &meson8b_clk81.hw,
- [CLKID_DDR] = &meson8b_ddr.hw,
- [CLKID_DOS] = &meson8b_dos.hw,
- [CLKID_ISA] = &meson8b_isa.hw,
- [CLKID_PL301] = &meson8b_pl301.hw,
- [CLKID_PERIPHS] = &meson8b_periphs.hw,
- [CLKID_SPICC] = &meson8b_spicc.hw,
- [CLKID_I2C] = &meson8b_i2c.hw,
- [CLKID_SAR_ADC] = &meson8b_sar_adc.hw,
- [CLKID_SMART_CARD] = &meson8b_smart_card.hw,
- [CLKID_RNG0] = &meson8b_rng0.hw,
- [CLKID_UART0] = &meson8b_uart0.hw,
- [CLKID_SDHC] = &meson8b_sdhc.hw,
- [CLKID_STREAM] = &meson8b_stream.hw,
- [CLKID_ASYNC_FIFO] = &meson8b_async_fifo.hw,
- [CLKID_SDIO] = &meson8b_sdio.hw,
- [CLKID_ABUF] = &meson8b_abuf.hw,
- [CLKID_HIU_IFACE] = &meson8b_hiu_iface.hw,
- [CLKID_ASSIST_MISC] = &meson8b_assist_misc.hw,
- [CLKID_SPI] = &meson8b_spi.hw,
- [CLKID_I2S_SPDIF] = &meson8b_i2s_spdif.hw,
- [CLKID_ETH] = &meson8b_eth.hw,
- [CLKID_DEMUX] = &meson8b_demux.hw,
- [CLKID_AIU_GLUE] = &meson8b_aiu_glue.hw,
- [CLKID_IEC958] = &meson8b_iec958.hw,
- [CLKID_I2S_OUT] = &meson8b_i2s_out.hw,
- [CLKID_AMCLK] = &meson8b_amclk.hw,
- [CLKID_AIFIFO2] = &meson8b_aififo2.hw,
- [CLKID_MIXER] = &meson8b_mixer.hw,
- [CLKID_MIXER_IFACE] = &meson8b_mixer_iface.hw,
- [CLKID_ADC] = &meson8b_adc.hw,
- [CLKID_BLKMV] = &meson8b_blkmv.hw,
- [CLKID_AIU] = &meson8b_aiu.hw,
- [CLKID_UART1] = &meson8b_uart1.hw,
- [CLKID_G2D] = &meson8b_g2d.hw,
- [CLKID_USB0] = &meson8b_usb0.hw,
- [CLKID_USB1] = &meson8b_usb1.hw,
- [CLKID_RESET] = &meson8b_reset.hw,
- [CLKID_NAND] = &meson8b_nand.hw,
- [CLKID_DOS_PARSER] = &meson8b_dos_parser.hw,
- [CLKID_USB] = &meson8b_usb.hw,
- [CLKID_VDIN1] = &meson8b_vdin1.hw,
- [CLKID_AHB_ARB0] = &meson8b_ahb_arb0.hw,
- [CLKID_EFUSE] = &meson8b_efuse.hw,
- [CLKID_BOOT_ROM] = &meson8b_boot_rom.hw,
- [CLKID_AHB_DATA_BUS] = &meson8b_ahb_data_bus.hw,
- [CLKID_AHB_CTRL_BUS] = &meson8b_ahb_ctrl_bus.hw,
- [CLKID_HDMI_INTR_SYNC] = &meson8b_hdmi_intr_sync.hw,
- [CLKID_HDMI_PCLK] = &meson8b_hdmi_pclk.hw,
- [CLKID_USB1_DDR_BRIDGE] = &meson8b_usb1_ddr_bridge.hw,
- [CLKID_USB0_DDR_BRIDGE] = &meson8b_usb0_ddr_bridge.hw,
- [CLKID_MMC_PCLK] = &meson8b_mmc_pclk.hw,
- [CLKID_DVIN] = &meson8b_dvin.hw,
- [CLKID_UART2] = &meson8b_uart2.hw,
- [CLKID_SANA] = &meson8b_sana.hw,
- [CLKID_VPU_INTR] = &meson8b_vpu_intr.hw,
- [CLKID_SEC_AHB_AHB3_BRIDGE] = &meson8b_sec_ahb_ahb3_bridge.hw,
- [CLKID_CLK81_A9] = &meson8b_clk81_a9.hw,
- [CLKID_VCLK2_VENCI0] = &meson8b_vclk2_venci0.hw,
- [CLKID_VCLK2_VENCI1] = &meson8b_vclk2_venci1.hw,
- [CLKID_VCLK2_VENCP0] = &meson8b_vclk2_vencp0.hw,
- [CLKID_VCLK2_VENCP1] = &meson8b_vclk2_vencp1.hw,
- [CLKID_GCLK_VENCI_INT] = &meson8b_gclk_venci_int.hw,
- [CLKID_GCLK_VENCP_INT] = &meson8b_gclk_vencp_int.hw,
- [CLKID_DAC_CLK] = &meson8b_dac_clk.hw,
- [CLKID_AOCLK_GATE] = &meson8b_aoclk_gate.hw,
- [CLKID_IEC958_GATE] = &meson8b_iec958_gate.hw,
- [CLKID_ENC480P] = &meson8b_enc480p.hw,
- [CLKID_RNG1] = &meson8b_rng1.hw,
- [CLKID_GCLK_VENCL_INT] = &meson8b_gclk_vencl_int.hw,
- [CLKID_VCLK2_VENCLMCC] = &meson8b_vclk2_venclmcc.hw,
- [CLKID_VCLK2_VENCL] = &meson8b_vclk2_vencl.hw,
- [CLKID_VCLK2_OTHER] = &meson8b_vclk2_other.hw,
- [CLKID_EDP] = &meson8b_edp.hw,
- [CLKID_AO_MEDIA_CPU] = &meson8b_ao_media_cpu.hw,
- [CLKID_AO_AHB_SRAM] = &meson8b_ao_ahb_sram.hw,
- [CLKID_AO_AHB_BUS] = &meson8b_ao_ahb_bus.hw,
- [CLKID_AO_IFACE] = &meson8b_ao_iface.hw,
- [CLKID_MPLL0] = &meson8b_mpll0.hw,
- [CLKID_MPLL1] = &meson8b_mpll1.hw,
- [CLKID_MPLL2] = &meson8b_mpll2.hw,
- [CLKID_MPLL0_DIV] = &meson8b_mpll0_div.hw,
- [CLKID_MPLL1_DIV] = &meson8b_mpll1_div.hw,
- [CLKID_MPLL2_DIV] = &meson8b_mpll2_div.hw,
- [CLKID_CPU_IN_SEL] = &meson8b_cpu_in_sel.hw,
- [CLKID_CPU_IN_DIV2] = &meson8b_cpu_in_div2.hw,
- [CLKID_CPU_IN_DIV3] = &meson8b_cpu_in_div3.hw,
- [CLKID_CPU_SCALE_DIV] = &meson8b_cpu_scale_div.hw,
- [CLKID_CPU_SCALE_OUT_SEL] = &meson8b_cpu_scale_out_sel.hw,
- [CLKID_MPLL_PREDIV] = &meson8b_mpll_prediv.hw,
- [CLKID_FCLK_DIV2_DIV] = &meson8b_fclk_div2_div.hw,
- [CLKID_FCLK_DIV3_DIV] = &meson8b_fclk_div3_div.hw,
- [CLKID_FCLK_DIV4_DIV] = &meson8b_fclk_div4_div.hw,
- [CLKID_FCLK_DIV5_DIV] = &meson8b_fclk_div5_div.hw,
- [CLKID_FCLK_DIV7_DIV] = &meson8b_fclk_div7_div.hw,
- [CLKID_NAND_SEL] = &meson8b_nand_clk_sel.hw,
- [CLKID_NAND_DIV] = &meson8b_nand_clk_div.hw,
- [CLKID_NAND_CLK] = &meson8b_nand_clk_gate.hw,
- [CLKID_PLL_FIXED_DCO] = &meson8b_fixed_pll_dco.hw,
- [CLKID_HDMI_PLL_DCO] = &meson8b_hdmi_pll_dco.hw,
- [CLKID_PLL_SYS_DCO] = &meson8b_sys_pll_dco.hw,
- [CLKID_CPU_CLK_DIV2] = &meson8b_cpu_clk_div2.hw,
- [CLKID_CPU_CLK_DIV3] = &meson8b_cpu_clk_div3.hw,
- [CLKID_CPU_CLK_DIV4] = &meson8b_cpu_clk_div4.hw,
- [CLKID_CPU_CLK_DIV5] = &meson8b_cpu_clk_div5.hw,
- [CLKID_CPU_CLK_DIV6] = &meson8b_cpu_clk_div6.hw,
- [CLKID_CPU_CLK_DIV7] = &meson8b_cpu_clk_div7.hw,
- [CLKID_CPU_CLK_DIV8] = &meson8b_cpu_clk_div8.hw,
- [CLKID_APB_SEL] = &meson8b_apb_clk_sel.hw,
- [CLKID_APB] = &meson8b_apb_clk_gate.hw,
- [CLKID_PERIPH_SEL] = &meson8b_periph_clk_sel.hw,
- [CLKID_PERIPH] = &meson8b_periph_clk_gate.hw,
- [CLKID_AXI_SEL] = &meson8b_axi_clk_sel.hw,
- [CLKID_AXI] = &meson8b_axi_clk_gate.hw,
- [CLKID_L2_DRAM_SEL] = &meson8b_l2_dram_clk_sel.hw,
- [CLKID_L2_DRAM] = &meson8b_l2_dram_clk_gate.hw,
- [CLKID_HDMI_PLL_LVDS_OUT] = &meson8b_hdmi_pll_lvds_out.hw,
- [CLKID_HDMI_PLL_HDMI_OUT] = &meson8b_hdmi_pll_hdmi_out.hw,
- [CLKID_VID_PLL_IN_SEL] = &meson8b_vid_pll_in_sel.hw,
- [CLKID_VID_PLL_IN_EN] = &meson8b_vid_pll_in_en.hw,
- [CLKID_VID_PLL_PRE_DIV] = &meson8b_vid_pll_pre_div.hw,
- [CLKID_VID_PLL_POST_DIV] = &meson8b_vid_pll_post_div.hw,
- [CLKID_VID_PLL_FINAL_DIV] = &meson8b_vid_pll_final_div.hw,
- [CLKID_VCLK_IN_SEL] = &meson8b_vclk_in_sel.hw,
- [CLKID_VCLK_IN_EN] = &meson8b_vclk_in_en.hw,
- [CLKID_VCLK_EN] = &meson8b_vclk_en.hw,
- [CLKID_VCLK_DIV1] = &meson8b_vclk_div1_gate.hw,
- [CLKID_VCLK_DIV2_DIV] = &meson8b_vclk_div2_div.hw,
- [CLKID_VCLK_DIV2] = &meson8b_vclk_div2_div_gate.hw,
- [CLKID_VCLK_DIV4_DIV] = &meson8b_vclk_div4_div.hw,
- [CLKID_VCLK_DIV4] = &meson8b_vclk_div4_div_gate.hw,
- [CLKID_VCLK_DIV6_DIV] = &meson8b_vclk_div6_div.hw,
- [CLKID_VCLK_DIV6] = &meson8b_vclk_div6_div_gate.hw,
- [CLKID_VCLK_DIV12_DIV] = &meson8b_vclk_div12_div.hw,
- [CLKID_VCLK_DIV12] = &meson8b_vclk_div12_div_gate.hw,
- [CLKID_VCLK2_IN_SEL] = &meson8b_vclk2_in_sel.hw,
- [CLKID_VCLK2_IN_EN] = &meson8b_vclk2_clk_in_en.hw,
- [CLKID_VCLK2_EN] = &meson8b_vclk2_clk_en.hw,
- [CLKID_VCLK2_DIV1] = &meson8b_vclk2_div1_gate.hw,
- [CLKID_VCLK2_DIV2_DIV] = &meson8b_vclk2_div2_div.hw,
- [CLKID_VCLK2_DIV2] = &meson8b_vclk2_div2_div_gate.hw,
- [CLKID_VCLK2_DIV4_DIV] = &meson8b_vclk2_div4_div.hw,
- [CLKID_VCLK2_DIV4] = &meson8b_vclk2_div4_div_gate.hw,
- [CLKID_VCLK2_DIV6_DIV] = &meson8b_vclk2_div6_div.hw,
- [CLKID_VCLK2_DIV6] = &meson8b_vclk2_div6_div_gate.hw,
- [CLKID_VCLK2_DIV12_DIV] = &meson8b_vclk2_div12_div.hw,
- [CLKID_VCLK2_DIV12] = &meson8b_vclk2_div12_div_gate.hw,
- [CLKID_CTS_ENCT_SEL] = &meson8b_cts_enct_sel.hw,
- [CLKID_CTS_ENCT] = &meson8b_cts_enct.hw,
- [CLKID_CTS_ENCP_SEL] = &meson8b_cts_encp_sel.hw,
- [CLKID_CTS_ENCP] = &meson8b_cts_encp.hw,
- [CLKID_CTS_ENCI_SEL] = &meson8b_cts_enci_sel.hw,
- [CLKID_CTS_ENCI] = &meson8b_cts_enci.hw,
- [CLKID_HDMI_TX_PIXEL_SEL] = &meson8b_hdmi_tx_pixel_sel.hw,
- [CLKID_HDMI_TX_PIXEL] = &meson8b_hdmi_tx_pixel.hw,
- [CLKID_CTS_ENCL_SEL] = &meson8b_cts_encl_sel.hw,
- [CLKID_CTS_ENCL] = &meson8b_cts_encl.hw,
- [CLKID_CTS_VDAC0_SEL] = &meson8b_cts_vdac0_sel.hw,
- [CLKID_CTS_VDAC0] = &meson8b_cts_vdac0.hw,
- [CLKID_HDMI_SYS_SEL] = &meson8b_hdmi_sys_sel.hw,
- [CLKID_HDMI_SYS_DIV] = &meson8b_hdmi_sys_div.hw,
- [CLKID_HDMI_SYS] = &meson8b_hdmi_sys.hw,
- [CLKID_MALI_0_SEL] = &meson8b_mali_0_sel.hw,
- [CLKID_MALI_0_DIV] = &meson8b_mali_0_div.hw,
- [CLKID_MALI] = &meson8b_mali_0.hw,
- [CLKID_VPU_0_SEL] = &meson8b_vpu_0_sel.hw,
- [CLKID_VPU_0_DIV] = &meson8b_vpu_0_div.hw,
- [CLKID_VPU] = &meson8b_vpu_0.hw,
- [CLKID_VDEC_1_SEL] = &meson8b_vdec_1_sel.hw,
- [CLKID_VDEC_1_1_DIV] = &meson8b_vdec_1_1_div.hw,
- [CLKID_VDEC_1] = &meson8b_vdec_1_1.hw,
- [CLKID_VDEC_HCODEC_SEL] = &meson8b_vdec_hcodec_sel.hw,
- [CLKID_VDEC_HCODEC_DIV] = &meson8b_vdec_hcodec_div.hw,
- [CLKID_VDEC_HCODEC] = &meson8b_vdec_hcodec.hw,
- [CLKID_VDEC_2_SEL] = &meson8b_vdec_2_sel.hw,
- [CLKID_VDEC_2_DIV] = &meson8b_vdec_2_div.hw,
- [CLKID_VDEC_2] = &meson8b_vdec_2.hw,
- [CLKID_VDEC_HEVC_SEL] = &meson8b_vdec_hevc_sel.hw,
- [CLKID_VDEC_HEVC_DIV] = &meson8b_vdec_hevc_div.hw,
- [CLKID_VDEC_HEVC_EN] = &meson8b_vdec_hevc_en.hw,
- [CLKID_VDEC_HEVC] = &meson8b_vdec_hevc.hw,
- [CLKID_CTS_AMCLK_SEL] = &meson8b_cts_amclk_sel.hw,
- [CLKID_CTS_AMCLK_DIV] = &meson8b_cts_amclk_div.hw,
- [CLKID_CTS_AMCLK] = &meson8b_cts_amclk.hw,
- [CLKID_CTS_MCLK_I958_SEL] = &meson8b_cts_mclk_i958_sel.hw,
- [CLKID_CTS_MCLK_I958_DIV] = &meson8b_cts_mclk_i958_div.hw,
- [CLKID_CTS_MCLK_I958] = &meson8b_cts_mclk_i958.hw,
- [CLKID_CTS_I958] = &meson8b_cts_i958.hw,
- [CLKID_VID_PLL_LVDS_EN] = &meson8b_vid_pll_lvds_en.hw,
- [CLKID_HDMI_PLL_DCO_IN] = &hdmi_pll_dco_in.hw,
- [CLK_NR_CLKS] = NULL,
- },
- .num = CLK_NR_CLKS,
- };
- static struct clk_hw_onecell_data meson8b_hw_onecell_data = {
- .hws = {
- [CLKID_PLL_FIXED] = &meson8b_fixed_pll.hw,
- [CLKID_PLL_VID] = &meson8b_vid_pll.hw,
- [CLKID_PLL_SYS] = &meson8b_sys_pll.hw,
- [CLKID_FCLK_DIV2] = &meson8b_fclk_div2.hw,
- [CLKID_FCLK_DIV3] = &meson8b_fclk_div3.hw,
- [CLKID_FCLK_DIV4] = &meson8b_fclk_div4.hw,
- [CLKID_FCLK_DIV5] = &meson8b_fclk_div5.hw,
- [CLKID_FCLK_DIV7] = &meson8b_fclk_div7.hw,
- [CLKID_CPUCLK] = &meson8b_cpu_clk.hw,
- [CLKID_MPEG_SEL] = &meson8b_mpeg_clk_sel.hw,
- [CLKID_MPEG_DIV] = &meson8b_mpeg_clk_div.hw,
- [CLKID_CLK81] = &meson8b_clk81.hw,
- [CLKID_DDR] = &meson8b_ddr.hw,
- [CLKID_DOS] = &meson8b_dos.hw,
- [CLKID_ISA] = &meson8b_isa.hw,
- [CLKID_PL301] = &meson8b_pl301.hw,
- [CLKID_PERIPHS] = &meson8b_periphs.hw,
- [CLKID_SPICC] = &meson8b_spicc.hw,
- [CLKID_I2C] = &meson8b_i2c.hw,
- [CLKID_SAR_ADC] = &meson8b_sar_adc.hw,
- [CLKID_SMART_CARD] = &meson8b_smart_card.hw,
- [CLKID_RNG0] = &meson8b_rng0.hw,
- [CLKID_UART0] = &meson8b_uart0.hw,
- [CLKID_SDHC] = &meson8b_sdhc.hw,
- [CLKID_STREAM] = &meson8b_stream.hw,
- [CLKID_ASYNC_FIFO] = &meson8b_async_fifo.hw,
- [CLKID_SDIO] = &meson8b_sdio.hw,
- [CLKID_ABUF] = &meson8b_abuf.hw,
- [CLKID_HIU_IFACE] = &meson8b_hiu_iface.hw,
- [CLKID_ASSIST_MISC] = &meson8b_assist_misc.hw,
- [CLKID_SPI] = &meson8b_spi.hw,
- [CLKID_I2S_SPDIF] = &meson8b_i2s_spdif.hw,
- [CLKID_ETH] = &meson8b_eth.hw,
- [CLKID_DEMUX] = &meson8b_demux.hw,
- [CLKID_AIU_GLUE] = &meson8b_aiu_glue.hw,
- [CLKID_IEC958] = &meson8b_iec958.hw,
- [CLKID_I2S_OUT] = &meson8b_i2s_out.hw,
- [CLKID_AMCLK] = &meson8b_amclk.hw,
- [CLKID_AIFIFO2] = &meson8b_aififo2.hw,
- [CLKID_MIXER] = &meson8b_mixer.hw,
- [CLKID_MIXER_IFACE] = &meson8b_mixer_iface.hw,
- [CLKID_ADC] = &meson8b_adc.hw,
- [CLKID_BLKMV] = &meson8b_blkmv.hw,
- [CLKID_AIU] = &meson8b_aiu.hw,
- [CLKID_UART1] = &meson8b_uart1.hw,
- [CLKID_G2D] = &meson8b_g2d.hw,
- [CLKID_USB0] = &meson8b_usb0.hw,
- [CLKID_USB1] = &meson8b_usb1.hw,
- [CLKID_RESET] = &meson8b_reset.hw,
- [CLKID_NAND] = &meson8b_nand.hw,
- [CLKID_DOS_PARSER] = &meson8b_dos_parser.hw,
- [CLKID_USB] = &meson8b_usb.hw,
- [CLKID_VDIN1] = &meson8b_vdin1.hw,
- [CLKID_AHB_ARB0] = &meson8b_ahb_arb0.hw,
- [CLKID_EFUSE] = &meson8b_efuse.hw,
- [CLKID_BOOT_ROM] = &meson8b_boot_rom.hw,
- [CLKID_AHB_DATA_BUS] = &meson8b_ahb_data_bus.hw,
- [CLKID_AHB_CTRL_BUS] = &meson8b_ahb_ctrl_bus.hw,
- [CLKID_HDMI_INTR_SYNC] = &meson8b_hdmi_intr_sync.hw,
- [CLKID_HDMI_PCLK] = &meson8b_hdmi_pclk.hw,
- [CLKID_USB1_DDR_BRIDGE] = &meson8b_usb1_ddr_bridge.hw,
- [CLKID_USB0_DDR_BRIDGE] = &meson8b_usb0_ddr_bridge.hw,
- [CLKID_MMC_PCLK] = &meson8b_mmc_pclk.hw,
- [CLKID_DVIN] = &meson8b_dvin.hw,
- [CLKID_UART2] = &meson8b_uart2.hw,
- [CLKID_SANA] = &meson8b_sana.hw,
- [CLKID_VPU_INTR] = &meson8b_vpu_intr.hw,
- [CLKID_SEC_AHB_AHB3_BRIDGE] = &meson8b_sec_ahb_ahb3_bridge.hw,
- [CLKID_CLK81_A9] = &meson8b_clk81_a9.hw,
- [CLKID_VCLK2_VENCI0] = &meson8b_vclk2_venci0.hw,
- [CLKID_VCLK2_VENCI1] = &meson8b_vclk2_venci1.hw,
- [CLKID_VCLK2_VENCP0] = &meson8b_vclk2_vencp0.hw,
- [CLKID_VCLK2_VENCP1] = &meson8b_vclk2_vencp1.hw,
- [CLKID_GCLK_VENCI_INT] = &meson8b_gclk_venci_int.hw,
- [CLKID_GCLK_VENCP_INT] = &meson8b_gclk_vencp_int.hw,
- [CLKID_DAC_CLK] = &meson8b_dac_clk.hw,
- [CLKID_AOCLK_GATE] = &meson8b_aoclk_gate.hw,
- [CLKID_IEC958_GATE] = &meson8b_iec958_gate.hw,
- [CLKID_ENC480P] = &meson8b_enc480p.hw,
- [CLKID_RNG1] = &meson8b_rng1.hw,
- [CLKID_GCLK_VENCL_INT] = &meson8b_gclk_vencl_int.hw,
- [CLKID_VCLK2_VENCLMCC] = &meson8b_vclk2_venclmcc.hw,
- [CLKID_VCLK2_VENCL] = &meson8b_vclk2_vencl.hw,
- [CLKID_VCLK2_OTHER] = &meson8b_vclk2_other.hw,
- [CLKID_EDP] = &meson8b_edp.hw,
- [CLKID_AO_MEDIA_CPU] = &meson8b_ao_media_cpu.hw,
- [CLKID_AO_AHB_SRAM] = &meson8b_ao_ahb_sram.hw,
- [CLKID_AO_AHB_BUS] = &meson8b_ao_ahb_bus.hw,
- [CLKID_AO_IFACE] = &meson8b_ao_iface.hw,
- [CLKID_MPLL0] = &meson8b_mpll0.hw,
- [CLKID_MPLL1] = &meson8b_mpll1.hw,
- [CLKID_MPLL2] = &meson8b_mpll2.hw,
- [CLKID_MPLL0_DIV] = &meson8b_mpll0_div.hw,
- [CLKID_MPLL1_DIV] = &meson8b_mpll1_div.hw,
- [CLKID_MPLL2_DIV] = &meson8b_mpll2_div.hw,
- [CLKID_CPU_IN_SEL] = &meson8b_cpu_in_sel.hw,
- [CLKID_CPU_IN_DIV2] = &meson8b_cpu_in_div2.hw,
- [CLKID_CPU_IN_DIV3] = &meson8b_cpu_in_div3.hw,
- [CLKID_CPU_SCALE_DIV] = &meson8b_cpu_scale_div.hw,
- [CLKID_CPU_SCALE_OUT_SEL] = &meson8b_cpu_scale_out_sel.hw,
- [CLKID_MPLL_PREDIV] = &meson8b_mpll_prediv.hw,
- [CLKID_FCLK_DIV2_DIV] = &meson8b_fclk_div2_div.hw,
- [CLKID_FCLK_DIV3_DIV] = &meson8b_fclk_div3_div.hw,
- [CLKID_FCLK_DIV4_DIV] = &meson8b_fclk_div4_div.hw,
- [CLKID_FCLK_DIV5_DIV] = &meson8b_fclk_div5_div.hw,
- [CLKID_FCLK_DIV7_DIV] = &meson8b_fclk_div7_div.hw,
- [CLKID_NAND_SEL] = &meson8b_nand_clk_sel.hw,
- [CLKID_NAND_DIV] = &meson8b_nand_clk_div.hw,
- [CLKID_NAND_CLK] = &meson8b_nand_clk_gate.hw,
- [CLKID_PLL_FIXED_DCO] = &meson8b_fixed_pll_dco.hw,
- [CLKID_HDMI_PLL_DCO] = &meson8b_hdmi_pll_dco.hw,
- [CLKID_PLL_SYS_DCO] = &meson8b_sys_pll_dco.hw,
- [CLKID_CPU_CLK_DIV2] = &meson8b_cpu_clk_div2.hw,
- [CLKID_CPU_CLK_DIV3] = &meson8b_cpu_clk_div3.hw,
- [CLKID_CPU_CLK_DIV4] = &meson8b_cpu_clk_div4.hw,
- [CLKID_CPU_CLK_DIV5] = &meson8b_cpu_clk_div5.hw,
- [CLKID_CPU_CLK_DIV6] = &meson8b_cpu_clk_div6.hw,
- [CLKID_CPU_CLK_DIV7] = &meson8b_cpu_clk_div7.hw,
- [CLKID_CPU_CLK_DIV8] = &meson8b_cpu_clk_div8.hw,
- [CLKID_APB_SEL] = &meson8b_apb_clk_sel.hw,
- [CLKID_APB] = &meson8b_apb_clk_gate.hw,
- [CLKID_PERIPH_SEL] = &meson8b_periph_clk_sel.hw,
- [CLKID_PERIPH] = &meson8b_periph_clk_gate.hw,
- [CLKID_AXI_SEL] = &meson8b_axi_clk_sel.hw,
- [CLKID_AXI] = &meson8b_axi_clk_gate.hw,
- [CLKID_L2_DRAM_SEL] = &meson8b_l2_dram_clk_sel.hw,
- [CLKID_L2_DRAM] = &meson8b_l2_dram_clk_gate.hw,
- [CLKID_HDMI_PLL_LVDS_OUT] = &meson8b_hdmi_pll_lvds_out.hw,
- [CLKID_HDMI_PLL_HDMI_OUT] = &meson8b_hdmi_pll_hdmi_out.hw,
- [CLKID_VID_PLL_IN_SEL] = &meson8b_vid_pll_in_sel.hw,
- [CLKID_VID_PLL_IN_EN] = &meson8b_vid_pll_in_en.hw,
- [CLKID_VID_PLL_PRE_DIV] = &meson8b_vid_pll_pre_div.hw,
- [CLKID_VID_PLL_POST_DIV] = &meson8b_vid_pll_post_div.hw,
- [CLKID_VID_PLL_FINAL_DIV] = &meson8b_vid_pll_final_div.hw,
- [CLKID_VCLK_IN_SEL] = &meson8b_vclk_in_sel.hw,
- [CLKID_VCLK_IN_EN] = &meson8b_vclk_in_en.hw,
- [CLKID_VCLK_EN] = &meson8b_vclk_en.hw,
- [CLKID_VCLK_DIV1] = &meson8b_vclk_div1_gate.hw,
- [CLKID_VCLK_DIV2_DIV] = &meson8b_vclk_div2_div.hw,
- [CLKID_VCLK_DIV2] = &meson8b_vclk_div2_div_gate.hw,
- [CLKID_VCLK_DIV4_DIV] = &meson8b_vclk_div4_div.hw,
- [CLKID_VCLK_DIV4] = &meson8b_vclk_div4_div_gate.hw,
- [CLKID_VCLK_DIV6_DIV] = &meson8b_vclk_div6_div.hw,
- [CLKID_VCLK_DIV6] = &meson8b_vclk_div6_div_gate.hw,
- [CLKID_VCLK_DIV12_DIV] = &meson8b_vclk_div12_div.hw,
- [CLKID_VCLK_DIV12] = &meson8b_vclk_div12_div_gate.hw,
- [CLKID_VCLK2_IN_SEL] = &meson8b_vclk2_in_sel.hw,
- [CLKID_VCLK2_IN_EN] = &meson8b_vclk2_clk_in_en.hw,
- [CLKID_VCLK2_EN] = &meson8b_vclk2_clk_en.hw,
- [CLKID_VCLK2_DIV1] = &meson8b_vclk2_div1_gate.hw,
- [CLKID_VCLK2_DIV2_DIV] = &meson8b_vclk2_div2_div.hw,
- [CLKID_VCLK2_DIV2] = &meson8b_vclk2_div2_div_gate.hw,
- [CLKID_VCLK2_DIV4_DIV] = &meson8b_vclk2_div4_div.hw,
- [CLKID_VCLK2_DIV4] = &meson8b_vclk2_div4_div_gate.hw,
- [CLKID_VCLK2_DIV6_DIV] = &meson8b_vclk2_div6_div.hw,
- [CLKID_VCLK2_DIV6] = &meson8b_vclk2_div6_div_gate.hw,
- [CLKID_VCLK2_DIV12_DIV] = &meson8b_vclk2_div12_div.hw,
- [CLKID_VCLK2_DIV12] = &meson8b_vclk2_div12_div_gate.hw,
- [CLKID_CTS_ENCT_SEL] = &meson8b_cts_enct_sel.hw,
- [CLKID_CTS_ENCT] = &meson8b_cts_enct.hw,
- [CLKID_CTS_ENCP_SEL] = &meson8b_cts_encp_sel.hw,
- [CLKID_CTS_ENCP] = &meson8b_cts_encp.hw,
- [CLKID_CTS_ENCI_SEL] = &meson8b_cts_enci_sel.hw,
- [CLKID_CTS_ENCI] = &meson8b_cts_enci.hw,
- [CLKID_HDMI_TX_PIXEL_SEL] = &meson8b_hdmi_tx_pixel_sel.hw,
- [CLKID_HDMI_TX_PIXEL] = &meson8b_hdmi_tx_pixel.hw,
- [CLKID_CTS_ENCL_SEL] = &meson8b_cts_encl_sel.hw,
- [CLKID_CTS_ENCL] = &meson8b_cts_encl.hw,
- [CLKID_CTS_VDAC0_SEL] = &meson8b_cts_vdac0_sel.hw,
- [CLKID_CTS_VDAC0] = &meson8b_cts_vdac0.hw,
- [CLKID_HDMI_SYS_SEL] = &meson8b_hdmi_sys_sel.hw,
- [CLKID_HDMI_SYS_DIV] = &meson8b_hdmi_sys_div.hw,
- [CLKID_HDMI_SYS] = &meson8b_hdmi_sys.hw,
- [CLKID_MALI_0_SEL] = &meson8b_mali_0_sel.hw,
- [CLKID_MALI_0_DIV] = &meson8b_mali_0_div.hw,
- [CLKID_MALI_0] = &meson8b_mali_0.hw,
- [CLKID_MALI_1_SEL] = &meson8b_mali_1_sel.hw,
- [CLKID_MALI_1_DIV] = &meson8b_mali_1_div.hw,
- [CLKID_MALI_1] = &meson8b_mali_1.hw,
- [CLKID_MALI] = &meson8b_mali.hw,
- [CLKID_VPU_0_SEL] = &meson8b_vpu_0_sel.hw,
- [CLKID_VPU_0_DIV] = &meson8b_vpu_0_div.hw,
- [CLKID_VPU_0] = &meson8b_vpu_0.hw,
- [CLKID_VPU_1_SEL] = &meson8b_vpu_1_sel.hw,
- [CLKID_VPU_1_DIV] = &meson8b_vpu_1_div.hw,
- [CLKID_VPU_1] = &meson8b_vpu_1.hw,
- [CLKID_VPU] = &meson8b_vpu.hw,
- [CLKID_VDEC_1_SEL] = &meson8b_vdec_1_sel.hw,
- [CLKID_VDEC_1_1_DIV] = &meson8b_vdec_1_1_div.hw,
- [CLKID_VDEC_1_1] = &meson8b_vdec_1_1.hw,
- [CLKID_VDEC_1_2_DIV] = &meson8b_vdec_1_2_div.hw,
- [CLKID_VDEC_1_2] = &meson8b_vdec_1_2.hw,
- [CLKID_VDEC_1] = &meson8b_vdec_1.hw,
- [CLKID_VDEC_HCODEC_SEL] = &meson8b_vdec_hcodec_sel.hw,
- [CLKID_VDEC_HCODEC_DIV] = &meson8b_vdec_hcodec_div.hw,
- [CLKID_VDEC_HCODEC] = &meson8b_vdec_hcodec.hw,
- [CLKID_VDEC_2_SEL] = &meson8b_vdec_2_sel.hw,
- [CLKID_VDEC_2_DIV] = &meson8b_vdec_2_div.hw,
- [CLKID_VDEC_2] = &meson8b_vdec_2.hw,
- [CLKID_VDEC_HEVC_SEL] = &meson8b_vdec_hevc_sel.hw,
- [CLKID_VDEC_HEVC_DIV] = &meson8b_vdec_hevc_div.hw,
- [CLKID_VDEC_HEVC_EN] = &meson8b_vdec_hevc_en.hw,
- [CLKID_VDEC_HEVC] = &meson8b_vdec_hevc.hw,
- [CLKID_CTS_AMCLK_SEL] = &meson8b_cts_amclk_sel.hw,
- [CLKID_CTS_AMCLK_DIV] = &meson8b_cts_amclk_div.hw,
- [CLKID_CTS_AMCLK] = &meson8b_cts_amclk.hw,
- [CLKID_CTS_MCLK_I958_SEL] = &meson8b_cts_mclk_i958_sel.hw,
- [CLKID_CTS_MCLK_I958_DIV] = &meson8b_cts_mclk_i958_div.hw,
- [CLKID_CTS_MCLK_I958] = &meson8b_cts_mclk_i958.hw,
- [CLKID_CTS_I958] = &meson8b_cts_i958.hw,
- [CLKID_VID_PLL_LVDS_EN] = &meson8b_vid_pll_lvds_en.hw,
- [CLKID_HDMI_PLL_DCO_IN] = &hdmi_pll_dco_in.hw,
- [CLK_NR_CLKS] = NULL,
- },
- .num = CLK_NR_CLKS,
- };
- static struct clk_hw_onecell_data meson8m2_hw_onecell_data = {
- .hws = {
- [CLKID_PLL_FIXED] = &meson8b_fixed_pll.hw,
- [CLKID_PLL_VID] = &meson8b_vid_pll.hw,
- [CLKID_PLL_SYS] = &meson8b_sys_pll.hw,
- [CLKID_FCLK_DIV2] = &meson8b_fclk_div2.hw,
- [CLKID_FCLK_DIV3] = &meson8b_fclk_div3.hw,
- [CLKID_FCLK_DIV4] = &meson8b_fclk_div4.hw,
- [CLKID_FCLK_DIV5] = &meson8b_fclk_div5.hw,
- [CLKID_FCLK_DIV7] = &meson8b_fclk_div7.hw,
- [CLKID_CPUCLK] = &meson8b_cpu_clk.hw,
- [CLKID_MPEG_SEL] = &meson8b_mpeg_clk_sel.hw,
- [CLKID_MPEG_DIV] = &meson8b_mpeg_clk_div.hw,
- [CLKID_CLK81] = &meson8b_clk81.hw,
- [CLKID_DDR] = &meson8b_ddr.hw,
- [CLKID_DOS] = &meson8b_dos.hw,
- [CLKID_ISA] = &meson8b_isa.hw,
- [CLKID_PL301] = &meson8b_pl301.hw,
- [CLKID_PERIPHS] = &meson8b_periphs.hw,
- [CLKID_SPICC] = &meson8b_spicc.hw,
- [CLKID_I2C] = &meson8b_i2c.hw,
- [CLKID_SAR_ADC] = &meson8b_sar_adc.hw,
- [CLKID_SMART_CARD] = &meson8b_smart_card.hw,
- [CLKID_RNG0] = &meson8b_rng0.hw,
- [CLKID_UART0] = &meson8b_uart0.hw,
- [CLKID_SDHC] = &meson8b_sdhc.hw,
- [CLKID_STREAM] = &meson8b_stream.hw,
- [CLKID_ASYNC_FIFO] = &meson8b_async_fifo.hw,
- [CLKID_SDIO] = &meson8b_sdio.hw,
- [CLKID_ABUF] = &meson8b_abuf.hw,
- [CLKID_HIU_IFACE] = &meson8b_hiu_iface.hw,
- [CLKID_ASSIST_MISC] = &meson8b_assist_misc.hw,
- [CLKID_SPI] = &meson8b_spi.hw,
- [CLKID_I2S_SPDIF] = &meson8b_i2s_spdif.hw,
- [CLKID_ETH] = &meson8b_eth.hw,
- [CLKID_DEMUX] = &meson8b_demux.hw,
- [CLKID_AIU_GLUE] = &meson8b_aiu_glue.hw,
- [CLKID_IEC958] = &meson8b_iec958.hw,
- [CLKID_I2S_OUT] = &meson8b_i2s_out.hw,
- [CLKID_AMCLK] = &meson8b_amclk.hw,
- [CLKID_AIFIFO2] = &meson8b_aififo2.hw,
- [CLKID_MIXER] = &meson8b_mixer.hw,
- [CLKID_MIXER_IFACE] = &meson8b_mixer_iface.hw,
- [CLKID_ADC] = &meson8b_adc.hw,
- [CLKID_BLKMV] = &meson8b_blkmv.hw,
- [CLKID_AIU] = &meson8b_aiu.hw,
- [CLKID_UART1] = &meson8b_uart1.hw,
- [CLKID_G2D] = &meson8b_g2d.hw,
- [CLKID_USB0] = &meson8b_usb0.hw,
- [CLKID_USB1] = &meson8b_usb1.hw,
- [CLKID_RESET] = &meson8b_reset.hw,
- [CLKID_NAND] = &meson8b_nand.hw,
- [CLKID_DOS_PARSER] = &meson8b_dos_parser.hw,
- [CLKID_USB] = &meson8b_usb.hw,
- [CLKID_VDIN1] = &meson8b_vdin1.hw,
- [CLKID_AHB_ARB0] = &meson8b_ahb_arb0.hw,
- [CLKID_EFUSE] = &meson8b_efuse.hw,
- [CLKID_BOOT_ROM] = &meson8b_boot_rom.hw,
- [CLKID_AHB_DATA_BUS] = &meson8b_ahb_data_bus.hw,
- [CLKID_AHB_CTRL_BUS] = &meson8b_ahb_ctrl_bus.hw,
- [CLKID_HDMI_INTR_SYNC] = &meson8b_hdmi_intr_sync.hw,
- [CLKID_HDMI_PCLK] = &meson8b_hdmi_pclk.hw,
- [CLKID_USB1_DDR_BRIDGE] = &meson8b_usb1_ddr_bridge.hw,
- [CLKID_USB0_DDR_BRIDGE] = &meson8b_usb0_ddr_bridge.hw,
- [CLKID_MMC_PCLK] = &meson8b_mmc_pclk.hw,
- [CLKID_DVIN] = &meson8b_dvin.hw,
- [CLKID_UART2] = &meson8b_uart2.hw,
- [CLKID_SANA] = &meson8b_sana.hw,
- [CLKID_VPU_INTR] = &meson8b_vpu_intr.hw,
- [CLKID_SEC_AHB_AHB3_BRIDGE] = &meson8b_sec_ahb_ahb3_bridge.hw,
- [CLKID_CLK81_A9] = &meson8b_clk81_a9.hw,
- [CLKID_VCLK2_VENCI0] = &meson8b_vclk2_venci0.hw,
- [CLKID_VCLK2_VENCI1] = &meson8b_vclk2_venci1.hw,
- [CLKID_VCLK2_VENCP0] = &meson8b_vclk2_vencp0.hw,
- [CLKID_VCLK2_VENCP1] = &meson8b_vclk2_vencp1.hw,
- [CLKID_GCLK_VENCI_INT] = &meson8b_gclk_venci_int.hw,
- [CLKID_GCLK_VENCP_INT] = &meson8b_gclk_vencp_int.hw,
- [CLKID_DAC_CLK] = &meson8b_dac_clk.hw,
- [CLKID_AOCLK_GATE] = &meson8b_aoclk_gate.hw,
- [CLKID_IEC958_GATE] = &meson8b_iec958_gate.hw,
- [CLKID_ENC480P] = &meson8b_enc480p.hw,
- [CLKID_RNG1] = &meson8b_rng1.hw,
- [CLKID_GCLK_VENCL_INT] = &meson8b_gclk_vencl_int.hw,
- [CLKID_VCLK2_VENCLMCC] = &meson8b_vclk2_venclmcc.hw,
- [CLKID_VCLK2_VENCL] = &meson8b_vclk2_vencl.hw,
- [CLKID_VCLK2_OTHER] = &meson8b_vclk2_other.hw,
- [CLKID_EDP] = &meson8b_edp.hw,
- [CLKID_AO_MEDIA_CPU] = &meson8b_ao_media_cpu.hw,
- [CLKID_AO_AHB_SRAM] = &meson8b_ao_ahb_sram.hw,
- [CLKID_AO_AHB_BUS] = &meson8b_ao_ahb_bus.hw,
- [CLKID_AO_IFACE] = &meson8b_ao_iface.hw,
- [CLKID_MPLL0] = &meson8b_mpll0.hw,
- [CLKID_MPLL1] = &meson8b_mpll1.hw,
- [CLKID_MPLL2] = &meson8b_mpll2.hw,
- [CLKID_MPLL0_DIV] = &meson8b_mpll0_div.hw,
- [CLKID_MPLL1_DIV] = &meson8b_mpll1_div.hw,
- [CLKID_MPLL2_DIV] = &meson8b_mpll2_div.hw,
- [CLKID_CPU_IN_SEL] = &meson8b_cpu_in_sel.hw,
- [CLKID_CPU_IN_DIV2] = &meson8b_cpu_in_div2.hw,
- [CLKID_CPU_IN_DIV3] = &meson8b_cpu_in_div3.hw,
- [CLKID_CPU_SCALE_DIV] = &meson8b_cpu_scale_div.hw,
- [CLKID_CPU_SCALE_OUT_SEL] = &meson8b_cpu_scale_out_sel.hw,
- [CLKID_MPLL_PREDIV] = &meson8b_mpll_prediv.hw,
- [CLKID_FCLK_DIV2_DIV] = &meson8b_fclk_div2_div.hw,
- [CLKID_FCLK_DIV3_DIV] = &meson8b_fclk_div3_div.hw,
- [CLKID_FCLK_DIV4_DIV] = &meson8b_fclk_div4_div.hw,
- [CLKID_FCLK_DIV5_DIV] = &meson8b_fclk_div5_div.hw,
- [CLKID_FCLK_DIV7_DIV] = &meson8b_fclk_div7_div.hw,
- [CLKID_NAND_SEL] = &meson8b_nand_clk_sel.hw,
- [CLKID_NAND_DIV] = &meson8b_nand_clk_div.hw,
- [CLKID_NAND_CLK] = &meson8b_nand_clk_gate.hw,
- [CLKID_PLL_FIXED_DCO] = &meson8b_fixed_pll_dco.hw,
- [CLKID_HDMI_PLL_DCO] = &meson8b_hdmi_pll_dco.hw,
- [CLKID_PLL_SYS_DCO] = &meson8b_sys_pll_dco.hw,
- [CLKID_CPU_CLK_DIV2] = &meson8b_cpu_clk_div2.hw,
- [CLKID_CPU_CLK_DIV3] = &meson8b_cpu_clk_div3.hw,
- [CLKID_CPU_CLK_DIV4] = &meson8b_cpu_clk_div4.hw,
- [CLKID_CPU_CLK_DIV5] = &meson8b_cpu_clk_div5.hw,
- [CLKID_CPU_CLK_DIV6] = &meson8b_cpu_clk_div6.hw,
- [CLKID_CPU_CLK_DIV7] = &meson8b_cpu_clk_div7.hw,
- [CLKID_CPU_CLK_DIV8] = &meson8b_cpu_clk_div8.hw,
- [CLKID_APB_SEL] = &meson8b_apb_clk_sel.hw,
- [CLKID_APB] = &meson8b_apb_clk_gate.hw,
- [CLKID_PERIPH_SEL] = &meson8b_periph_clk_sel.hw,
- [CLKID_PERIPH] = &meson8b_periph_clk_gate.hw,
- [CLKID_AXI_SEL] = &meson8b_axi_clk_sel.hw,
- [CLKID_AXI] = &meson8b_axi_clk_gate.hw,
- [CLKID_L2_DRAM_SEL] = &meson8b_l2_dram_clk_sel.hw,
- [CLKID_L2_DRAM] = &meson8b_l2_dram_clk_gate.hw,
- [CLKID_HDMI_PLL_LVDS_OUT] = &meson8b_hdmi_pll_lvds_out.hw,
- [CLKID_HDMI_PLL_HDMI_OUT] = &meson8b_hdmi_pll_hdmi_out.hw,
- [CLKID_VID_PLL_IN_SEL] = &meson8b_vid_pll_in_sel.hw,
- [CLKID_VID_PLL_IN_EN] = &meson8b_vid_pll_in_en.hw,
- [CLKID_VID_PLL_PRE_DIV] = &meson8b_vid_pll_pre_div.hw,
- [CLKID_VID_PLL_POST_DIV] = &meson8b_vid_pll_post_div.hw,
- [CLKID_VID_PLL_FINAL_DIV] = &meson8b_vid_pll_final_div.hw,
- [CLKID_VCLK_IN_SEL] = &meson8b_vclk_in_sel.hw,
- [CLKID_VCLK_IN_EN] = &meson8b_vclk_in_en.hw,
- [CLKID_VCLK_EN] = &meson8b_vclk_en.hw,
- [CLKID_VCLK_DIV1] = &meson8b_vclk_div1_gate.hw,
- [CLKID_VCLK_DIV2_DIV] = &meson8b_vclk_div2_div.hw,
- [CLKID_VCLK_DIV2] = &meson8b_vclk_div2_div_gate.hw,
- [CLKID_VCLK_DIV4_DIV] = &meson8b_vclk_div4_div.hw,
- [CLKID_VCLK_DIV4] = &meson8b_vclk_div4_div_gate.hw,
- [CLKID_VCLK_DIV6_DIV] = &meson8b_vclk_div6_div.hw,
- [CLKID_VCLK_DIV6] = &meson8b_vclk_div6_div_gate.hw,
- [CLKID_VCLK_DIV12_DIV] = &meson8b_vclk_div12_div.hw,
- [CLKID_VCLK_DIV12] = &meson8b_vclk_div12_div_gate.hw,
- [CLKID_VCLK2_IN_SEL] = &meson8b_vclk2_in_sel.hw,
- [CLKID_VCLK2_IN_EN] = &meson8b_vclk2_clk_in_en.hw,
- [CLKID_VCLK2_EN] = &meson8b_vclk2_clk_en.hw,
- [CLKID_VCLK2_DIV1] = &meson8b_vclk2_div1_gate.hw,
- [CLKID_VCLK2_DIV2_DIV] = &meson8b_vclk2_div2_div.hw,
- [CLKID_VCLK2_DIV2] = &meson8b_vclk2_div2_div_gate.hw,
- [CLKID_VCLK2_DIV4_DIV] = &meson8b_vclk2_div4_div.hw,
- [CLKID_VCLK2_DIV4] = &meson8b_vclk2_div4_div_gate.hw,
- [CLKID_VCLK2_DIV6_DIV] = &meson8b_vclk2_div6_div.hw,
- [CLKID_VCLK2_DIV6] = &meson8b_vclk2_div6_div_gate.hw,
- [CLKID_VCLK2_DIV12_DIV] = &meson8b_vclk2_div12_div.hw,
- [CLKID_VCLK2_DIV12] = &meson8b_vclk2_div12_div_gate.hw,
- [CLKID_CTS_ENCT_SEL] = &meson8b_cts_enct_sel.hw,
- [CLKID_CTS_ENCT] = &meson8b_cts_enct.hw,
- [CLKID_CTS_ENCP_SEL] = &meson8b_cts_encp_sel.hw,
- [CLKID_CTS_ENCP] = &meson8b_cts_encp.hw,
- [CLKID_CTS_ENCI_SEL] = &meson8b_cts_enci_sel.hw,
- [CLKID_CTS_ENCI] = &meson8b_cts_enci.hw,
- [CLKID_HDMI_TX_PIXEL_SEL] = &meson8b_hdmi_tx_pixel_sel.hw,
- [CLKID_HDMI_TX_PIXEL] = &meson8b_hdmi_tx_pixel.hw,
- [CLKID_CTS_ENCL_SEL] = &meson8b_cts_encl_sel.hw,
- [CLKID_CTS_ENCL] = &meson8b_cts_encl.hw,
- [CLKID_CTS_VDAC0_SEL] = &meson8b_cts_vdac0_sel.hw,
- [CLKID_CTS_VDAC0] = &meson8b_cts_vdac0.hw,
- [CLKID_HDMI_SYS_SEL] = &meson8b_hdmi_sys_sel.hw,
- [CLKID_HDMI_SYS_DIV] = &meson8b_hdmi_sys_div.hw,
- [CLKID_HDMI_SYS] = &meson8b_hdmi_sys.hw,
- [CLKID_MALI_0_SEL] = &meson8b_mali_0_sel.hw,
- [CLKID_MALI_0_DIV] = &meson8b_mali_0_div.hw,
- [CLKID_MALI_0] = &meson8b_mali_0.hw,
- [CLKID_MALI_1_SEL] = &meson8b_mali_1_sel.hw,
- [CLKID_MALI_1_DIV] = &meson8b_mali_1_div.hw,
- [CLKID_MALI_1] = &meson8b_mali_1.hw,
- [CLKID_MALI] = &meson8b_mali.hw,
- [CLKID_GP_PLL_DCO] = &meson8m2_gp_pll_dco.hw,
- [CLKID_GP_PLL] = &meson8m2_gp_pll.hw,
- [CLKID_VPU_0_SEL] = &meson8m2_vpu_0_sel.hw,
- [CLKID_VPU_0_DIV] = &meson8b_vpu_0_div.hw,
- [CLKID_VPU_0] = &meson8b_vpu_0.hw,
- [CLKID_VPU_1_SEL] = &meson8m2_vpu_1_sel.hw,
- [CLKID_VPU_1_DIV] = &meson8b_vpu_1_div.hw,
- [CLKID_VPU_1] = &meson8b_vpu_1.hw,
- [CLKID_VPU] = &meson8b_vpu.hw,
- [CLKID_VDEC_1_SEL] = &meson8b_vdec_1_sel.hw,
- [CLKID_VDEC_1_1_DIV] = &meson8b_vdec_1_1_div.hw,
- [CLKID_VDEC_1_1] = &meson8b_vdec_1_1.hw,
- [CLKID_VDEC_1_2_DIV] = &meson8b_vdec_1_2_div.hw,
- [CLKID_VDEC_1_2] = &meson8b_vdec_1_2.hw,
- [CLKID_VDEC_1] = &meson8b_vdec_1.hw,
- [CLKID_VDEC_HCODEC_SEL] = &meson8b_vdec_hcodec_sel.hw,
- [CLKID_VDEC_HCODEC_DIV] = &meson8b_vdec_hcodec_div.hw,
- [CLKID_VDEC_HCODEC] = &meson8b_vdec_hcodec.hw,
- [CLKID_VDEC_2_SEL] = &meson8b_vdec_2_sel.hw,
- [CLKID_VDEC_2_DIV] = &meson8b_vdec_2_div.hw,
- [CLKID_VDEC_2] = &meson8b_vdec_2.hw,
- [CLKID_VDEC_HEVC_SEL] = &meson8b_vdec_hevc_sel.hw,
- [CLKID_VDEC_HEVC_DIV] = &meson8b_vdec_hevc_div.hw,
- [CLKID_VDEC_HEVC_EN] = &meson8b_vdec_hevc_en.hw,
- [CLKID_VDEC_HEVC] = &meson8b_vdec_hevc.hw,
- [CLKID_CTS_AMCLK_SEL] = &meson8b_cts_amclk_sel.hw,
- [CLKID_CTS_AMCLK_DIV] = &meson8b_cts_amclk_div.hw,
- [CLKID_CTS_AMCLK] = &meson8b_cts_amclk.hw,
- [CLKID_CTS_MCLK_I958_SEL] = &meson8b_cts_mclk_i958_sel.hw,
- [CLKID_CTS_MCLK_I958_DIV] = &meson8b_cts_mclk_i958_div.hw,
- [CLKID_CTS_MCLK_I958] = &meson8b_cts_mclk_i958.hw,
- [CLKID_CTS_I958] = &meson8b_cts_i958.hw,
- [CLKID_VID_PLL_LVDS_EN] = &meson8b_vid_pll_lvds_en.hw,
- [CLKID_HDMI_PLL_DCO_IN] = &hdmi_pll_dco_in.hw,
- [CLK_NR_CLKS] = NULL,
- },
- .num = CLK_NR_CLKS,
- };
- static struct clk_regmap *const meson8b_clk_regmaps[] = {
- &meson8b_clk81,
- &meson8b_ddr,
- &meson8b_dos,
- &meson8b_isa,
- &meson8b_pl301,
- &meson8b_periphs,
- &meson8b_spicc,
- &meson8b_i2c,
- &meson8b_sar_adc,
- &meson8b_smart_card,
- &meson8b_rng0,
- &meson8b_uart0,
- &meson8b_sdhc,
- &meson8b_stream,
- &meson8b_async_fifo,
- &meson8b_sdio,
- &meson8b_abuf,
- &meson8b_hiu_iface,
- &meson8b_assist_misc,
- &meson8b_spi,
- &meson8b_i2s_spdif,
- &meson8b_eth,
- &meson8b_demux,
- &meson8b_aiu_glue,
- &meson8b_iec958,
- &meson8b_i2s_out,
- &meson8b_amclk,
- &meson8b_aififo2,
- &meson8b_mixer,
- &meson8b_mixer_iface,
- &meson8b_adc,
- &meson8b_blkmv,
- &meson8b_aiu,
- &meson8b_uart1,
- &meson8b_g2d,
- &meson8b_usb0,
- &meson8b_usb1,
- &meson8b_reset,
- &meson8b_nand,
- &meson8b_dos_parser,
- &meson8b_usb,
- &meson8b_vdin1,
- &meson8b_ahb_arb0,
- &meson8b_efuse,
- &meson8b_boot_rom,
- &meson8b_ahb_data_bus,
- &meson8b_ahb_ctrl_bus,
- &meson8b_hdmi_intr_sync,
- &meson8b_hdmi_pclk,
- &meson8b_usb1_ddr_bridge,
- &meson8b_usb0_ddr_bridge,
- &meson8b_mmc_pclk,
- &meson8b_dvin,
- &meson8b_uart2,
- &meson8b_sana,
- &meson8b_vpu_intr,
- &meson8b_sec_ahb_ahb3_bridge,
- &meson8b_clk81_a9,
- &meson8b_vclk2_venci0,
- &meson8b_vclk2_venci1,
- &meson8b_vclk2_vencp0,
- &meson8b_vclk2_vencp1,
- &meson8b_gclk_venci_int,
- &meson8b_gclk_vencp_int,
- &meson8b_dac_clk,
- &meson8b_aoclk_gate,
- &meson8b_iec958_gate,
- &meson8b_enc480p,
- &meson8b_rng1,
- &meson8b_gclk_vencl_int,
- &meson8b_vclk2_venclmcc,
- &meson8b_vclk2_vencl,
- &meson8b_vclk2_other,
- &meson8b_edp,
- &meson8b_ao_media_cpu,
- &meson8b_ao_ahb_sram,
- &meson8b_ao_ahb_bus,
- &meson8b_ao_iface,
- &meson8b_mpeg_clk_div,
- &meson8b_mpeg_clk_sel,
- &meson8b_mpll0,
- &meson8b_mpll1,
- &meson8b_mpll2,
- &meson8b_mpll0_div,
- &meson8b_mpll1_div,
- &meson8b_mpll2_div,
- &meson8b_fixed_pll,
- &meson8b_sys_pll,
- &meson8b_cpu_in_sel,
- &meson8b_cpu_scale_div,
- &meson8b_cpu_scale_out_sel,
- &meson8b_cpu_clk,
- &meson8b_mpll_prediv,
- &meson8b_fclk_div2,
- &meson8b_fclk_div3,
- &meson8b_fclk_div4,
- &meson8b_fclk_div5,
- &meson8b_fclk_div7,
- &meson8b_nand_clk_sel,
- &meson8b_nand_clk_div,
- &meson8b_nand_clk_gate,
- &meson8b_fixed_pll_dco,
- &meson8b_hdmi_pll_dco,
- &meson8b_sys_pll_dco,
- &meson8b_apb_clk_sel,
- &meson8b_apb_clk_gate,
- &meson8b_periph_clk_sel,
- &meson8b_periph_clk_gate,
- &meson8b_axi_clk_sel,
- &meson8b_axi_clk_gate,
- &meson8b_l2_dram_clk_sel,
- &meson8b_l2_dram_clk_gate,
- &meson8b_hdmi_pll_lvds_out,
- &meson8b_hdmi_pll_hdmi_out,
- &meson8b_vid_pll_in_sel,
- &meson8b_vid_pll_in_en,
- &meson8b_vid_pll_pre_div,
- &meson8b_vid_pll_post_div,
- &meson8b_vid_pll,
- &meson8b_vid_pll_final_div,
- &meson8b_vclk_in_sel,
- &meson8b_vclk_in_en,
- &meson8b_vclk_en,
- &meson8b_vclk_div1_gate,
- &meson8b_vclk_div2_div_gate,
- &meson8b_vclk_div4_div_gate,
- &meson8b_vclk_div6_div_gate,
- &meson8b_vclk_div12_div_gate,
- &meson8b_vclk2_in_sel,
- &meson8b_vclk2_clk_in_en,
- &meson8b_vclk2_clk_en,
- &meson8b_vclk2_div1_gate,
- &meson8b_vclk2_div2_div_gate,
- &meson8b_vclk2_div4_div_gate,
- &meson8b_vclk2_div6_div_gate,
- &meson8b_vclk2_div12_div_gate,
- &meson8b_cts_enct_sel,
- &meson8b_cts_enct,
- &meson8b_cts_encp_sel,
- &meson8b_cts_encp,
- &meson8b_cts_enci_sel,
- &meson8b_cts_enci,
- &meson8b_hdmi_tx_pixel_sel,
- &meson8b_hdmi_tx_pixel,
- &meson8b_cts_encl_sel,
- &meson8b_cts_encl,
- &meson8b_cts_vdac0_sel,
- &meson8b_cts_vdac0,
- &meson8b_hdmi_sys_sel,
- &meson8b_hdmi_sys_div,
- &meson8b_hdmi_sys,
- &meson8b_mali_0_sel,
- &meson8b_mali_0_div,
- &meson8b_mali_0,
- &meson8b_mali_1_sel,
- &meson8b_mali_1_div,
- &meson8b_mali_1,
- &meson8b_mali,
- &meson8m2_gp_pll_dco,
- &meson8m2_gp_pll,
- &meson8b_vpu_0_sel,
- &meson8m2_vpu_0_sel,
- &meson8b_vpu_0_div,
- &meson8b_vpu_0,
- &meson8b_vpu_1_sel,
- &meson8m2_vpu_1_sel,
- &meson8b_vpu_1_div,
- &meson8b_vpu_1,
- &meson8b_vpu,
- &meson8b_vdec_1_sel,
- &meson8b_vdec_1_1_div,
- &meson8b_vdec_1_1,
- &meson8b_vdec_1_2_div,
- &meson8b_vdec_1_2,
- &meson8b_vdec_1,
- &meson8b_vdec_hcodec_sel,
- &meson8b_vdec_hcodec_div,
- &meson8b_vdec_hcodec,
- &meson8b_vdec_2_sel,
- &meson8b_vdec_2_div,
- &meson8b_vdec_2,
- &meson8b_vdec_hevc_sel,
- &meson8b_vdec_hevc_div,
- &meson8b_vdec_hevc_en,
- &meson8b_vdec_hevc,
- &meson8b_cts_amclk,
- &meson8b_cts_amclk_sel,
- &meson8b_cts_amclk_div,
- &meson8b_cts_mclk_i958_sel,
- &meson8b_cts_mclk_i958_div,
- &meson8b_cts_mclk_i958,
- &meson8b_cts_i958,
- &meson8b_vid_pll_lvds_en,
- };
- static const struct meson8b_clk_reset_line {
- u32 reg;
- u8 bit_idx;
- bool active_low;
- } meson8b_clk_reset_bits[] = {
- [CLKC_RESET_L2_CACHE_SOFT_RESET] = {
- .reg = HHI_SYS_CPU_CLK_CNTL0,
- .bit_idx = 30,
- .active_low = false,
- },
- [CLKC_RESET_AXI_64_TO_128_BRIDGE_A5_SOFT_RESET] = {
- .reg = HHI_SYS_CPU_CLK_CNTL0,
- .bit_idx = 29,
- .active_low = false,
- },
- [CLKC_RESET_SCU_SOFT_RESET] = {
- .reg = HHI_SYS_CPU_CLK_CNTL0,
- .bit_idx = 28,
- .active_low = false,
- },
- [CLKC_RESET_CPU3_SOFT_RESET] = {
- .reg = HHI_SYS_CPU_CLK_CNTL0,
- .bit_idx = 27,
- .active_low = false,
- },
- [CLKC_RESET_CPU2_SOFT_RESET] = {
- .reg = HHI_SYS_CPU_CLK_CNTL0,
- .bit_idx = 26,
- .active_low = false,
- },
- [CLKC_RESET_CPU1_SOFT_RESET] = {
- .reg = HHI_SYS_CPU_CLK_CNTL0,
- .bit_idx = 25,
- .active_low = false,
- },
- [CLKC_RESET_CPU0_SOFT_RESET] = {
- .reg = HHI_SYS_CPU_CLK_CNTL0,
- .bit_idx = 24,
- .active_low = false,
- },
- [CLKC_RESET_A5_GLOBAL_RESET] = {
- .reg = HHI_SYS_CPU_CLK_CNTL0,
- .bit_idx = 18,
- .active_low = false,
- },
- [CLKC_RESET_A5_AXI_SOFT_RESET] = {
- .reg = HHI_SYS_CPU_CLK_CNTL0,
- .bit_idx = 17,
- .active_low = false,
- },
- [CLKC_RESET_A5_ABP_SOFT_RESET] = {
- .reg = HHI_SYS_CPU_CLK_CNTL0,
- .bit_idx = 16,
- .active_low = false,
- },
- [CLKC_RESET_AXI_64_TO_128_BRIDGE_MMC_SOFT_RESET] = {
- .reg = HHI_SYS_CPU_CLK_CNTL1,
- .bit_idx = 30,
- .active_low = false,
- },
- [CLKC_RESET_VID_CLK_CNTL_SOFT_RESET] = {
- .reg = HHI_VID_CLK_CNTL,
- .bit_idx = 15,
- .active_low = false,
- },
- [CLKC_RESET_VID_DIVIDER_CNTL_SOFT_RESET_POST] = {
- .reg = HHI_VID_DIVIDER_CNTL,
- .bit_idx = 7,
- .active_low = false,
- },
- [CLKC_RESET_VID_DIVIDER_CNTL_SOFT_RESET_PRE] = {
- .reg = HHI_VID_DIVIDER_CNTL,
- .bit_idx = 3,
- .active_low = false,
- },
- [CLKC_RESET_VID_DIVIDER_CNTL_RESET_N_POST] = {
- .reg = HHI_VID_DIVIDER_CNTL,
- .bit_idx = 1,
- .active_low = true,
- },
- [CLKC_RESET_VID_DIVIDER_CNTL_RESET_N_PRE] = {
- .reg = HHI_VID_DIVIDER_CNTL,
- .bit_idx = 0,
- .active_low = true,
- },
- };
- static int meson8b_clk_reset_update(struct reset_controller_dev *rcdev,
- unsigned long id, bool assert)
- {
- struct meson8b_clk_reset *meson8b_clk_reset =
- container_of(rcdev, struct meson8b_clk_reset, reset);
- const struct meson8b_clk_reset_line *reset;
- unsigned int value = 0;
- unsigned long flags;
- if (id >= ARRAY_SIZE(meson8b_clk_reset_bits))
- return -EINVAL;
- reset = &meson8b_clk_reset_bits[id];
- if (assert != reset->active_low)
- value = BIT(reset->bit_idx);
- spin_lock_irqsave(&meson_clk_lock, flags);
- regmap_update_bits(meson8b_clk_reset->regmap, reset->reg,
- BIT(reset->bit_idx), value);
- spin_unlock_irqrestore(&meson_clk_lock, flags);
- return 0;
- }
- static int meson8b_clk_reset_assert(struct reset_controller_dev *rcdev,
- unsigned long id)
- {
- return meson8b_clk_reset_update(rcdev, id, true);
- }
- static int meson8b_clk_reset_deassert(struct reset_controller_dev *rcdev,
- unsigned long id)
- {
- return meson8b_clk_reset_update(rcdev, id, false);
- }
- static const struct reset_control_ops meson8b_clk_reset_ops = {
- .assert = meson8b_clk_reset_assert,
- .deassert = meson8b_clk_reset_deassert,
- };
- struct meson8b_nb_data {
- struct notifier_block nb;
- struct clk_hw *cpu_clk;
- };
- static int meson8b_cpu_clk_notifier_cb(struct notifier_block *nb,
- unsigned long event, void *data)
- {
- struct meson8b_nb_data *nb_data =
- container_of(nb, struct meson8b_nb_data, nb);
- struct clk_hw *parent_clk;
- int ret;
- switch (event) {
- case PRE_RATE_CHANGE:
- /* xtal */
- parent_clk = clk_hw_get_parent_by_index(nb_data->cpu_clk, 0);
- break;
- case POST_RATE_CHANGE:
- /* cpu_scale_out_sel */
- parent_clk = clk_hw_get_parent_by_index(nb_data->cpu_clk, 1);
- break;
- default:
- return NOTIFY_DONE;
- }
- ret = clk_hw_set_parent(nb_data->cpu_clk, parent_clk);
- if (ret)
- return notifier_from_errno(ret);
- udelay(100);
- return NOTIFY_OK;
- }
- static struct meson8b_nb_data meson8b_cpu_nb_data = {
- .nb.notifier_call = meson8b_cpu_clk_notifier_cb,
- };
- static void __init meson8b_clkc_init_common(struct device_node *np,
- struct clk_hw_onecell_data *clk_hw_onecell_data)
- {
- struct meson8b_clk_reset *rstc;
- struct device_node *parent_np;
- const char *notifier_clk_name;
- struct clk *notifier_clk;
- struct regmap *map;
- int i, ret;
- parent_np = of_get_parent(np);
- map = syscon_node_to_regmap(parent_np);
- of_node_put(parent_np);
- if (IS_ERR(map)) {
- pr_err("failed to get HHI regmap - Trying obsolete regs\n");
- return;
- }
- rstc = kzalloc(sizeof(*rstc), GFP_KERNEL);
- if (!rstc)
- return;
- /* Reset Controller */
- rstc->regmap = map;
- rstc->reset.ops = &meson8b_clk_reset_ops;
- rstc->reset.nr_resets = ARRAY_SIZE(meson8b_clk_reset_bits);
- rstc->reset.of_node = np;
- ret = reset_controller_register(&rstc->reset);
- if (ret) {
- pr_err("%s: Failed to register clkc reset controller: %d\n",
- __func__, ret);
- return;
- }
- /* Populate regmap for the regmap backed clocks */
- for (i = 0; i < ARRAY_SIZE(meson8b_clk_regmaps); i++)
- meson8b_clk_regmaps[i]->map = map;
- /*
- * register all clks and start with the first used ID (which is
- * CLKID_PLL_FIXED)
- */
- for (i = CLKID_PLL_FIXED; i < CLK_NR_CLKS; i++) {
- /* array might be sparse */
- if (!clk_hw_onecell_data->hws[i])
- continue;
- ret = of_clk_hw_register(np, clk_hw_onecell_data->hws[i]);
- if (ret)
- return;
- }
- meson8b_cpu_nb_data.cpu_clk = clk_hw_onecell_data->hws[CLKID_CPUCLK];
- /*
- * FIXME we shouldn't program the muxes in notifier handlers. The
- * tricky programming sequence will be handled by the forthcoming
- * coordinated clock rates mechanism once that feature is released.
- */
- notifier_clk_name = clk_hw_get_name(&meson8b_cpu_scale_out_sel.hw);
- notifier_clk = __clk_lookup(notifier_clk_name);
- ret = clk_notifier_register(notifier_clk, &meson8b_cpu_nb_data.nb);
- if (ret) {
- pr_err("%s: failed to register the CPU clock notifier\n",
- __func__);
- return;
- }
- ret = of_clk_add_hw_provider(np, of_clk_hw_onecell_get,
- clk_hw_onecell_data);
- if (ret)
- pr_err("%s: failed to register clock provider\n", __func__);
- }
- static void __init meson8_clkc_init(struct device_node *np)
- {
- return meson8b_clkc_init_common(np, &meson8_hw_onecell_data);
- }
- static void __init meson8b_clkc_init(struct device_node *np)
- {
- return meson8b_clkc_init_common(np, &meson8b_hw_onecell_data);
- }
- static void __init meson8m2_clkc_init(struct device_node *np)
- {
- return meson8b_clkc_init_common(np, &meson8m2_hw_onecell_data);
- }
- CLK_OF_DECLARE_DRIVER(meson8_clkc, "amlogic,meson8-clkc",
- meson8_clkc_init);
- CLK_OF_DECLARE_DRIVER(meson8b_clkc, "amlogic,meson8b-clkc",
- meson8b_clkc_init);
- CLK_OF_DECLARE_DRIVER(meson8m2_clkc, "amlogic,meson8m2-clkc",
- meson8m2_clkc_init);
|