1*4882a593Smuzhiyun# SPDX-License-Identifier: GPL-2.0-only 2*4882a593Smuzhiyun# Copyright (C) 2020 Renesas Electronics Corp. 3*4882a593Smuzhiyun%YAML 1.2 4*4882a593Smuzhiyun--- 5*4882a593Smuzhiyun$id: http://devicetree.org/schemas/thermal/rcar-thermal.yaml# 6*4882a593Smuzhiyun$schema: http://devicetree.org/meta-schemas/core.yaml# 7*4882a593Smuzhiyun 8*4882a593Smuzhiyuntitle: Renesas R-Car Thermal 9*4882a593Smuzhiyun 10*4882a593Smuzhiyunmaintainers: 11*4882a593Smuzhiyun - Niklas Söderlund <niklas.soderlund@ragnatech.se> 12*4882a593Smuzhiyun 13*4882a593Smuzhiyunproperties: 14*4882a593Smuzhiyun compatible: 15*4882a593Smuzhiyun oneOf: 16*4882a593Smuzhiyun - items: 17*4882a593Smuzhiyun - enum: 18*4882a593Smuzhiyun - renesas,thermal-r8a73a4 # R-Mobile APE6 19*4882a593Smuzhiyun - renesas,thermal-r8a7779 # R-Car H1 20*4882a593Smuzhiyun - const: renesas,rcar-thermal # Generic without thermal-zone 21*4882a593Smuzhiyun - items: 22*4882a593Smuzhiyun - enum: 23*4882a593Smuzhiyun - renesas,thermal-r8a7742 # RZ/G1H 24*4882a593Smuzhiyun - renesas,thermal-r8a7743 # RZ/G1M 25*4882a593Smuzhiyun - renesas,thermal-r8a7744 # RZ/G1N 26*4882a593Smuzhiyun - const: renesas,rcar-gen2-thermal # Generic thermal-zone 27*4882a593Smuzhiyun - items: 28*4882a593Smuzhiyun - enum: 29*4882a593Smuzhiyun - renesas,thermal-r8a7790 # R-Car H2 30*4882a593Smuzhiyun - renesas,thermal-r8a7791 # R-Car M2-W 31*4882a593Smuzhiyun - renesas,thermal-r8a7792 # R-Car V2H 32*4882a593Smuzhiyun - renesas,thermal-r8a7793 # R-Car M2-N 33*4882a593Smuzhiyun - const: renesas,rcar-gen2-thermal # Generic thermal-zone 34*4882a593Smuzhiyun - const: renesas,rcar-thermal # Generic without thermal-zone 35*4882a593Smuzhiyun - items: 36*4882a593Smuzhiyun - enum: 37*4882a593Smuzhiyun - renesas,thermal-r8a774c0 # RZ/G2E 38*4882a593Smuzhiyun - renesas,thermal-r8a77970 # R-Car V3M 39*4882a593Smuzhiyun - renesas,thermal-r8a77990 # R-Car E3 40*4882a593Smuzhiyun - renesas,thermal-r8a77995 # R-Car D3 41*4882a593Smuzhiyun reg: 42*4882a593Smuzhiyun description: 43*4882a593Smuzhiyun Address ranges of the thermal registers. If more then one range is given 44*4882a593Smuzhiyun the first one must be the common registers followed by each sensor 45*4882a593Smuzhiyun according the the datasheet. 46*4882a593Smuzhiyun minItems: 1 47*4882a593Smuzhiyun maxItems: 4 48*4882a593Smuzhiyun 49*4882a593Smuzhiyun interrupts: 50*4882a593Smuzhiyun minItems: 1 51*4882a593Smuzhiyun maxItems: 3 52*4882a593Smuzhiyun 53*4882a593Smuzhiyun clocks: 54*4882a593Smuzhiyun maxItems: 1 55*4882a593Smuzhiyun 56*4882a593Smuzhiyun power-domains: 57*4882a593Smuzhiyun maxItems: 1 58*4882a593Smuzhiyun 59*4882a593Smuzhiyun resets: 60*4882a593Smuzhiyun maxItems: 1 61*4882a593Smuzhiyun 62*4882a593Smuzhiyun "#thermal-sensor-cells": 63*4882a593Smuzhiyun const: 0 64*4882a593Smuzhiyun 65*4882a593Smuzhiyunif: 66*4882a593Smuzhiyun properties: 67*4882a593Smuzhiyun compatible: 68*4882a593Smuzhiyun contains: 69*4882a593Smuzhiyun enum: 70*4882a593Smuzhiyun - renesas,thermal-r8a73a4 # R-Mobile APE6 71*4882a593Smuzhiyun - renesas,thermal-r8a7779 # R-Car H1 72*4882a593Smuzhiyunthen: 73*4882a593Smuzhiyun required: 74*4882a593Smuzhiyun - compatible 75*4882a593Smuzhiyun - reg 76*4882a593Smuzhiyunelse: 77*4882a593Smuzhiyun required: 78*4882a593Smuzhiyun - compatible 79*4882a593Smuzhiyun - reg 80*4882a593Smuzhiyun - interrupts 81*4882a593Smuzhiyun - clocks 82*4882a593Smuzhiyun - power-domains 83*4882a593Smuzhiyun - resets 84*4882a593Smuzhiyun 85*4882a593SmuzhiyunadditionalProperties: false 86*4882a593Smuzhiyun 87*4882a593Smuzhiyunexamples: 88*4882a593Smuzhiyun # Example (non interrupt support) 89*4882a593Smuzhiyun - | 90*4882a593Smuzhiyun thermal@ffc48000 { 91*4882a593Smuzhiyun compatible = "renesas,thermal-r8a7779", "renesas,rcar-thermal"; 92*4882a593Smuzhiyun reg = <0xffc48000 0x38>; 93*4882a593Smuzhiyun }; 94*4882a593Smuzhiyun 95*4882a593Smuzhiyun # Example (interrupt support) 96*4882a593Smuzhiyun - | 97*4882a593Smuzhiyun #include <dt-bindings/clock/r8a73a4-clock.h> 98*4882a593Smuzhiyun #include <dt-bindings/interrupt-controller/arm-gic.h> 99*4882a593Smuzhiyun #include <dt-bindings/interrupt-controller/irq.h> 100*4882a593Smuzhiyun 101*4882a593Smuzhiyun thermal@e61f0000 { 102*4882a593Smuzhiyun compatible = "renesas,thermal-r8a73a4", "renesas,rcar-thermal"; 103*4882a593Smuzhiyun reg = <0xe61f0000 0x14>, <0xe61f0100 0x38>, 104*4882a593Smuzhiyun <0xe61f0200 0x38>, <0xe61f0300 0x38>; 105*4882a593Smuzhiyun interrupts = <GIC_SPI 69 IRQ_TYPE_LEVEL_HIGH>; 106*4882a593Smuzhiyun clocks = <&mstp5_clks R8A73A4_CLK_THERMAL>; 107*4882a593Smuzhiyun power-domains = <&pd_c5>; 108*4882a593Smuzhiyun }; 109*4882a593Smuzhiyun 110*4882a593Smuzhiyun # Example (with thermal-zone) 111*4882a593Smuzhiyun - | 112*4882a593Smuzhiyun #include <dt-bindings/clock/r8a7790-cpg-mssr.h> 113*4882a593Smuzhiyun #include <dt-bindings/interrupt-controller/arm-gic.h> 114*4882a593Smuzhiyun #include <dt-bindings/power/r8a7790-sysc.h> 115*4882a593Smuzhiyun 116*4882a593Smuzhiyun thermal: thermal@e61f0000 { 117*4882a593Smuzhiyun compatible = "renesas,thermal-r8a7790", 118*4882a593Smuzhiyun "renesas,rcar-gen2-thermal", 119*4882a593Smuzhiyun "renesas,rcar-thermal"; 120*4882a593Smuzhiyun reg = <0xe61f0000 0x10>, <0xe61f0100 0x38>; 121*4882a593Smuzhiyun interrupts = <GIC_SPI 69 IRQ_TYPE_LEVEL_HIGH>; 122*4882a593Smuzhiyun clocks = <&cpg CPG_MOD 522>; 123*4882a593Smuzhiyun power-domains = <&sysc R8A7790_PD_ALWAYS_ON>; 124*4882a593Smuzhiyun resets = <&cpg 522>; 125*4882a593Smuzhiyun #thermal-sensor-cells = <0>; 126*4882a593Smuzhiyun }; 127*4882a593Smuzhiyun 128*4882a593Smuzhiyun thermal-zones { 129*4882a593Smuzhiyun cpu_thermal: cpu-thermal { 130*4882a593Smuzhiyun polling-delay-passive = <1000>; 131*4882a593Smuzhiyun polling-delay = <5000>; 132*4882a593Smuzhiyun 133*4882a593Smuzhiyun thermal-sensors = <&thermal>; 134*4882a593Smuzhiyun 135*4882a593Smuzhiyun trips { 136*4882a593Smuzhiyun cpu-crit { 137*4882a593Smuzhiyun temperature = <115000>; 138*4882a593Smuzhiyun hysteresis = <0>; 139*4882a593Smuzhiyun type = "critical"; 140*4882a593Smuzhiyun }; 141*4882a593Smuzhiyun }; 142*4882a593Smuzhiyun cooling-maps { 143*4882a593Smuzhiyun }; 144*4882a593Smuzhiyun }; 145*4882a593Smuzhiyun }; 146