// SPDX-License-Identifier: GPL-2.0 /* * Device Tree Source for Keystone 2 clock tree * * Copyright (C) 2013-2017 Texas Instruments Incorporated - http://www.ti.com/ */ clocks { #address-cells = <1>; #size-cells = <1>; ranges; mainmuxclk: mainmuxclk@2310108 { #clock-cells = <0>; compatible = "ti,keystone,pll-mux-clock"; clocks = <&mainpllclk>, <&refclksys>; reg = <0x02310108 4>; bit-shift = <23>; bit-mask = <1>; clock-output-names = "mainmuxclk"; }; chipclk1: chipclk1 { #clock-cells = <0>; compatible = "fixed-factor-clock"; clocks = <&mainmuxclk>; clock-div = <1>; clock-mult = <1>; clock-output-names = "chipclk1"; }; chipclk1rstiso: chipclk1rstiso { #clock-cells = <0>; compatible = "fixed-factor-clock"; clocks = <&mainmuxclk>; clock-div = <1>; clock-mult = <1>; clock-output-names = "chipclk1rstiso"; }; gemtraceclk: gemtraceclk@2310120 { #clock-cells = <0>; compatible = "ti,keystone,pll-divider-clock"; clocks = <&mainmuxclk>; reg = <0x02310120 4>; bit-shift = <0>; bit-mask = <8>; clock-output-names = "gemtraceclk"; }; chipstmxptclk: chipstmxptclk { #clock-cells = <0>; compatible = "ti,keystone,pll-divider-clock"; clocks = <&mainmuxclk>; reg = <0x02310164 4>; bit-shift = <0>; bit-mask = <8>; clock-output-names = "chipstmxptclk"; }; chipclk12: chipclk12 { #clock-cells = <0>; compatible = "fixed-factor-clock"; clocks = <&chipclk1>; clock-div = <2>; clock-mult = <1>; clock-output-names = "chipclk12"; }; chipclk13: chipclk13 { #clock-cells = <0>; compatible = "fixed-factor-clock"; clocks = <&chipclk1>; clock-div = <3>; clock-mult = <1>; clock-output-names = "chipclk13"; }; paclk13: paclk13 { #clock-cells = <0>; compatible = "fixed-factor-clock"; clocks = <&papllclk>; clock-div = <3>; clock-mult = <1>; clock-output-names = "paclk13"; }; chipclk14: chipclk14 { #clock-cells = <0>; compatible = "fixed-factor-clock"; clocks = <&chipclk1>; clock-div = <4>; clock-mult = <1>; clock-output-names = "chipclk14"; }; chipclk16: chipclk16 { #clock-cells = <0>; compatible = "fixed-factor-clock"; clocks = <&chipclk1>; clock-div = <6>; clock-mult = <1>; clock-output-names = "chipclk16"; }; chipclk112: chipclk112 { #clock-cells = <0>; compatible = "fixed-factor-clock"; clocks = <&chipclk1>; clock-div = <12>; clock-mult = <1>; clock-output-names = "chipclk112"; }; chipclk124: chipclk124 { #clock-cells = <0>; compatible = "fixed-factor-clock"; clocks = <&chipclk1>; clock-div = <24>; clock-mult = <1>; clock-output-names = "chipclk114"; }; chipclk1rstiso13: chipclk1rstiso13 { #clock-cells = <0>; compatible = "fixed-factor-clock"; clocks = <&chipclk1rstiso>; clock-div = <3>; clock-mult = <1>; clock-output-names = "chipclk1rstiso13"; }; chipclk1rstiso14: chipclk1rstiso14 { #clock-cells = <0>; compatible = "fixed-factor-clock"; clocks = <&chipclk1rstiso>; clock-div = <4>; clock-mult = <1>; clock-output-names = "chipclk1rstiso14"; }; chipclk1rstiso16: chipclk1rstiso16 { #clock-cells = <0>; compatible = "fixed-factor-clock"; clocks = <&chipclk1rstiso>; clock-div = <6>; clock-mult = <1>; clock-output-names = "chipclk1rstiso16"; }; chipclk1rstiso112: chipclk1rstiso112 { #clock-cells = <0>; compatible = "fixed-factor-clock"; clocks = <&chipclk1rstiso>; clock-div = <12>; clock-mult = <1>; clock-output-names = "chipclk1rstiso112"; }; clkmodrst0: clkmodrst0 { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&chipclk16>; clock-output-names = "modrst0"; reg = <0x02350000 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; clkusb: clkusb { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&chipclk16>; clock-output-names = "usb"; reg = <0x02350008 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; clkaemifspi: clkaemifspi { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&chipclk16>; clock-output-names = "aemif-spi"; reg = <0x0235000c 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; clkdebugsstrc: clkdebugsstrc { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&chipclk13>; clock-output-names = "debugss-trc"; reg = <0x02350014 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <1>; }; clktetbtrc: clktetbtrc { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&chipclk13>; clock-output-names = "tetb-trc"; reg = <0x02350018 0xb00>, <0x02350004 0x400>; reg-names = "control", "domain"; domain-id = <1>; }; clkpa: clkpa { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&paclk13>; clock-output-names = "pa"; reg = <0x0235001c 0xb00>, <0x02350008 0x400>; reg-names = "control", "domain"; domain-id = <2>; }; clkcpgmac: clkcpgmac { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&clkpa>; clock-output-names = "cpgmac"; reg = <0x02350020 0xb00>, <0x02350008 0x400>; reg-names = "control", "domain"; domain-id = <2>; }; clksa: clksa { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&clkpa>; clock-output-names = "sa"; reg = <0x02350024 0xb00>, <0x02350008 0x400>; reg-names = "control", "domain"; domain-id = <2>; }; clkpcie: clkpcie { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&chipclk12>; clock-output-names = "pcie"; reg = <0x02350028 0xb00>, <0x0235000c 0x400>; reg-names = "control", "domain"; domain-id = <3>; }; clksr: clksr { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&chipclk1rstiso112>; clock-output-names = "sr"; reg = <0x02350034 0xb00>, <0x02350018 0x400>; reg-names = "control", "domain"; domain-id = <6>; }; clkgem0: clkgem0 { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&chipclk1>; clock-output-names = "gem0"; reg = <0x0235003c 0xb00>, <0x02350020 0x400>; reg-names = "control", "domain"; domain-id = <8>; }; clkddr30: clkddr30 { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&chipclk12>; clock-output-names = "ddr3-0"; reg = <0x0235005c 0xb00>, <0x02350040 0x400>; reg-names = "control", "domain"; domain-id = <16>; }; clkwdtimer0: clkwdtimer0 { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&clkmodrst0>; clock-output-names = "timer0"; reg = <0x02350000 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; clkwdtimer1: clkwdtimer1 { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&clkmodrst0>; clock-output-names = "timer1"; reg = <0x02350000 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; clkwdtimer2: clkwdtimer2 { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&clkmodrst0>; clock-output-names = "timer2"; reg = <0x02350000 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; clkwdtimer3: clkwdtimer3 { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&clkmodrst0>; clock-output-names = "timer3"; reg = <0x02350000 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; clktimer15: clktimer15 { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&clkmodrst0>; clock-output-names = "timer15"; reg = <0x02350000 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; clkuart0: clkuart0 { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&clkmodrst0>; clock-output-names = "uart0"; reg = <0x02350000 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; clkuart1: clkuart1 { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&clkmodrst0>; clock-output-names = "uart1"; reg = <0x02350000 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; clkaemif: clkaemif { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&clkaemifspi>; clock-output-names = "aemif"; reg = <0x02350000 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; clkusim: clkusim { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&clkmodrst0>; clock-output-names = "usim"; reg = <0x02350000 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; clki2c: clki2c { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&clkmodrst0>; clock-output-names = "i2c"; reg = <0x02350000 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; clkspi: clkspi { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&clkaemifspi>; clock-output-names = "spi"; reg = <0x02350000 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; clkgpio: clkgpio { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&clkmodrst0>; clock-output-names = "gpio"; reg = <0x02350000 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; clkkeymgr: clkkeymgr { #clock-cells = <0>; compatible = "ti,keystone,psc-clock"; clocks = <&clkmodrst0>; clock-output-names = "keymgr"; reg = <0x02350000 0xb00>, <0x02350000 0x400>; reg-names = "control", "domain"; domain-id = <0>; }; };