mirror of
https://github.com/ARM-software/arm-trusted-firmware.git
synced 2025-04-22 04:24:19 +00:00
SPMD: lock the g_spmd_pm structure
Add a lock and spin lock/unlock calls when accessing the fields of the SPMD PM structure. Signed-off-by: Olivier Deprez <olivier.deprez@arm.com> Change-Id: I9bab705564dc1ba003c29512b1f9be5f126fbb0d
This commit is contained in:
parent
cdb49d475e
commit
473ced5670
1 changed files with 18 additions and 3 deletions
|
@ -7,11 +7,13 @@
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <lib/el3_runtime/context_mgmt.h>
|
#include <lib/el3_runtime/context_mgmt.h>
|
||||||
|
#include <lib/spinlock.h>
|
||||||
#include "spmd_private.h"
|
#include "spmd_private.h"
|
||||||
|
|
||||||
static struct {
|
static struct {
|
||||||
bool secondary_ep_locked;
|
bool secondary_ep_locked;
|
||||||
uintptr_t secondary_ep;
|
uintptr_t secondary_ep;
|
||||||
|
spinlock_t lock;
|
||||||
} g_spmd_pm;
|
} g_spmd_pm;
|
||||||
|
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
|
@ -34,8 +36,12 @@ static void spmd_build_spmc_message(gp_regs_t *gpregs, unsigned long long messag
|
||||||
******************************************************************************/
|
******************************************************************************/
|
||||||
int spmd_pm_secondary_ep_register(uintptr_t entry_point)
|
int spmd_pm_secondary_ep_register(uintptr_t entry_point)
|
||||||
{
|
{
|
||||||
|
int ret = FFA_ERROR_INVALID_PARAMETER;
|
||||||
|
|
||||||
|
spin_lock(&g_spmd_pm.lock);
|
||||||
|
|
||||||
if (g_spmd_pm.secondary_ep_locked == true) {
|
if (g_spmd_pm.secondary_ep_locked == true) {
|
||||||
return FFA_ERROR_INVALID_PARAMETER;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -45,7 +51,7 @@ int spmd_pm_secondary_ep_register(uintptr_t entry_point)
|
||||||
if (!spmd_check_address_in_binary_image(entry_point)) {
|
if (!spmd_check_address_in_binary_image(entry_point)) {
|
||||||
ERROR("%s entry point is not within image boundaries\n",
|
ERROR("%s entry point is not within image boundaries\n",
|
||||||
__func__);
|
__func__);
|
||||||
return FFA_ERROR_INVALID_PARAMETER;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
g_spmd_pm.secondary_ep = entry_point;
|
g_spmd_pm.secondary_ep = entry_point;
|
||||||
|
@ -53,7 +59,12 @@ int spmd_pm_secondary_ep_register(uintptr_t entry_point)
|
||||||
|
|
||||||
VERBOSE("%s %lx\n", __func__, entry_point);
|
VERBOSE("%s %lx\n", __func__, entry_point);
|
||||||
|
|
||||||
return 0;
|
ret = 0;
|
||||||
|
|
||||||
|
out:
|
||||||
|
spin_unlock(&g_spmd_pm.lock);
|
||||||
|
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
|
@ -73,6 +84,8 @@ static void spmd_cpu_on_finish_handler(u_register_t unused)
|
||||||
assert(ctx->state != SPMC_STATE_ON);
|
assert(ctx->state != SPMC_STATE_ON);
|
||||||
assert(spmc_ep_info != NULL);
|
assert(spmc_ep_info != NULL);
|
||||||
|
|
||||||
|
spin_lock(&g_spmd_pm.lock);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Leave the possibility that the SPMC does not call
|
* Leave the possibility that the SPMC does not call
|
||||||
* FFA_SECONDARY_EP_REGISTER in which case re-use the
|
* FFA_SECONDARY_EP_REGISTER in which case re-use the
|
||||||
|
@ -82,6 +95,8 @@ static void spmd_cpu_on_finish_handler(u_register_t unused)
|
||||||
spmc_ep_info->pc = g_spmd_pm.secondary_ep;
|
spmc_ep_info->pc = g_spmd_pm.secondary_ep;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
spin_unlock(&g_spmd_pm.lock);
|
||||||
|
|
||||||
cm_setup_context(&ctx->cpu_ctx, spmc_ep_info);
|
cm_setup_context(&ctx->cpu_ctx, spmc_ep_info);
|
||||||
|
|
||||||
/* Mark CPU as initiating ON operation */
|
/* Mark CPU as initiating ON operation */
|
||||||
|
|
Loading…
Add table
Reference in a new issue