blob: 2f063caba298de7634f02c73138b38f25b73d168 [file] [log] [blame]
Mingyang Sundeae45d2021-09-06 15:31:07 +08001/*
Mingyang Suna09adda2022-02-16 18:11:33 +08002 * Copyright (c) 2021-2022, Arm Limited. All rights reserved.
Mingyang Sundeae45d2021-09-06 15:31:07 +08003 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 *
6 */
7
8#ifndef __BACKEND_H__
9#define __BACKEND_H__
10
11#include <stdint.h>
Mingyang Sundeae45d2021-09-06 15:31:07 +080012#include "spm_ipc.h"
Ken Liue07c3b72021-10-14 16:19:13 +080013#include "tfm_arch.h"
Mingyang Sundeae45d2021-09-06 15:31:07 +080014#include "load/spm_load_api.h"
Ken Liue07c3b72021-10-14 16:19:13 +080015#include "psa/error.h"
Mingyang Sundeae45d2021-09-06 15:31:07 +080016
Ken Liu82a38832022-05-23 09:46:52 +080017#if CONFIG_TFM_SPM_BACKEND_IPC == 1
18#include "backend_ipc.h"
19#elif CONFIG_TFM_SPM_BACKEND_SFN == 1
20#include "backend_sfn.h"
21#else
22#error "No backend selected, check configurations."
23#endif
24
Ken Liu995a9742022-05-18 19:28:30 +080025/*
26 * Runtime model-specific component initialization routine. This
27 * is an `assuredly` function, would panic if any error occurred.
28 */
29void backend_init_comp_assuredly(struct partition_t *p_pt,
30 uint32_t service_setting);
Mingyang Sundeae45d2021-09-06 15:31:07 +080031
Ken Liu995a9742022-05-18 19:28:30 +080032/*
33 * Runtime model-specific kick-off method for the whole system.
34 * Returns a hardware-specific control value, which is transparent
35 * to SPM common logic.
36 */
37uint32_t backend_system_run(void);
Mingyang Sundeae45d2021-09-06 15:31:07 +080038
Ken Liu995a9742022-05-18 19:28:30 +080039/* Runtime model-specific message handling mechanism. */
40psa_status_t backend_messaging(struct service_t *p_serv,
41 struct conn_handle_t *handle);
Mingyang Sundeae45d2021-09-06 15:31:07 +080042
Ken Liu995a9742022-05-18 19:28:30 +080043/*
44 * Runtime model-specific message replying.
45 * Return the connection handle or the acked status code.
46 */
47psa_status_t backend_replying(struct conn_handle_t *handle, int32_t status);
Mingyang Sundeae45d2021-09-06 15:31:07 +080048
Ken Liu995a9742022-05-18 19:28:30 +080049/*
50 * Runtime model-specific Partition wait operation.
51 * Put the Partition to a status that waits for signals.
52 */
53psa_signal_t backend_wait(struct partition_t *p_pt, psa_signal_t signal_mask);
Kevin Pengdef92de2021-11-10 16:14:48 +080054
Ken Liu995a9742022-05-18 19:28:30 +080055/*
56 * Runtime model-specific Partition wake up operation.
57 * Wakes up the Partition with the asserted signals in 'p_pt'.
58 */
59void backend_wake_up(struct partition_t *p_pt);
Kevin Pengdef92de2021-11-10 16:14:48 +080060
Mingyang Sundeae45d2021-09-06 15:31:07 +080061
62/* The component list, and a MACRO indicate this is not a common global. */
63extern struct partition_head_t partition_listhead;
64#define PARTITION_LIST_ADDR (&partition_listhead)
65
Ken Liue07c3b72021-10-14 16:19:13 +080066/* TODO: Put this into NS Agent related service when available. */
67extern struct context_ctrl_t *p_spm_thread_context;
68#define SPM_THREAD_CONTEXT p_spm_thread_context
69
Mingyang Sundeae45d2021-09-06 15:31:07 +080070#endif /* __BACKEND_H__ */