Hi folks, here's a first attempt at cpufreq support for the Apple M1. I'd appreciate any feedback on this approach. The hardware in these SoCs is very simple: you just poke a single register to change the performance state of a CPU cluster. There's some init required on older firmware versions, but we're going to say that's the bootloader's responsibility. This keeps the driver nice and simple and generic and likely to work on future SoCs too. However, there's a catch: the memory controller config should also be modified when higher clock states are engaged on the P-cores, to get optimal performance. This series implements this using two drivers, on top of the existing cpufreq-dt infrastructure. The cpu clock driver represents the p-state switching as if it were a standard clock driver, so it can work with cpufreq-dt. To do this, it also needs access to the OPP table, so it can map the incoming clock frequences back to P-State index numbers, so that is present in the binding. This might be a bit strange, since the same OPP table is referenced by the CPUs themselves, and by the clocks driver that provides the actual switching for them... The memory controller stuff is implemented as a genpd provider that exposes two performance states that the CPU OPP tables can depend on. Unfortunately, the cpufreq path doesn't work properly for this, since the CPUs aren't typical devices participating in runtime-pm. So instead I opted to put that logic in the clock driver, which means it gets a power-domains reference to the memory controller. This required a hack to the OPP core so that it wouldn't complain about the missing parent domain when evaluating the OPPs in the context of the CPUs... The actual memory controller config is two magic numbers per performance state. I'd love to find out what they do, but this seems unlikely without docs or a deep memory performance analysis expedition... so I think we're going to have to settle for this way, at least for now. If things become better understood in the future, we can modify the binding and keep the driver backwards-compatible with old DTs at least. I did benchmark the CPU p-state switching, so the latency numbers there have been experimentally measured. The CPU capacity numbers are also based on real benchmarks (oddly enough, Dhrystone was a big outlier here that was not representative of everything else, so we didn't use it). Patches: #1: MAINTAINERS updates, split out so this can go through the SoC tree so we can spare all the subsystem maintainers the merge conflicts, since we have a bunch of other changes here going on in parallel. #2-3: DT bindings #4: The aforementioned hack for the OPP core #5: Add of_genpd_add_provider_simple_noclk() #6: Memory controller driver #7: CPU p-state clock driver #8: Add some deps for ARCH_APPLE #9: DT updates (for asahi-soc tree) Hector Martin (9): MAINTAINERS: apple: Add apple-mcc and clk-apple-cluster paths dt-bindings: memory-controller: Add apple,mcc binding dt-bindings: clock: Add apple,cluster-clk binding opp: core: Don't warn if required OPP device does not exist PM: domains: Add of_genpd_add_provider_simple_noclk() memory: apple: Add apple-mcc driver to manage MCC perf in Apple SoCs clk: apple: Add clk-apple-cluster driver to manage CPU p-states arm64: apple: Select MEMORY and APPLE_MCC arm64: apple: Add CPU frequency scaling support for t8103 .../bindings/clock/apple,cluster-clk.yaml | 115 ++++++++ .../memory-controllers/apple,mcc.yaml | 80 ++++++ .../opp/apple,mcc-operating-points.yaml | 62 +++++ MAINTAINERS | 5 + arch/arm64/Kconfig.platforms | 2 + arch/arm64/boot/dts/apple/t8103.dtsi | 255 +++++++++++++++++- drivers/base/power/domain.c | 39 ++- drivers/clk/Kconfig | 9 + drivers/clk/Makefile | 1 + drivers/clk/clk-apple-cluster.c | 184 +++++++++++++ drivers/memory/Kconfig | 9 + drivers/memory/Makefile | 1 + drivers/memory/apple-mcc.c | 130 +++++++++ drivers/opp/core.c | 5 +- include/linux/pm_domain.h | 8 + 15 files changed, 887 insertions(+), 18 deletions(-) create mode 100644 Documentation/devicetree/bindings/clock/apple,cluster-clk.yaml create mode 100644 Documentation/devicetree/bindings/memory-controllers/apple,mcc.yaml create mode 100644 Documentation/devicetree/bindings/opp/apple,mcc-operating-points.yaml create mode 100644 drivers/clk/clk-apple-cluster.c create mode 100644 drivers/memory/apple-mcc.c -- 2.33.0