| | | |
Offset 1, 345 lines modified | Offset 1, 95 lines modified |
1 | /*·SPDX-License-Identifier:·GPL-2.0·*/ | 1 | /*·SPDX-License-Identifier:·GPL-2.0·WITH·Linux-syscall-note·*/ |
| 2 | #ifndef·_UAPI_LINUX_THERMAL_H |
| 3 | #define·_UAPI_LINUX_THERMAL_H |
2 | /* | |
3 | ·*··thermal.h··($Revision:·0·$) | |
4 | ·* | |
5 | ·*··Copyright·(C)·2008··Intel·Corp | |
6 | ·*··Copyright·(C)·2008··Zhang·Rui·<rui.zhang@intel.com> | |
7 | ·*··Copyright·(C)·2008··Sujith·Thomas·<sujith.thomas@intel.com> | |
8 | ·*/ | |
| |
| 4 | #define·THERMAL_NAME_LENGTH» 20 |
9 | #ifndef·__THERMAL_H__ | |
10 | #define·__THERMAL_H__ | |
| |
| 5 | enum·thermal_device_mode·{ |
| 6 | » THERMAL_DEVICE_DISABLED·=·0, |
| 7 | » THERMAL_DEVICE_ENABLED, |
11 | #include·<linux/of.h> | |
12 | #include·<linux/idr.h> | |
13 | #include·<linux/device.h> | |
14 | #include·<linux/sysfs.h> | |
15 | #include·<linux/workqueue.h> | |
16 | #include·<uapi/linux/thermal.h> | |
| |
17 | /*·invalid·cooling·state·*/ | |
18 | #define·THERMAL_CSTATE_INVALID·-1UL | |
| |
19 | /*·No·upper/lower·limit·requirement·*/ | |
20 | #define·THERMAL_NO_LIMIT»((u32)~0) | |
| |
21 | /*·Default·weight·of·a·bound·cooling·device·*/ | |
22 | #define·THERMAL_WEIGHT_DEFAULT·0 | |
| |
23 | /*·use·value,·which·<·0K,·to·indicate·an·invalid/uninitialized·temperature·*/ | |
24 | #define·THERMAL_TEMP_INVALID» -274000 | |
| |
25 | struct·thermal_zone_device; | |
26 | struct·thermal_cooling_device; | |
27 | struct·thermal_instance; | |
28 | struct·thermal_debugfs; | |
29 | struct·thermal_attr; | |
| |
30 | enum·thermal_trend·{ | |
31 | » THERMAL_TREND_STABLE,·/*·temperature·is·stable·*/ | |
32 | » THERMAL_TREND_RAISING,·/*·temperature·is·raising·*/ | |
33 | » THERMAL_TREND_DROPPING,·/*·temperature·is·dropping·*/ | |
34 | }; | 8 | }; |
| |
| 9 | enum·thermal_trip_type·{ |
| 10 | » THERMAL_TRIP_ACTIVE·=·0, |
| 11 | » THERMAL_TRIP_PASSIVE, |
| 12 | » THERMAL_TRIP_HOT, |
| 13 | » THERMAL_TRIP_CRITICAL, |
35 | /*·Thermal·notification·reason·*/ | |
36 | enum·thermal_notify_event·{ | |
37 | » THERMAL_EVENT_UNSPECIFIED,·/*·Unspecified·event·*/ | |
38 | » THERMAL_EVENT_TEMP_SAMPLE,·/*·New·Temperature·sample·*/ | |
39 | » THERMAL_TRIP_VIOLATED,·/*·TRIP·Point·violation·*/ | |
40 | » THERMAL_TRIP_CHANGED,·/*·TRIP·Point·temperature·changed·*/ | |
41 | » THERMAL_DEVICE_DOWN,·/*·Thermal·device·is·down·*/ | |
42 | » THERMAL_DEVICE_UP,·/*·Thermal·device·is·up·after·a·down·event·*/ | |
43 | » THERMAL_DEVICE_POWER_CAPABILITY_CHANGED,·/*·power·capability·changed·*/ | |
44 | » THERMAL_TABLE_CHANGED,·/*·Thermal·table(s)·changed·*/ | |
45 | » THERMAL_EVENT_KEEP_ALIVE,·/*·Request·for·user·space·handler·to·respond·*/ | |
46 | » THERMAL_TZ_BIND_CDEV,·/*·Cooling·dev·is·bind·to·the·thermal·zone·*/ | |
47 | » THERMAL_TZ_UNBIND_CDEV,·/*·Cooling·dev·is·unbind·from·the·thermal·zone·*/ | |
48 | » THERMAL_INSTANCE_WEIGHT_CHANGED,·/*·Thermal·instance·weight·changed·*/ | |
49 | » THERMAL_TZ_RESUME,·/*·Thermal·zone·is·resuming·after·system·sleep·*/ | |
50 | }; | 14 | }; |
| |
51 | /** | |
52 | ·*·struct·thermal_trip·-·representation·of·a·point·in·temperature·domain | |
53 | ·*·@temperature:·temperature·value·in·miliCelsius | |
54 | ·*·@hysteresis:·relative·hysteresis·in·miliCelsius | |
55 | ·*·@type:·trip·point·type | |
56 | ·*·@priv:·pointer·to·driver·data·associated·with·this·trip | |
57 | ·*·@flags:·flags·representing·binary·properties·of·the·trip | |
58 | ·*/ | |
59 | struct·thermal_trip·{ | |
60 | » int·temperature; | |
61 | » int·hysteresis; | |
62 | » enum·thermal_trip_type·type; | |
63 | » u8·flags; | |
64 | » void·*priv; | 15 | /*·Adding·event·notification·support·elements·*/ |
| 16 | #define·THERMAL_GENL_FAMILY_NAME»»"thermal" |
| 17 | #define·THERMAL_GENL_VERSION» » » 0x01 |
| 18 | #define·THERMAL_GENL_SAMPLING_GROUP_NAME»"sampling" |
| 19 | #define·THERMAL_GENL_EVENT_GROUP_NAME» » "event" |
| |
| 20 | /*·Attributes·of·thermal_genl_family·*/ |
| 21 | enum·thermal_genl_attr·{ |
| 22 | » THERMAL_GENL_ATTR_UNSPEC, |
| 23 | » THERMAL_GENL_ATTR_TZ, |
| 24 | » THERMAL_GENL_ATTR_TZ_ID, |
| 25 | » THERMAL_GENL_ATTR_TZ_TEMP, |
| 26 | » THERMAL_GENL_ATTR_TZ_TRIP, |
| 27 | » THERMAL_GENL_ATTR_TZ_TRIP_ID, |
| 28 | » THERMAL_GENL_ATTR_TZ_TRIP_TYPE, |
| 29 | » THERMAL_GENL_ATTR_TZ_TRIP_TEMP, |
| 30 | » THERMAL_GENL_ATTR_TZ_TRIP_HYST, |
| 31 | » THERMAL_GENL_ATTR_TZ_MODE, |
| 32 | » THERMAL_GENL_ATTR_TZ_NAME, |
| 33 | » THERMAL_GENL_ATTR_TZ_CDEV_WEIGHT, |
| 34 | » THERMAL_GENL_ATTR_TZ_GOV, |
| 35 | » THERMAL_GENL_ATTR_TZ_GOV_NAME, |
| 36 | » THERMAL_GENL_ATTR_CDEV, |
| 37 | » THERMAL_GENL_ATTR_CDEV_ID, |
| 38 | » THERMAL_GENL_ATTR_CDEV_CUR_STATE, |
| 39 | » THERMAL_GENL_ATTR_CDEV_MAX_STATE, |
| 40 | » THERMAL_GENL_ATTR_CDEV_NAME, |
| 41 | » THERMAL_GENL_ATTR_GOV_NAME, |
| 42 | » THERMAL_GENL_ATTR_CPU_CAPABILITY, |
| 43 | » THERMAL_GENL_ATTR_CPU_CAPABILITY_ID, |
| 44 | » THERMAL_GENL_ATTR_CPU_CAPABILITY_PERFORMANCE, |
| 45 | » THERMAL_GENL_ATTR_CPU_CAPABILITY_EFFICIENCY, |
| 46 | » __THERMAL_GENL_ATTR_MAX, |
65 | }; | 47 | }; |
| 48 | #define·THERMAL_GENL_ATTR_MAX·(__THERMAL_GENL_ATTR_MAX·-·1) |
| |
66 | #define·THERMAL_TRIP_FLAG_RW_TEMP» BIT(0) | |
67 | #define·THERMAL_TRIP_FLAG_RW_HYST» BIT(1) | 49 | enum·thermal_genl_sampling·{ |
| 50 | » THERMAL_GENL_SAMPLING_TEMP, |
| 51 | » __THERMAL_GENL_SAMPLING_MAX, |
| 52 | }; |
| 53 | #define·THERMAL_GENL_SAMPLING_MAX·(__THERMAL_GENL_SAMPLING_MAX·-·1) |
| |
68 | #define·THERMAL_TRIP_FLAG_RW» (THERMAL_TRIP_FLAG_RW_TEMP·|·\ | |
69 | » » » » ·THERMAL_TRIP_FLAG_RW_HYST) | 54 | /*·Events·of·thermal_genl_family·*/ |
| 55 | enum·thermal_genl_event·{ |
| 56 | » THERMAL_GENL_EVENT_UNSPEC, |
| 57 | » THERMAL_GENL_EVENT_TZ_CREATE,» » /*·Thermal·zone·creation·*/ |
| 58 | » THERMAL_GENL_EVENT_TZ_DELETE,» » /*·Thermal·zone·deletion·*/ |
| 59 | » THERMAL_GENL_EVENT_TZ_DISABLE,» » /*·Thermal·zone·disabled·*/ |
| 60 | » THERMAL_GENL_EVENT_TZ_ENABLE,» » /*·Thermal·zone·enabled·*/ |
| 61 | » THERMAL_GENL_EVENT_TZ_TRIP_UP,» » /*·Trip·point·crossed·the·way·up·*/ |
| 62 | » THERMAL_GENL_EVENT_TZ_TRIP_DOWN,» /*·Trip·point·crossed·the·way·down·*/ |
| 63 | » THERMAL_GENL_EVENT_TZ_TRIP_CHANGE,» /*·Trip·point·changed·*/ |
| 64 | » THERMAL_GENL_EVENT_TZ_TRIP_ADD,»»/*·Trip·point·added·*/ |
| 65 | » THERMAL_GENL_EVENT_TZ_TRIP_DELETE,» /*·Trip·point·deleted·*/ |
| 66 | » THERMAL_GENL_EVENT_CDEV_ADD,» » /*·Cdev·bound·to·the·thermal·zone·*/ |
| 67 | » THERMAL_GENL_EVENT_CDEV_DELETE,»»/*·Cdev·unbound·*/ |
| 68 | » THERMAL_GENL_EVENT_CDEV_STATE_UPDATE,» /*·Cdev·state·updated·*/ |
| 69 | » THERMAL_GENL_EVENT_TZ_GOV_CHANGE,» /*·Governor·policy·changed··*/ |
| 70 | » THERMAL_GENL_EVENT_CPU_CAPABILITY_CHANGE,» /*·CPU·capability·changed·*/ |
| 71 | » __THERMAL_GENL_EVENT_MAX, |
| 72 | }; |
| 73 | #define·THERMAL_GENL_EVENT_MAX·(__THERMAL_GENL_EVENT_MAX·-·1) |
| |
| 74 | /*·Commands·supported·by·the·thermal_genl_family·*/ |
| 75 | enum·thermal_genl_cmd·{ |
| 76 | » THERMAL_GENL_CMD_UNSPEC, |
| 77 | » THERMAL_GENL_CMD_TZ_GET_ID,» /*·List·of·thermal·zones·id·*/ |
| 78 | » THERMAL_GENL_CMD_TZ_GET_TRIP,» /*·List·of·thermal·trips·*/ |
| 79 | » THERMAL_GENL_CMD_TZ_GET_TEMP,» /*·Get·the·thermal·zone·temperature·*/ |
| 80 | » THERMAL_GENL_CMD_TZ_GET_GOV,» /*·Get·the·thermal·zone·governor·*/ |
| 81 | » THERMAL_GENL_CMD_TZ_GET_MODE,» /*·Get·the·thermal·zone·mode·*/ |
| 82 | » THERMAL_GENL_CMD_CDEV_GET,» /*·List·of·cdev·id·*/ |
| 83 | » __THERMAL_GENL_CMD_MAX, |
70 | #define·THERMAL_TRIP_PRIV_TO_INT(_val_)» (uintptr_t)(_val_) | |
71 | #define·THERMAL_INT_TO_TRIP_PRIV(_val_)» (void·*)(uintptr_t)(_val_) | |
| |
72 | struct·cooling_spec·{ | |
73 | » unsigned·long·upper;» /*·Highest·cooling·state··*/ | |
74 | » unsigned·long·lower;» /*·Lowest·cooling·state··*/ | |
75 | » unsigned·int·weight;» /*·Cooling·device·weight·*/ | |
76 | }; | |
| |
77 | struct·thermal_zone_device_ops·{ | |
78 | » bool·(*should_bind)·(struct·thermal_zone_device·*, | |
79 | » » » ·····const·struct·thermal_trip·*, | |
80 | » » » ·····struct·thermal_cooling_device·*, | |
81 | » » » ·····struct·cooling_spec·*); | |
82 | » int·(*get_temp)·(struct·thermal_zone_device·*,·int·*); | |
83 | » int·(*set_trips)·(struct·thermal_zone_device·*,·int,·int); | |
84 | » int·(*change_mode)·(struct·thermal_zone_device·*, | |
85 | » » enum·thermal_device_mode); | |
86 | » int·(*set_trip_temp)·(struct·thermal_zone_device·*, | |
87 | » » » ······const·struct·thermal_trip·*,·int); | |
88 | » int·(*get_crit_temp)·(struct·thermal_zone_device·*,·int·*); | |
89 | » int·(*set_emul_temp)·(struct·thermal_zone_device·*,·int); | |
90 | » int·(*get_trend)·(struct·thermal_zone_device·*, | |
91 | » » » ··const·struct·thermal_trip·*,·enum·thermal_trend·*); | |
92 | » void·(*hot)(struct·thermal_zone_device·*); | |
93 | » void·(*critical)(struct·thermal_zone_device·*); | |
94 | }; | |
| |
95 | struct·thermal_cooling_device_ops·{ | |
96 | » int·(*get_max_state)·(struct·thermal_cooling_device·*,·unsigned·long·*); | |
97 | » int·(*get_cur_state)·(struct·thermal_cooling_device·*,·unsigned·long·*); | |
98 | » int·(*set_cur_state)·(struct·thermal_cooling_device·*,·unsigned·long); | |
99 | » int·(*get_requested_power)(struct·thermal_cooling_device·*,·u32·*); | |
100 | » int·(*state2power)(struct·thermal_cooling_device·*,·unsigned·long,·u32·*); | |
101 | » int·(*power2state)(struct·thermal_cooling_device·*,·u32,·unsigned·long·*); | |
102 | }; | 84 | }; |
| 85 | #define·THERMAL_GENL_CMD_MAX·(__THERMAL_GENL_CMD_MAX·-·1) |
| |
103 | struct·thermal_cooling_device·{ | |
104 | » int·id; | |
105 | » const·char·*type; | |
106 | » unsigned·long·max_state; | |
107 | » struct·device·device; | |
108 | » struct·device_node·*np; | |
109 | » void·*devdata; | |
110 | » void·*stats; | |
111 | » const·struct·thermal_cooling_device_ops·*ops; | |
112 | » bool·updated;·/*·true·if·the·cooling·device·does·not·need·update·*/ | |
113 | » struct·mutex·lock;·/*·protect·thermal_instances·list·*/ | |
114 | » struct·list_head·thermal_instances; | |
115 | » struct·list_head·node; | |
116 | #ifdef·CONFIG_THERMAL_DEBUGFS | |
117 | » struct·thermal_debugfs·*debugfs; | |
118 | #endif | |
119 | }; | |
| |
120 | /*·Structure·to·define·Thermal·Zone·parameters·*/ | |
121 | struct·thermal_zone_params·{ | |
122 | » const·char·*governor_name; | |
| |
123 | » /* | |
124 | » ·*·a·boolean·to·indicate·if·the·thermal·to·hwmon·sysfs·interface | |
125 | » ·*·is·required.·when·no_hwmon·==·false,·a·hwmon·sysfs·interface | |
126 | » ·*·will·be·created.·when·no_hwmon·==·true,·nothing·will·be·done | |
127 | » ·*/ | |
128 | » bool·no_hwmon; | |
| |
129 | » /* | |
130 | » ·*·Sustainable·power·(heat)·that·this·thermal·zone·can·dissipate·in | |
131 | » ·*·mW | |
132 | » ·*/ | |
133 | » u32·sustainable_power; | |
| |
134 | » /* | |
135 | » ·*·Proportional·parameter·of·the·PID·controller·when | |
136 | » ·*·overshooting·(i.e.,·when·temperature·is·below·the·target) | |
137 | » ·*/ | |
138 | » s32·k_po; | |
| |
139 | » /* | |
140 | » ·*·Proportional·parameter·of·the·PID·controller·when | |
141 | » ·*·undershooting | |
142 | » ·*/ | |
143 | » s32·k_pu; | |
| |
144 | » /*·Integral·parameter·of·the·PID·controller·*/ | |
145 | » s32·k_i; | |
| |
146 | » /*·Derivative·parameter·of·the·PID·controller·*/ | |
147 | » s32·k_d; | |
| |
148 | » /*·threshold·below·which·the·error·is·no·longer·accumulated·*/ | |
149 | » s32·integral_cutoff; | |
| |
150 | » /* | |
151 | » ·*·@slope:» slope·of·a·linear·temperature·adjustment·curve. | |
152 | » ·*·» » Used·by·thermal·zone·drivers. | |
153 | » ·*/ | |
154 | » int·slope; | |
155 | » /* | |
156 | » ·*·@offset:» offset·of·a·linear·temperature·adjustment·curve. | |
157 | » ·*·» » Used·by·thermal·zone·drivers·(default·0). | |
158 | » ·*/ | |
159 | » int·offset; | |
160 | }; | |
| |
161 | /*·Function·declarations·*/ | |
162 | #ifdef·CONFIG_THERMAL_OF | |
163 | struct·thermal_zone_device·*devm_thermal_of_zone_register(struct·device·*dev,·int·id,·void·*data, | |
164 | » » » » » » » ··const·struct·thermal_zone_device_ops·*ops); | |
| |
165 | void·devm_thermal_of_zone_unregister(struct·device·*dev,·struct·thermal_zone_device·*tz); | |
| |
166 | #else | |
| |
167 | static·inline | |
168 | struct·thermal_zone_device·*devm_thermal_of_zone_register(struct·device·*dev,·int·id,·void·*data, | |
169 | » » » » » » » ··const·struct·thermal_zone_device_ops·*ops) | |
170 | { | |
171 | » return·ERR_PTR(-ENOTSUPP); | |
172 | } | |
| |
173 | static·inline·void·devm_thermal_of_zone_unregister(struct·device·*dev, | |
174 | » » » » » » ···struct·thermal_zone_device·*tz) | |
175 | { | |
176 | } | |
177 | #endif | |
| |
178 | int·for_each_thermal_trip(struct·thermal_zone_device·*tz, | |
179 | » » » ··int·(*cb)(struct·thermal_trip·*,·void·*), | |
180 | » » » ··void·*data); | |
181 | int·thermal_zone_for_each_trip(struct·thermal_zone_device·*tz, | |
182 | » » » ·······int·(*cb)(struct·thermal_trip·*,·void·*), | |
183 | » » » ·······void·*data); | |
184 | void·thermal_zone_set_trip_temp(struct·thermal_zone_device·*tz, | |
185 | » » » » struct·thermal_trip·*trip,·int·temp); | |
| |
186 | int·thermal_zone_get_crit_temp(struct·thermal_zone_device·*tz,·int·*temp); | |
| |
187 | #ifdef·CONFIG_THERMAL | |
188 | struct·thermal_zone_device·*thermal_zone_device_register_with_trips( | |
189 | » » » » » const·char·*type, | |
190 | » » » » » const·struct·thermal_trip·*trips, | |
191 | » » » » » int·num_trips,·void·*devdata, | |
192 | » » » » » const·struct·thermal_zone_device_ops·*ops, | |
193 | » » » » » const·struct·thermal_zone_params·*tzp, | |
194 | » » » » » unsigned·int·passive_delay, | |
195 | » » » » » unsigned·int·polling_delay); | |
| |
196 | struct·thermal_zone_device·*thermal_tripless_zone_device_register( | |
197 | » » » » » const·char·*type, | |
198 | » » » » » void·*devdata, | |
199 | » » » » » const·struct·thermal_zone_device_ops·*ops, | |
200 | » » » » » const·struct·thermal_zone_params·*tzp); | |
| |
201 | void·thermal_zone_device_unregister(struct·thermal_zone_device·*tz); | |
| |
202 | void·*thermal_zone_device_priv(struct·thermal_zone_device·*tzd); | |
203 | const·char·*thermal_zone_device_type(struct·thermal_zone_device·*tzd); | |
204 | int·thermal_zone_device_id(struct·thermal_zone_device·*tzd); | |
205 | struct·device·*thermal_zone_device(struct·thermal_zone_device·*tzd); | |
| |
206 | void·thermal_zone_device_update(struct·thermal_zone_device·*, | |
207 | » » » » enum·thermal_notify_event); | |
| |
208 | struct·thermal_cooling_device·*thermal_cooling_device_register(const·char·*, | |
209 | » » void·*,·const·struct·thermal_cooling_device_ops·*); | |
210 | struct·thermal_cooling_device·* | |
211 | thermal_of_cooling_device_register(struct·device_node·*np,·const·char·*,·void·*, | |
212 | » » » » ···const·struct·thermal_cooling_device_ops·*); | |
213 | struct·thermal_cooling_device·* | |
214 | devm_thermal_of_cooling_device_register(struct·device·*dev, | |
215 | » » » » struct·device_node·*np, | |
216 | » » » » const·char·*type,·void·*devdata, | |
217 | » » » » const·struct·thermal_cooling_device_ops·*ops); | |
218 | void·thermal_cooling_device_update(struct·thermal_cooling_device·*); | |
219 | void·thermal_cooling_device_unregister(struct·thermal_cooling_device·*); | |
220 | struct·thermal_zone_device·*thermal_zone_get_zone_by_name(const·char·*name); | |
221 | int·thermal_zone_get_temp(struct·thermal_zone_device·*tz,·int·*temp); | |
222 | int·thermal_zone_get_slope(struct·thermal_zone_device·*tz); | |
223 | int·thermal_zone_get_offset(struct·thermal_zone_device·*tz); | |
224 | bool·thermal_trip_is_bound_to_cdev(struct·thermal_zone_device·*tz, | |
225 | » » » » ···const·struct·thermal_trip·*trip, | |
226 | » » » » ···struct·thermal_cooling_device·*cdev); | |
| |
227 | int·thermal_zone_device_enable(struct·thermal_zone_device·*tz); | |
228 | int·thermal_zone_device_disable(struct·thermal_zone_device·*tz); | |
229 | void·thermal_zone_device_critical(struct·thermal_zone_device·*tz); | |
230 | #else | |
231 | static·inline·struct·thermal_zone_device·*thermal_zone_device_register_with_trips( | |
232 | » » » » » const·char·*type, | |
233 | » » » » » const·struct·thermal_trip·*trips, | |
234 | » » » » » int·num_trips,·void·*devdata, | |
235 | » » » » » const·struct·thermal_zone_device_ops·*ops, | |
236 | » » » » » const·struct·thermal_zone_params·*tzp, | |
237 | » » » » » int·passive_delay,·int·polling_delay) | |
238 | {·return·ERR_PTR(-ENODEV);·} | |
| |
239 | static·inline·struct·thermal_zone_device·*thermal_tripless_zone_device_register( | |
240 | » » » » » const·char·*type, | |
241 | » » » » » void·*devdata, | |
242 | » » » » » struct·thermal_zone_device_ops·*ops, | |
243 | » » » » » const·struct·thermal_zone_params·*tzp) | |
244 | {·return·ERR_PTR(-ENODEV);·} | |
| |
245 | static·inline·void·thermal_zone_device_unregister(struct·thermal_zone_device·*tz) | |
246 | {·} | |
| |
247 | static·inline·struct·thermal_cooling_device·* | |
248 | thermal_cooling_device_register(const·char·*type,·void·*devdata, | |
249 | » const·struct·thermal_cooling_device_ops·*ops) | |
250 | {·return·ERR_PTR(-ENODEV);·} | |
251 | static·inline·struct·thermal_cooling_device·* | |
252 | thermal_of_cooling_device_register(struct·device_node·*np, | |
253 | » const·char·*type,·void·*devdata, | |
254 | » const·struct·thermal_cooling_device_ops·*ops) | |
255 | {·return·ERR_PTR(-ENODEV);·} | |
256 | static·inline·struct·thermal_cooling_device·* | |
257 | devm_thermal_of_cooling_device_register(struct·device·*dev, | |
258 | » » » » struct·device_node·*np, | |
259 | » » » » const·char·*type,·void·*devdata, | |
260 | » » » » const·struct·thermal_cooling_device_ops·*ops) | |
261 | { | |
262 | » return·ERR_PTR(-ENODEV); | |
263 | } | |
264 | static·inline·void·thermal_cooling_device_unregister( | |
265 | » struct·thermal_cooling_device·*cdev) | |
266 | {·} | |
267 | static·inline·struct·thermal_zone_device·*thermal_zone_get_zone_by_name( | |
268 | » » const·char·*name) | |
269 | {·return·ERR_PTR(-ENODEV);·} | |
270 | static·inline·int·thermal_zone_get_temp( | |
271 | » » struct·thermal_zone_device·*tz,·int·*temp) | |
272 | {·return·-ENODEV;·} | |
273 | static·inline·int·thermal_zone_get_slope( | |
274 | » » struct·thermal_zone_device·*tz) | |
275 | {·return·-ENODEV;·} | |
276 | static·inline·int·thermal_zone_get_offset( | |
277 | » » struct·thermal_zone_device·*tz) | |
278 | {·return·-ENODEV;·} | |
| |
279 | static·inline·void·*thermal_zone_device_priv(struct·thermal_zone_device·*tz) | |
280 | { | |
281 | » return·NULL; | |
282 | } | |
| |
283 | static·inline·const·char·*thermal_zone_device_type(struct·thermal_zone_device·*tzd) | |
284 | { | |
285 | » return·NULL; | |
286 | } | |
| |
287 | static·inline·int·thermal_zone_device_id(struct·thermal_zone_device·*tzd) | |
288 | { | |
289 | » return·-ENODEV; | |
290 | } | |
| |
291 | static·inline·int·thermal_zone_device_enable(struct·thermal_zone_device·*tz) | |
292 | {·return·-ENODEV;·} | |
| |
293 | static·inline·int·thermal_zone_device_disable(struct·thermal_zone_device·*tz) | |
294 | {·return·-ENODEV;·} | |
295 | #endif·/*·CONFIG_THERMAL·*/ | |
| |
296 | #endif·/*·__THERMAL_H__·*/ | 86 | #endif·/*·_UAPI_LINUX_THERMAL_H·*/ |