Skip to content

Commit 60cdeae

Browse files
stephan-ghvireshk
authored andcommitted
opp: Reduce code duplication in _set_required_opps()
Move call to dev_pm_genpd_set_performance_state() to a separate function so we can avoid duplicating the code for the single and multiple genpd case. Signed-off-by: Stephan Gerhold <stephan@gerhold.net> [ Viresh: Validate virtual device before use ] Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
1 parent 475ac8e commit 60cdeae

1 file changed

Lines changed: 22 additions & 21 deletions

File tree

drivers/opp/core.c

Lines changed: 22 additions & 21 deletions
Original file line numberDiff line numberDiff line change
@@ -779,29 +779,39 @@ static int _set_opp_custom(const struct opp_table *opp_table,
779779
return opp_table->set_opp(data);
780780
}
781781

782+
static int _set_required_opp(struct device *dev, struct device *pd_dev,
783+
struct dev_pm_opp *opp, int i)
784+
{
785+
unsigned int pstate = likely(opp) ? opp->required_opps[i]->pstate : 0;
786+
int ret;
787+
788+
if (!pd_dev)
789+
return 0;
790+
791+
ret = dev_pm_genpd_set_performance_state(pd_dev, pstate);
792+
if (ret) {
793+
dev_err(dev, "Failed to set performance rate of %s: %d (%d)\n",
794+
dev_name(pd_dev), pstate, ret);
795+
}
796+
797+
return ret;
798+
}
799+
782800
/* This is only called for PM domain for now */
783801
static int _set_required_opps(struct device *dev,
784802
struct opp_table *opp_table,
785803
struct dev_pm_opp *opp)
786804
{
787805
struct opp_table **required_opp_tables = opp_table->required_opp_tables;
788806
struct device **genpd_virt_devs = opp_table->genpd_virt_devs;
789-
unsigned int pstate;
790807
int i, ret = 0;
791808

792809
if (!required_opp_tables)
793810
return 0;
794811

795812
/* Single genpd case */
796-
if (!genpd_virt_devs) {
797-
pstate = likely(opp) ? opp->required_opps[0]->pstate : 0;
798-
ret = dev_pm_genpd_set_performance_state(dev, pstate);
799-
if (ret) {
800-
dev_err(dev, "Failed to set performance state of %s: %d (%d)\n",
801-
dev_name(dev), pstate, ret);
802-
}
803-
return ret;
804-
}
813+
if (!genpd_virt_devs)
814+
return _set_required_opp(dev, dev, opp, 0);
805815

806816
/* Multiple genpd case */
807817

@@ -810,19 +820,10 @@ static int _set_required_opps(struct device *dev,
810820
* after it is freed from another thread.
811821
*/
812822
mutex_lock(&opp_table->genpd_virt_dev_lock);
813-
814823
for (i = 0; i < opp_table->required_opp_count; i++) {
815-
pstate = likely(opp) ? opp->required_opps[i]->pstate : 0;
816-
817-
if (!genpd_virt_devs[i])
818-
continue;
819-
820-
ret = dev_pm_genpd_set_performance_state(genpd_virt_devs[i], pstate);
821-
if (ret) {
822-
dev_err(dev, "Failed to set performance rate of %s: %d (%d)\n",
823-
dev_name(genpd_virt_devs[i]), pstate, ret);
824+
ret = _set_required_opp(dev, genpd_virt_devs[i], opp, i);
825+
if (ret)
824826
break;
825-
}
826827
}
827828
mutex_unlock(&opp_table->genpd_virt_dev_lock);
828829

0 commit comments

Comments
 (0)