Hi Frank, First of all: when you start a new discussion topic, please also start a new thread on the mailing list, rather than replying to an old post and changing the subject line. The way you did, threading looks horrible. See by yourself: http://lists.lm-sensors.org/pipermail/lm-sensors/2008-June/thread.html#23382 On Mon, 23 Jun 2008 23:06:29 -0400, Frank Myhr wrote: > I've added automatic pwm control to the it87.c driver and it's working > on my Gigabyte GA-MA770-DS3 motherboard with it8718f chip. I plan to > contribute the modified driver, but need to do significant cleanup and > logical patch-splitting before it's in a fit state to submit. > In my naivete I didn't read sysfs-interface until I'd already rolled > my own non-conforming interface for it87. My bad, my pain as I fix that. > I do have a comment, though: > > For pwm[1-*], it seems to me to make better sense to use a range > [0, 100] ("% duty cycle"), rather than the current 8-bit range [0, 255]. > > Points in favor of using range [0, 100] "% duty cycle" for pwm[1-*]: > > 1) Consistency: other hwmon sysfs attributes that correspond to > physical quantities (temp[1-*], fan[1-*], etc.) are in physical units. A duty cycle expressed in % is not a physical unit. > > 2) Freedom from chip implementation: 0-100% duty cycle remains > the same regardless of whether specific chip uses 6,7,8 or whatever > bits to represent it. Same is true of the 0-255 range we use at the moment. > > 3) Meaningful value: natural for user to think in terms of 0-100% duty > cycle, rather than "255 means 100%... 60% would be... (pulls out calculator)" True. > > Of course I remain naive, and so have some questions: > > a) Is there any possibility of changing pwm[1-*] to use range [0, 100] ?* No there isn't. This would break compatibility when the users upgrade, and several applications would have to be updated (pwmconfig and fancontrol to start with.) > > b) If backward compatibility with [0, 255] range must be preserved, > would it be acceptable to make available an additional redundant > attribute, named something like pwm[1-*]_duty that would have range [0, 100] ?* I see very little benefit in doing this. In fact the only benefit is your point 3 above. Drawbacks are many: bigger drivers, higher memory usage, possible confusion between both interfaces. > > c) Is your [dog / cat / fish / fill in the blank] less naive than I am? :-) Well, my baby daughter didn't propose this change ;-) > > *Note that the following attributes would also be affected: > pwm[1-*]_auto_point[1-*]_pwm > temp[1-*]_auto_point[1-*]_pwm The 0-255 range for pwm values has its share of benefits. It is the natural range for many chips, so it saves conversions back and forth. Other chips almost always have a 0-2^n range which can easily be mapped to 0-255 with no resolution loss. The 0-100 range, on the other hand, required conversions. Given that only integer values can be used in sysfs, this would decrease the resolution. This would be a real problem. It is frequent that only the smallest pwm values are usable to control a fan, so if you can't use all the available values, the granularity can become too important for smooth fan speed control to be possible. If you think that converting from 0-255 to 0-100% is too difficult for the users, this is something for applications to address. pwmconfig and fancontrol could be adjusted to understand duty cycles expressed in percent for example. It shouldn't be too difficult. It could bring in some confusion though, for people used to the 0-255 range. The sysfs interface itself will not change, pwm value range is 0-255. -- Jean Delvare