aboutsummaryrefslogtreecommitdiffstats
path: root/Documentation/devicetree/bindings/opp/opp-v2-qcom-adreno.yaml
blob: a27ba7b663d456f964628a91a661b51a684de1be (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
%YAML 1.2
---
$id: http://devicetree.org/schemas/opp/opp-v2-qcom-adreno.yaml#
$schema: http://devicetree.org/meta-schemas/core.yaml#

title: Qualcomm Adreno compatible OPP supply

description:
  Adreno GPUs present in Qualcomm's Snapdragon chipsets uses an OPP specific
  ACD related information tailored for the specific chipset. This binding
  provides the information needed to describe such a hardware value.

maintainers:
  - Rob Clark <robdclark@gmail.com>

allOf:
  - $ref: opp-v2-base.yaml#

properties:
  compatible:
    contains:
      const: operating-points-v2-adreno

patternProperties:
  '^opp-[0-9]+$':
    type: object
    additionalProperties: false

    properties:
      opp-hz: true

      opp-level: true

      opp-peak-kBps: true

      opp-supported-hw: true

      qcom,opp-acd-level:
        description: |
          A positive value representing the ACD (Adaptive Clock Distribution,
          a fancy name for clk throttling during voltage droop) level associated
          with this OPP node. This value is shared to a co-processor inside GPU
          (called Graphics Management Unit a.k.a GMU) during wake up. It may not
          be present for some OPPs and GMU will disable ACD while transitioning
          to that OPP. This value encodes a voltage threshold, delay cycles &
          calibration margins which are identified by characterization of the
          SoC. So, it doesn't have any unit. This data is passed to GMU firmware
          via 'HFI_H2F_MSG_ACD' packet.
        $ref: /schemas/types.yaml#/definitions/uint32

    required:
      - opp-hz
      - opp-level

required:
  - compatible

additionalProperties: false

examples:
  - |
    #include <dt-bindings/power/qcom-rpmpd.h>

    gpu_opp_table: opp-table {
        compatible = "operating-points-v2-adreno", "operating-points-v2";

        opp-687000000 {
            opp-hz = /bits/ 64 <687000000>;
            opp-level = <RPMH_REGULATOR_LEVEL_SVS_L1>;
            opp-peak-kBps = <8171875>;
            qcom,opp-acd-level = <0x882e5ffd>;
        };

        opp-550000000 {
            opp-hz = /bits/ 64 <550000000>;
            opp-level = <RPMH_REGULATOR_LEVEL_SVS>;
            opp-peak-kBps = <6074219>;
            qcom,opp-acd-level = <0xc0285ffd>;
        };

        opp-390000000 {
            opp-hz = /bits/ 64 <390000000>;
            opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS>;
            opp-peak-kBps = <3000000>;
            qcom,opp-acd-level = <0xc0285ffd>;
        };

        opp-300000000 {
            opp-hz = /bits/ 64 <300000000>;
            opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS_D1>;
            opp-peak-kBps = <2136719>;
            /* Intentionally left out qcom,opp-acd-level property here */
        };

    };