Due to the requirement of of_changesets that of_changeset_apply be called holding the of_mutex and that the of_mutex cannot be accessed nicely outside the of code, added a wrapper which grabs the lock and called of_changeset_apply.
Signed-off-by: Cyril Bur <cyril....@au1.ibm.com> --- drivers/of/dynamic.c | 11 +++++++++++ include/linux/of.h | 1 + 2 files changed, 12 insertions(+) diff --git a/drivers/of/dynamic.c b/drivers/of/dynamic.c index 54fecc4..cbff2a2 100644 --- a/drivers/of/dynamic.c +++ b/drivers/of/dynamic.c @@ -542,6 +542,17 @@ void of_changeset_destroy(struct of_changeset *ocs) __of_changeset_entry_destroy(ce); } +int of_changeset_apply_locked(struct of_changeset *ocs) +{ + int ret; + + mutex_lock(&of_mutex); + ret = of_changeset_apply(ocs); + mutex_unlock(&of_mutex); + + return ret; +} + /** * of_changeset_apply - Applies a changeset * diff --git a/include/linux/of.h b/include/linux/of.h index 6c4363b..f5c48fa 100644 --- a/include/linux/of.h +++ b/include/linux/of.h @@ -827,6 +827,7 @@ struct of_changeset { extern void of_changeset_init(struct of_changeset *ocs); extern void of_changeset_destroy(struct of_changeset *ocs); extern int of_changeset_apply(struct of_changeset *ocs); +extern int of_changeset_apply_locked(struct of_changeset *ocs); extern int of_changeset_revert(struct of_changeset *ocs); extern int of_changeset_action(struct of_changeset *ocs, unsigned long action, struct device_node *np, -- 1.9.1 _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev