Skip to content

Commit e213cd8

Browse files
committed
Merge branch 'opp/fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/vireshk/pm
Pull operating performance points (OPP) framework fixes for 5.10-rc2 from Viresh Kumar: "- Don't remove the static OPPs erroneously. - Check for the right condition before making an early exit. - Avoid a lockdep by reducing the size of the critical section." * 'opp/fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/vireshk/pm: opp: Reduce the size of critical section in _opp_table_kref_release() opp: Fix early exit from dev_pm_opp_register_set_opp_helper() opp: Don't always remove static OPPs in _of_add_opp_table_v1()
2 parents 3650b22 + e0df59d commit e213cd8

2 files changed

Lines changed: 7 additions & 4 deletions

File tree

drivers/opp/core.c

Lines changed: 5 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1181,6 +1181,10 @@ static void _opp_table_kref_release(struct kref *kref)
11811181
struct opp_device *opp_dev, *temp;
11821182
int i;
11831183

1184+
/* Drop the lock as soon as we can */
1185+
list_del(&opp_table->node);
1186+
mutex_unlock(&opp_table_lock);
1187+
11841188
_of_clear_opp_table(opp_table);
11851189

11861190
/* Release clk */
@@ -1208,10 +1212,7 @@ static void _opp_table_kref_release(struct kref *kref)
12081212

12091213
mutex_destroy(&opp_table->genpd_virt_dev_lock);
12101214
mutex_destroy(&opp_table->lock);
1211-
list_del(&opp_table->node);
12121215
kfree(opp_table);
1213-
1214-
mutex_unlock(&opp_table_lock);
12151216
}
12161217

12171218
void dev_pm_opp_put_opp_table(struct opp_table *opp_table)
@@ -1930,7 +1931,7 @@ struct opp_table *dev_pm_opp_register_set_opp_helper(struct device *dev,
19301931
return ERR_PTR(-EINVAL);
19311932

19321933
opp_table = dev_pm_opp_get_opp_table(dev);
1933-
if (!IS_ERR(opp_table))
1934+
if (IS_ERR(opp_table))
19341935
return opp_table;
19351936

19361937
/* This should be called before OPPs are initialized */

drivers/opp/of.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -944,6 +944,8 @@ static int _of_add_opp_table_v1(struct device *dev, struct opp_table *opp_table)
944944
nr -= 2;
945945
}
946946

947+
return 0;
948+
947949
remove_static_opp:
948950
_opp_remove_all_static(opp_table);
949951

0 commit comments

Comments
 (0)