mbox series

[v9,0/5] Introduce SoC sleep stats driver

Message ID 1630906083-32194-1-git-send-email-mkshah@codeaurora.org
Headers show
Series Introduce SoC sleep stats driver | expand

Message

Maulik Shah Sept. 6, 2021, 5:27 a.m. UTC
Changes in v9:
- Remove soft dependency on smem module
- Return -EIO to userspace in case of error
- Make struct sleep_stats *stat a const pointer
- Remove the driver from soc_sleep_stats_driver name
- Remove offset address and directly mention the msgram address in dtsi
- Use devm_platform_get_and_ioremap_resource() to ioremap dtsi address
- Update device node name to mention aop_msgram instead rpmh-sleep-stats
- Update dtsi and documentation accordingly but retain the reviews

Changes in v8:
- Addressed bjorn's comments in driver from v7
- Update aoss_qmp device node reg size for sc7280

Changes in v7:
- Fix example in bindings documentation as per #address/size-cells = <1>.
- Add comment in driver from where 'ddr' subsystems name is read.
- Update comment in driver to s/beside/besides and others from v6.
- Rename debugfs_create_entries() from v6.
- Drop use of memcpy_fromio() to find the name.
- Use sizeof(*prv_data) in devm_kzalloc().
- Add change to define readq() if its not yet defined for compile support.
- Add wpss subsystem in the list of subsystems.
- Add module soft dependency on smem module.
- Add new change to add device node for sc7280.

Changes in v6:
- Address stephen's comments from v5 which includes below
- Pad 0 in documentation example to make address 8 digit
- define macro to calculate offset in driver
- Add appended_stats_avail to prv_data instead of using entire stats_config
- make array subsystems[] as const
- Add comment for SSR case
- Use memcpy_fromio() and devm_kcalloc() during probe
- Change file permission mode from 444 to 400 

- Address guenter's comments to add depends on QCOM_SMEM

- Add adsp_island and cdsp_island subsystems
- Use strim() to remove whitespace in stat name

Changes in v5:
- Remove underscore from node name in Documentation and DTSI change
- Remove global config from driver change

Changes in v4:
- Address bjorn's comments from v3 on change 2.
- Add bjorn's Reviewed-by on change 3 and 4.

Changes in v3:
- Address stephen's comments from v2 in change 1 and 2.
- Address bjorn's comments from v2 in change 3 and 4.
- Add Rob and bjorn's Reviewed-by on YAML change.

Changes in v2:
- Convert Documentation to YAML.
- Address stephen's comments from v1.
- Use debugfs instead of sysfs.
- Add sc7180 dts changes for sleep stats
- Add defconfig changes to enable driver
- Include subsystem stats from [1] in this single stats driver.
- Address stephen's comments from [1]
- Update cover letter inline to mention [1]

Qualcomm Technologies, Inc. (QTI)'s chipsets support SoC level low power
modes. SoCs Always On Processor/Resource Power Manager produces statistics
of the SoC sleep modes involving lowering or powering down of the rails and
the oscillator clock.

Additionally multiple subsystems present on SoC like modem, spss, adsp,
cdsp maintains their low power mode statistics in shared memory (SMEM).

Statistics includes SoC sleep mode type, number of times LPM entered, time
of last entry, exit, and accumulated sleep duration in seconds.

This series adds a driver to read the stats and export to debugfs.

[1] https://lore.kernel.org/patchwork/patch/1149381/

Mahesh Sivasubramanian (2):
  dt-bindings: Introduce SoC sleep stats bindings
  soc: qcom: Add SoC sleep stats driver

Maulik Shah (3):
  arm64: dts: qcom: sc7180: Enable SoC sleep stats
  arm64: defconfig: Enable SoC sleep stats driver
  arm64: dts: qcom: sc7280: Enable SoC sleep stats

 .../bindings/soc/qcom/soc-sleep-stats.yaml         |  48 ++++
 arch/arm64/boot/dts/qcom/sc7180.dtsi               |   7 +-
 arch/arm64/boot/dts/qcom/sc7280.dtsi               |   7 +-
 arch/arm64/configs/defconfig                       |   1 +
 drivers/soc/qcom/Kconfig                           |  10 +
 drivers/soc/qcom/Makefile                          |   1 +
 drivers/soc/qcom/soc_sleep_stats.c                 | 241 +++++++++++++++++++++
 7 files changed, 313 insertions(+), 2 deletions(-)
 create mode 100644 Documentation/devicetree/bindings/soc/qcom/soc-sleep-stats.yaml
 create mode 100644 drivers/soc/qcom/soc_sleep_stats.c

