blob: 65e15b797329c7ccebcfce2d27ec66e7360e0b7f [file] [log] [blame]
Mingyang Sun00df2352021-04-15 15:46:08 +08001/*
Kevin Peng56c571e2022-01-10 14:06:05 +08002 * Copyright (c) 2021-2022, Arm Limited. All rights reserved.
Chris Brandb4c2b002022-07-21 12:54:00 -07003 * Copyright (c) 2022 Cypress Semiconductor Corporation (an Infineon
4 * company) or an affiliate of Cypress Semiconductor Corporation. All rights
5 * reserved.
Mingyang Sun00df2352021-04-15 15:46:08 +08006 *
7 * SPDX-License-Identifier: BSD-3-Clause
8 *
9 */
10
11#ifndef __PARTITION_DEFS_H__
12#define __PARTITION_DEFS_H__
13
14#include <stddef.h>
15#include <stdint.h>
16
Mingyang Sunae774162021-07-08 15:18:14 +080017/* TF-M internal partition ID */
18#define TFM_SP_NON_SECURE_ID (0)
19#define TFM_SP_IDLE_ID (1)
20#define INVALID_PARTITION_ID (~0U)
21
Mingyang Sun00df2352021-04-15 15:46:08 +080022/* Encode a magic number into version for validating partition info */
23#define PARTITION_INFO_VERSION_MASK (0x0000FFFF)
24#define PARTITION_INFO_MAGIC_MASK (0xFFFF0000)
25#define PARTITION_INFO_MAGIC (0x5F5F0000)
26
Mingyang Sun00df2352021-04-15 15:46:08 +080027/*
Ken Liu4520ce32021-05-11 22:49:10 +080028 * Partition load data - flags
Ken Liu897e8f12022-02-10 03:21:17 +010029 * bit 7-0: priority
30 * bit 8: 1 - PSA_ROT, 0 - APP_ROT
31 * bit 9: 1 - IPC model, 0 - SFN model
Mingyang Sun00df2352021-04-15 15:46:08 +080032 */
33#define PARTITION_PRI_HIGHEST (0x0)
34#define PARTITION_PRI_HIGH (0xF)
35#define PARTITION_PRI_NORMAL (0x1F)
36#define PARTITION_PRI_LOW (0x7F)
37#define PARTITION_PRI_LOWEST (0xFF)
38#define PARTITION_PRI_MASK (0xFF)
39
Ken Liu897e8f12022-02-10 03:21:17 +010040#define PARTITION_MODEL_PSA_ROT (1U << 8)
Ken Liu59728d02021-10-06 12:47:39 +080041#define PARTITION_MODEL_IPC (1U << 9)
Mingyang Sun00df2352021-04-15 15:46:08 +080042
Ken Liuacd2a572021-05-12 16:19:04 +080043#define PARTITION_PRIORITY(flag) ((flag) & PARTITION_PRI_MASK)
44#define TO_THREAD_PRIORITY(x) (x)
45
46#define ENTRY_TO_POSITION(x) (uintptr_t)(x)
47#define POSITION_TO_ENTRY(x, t) (t)(x)
Ken Liu5d73c872021-08-19 19:23:17 +080048
49#define PTR_TO_REFERENCE(x) (uintptr_t)(x)
50#define REFERENCE_TO_PTR(x, t) (t)(x)
51
Kevin Peng56c571e2022-01-10 14:06:05 +080052#define IS_PARTITION_PSA_ROT(pldi) (!!((pldi)->flags \
Ken Liu897e8f12022-02-10 03:21:17 +010053 & PARTITION_MODEL_PSA_ROT))
Kevin Peng56c571e2022-01-10 14:06:05 +080054#define IS_PARTITION_IPC_MODEL(pldi) (!!((pldi)->flags \
Ken Liu897e8f12022-02-10 03:21:17 +010055 & PARTITION_MODEL_IPC))
Chris Brandb4c2b002022-07-21 12:54:00 -070056#define IS_PARTITION_NS_AGENT(pldi) ((pldi)->pid == TFM_SP_NON_SECURE_ID)
Kevin Peng56c571e2022-01-10 14:06:05 +080057
Mingyang Sunf0851842021-05-11 11:44:19 +080058/*
59 * Common partition structure type, the extendable data is right after it.
60 * Extendable data has different size for each partition, and must be 4-byte
61 * aligned. It includes: stack and heap position, dependencies, services and
62 * assets data.
63 */
Ken Liu4520ce32021-05-11 22:49:10 +080064struct partition_load_info_t {
Mingyang Sun00df2352021-04-15 15:46:08 +080065 uint32_t psa_ff_ver; /* Encode the version with magic */
Kevin Pengeec41a82021-08-18 13:56:23 +080066 int32_t pid; /* Partition ID */
Mingyang Sun00df2352021-04-15 15:46:08 +080067 uint32_t flags; /* ARoT/PRoT, SFN/IPC, priority */
68 uintptr_t entry; /* Entry point */
69 size_t stack_size; /* Stack size */
70 size_t heap_size; /* Heap size */
71 uint32_t ndeps; /* Dependency number */
72 uint32_t nservices; /* Service number */
Ken Liu86686282021-04-27 11:11:15 +080073 uint32_t nassets; /* Asset numbers */
Kevin Peng27e42272021-05-24 17:58:53 +080074 uint32_t nirqs; /* Number of IRQ owned by Partition */
Mingyang Sun00df2352021-04-15 15:46:08 +080075} __attribute__((aligned(4)));
76
77#endif /* __PARTITION_DEFS_H__ */