1*1bfc1082SMarouene Boubakri // SPDX-License-Identifier: BSD-2-Clause
2*1bfc1082SMarouene Boubakri /*
3*1bfc1082SMarouene Boubakri * Copyright (c) 2017, Linaro Limited
4*1bfc1082SMarouene Boubakri * Copyright (c) 2020, Arm Limited.
5*1bfc1082SMarouene Boubakri */
6*1bfc1082SMarouene Boubakri #include <crypto/crypto.h>
7*1bfc1082SMarouene Boubakri #include <initcall.h>
8*1bfc1082SMarouene Boubakri #include <kernel/early_ta.h>
9*1bfc1082SMarouene Boubakri #include <kernel/embedded_ts.h>
10*1bfc1082SMarouene Boubakri #include <kernel/ts_store.h>
11*1bfc1082SMarouene Boubakri #include <kernel/user_ta.h>
12*1bfc1082SMarouene Boubakri #include <stdio.h>
13*1bfc1082SMarouene Boubakri #include <string.h>
14*1bfc1082SMarouene Boubakri #include <trace.h>
15*1bfc1082SMarouene Boubakri #include <utee_defines.h>
16*1bfc1082SMarouene Boubakri #include <util.h>
17*1bfc1082SMarouene Boubakri
find_early_ta(const TEE_UUID * uuid)18*1bfc1082SMarouene Boubakri static const struct embedded_ts *find_early_ta(const TEE_UUID *uuid)
19*1bfc1082SMarouene Boubakri {
20*1bfc1082SMarouene Boubakri const struct embedded_ts *ta = NULL;
21*1bfc1082SMarouene Boubakri
22*1bfc1082SMarouene Boubakri for_each_early_ta(ta)
23*1bfc1082SMarouene Boubakri if (!memcmp(&ta->uuid, uuid, sizeof(*uuid)))
24*1bfc1082SMarouene Boubakri return ta;
25*1bfc1082SMarouene Boubakri
26*1bfc1082SMarouene Boubakri return NULL;
27*1bfc1082SMarouene Boubakri }
28*1bfc1082SMarouene Boubakri
early_ta_open(const TEE_UUID * uuid,struct ts_store_handle ** h)29*1bfc1082SMarouene Boubakri static TEE_Result early_ta_open(const TEE_UUID *uuid,
30*1bfc1082SMarouene Boubakri struct ts_store_handle **h)
31*1bfc1082SMarouene Boubakri {
32*1bfc1082SMarouene Boubakri return emb_ts_open(uuid, h, find_early_ta);
33*1bfc1082SMarouene Boubakri }
34*1bfc1082SMarouene Boubakri
35*1bfc1082SMarouene Boubakri REGISTER_TA_STORE(2) = {
36*1bfc1082SMarouene Boubakri .description = "early TA",
37*1bfc1082SMarouene Boubakri .open = early_ta_open,
38*1bfc1082SMarouene Boubakri .get_size = emb_ts_get_size,
39*1bfc1082SMarouene Boubakri .get_tag = emb_ts_get_tag,
40*1bfc1082SMarouene Boubakri .read = emb_ts_read,
41*1bfc1082SMarouene Boubakri .close = emb_ts_close,
42*1bfc1082SMarouene Boubakri };
43*1bfc1082SMarouene Boubakri
early_ta_init(void)44*1bfc1082SMarouene Boubakri static TEE_Result early_ta_init(void)
45*1bfc1082SMarouene Boubakri {
46*1bfc1082SMarouene Boubakri const struct embedded_ts *ta = NULL;
47*1bfc1082SMarouene Boubakri char __maybe_unused msg[60] = { '\0', };
48*1bfc1082SMarouene Boubakri
49*1bfc1082SMarouene Boubakri for_each_early_ta(ta) {
50*1bfc1082SMarouene Boubakri if (ta->uncompressed_size)
51*1bfc1082SMarouene Boubakri snprintf(msg, sizeof(msg),
52*1bfc1082SMarouene Boubakri " (compressed, uncompressed %u)",
53*1bfc1082SMarouene Boubakri ta->uncompressed_size);
54*1bfc1082SMarouene Boubakri else
55*1bfc1082SMarouene Boubakri msg[0] = '\0';
56*1bfc1082SMarouene Boubakri DMSG("Early TA %pUl size %u%s", (void *)&ta->uuid, ta->size,
57*1bfc1082SMarouene Boubakri msg);
58*1bfc1082SMarouene Boubakri }
59*1bfc1082SMarouene Boubakri
60*1bfc1082SMarouene Boubakri return TEE_SUCCESS;
61*1bfc1082SMarouene Boubakri }
62*1bfc1082SMarouene Boubakri
63*1bfc1082SMarouene Boubakri service_init(early_ta_init);
64