From: Serge Semin <fancer.lancer@xxxxxxxxx> Clocks Control Unit is the core of Baikal-T1 SoC responsible for the chip subsystems clocking and resetting. The CCU is connected with an external fixed rate oscillator, which signal is transformed into clocks of various frequencies and then propagated to either individual IP-blocks or to groups of blocks (clock domains). The transformation is done by means of PLLs and gateable/non-gateable, fixed/variable dividers embedded into the CCU. There are five PLLs to create a clock for the MIPS P5600 cores, the embedded DDR controller, SATA, Ethernet and PCIe domains. The last three PLLs CLKOUT are then passed over CCU dividers to create signals required for the target clock domains: individual AXI and APB bus clocks, SoC devices reference clocks. The CCU divider registers may also provide a way to reset the target devices state. So this patchset introduces the Baikal-T1 clock and reset drivers of CCU PLLs, AXI-bus clock dividers and system devices clock dividers. This patchset is rebased and tested on the mainline Linux kernel 5.6-rc4: commit 98d54f81e36b ("Linux 5.6-rc4"). Signed-off-by: Serge Semin <Sergey.Semin@xxxxxxxxxxxxxxxxxxxx> Signed-off-by: Alexey Malahov <Alexey.Malahov@xxxxxxxxxxxxxxxxxxxx> Cc: Maxim Kaurkin <Maxim.Kaurkin@xxxxxxxxxxxxxxxxxxxx> Cc: Pavel Parkhomenko <Pavel.Parkhomenko@xxxxxxxxxxxxxxxxxxxx> Cc: Ramil Zaripov <Ramil.Zaripov@xxxxxxxxxxxxxxxxxxxx> Cc: Ekaterina Skachko <Ekaterina.Skachko@xxxxxxxxxxxxxxxxxxxx> Cc: Vadim Vlasov <V.Vlasov@xxxxxxxxxxxxxxxxxxxx> Cc: Thomas Bogendoerfer <tsbogend@xxxxxxxxxxxxxxxx> Cc: Paul Burton <paulburton@xxxxxxxxxx> Cc: Ralf Baechle <ralf@xxxxxxxxxxxxxx> Cc: Michael Turquette <mturquette@xxxxxxxxxxxx> Cc: Stephen Boyd <sboyd@xxxxxxxxxx> Cc: Rob Herring <robh+dt@xxxxxxxxxx> Cc: Mark Rutland <mark.rutland@xxxxxxx> Cc: linux-clk@xxxxxxxxxxxxxxx Cc: devicetree@xxxxxxxxxxxxxxx Cc: linux-kernel@xxxxxxxxxxxxxxx Serge Semin (5): dt-bindings: clk: Add Baikal-T1 CCU PLLs bindings dt-bindings: clk: Add Baikal-T1 AXI-bus CCU bindings dt-bindings: clk: Add Baikal-T1 System Devices CCU bindings clk: Add Baikal-T1 CCU PLLs driver clk: Add Baikal-T1 CCU dividers driver .../bindings/clock/be,bt1-ccu-axi.yaml | 151 +++++ .../bindings/clock/be,bt1-ccu-pll.yaml | 139 +++++ .../bindings/clock/be,bt1-ccu-sys.yaml | 169 ++++++ drivers/clk/Kconfig | 1 + drivers/clk/Makefile | 1 + drivers/clk/baikal-t1/Kconfig | 46 ++ drivers/clk/baikal-t1/Makefile | 3 + drivers/clk/baikal-t1/ccu-div.c | 531 ++++++++++++++++++ drivers/clk/baikal-t1/ccu-div.h | 114 ++++ drivers/clk/baikal-t1/ccu-pll.c | 474 ++++++++++++++++ drivers/clk/baikal-t1/ccu-pll.h | 73 +++ drivers/clk/baikal-t1/clk-ccu-div.c | 522 +++++++++++++++++ drivers/clk/baikal-t1/clk-ccu-pll.c | 217 +++++++ drivers/clk/baikal-t1/common.h | 51 ++ include/dt-bindings/clock/bt1-ccu.h | 54 ++ include/dt-bindings/reset/bt1-ccu.h | 27 + 16 files changed, 2573 insertions(+) create mode 100644 Documentation/devicetree/bindings/clock/be,bt1-ccu-axi.yaml create mode 100644 Documentation/devicetree/bindings/clock/be,bt1-ccu-pll.yaml create mode 100644 Documentation/devicetree/bindings/clock/be,bt1-ccu-sys.yaml create mode 100644 drivers/clk/baikal-t1/Kconfig create mode 100644 drivers/clk/baikal-t1/Makefile create mode 100644 drivers/clk/baikal-t1/ccu-div.c create mode 100644 drivers/clk/baikal-t1/ccu-div.h create mode 100644 drivers/clk/baikal-t1/ccu-pll.c create mode 100644 drivers/clk/baikal-t1/ccu-pll.h create mode 100644 drivers/clk/baikal-t1/clk-ccu-div.c create mode 100644 drivers/clk/baikal-t1/clk-ccu-pll.c create mode 100644 drivers/clk/baikal-t1/common.h create mode 100644 include/dt-bindings/clock/bt1-ccu.h create mode 100644 include/dt-bindings/reset/bt1-ccu.h -- 2.25.1