mirror of https://gitee.com/openkylin/linux.git
hwmon: (w83792d) Additional PWM outputs support
Add pwm[4-7] and the associated pwm[4-7]_mode attributes. Signed-off-by: Roger Lucas <vt8231@hiddenengine.co.uk> Signed-off-by: Jean Delvare <jdelvare@suse.de>
This commit is contained in:
parent
9bdc771f2c
commit
f617f7310c
|
@ -8,6 +8,7 @@ Supported chips:
|
||||||
Datasheet: http://www.winbond.com.tw
|
Datasheet: http://www.winbond.com.tw
|
||||||
|
|
||||||
Author: Shane Huang (Winbond)
|
Author: Shane Huang (Winbond)
|
||||||
|
Updated: Roger Lucas
|
||||||
|
|
||||||
|
|
||||||
Module Parameters
|
Module Parameters
|
||||||
|
@ -38,9 +39,16 @@ parameter; this will put it into a more well-behaved state first.
|
||||||
The driver implements three temperature sensors, seven fan rotation speed
|
The driver implements three temperature sensors, seven fan rotation speed
|
||||||
sensors, nine voltage sensors, and two automatic fan regulation
|
sensors, nine voltage sensors, and two automatic fan regulation
|
||||||
strategies called: Smart Fan I (Thermal Cruise mode) and Smart Fan II.
|
strategies called: Smart Fan I (Thermal Cruise mode) and Smart Fan II.
|
||||||
Automatic fan control mode is possible only for fan1-fan3. Fan4-fan7 can run
|
|
||||||
synchronized with selected fan (fan1-fan3). This functionality and manual PWM
|
The driver also implements up to seven fan control outputs: pwm1-7. Pwm1-7
|
||||||
control for fan4-fan7 is not yet implemented.
|
can be configured to PWM output or Analogue DC output via their associated
|
||||||
|
pwmX_mode. Outputs pwm4 through pwm7 may or may not be present depending on
|
||||||
|
how the W83792AD/D was configured by the BIOS.
|
||||||
|
|
||||||
|
Automatic fan control mode is possible only for fan1-fan3.
|
||||||
|
|
||||||
|
For all pwmX outputs, a value of 0 means minimum fan speed and a value of
|
||||||
|
255 means maximum fan speed.
|
||||||
|
|
||||||
Temperatures are measured in degrees Celsius and measurement resolution is 1
|
Temperatures are measured in degrees Celsius and measurement resolution is 1
|
||||||
degC for temp1 and 0.5 degC for temp2 and temp3. An alarm is triggered when
|
degC for temp1 and 0.5 degC for temp2 and temp3. An alarm is triggered when
|
||||||
|
@ -157,14 +165,14 @@ for each fan.
|
||||||
/sys files
|
/sys files
|
||||||
----------
|
----------
|
||||||
|
|
||||||
pwm[1-3] - this file stores PWM duty cycle or DC value (fan speed) in range:
|
pwm[1-7] - this file stores PWM duty cycle or DC value (fan speed) in range:
|
||||||
0 (stop) to 255 (full)
|
0 (stop) to 255 (full)
|
||||||
pwm[1-3]_enable - this file controls mode of fan/temperature control:
|
pwm[1-3]_enable - this file controls mode of fan/temperature control:
|
||||||
* 0 Disabled
|
* 0 Disabled
|
||||||
* 1 Manual mode
|
* 1 Manual mode
|
||||||
* 2 Smart Fan II
|
* 2 Smart Fan II
|
||||||
* 3 Thermal Cruise
|
* 3 Thermal Cruise
|
||||||
pwm[1-3]_mode - Select PWM of DC mode
|
pwm[1-7]_mode - Select PWM or DC mode
|
||||||
* 0 DC
|
* 0 DC
|
||||||
* 1 PWM
|
* 1 PWM
|
||||||
thermal_cruise[1-3] - Selects the desired temperature for cruise (degC)
|
thermal_cruise[1-3] - Selects the desired temperature for cruise (degC)
|
||||||
|
|
|
@ -289,10 +289,7 @@ struct w83792d_data {
|
||||||
u8 temp1[3]; /* current, over, thyst */
|
u8 temp1[3]; /* current, over, thyst */
|
||||||
u8 temp_add[2][6]; /* Register value */
|
u8 temp_add[2][6]; /* Register value */
|
||||||
u8 fan_div[7]; /* Register encoding, shifted right */
|
u8 fan_div[7]; /* Register encoding, shifted right */
|
||||||
u8 pwm[7]; /*
|
u8 pwm[7]; /* The 7 PWM outputs */
|
||||||
* We only consider the first 3 set of pwm,
|
|
||||||
* although 792 chip has 7 set of pwm.
|
|
||||||
*/
|
|
||||||
u8 pwmenable[3];
|
u8 pwmenable[3];
|
||||||
u32 alarms; /* realtime status register encoding,combined */
|
u32 alarms; /* realtime status register encoding,combined */
|
||||||
u8 chassis; /* Chassis status */
|
u8 chassis; /* Chassis status */
|
||||||
|
@ -1075,6 +1072,10 @@ static DEVICE_ATTR(intrusion0_alarm, S_IRUGO | S_IWUSR,
|
||||||
static SENSOR_DEVICE_ATTR(pwm1, S_IWUSR | S_IRUGO, show_pwm, store_pwm, 0);
|
static SENSOR_DEVICE_ATTR(pwm1, S_IWUSR | S_IRUGO, show_pwm, store_pwm, 0);
|
||||||
static SENSOR_DEVICE_ATTR(pwm2, S_IWUSR | S_IRUGO, show_pwm, store_pwm, 1);
|
static SENSOR_DEVICE_ATTR(pwm2, S_IWUSR | S_IRUGO, show_pwm, store_pwm, 1);
|
||||||
static SENSOR_DEVICE_ATTR(pwm3, S_IWUSR | S_IRUGO, show_pwm, store_pwm, 2);
|
static SENSOR_DEVICE_ATTR(pwm3, S_IWUSR | S_IRUGO, show_pwm, store_pwm, 2);
|
||||||
|
static SENSOR_DEVICE_ATTR(pwm4, S_IWUSR | S_IRUGO, show_pwm, store_pwm, 3);
|
||||||
|
static SENSOR_DEVICE_ATTR(pwm5, S_IWUSR | S_IRUGO, show_pwm, store_pwm, 4);
|
||||||
|
static SENSOR_DEVICE_ATTR(pwm6, S_IWUSR | S_IRUGO, show_pwm, store_pwm, 5);
|
||||||
|
static SENSOR_DEVICE_ATTR(pwm7, S_IWUSR | S_IRUGO, show_pwm, store_pwm, 6);
|
||||||
static SENSOR_DEVICE_ATTR(pwm1_enable, S_IWUSR | S_IRUGO,
|
static SENSOR_DEVICE_ATTR(pwm1_enable, S_IWUSR | S_IRUGO,
|
||||||
show_pwmenable, store_pwmenable, 1);
|
show_pwmenable, store_pwmenable, 1);
|
||||||
static SENSOR_DEVICE_ATTR(pwm2_enable, S_IWUSR | S_IRUGO,
|
static SENSOR_DEVICE_ATTR(pwm2_enable, S_IWUSR | S_IRUGO,
|
||||||
|
@ -1087,6 +1088,14 @@ static SENSOR_DEVICE_ATTR(pwm2_mode, S_IWUSR | S_IRUGO,
|
||||||
show_pwm_mode, store_pwm_mode, 1);
|
show_pwm_mode, store_pwm_mode, 1);
|
||||||
static SENSOR_DEVICE_ATTR(pwm3_mode, S_IWUSR | S_IRUGO,
|
static SENSOR_DEVICE_ATTR(pwm3_mode, S_IWUSR | S_IRUGO,
|
||||||
show_pwm_mode, store_pwm_mode, 2);
|
show_pwm_mode, store_pwm_mode, 2);
|
||||||
|
static SENSOR_DEVICE_ATTR(pwm4_mode, S_IWUSR | S_IRUGO,
|
||||||
|
show_pwm_mode, store_pwm_mode, 3);
|
||||||
|
static SENSOR_DEVICE_ATTR(pwm5_mode, S_IWUSR | S_IRUGO,
|
||||||
|
show_pwm_mode, store_pwm_mode, 4);
|
||||||
|
static SENSOR_DEVICE_ATTR(pwm6_mode, S_IWUSR | S_IRUGO,
|
||||||
|
show_pwm_mode, store_pwm_mode, 5);
|
||||||
|
static SENSOR_DEVICE_ATTR(pwm7_mode, S_IWUSR | S_IRUGO,
|
||||||
|
show_pwm_mode, store_pwm_mode, 6);
|
||||||
static SENSOR_DEVICE_ATTR(tolerance1, S_IWUSR | S_IRUGO,
|
static SENSOR_DEVICE_ATTR(tolerance1, S_IWUSR | S_IRUGO,
|
||||||
show_tolerance, store_tolerance, 1);
|
show_tolerance, store_tolerance, 1);
|
||||||
static SENSOR_DEVICE_ATTR(tolerance2, S_IWUSR | S_IRUGO,
|
static SENSOR_DEVICE_ATTR(tolerance2, S_IWUSR | S_IRUGO,
|
||||||
|
@ -1177,30 +1186,38 @@ static SENSOR_DEVICE_ATTR(fan6_div, S_IWUSR | S_IRUGO,
|
||||||
static SENSOR_DEVICE_ATTR(fan7_div, S_IWUSR | S_IRUGO,
|
static SENSOR_DEVICE_ATTR(fan7_div, S_IWUSR | S_IRUGO,
|
||||||
show_fan_div, store_fan_div, 7);
|
show_fan_div, store_fan_div, 7);
|
||||||
|
|
||||||
static struct attribute *w83792d_attributes_fan[4][5] = {
|
static struct attribute *w83792d_attributes_fan[4][7] = {
|
||||||
{
|
{
|
||||||
&sensor_dev_attr_fan4_input.dev_attr.attr,
|
&sensor_dev_attr_fan4_input.dev_attr.attr,
|
||||||
&sensor_dev_attr_fan4_min.dev_attr.attr,
|
&sensor_dev_attr_fan4_min.dev_attr.attr,
|
||||||
&sensor_dev_attr_fan4_div.dev_attr.attr,
|
&sensor_dev_attr_fan4_div.dev_attr.attr,
|
||||||
&sensor_dev_attr_fan4_alarm.dev_attr.attr,
|
&sensor_dev_attr_fan4_alarm.dev_attr.attr,
|
||||||
|
&sensor_dev_attr_pwm4.dev_attr.attr,
|
||||||
|
&sensor_dev_attr_pwm4_mode.dev_attr.attr,
|
||||||
NULL
|
NULL
|
||||||
}, {
|
}, {
|
||||||
&sensor_dev_attr_fan5_input.dev_attr.attr,
|
&sensor_dev_attr_fan5_input.dev_attr.attr,
|
||||||
&sensor_dev_attr_fan5_min.dev_attr.attr,
|
&sensor_dev_attr_fan5_min.dev_attr.attr,
|
||||||
&sensor_dev_attr_fan5_div.dev_attr.attr,
|
&sensor_dev_attr_fan5_div.dev_attr.attr,
|
||||||
&sensor_dev_attr_fan5_alarm.dev_attr.attr,
|
&sensor_dev_attr_fan5_alarm.dev_attr.attr,
|
||||||
|
&sensor_dev_attr_pwm5.dev_attr.attr,
|
||||||
|
&sensor_dev_attr_pwm5_mode.dev_attr.attr,
|
||||||
NULL
|
NULL
|
||||||
}, {
|
}, {
|
||||||
&sensor_dev_attr_fan6_input.dev_attr.attr,
|
&sensor_dev_attr_fan6_input.dev_attr.attr,
|
||||||
&sensor_dev_attr_fan6_min.dev_attr.attr,
|
&sensor_dev_attr_fan6_min.dev_attr.attr,
|
||||||
&sensor_dev_attr_fan6_div.dev_attr.attr,
|
&sensor_dev_attr_fan6_div.dev_attr.attr,
|
||||||
&sensor_dev_attr_fan6_alarm.dev_attr.attr,
|
&sensor_dev_attr_fan6_alarm.dev_attr.attr,
|
||||||
|
&sensor_dev_attr_pwm6.dev_attr.attr,
|
||||||
|
&sensor_dev_attr_pwm6_mode.dev_attr.attr,
|
||||||
NULL
|
NULL
|
||||||
}, {
|
}, {
|
||||||
&sensor_dev_attr_fan7_input.dev_attr.attr,
|
&sensor_dev_attr_fan7_input.dev_attr.attr,
|
||||||
&sensor_dev_attr_fan7_min.dev_attr.attr,
|
&sensor_dev_attr_fan7_min.dev_attr.attr,
|
||||||
&sensor_dev_attr_fan7_div.dev_attr.attr,
|
&sensor_dev_attr_fan7_div.dev_attr.attr,
|
||||||
&sensor_dev_attr_fan7_alarm.dev_attr.attr,
|
&sensor_dev_attr_fan7_alarm.dev_attr.attr,
|
||||||
|
&sensor_dev_attr_pwm7.dev_attr.attr,
|
||||||
|
&sensor_dev_attr_pwm7_mode.dev_attr.attr,
|
||||||
NULL
|
NULL
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue