ChangeSet 1.2046, 2005/02/03 00:30:49-08:00, [EMAIL PROTECTED]

[PATCH] I2C: Do not show disabled pc87360 fans

The pc87360 driver create sysfs files even for disabled fans. Since data
won't ever be updated, it doesn't make much sense. The following patch
adds some tests to only create the interface files that are actually
needed.

Signed-off-by: Jean Delvare <[EMAIL PROTECTED]>
Signed-off-by: Greg Kroah-Hartman <[EMAIL PROTECTED]>


 drivers/i2c/chips/pc87360.c |   49 +++++++++++++++++++++++++++++++-------------
 1 files changed, 35 insertions(+), 14 deletions(-)


diff -Nru a/drivers/i2c/chips/pc87360.c b/drivers/i2c/chips/pc87360.c
--- a/drivers/i2c/chips/pc87360.c       2005-02-03 09:34:48 -08:00
+++ b/drivers/i2c/chips/pc87360.c       2005-02-03 09:34:48 -08:00
@@ -795,8 +795,10 @@
 
        /* Fan clock dividers may be needed before any data is read */
        for (i = 0; i < data->fannr; i++) {
-               data->fan_status[i] = pc87360_read_value(data, LD_FAN,
-                                     NO_BANK, PC87360_REG_FAN_STATUS(i));
+               if (FAN_CONFIG_MONITOR(data->fan_conf, i))
+                       data->fan_status[i] = pc87360_read_value(data,
+                                             LD_FAN, NO_BANK,
+                                             PC87360_REG_FAN_STATUS(i));
        }
 
        if (init > 0) {
@@ -898,14 +900,27 @@
        }
 
        if (data->fannr) {
-               device_create_file(&new_client->dev, &dev_attr_fan1_input);
-               device_create_file(&new_client->dev, &dev_attr_fan2_input);
-               device_create_file(&new_client->dev, &dev_attr_fan1_min);
-               device_create_file(&new_client->dev, &dev_attr_fan2_min);
-               device_create_file(&new_client->dev, &dev_attr_fan1_div);
-               device_create_file(&new_client->dev, &dev_attr_fan2_div);
-               device_create_file(&new_client->dev, &dev_attr_fan1_status);
-               device_create_file(&new_client->dev, &dev_attr_fan2_status);
+               if (FAN_CONFIG_MONITOR(data->fan_conf, 0)) {
+                       device_create_file(&new_client->dev,
+                                          &dev_attr_fan1_input);
+                       device_create_file(&new_client->dev,
+                                          &dev_attr_fan1_min);
+                       device_create_file(&new_client->dev,
+                                          &dev_attr_fan1_div);
+                       device_create_file(&new_client->dev,
+                                          &dev_attr_fan1_status);
+               }
+
+               if (FAN_CONFIG_MONITOR(data->fan_conf, 1)) {
+                       device_create_file(&new_client->dev,
+                                          &dev_attr_fan2_input);
+                       device_create_file(&new_client->dev,
+                                          &dev_attr_fan2_min);
+                       device_create_file(&new_client->dev,
+                                          &dev_attr_fan2_div);
+                       device_create_file(&new_client->dev,
+                                          &dev_attr_fan2_status);
+               }
 
                if (FAN_CONFIG_CONTROL(data->fan_conf, 0))
                        device_create_file(&new_client->dev, &dev_attr_pwm1);
@@ -913,10 +928,16 @@
                        device_create_file(&new_client->dev, &dev_attr_pwm2);
        }
        if (data->fannr == 3) {
-               device_create_file(&new_client->dev, &dev_attr_fan3_input);
-               device_create_file(&new_client->dev, &dev_attr_fan3_min);
-               device_create_file(&new_client->dev, &dev_attr_fan3_div);
-               device_create_file(&new_client->dev, &dev_attr_fan3_status);
+               if (FAN_CONFIG_MONITOR(data->fan_conf, 2)) {
+                       device_create_file(&new_client->dev,
+                                          &dev_attr_fan3_input);
+                       device_create_file(&new_client->dev,
+                                          &dev_attr_fan3_min);
+                       device_create_file(&new_client->dev,
+                                          &dev_attr_fan3_div);
+                       device_create_file(&new_client->dev,
+                                          &dev_attr_fan3_status);
+               }
 
                if (FAN_CONFIG_CONTROL(data->fan_conf, 2))
                        device_create_file(&new_client->dev, &dev_attr_pwm3);

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to