Comments

Bjorn Andersson Sept. 24, 2021, 11:23 p.m. UTC | #1
On Mon 06 Sep 00:27 CDT 2021, Maulik Shah wrote:

> From: Mahesh Sivasubramanian <msivasub@codeaurora.org>

> 

> Add device binding documentation for Qualcomm Technologies, Inc. (QTI)

> SoC sleep stats driver. The driver is used for displaying SoC sleep

> statistic maintained by Always On Processor or Resource Power Manager.

> 

> Cc: devicetree@vger.kernel.org

> Signed-off-by: Mahesh Sivasubramanian <msivasub@codeaurora.org>

> Signed-off-by: Lina Iyer <ilina@codeaurora.org>

> Signed-off-by: Maulik Shah <mkshah@codeaurora.org>

> Reviewed-by: Rob Herring <robh@kernel.org>

> Reviewed-by: Bjorn Andersson <bjorn.andersson@linaro.org>

> Reviewed-by: Stephen Boyd <swboyd@chromium.org>

> ---

>  .../bindings/soc/qcom/soc-sleep-stats.yaml         | 48 ++++++++++++++++++++++

>  1 file changed, 48 insertions(+)

>  create mode 100644 Documentation/devicetree/bindings/soc/qcom/soc-sleep-stats.yaml

> 

> diff --git a/Documentation/devicetree/bindings/soc/qcom/soc-sleep-stats.yaml b/Documentation/devicetree/bindings/soc/qcom/soc-sleep-stats.yaml

> new file mode 100644

> index 0000000..4161156

> --- /dev/null

> +++ b/Documentation/devicetree/bindings/soc/qcom/soc-sleep-stats.yaml

> @@ -0,0 +1,48 @@

> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)

> +%YAML 1.2

> +---

> +$id: http://devicetree.org/schemas/soc/qcom/soc-sleep-stats.yaml#

> +$schema: http://devicetree.org/meta-schemas/core.yaml#

> +

> +title: Qualcomm Technologies, Inc. (QTI) SoC sleep stats bindings

> +

> +maintainers:

> +  - Maulik Shah <mkshah@codeaurora.org>

> +  - Lina Iyer <ilina@codeaurora.org>


Lina's address is no longer valid.

> +

> +description:

> +  Always On Processor/Resource Power Manager maintains statistics of the SoC

> +  sleep modes involving powering down of the rails and oscillator clock.

> +

> +  Statistics includes SoC sleep mode type, number of times low power mode were

> +  entered, time of last entry, time of last exit and accumulated sleep duration.

> +

> +properties:

> +  compatible:

> +    enum:

> +      - qcom,rpmh-sleep-stats

> +      - qcom,rpm-sleep-stats

> +

> +  reg:

> +    maxItems: 1

> +

> +required:

> +  - compatible

> +  - reg

> +

> +additionalProperties: false

> +

> +examples:

> +  # Example of rpmh sleep stats

> +  - |

> +    aop_msgram@c3f0048 {

> +      compatible = "qcom,rpmh-sleep-stats";

> +      reg = <0x0c3f0048 0x400>;


As I tested this series I did find it quite odd that the start address
of this block is $48 bytes into a page and still the length is an even
$400.

Is there any single platform where qcom,rpmh-sleep-stats doesn't start
at an offset of $48 from the beginning of its msgram? Could we move this
number to the driver?

Regards,
Bjorn

> +    };

> +  # Example of rpm sleep stats

> +  - |

> +    rpm_msgram@4690000 {

> +      compatible = "qcom,rpm-sleep-stats";

> +      reg = <0x04690000 0x400>;

> +    };

> +...

> -- 

> QUALCOMM INDIA, on behalf of Qualcomm Innovation Center, Inc. is a member

> of Code Aurora Forum, hosted by The Linux Foundation

>
Maulik Shah Oct. 5, 2021, 8:53 a.m. UTC | #2
Hi,

