~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/devicetree/bindings/thermal/nvidia,tegra124-soctherm.yaml

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /Documentation/devicetree/bindings/thermal/nvidia,tegra124-soctherm.yaml (Architecture i386) and /Documentation/devicetree/bindings/thermal/nvidia,tegra124-soctherm.yaml (Architecture alpha)


  1 # SPDX-License-Identifier: (GPL-2.0-only OR BS      1 # SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
  2 %YAML 1.2                                           2 %YAML 1.2
  3 ---                                                 3 ---
  4 $id: http://devicetree.org/schemas/thermal/nvi      4 $id: http://devicetree.org/schemas/thermal/nvidia,tegra124-soctherm.yaml#
  5 $schema: http://devicetree.org/meta-schemas/co      5 $schema: http://devicetree.org/meta-schemas/core.yaml#
  6                                                     6 
  7 title: NVIDIA Tegra124 SOCTHERM Thermal Manage      7 title: NVIDIA Tegra124 SOCTHERM Thermal Management System
  8                                                     8 
  9 maintainers:                                        9 maintainers:
 10   - Thierry Reding <thierry.reding@gmail.com>       10   - Thierry Reding <thierry.reding@gmail.com>
 11   - Jon Hunter <jonathanh@nvidia.com>               11   - Jon Hunter <jonathanh@nvidia.com>
 12                                                    12 
 13 description: The SOCTHERM IP block contains th     13 description: The SOCTHERM IP block contains thermal sensors, support for
 14   polled or interrupt-based thermal monitoring     14   polled or interrupt-based thermal monitoring, CPU and GPU throttling based
 15   on temperature trip points, and handling ext     15   on temperature trip points, and handling external overcurrent notifications.
 16   It is also used to manage emergency shutdown     16   It is also used to manage emergency shutdown in an overheating situation.
 17                                                    17 
 18 properties:                                        18 properties:
 19   compatible:                                      19   compatible:
 20     enum:                                          20     enum:
 21       - nvidia,tegra124-soctherm                   21       - nvidia,tegra124-soctherm
 22       - nvidia,tegra132-soctherm                   22       - nvidia,tegra132-soctherm
 23       - nvidia,tegra210-soctherm                   23       - nvidia,tegra210-soctherm
 24                                                    24 
 25   reg:                                             25   reg:
 26     maxItems: 2                                    26     maxItems: 2
 27                                                    27 
 28   reg-names:                                       28   reg-names:
 29     maxItems: 2                                    29     maxItems: 2
 30                                                    30 
 31   interrupts:                                      31   interrupts:
 32     items:                                         32     items:
 33       - description: module interrupt              33       - description: module interrupt
 34       - description: EDP interrupt                 34       - description: EDP interrupt
 35                                                    35 
 36   interrupt-names:                                 36   interrupt-names:
 37     items:                                         37     items:
 38       - const: thermal                             38       - const: thermal
 39       - const: edp                                 39       - const: edp
 40                                                    40 
 41   clocks:                                          41   clocks:
 42     items:                                         42     items:
 43       - description: thermal sensor clock          43       - description: thermal sensor clock
 44       - description: module clock                  44       - description: module clock
 45                                                    45 
 46   clock-names:                                     46   clock-names:
 47     items:                                         47     items:
 48       - const: tsensor                             48       - const: tsensor
 49       - const: soctherm                            49       - const: soctherm
 50                                                    50 
 51   resets:                                          51   resets:
 52     items:                                         52     items:
 53       - description: module reset                  53       - description: module reset
 54                                                    54 
 55   reset-names:                                     55   reset-names:
 56     items:                                         56     items:
 57       - const: soctherm                            57       - const: soctherm
 58                                                    58 
 59   "#thermal-sensor-cells":                         59   "#thermal-sensor-cells":
 60     const: 1                                       60     const: 1
 61                                                    61 
 62   throttle-cfgs:                                   62   throttle-cfgs:
 63     $ref: thermal-cooling-devices.yaml             63     $ref: thermal-cooling-devices.yaml
 64     description: A sub-node which is a contain     64     description: A sub-node which is a container of configuration for each
 65       hardware throttle events. These events c     65       hardware throttle events. These events can be set as cooling devices.
 66       Throttle event sub-nodes must be named a     66       Throttle event sub-nodes must be named as "light" or "heavy".
 67     unevaluatedProperties: false                   67     unevaluatedProperties: false
 68     patternProperties:                             68     patternProperties:
 69       "^(light|heavy|oc1)$":                       69       "^(light|heavy|oc1)$":
 70         type: object                               70         type: object
 71         additionalProperties: false                71         additionalProperties: false
 72                                                    72 
 73         properties:                                73         properties:
 74           "#cooling-cells":                        74           "#cooling-cells":
 75             const: 2                               75             const: 2
 76                                                    76 
 77           nvidia,priority:                         77           nvidia,priority:
 78             $ref: /schemas/types.yaml#/definit     78             $ref: /schemas/types.yaml#/definitions/uint32
 79             minimum: 1                             79             minimum: 1
 80             maximum: 100                           80             maximum: 100
 81             description: Each throttles has it     81             description: Each throttles has its own throttle settings, so the
 82               SW need to set priorities for va     82               SW need to set priorities for various throttle, the HW arbiter
 83               can select the final throttle se     83               can select the final throttle settings. Bigger value indicates
 84               higher priority, In general, hig     84               higher priority, In general, higher priority translates to lower
 85               target frequency. SW needs to en     85               target frequency. SW needs to ensure that critical thermal
 86               alarms are given higher priority     86               alarms are given higher priority, and ensure that there is no
 87               race if priority of two vectors      87               race if priority of two vectors is set to the same value.
 88                                                    88 
 89           nvidia,cpu-throt-percent:                89           nvidia,cpu-throt-percent:
 90             description: This property is for      90             description: This property is for Tegra124 and Tegra210. It is the
 91               throttling depth of pulse skippe     91               throttling depth of pulse skippers, it's the percentage
 92               throttling.                          92               throttling.
 93             minimum: 0                             93             minimum: 0
 94             maximum: 100                           94             maximum: 100
 95                                                    95 
 96           nvidia,cpu-throt-level:                  96           nvidia,cpu-throt-level:
 97             $ref: /schemas/types.yaml#/definit     97             $ref: /schemas/types.yaml#/definitions/uint32
 98             description: This property is only     98             description: This property is only for Tegra132, it is the level
 99               of pulse skippers, which used to     99               of pulse skippers, which used to throttle clock frequencies. It
