From patchwork Thu Apr 12 11:14:05 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Ulf Hansson X-Patchwork-Id: 133238 Delivered-To: patches@linaro.org Received: by 10.46.84.29 with SMTP id i29csp1573354ljb; Thu, 12 Apr 2018 04:14:38 -0700 (PDT) X-Received: by 10.46.152.203 with SMTP id s11mr379099ljj.92.1523531678641; Thu, 12 Apr 2018 04:14:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1523531678; cv=none; d=google.com; s=arc-20160816; b=ZMBbHD5U5ji72kuWrpUeYMQWCUHqC37SdHia8BHFtVWsYHpcYFv16Kb4nOYN0QmzHO WunkZ/z2+5eBDXBzanC2QQD7A71/8dsTN0GYb/yjvjClks+yPz7H/7t4SqDdDq5FG+bn E2ohaCwsWiizWypDgqovieyrAqgMQ7/aoxwPFb29nC06HPT3eBQh54+nMzpFLwJWb+R7 IAaFXaqCkcCmSf4KJpJx435Z9bkrgk8LrsHJEt8SI+pj3tEP0CX93PwexYbGlX9oGIkX IMTQP6FT+s4LcHneKZVCfQBukdLOCvlQiuA5nUBrxmSwusf9SIIuzVvdvMo8Sm1mXC9x 5wYA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=message-id:date:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=0D27DJ4jjGe9QFOF06ej6zIiXeCa8jlMlJO/f1MEKO0=; b=FsDJ680rmxl0LoLmH2iU9cALpoxc4B8o71TMTL1/afq0V0Rdu5yv3Ke/vqv4r/rJJM AIpAs0MD/eXeYYaDjYkj0eZL7OMH/Cey7klVCrB7zU8Z5f//5Ak0v+9KG8bMKsAU543b DKrrqsMy9w3ZKJEtk96vSy4sOPqV2E/7NoFr4SbOL1PYWsbOLr+ksvrL3dRMwNbKPlIe FdCGiI+c6vBKUnHWdgw1Zkxs4Vx99GbQBu2IZwmVLIf49W5EJGX+P+uFRMNC+AO6go8H 2LyKvb0P2rvau0t87MlDFWjwaKYMH9KIJbcVzZJIcOar/h6QUA0pci+W7Dmn9TULtYXy minA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=TkEWTH1d; spf=pass (google.com: domain of ulf.hansson@linaro.org designates 209.85.220.65 as permitted sender) smtp.mailfrom=ulf.hansson@linaro.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from mail-sor-f65.google.com (mail-sor-f65.google.com. [209.85.220.65]) by mx.google.com with SMTPS id v2sor898127ljj.45.2018.04.12.04.14.38 for (Google Transport Security); Thu, 12 Apr 2018 04:14:38 -0700 (PDT) Received-SPF: pass (google.com: domain of ulf.hansson@linaro.org designates 209.85.220.65 as permitted sender) client-ip=209.85.220.65; Authentication-Results: mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=TkEWTH1d; spf=pass (google.com: domain of ulf.hansson@linaro.org designates 209.85.220.65 as permitted sender) smtp.mailfrom=ulf.hansson@linaro.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id; bh=0D27DJ4jjGe9QFOF06ej6zIiXeCa8jlMlJO/f1MEKO0=; b=TkEWTH1dqlzNW9/9hYDNABU5yz31lOhgVpFMg5YgYrCrAR5aM3k9gJV3Jq14VZvWDi S3zzj7J1InEPESbo5t0qtRRrNxe7/X0YEait7umLixjbXHZKpyz5yUwYDq2rjspdhYLe 6EdFzpTqL4wY9JuBcIqqZf6YmNQovhA9RgrHM= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=0D27DJ4jjGe9QFOF06ej6zIiXeCa8jlMlJO/f1MEKO0=; b=klbaIlglLQKpMV0uMUoQjloktciYPI3RpWQ5UZNj965ObQeMIy+7tr9gi1KMUH2DBP OjGrHBSl1FUijjJkgFtLVNJfDQj1q8Lfps7X0GBOnS0gQ1lPfr1xzZxB7YqQS90hy7PD gjF/hH7sMuain3MWvCNRp8z929xbFThhBboZiBUtbEsNn9WpIRjcXKbrO9OVtvsAmiMY AsaBjx5EyF4lyN/4qcy3c/ss7m2maB+jiTukYUfG4nI7AHjoxq5ssId8W4nSyT/FASVw v94UwaZJsh/Vft3Gdt92Fr0V09NXF8gXWT49oHvB6rHtWONdIz5CLWS+NOy+8ezDvxgv 1osA== X-Gm-Message-State: ALQs6tBBZJSKa8wR0UPLvACsEajhrLmes592Sfcmf9ytdDrQ7DIOByHJ B+apzad1zsiOV0tRDeWtBIPegwqo X-Google-Smtp-Source: AIpwx4/RQc0AIxBemvBq4HPM4h/G5k+53adsm0KIPiByjIS4/mvl3DNjnnIy8yhc1X+N4uQyAhkQ0g== X-Received: by 10.46.144.2 with SMTP id h2mr367333ljg.37.1523531678236; Thu, 12 Apr 2018 04:14:38 -0700 (PDT) Return-Path: Received: from localhost.localdomain (h-158-174-22-210.NA.cust.bahnhof.se. [158.174.22.210]) by smtp.gmail.com with ESMTPSA id r29sm543187lje.72.2018.04.12.04.14.36 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Thu, 12 Apr 2018 04:14:37 -0700 (PDT) From: Ulf Hansson To: "Rafael J . Wysocki" , Sudeep Holla , Lorenzo Pieralisi , Mark Rutland , linux-pm@vger.kernel.org Cc: Kevin Hilman , Lina Iyer , Lina Iyer , Ulf Hansson , Rob Herring , Daniel Lezcano , Thomas Gleixner , Vincent Guittot , Stephen Boyd , Juri Lelli , Geert Uytterhoeven , linux-arm-kernel@lists.infradead.org, linux-arm-msm@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v7 00/26] PM / Domains: Support hierarchical CPU arrangement (PSCI/ARM) Date: Thu, 12 Apr 2018 13:14:05 +0200 Message-Id: <1523531671-27491-1-git-send-email-ulf.hansson@linaro.org> X-Mailer: git-send-email 2.7.4 Changes in v7: - Addressed comments concerning the PSCI changes from Mark Rutland, which moves the psci firmware driver to a new firmware subdir and change to force PSCI PC mode during boot to cope with kexec'ed booted kernels. - Added some maintainers in cc for the timer/nohz patches. - Minor update to the new genpd governor, taking into account the state's poweroff latency while validating the sleep duration time. - Addressed a problem pointed out by Geert Uytterhoeven, around calling pm_runtime_get|put() for CPUs that has not been attached to a CPU PM domain. - Re-based on Linus' latest master. This series is a re-worked version from Lina Iyer's two series [1] that got posted more than a year ago by now. I have picked up the series and done a significant re-work of it and here's the result. All patches have been changed, some have been dropped, some are entirely new. For those few changes that are kind of similar, I have kept Lina's authorship, the rest are now authored by me. - Lina (or anybody else for that matter) please tell if you think I should change, in regards to what tag/authorship should be for each commit! Some background: Overall this series have been discussed over years at various Linux conferences and LKML, although let me give a brief introduction and then the rest can be read in each changelog. For ARM, the PSCI firmware interface may be managing the power to the CPUs. Depending on the SoC, CPUs may also be arranged in hierarchical manner, which could add another level of complexity from a CPU idle management point of view. PSCI v1.0+ adds support for the so called OS initiated CPU suspend mode, which enables a more fine grained method, allowing Linux to get more control, in regards to being energy efficient. This is typically useful for these kind of complex battery driven platforms. Now, in principle what is missing today around CPU idle management for these SoCs arranging CPUs in a hierarchical manner, that is what this series intends to address. I could potentially have split the series into two parts, but for completeness I decided to post it as one. Please tell if want me to change! - The first part are changes to generic PM code (genpd, cpu_pm and timers): Patch 1 -> Patch 9. - The second part, which depends on the first, are changes specific to PSCI/ARM64 (psci, of, arm64): Patch 10 -> Patch 26. The series is based on Linus' master as of today. The code has been tested on a QCOM 410c dragonboard and I except that test coverage should be increased by some more boards shortly (for ARM64 with PSCI OSI support - only a few DT changes are needed). You may find the code at: git.linaro.org/people/ulf.hansson/linux-pm.git next If for some reason you want to have a look at the previous version, it's available at a branch, next_v6, in the same git as above. Kind regards Ulf Hansson [1] https://lwn.net/Articles/716300/ https://www.spinics.net/lists/arm-kernel/msg566200.html Lina Iyer (6): PM / Domains: Add generic data pointer to genpd_power_state struct timer: Export next wakeup time of a CPU dt: psci: Update DT bindings to support hierarchical PSCI states cpuidle: dt: Support hierarchical CPU idle states drivers: firmware: psci: Support hierarchical CPU idle states arm64: dts: Convert to the hierarchical CPU topology layout for MSM8916 Ulf Hansson (20): PM / Domains: Don't treat zero found compatible idle states as an error PM / Domains: Deal with multiple states but no governor in genpd PM / Domains: Add support for CPU devices to genpd PM / Domains: Add helper functions to attach/detach CPUs to/from genpd PM / Domains: Add genpd governor for CPUs PM / Domains: Extend genpd CPU governor to cope with QoS constraints kernel/cpu_pm: Manage runtime PM in the idle path for CPUs of: base: Add of_get_cpu_state_node() to get idle states for a CPU node drivers: firmware: psci: Move psci to separate directory MAINTAINERS: Update files for PSCI drivers: firmware: psci: Split psci_dt_cpu_init_idle() drivers: firmware: psci: Simplify error path of psci_dt_init() drivers: firmware: psci: Announce support for OS initiated suspend mode drivers: firmware: psci: Prepare to use OS initiated suspend mode drivers: firmware: psci: Share a few internal PSCI functions drivers: firmware: psci: Add support for PM domains using genpd drivers: firmware: psci: Introduce psci_dt_topology_init() drivers: firmware: psci: Try to attach CPU devices to their PM domains drivers: firmware: psci: Deal with CPU hotplug when using OSI mode arm64: kernel: Respect the hierarchical CPU topology in DT for PSCI Documentation/devicetree/bindings/arm/psci.txt | 156 +++++++++++++++++++++ MAINTAINERS | 2 +- arch/arm64/boot/dts/qcom/msm8916.dtsi | 53 +++++++- arch/arm64/kernel/setup.c | 3 + drivers/base/power/domain.c | 156 ++++++++++++++++++++- drivers/base/power/domain_governor.c | 67 ++++++++- drivers/cpuidle/dt_idle_states.c | 5 +- drivers/firmware/Kconfig | 15 +-- drivers/firmware/Makefile | 3 +- drivers/firmware/psci/Kconfig | 13 ++ drivers/firmware/psci/Makefile | 4 + drivers/firmware/{ => psci}/psci.c | 174 ++++++++++++++++++------ drivers/firmware/psci/psci.h | 19 +++ drivers/firmware/{ => psci}/psci_checker.c | 0 drivers/firmware/psci/psci_pm_domain.c | 180 +++++++++++++++++++++++++ drivers/of/base.c | 35 +++++ include/linux/of.h | 8 ++ include/linux/pm_domain.h | 16 +++ include/linux/psci.h | 2 + include/linux/tick.h | 10 ++ include/uapi/linux/psci.h | 5 + kernel/cpu_pm.c | 11 ++ kernel/time/tick-sched.c | 11 ++ 23 files changed, 878 insertions(+), 70 deletions(-) create mode 100644 drivers/firmware/psci/Kconfig create mode 100644 drivers/firmware/psci/Makefile rename drivers/firmware/{ => psci}/psci.c (83%) create mode 100644 drivers/firmware/psci/psci.h rename drivers/firmware/{ => psci}/psci_checker.c (100%) create mode 100644 drivers/firmware/psci/psci_pm_domain.c -- 2.7.4