aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/radeon/evergreen.c
diff options
context:
space:
mode:
authorAlex Deucher <alexdeucher@gmail.com>2010-06-07 18:15:18 -0400
committerDave Airlie <airlied@redhat.com>2010-06-07 19:35:53 -0400
commit4d60173fc1b12b0c308f861620fe8e2a84f6e5da (patch)
treedd42b72d50e0859e632b2e9ffd0b7c0961b7bf86 /drivers/gpu/drm/radeon/evergreen.c
parentaa1df0f229829109e49d1dc493252fd94a7af2a1 (diff)
drm/radeon/kms/pm: track current voltage (v2)
track the current voltage level and avoid setting it if the requested voltage is already set. v2: check voltage type before checking current voltage Signed-off-by: Alex Deucher <alexdeucher@gmail.com> Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers/gpu/drm/radeon/evergreen.c')
-rw-r--r--drivers/gpu/drm/radeon/evergreen.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/drivers/gpu/drm/radeon/evergreen.c b/drivers/gpu/drm/radeon/evergreen.c
index 49c94aef0dd..b86d6ac9c5b 100644
--- a/drivers/gpu/drm/radeon/evergreen.c
+++ b/drivers/gpu/drm/radeon/evergreen.c
@@ -45,8 +45,12 @@ void evergreen_pm_misc(struct radeon_device *rdev)
45 struct radeon_power_state *ps = &rdev->pm.power_state[requested_index]; 45 struct radeon_power_state *ps = &rdev->pm.power_state[requested_index];
46 struct radeon_voltage *voltage = &ps->clock_info[0].voltage; 46 struct radeon_voltage *voltage = &ps->clock_info[0].voltage;
47 47
48 if ((voltage->type == VOLTAGE_SW) && voltage->voltage) 48 if ((voltage->type == VOLTAGE_SW) && voltage->voltage) {
49 radeon_atom_set_voltage(rdev, voltage->voltage); 49 if (voltage->voltage != rdev->pm.current_vddc) {
50 radeon_atom_set_voltage(rdev, voltage->voltage);
51 rdev->pm.current_vddc = voltage->voltage;
52 }
53 }
50} 54}
51 55
52void evergreen_pm_prepare(struct radeon_device *rdev) 56void evergreen_pm_prepare(struct radeon_device *rdev)