MALI: midgard: support sharing regulator with other devices
authorFinley Xiao <finley.xiao@rock-chips.com>
Mon, 28 Nov 2016 11:40:09 +0000 (19:40 +0800)
committerFinley Xiao <finley.xiao@rock-chips.com>
Tue, 29 Nov 2016 06:18:22 +0000 (14:18 +0800)
If the regulator is shared between several devices then the lowest
request voltage that meets the system constraints will be used.

Change-Id: I7dda43b24c7e19098db65b51ae0c4386b46ee0b7
Signed-off-by: Finley Xiao <finley.xiao@rock-chips.com>
drivers/gpu/arm/midgard/backend/gpu/mali_kbase_devfreq.c

index fd3c1f58a7d409b35da10c8195802476d74376ff..083810f853ae050b6949de966a685c3e95f4641b 100644 (file)
@@ -76,7 +76,7 @@ kbase_devfreq_target(struct device *dev, unsigned long *target_freq, u32 flags)
 #ifdef CONFIG_REGULATOR
                if (kbdev->current_voltage == voltage)
                        return 0;
-               err = regulator_set_voltage(kbdev->regulator, voltage, voltage);
+               err = regulator_set_voltage(kbdev->regulator, voltage, INT_MAX);
                if (err) {
                        dev_err(dev, "Failed to set voltage (%d)\n", err);
                        return err;
@@ -89,7 +89,7 @@ kbase_devfreq_target(struct device *dev, unsigned long *target_freq, u32 flags)
 #ifdef CONFIG_REGULATOR
        if (kbdev->regulator && kbdev->current_voltage != voltage &&
            old_freq < freq) {
-               err = regulator_set_voltage(kbdev->regulator, voltage, voltage);
+               err = regulator_set_voltage(kbdev->regulator, voltage, INT_MAX);
                if (err) {
                        dev_err(dev, "Failed to increase voltage (%d)\n", err);
                        return err;
@@ -113,7 +113,7 @@ kbase_devfreq_target(struct device *dev, unsigned long *target_freq, u32 flags)
 #ifdef CONFIG_REGULATOR
        if (kbdev->regulator && kbdev->current_voltage != voltage &&
            old_freq > freq) {
-               err = regulator_set_voltage(kbdev->regulator, voltage, voltage);
+               err = regulator_set_voltage(kbdev->regulator, voltage, INT_MAX);
                if (err) {
                        dev_err(dev, "Failed to decrease voltage (%d)\n", err);
                        return err;