The new thermal management sysfs class, and hwmon

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sun, 03 Feb 2008, Mark M. Hoffman wrote:
> * Zhang Rui <rui.zhang at intel.com> [2008-02-03 17:31:12 +0800]:
> > On Sun, 2008-02-03 at 10:26 +0800, Henrique de Moraes Holschuh wrote:
> > > And the two sysfs ABIs are incompatible.  The ACPI one uses
> > > low-precision units, (temperature in 10^0 degrees Celcius), while
> > > the hwmon ABI uses medium precision units (10^-3 degrees Celcius),
> > > for example.  There is also no tachometer feedback for fans, etc.
> 
> > Yes, currently ACPI is the only user of the thermal sysfs I/F. We can
> > add new sys I/F if someone really need it.

I would really appreciate if the thermal zone ABI used a subset of the hwmon
ABI.  There is absolutely no reason to have one return data in 10^-3 C while
the other returns data in 10^0 C, for example.  IMO, if both ABIs need
thermal readings, both should use the same attribute, defined in the same
way.  The same goes for other attributes in the two interfaces that share a
common concept.

> > > IMHO, we can probably do better than two incompatible sysfs ABIs for
> > > what ammounts to the same functionality for many userspace
> > > applications (i.e.  thermal monitor apps, and fan control and
> > > monitoring apps).  And it would be really neat if the new thermal
> > > management stuff could just plug into the already available
> > > temperature sensors and fan controllers that follow the hwmon sysfs
> > > ABI.
> 
> > Yes, we do want to use the hwmon sysfs ABI at the beginning.
> > But there are several gaps that making us turn to a new thermal sysfs
> > class. And the biggest one is that hwmon does NOT support ACPI passive
> > cooling devices like processor, video, etc. intel menlow platform even
> > has a ACPI memory controller device which can be throttled by changing
> > the bandwidth. These are quite different from the hwmon's fan-based
> > thermal management, right?
> 
> The hwmon class ABI is more about exposing the functionality that is
> available on various devices than it is about accomplishing some
> specific task like "thermal management".  That said...

But a lot of chips *can* do thermal management, and there is an ABI for it
on hwmon (but it is not easy to use, I started messing with lm85 to do so
and dropped the ball because the in-chip ABI was not so easy to map to the
hwmon ABI and I got sidetracked).

We could reshape that ABI into something that could be useful for all
monitoring chips AND for both ACPI active and passive cooling control.

> I don't see why the hwmon class ABI couldn't be extended to accomodate
> CPU throttling, etc.  But I also don't see that it hurts anything to put
> these controls somewhere else in sysfs.

Agreed.  However, *duplicating* what is already in hwmon elsewhere is not
fun.  Please reconsider.  I'd like to see passive cooling (heck, the entire
ACPI v3.0 thermal model, if needed) added to hwmon, that will enhance hwmon
to be even more generic, and we all benefit from that.

> I *do* think that any driver which reports temperature, etc. should
> expose those measurements through the hwmon class - even if they're
> exposed somewhere else as well.

While I *do* think if we have to expose them twice, we are doing something
wrong :-)

-- 
  "One disk to rule them all, One disk to find them. One disk to bring
  them all and in the darkness grind them. In the Land of Redmond
  where the shadows lie." -- The Silicon Valley Tarot
  Henrique Holschuh




[Index of Archives]     [Linux Kernel]     [Linux Hardware Monitoring]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]

  Powered by Linux