| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817 |
- // SPDX-License-Identifier: (GPL-2.0-only OR MIT)
- /*
- * Amlogic S4 Peripherals Clock Controller Driver
- *
- * Copyright (c) 2022-2023 Amlogic, inc. All rights reserved
- * Author: Yu Tu <yu.tu@amlogic.com>
- */
- #include <linux/clk-provider.h>
- #include <linux/of_device.h>
- #include <linux/platform_device.h>
- #include "clk-regmap.h"
- #include "vid-pll-div.h"
- #include "clk-dualdiv.h"
- #include "s4-peripherals.h"
- #include "meson-clkc-utils.h"
- #include <dt-bindings/clock/amlogic,s4-peripherals-clkc.h>
- static struct clk_regmap s4_rtc_32k_by_oscin_clkin = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_RTC_BY_OSCIN_CTRL0,
- .bit_idx = 31,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "rtc_32k_by_oscin_clkin",
- .ops = &clk_regmap_gate_ops,
- .parent_data = (const struct clk_parent_data []) {
- { .fw_name = "xtal", }
- },
- .num_parents = 1,
- },
- };
- static const struct meson_clk_dualdiv_param s4_32k_div_table[] = {
- {
- .dual = 1,
- .n1 = 733,
- .m1 = 8,
- .n2 = 732,
- .m2 = 11,
- },
- {}
- };
- static struct clk_regmap s4_rtc_32k_by_oscin_div = {
- .data = &(struct meson_clk_dualdiv_data){
- .n1 = {
- .reg_off = CLKCTRL_RTC_BY_OSCIN_CTRL0,
- .shift = 0,
- .width = 12,
- },
- .n2 = {
- .reg_off = CLKCTRL_RTC_BY_OSCIN_CTRL0,
- .shift = 12,
- .width = 12,
- },
- .m1 = {
- .reg_off = CLKCTRL_RTC_BY_OSCIN_CTRL1,
- .shift = 0,
- .width = 12,
- },
- .m2 = {
- .reg_off = CLKCTRL_RTC_BY_OSCIN_CTRL1,
- .shift = 12,
- .width = 12,
- },
- .dual = {
- .reg_off = CLKCTRL_RTC_BY_OSCIN_CTRL0,
- .shift = 28,
- .width = 1,
- },
- .table = s4_32k_div_table,
- },
- .hw.init = &(struct clk_init_data){
- .name = "rtc_32k_by_oscin_div",
- .ops = &meson_clk_dualdiv_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_rtc_32k_by_oscin_clkin.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap s4_rtc_32k_by_oscin_sel = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_RTC_BY_OSCIN_CTRL1,
- .mask = 0x1,
- .shift = 24,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "rtc_32k_by_oscin_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_rtc_32k_by_oscin_div.hw,
- &s4_rtc_32k_by_oscin_clkin.hw,
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_rtc_32k_by_oscin = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_RTC_BY_OSCIN_CTRL0,
- .bit_idx = 30,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "rtc_32k_by_oscin",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_rtc_32k_by_oscin_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_rtc_clk = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_RTC_CTRL,
- .mask = 0x3,
- .shift = 0,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "rtc_clk_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_rtc_32k_by_oscin.hw,
- &s4_rtc_32k_by_oscin_div.hw,
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* The index 5 is AXI_CLK, which is dedicated to AXI. So skip it. */
- static u32 mux_table_sys_ab_clk_sel[] = { 0, 1, 2, 3, 4, 6, 7 };
- static const struct clk_parent_data sys_ab_clk_parent_data[] = {
- { .fw_name = "xtal" },
- { .fw_name = "fclk_div2" },
- { .fw_name = "fclk_div3" },
- { .fw_name = "fclk_div4" },
- { .fw_name = "fclk_div5" },
- { .fw_name = "fclk_div7" },
- { .hw = &s4_rtc_clk.hw }
- };
- /*
- * This clock is initialized by ROMcode.
- * The chip was changed SYS CLK for security reasons. SYS CLK registers are not writable
- * in the kernel phase. Write of SYS related register will cause the system to crash.
- * Meanwhile, these clock won't ever change at runtime.
- * For the above reasons, we can only use ro_ops for SYS related clocks.
- */
- static struct clk_regmap s4_sysclk_b_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_SYS_CLK_CTRL0,
- .mask = 0x7,
- .shift = 26,
- .table = mux_table_sys_ab_clk_sel,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sysclk_b_sel",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_data = sys_ab_clk_parent_data,
- .num_parents = ARRAY_SIZE(sys_ab_clk_parent_data),
- },
- };
- static struct clk_regmap s4_sysclk_b_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_SYS_CLK_CTRL0,
- .shift = 16,
- .width = 10,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sysclk_b_div",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_sysclk_b_sel.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap s4_sysclk_b = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_SYS_CLK_CTRL0,
- .bit_idx = 29,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sysclk_b",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_sysclk_b_div.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap s4_sysclk_a_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_SYS_CLK_CTRL0,
- .mask = 0x7,
- .shift = 10,
- .table = mux_table_sys_ab_clk_sel,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sysclk_a_sel",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_data = sys_ab_clk_parent_data,
- .num_parents = ARRAY_SIZE(sys_ab_clk_parent_data),
- },
- };
- static struct clk_regmap s4_sysclk_a_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_SYS_CLK_CTRL0,
- .shift = 0,
- .width = 10,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sysclk_a_div",
- .ops = &clk_regmap_divider_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_sysclk_a_sel.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap s4_sysclk_a = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_SYS_CLK_CTRL0,
- .bit_idx = 13,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sysclk_a",
- .ops = &clk_regmap_gate_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_sysclk_a_div.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap s4_sys_clk = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_SYS_CLK_CTRL0,
- .mask = 0x1,
- .shift = 31,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sys_clk",
- .ops = &clk_regmap_mux_ro_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_sysclk_a.hw,
- &s4_sysclk_b.hw
- },
- .num_parents = 2,
- },
- };
- static struct clk_regmap s4_ceca_32k_clkin = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_CECA_CTRL0,
- .bit_idx = 31,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "ceca_32k_clkin",
- .ops = &clk_regmap_gate_ops,
- .parent_data = (const struct clk_parent_data []) {
- { .fw_name = "xtal", }
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap s4_ceca_32k_div = {
- .data = &(struct meson_clk_dualdiv_data){
- .n1 = {
- .reg_off = CLKCTRL_CECA_CTRL0,
- .shift = 0,
- .width = 12,
- },
- .n2 = {
- .reg_off = CLKCTRL_CECA_CTRL0,
- .shift = 12,
- .width = 12,
- },
- .m1 = {
- .reg_off = CLKCTRL_CECA_CTRL1,
- .shift = 0,
- .width = 12,
- },
- .m2 = {
- .reg_off = CLKCTRL_CECA_CTRL1,
- .shift = 12,
- .width = 12,
- },
- .dual = {
- .reg_off = CLKCTRL_CECA_CTRL0,
- .shift = 28,
- .width = 1,
- },
- .table = s4_32k_div_table,
- },
- .hw.init = &(struct clk_init_data){
- .name = "ceca_32k_div",
- .ops = &meson_clk_dualdiv_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_ceca_32k_clkin.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap s4_ceca_32k_sel_pre = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_CECA_CTRL1,
- .mask = 0x1,
- .shift = 24,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "ceca_32k_sel_pre",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_ceca_32k_div.hw,
- &s4_ceca_32k_clkin.hw
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_ceca_32k_sel = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_CECA_CTRL1,
- .mask = 0x1,
- .shift = 31,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "ceca_32k_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_ceca_32k_sel_pre.hw,
- &s4_rtc_clk.hw
- },
- .num_parents = 2,
- },
- };
- static struct clk_regmap s4_ceca_32k_clkout = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_CECA_CTRL0,
- .bit_idx = 30,
- },
- .hw.init = &(struct clk_init_data){
- .name = "ceca_32k_clkout",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_ceca_32k_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_cecb_32k_clkin = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_CECB_CTRL0,
- .bit_idx = 31,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cecb_32k_clkin",
- .ops = &clk_regmap_gate_ops,
- .parent_data = (const struct clk_parent_data []) {
- { .fw_name = "xtal", }
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap s4_cecb_32k_div = {
- .data = &(struct meson_clk_dualdiv_data){
- .n1 = {
- .reg_off = CLKCTRL_CECB_CTRL0,
- .shift = 0,
- .width = 12,
- },
- .n2 = {
- .reg_off = CLKCTRL_CECB_CTRL0,
- .shift = 12,
- .width = 12,
- },
- .m1 = {
- .reg_off = CLKCTRL_CECB_CTRL1,
- .shift = 0,
- .width = 12,
- },
- .m2 = {
- .reg_off = CLKCTRL_CECB_CTRL1,
- .shift = 12,
- .width = 12,
- },
- .dual = {
- .reg_off = CLKCTRL_CECB_CTRL0,
- .shift = 28,
- .width = 1,
- },
- .table = s4_32k_div_table,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cecb_32k_div",
- .ops = &meson_clk_dualdiv_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_cecb_32k_clkin.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap s4_cecb_32k_sel_pre = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_CECB_CTRL1,
- .mask = 0x1,
- .shift = 24,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cecb_32k_sel_pre",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_cecb_32k_div.hw,
- &s4_cecb_32k_clkin.hw
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_cecb_32k_sel = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_CECB_CTRL1,
- .mask = 0x1,
- .shift = 31,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cecb_32k_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_cecb_32k_sel_pre.hw,
- &s4_rtc_clk.hw
- },
- .num_parents = 2,
- },
- };
- static struct clk_regmap s4_cecb_32k_clkout = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_CECB_CTRL0,
- .bit_idx = 30,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cecb_32k_clkout",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_cecb_32k_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_parent_data s4_sc_parent_data[] = {
- { .fw_name = "fclk_div4" },
- { .fw_name = "fclk_div3" },
- { .fw_name = "fclk_div5" },
- { .fw_name = "xtal", }
- };
- static struct clk_regmap s4_sc_clk_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_SC_CLK_CTRL,
- .mask = 0x3,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sc_clk_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_sc_parent_data,
- .num_parents = ARRAY_SIZE(s4_sc_parent_data),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_sc_clk_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_SC_CLK_CTRL,
- .shift = 0,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sc_clk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_sc_clk_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_sc_clk_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_SC_CLK_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sc_clk_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_sc_clk_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_12_24M_clk_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_CLK12_24_CTRL,
- .bit_idx = 11,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "12_24m_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_data = (const struct clk_parent_data []) {
- { .fw_name = "xtal", }
- },
- .num_parents = 1,
- },
- };
- static struct clk_fixed_factor s4_12M_clk_div = {
- .mult = 1,
- .div = 2,
- .hw.init = &(struct clk_init_data){
- .name = "12M",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_12_24M_clk_gate.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_12_24M_clk = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_CLK12_24_CTRL,
- .mask = 0x1,
- .shift = 10,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "12_24m",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_12_24M_clk_gate.hw,
- &s4_12M_clk_div.hw,
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* Video Clocks */
- static struct clk_regmap s4_vid_pll_div = {
- .data = &(struct meson_vid_pll_div_data){
- .val = {
- .reg_off = CLKCTRL_VID_PLL_CLK_DIV,
- .shift = 0,
- .width = 15,
- },
- .sel = {
- .reg_off = CLKCTRL_VID_PLL_CLK_DIV,
- .shift = 16,
- .width = 2,
- },
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vid_pll_div",
- /*
- * TODO meson_vid_pll_div_ro_ops to meson_vid_pll_div_ops
- */
- .ops = &meson_vid_pll_div_ro_ops,
- .parent_data = (const struct clk_parent_data []) {
- { .fw_name = "hdmi_pll", }
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vid_pll_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VID_PLL_CLK_DIV,
- .mask = 0x1,
- .shift = 18,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vid_pll_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = (const struct clk_parent_data []) {
- { .hw = &s4_vid_pll_div.hw },
- { .fw_name = "hdmi_pll", }
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vid_pll = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VID_PLL_CLK_DIV,
- .bit_idx = 19,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vid_pll",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vid_pll_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_parent_data s4_vclk_parent_data[] = {
- { .hw = &s4_vid_pll.hw },
- { .fw_name = "gp0_pll", },
- { .fw_name = "hifi_pll", },
- { .fw_name = "mpll1", },
- { .fw_name = "fclk_div3", },
- { .fw_name = "fclk_div4", },
- { .fw_name = "fclk_div5", },
- { .fw_name = "fclk_div7", },
- };
- static struct clk_regmap s4_vclk_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VID_CLK_CTRL,
- .mask = 0x7,
- .shift = 16,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_vclk_parent_data,
- .num_parents = ARRAY_SIZE(s4_vclk_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_vclk2_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VIID_CLK_CTRL,
- .mask = 0x7,
- .shift = 16,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_vclk_parent_data,
- .num_parents = ARRAY_SIZE(s4_vclk_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_vclk_input = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VID_CLK_DIV,
- .bit_idx = 16,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk_input",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vclk_sel.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vclk2_input = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VIID_CLK_DIV,
- .bit_idx = 16,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk2_input",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vclk2_sel.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vclk_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_VID_CLK_DIV,
- .shift = 0,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vclk_input.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vclk2_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_VIID_CLK_DIV,
- .shift = 0,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vclk2_input.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vclk = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VID_CLK_CTRL,
- .bit_idx = 19,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vclk_div.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vclk2 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VIID_CLK_CTRL,
- .bit_idx = 19,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk2",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vclk2_div.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vclk_div1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VID_CLK_CTRL,
- .bit_idx = 0,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk_div1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vclk.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vclk_div2_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VID_CLK_CTRL,
- .bit_idx = 1,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk_div2_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vclk.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vclk_div4_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VID_CLK_CTRL,
- .bit_idx = 2,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk_div4_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vclk.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vclk_div6_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VID_CLK_CTRL,
- .bit_idx = 3,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk_div6_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vclk.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vclk_div12_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VID_CLK_CTRL,
- .bit_idx = 4,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk_div12_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vclk.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vclk2_div1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VIID_CLK_CTRL,
- .bit_idx = 0,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk2_div1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vclk2.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vclk2_div2_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VIID_CLK_CTRL,
- .bit_idx = 1,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk2_div2_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vclk2.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vclk2_div4_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VIID_CLK_CTRL,
- .bit_idx = 2,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk2_div4_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vclk2.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vclk2_div6_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VIID_CLK_CTRL,
- .bit_idx = 3,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk2_div6_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vclk2.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vclk2_div12_en = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VIID_CLK_CTRL,
- .bit_idx = 4,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vclk2_div12_en",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vclk2.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor s4_vclk_div2 = {
- .mult = 1,
- .div = 2,
- .hw.init = &(struct clk_init_data){
- .name = "vclk_div2",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vclk_div2_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor s4_vclk_div4 = {
- .mult = 1,
- .div = 4,
- .hw.init = &(struct clk_init_data){
- .name = "vclk_div4",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vclk_div4_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor s4_vclk_div6 = {
- .mult = 1,
- .div = 6,
- .hw.init = &(struct clk_init_data){
- .name = "vclk_div6",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vclk_div6_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor s4_vclk_div12 = {
- .mult = 1,
- .div = 12,
- .hw.init = &(struct clk_init_data){
- .name = "vclk_div12",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vclk_div12_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor s4_vclk2_div2 = {
- .mult = 1,
- .div = 2,
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div2",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vclk2_div2_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor s4_vclk2_div4 = {
- .mult = 1,
- .div = 4,
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div4",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vclk2_div4_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor s4_vclk2_div6 = {
- .mult = 1,
- .div = 6,
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div6",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vclk2_div6_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_fixed_factor s4_vclk2_div12 = {
- .mult = 1,
- .div = 12,
- .hw.init = &(struct clk_init_data){
- .name = "vclk2_div12",
- .ops = &clk_fixed_factor_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vclk2_div12_en.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* The 5,6,7 indexes corresponds to no real clock, so there are not used. */
- static u32 mux_table_cts_sel[] = { 0, 1, 2, 3, 4, 8, 9, 10, 11, 12 };
- static const struct clk_hw *s4_cts_parent_hws[] = {
- &s4_vclk_div1.hw,
- &s4_vclk_div2.hw,
- &s4_vclk_div4.hw,
- &s4_vclk_div6.hw,
- &s4_vclk_div12.hw,
- &s4_vclk2_div1.hw,
- &s4_vclk2_div2.hw,
- &s4_vclk2_div4.hw,
- &s4_vclk2_div6.hw,
- &s4_vclk2_div12.hw
- };
- static struct clk_regmap s4_cts_enci_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VID_CLK_DIV,
- .mask = 0xf,
- .shift = 28,
- .table = mux_table_cts_sel,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_enci_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = s4_cts_parent_hws,
- .num_parents = ARRAY_SIZE(s4_cts_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_cts_encp_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VID_CLK_DIV,
- .mask = 0xf,
- .shift = 20,
- .table = mux_table_cts_sel,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_encp_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = s4_cts_parent_hws,
- .num_parents = ARRAY_SIZE(s4_cts_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_cts_vdac_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VIID_CLK_DIV,
- .mask = 0xf,
- .shift = 28,
- .table = mux_table_cts_sel,
- },
- .hw.init = &(struct clk_init_data){
- .name = "cts_vdac_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = s4_cts_parent_hws,
- .num_parents = ARRAY_SIZE(s4_cts_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* The 5,6,7 indexes corresponds to no real clock, so there are not used. */
- static u32 mux_table_hdmi_tx_sel[] = { 0, 1, 2, 3, 4, 8, 9, 10, 11, 12 };
- static const struct clk_hw *s4_cts_hdmi_tx_parent_hws[] = {
- &s4_vclk_div1.hw,
- &s4_vclk_div2.hw,
- &s4_vclk_div4.hw,
- &s4_vclk_div6.hw,
- &s4_vclk_div12.hw,
- &s4_vclk2_div1.hw,
- &s4_vclk2_div2.hw,
- &s4_vclk2_div4.hw,
- &s4_vclk2_div6.hw,
- &s4_vclk2_div12.hw
- };
- static struct clk_regmap s4_hdmi_tx_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_HDMI_CLK_CTRL,
- .mask = 0xf,
- .shift = 16,
- .table = mux_table_hdmi_tx_sel,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_tx_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = s4_cts_hdmi_tx_parent_hws,
- .num_parents = ARRAY_SIZE(s4_cts_hdmi_tx_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_cts_enci = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VID_CLK_CTRL2,
- .bit_idx = 0,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cts_enci",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_cts_enci_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_cts_encp = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VID_CLK_CTRL2,
- .bit_idx = 2,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cts_encp",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_cts_encp_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_cts_vdac = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VID_CLK_CTRL2,
- .bit_idx = 4,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "cts_vdac",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_cts_vdac_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_hdmi_tx = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VID_CLK_CTRL2,
- .bit_idx = 5,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "hdmi_tx",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_hdmi_tx_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* HDMI Clocks */
- static const struct clk_parent_data s4_hdmi_parent_data[] = {
- { .fw_name = "xtal", },
- { .fw_name = "fclk_div4", },
- { .fw_name = "fclk_div3", },
- { .fw_name = "fclk_div5", }
- };
- static struct clk_regmap s4_hdmi_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_HDMI_CLK_CTRL,
- .mask = 0x3,
- .shift = 9,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_hdmi_parent_data,
- .num_parents = ARRAY_SIZE(s4_hdmi_parent_data),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_hdmi_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_HDMI_CLK_CTRL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdmi_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_hdmi_sel.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_hdmi = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_HDMI_CLK_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "hdmi",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_hdmi_div.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_ts_clk_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_TS_CLK_CTRL,
- .shift = 0,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "ts_clk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_data = &(const struct clk_parent_data) {
- .fw_name = "xtal",
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_ts_clk_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_TS_CLK_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "ts_clk",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_ts_clk_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. The CCF can manage this glitch-free
- * mux because it does top-to-bottom updates the each clock tree and
- * switches to the "inactive" one when CLK_SET_RATE_GATE is set.
- */
- static const struct clk_parent_data s4_mali_0_1_parent_data[] = {
- { .fw_name = "xtal", },
- { .fw_name = "gp0_pll", },
- { .fw_name = "hifi_pll", },
- { .fw_name = "fclk_div2p5", },
- { .fw_name = "fclk_div3", },
- { .fw_name = "fclk_div4", },
- { .fw_name = "fclk_div5", },
- { .fw_name = "fclk_div7", }
- };
- static struct clk_regmap s4_mali_0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_MALI_CLK_CTRL,
- .mask = 0x7,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mali_0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_mali_0_1_parent_data,
- .num_parents = ARRAY_SIZE(s4_mali_0_1_parent_data),
- /*
- * Don't request the parent to change the rate because
- * all GPU frequencies can be derived from the fclk_*
- * clocks and one special GP0_PLL setting. This is
- * important because we need the HIFI PLL clock for audio.
- */
- .flags = 0,
- },
- };
- static struct clk_regmap s4_mali_0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_MALI_CLK_CTRL,
- .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 *[]) {
- &s4_mali_0_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_mali_0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_MALI_CLK_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mali_0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_mali_0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_GATE | CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_mali_1_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_MALI_CLK_CTRL,
- .mask = 0x7,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mali_1_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_mali_0_1_parent_data,
- .num_parents = ARRAY_SIZE(s4_mali_0_1_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_mali_1_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_MALI_CLK_CTRL,
- .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 *[]) {
- &s4_mali_1_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_mali_1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_MALI_CLK_CTRL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mali_1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_mali_1_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_GATE | CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_hw *s4_mali_parent_hws[] = {
- &s4_mali_0.hw,
- &s4_mali_1.hw
- };
- static struct clk_regmap s4_mali_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_MALI_CLK_CTRL,
- .mask = 1,
- .shift = 31,
- },
- .hw.init = &(struct clk_init_data){
- .name = "mali",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = s4_mali_parent_hws,
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* VDEC clocks */
- static const struct clk_parent_data s4_dec_parent_data[] = {
- { .fw_name = "fclk_div2p5", },
- { .fw_name = "fclk_div3", },
- { .fw_name = "fclk_div4", },
- { .fw_name = "fclk_div5", },
- { .fw_name = "fclk_div7", },
- { .fw_name = "hifi_pll", },
- { .fw_name = "gp0_pll", },
- { .fw_name = "xtal", }
- };
- static struct clk_regmap s4_vdec_p0_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VDEC_CLK_CTRL,
- .mask = 0x7,
- .shift = 9,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vdec_p0_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_dec_parent_data,
- .num_parents = ARRAY_SIZE(s4_dec_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_vdec_p0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_VDEC_CLK_CTRL,
- .shift = 0,
- .width = 7,
- .flags = CLK_DIVIDER_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vdec_p0_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vdec_p0_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vdec_p0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VDEC_CLK_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_p0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vdec_p0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vdec_p1_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VDEC3_CLK_CTRL,
- .mask = 0x7,
- .shift = 9,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vdec_p1_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_dec_parent_data,
- .num_parents = ARRAY_SIZE(s4_dec_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_vdec_p1_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_VDEC3_CLK_CTRL,
- .shift = 0,
- .width = 7,
- .flags = CLK_DIVIDER_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vdec_p1_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vdec_p1_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vdec_p1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VDEC3_CLK_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdec_p1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vdec_p1_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_hw *s4_vdec_mux_parent_hws[] = {
- &s4_vdec_p0.hw,
- &s4_vdec_p1.hw
- };
- static struct clk_regmap s4_vdec_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VDEC3_CLK_CTRL,
- .mask = 0x1,
- .shift = 15,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vdec_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = s4_vdec_mux_parent_hws,
- .num_parents = ARRAY_SIZE(s4_vdec_mux_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_hevcf_p0_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VDEC2_CLK_CTRL,
- .mask = 0x7,
- .shift = 9,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "hevcf_p0_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_dec_parent_data,
- .num_parents = ARRAY_SIZE(s4_dec_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_hevcf_p0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_VDEC2_CLK_CTRL,
- .shift = 0,
- .width = 7,
- .flags = CLK_DIVIDER_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "hevcf_p0_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_hevcf_p0_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_hevcf_p0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VDEC2_CLK_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hevcf_p0_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_hevcf_p0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_hevcf_p1_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VDEC4_CLK_CTRL,
- .mask = 0x7,
- .shift = 9,
- .flags = CLK_MUX_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "hevcf_p1_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_dec_parent_data,
- .num_parents = ARRAY_SIZE(s4_dec_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_hevcf_p1_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_VDEC4_CLK_CTRL,
- .shift = 0,
- .width = 7,
- .flags = CLK_DIVIDER_ROUND_CLOSEST,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "hevcf_p1_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_hevcf_p1_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_hevcf_p1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VDEC4_CLK_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hevcf_p1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_hevcf_p1_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_hw *s4_hevcf_mux_parent_hws[] = {
- &s4_hevcf_p0.hw,
- &s4_hevcf_p1.hw
- };
- static struct clk_regmap s4_hevcf_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VDEC4_CLK_CTRL,
- .mask = 0x1,
- .shift = 15,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "hevcf",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = s4_hevcf_mux_parent_hws,
- .num_parents = ARRAY_SIZE(s4_hevcf_mux_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* VPU Clock */
- static const struct clk_parent_data s4_vpu_parent_data[] = {
- { .fw_name = "fclk_div3", },
- { .fw_name = "fclk_div4", },
- { .fw_name = "fclk_div5", },
- { .fw_name = "fclk_div7", },
- { .fw_name = "mpll1", },
- { .hw = &s4_vid_pll.hw },
- { .fw_name = "hifi_pll", },
- { .fw_name = "gp0_pll", },
- };
- static struct clk_regmap s4_vpu_0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VPU_CLK_CTRL,
- .mask = 0x7,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_vpu_parent_data,
- .num_parents = ARRAY_SIZE(s4_vpu_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_vpu_0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_VPU_CLK_CTRL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_0_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vpu_0_sel.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vpu_0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VPU_CLK_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vpu_0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vpu_0_div.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vpu_1_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VPU_CLK_CTRL,
- .mask = 0x7,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_1_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_vpu_parent_data,
- .num_parents = ARRAY_SIZE(s4_vpu_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_vpu_1_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_VPU_CLK_CTRL,
- .shift = 16,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_1_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vpu_1_sel.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vpu_1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VPU_CLK_CTRL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vpu_1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vpu_1_div.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vpu = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VPU_CLK_CTRL,
- .mask = 1,
- .shift = 31,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vpu_0.hw,
- &s4_vpu_1.hw,
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_parent_data vpu_clkb_tmp_parent_data[] = {
- { .hw = &s4_vpu.hw },
- { .fw_name = "fclk_div4", },
- { .fw_name = "fclk_div5", },
- { .fw_name = "fclk_div7", }
- };
- static struct clk_regmap s4_vpu_clkb_tmp_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VPU_CLKB_CTRL,
- .mask = 0x3,
- .shift = 20,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vpu_clkb_tmp_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = vpu_clkb_tmp_parent_data,
- .num_parents = ARRAY_SIZE(vpu_clkb_tmp_parent_data),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vpu_clkb_tmp_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_VPU_CLKB_CTRL,
- .shift = 16,
- .width = 4,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vpu_clkb_tmp_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vpu_clkb_tmp_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vpu_clkb_tmp = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VPU_CLKB_CTRL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_clkb_tmp",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vpu_clkb_tmp_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vpu_clkb_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_VPU_CLKB_CTRL,
- .shift = 0,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vpu_clkb_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vpu_clkb_tmp.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vpu_clkb = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VPU_CLKB_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_clkb",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vpu_clkb_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_parent_data s4_vpu_clkc_parent_data[] = {
- { .fw_name = "fclk_div4", },
- { .fw_name = "fclk_div3", },
- { .fw_name = "fclk_div5", },
- { .fw_name = "fclk_div7", },
- { .fw_name = "mpll1", },
- { .hw = &s4_vid_pll.hw },
- { .fw_name = "mpll2", },
- { .fw_name = "gp0_pll", },
- };
- static struct clk_regmap s4_vpu_clkc_p0_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VPU_CLKC_CTRL,
- .mask = 0x7,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vpu_clkc_p0_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_vpu_clkc_parent_data,
- .num_parents = ARRAY_SIZE(s4_vpu_clkc_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_vpu_clkc_p0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_VPU_CLKC_CTRL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vpu_clkc_p0_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vpu_clkc_p0_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vpu_clkc_p0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VPU_CLKC_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_clkc_p0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vpu_clkc_p0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vpu_clkc_p1_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VPU_CLKC_CTRL,
- .mask = 0x7,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vpu_clkc_p1_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_vpu_clkc_parent_data,
- .num_parents = ARRAY_SIZE(s4_vpu_clkc_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_vpu_clkc_p1_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_VPU_CLKC_CTRL,
- .shift = 16,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vpu_clkc_p1_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vpu_clkc_p1_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vpu_clkc_p1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VPU_CLKC_CTRL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vpu_clkc_p1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vpu_clkc_p1_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_hw *s4_vpu_mux_parent_hws[] = {
- &s4_vpu_clkc_p0.hw,
- &s4_vpu_clkc_p1.hw
- };
- static struct clk_regmap s4_vpu_clkc_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VPU_CLKC_CTRL,
- .mask = 0x1,
- .shift = 31,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vpu_clkc_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = s4_vpu_mux_parent_hws,
- .num_parents = ARRAY_SIZE(s4_vpu_mux_parent_hws),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* VAPB Clock */
- static const struct clk_parent_data s4_vapb_parent_data[] = {
- { .fw_name = "fclk_div4", },
- { .fw_name = "fclk_div3", },
- { .fw_name = "fclk_div5", },
- { .fw_name = "fclk_div7", },
- { .fw_name = "mpll1", },
- { .hw = &s4_vid_pll.hw },
- { .fw_name = "mpll2", },
- { .fw_name = "fclk_div2p5", },
- };
- static struct clk_regmap s4_vapb_0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VAPBCLK_CTRL,
- .mask = 0x7,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vapb_0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_vapb_parent_data,
- .num_parents = ARRAY_SIZE(s4_vapb_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_vapb_0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_VAPBCLK_CTRL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vapb_0_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vapb_0_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vapb_0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VAPBCLK_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vapb_0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vapb_0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vapb_1_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VAPBCLK_CTRL,
- .mask = 0x7,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vapb_1_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_vapb_parent_data,
- .num_parents = ARRAY_SIZE(s4_vapb_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_vapb_1_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_VAPBCLK_CTRL,
- .shift = 16,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vapb_1_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vapb_1_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vapb_1 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VAPBCLK_CTRL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vapb_1",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vapb_1_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vapb = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VAPBCLK_CTRL,
- .mask = 1,
- .shift = 31,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vapb_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vapb_0.hw,
- &s4_vapb_1.hw
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_ge2d_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VAPBCLK_CTRL,
- .bit_idx = 30,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "ge2d_clk",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) { &s4_vapb.hw },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_parent_data s4_esmclk_parent_data[] = {
- { .fw_name = "fclk_div7", },
- { .fw_name = "fclk_div4", },
- { .fw_name = "fclk_div3", },
- { .fw_name = "fclk_div5", },
- };
- static struct clk_regmap s4_hdcp22_esmclk_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_HDCP22_CTRL,
- .mask = 0x3,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "hdcp22_esmclk_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_esmclk_parent_data,
- .num_parents = ARRAY_SIZE(s4_esmclk_parent_data),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_hdcp22_esmclk_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_HDCP22_CTRL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "hdcp22_esmclk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_hdcp22_esmclk_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_hdcp22_esmclk_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_HDCP22_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdcp22_esmclk_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_hdcp22_esmclk_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_parent_data s4_skpclk_parent_data[] = {
- { .fw_name = "xtal", },
- { .fw_name = "fclk_div4", },
- { .fw_name = "fclk_div3", },
- { .fw_name = "fclk_div5", },
- };
- static struct clk_regmap s4_hdcp22_skpclk_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_HDCP22_CTRL,
- .mask = 0x3,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "hdcp22_skpclk_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_skpclk_parent_data,
- .num_parents = ARRAY_SIZE(s4_skpclk_parent_data),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_hdcp22_skpclk_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_HDCP22_CTRL,
- .shift = 16,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "hdcp22_skpclk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_hdcp22_skpclk_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_hdcp22_skpclk_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_HDCP22_CTRL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "hdcp22_skpclk_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_hdcp22_skpclk_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_parent_data s4_vdin_parent_data[] = {
- { .fw_name = "xtal", },
- { .fw_name = "fclk_div4", },
- { .fw_name = "fclk_div3", },
- { .fw_name = "fclk_div5", },
- { .hw = &s4_vid_pll.hw }
- };
- static struct clk_regmap s4_vdin_meas_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_VDIN_MEAS_CLK_CTRL,
- .mask = 0x7,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vdin_meas_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_vdin_parent_data,
- .num_parents = ARRAY_SIZE(s4_vdin_parent_data),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vdin_meas_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_VDIN_MEAS_CLK_CTRL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "vdin_meas_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vdin_meas_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_vdin_meas_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_VDIN_MEAS_CLK_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "vdin_meas_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_vdin_meas_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* EMMC/NAND clock */
- static const struct clk_parent_data s4_sd_emmc_clk0_parent_data[] = {
- { .fw_name = "xtal", },
- { .fw_name = "fclk_div2", },
- { .fw_name = "fclk_div3", },
- { .fw_name = "hifi_pll", },
- { .fw_name = "fclk_div2p5", },
- { .fw_name = "mpll2", },
- { .fw_name = "mpll3", },
- { .fw_name = "gp0_pll", },
- };
- static struct clk_regmap s4_sd_emmc_c_clk0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_NAND_CLK_CTRL,
- .mask = 0x7,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sd_emmc_c_clk0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_sd_emmc_clk0_parent_data,
- .num_parents = ARRAY_SIZE(s4_sd_emmc_clk0_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_sd_emmc_c_clk0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_NAND_CLK_CTRL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sd_emmc_c_clk0_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_sd_emmc_c_clk0_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_sd_emmc_c_clk0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_NAND_CLK_CTRL,
- .bit_idx = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sd_emmc_c_clk0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_sd_emmc_c_clk0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_sd_emmc_a_clk0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_SD_EMMC_CLK_CTRL,
- .mask = 0x7,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sd_emmc_a_clk0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_sd_emmc_clk0_parent_data,
- .num_parents = ARRAY_SIZE(s4_sd_emmc_clk0_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_sd_emmc_a_clk0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_SD_EMMC_CLK_CTRL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sd_emmc_a_clk0_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_sd_emmc_a_clk0_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_sd_emmc_a_clk0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_SD_EMMC_CLK_CTRL,
- .bit_idx = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sd_emmc_a_clk0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_sd_emmc_a_clk0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_sd_emmc_b_clk0_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_SD_EMMC_CLK_CTRL,
- .mask = 0x7,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sd_emmc_b_clk0_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_sd_emmc_clk0_parent_data,
- .num_parents = ARRAY_SIZE(s4_sd_emmc_clk0_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_sd_emmc_b_clk0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_SD_EMMC_CLK_CTRL,
- .shift = 16,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "sd_emmc_b_clk0_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_sd_emmc_b_clk0_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_sd_emmc_b_clk0 = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_SD_EMMC_CLK_CTRL,
- .bit_idx = 23,
- },
- .hw.init = &(struct clk_init_data){
- .name = "sd_emmc_b_clk0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_sd_emmc_b_clk0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* SPICC Clock */
- static const struct clk_parent_data s4_spicc_parent_data[] = {
- { .fw_name = "xtal", },
- { .hw = &s4_sys_clk.hw },
- { .fw_name = "fclk_div4", },
- { .fw_name = "fclk_div3", },
- { .fw_name = "fclk_div2", },
- { .fw_name = "fclk_div5", },
- { .fw_name = "fclk_div7", },
- };
- static struct clk_regmap s4_spicc0_mux = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_SPICC_CLK_CTRL,
- .mask = 0x7,
- .shift = 7,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "spicc0_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_spicc_parent_data,
- .num_parents = ARRAY_SIZE(s4_spicc_parent_data),
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_spicc0_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_SPICC_CLK_CTRL,
- .shift = 0,
- .width = 6,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "spicc0_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_spicc0_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_spicc0_gate = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_SPICC_CLK_CTRL,
- .bit_idx = 6,
- },
- .hw.init = &(struct clk_init_data){
- .name = "spicc0",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_spicc0_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /* PWM Clock */
- static const struct clk_parent_data s4_pwm_parent_data[] = {
- { .fw_name = "xtal", },
- { .hw = &s4_vid_pll.hw },
- { .fw_name = "fclk_div4", },
- { .fw_name = "fclk_div3", },
- };
- static struct clk_regmap s4_pwm_a_mux = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_PWM_CLK_AB_CTRL,
- .mask = 0x3,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_a_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_pwm_parent_data,
- .num_parents = ARRAY_SIZE(s4_pwm_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_pwm_a_div = {
- .data = &(struct clk_regmap_div_data) {
- .offset = CLKCTRL_PWM_CLK_AB_CTRL,
- .shift = 0,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_a_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_a_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_a_gate = {
- .data = &(struct clk_regmap_gate_data) {
- .offset = CLKCTRL_PWM_CLK_AB_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_a_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_a_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_b_mux = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_PWM_CLK_AB_CTRL,
- .mask = 0x3,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_b_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_pwm_parent_data,
- .num_parents = ARRAY_SIZE(s4_pwm_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_pwm_b_div = {
- .data = &(struct clk_regmap_div_data) {
- .offset = CLKCTRL_PWM_CLK_AB_CTRL,
- .shift = 16,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_b_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_b_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_b_gate = {
- .data = &(struct clk_regmap_gate_data) {
- .offset = CLKCTRL_PWM_CLK_AB_CTRL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_b_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_b_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_c_mux = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_PWM_CLK_CD_CTRL,
- .mask = 0x3,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_c_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_pwm_parent_data,
- .num_parents = ARRAY_SIZE(s4_pwm_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_pwm_c_div = {
- .data = &(struct clk_regmap_div_data) {
- .offset = CLKCTRL_PWM_CLK_CD_CTRL,
- .shift = 0,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_c_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_c_mux.hw
- },
- .num_parents = 1,
- },
- };
- static struct clk_regmap s4_pwm_c_gate = {
- .data = &(struct clk_regmap_gate_data) {
- .offset = CLKCTRL_PWM_CLK_CD_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_c_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_c_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_d_mux = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_PWM_CLK_CD_CTRL,
- .mask = 0x3,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_d_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_pwm_parent_data,
- .num_parents = ARRAY_SIZE(s4_pwm_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_pwm_d_div = {
- .data = &(struct clk_regmap_div_data) {
- .offset = CLKCTRL_PWM_CLK_CD_CTRL,
- .shift = 16,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_d_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_d_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_d_gate = {
- .data = &(struct clk_regmap_gate_data) {
- .offset = CLKCTRL_PWM_CLK_CD_CTRL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_d_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_d_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_e_mux = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_PWM_CLK_EF_CTRL,
- .mask = 0x3,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_e_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_pwm_parent_data,
- .num_parents = ARRAY_SIZE(s4_pwm_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_pwm_e_div = {
- .data = &(struct clk_regmap_div_data) {
- .offset = CLKCTRL_PWM_CLK_EF_CTRL,
- .shift = 0,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_e_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_e_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_e_gate = {
- .data = &(struct clk_regmap_gate_data) {
- .offset = CLKCTRL_PWM_CLK_EF_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_e_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_e_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_f_mux = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_PWM_CLK_EF_CTRL,
- .mask = 0x3,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_f_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_pwm_parent_data,
- .num_parents = ARRAY_SIZE(s4_pwm_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_pwm_f_div = {
- .data = &(struct clk_regmap_div_data) {
- .offset = CLKCTRL_PWM_CLK_EF_CTRL,
- .shift = 16,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_f_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_f_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_f_gate = {
- .data = &(struct clk_regmap_gate_data) {
- .offset = CLKCTRL_PWM_CLK_EF_CTRL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_f_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_f_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_g_mux = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_PWM_CLK_GH_CTRL,
- .mask = 0x3,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_g_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_pwm_parent_data,
- .num_parents = ARRAY_SIZE(s4_pwm_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_pwm_g_div = {
- .data = &(struct clk_regmap_div_data) {
- .offset = CLKCTRL_PWM_CLK_GH_CTRL,
- .shift = 0,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_g_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_g_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_g_gate = {
- .data = &(struct clk_regmap_gate_data) {
- .offset = CLKCTRL_PWM_CLK_GH_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_g_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_g_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_h_mux = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_PWM_CLK_GH_CTRL,
- .mask = 0x3,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_h_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_pwm_parent_data,
- .num_parents = ARRAY_SIZE(s4_pwm_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_pwm_h_div = {
- .data = &(struct clk_regmap_div_data) {
- .offset = CLKCTRL_PWM_CLK_GH_CTRL,
- .shift = 16,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_h_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_h_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_h_gate = {
- .data = &(struct clk_regmap_gate_data) {
- .offset = CLKCTRL_PWM_CLK_GH_CTRL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_h_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_h_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_i_mux = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_PWM_CLK_IJ_CTRL,
- .mask = 0x3,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_i_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_pwm_parent_data,
- .num_parents = ARRAY_SIZE(s4_pwm_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_pwm_i_div = {
- .data = &(struct clk_regmap_div_data) {
- .offset = CLKCTRL_PWM_CLK_IJ_CTRL,
- .shift = 0,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_i_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_i_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_i_gate = {
- .data = &(struct clk_regmap_gate_data) {
- .offset = CLKCTRL_PWM_CLK_IJ_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_i_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_i_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_j_mux = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_PWM_CLK_IJ_CTRL,
- .mask = 0x3,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_j_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_pwm_parent_data,
- .num_parents = ARRAY_SIZE(s4_pwm_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_pwm_j_div = {
- .data = &(struct clk_regmap_div_data) {
- .offset = CLKCTRL_PWM_CLK_IJ_CTRL,
- .shift = 16,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_j_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_j_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_pwm_j_gate = {
- .data = &(struct clk_regmap_gate_data) {
- .offset = CLKCTRL_PWM_CLK_IJ_CTRL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "pwm_j_gate",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_pwm_j_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_saradc_mux = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_SAR_CLK_CTRL,
- .mask = 0x3,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "saradc_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = (const struct clk_parent_data []) {
- { .fw_name = "xtal", },
- { .hw = &s4_sys_clk.hw },
- },
- .num_parents = 2,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_saradc_div = {
- .data = &(struct clk_regmap_div_data) {
- .offset = CLKCTRL_SAR_CLK_CTRL,
- .shift = 0,
- .width = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "saradc_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_saradc_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_saradc_gate = {
- .data = &(struct clk_regmap_gate_data) {
- .offset = CLKCTRL_SAR_CLK_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "saradc_clk",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_saradc_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- /*
- * gen clk is designed for debug/monitor some internal clock quality. Some of the
- * corresponding clock sources are not described in the clock tree and internal clock
- * for debug, so they are skipped.
- */
- static u32 s4_gen_clk_mux_table[] = { 0, 4, 5, 7, 19, 21, 22,
- 23, 24, 25, 26, 27, 28 };
- static const struct clk_parent_data s4_gen_clk_parent_data[] = {
- { .fw_name = "xtal", },
- { .hw = &s4_vid_pll.hw },
- { .fw_name = "gp0_pll", },
- { .fw_name = "hifi_pll", },
- { .fw_name = "fclk_div2", },
- { .fw_name = "fclk_div3", },
- { .fw_name = "fclk_div4", },
- { .fw_name = "fclk_div5", },
- { .fw_name = "fclk_div7", },
- { .fw_name = "mpll0", },
- { .fw_name = "mpll1", },
- { .fw_name = "mpll2", },
- { .fw_name = "mpll3", },
- };
- static struct clk_regmap s4_gen_clk_sel = {
- .data = &(struct clk_regmap_mux_data){
- .offset = CLKCTRL_GEN_CLK_CTRL,
- .mask = 0x1f,
- .shift = 12,
- .table = s4_gen_clk_mux_table,
- },
- .hw.init = &(struct clk_init_data){
- .name = "gen_clk_sel",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_gen_clk_parent_data,
- .num_parents = ARRAY_SIZE(s4_gen_clk_parent_data),
- /*
- * Because the GEN clock can be connected to an external pad
- * and may be set up directly from the device tree. Don't
- * really want to automatically reparent.
- */
- .flags = CLK_SET_RATE_NO_REPARENT,
- },
- };
- static struct clk_regmap s4_gen_clk_div = {
- .data = &(struct clk_regmap_div_data){
- .offset = CLKCTRL_GEN_CLK_CTRL,
- .shift = 0,
- .width = 11,
- },
- .hw.init = &(struct clk_init_data){
- .name = "gen_clk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_gen_clk_sel.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_gen_clk = {
- .data = &(struct clk_regmap_gate_data){
- .offset = CLKCTRL_GEN_CLK_CTRL,
- .bit_idx = 11,
- },
- .hw.init = &(struct clk_init_data) {
- .name = "gen_clk",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_gen_clk_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static const struct clk_parent_data s4_adc_extclk_in_parent_data[] = {
- { .fw_name = "xtal", },
- { .fw_name = "fclk_div4", },
- { .fw_name = "fclk_div3", },
- { .fw_name = "fclk_div5", },
- { .fw_name = "fclk_div7", },
- { .fw_name = "mpll2", },
- { .fw_name = "gp0_pll", },
- { .fw_name = "hifi_pll", },
- };
- static struct clk_regmap s4_adc_extclk_in_mux = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_DEMOD_CLK_CTRL,
- .mask = 0x7,
- .shift = 25,
- },
- .hw.init = &(struct clk_init_data){
- .name = "adc_extclk_in_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = s4_adc_extclk_in_parent_data,
- .num_parents = ARRAY_SIZE(s4_adc_extclk_in_parent_data),
- .flags = 0,
- },
- };
- static struct clk_regmap s4_adc_extclk_in_div = {
- .data = &(struct clk_regmap_div_data) {
- .offset = CLKCTRL_DEMOD_CLK_CTRL,
- .shift = 16,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "adc_extclk_in_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_adc_extclk_in_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_adc_extclk_in_gate = {
- .data = &(struct clk_regmap_gate_data) {
- .offset = CLKCTRL_DEMOD_CLK_CTRL,
- .bit_idx = 24,
- },
- .hw.init = &(struct clk_init_data){
- .name = "adc_extclk_in",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_adc_extclk_in_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_demod_core_clk_mux = {
- .data = &(struct clk_regmap_mux_data) {
- .offset = CLKCTRL_DEMOD_CLK_CTRL,
- .mask = 0x3,
- .shift = 9,
- },
- .hw.init = &(struct clk_init_data){
- .name = "demod_core_clk_mux",
- .ops = &clk_regmap_mux_ops,
- .parent_data = (const struct clk_parent_data []) {
- { .fw_name = "xtal", },
- { .fw_name = "fclk_div7", },
- { .fw_name = "fclk_div4", },
- { .hw = &s4_adc_extclk_in_gate.hw }
- },
- .num_parents = 4,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_demod_core_clk_div = {
- .data = &(struct clk_regmap_div_data) {
- .offset = CLKCTRL_DEMOD_CLK_CTRL,
- .shift = 0,
- .width = 7,
- },
- .hw.init = &(struct clk_init_data){
- .name = "demod_core_clk_div",
- .ops = &clk_regmap_divider_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_demod_core_clk_mux.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- static struct clk_regmap s4_demod_core_clk_gate = {
- .data = &(struct clk_regmap_gate_data) {
- .offset = CLKCTRL_DEMOD_CLK_CTRL,
- .bit_idx = 8,
- },
- .hw.init = &(struct clk_init_data){
- .name = "demod_core_clk",
- .ops = &clk_regmap_gate_ops,
- .parent_hws = (const struct clk_hw *[]) {
- &s4_demod_core_clk_div.hw
- },
- .num_parents = 1,
- .flags = CLK_SET_RATE_PARENT,
- },
- };
- #define MESON_GATE(_name, _reg, _bit) \
- MESON_PCLK(_name, _reg, _bit, &s4_sys_clk.hw)
- static MESON_GATE(s4_ddr, CLKCTRL_SYS_CLK_EN0_REG0, 0);
- static MESON_GATE(s4_dos, CLKCTRL_SYS_CLK_EN0_REG0, 1);
- static MESON_GATE(s4_ethphy, CLKCTRL_SYS_CLK_EN0_REG0, 4);
- static MESON_GATE(s4_mali, CLKCTRL_SYS_CLK_EN0_REG0, 6);
- static MESON_GATE(s4_aocpu, CLKCTRL_SYS_CLK_EN0_REG0, 13);
- static MESON_GATE(s4_aucpu, CLKCTRL_SYS_CLK_EN0_REG0, 14);
- static MESON_GATE(s4_cec, CLKCTRL_SYS_CLK_EN0_REG0, 16);
- static MESON_GATE(s4_sdemmca, CLKCTRL_SYS_CLK_EN0_REG0, 24);
- static MESON_GATE(s4_sdemmcb, CLKCTRL_SYS_CLK_EN0_REG0, 25);
- static MESON_GATE(s4_nand, CLKCTRL_SYS_CLK_EN0_REG0, 26);
- static MESON_GATE(s4_smartcard, CLKCTRL_SYS_CLK_EN0_REG0, 27);
- static MESON_GATE(s4_acodec, CLKCTRL_SYS_CLK_EN0_REG0, 28);
- static MESON_GATE(s4_spifc, CLKCTRL_SYS_CLK_EN0_REG0, 29);
- static MESON_GATE(s4_msr_clk, CLKCTRL_SYS_CLK_EN0_REG0, 30);
- static MESON_GATE(s4_ir_ctrl, CLKCTRL_SYS_CLK_EN0_REG0, 31);
- static MESON_GATE(s4_audio, CLKCTRL_SYS_CLK_EN0_REG1, 0);
- static MESON_GATE(s4_eth, CLKCTRL_SYS_CLK_EN0_REG1, 3);
- static MESON_GATE(s4_uart_a, CLKCTRL_SYS_CLK_EN0_REG1, 5);
- static MESON_GATE(s4_uart_b, CLKCTRL_SYS_CLK_EN0_REG1, 6);
- static MESON_GATE(s4_uart_c, CLKCTRL_SYS_CLK_EN0_REG1, 7);
- static MESON_GATE(s4_uart_d, CLKCTRL_SYS_CLK_EN0_REG1, 8);
- static MESON_GATE(s4_uart_e, CLKCTRL_SYS_CLK_EN0_REG1, 9);
- static MESON_GATE(s4_aififo, CLKCTRL_SYS_CLK_EN0_REG1, 11);
- static MESON_GATE(s4_ts_ddr, CLKCTRL_SYS_CLK_EN0_REG1, 15);
- static MESON_GATE(s4_ts_pll, CLKCTRL_SYS_CLK_EN0_REG1, 16);
- static MESON_GATE(s4_g2d, CLKCTRL_SYS_CLK_EN0_REG1, 20);
- static MESON_GATE(s4_spicc0, CLKCTRL_SYS_CLK_EN0_REG1, 21);
- static MESON_GATE(s4_usb, CLKCTRL_SYS_CLK_EN0_REG1, 26);
- static MESON_GATE(s4_i2c_m_a, CLKCTRL_SYS_CLK_EN0_REG1, 30);
- static MESON_GATE(s4_i2c_m_b, CLKCTRL_SYS_CLK_EN0_REG1, 31);
- static MESON_GATE(s4_i2c_m_c, CLKCTRL_SYS_CLK_EN0_REG2, 0);
- static MESON_GATE(s4_i2c_m_d, CLKCTRL_SYS_CLK_EN0_REG2, 1);
- static MESON_GATE(s4_i2c_m_e, CLKCTRL_SYS_CLK_EN0_REG2, 2);
- static MESON_GATE(s4_hdmitx_apb, CLKCTRL_SYS_CLK_EN0_REG2, 4);
- static MESON_GATE(s4_i2c_s_a, CLKCTRL_SYS_CLK_EN0_REG2, 5);
- static MESON_GATE(s4_usb1_to_ddr, CLKCTRL_SYS_CLK_EN0_REG2, 8);
- static MESON_GATE(s4_hdcp22, CLKCTRL_SYS_CLK_EN0_REG2, 10);
- static MESON_GATE(s4_mmc_apb, CLKCTRL_SYS_CLK_EN0_REG2, 11);
- static MESON_GATE(s4_rsa, CLKCTRL_SYS_CLK_EN0_REG2, 18);
- static MESON_GATE(s4_cpu_debug, CLKCTRL_SYS_CLK_EN0_REG2, 19);
- static MESON_GATE(s4_vpu_intr, CLKCTRL_SYS_CLK_EN0_REG2, 25);
- static MESON_GATE(s4_demod, CLKCTRL_SYS_CLK_EN0_REG2, 27);
- static MESON_GATE(s4_sar_adc, CLKCTRL_SYS_CLK_EN0_REG2, 28);
- static MESON_GATE(s4_gic, CLKCTRL_SYS_CLK_EN0_REG2, 30);
- static MESON_GATE(s4_pwm_ab, CLKCTRL_SYS_CLK_EN0_REG3, 7);
- static MESON_GATE(s4_pwm_cd, CLKCTRL_SYS_CLK_EN0_REG3, 8);
- static MESON_GATE(s4_pwm_ef, CLKCTRL_SYS_CLK_EN0_REG3, 9);
- static MESON_GATE(s4_pwm_gh, CLKCTRL_SYS_CLK_EN0_REG3, 10);
- static MESON_GATE(s4_pwm_ij, CLKCTRL_SYS_CLK_EN0_REG3, 11);
- /* Array of all clocks provided by this provider */
- static struct clk_hw *s4_periphs_hw_clks[] = {
- [CLKID_RTC_32K_CLKIN] = &s4_rtc_32k_by_oscin_clkin.hw,
- [CLKID_RTC_32K_DIV] = &s4_rtc_32k_by_oscin_div.hw,
- [CLKID_RTC_32K_SEL] = &s4_rtc_32k_by_oscin_sel.hw,
- [CLKID_RTC_32K_XATL] = &s4_rtc_32k_by_oscin.hw,
- [CLKID_RTC] = &s4_rtc_clk.hw,
- [CLKID_SYS_CLK_B_SEL] = &s4_sysclk_b_sel.hw,
- [CLKID_SYS_CLK_B_DIV] = &s4_sysclk_b_div.hw,
- [CLKID_SYS_CLK_B] = &s4_sysclk_b.hw,
- [CLKID_SYS_CLK_A_SEL] = &s4_sysclk_a_sel.hw,
- [CLKID_SYS_CLK_A_DIV] = &s4_sysclk_a_div.hw,
- [CLKID_SYS_CLK_A] = &s4_sysclk_a.hw,
- [CLKID_SYS] = &s4_sys_clk.hw,
- [CLKID_CECA_32K_CLKIN] = &s4_ceca_32k_clkin.hw,
- [CLKID_CECA_32K_DIV] = &s4_ceca_32k_div.hw,
- [CLKID_CECA_32K_SEL_PRE] = &s4_ceca_32k_sel_pre.hw,
- [CLKID_CECA_32K_SEL] = &s4_ceca_32k_sel.hw,
- [CLKID_CECA_32K_CLKOUT] = &s4_ceca_32k_clkout.hw,
- [CLKID_CECB_32K_CLKIN] = &s4_cecb_32k_clkin.hw,
- [CLKID_CECB_32K_DIV] = &s4_cecb_32k_div.hw,
- [CLKID_CECB_32K_SEL_PRE] = &s4_cecb_32k_sel_pre.hw,
- [CLKID_CECB_32K_SEL] = &s4_cecb_32k_sel.hw,
- [CLKID_CECB_32K_CLKOUT] = &s4_cecb_32k_clkout.hw,
- [CLKID_SC_CLK_SEL] = &s4_sc_clk_mux.hw,
- [CLKID_SC_CLK_DIV] = &s4_sc_clk_div.hw,
- [CLKID_SC] = &s4_sc_clk_gate.hw,
- [CLKID_12_24M] = &s4_12_24M_clk_gate.hw,
- [CLKID_12M_CLK_DIV] = &s4_12M_clk_div.hw,
- [CLKID_12_24M_CLK_SEL] = &s4_12_24M_clk.hw,
- [CLKID_VID_PLL_DIV] = &s4_vid_pll_div.hw,
- [CLKID_VID_PLL_SEL] = &s4_vid_pll_sel.hw,
- [CLKID_VID_PLL] = &s4_vid_pll.hw,
- [CLKID_VCLK_SEL] = &s4_vclk_sel.hw,
- [CLKID_VCLK2_SEL] = &s4_vclk2_sel.hw,
- [CLKID_VCLK_INPUT] = &s4_vclk_input.hw,
- [CLKID_VCLK2_INPUT] = &s4_vclk2_input.hw,
- [CLKID_VCLK_DIV] = &s4_vclk_div.hw,
- [CLKID_VCLK2_DIV] = &s4_vclk2_div.hw,
- [CLKID_VCLK] = &s4_vclk.hw,
- [CLKID_VCLK2] = &s4_vclk2.hw,
- [CLKID_VCLK_DIV1] = &s4_vclk_div1.hw,
- [CLKID_VCLK_DIV2_EN] = &s4_vclk_div2_en.hw,
- [CLKID_VCLK_DIV4_EN] = &s4_vclk_div4_en.hw,
- [CLKID_VCLK_DIV6_EN] = &s4_vclk_div6_en.hw,
- [CLKID_VCLK_DIV12_EN] = &s4_vclk_div12_en.hw,
- [CLKID_VCLK2_DIV1] = &s4_vclk2_div1.hw,
- [CLKID_VCLK2_DIV2_EN] = &s4_vclk2_div2_en.hw,
- [CLKID_VCLK2_DIV4_EN] = &s4_vclk2_div4_en.hw,
- [CLKID_VCLK2_DIV6_EN] = &s4_vclk2_div6_en.hw,
- [CLKID_VCLK2_DIV12_EN] = &s4_vclk2_div12_en.hw,
- [CLKID_VCLK_DIV2] = &s4_vclk_div2.hw,
- [CLKID_VCLK_DIV4] = &s4_vclk_div4.hw,
- [CLKID_VCLK_DIV6] = &s4_vclk_div6.hw,
- [CLKID_VCLK_DIV12] = &s4_vclk_div12.hw,
- [CLKID_VCLK2_DIV2] = &s4_vclk2_div2.hw,
- [CLKID_VCLK2_DIV4] = &s4_vclk2_div4.hw,
- [CLKID_VCLK2_DIV6] = &s4_vclk2_div6.hw,
- [CLKID_VCLK2_DIV12] = &s4_vclk2_div12.hw,
- [CLKID_CTS_ENCI_SEL] = &s4_cts_enci_sel.hw,
- [CLKID_CTS_ENCP_SEL] = &s4_cts_encp_sel.hw,
- [CLKID_CTS_VDAC_SEL] = &s4_cts_vdac_sel.hw,
- [CLKID_HDMI_TX_SEL] = &s4_hdmi_tx_sel.hw,
- [CLKID_CTS_ENCI] = &s4_cts_enci.hw,
- [CLKID_CTS_ENCP] = &s4_cts_encp.hw,
- [CLKID_CTS_VDAC] = &s4_cts_vdac.hw,
- [CLKID_HDMI_TX] = &s4_hdmi_tx.hw,
- [CLKID_HDMI_SEL] = &s4_hdmi_sel.hw,
- [CLKID_HDMI_DIV] = &s4_hdmi_div.hw,
- [CLKID_HDMI] = &s4_hdmi.hw,
- [CLKID_TS_CLK_DIV] = &s4_ts_clk_div.hw,
- [CLKID_TS] = &s4_ts_clk_gate.hw,
- [CLKID_MALI_0_SEL] = &s4_mali_0_sel.hw,
- [CLKID_MALI_0_DIV] = &s4_mali_0_div.hw,
- [CLKID_MALI_0] = &s4_mali_0.hw,
- [CLKID_MALI_1_SEL] = &s4_mali_1_sel.hw,
- [CLKID_MALI_1_DIV] = &s4_mali_1_div.hw,
- [CLKID_MALI_1] = &s4_mali_1.hw,
- [CLKID_MALI_SEL] = &s4_mali_mux.hw,
- [CLKID_VDEC_P0_SEL] = &s4_vdec_p0_mux.hw,
- [CLKID_VDEC_P0_DIV] = &s4_vdec_p0_div.hw,
- [CLKID_VDEC_P0] = &s4_vdec_p0.hw,
- [CLKID_VDEC_P1_SEL] = &s4_vdec_p1_mux.hw,
- [CLKID_VDEC_P1_DIV] = &s4_vdec_p1_div.hw,
- [CLKID_VDEC_P1] = &s4_vdec_p1.hw,
- [CLKID_VDEC_SEL] = &s4_vdec_mux.hw,
- [CLKID_HEVCF_P0_SEL] = &s4_hevcf_p0_mux.hw,
- [CLKID_HEVCF_P0_DIV] = &s4_hevcf_p0_div.hw,
- [CLKID_HEVCF_P0] = &s4_hevcf_p0.hw,
- [CLKID_HEVCF_P1_SEL] = &s4_hevcf_p1_mux.hw,
- [CLKID_HEVCF_P1_DIV] = &s4_hevcf_p1_div.hw,
- [CLKID_HEVCF_P1] = &s4_hevcf_p1.hw,
- [CLKID_HEVCF_SEL] = &s4_hevcf_mux.hw,
- [CLKID_VPU_0_SEL] = &s4_vpu_0_sel.hw,
- [CLKID_VPU_0_DIV] = &s4_vpu_0_div.hw,
- [CLKID_VPU_0] = &s4_vpu_0.hw,
- [CLKID_VPU_1_SEL] = &s4_vpu_1_sel.hw,
- [CLKID_VPU_1_DIV] = &s4_vpu_1_div.hw,
- [CLKID_VPU_1] = &s4_vpu_1.hw,
- [CLKID_VPU] = &s4_vpu.hw,
- [CLKID_VPU_CLKB_TMP_SEL] = &s4_vpu_clkb_tmp_mux.hw,
- [CLKID_VPU_CLKB_TMP_DIV] = &s4_vpu_clkb_tmp_div.hw,
- [CLKID_VPU_CLKB_TMP] = &s4_vpu_clkb_tmp.hw,
- [CLKID_VPU_CLKB_DIV] = &s4_vpu_clkb_div.hw,
- [CLKID_VPU_CLKB] = &s4_vpu_clkb.hw,
- [CLKID_VPU_CLKC_P0_SEL] = &s4_vpu_clkc_p0_mux.hw,
- [CLKID_VPU_CLKC_P0_DIV] = &s4_vpu_clkc_p0_div.hw,
- [CLKID_VPU_CLKC_P0] = &s4_vpu_clkc_p0.hw,
- [CLKID_VPU_CLKC_P1_SEL] = &s4_vpu_clkc_p1_mux.hw,
- [CLKID_VPU_CLKC_P1_DIV] = &s4_vpu_clkc_p1_div.hw,
- [CLKID_VPU_CLKC_P1] = &s4_vpu_clkc_p1.hw,
- [CLKID_VPU_CLKC_SEL] = &s4_vpu_clkc_mux.hw,
- [CLKID_VAPB_0_SEL] = &s4_vapb_0_sel.hw,
- [CLKID_VAPB_0_DIV] = &s4_vapb_0_div.hw,
- [CLKID_VAPB_0] = &s4_vapb_0.hw,
- [CLKID_VAPB_1_SEL] = &s4_vapb_1_sel.hw,
- [CLKID_VAPB_1_DIV] = &s4_vapb_1_div.hw,
- [CLKID_VAPB_1] = &s4_vapb_1.hw,
- [CLKID_VAPB] = &s4_vapb.hw,
- [CLKID_GE2D] = &s4_ge2d_gate.hw,
- [CLKID_VDIN_MEAS_SEL] = &s4_vdin_meas_mux.hw,
- [CLKID_VDIN_MEAS_DIV] = &s4_vdin_meas_div.hw,
- [CLKID_VDIN_MEAS] = &s4_vdin_meas_gate.hw,
- [CLKID_SD_EMMC_C_CLK_SEL] = &s4_sd_emmc_c_clk0_sel.hw,
- [CLKID_SD_EMMC_C_CLK_DIV] = &s4_sd_emmc_c_clk0_div.hw,
- [CLKID_SD_EMMC_C] = &s4_sd_emmc_c_clk0.hw,
- [CLKID_SD_EMMC_A_CLK_SEL] = &s4_sd_emmc_a_clk0_sel.hw,
- [CLKID_SD_EMMC_A_CLK_DIV] = &s4_sd_emmc_a_clk0_div.hw,
- [CLKID_SD_EMMC_A] = &s4_sd_emmc_a_clk0.hw,
- [CLKID_SD_EMMC_B_CLK_SEL] = &s4_sd_emmc_b_clk0_sel.hw,
- [CLKID_SD_EMMC_B_CLK_DIV] = &s4_sd_emmc_b_clk0_div.hw,
- [CLKID_SD_EMMC_B] = &s4_sd_emmc_b_clk0.hw,
- [CLKID_SPICC0_SEL] = &s4_spicc0_mux.hw,
- [CLKID_SPICC0_DIV] = &s4_spicc0_div.hw,
- [CLKID_SPICC0_EN] = &s4_spicc0_gate.hw,
- [CLKID_PWM_A_SEL] = &s4_pwm_a_mux.hw,
- [CLKID_PWM_A_DIV] = &s4_pwm_a_div.hw,
- [CLKID_PWM_A] = &s4_pwm_a_gate.hw,
- [CLKID_PWM_B_SEL] = &s4_pwm_b_mux.hw,
- [CLKID_PWM_B_DIV] = &s4_pwm_b_div.hw,
- [CLKID_PWM_B] = &s4_pwm_b_gate.hw,
- [CLKID_PWM_C_SEL] = &s4_pwm_c_mux.hw,
- [CLKID_PWM_C_DIV] = &s4_pwm_c_div.hw,
- [CLKID_PWM_C] = &s4_pwm_c_gate.hw,
- [CLKID_PWM_D_SEL] = &s4_pwm_d_mux.hw,
- [CLKID_PWM_D_DIV] = &s4_pwm_d_div.hw,
- [CLKID_PWM_D] = &s4_pwm_d_gate.hw,
- [CLKID_PWM_E_SEL] = &s4_pwm_e_mux.hw,
- [CLKID_PWM_E_DIV] = &s4_pwm_e_div.hw,
- [CLKID_PWM_E] = &s4_pwm_e_gate.hw,
- [CLKID_PWM_F_SEL] = &s4_pwm_f_mux.hw,
- [CLKID_PWM_F_DIV] = &s4_pwm_f_div.hw,
- [CLKID_PWM_F] = &s4_pwm_f_gate.hw,
- [CLKID_PWM_G_SEL] = &s4_pwm_g_mux.hw,
- [CLKID_PWM_G_DIV] = &s4_pwm_g_div.hw,
- [CLKID_PWM_G] = &s4_pwm_g_gate.hw,
- [CLKID_PWM_H_SEL] = &s4_pwm_h_mux.hw,
- [CLKID_PWM_H_DIV] = &s4_pwm_h_div.hw,
- [CLKID_PWM_H] = &s4_pwm_h_gate.hw,
- [CLKID_PWM_I_SEL] = &s4_pwm_i_mux.hw,
- [CLKID_PWM_I_DIV] = &s4_pwm_i_div.hw,
- [CLKID_PWM_I] = &s4_pwm_i_gate.hw,
- [CLKID_PWM_J_SEL] = &s4_pwm_j_mux.hw,
- [CLKID_PWM_J_DIV] = &s4_pwm_j_div.hw,
- [CLKID_PWM_J] = &s4_pwm_j_gate.hw,
- [CLKID_SARADC_SEL] = &s4_saradc_mux.hw,
- [CLKID_SARADC_DIV] = &s4_saradc_div.hw,
- [CLKID_SARADC] = &s4_saradc_gate.hw,
- [CLKID_GEN_SEL] = &s4_gen_clk_sel.hw,
- [CLKID_GEN_DIV] = &s4_gen_clk_div.hw,
- [CLKID_GEN] = &s4_gen_clk.hw,
- [CLKID_DDR] = &s4_ddr.hw,
- [CLKID_DOS] = &s4_dos.hw,
- [CLKID_ETHPHY] = &s4_ethphy.hw,
- [CLKID_MALI] = &s4_mali.hw,
- [CLKID_AOCPU] = &s4_aocpu.hw,
- [CLKID_AUCPU] = &s4_aucpu.hw,
- [CLKID_CEC] = &s4_cec.hw,
- [CLKID_SDEMMC_A] = &s4_sdemmca.hw,
- [CLKID_SDEMMC_B] = &s4_sdemmcb.hw,
- [CLKID_NAND] = &s4_nand.hw,
- [CLKID_SMARTCARD] = &s4_smartcard.hw,
- [CLKID_ACODEC] = &s4_acodec.hw,
- [CLKID_SPIFC] = &s4_spifc.hw,
- [CLKID_MSR] = &s4_msr_clk.hw,
- [CLKID_IR_CTRL] = &s4_ir_ctrl.hw,
- [CLKID_AUDIO] = &s4_audio.hw,
- [CLKID_ETH] = &s4_eth.hw,
- [CLKID_UART_A] = &s4_uart_a.hw,
- [CLKID_UART_B] = &s4_uart_b.hw,
- [CLKID_UART_C] = &s4_uart_c.hw,
- [CLKID_UART_D] = &s4_uart_d.hw,
- [CLKID_UART_E] = &s4_uart_e.hw,
- [CLKID_AIFIFO] = &s4_aififo.hw,
- [CLKID_TS_DDR] = &s4_ts_ddr.hw,
- [CLKID_TS_PLL] = &s4_ts_pll.hw,
- [CLKID_G2D] = &s4_g2d.hw,
- [CLKID_SPICC0] = &s4_spicc0.hw,
- [CLKID_USB] = &s4_usb.hw,
- [CLKID_I2C_M_A] = &s4_i2c_m_a.hw,
- [CLKID_I2C_M_B] = &s4_i2c_m_b.hw,
- [CLKID_I2C_M_C] = &s4_i2c_m_c.hw,
- [CLKID_I2C_M_D] = &s4_i2c_m_d.hw,
- [CLKID_I2C_M_E] = &s4_i2c_m_e.hw,
- [CLKID_HDMITX_APB] = &s4_hdmitx_apb.hw,
- [CLKID_I2C_S_A] = &s4_i2c_s_a.hw,
- [CLKID_USB1_TO_DDR] = &s4_usb1_to_ddr.hw,
- [CLKID_HDCP22] = &s4_hdcp22.hw,
- [CLKID_MMC_APB] = &s4_mmc_apb.hw,
- [CLKID_RSA] = &s4_rsa.hw,
- [CLKID_CPU_DEBUG] = &s4_cpu_debug.hw,
- [CLKID_VPU_INTR] = &s4_vpu_intr.hw,
- [CLKID_DEMOD] = &s4_demod.hw,
- [CLKID_SAR_ADC] = &s4_sar_adc.hw,
- [CLKID_GIC] = &s4_gic.hw,
- [CLKID_PWM_AB] = &s4_pwm_ab.hw,
- [CLKID_PWM_CD] = &s4_pwm_cd.hw,
- [CLKID_PWM_EF] = &s4_pwm_ef.hw,
- [CLKID_PWM_GH] = &s4_pwm_gh.hw,
- [CLKID_PWM_IJ] = &s4_pwm_ij.hw,
- [CLKID_HDCP22_ESMCLK_SEL] = &s4_hdcp22_esmclk_mux.hw,
- [CLKID_HDCP22_ESMCLK_DIV] = &s4_hdcp22_esmclk_div.hw,
- [CLKID_HDCP22_ESMCLK] = &s4_hdcp22_esmclk_gate.hw,
- [CLKID_HDCP22_SKPCLK_SEL] = &s4_hdcp22_skpclk_mux.hw,
- [CLKID_HDCP22_SKPCLK_DIV] = &s4_hdcp22_skpclk_div.hw,
- [CLKID_HDCP22_SKPCLK] = &s4_hdcp22_skpclk_gate.hw,
- };
- /* Convenience table to populate regmap in .probe */
- static struct clk_regmap *const s4_periphs_clk_regmaps[] = {
- &s4_rtc_32k_by_oscin_clkin,
- &s4_rtc_32k_by_oscin_div,
- &s4_rtc_32k_by_oscin_sel,
- &s4_rtc_32k_by_oscin,
- &s4_rtc_clk,
- &s4_sysclk_b_sel,
- &s4_sysclk_b_div,
- &s4_sysclk_b,
- &s4_sysclk_a_sel,
- &s4_sysclk_a_div,
- &s4_sysclk_a,
- &s4_sys_clk,
- &s4_ceca_32k_clkin,
- &s4_ceca_32k_div,
- &s4_ceca_32k_sel_pre,
- &s4_ceca_32k_sel,
- &s4_ceca_32k_clkout,
- &s4_cecb_32k_clkin,
- &s4_cecb_32k_div,
- &s4_cecb_32k_sel_pre,
- &s4_cecb_32k_sel,
- &s4_cecb_32k_clkout,
- &s4_sc_clk_mux,
- &s4_sc_clk_div,
- &s4_sc_clk_gate,
- &s4_12_24M_clk_gate,
- &s4_12_24M_clk,
- &s4_vid_pll_div,
- &s4_vid_pll_sel,
- &s4_vid_pll,
- &s4_vclk_sel,
- &s4_vclk2_sel,
- &s4_vclk_input,
- &s4_vclk2_input,
- &s4_vclk_div,
- &s4_vclk2_div,
- &s4_vclk,
- &s4_vclk2,
- &s4_vclk_div1,
- &s4_vclk_div2_en,
- &s4_vclk_div4_en,
- &s4_vclk_div6_en,
- &s4_vclk_div12_en,
- &s4_vclk2_div1,
- &s4_vclk2_div2_en,
- &s4_vclk2_div4_en,
- &s4_vclk2_div6_en,
- &s4_vclk2_div12_en,
- &s4_cts_enci_sel,
- &s4_cts_encp_sel,
- &s4_cts_vdac_sel,
- &s4_hdmi_tx_sel,
- &s4_cts_enci,
- &s4_cts_encp,
- &s4_cts_vdac,
- &s4_hdmi_tx,
- &s4_hdmi_sel,
- &s4_hdmi_div,
- &s4_hdmi,
- &s4_ts_clk_div,
- &s4_ts_clk_gate,
- &s4_mali_0_sel,
- &s4_mali_0_div,
- &s4_mali_0,
- &s4_mali_1_sel,
- &s4_mali_1_div,
- &s4_mali_1,
- &s4_mali_mux,
- &s4_vdec_p0_mux,
- &s4_vdec_p0_div,
- &s4_vdec_p0,
- &s4_vdec_p1_mux,
- &s4_vdec_p1_div,
- &s4_vdec_p1,
- &s4_vdec_mux,
- &s4_hevcf_p0_mux,
- &s4_hevcf_p0_div,
- &s4_hevcf_p0,
- &s4_hevcf_p1_mux,
- &s4_hevcf_p1_div,
- &s4_hevcf_p1,
- &s4_hevcf_mux,
- &s4_vpu_0_sel,
- &s4_vpu_0_div,
- &s4_vpu_0,
- &s4_vpu_1_sel,
- &s4_vpu_1_div,
- &s4_vpu_1,
- &s4_vpu,
- &s4_vpu_clkb_tmp_mux,
- &s4_vpu_clkb_tmp_div,
- &s4_vpu_clkb_tmp,
- &s4_vpu_clkb_div,
- &s4_vpu_clkb,
- &s4_vpu_clkc_p0_mux,
- &s4_vpu_clkc_p0_div,
- &s4_vpu_clkc_p0,
- &s4_vpu_clkc_p1_mux,
- &s4_vpu_clkc_p1_div,
- &s4_vpu_clkc_p1,
- &s4_vpu_clkc_mux,
- &s4_vapb_0_sel,
- &s4_vapb_0_div,
- &s4_vapb_0,
- &s4_vapb_1_sel,
- &s4_vapb_1_div,
- &s4_vapb_1,
- &s4_vapb,
- &s4_ge2d_gate,
- &s4_hdcp22_esmclk_mux,
- &s4_hdcp22_esmclk_div,
- &s4_hdcp22_esmclk_gate,
- &s4_hdcp22_skpclk_mux,
- &s4_hdcp22_skpclk_div,
- &s4_hdcp22_skpclk_gate,
- &s4_vdin_meas_mux,
- &s4_vdin_meas_div,
- &s4_vdin_meas_gate,
- &s4_sd_emmc_c_clk0_sel,
- &s4_sd_emmc_c_clk0_div,
- &s4_sd_emmc_c_clk0,
- &s4_sd_emmc_a_clk0_sel,
- &s4_sd_emmc_a_clk0_div,
- &s4_sd_emmc_a_clk0,
- &s4_sd_emmc_b_clk0_sel,
- &s4_sd_emmc_b_clk0_div,
- &s4_sd_emmc_b_clk0,
- &s4_spicc0_mux,
- &s4_spicc0_div,
- &s4_spicc0_gate,
- &s4_pwm_a_mux,
- &s4_pwm_a_div,
- &s4_pwm_a_gate,
- &s4_pwm_b_mux,
- &s4_pwm_b_div,
- &s4_pwm_b_gate,
- &s4_pwm_c_mux,
- &s4_pwm_c_div,
- &s4_pwm_c_gate,
- &s4_pwm_d_mux,
- &s4_pwm_d_div,
- &s4_pwm_d_gate,
- &s4_pwm_e_mux,
- &s4_pwm_e_div,
- &s4_pwm_e_gate,
- &s4_pwm_f_mux,
- &s4_pwm_f_div,
- &s4_pwm_f_gate,
- &s4_pwm_g_mux,
- &s4_pwm_g_div,
- &s4_pwm_g_gate,
- &s4_pwm_h_mux,
- &s4_pwm_h_div,
- &s4_pwm_h_gate,
- &s4_pwm_i_mux,
- &s4_pwm_i_div,
- &s4_pwm_i_gate,
- &s4_pwm_j_mux,
- &s4_pwm_j_div,
- &s4_pwm_j_gate,
- &s4_saradc_mux,
- &s4_saradc_div,
- &s4_saradc_gate,
- &s4_gen_clk_sel,
- &s4_gen_clk_div,
- &s4_gen_clk,
- &s4_ddr,
- &s4_dos,
- &s4_ethphy,
- &s4_mali,
- &s4_aocpu,
- &s4_aucpu,
- &s4_cec,
- &s4_sdemmca,
- &s4_sdemmcb,
- &s4_nand,
- &s4_smartcard,
- &s4_acodec,
- &s4_spifc,
- &s4_msr_clk,
- &s4_ir_ctrl,
- &s4_audio,
- &s4_eth,
- &s4_uart_a,
- &s4_uart_b,
- &s4_uart_c,
- &s4_uart_d,
- &s4_uart_e,
- &s4_aififo,
- &s4_ts_ddr,
- &s4_ts_pll,
- &s4_g2d,
- &s4_spicc0,
- &s4_usb,
- &s4_i2c_m_a,
- &s4_i2c_m_b,
- &s4_i2c_m_c,
- &s4_i2c_m_d,
- &s4_i2c_m_e,
- &s4_hdmitx_apb,
- &s4_i2c_s_a,
- &s4_usb1_to_ddr,
- &s4_hdcp22,
- &s4_mmc_apb,
- &s4_rsa,
- &s4_cpu_debug,
- &s4_vpu_intr,
- &s4_demod,
- &s4_sar_adc,
- &s4_gic,
- &s4_pwm_ab,
- &s4_pwm_cd,
- &s4_pwm_ef,
- &s4_pwm_gh,
- &s4_pwm_ij,
- &s4_demod_core_clk_mux,
- &s4_demod_core_clk_div,
- &s4_demod_core_clk_gate,
- &s4_adc_extclk_in_mux,
- &s4_adc_extclk_in_div,
- &s4_adc_extclk_in_gate,
- };
- static const struct regmap_config clkc_regmap_config = {
- .reg_bits = 32,
- .val_bits = 32,
- .reg_stride = 4,
- .max_register = CLKCTRL_DEMOD_CLK_CTRL,
- };
- static struct meson_clk_hw_data s4_periphs_clks = {
- .hws = s4_periphs_hw_clks,
- .num = ARRAY_SIZE(s4_periphs_hw_clks),
- };
- static int meson_s4_periphs_probe(struct platform_device *pdev)
- {
- struct device *dev = &pdev->dev;
- struct regmap *regmap;
- void __iomem *base;
- int ret, i;
- base = devm_platform_ioremap_resource(pdev, 0);
- if (IS_ERR(base))
- return dev_err_probe(dev, PTR_ERR(base),
- "can't ioremap resource\n");
- regmap = devm_regmap_init_mmio(dev, base, &clkc_regmap_config);
- if (IS_ERR(regmap))
- return dev_err_probe(dev, PTR_ERR(regmap),
- "can't init regmap mmio region\n");
- /* Populate regmap for the regmap backed clocks */
- for (i = 0; i < ARRAY_SIZE(s4_periphs_clk_regmaps); i++)
- s4_periphs_clk_regmaps[i]->map = regmap;
- for (i = 0; i < s4_periphs_clks.num; i++) {
- /* array might be sparse */
- if (!s4_periphs_clks.hws[i])
- continue;
- ret = devm_clk_hw_register(dev, s4_periphs_clks.hws[i]);
- if (ret)
- return dev_err_probe(dev, ret,
- "clock[%d] registration failed\n", i);
- }
- return devm_of_clk_add_hw_provider(dev, meson_clk_hw_get, &s4_periphs_clks);
- }
- static const struct of_device_id clkc_match_table[] = {
- {
- .compatible = "amlogic,s4-peripherals-clkc",
- },
- {}
- };
- MODULE_DEVICE_TABLE(of, clkc_match_table);
- static struct platform_driver s4_driver = {
- .probe = meson_s4_periphs_probe,
- .driver = {
- .name = "s4-periphs-clkc",
- .of_match_table = clkc_match_table,
- },
- };
- module_platform_driver(s4_driver);
- MODULE_DESCRIPTION("Amlogic S4 Peripherals Clock Controller driver");
- MODULE_AUTHOR("Yu Tu <yu.tu@amlogic.com>");
- MODULE_LICENSE("GPL");
- MODULE_IMPORT_NS(CLK_MESON);
|