100               indicates cpu clock throttling d    100               indicates cpu clock throttling depth, and the depth can be
101               programmed.                         101               programmed.
102             enum:                                 102             enum:
103               # none (TEGRA_SOCTHERM_THROT_LEV    103               # none (TEGRA_SOCTHERM_THROT_LEVEL_NONE)
104               - 0                                 104               - 0
105               # low (TEGRA_SOCTHERM_THROT_LEVE    105               # low (TEGRA_SOCTHERM_THROT_LEVEL_LOW)
106               - 1                                 106               - 1
107               # medium (TEGRA_SOCTHERM_THROT_L    107               # medium (TEGRA_SOCTHERM_THROT_LEVEL_MED)
108               - 2                                 108               - 2
109               # high (TEGRA_SOCTHERM_THROT_LEV    109               # high (TEGRA_SOCTHERM_THROT_LEVEL_HIGH)
110               - 3                                 110               - 3
111                                                   111 
112           nvidia,gpu-throt-level:                 112           nvidia,gpu-throt-level:
113             $ref: /schemas/types.yaml#/definit    113             $ref: /schemas/types.yaml#/definitions/uint32
114             description: This property is for     114             description: This property is for Tegra124 and Tegra210. It is the
115               level of pulse skippers, which u    115               level of pulse skippers, which used to throttle clock
116               frequencies. It indicates gpu cl    116               frequencies. It indicates gpu clock throttling depth and can be
117               programmed to any of the followi    117               programmed to any of the following values which represent a
118               throttling percentage.              118               throttling percentage.
119             enum:                                 119             enum:
120               # none (0%, TEGRA_SOCTHERM_THROT    120               # none (0%, TEGRA_SOCTHERM_THROT_LEVEL_NONE)
121               - 0                                 121               - 0
122               # low (50%, TEGRA_SOCTHERM_THROT    122               # low (50%, TEGRA_SOCTHERM_THROT_LEVEL_LOW)
123               - 1                                 123               - 1
124               # medium (75%, TEGRA_SOCTHERM_TH    124               # medium (75%, TEGRA_SOCTHERM_THROT_LEVEL_MED)
125               - 2                                 125               - 2
126               # high (85%, TEGRA_SOCTHERM_THRO    126               # high (85%, TEGRA_SOCTHERM_THROT_LEVEL_HIGH)
127               - 3                                 127               - 3
128                                                   128 
129           # optional                              129           # optional
130           # Tegra210 specific and valid only f    130           # Tegra210 specific and valid only for OCx throttle events
131           nvidia,count-threshold:                 131           nvidia,count-threshold:
132             $ref: /schemas/types.yaml#/definit    132             $ref: /schemas/types.yaml#/definitions/uint32
133             description: Specifies the number     133             description: Specifies the number of OC events that are required
134               for triggering an interrupt. Int    134               for triggering an interrupt. Interrupts are not triggered if the
135               property is missing. A value of     135               property is missing. A value of 0 will interrupt on every OC
136               alarm.                              136               alarm.
137                                                   137 
138           nvidia,polarity-active-low:             138           nvidia,polarity-active-low:
139             $ref: /schemas/types.yaml#/definit    139             $ref: /schemas/types.yaml#/definitions/flag
140             description: Configures the polari    140             description: Configures the polarity of the OC alaram signal. If
141               present, this means assert low,     141               present, this means assert low, otherwise assert high.
142                                                   142 
143           nvidia,alarm-filter:                    143           nvidia,alarm-filter:
144             $ref: /schemas/types.yaml#/definit    144             $ref: /schemas/types.yaml#/definitions/uint32
145             description: Number of clocks to f    145             description: Number of clocks to filter event. When the filter
146               expires (which means the OC even    146               expires (which means the OC event has not occurred for a long
147               time), the counter is cleared an    147               time), the counter is cleared and filter is rearmed.
148             default: 0                            148             default: 0
149                                                   149 
150           nvidia,throttle-period-us:              150           nvidia,throttle-period-us:
151             description: Specifies the number     151             description: Specifies the number of microseconds for which
152               throttling is engaged after the     152               throttling is engaged after the OC event is deasserted.
153             default: 0                            153             default: 0
154                                                   154 
155   # optional                                      155   # optional
156   nvidia,thermtrips:                              156   nvidia,thermtrips:
157     $ref: /schemas/types.yaml#/definitions/uin    157     $ref: /schemas/types.yaml#/definitions/uint32-matrix
158     description: |                                158     description: |
159       When present, this property specifies th    159       When present, this property specifies the temperature at which the
160       SOCTHERM hardware will assert the therma    160       SOCTHERM hardware will assert the thermal trigger signal to the Power
161       Management IC, which can be configured t    161       Management IC, which can be configured to reset or shutdown the device.
162       It is an array of pairs where each pair     162       It is an array of pairs where each pair represents a tsensor ID followed
163       by a temperature in milli Celcius. In th    163       by a temperature in milli Celcius. In the absence of this property the
164       critical trip point will be used for the    164       critical trip point will be used for thermtrip temperature.
165                                                   165 
166       Note:                                       166       Note:
167       - the "critical" type trip points will b    167       - the "critical" type trip points will be used to set the temperature at
168         which the SOCTHERM hardware will asser    168         which the SOCTHERM hardware will assert a thermal trigger if the
169         "nvidia,thermtrips" property is missin    169         "nvidia,thermtrips" property is missing.  When the thermtrips property
170         is present, the breach of a critical t    170         is present, the breach of a critical trip point is reported back to
171         the thermal framework to implement sof    171         the thermal framework to implement software shutdown.
172                                                   172 
173       - the "hot" type trip points will be set    173       - the "hot" type trip points will be set to SOCTHERM hardware as the
174         throttle temperature.  Once the temper    174         throttle temperature.  Once the temperature of this thermal zone is
175         higher than it, it will trigger the HW    175         higher than it, it will trigger the HW throttle event.
176     items:                                        176     items:
177       items:                                      177       items:
178         - description: sensor ID                  178         - description: sensor ID
179           oneOf:                                  179           oneOf:
180             - description: CPU sensor             180             - description: CPU sensor
181               const: 0                            181               const: 0
182             - description: MEM sensor             182             - description: MEM sensor
183               const: 1                            183               const: 1
184             - description: GPU sensor             184             - description: GPU sensor
185               const: 2                            185               const: 2
186             - description: PLLX sensor            186             - description: PLLX sensor
187               const: 3                            187               const: 3
188         - description: temperature threshold (    188         - description: temperature threshold (in millidegree Celsius)
189                                                   189 
190 required:                                         190 required:
191   - compatible                                    191   - compatible
192   - reg                                           192   - reg
193   - reg-names                                     193   - reg-names
194   - interrupts                                    194   - interrupts
195   - interrupt-names                               195   - interrupt-names
196   - clocks                                        196   - clocks
197   - clock-names                                   197   - clock-names
198   - resets                                        198   - resets
199   - reset-names                                   199   - reset-names
200                                                   200 
201 allOf:                                            201 allOf:
202   - $ref: thermal-sensor.yaml                     202   - $ref: thermal-sensor.yaml
203   - if:                                           203   - if:
204       properties:                                 204       properties:
205         compatible:                               205         compatible:
206           contains:                               206           contains:
207             enum:                                 207             enum:
208               - nvidia,tegra124-soctherm          208               - nvidia,tegra124-soctherm
209               - nvidia,tegra210-soctherm          209               - nvidia,tegra210-soctherm
210     then:                                         210     then:
211       properties:                                 211       properties:
212         reg:                                      212         reg:
213           items:                                  213           items:
214             - description: SOCTHERM register s    214             - description: SOCTHERM register set
215             - description: clock and reset con    215             - description: clock and reset controller registers
216                                                   216 
217         reg-names:                                217         reg-names:
218           items:                                  218           items:
219             - const: soctherm-reg                 219             - const: soctherm-reg
220             - const: car-reg                      220             - const: car-reg
221                                                   221 
222     else:                                         222     else:
223       properties:                                 223       properties:
224         reg:                                      224         reg:
225           items:                                  225           items:
226             - description: SOCTHERM register s    226             - description: SOCTHERM register set
227             - description: CCROC registers        227             - description: CCROC registers
228                                                   228 
229         reg-names:                                229         reg-names:
230           items:                                  230           items:
231             - const: soctherm-reg                 231             - const: soctherm-reg
232             - const: ccroc-reg                    232             - const: ccroc-reg
233                                                   233 
234 additionalProperties: false                       234 additionalProperties: false
235                                                   235 
236 examples:                                         236 examples:
237   - |                                             237   - |
238     #include <dt-bindings/clock/tegra124-car.h    238     #include <dt-bindings/clock/tegra124-car.h>
239     #include <dt-bindings/interrupt-controller    239     #include <dt-bindings/interrupt-controller/arm-gic.h>
240     #include <dt-bindings/thermal/tegra124-soc    240     #include <dt-bindings/thermal/tegra124-soctherm.h>
241                                                   241 
242     soctherm@700e2000 {                           242     soctherm@700e2000 {
243         compatible = "nvidia,tegra124-soctherm    243         compatible = "nvidia,tegra124-soctherm";
244         reg = <0x700e2000 0x600>, /* SOC_THERM    244         reg = <0x700e2000 0x600>, /* SOC_THERM reg_base */
245               <0x60006000 0x400>; /* CAR reg_b    245               <0x60006000 0x400>; /* CAR reg_base */
246         reg-names = "soctherm-reg", "car-reg";    246         reg-names = "soctherm-reg", "car-reg";
247         interrupts = <GIC_SPI 48 IRQ_TYPE_LEVE    247         interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>,
248                      <GIC_SPI 51 IRQ_TYPE_LEVE    248                      <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>;
249         interrupt-names = "thermal", "edp";       249         interrupt-names = "thermal", "edp";
250         clocks = <&tegra_car TEGRA124_CLK_TSEN    250         clocks = <&tegra_car TEGRA124_CLK_TSENSOR>,
251                  <&tegra_car TEGRA124_CLK_SOC_    251                  <&tegra_car TEGRA124_CLK_SOC_THERM>;
252         clock-names = "tsensor", "soctherm";      252         clock-names = "tsensor", "soctherm";
253         resets = <&tegra_car 78>;                 253         resets = <&tegra_car 78>;
254         reset-names = "soctherm";                 254         reset-names = "soctherm";
255                                                   255 
256         #thermal-sensor-cells = <1>;              256         #thermal-sensor-cells = <1>;
257                                                   257 
258         nvidia,thermtrips = <TEGRA124_SOCTHERM    258         nvidia,thermtrips = <TEGRA124_SOCTHERM_SENSOR_CPU 102500>,
259                             <TEGRA124_SOCTHERM    259                             <TEGRA124_SOCTHERM_SENSOR_GPU 103000>;
260                                                   260 
261         throttle-cfgs {                           261         throttle-cfgs {
262             /*                                    262             /*
263              * When the "heavy" cooling device    263              * When the "heavy" cooling device triggered,
264              * the HW will skip cpu clock's pu    264              * the HW will skip cpu clock's pulse in 85% depth,
265              * skip gpu clock's pulse in 85% l    265              * skip gpu clock's pulse in 85% level
266              */                                   266              */
267             heavy {                               267             heavy {
268                 nvidia,priority = <100>;          268                 nvidia,priority = <100>;
269                 nvidia,cpu-throt-percent = <85    269                 nvidia,cpu-throt-percent = <85>;
270                 nvidia,gpu-throt-level = <TEGR    270                 nvidia,gpu-throt-level = <TEGRA_SOCTHERM_THROT_LEVEL_HIGH>;
271                                                   271 
272                 #cooling-cells = <2>;             272                 #cooling-cells = <2>;
273             };                                    273             };
274                                                   274 
275             /*                                    275             /*
276              * When the "light" cooling device    276              * When the "light" cooling device triggered,
277              * the HW will skip cpu clock's pu    277              * the HW will skip cpu clock's pulse in 50% depth,
278              * skip gpu clock's pulse in 50% l    278              * skip gpu clock's pulse in 50% level
279              */                                   279              */
280             light {                               280             light {
281                 nvidia,priority = <80>;           281                 nvidia,priority = <80>;
282                 nvidia,cpu-throt-percent = <50    282                 nvidia,cpu-throt-percent = <50>;
283                 nvidia,gpu-throt-level = <TEGR    283                 nvidia,gpu-throt-level = <TEGRA_SOCTHERM_THROT_LEVEL_LOW>;
284                                                   284 
285                 #cooling-cells = <2>;             285                 #cooling-cells = <2>;
286             };                                    286             };
287                                                   287 
288             /*                                    288             /*
289              * If these two devices are trigge    289              * If these two devices are triggered in same time, the HW throttle
290              * arbiter will select the highest    290              * arbiter will select the highest priority as the final throttle
291              * settings to skip cpu pulse.        291              * settings to skip cpu pulse.
292              */                                   292              */
293                                                   293 
294             oc1 {                                 294             oc1 {
295                 nvidia,priority = <50>;           295                 nvidia,priority = <50>;
296                 nvidia,polarity-active-low;       296                 nvidia,polarity-active-low;
297                 nvidia,count-threshold = <100>    297                 nvidia,count-threshold = <100>;
298                 nvidia,alarm-filter = <5100000    298                 nvidia,alarm-filter = <5100000>;
299                 nvidia,throttle-period-us = <0    299                 nvidia,throttle-period-us = <0>;
300                 nvidia,cpu-throt-percent = <75    300                 nvidia,cpu-throt-percent = <75>;
301                 nvidia,gpu-throt-level = <TEGR    301                 nvidia,gpu-throt-level = <TEGRA_SOCTHERM_THROT_LEVEL_MED>;
302             };                                    302             };
303         };                                        303         };
304     };                                            304     };
305                                                   305 
306   # referring to Tegra132's "reg", "reg-names"    306   # referring to Tegra132's "reg", "reg-names" and "throttle-cfgs"
307   - |                                             307   - |
308     thermal-sensor@700e2000 {                     308     thermal-sensor@700e2000 {
309         compatible = "nvidia,tegra132-soctherm    309         compatible = "nvidia,tegra132-soctherm";
310         reg = <0x700e2000 0x600>, /* SOC_THERM    310         reg = <0x700e2000 0x600>, /* SOC_THERM reg_base */
311               <0x70040000 0x200>; /* CCROC reg    311               <0x70040000 0x200>; /* CCROC reg_base */
312         reg-names = "soctherm-reg", "ccroc-reg    312         reg-names = "soctherm-reg", "ccroc-reg";
313         interrupts = <GIC_SPI 48 IRQ_TYPE_LEVE    313         interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>,
314                      <GIC_SPI 51 IRQ_TYPE_LEVE    314                      <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>;
315         interrupt-names = "thermal", "edp";       315         interrupt-names = "thermal", "edp";
316         clocks = <&tegra_car TEGRA124_CLK_TSEN    316         clocks = <&tegra_car TEGRA124_CLK_TSENSOR>,
317                  <&tegra_car TEGRA124_CLK_SOC_    317                  <&tegra_car TEGRA124_CLK_SOC_THERM>;
318         clock-names = "tsensor", "soctherm";      318         clock-names = "tsensor", "soctherm";
319         resets = <&tegra_car 78>;                 319         resets = <&tegra_car 78>;
320         reset-names = "soctherm";                 320         reset-names = "soctherm";
321         #thermal-sensor-cells = <1>;              321         #thermal-sensor-cells = <1>;
322                                                   322 
323         throttle-cfgs {                           323         throttle-cfgs {
324             /*                                    324             /*
325              * When the "heavy" cooling device    325              * When the "heavy" cooling device triggered,
326              * the HW will skip cpu clock's pu    326              * the HW will skip cpu clock's pulse in HIGH level
327              */                                   327              */
328             heavy {                               328             heavy {
329                 nvidia,priority = <100>;          329                 nvidia,priority = <100>;
330                 nvidia,cpu-throt-level = <TEGR    330                 nvidia,cpu-throt-level = <TEGRA_SOCTHERM_THROT_LEVEL_HIGH>;
331                                                   331 
332                 #cooling-cells = <2>;             332                 #cooling-cells = <2>;
333             };                                    333             };
334                                                   334 
335             /*                                    335             /*
336              * When the "light" cooling device    336              * When the "light" cooling device triggered,
337              * the HW will skip cpu clock's pu    337              * the HW will skip cpu clock's pulse in MED level
338              */                                   338              */
339             light {                               339             light {
340                 nvidia,priority = <80>;           340                 nvidia,priority = <80>;
341                 nvidia,cpu-throt-level = <TEGR    341                 nvidia,cpu-throt-level = <TEGRA_SOCTHERM_THROT_LEVEL_MED>;
342                                                   342 
343                 #cooling-cells = <2>;             343                 #cooling-cells = <2>;
344             };                                    344             };
345                                                   345 
346             /*                                    346             /*
347              * If these two devices are trigge    347              * If these two devices are triggered in same time, the HW throttle
348              * arbiter will select the highest    348              * arbiter will select the highest priority as the final throttle
349              * settings to skip cpu pulse.        349              * settings to skip cpu pulse.
350              */                                   350              */
351         };                                        351         };
352     };                                            352     };
353                                                   353 
354   # referring to thermal sensors                  354   # referring to thermal sensors
355   - |                                             355   - |
356     thermal-zones {                               356     thermal-zones {
357         cpu-thermal {                             357         cpu-thermal {
358             polling-delay-passive = <1000>;       358             polling-delay-passive = <1000>;
359             polling-delay = <1000>;               359             polling-delay = <1000>;
360                                                   360 
361             thermal-sensors = <&soctherm TEGRA    361             thermal-sensors = <&soctherm TEGRA124_SOCTHERM_SENSOR_CPU>;
362                                                   362 
363             trips {                               363             trips {
364                 cpu_shutdown_trip: shutdown-tr    364                 cpu_shutdown_trip: shutdown-trip {
365                     temperature = <102500>;       365                     temperature = <102500>;
366                     hysteresis = <1000>;          366                     hysteresis = <1000>;
367                     type = "critical";            367                     type = "critical";
368                 };                                368                 };
369                                                   369 
370                 cpu_throttle_trip: throttle-tr    370                 cpu_throttle_trip: throttle-trip {
371                     temperature = <100000>;       371                     temperature = <100000>;
372                     hysteresis = <1000>;          372                     hysteresis = <1000>;
373                     type = "hot";                 373                     type = "hot";
374                 };                                374                 };
375             };                                    375             };
376                                                   376 
377             cooling-maps {                        377             cooling-maps {
378                 map0 {                            378                 map0 {
379                     trip = <&cpu_throttle_trip    379                     trip = <&cpu_throttle_trip>;
380                     cooling-device = <&throttl    380                     cooling-device = <&throttle_heavy 1 1>;
381                 };                                381                 };
382             };                                    382             };
383         };                                        383         };
384     };                                            384     };
                                                      

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php