Greeting, Funnily enough I had this discussion couple a months ago and made my mind back then :-) > On 07/22/2013 07:25 AM, Eduardo Valentin wrote: > > representing in device tree would not > > infringe the original purpose of this data structure ("The Device > > Tree is a data structure for describing hardware."[2]). I couldn't agree more, with a few remarks... > > In this current proposal, a 'thermal_zone' node would be embedded > > inside a temperature sensor node, for simplicity. But other > > possible builds could embedded them in the device with thermal > > limits (CPU nodes, for instance) or they could be not embedded in > > any specific node. So this is the detail that actually caused most of the disagreement :-) My position on this can be summarized as follows: 1. As you have pointed out, the thermal limits are related to the *device being monitored*, not the sensor itself. 2. Therefore the tree should express relation between those two; a sensor mode should be connected (via phandle most likely) to the device being monitored, eg. (I'm not suggesting any property names, just trying to express the idea ;-) memory mapped PVT "sensor" monitoring a core (cpu) temperature could look like this: cpu0: cpu@0 { }; sensor@xxxx { reg = <xxx>; device_monitored = <&cpu0>; }; while I2C or 1Wire sensor measuring temperature of the board (or even inside the device enclosure) would point at the root of the tree. 3. Basing on the above, the thermal limits of the device could be described in the tree (again, don't pay attention to naming): cpu0: cpu@0 { thermal_limits { cooling { }; critical { }; }; }; or "hardcoded" in the device driver. After all, as you have pointed out, the limits are the device's characteristic, so I see no problem with the "SOC driver" registering the trip points on its own. I'm sure there will be situations when it's better to parametrize such data via Device Tree, so it makes perfect sense to have bindings defined for such occasion. Anyway, as long as the tree describes the relation between the monitored device, the sensor and the cooling device all should work. Now, my personal opinion is that the tree should focus at "system level" data (ie. how is the device connected to others) and describe as little information that can be probed in runtime - a small (small!) array of silicon variants in the driver doesn't hurt (unless we're talking about hundreds of possibilities, where the device tree is obviously the place to have them). But this is just a rule of thumb I'm following. Cheers! Pawel _______________________________________________ lm-sensors mailing list lm-sensors@xxxxxxxxxxxxxx http://lists.lm-sensors.org/mailman/listinfo/lm-sensors