提交 1783e4bf 编写于 作者: T Thomas Renninger 提交者: Dave Airlie

drm radeon: Return -EINVAL on wrong pm sysfs access

Throw an error if someone tries to fill this with
wrong data, instead of simply ignoring the input.
Now you get:

echo hello >/sys/../power_method
-bash: echo: write error: Invalid argument
Signed-off-by: NThomas Renninger <trenn@suse.de>
CC: Alexander.Deucher@amd.com
CC: dri-devel@lists.freedesktop.org
Reviewed-by: NAlex Deucher <alexdeucher@gmail.com>
Signed-off-by: NDave Airlie <airlied@redhat.com>
上级 fafcf94e
...@@ -365,12 +365,14 @@ static ssize_t radeon_set_pm_profile(struct device *dev, ...@@ -365,12 +365,14 @@ static ssize_t radeon_set_pm_profile(struct device *dev,
else if (strncmp("high", buf, strlen("high")) == 0) else if (strncmp("high", buf, strlen("high")) == 0)
rdev->pm.profile = PM_PROFILE_HIGH; rdev->pm.profile = PM_PROFILE_HIGH;
else { else {
DRM_ERROR("invalid power profile!\n"); count = -EINVAL;
goto fail; goto fail;
} }
radeon_pm_update_profile(rdev); radeon_pm_update_profile(rdev);
radeon_pm_set_clocks(rdev); radeon_pm_set_clocks(rdev);
} } else
count = -EINVAL;
fail: fail:
mutex_unlock(&rdev->pm.mutex); mutex_unlock(&rdev->pm.mutex);
...@@ -413,7 +415,7 @@ static ssize_t radeon_set_pm_method(struct device *dev, ...@@ -413,7 +415,7 @@ static ssize_t radeon_set_pm_method(struct device *dev,
mutex_unlock(&rdev->pm.mutex); mutex_unlock(&rdev->pm.mutex);
cancel_delayed_work_sync(&rdev->pm.dynpm_idle_work); cancel_delayed_work_sync(&rdev->pm.dynpm_idle_work);
} else { } else {
DRM_ERROR("invalid power method!\n"); count = -EINVAL;
goto fail; goto fail;
} }
radeon_pm_compute_clocks(rdev); radeon_pm_compute_clocks(rdev);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册