blob: 37cce2550514bdd814cb5726993ecf6df9580261 [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 */
Mingyang Sunae774162021-07-08 15:18:14 +080018#define TFM_SP_IDLE_ID (1)
19#define INVALID_PARTITION_ID (~0U)
20
Mingyang Sun00df2352021-04-15 15:46:08 +080021/* Encode a magic number into version for validating partition info */
22#define PARTITION_INFO_VERSION_MASK (0x0000FFFF)
23#define PARTITION_INFO_MAGIC_MASK (0xFFFF0000)
24#define PARTITION_INFO_MAGIC (0x5F5F0000)
25
Mingyang Sun00df2352021-04-15 15:46:08 +080026/*
Ken Liu4520ce32021-05-11 22:49:10 +080027 * Partition load data - flags
Ken Liu897e8f12022-02-10 03:21:17 +010028 * bit 7-0: priority
29 * bit 8: 1 - PSA_ROT, 0 - APP_ROT
30 * bit 9: 1 - IPC model, 0 - SFN model
Mingyang Sun00df2352021-04-15 15:46:08 +080031 */
32#define PARTITION_PRI_HIGHEST (0x0)
33#define PARTITION_PRI_HIGH (0xF)
34#define PARTITION_PRI_NORMAL (0x1F)
35#define PARTITION_PRI_LOW (0x7F)
36#define PARTITION_PRI_LOWEST (0xFF)
37#define PARTITION_PRI_MASK (0xFF)
38
Ken Liu897e8f12022-02-10 03:21:17 +010039#define PARTITION_MODEL_PSA_ROT (1U << 8)
Ken Liu59728d02021-10-06 12:47:39 +080040#define PARTITION_MODEL_IPC (1U << 9)
Mingyang Sun00df2352021-04-15 15:46:08 +080041
Chris Brandc422cdd2022-07-21 13:32:47 -070042#define PARTITION_NS_AGENT (1U << 10)
43
Ken Liuacd2a572021-05-12 16:19:04 +080044#define PARTITION_PRIORITY(flag) ((flag) & PARTITION_PRI_MASK)
45#define TO_THREAD_PRIORITY(x) (x)
46
47#define ENTRY_TO_POSITION(x) (uintptr_t)(x)
48#define POSITION_TO_ENTRY(x, t) (t)(x)
Ken Liu5d73c872021-08-19 19:23:17 +080049
50#define PTR_TO_REFERENCE(x) (uintptr_t)(x)
51#define REFERENCE_TO_PTR(x, t) (t)(x)
52
Kevin Peng56c571e2022-01-10 14:06:05 +080053#define IS_PARTITION_PSA_ROT(pldi) (!!((pldi)->flags \
Ken Liu897e8f12022-02-10 03:21:17 +010054 & PARTITION_MODEL_PSA_ROT))
Kevin Peng56c571e2022-01-10 14:06:05 +080055#define IS_PARTITION_IPC_MODEL(pldi) (!!((pldi)->flags \
Ken Liu897e8f12022-02-10 03:21:17 +010056 & PARTITION_MODEL_IPC))
Chris Brandc422cdd2022-07-21 13:32:47 -070057#define IS_PARTITION_NS_AGENT(pldi) (!!((pldi)->flags \
58 & PARTITION_NS_AGENT))
Kevin Peng56c571e2022-01-10 14:06:05 +080059
Mingyang Sunf0851842021-05-11 11:44:19 +080060/*
61 * Common partition structure type, the extendable data is right after it.
62 * Extendable data has different size for each partition, and must be 4-byte
63 * aligned. It includes: stack and heap position, dependencies, services and
64 * assets data.
65 */
Ken Liu4520ce32021-05-11 22:49:10 +080066struct partition_load_info_t {
Mingyang Sun00df2352021-04-15 15:46:08 +080067 uint32_t psa_ff_ver; /* Encode the version with magic */
Kevin Pengeec41a82021-08-18 13:56:23 +080068 int32_t pid; /* Partition ID */
Mingyang Sun00df2352021-04-15 15:46:08 +080069 uint32_t flags; /* ARoT/PRoT, SFN/IPC, priority */
70 uintptr_t entry; /* Entry point */
71 size_t stack_size; /* Stack size */
72 size_t heap_size; /* Heap size */
73 uint32_t ndeps; /* Dependency number */
74 uint32_t nservices; /* Service number */
Ken Liu86686282021-04-27 11:11:15 +080075 uint32_t nassets; /* Asset numbers */
Kevin Peng27e42272021-05-24 17:58:53 +080076 uint32_t nirqs; /* Number of IRQ owned by Partition */
Mingyang Sun00df2352021-04-15 15:46:08 +080077} __attribute__((aligned(4)));
78
79#endif /* __PARTITION_DEFS_H__ */