xref: /optee_os/lib/libutee/arch/arm/gprof/gprof_pta.c (revision 1bb929836182ecb96d2d9d268daa807c67596396)
1*1bb92983SJerome Forissier // SPDX-License-Identifier: BSD-2-Clause
2883c4be3SJerome Forissier /*
3883c4be3SJerome Forissier  * Copyright (c) 2016, Linaro Limited
4883c4be3SJerome Forissier  * All rights reserved.
5883c4be3SJerome Forissier  *
6883c4be3SJerome Forissier  * Redistribution and use in source and binary forms, with or without
7883c4be3SJerome Forissier  * modification, are permitted provided that the following conditions are met:
8883c4be3SJerome Forissier  *
9883c4be3SJerome Forissier  * 1. Redistributions of source code must retain the above copyright notice,
10883c4be3SJerome Forissier  * this list of conditions and the following disclaimer.
11883c4be3SJerome Forissier  *
12883c4be3SJerome Forissier  * 2. Redistributions in binary form must reproduce the above copyright notice,
13883c4be3SJerome Forissier  * this list of conditions and the following disclaimer in the documentation
14883c4be3SJerome Forissier  * and/or other materials provided with the distribution.
15883c4be3SJerome Forissier  *
16883c4be3SJerome Forissier  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17883c4be3SJerome Forissier  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18883c4be3SJerome Forissier  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19883c4be3SJerome Forissier  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
20883c4be3SJerome Forissier  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21883c4be3SJerome Forissier  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22883c4be3SJerome Forissier  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
23883c4be3SJerome Forissier  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
24883c4be3SJerome Forissier  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
25883c4be3SJerome Forissier  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
26883c4be3SJerome Forissier  * POSSIBILITY OF SUCH DAMAGE.
27883c4be3SJerome Forissier  */
28883c4be3SJerome Forissier 
29883c4be3SJerome Forissier #include <pta_gprof.h>
30883c4be3SJerome Forissier #include <string.h>
31883c4be3SJerome Forissier #include <tee_api.h>
32883c4be3SJerome Forissier #include "gprof_pta.h"
33883c4be3SJerome Forissier 
34883c4be3SJerome Forissier static TEE_TASessionHandle sess = TEE_HANDLE_NULL;
35883c4be3SJerome Forissier 
36883c4be3SJerome Forissier static TEE_Result invoke_gprof_pta(uint32_t cmd_id, uint32_t param_types,
37883c4be3SJerome Forissier 				   TEE_Param params[TEE_NUM_PARAMS])
38883c4be3SJerome Forissier {
39883c4be3SJerome Forissier 	static const TEE_UUID core_uuid = PTA_GPROF_UUID;
40883c4be3SJerome Forissier 	TEE_Result res;
41883c4be3SJerome Forissier 
42883c4be3SJerome Forissier 	if (!sess) {
43883c4be3SJerome Forissier 		res = TEE_OpenTASession(&core_uuid, 0, 0, NULL, &sess, NULL);
44883c4be3SJerome Forissier 		if (res != TEE_SUCCESS)
45883c4be3SJerome Forissier 			return res;
46883c4be3SJerome Forissier 	}
47883c4be3SJerome Forissier 	res = TEE_InvokeTACommand(sess, 0, cmd_id, param_types, params, NULL);
48883c4be3SJerome Forissier 	return res;
49883c4be3SJerome Forissier }
50883c4be3SJerome Forissier 
51883c4be3SJerome Forissier TEE_Result __pta_gprof_send(void *buf, size_t len, uint32_t *id)
52883c4be3SJerome Forissier {
53883c4be3SJerome Forissier 	TEE_Param params[TEE_NUM_PARAMS];
54883c4be3SJerome Forissier 	uint32_t param_types;
55883c4be3SJerome Forissier 	TEE_Result res;
56883c4be3SJerome Forissier 
57883c4be3SJerome Forissier 	param_types = TEE_PARAM_TYPES(TEE_PARAM_TYPE_VALUE_INOUT,
58883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_MEMREF_INPUT,
59883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_NONE,
60883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_NONE);
61883c4be3SJerome Forissier 	memset(params, 0, sizeof(params));
62883c4be3SJerome Forissier 	params[0].value.a = *id;
63883c4be3SJerome Forissier 	params[1].memref.buffer = buf;
64883c4be3SJerome Forissier 	params[1].memref.size = len;
65883c4be3SJerome Forissier 	res = invoke_gprof_pta(PTA_GPROF_SEND, param_types, params);
66883c4be3SJerome Forissier 	if (res == TEE_SUCCESS)
67883c4be3SJerome Forissier 		*id = params[0].value.a;
68883c4be3SJerome Forissier 	return res;
69883c4be3SJerome Forissier }
70883c4be3SJerome Forissier 
71883c4be3SJerome Forissier TEE_Result __pta_gprof_pc_sampling_start(void *buf, size_t len, size_t offset,
72883c4be3SJerome Forissier 					 size_t scale)
73883c4be3SJerome Forissier {
74883c4be3SJerome Forissier 	TEE_Param params[TEE_NUM_PARAMS];
75883c4be3SJerome Forissier 	uint32_t param_types;
76883c4be3SJerome Forissier 
77883c4be3SJerome Forissier 	param_types = TEE_PARAM_TYPES(TEE_PARAM_TYPE_MEMREF_INOUT,
78883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_VALUE_INPUT,
79883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_NONE,
80883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_NONE);
81883c4be3SJerome Forissier 	memset(params, 0, sizeof(params));
82883c4be3SJerome Forissier 	params[0].memref.buffer = buf;
83883c4be3SJerome Forissier 	params[0].memref.size = len;
84883c4be3SJerome Forissier 	params[1].value.a = offset;
85883c4be3SJerome Forissier 	params[1].value.b = scale;
86883c4be3SJerome Forissier 	return invoke_gprof_pta(PTA_GPROF_START_PC_SAMPLING, param_types,
87883c4be3SJerome Forissier 				params);
88883c4be3SJerome Forissier }
89883c4be3SJerome Forissier 
90883c4be3SJerome Forissier TEE_Result __pta_gprof_pc_sampling_stop(uint32_t *rate)
91883c4be3SJerome Forissier {
92883c4be3SJerome Forissier 	TEE_Param params[TEE_NUM_PARAMS];
93883c4be3SJerome Forissier 	uint32_t param_types;
94883c4be3SJerome Forissier 	TEE_Result res;
95883c4be3SJerome Forissier 
96883c4be3SJerome Forissier 	param_types = TEE_PARAM_TYPES(TEE_PARAM_TYPE_VALUE_OUTPUT,
97883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_NONE,
98883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_NONE,
99883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_NONE);
100883c4be3SJerome Forissier 	memset(params, 0, sizeof(params));
101883c4be3SJerome Forissier 	res = invoke_gprof_pta(PTA_GPROF_STOP_PC_SAMPLING, param_types,
102883c4be3SJerome Forissier 				params);
103883c4be3SJerome Forissier 	if (res != TEE_SUCCESS)
104883c4be3SJerome Forissier 		return res;
105883c4be3SJerome Forissier 	if (rate)
106883c4be3SJerome Forissier 		*rate = params[0].value.a;
107883c4be3SJerome Forissier 	return res;
108883c4be3SJerome Forissier }
109883c4be3SJerome Forissier 
110883c4be3SJerome Forissier void __pta_gprof_fini(void)
111883c4be3SJerome Forissier {
112883c4be3SJerome Forissier 	if (sess)
113883c4be3SJerome Forissier 		TEE_CloseTASession(sess);
114883c4be3SJerome Forissier }
115