diff options
| author | Martin Peres <martin.peres@labri.fr> | 2013-03-14 19:59:55 -0400 |
|---|---|---|
| committer | Ben Skeggs <bskeggs@redhat.com> | 2013-03-17 21:15:27 -0400 |
| commit | 804ca90f3fe35dd7c12889eaa74a44abbc4b91fd (patch) | |
| tree | 24e219980f7c3684d79e2b38b5bfd0bb39923976 | |
| parent | 0b3ee3772e11da2f36c91e542545780d3ed28415 (diff) | |
drm/nouveau/hwmon: do not expose a buggy temperature if it is unavailable
Signed-off-by: Martin Peres <martin.peres@labri.fr>
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
| -rw-r--r-- | drivers/gpu/drm/nouveau/nouveau_pm.c | 44 |
1 files changed, 31 insertions, 13 deletions
diff --git a/drivers/gpu/drm/nouveau/nouveau_pm.c b/drivers/gpu/drm/nouveau/nouveau_pm.c index bb54098c6d97..936b442a6ab7 100644 --- a/drivers/gpu/drm/nouveau/nouveau_pm.c +++ b/drivers/gpu/drm/nouveau/nouveau_pm.c | |||
| @@ -402,8 +402,12 @@ nouveau_hwmon_show_temp(struct device *d, struct device_attribute *a, char *buf) | |||
| 402 | struct drm_device *dev = dev_get_drvdata(d); | 402 | struct drm_device *dev = dev_get_drvdata(d); |
| 403 | struct nouveau_drm *drm = nouveau_drm(dev); | 403 | struct nouveau_drm *drm = nouveau_drm(dev); |
| 404 | struct nouveau_therm *therm = nouveau_therm(drm->device); | 404 | struct nouveau_therm *therm = nouveau_therm(drm->device); |
| 405 | int temp = therm->temp_get(therm); | ||
| 405 | 406 | ||
| 406 | return snprintf(buf, PAGE_SIZE, "%d\n", therm->temp_get(therm) * 1000); | 407 | if (temp < 0) |
| 408 | return temp; | ||
| 409 | |||
| 410 | return snprintf(buf, PAGE_SIZE, "%d\n", temp * 1000); | ||
| 407 | } | 411 | } |
| 408 | static SENSOR_DEVICE_ATTR(temp1_input, S_IRUGO, nouveau_hwmon_show_temp, | 412 | static SENSOR_DEVICE_ATTR(temp1_input, S_IRUGO, nouveau_hwmon_show_temp, |
| 409 | NULL, 0); | 413 | NULL, 0); |
| @@ -871,7 +875,12 @@ static SENSOR_DEVICE_ATTR(pwm1_max, S_IRUGO | S_IWUSR, | |||
| 871 | nouveau_hwmon_get_pwm1_max, | 875 | nouveau_hwmon_get_pwm1_max, |
| 872 | nouveau_hwmon_set_pwm1_max, 0); | 876 | nouveau_hwmon_set_pwm1_max, 0); |
| 873 | 877 | ||
| 874 | static struct attribute *hwmon_attributes[] = { | 878 | static struct attribute *hwmon_default_attributes[] = { |
| 879 | &sensor_dev_attr_name.dev_attr.attr, | ||
| 880 | &sensor_dev_attr_update_rate.dev_attr.attr, | ||
| 881 | NULL | ||
| 882 | }; | ||
| 883 | static struct attribute *hwmon_temp_attributes[] = { | ||
| 875 | &sensor_dev_attr_temp1_input.dev_attr.attr, | 884 | &sensor_dev_attr_temp1_input.dev_attr.attr, |
| 876 | &sensor_dev_attr_temp1_auto_point1_pwm.dev_attr.attr, | 885 | &sensor_dev_attr_temp1_auto_point1_pwm.dev_attr.attr, |
| 877 | &sensor_dev_attr_temp1_auto_point1_temp.dev_attr.attr, | 886 | &sensor_dev_attr_temp1_auto_point1_temp.dev_attr.attr, |
| @@ -882,8 +891,6 @@ static struct attribute *hwmon_attributes[] = { | |||
| 882 | &sensor_dev_attr_temp1_crit_hyst.dev_attr.attr, | 891 | &sensor_dev_attr_temp1_crit_hyst.dev_attr.attr, |
| 883 | &sensor_dev_attr_temp1_emergency.dev_attr.attr, | 892 | &sensor_dev_attr_temp1_emergency.dev_attr.attr, |
| 884 | &sensor_dev_attr_temp1_emergency_hyst.dev_attr.attr, | 893 | &sensor_dev_attr_temp1_emergency_hyst.dev_attr.attr, |
| 885 | &sensor_dev_attr_name.dev_attr.attr, | ||
| 886 | &sensor_dev_attr_update_rate.dev_attr.attr, | ||
| 887 | NULL | 894 | NULL |
| 888 | }; | 895 | }; |
| 889 | static struct attribute *hwmon_fan_rpm_attributes[] = { | 896 | static struct attribute *hwmon_fan_rpm_attributes[] = { |
| @@ -898,8 +905,11 @@ static struct attribute *hwmon_pwm_fan_attributes[] = { | |||
| 898 | NULL | 905 | NULL |
| 899 | }; | 906 | }; |
| 900 | 907 | ||
| 901 | static const struct attribute_group hwmon_attrgroup = { | 908 | static const struct attribute_group hwmon_default_attrgroup = { |
| 902 | .attrs = hwmon_attributes, | 909 | .attrs = hwmon_default_attributes, |
| 910 | }; | ||
| 911 | static const struct attribute_group hwmon_temp_attrgroup = { | ||
| 912 | .attrs = hwmon_temp_attributes, | ||
| 903 | }; | 913 | }; |
| 904 | static const struct attribute_group hwmon_fan_rpm_attrgroup = { | 914 | static const struct attribute_group hwmon_fan_rpm_attrgroup = { |
| 905 | .attrs = hwmon_fan_rpm_attributes, | 915 | .attrs = hwmon_fan_rpm_attributes, |
| @@ -931,13 +941,22 @@ nouveau_hwmon_init(struct drm_device *dev) | |||
| 931 | } | 941 | } |
| 932 | dev_set_drvdata(hwmon_dev, dev); | 942 | dev_set_drvdata(hwmon_dev, dev); |
| 933 | 943 | ||
| 934 | /* default sysfs entries */ | 944 | /* set the default attributes */ |
| 935 | ret = sysfs_create_group(&hwmon_dev->kobj, &hwmon_attrgroup); | 945 | ret = sysfs_create_group(&hwmon_dev->kobj, &hwmon_default_attrgroup); |
| 936 | if (ret) { | 946 | if (ret) { |
| 937 | if (ret) | 947 | if (ret) |
| 938 | goto error; | 948 | goto error; |
| 939 | } | 949 | } |
| 940 | 950 | ||
| 951 | /* if the card has a working thermal sensor */ | ||
| 952 | if (therm->temp_get(therm) >= 0) { | ||
| 953 | ret = sysfs_create_group(&hwmon_dev->kobj, &hwmon_temp_attrgroup); | ||
| 954 | if (ret) { | ||
| 955 | if (ret) | ||
| 956 | goto error; | ||
| 957 | } | ||
| 958 | } | ||
| 959 | |||
| 941 | /* if the card has a pwm fan */ | 960 | /* if the card has a pwm fan */ |
| 942 | /*XXX: incorrect, need better detection for this, some boards have | 961 | /*XXX: incorrect, need better detection for this, some boards have |
| 943 | * the gpio entries for pwm fan control even when there's no | 962 | * the gpio entries for pwm fan control even when there's no |
| @@ -979,11 +998,10 @@ nouveau_hwmon_fini(struct drm_device *dev) | |||
| 979 | struct nouveau_pm *pm = nouveau_pm(dev); | 998 | struct nouveau_pm *pm = nouveau_pm(dev); |
| 980 | 999 | ||
| 981 | if (pm->hwmon) { | 1000 | if (pm->hwmon) { |
| 982 | sysfs_remove_group(&pm->hwmon->kobj, &hwmon_attrgroup); | 1001 | sysfs_remove_group(&pm->hwmon->kobj, &hwmon_default_attrgroup); |
| 983 | sysfs_remove_group(&pm->hwmon->kobj, | 1002 | sysfs_remove_group(&pm->hwmon->kobj, &hwmon_temp_attrgroup); |
| 984 | &hwmon_pwm_fan_attrgroup); | 1003 | sysfs_remove_group(&pm->hwmon->kobj, &hwmon_pwm_fan_attrgroup); |
| 985 | sysfs_remove_group(&pm->hwmon->kobj, | 1004 | sysfs_remove_group(&pm->hwmon->kobj, &hwmon_fan_rpm_attrgroup); |
| 986 | &hwmon_fan_rpm_attrgroup); | ||
| 987 | 1005 | ||
| 988 | hwmon_device_unregister(pm->hwmon); | 1006 | hwmon_device_unregister(pm->hwmon); |
| 989 | } | 1007 | } |
