aboutsummaryrefslogtreecommitdiff
path: root/arch/arm/include/asm/bL_switcher.h
diff options
context:
space:
mode:
authorDave Martin <Dave.Martin@arm.com>2013-06-18 14:37:02 +0100
committerNicolas Pitre <nicolas.pitre@linaro.org>2013-06-20 00:45:27 -0400
commit4725d41daea7e0cc79b3fb92af012b8cb18fccff (patch)
tree65dc3ec132d758a2d01b8b9cddf8d95654ffa233 /arch/arm/include/asm/bL_switcher.h
parent0e95b2814e880cb031550d7c812c622df37f9154 (diff)
downloadvexpress-lsk-4725d41daea7e0cc79b3fb92af012b8cb18fccff.tar.gz
ARM: bL_switcher: Allow detachment of outstanding switch requests
In rare situations, it may be neecssary to prevent a completer registered using bL_switch_request_cb() from being called. For example, a cpufreq driver module needs to ensure that its completer won't get called if the module is about to be unloaded from the kernel. This patch provides a bL_switch_request_detach() function which detaches the completer from an outstanding request. The request continues in the background, as if it had been started using bL_switch_request(). If somebody else's completer is registered instead then the caller shouldn't care about it, so nothing is done in this case. Signed-off-by: Dave Martin <Dave.Martin@arm.com> Acked-by: Viresh Kumar <viresh.kumar@linaro.org> Signed-off-by: Nicolas Pitre <nicolas.pitre@linaro.org>
Diffstat (limited to 'arch/arm/include/asm/bL_switcher.h')
-rw-r--r--arch/arm/include/asm/bL_switcher.h6
1 files changed, 6 insertions, 0 deletions
diff --git a/arch/arm/include/asm/bL_switcher.h b/arch/arm/include/asm/bL_switcher.h
index 98427597828..71d1b6a986b 100644
--- a/arch/arm/include/asm/bL_switcher.h
+++ b/arch/arm/include/asm/bL_switcher.h
@@ -40,6 +40,9 @@ static inline int bL_switch_request(unsigned int cpu, unsigned int new_cluster_i
#ifdef CONFIG_BL_SWITCHER
+void bL_switch_request_detach(unsigned int cpu,
+ bL_switch_completion_handler completer);
+
int bL_switcher_register_notifier(struct notifier_block *nb);
int bL_switcher_unregister_notifier(struct notifier_block *nb);
@@ -55,6 +58,9 @@ bool bL_switcher_get_enabled(void);
void bL_switcher_put_enabled(void);
#else
+static void bL_switch_request_detach(unsigned int cpu,
+ bL_switch_completion_handler completer) { }
+
static inline int bL_switcher_register_notifier(struct notifier_block *nb)
{
return 0;