On 9/25/2021 4:53 AM, Bjorn Andersson wrote:
> On Mon 06 Sep 00:27 CDT 2021, Maulik Shah wrote:

> 

>> From: Mahesh Sivasubramanian <msivasub@codeaurora.org>

>>

>> Add device binding documentation for Qualcomm Technologies, Inc. (QTI)

>> SoC sleep stats driver. The driver is used for displaying SoC sleep

>> statistic maintained by Always On Processor or Resource Power Manager.

>>

>> Cc: devicetree@vger.kernel.org

>> Signed-off-by: Mahesh Sivasubramanian <msivasub@codeaurora.org>

>> Signed-off-by: Lina Iyer <ilina@codeaurora.org>

>> Signed-off-by: Maulik Shah <mkshah@codeaurora.org>

>> Reviewed-by: Rob Herring <robh@kernel.org>

>> Reviewed-by: Bjorn Andersson <bjorn.andersson@linaro.org>

>> Reviewed-by: Stephen Boyd <swboyd@chromium.org>

>> ---

>>   .../bindings/soc/qcom/soc-sleep-stats.yaml         | 48 ++++++++++++++++++++++

>>   1 file changed, 48 insertions(+)

>>   create mode 100644 Documentation/devicetree/bindings/soc/qcom/soc-sleep-stats.yaml

>>

>> diff --git a/Documentation/devicetree/bindings/soc/qcom/soc-sleep-stats.yaml b/Documentation/devicetree/bindings/soc/qcom/soc-sleep-stats.yaml

>> new file mode 100644

>> index 0000000..4161156

>> --- /dev/null

>> +++ b/Documentation/devicetree/bindings/soc/qcom/soc-sleep-stats.yaml

>> @@ -0,0 +1,48 @@

>> +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)

>> +%YAML 1.2

>> +---

>> +$id: http://devicetree.org/schemas/soc/qcom/soc-sleep-stats.yaml#

>> +$schema: http://devicetree.org/meta-schemas/core.yaml#

>> +

>> +title: Qualcomm Technologies, Inc. (QTI) SoC sleep stats bindings

>> +

>> +maintainers:

>> +  - Maulik Shah <mkshah@codeaurora.org>

>> +  - Lina Iyer <ilina@codeaurora.org>

> 

> Lina's address is no longer valid.


Removed in v10.

> 

>> +

>> +description:

>> +  Always On Processor/Resource Power Manager maintains statistics of the SoC

>> +  sleep modes involving powering down of the rails and oscillator clock.

>> +

>> +  Statistics includes SoC sleep mode type, number of times low power mode were

>> +  entered, time of last entry, time of last exit and accumulated sleep duration.

>> +

>> +properties:

>> +  compatible:

>> +    enum:

>> +      - qcom,rpmh-sleep-stats

>> +      - qcom,rpm-sleep-stats

>> +

>> +  reg:

>> +    maxItems: 1

>> +

>> +required:

>> +  - compatible

>> +  - reg

>> +

>> +additionalProperties: false

>> +

>> +examples:

>> +  # Example of rpmh sleep stats

>> +  - |

>> +    aop_msgram@c3f0048 {

>> +      compatible = "qcom,rpmh-sleep-stats";

>> +      reg = <0x0c3f0048 0x400>;

> 

> As I tested this series I did find it quite odd that the start address

> of this block is $48 bytes into a page and still the length is an even

> $400.

> 

> Is there any single platform where qcom,rpmh-sleep-stats doesn't start

> at an offset of $48 from the beginning of its msgram? Could we move this

> number to the driver?

> 

> Regards,

> Bjorn


Sure, i have moved 0x48 into driver in v10.

Thanks,
Maulik

> 

>> +    };

>> +  # Example of rpm sleep stats

>> +  - |

>> +    rpm_msgram@4690000 {

>> +      compatible = "qcom,rpm-sleep-stats";

>> +      reg = <0x04690000 0x400>;

>> +    };

>> +...

>> -- 

>> QUALCOMM INDIA, on behalf of Qualcomm Innovation Center, Inc. is a member

>> of Code Aurora Forum, hosted by The Linux Foundation

>>


-- 
QUALCOMM INDIA, on behalf of Qualcomm Innovation Center, Inc. is a 
member of Code Aurora Forum, hosted by The Linux Foundation