The i.MX8MP has some new IPs called mixes. They are formed usually by some GPRs that can be split into different functionalities. The first example here is the audiomix which has dedicated registers that can be registered as a clock controller and some other registers that can be registered as a reset controller, plus some dedicated ones that will be registered as syscon and used by each dedicated audio IP. More mixes to be following the same structure are to come, like hdmimix, dispmix and mediamix. They will all be populated and registered by the MFD imx-mix generic driver. Changes since v2: * removed the runtime PM for now * changed the new SPDX identifiers to GPL-2.0-only * took care of the DT schema comment Abel Vesa (13): mfd: Add i.MX generic mix support Documentation: mfd: Add DT bindings for i.MX Mix arm64: dts: imx8mp: Add AIPS 4 and 5 arm64: dts: imx8mp: Add audiomix node clk: imx: gate2: Allow single bit gating clock clk: imx: pll14xx: Add the device as argument when registering clk: imx: Add helpers for passing the device as argument dt-bindings: clocks: imx8mp: Add ids for audiomix clocks clk: imx: Add audiomix clock controller support arm64: dts: imx8mp: Add audiomix clock controller node dt-bindings: reset: imx8mp: Add ids for audiomix reset reset: imx: Add audiomix reset controller support arm64: dts: imx8mp: Add audiomix reset controller node .../devicetree/bindings/mfd/fsl,imx-mix.yaml | 34 ++++ arch/arm64/boot/dts/freescale/imx8mp.dtsi | 41 ++++- drivers/clk/imx/Makefile | 2 +- drivers/clk/imx/clk-audiomix.c | 175 +++++++++++++++++++++ drivers/clk/imx/clk-gate2.c | 31 +++- drivers/clk/imx/clk-pll14xx.c | 8 +- drivers/clk/imx/clk.h | 55 ++++++- drivers/mfd/Kconfig | 11 ++ drivers/mfd/Makefile | 1 + drivers/mfd/imx-mix.c | 48 ++++++ drivers/reset/Kconfig | 7 + drivers/reset/Makefile | 1 + drivers/reset/reset-imx-audiomix.c | 117 ++++++++++++++ include/dt-bindings/clock/imx8mp-clock.h | 62 ++++++++ include/dt-bindings/reset/imx-audiomix-reset.h | 15 ++ 15 files changed, 590 insertions(+), 18 deletions(-) create mode 100644 Documentation/devicetree/bindings/mfd/fsl,imx-mix.yaml create mode 100644 drivers/clk/imx/clk-audiomix.c create mode 100644 drivers/mfd/imx-mix.c create mode 100644 drivers/reset/reset-imx-audiomix.c create mode 100644 include/dt-bindings/reset/imx-audiomix-reset.h -- 2.7.4