PM / OPP: fix incorrect OPP count handling in of_init_opp_table
authorChander Kashyap <chander.kashyap@linaro.org>
Fri, 16 May 2014 10:51:17 +0000 (16:21 +0530)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Mon, 19 May 2014 21:02:36 +0000 (23:02 +0200)
In of_init_opp_table function, if a failure to add an OPP is
detected, the count of OPPs, yet to be added is not updated.
Fix this by decrementing this count on failure as well.

Signed-off-by: Chander Kashyap <k.chander@samsung.com>
Signed-off-by: Inderpal Singh <inderpal.s@samsung.com>
Acked-by: Viresh Kumar <viresh.kumar@linaro.org>
Cc: 3.7+ <stable@vger.kernel.org> # 3.7+
Acked-by: Nishanth Menon <nm@ti.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
drivers/base/power/opp.c

index 25538675d59e29ced3e8f72db2f31fe1427b920f..c539d70b97abde7c98b3d9f6d0ca190c5a0d91df 100644 (file)
@@ -734,11 +734,9 @@ int of_init_opp_table(struct device *dev)
                unsigned long freq = be32_to_cpup(val++) * 1000;
                unsigned long volt = be32_to_cpup(val++);
 
-               if (dev_pm_opp_add(dev, freq, volt)) {
+               if (dev_pm_opp_add(dev, freq, volt))
                        dev_warn(dev, "%s: Failed to add OPP %ld\n",
                                 __func__, freq);
-                       continue;
-               }
                nr -= 2;
        }