From 17b4c0dd0a12b1c306057b71182e25a69807ff89 Mon Sep 17 00:00:00 2001 From: Dimitris Papastamos <dimitris.papastamos@arm.com> Date: Fri, 13 Oct 2017 15:27:58 +0100 Subject: [PATCH] aarch64: Add PubSub events to capture security state transitions Add events that trigger before entry to normal/secure world. The events trigger after the normal/secure context has been restored. Similarly add events that trigger after leaving normal/secure world. The events trigger after the normal/secure context has been saved. Change-Id: I1b48a7ea005d56b1f25e2b5313d77e67d2f02bc5 Signed-off-by: Dimitris Papastamos <dimitris.papastamos@arm.com> --- docs/firmware-design.rst | 22 ++++++---------------- include/lib/el3_runtime/pubsub_events.h | 18 ++++++++++++++++++ lib/el3_runtime/aarch64/context_mgmt.c | 20 +++++++++++++++++--- 3 files changed, 41 insertions(+), 19 deletions(-) diff --git a/docs/firmware-design.rst b/docs/firmware-design.rst index 853e39011..7cc197096 100644 --- a/docs/firmware-design.rst +++ b/docs/firmware-design.rst @@ -2309,6 +2309,12 @@ PE only; it won't cause handlers to execute on a different PE. Note that publishing an event on a PE blocks until all the subscribed handlers finish executing on the PE. +ARM Trusted Firmware generic code publishes and subscribes to some events +within. Platform ports are discouraged from subscribing to them. These events +may be withdrawn, renamed, or have their semantics altered in the future. +Platforms may however register, publish, and subscribe to platform-specific +events. + Publish and Subscribe Example ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ @@ -2339,22 +2345,6 @@ implement: SUBSCRIBE_TO_EVENT(foo, foo_handler); -Available Events -~~~~~~~~~~~~~~~~ - -ARM Trusted Firmware core makes some events available by default. They're listed -below, along with information as to when they're published, and the arguments -passed to subscribed handlers. - -Other EL3 components that are conditionally compiled in may make their own -events available, but aren't documented here. - -- ``psci_cpu_on_finish`` - - - When: Published on a PE after it's finished its power-up sequence. - - - Argument: ``NULL``. - Performance Measurement Framework --------------------------------- diff --git a/include/lib/el3_runtime/pubsub_events.h b/include/lib/el3_runtime/pubsub_events.h index 62550f81e..9cfedb4de 100644 --- a/include/lib/el3_runtime/pubsub_events.h +++ b/include/lib/el3_runtime/pubsub_events.h @@ -16,3 +16,21 @@ * initialization. */ REGISTER_PUBSUB_EVENT(psci_cpu_on_finish); + +#ifdef AARCH64 +/* + * These events are published by the AArch64 context management framework + * after the secure context is restored/saved via + * cm_el1_sysregs_context_{restore,save}() API. + */ +REGISTER_PUBSUB_EVENT(cm_entering_secure_world); +REGISTER_PUBSUB_EVENT(cm_exited_secure_world); + +/* + * These events are published by the AArch64 context management framework + * after the normal context is restored/saved via + * cm_el1_sysregs_context_{restore,save}() API. + */ +REGISTER_PUBSUB_EVENT(cm_entering_normal_world); +REGISTER_PUBSUB_EVENT(cm_exited_normal_world); +#endif /* AARCH64 */ diff --git a/lib/el3_runtime/aarch64/context_mgmt.c b/lib/el3_runtime/aarch64/context_mgmt.c index 21e86de05..c8232df96 100644 --- a/lib/el3_runtime/aarch64/context_mgmt.c +++ b/lib/el3_runtime/aarch64/context_mgmt.c @@ -13,6 +13,7 @@ #include <interrupt_mgmt.h> #include <platform.h> #include <platform_def.h> +#include <pubsub_events.h> #include <smcc_helpers.h> #include <string.h> #include <utils.h> @@ -421,9 +422,8 @@ void cm_prepare_el3_exit(uint32_t security_state) } } - el1_sysregs_context_restore(get_sysregs_ctx(ctx)); - - cm_set_next_context(ctx); + cm_el1_sysregs_context_restore(security_state); + cm_set_next_eret_context(security_state); } /******************************************************************************* @@ -440,6 +440,13 @@ void cm_el1_sysregs_context_save(uint32_t security_state) el1_sysregs_context_save(get_sysregs_ctx(ctx)); el1_sysregs_context_save_post_ops(); + +#if IMAGE_BL31 + if (security_state == SECURE) + PUBLISH_EVENT(cm_exited_secure_world); + else + PUBLISH_EVENT(cm_exited_normal_world); +#endif } void cm_el1_sysregs_context_restore(uint32_t security_state) @@ -450,6 +457,13 @@ void cm_el1_sysregs_context_restore(uint32_t security_state) assert(ctx); el1_sysregs_context_restore(get_sysregs_ctx(ctx)); + +#if IMAGE_BL31 + if (security_state == SECURE) + PUBLISH_EVENT(cm_entering_secure_world); + else + PUBLISH_EVENT(cm_entering_normal_world); +#endif } /******************************************************************************* -- GitLab