xref: /optee_os/lib/libutee/arch/arm/gprof/gprof_pta.c (revision 883c4be3d11cacf49665f51d1d6af4c02a0a0afd)
1*883c4be3SJerome Forissier /*
2*883c4be3SJerome Forissier  * Copyright (c) 2016, Linaro Limited
3*883c4be3SJerome Forissier  * All rights reserved.
4*883c4be3SJerome Forissier  *
5*883c4be3SJerome Forissier  * Redistribution and use in source and binary forms, with or without
6*883c4be3SJerome Forissier  * modification, are permitted provided that the following conditions are met:
7*883c4be3SJerome Forissier  *
8*883c4be3SJerome Forissier  * 1. Redistributions of source code must retain the above copyright notice,
9*883c4be3SJerome Forissier  * this list of conditions and the following disclaimer.
10*883c4be3SJerome Forissier  *
11*883c4be3SJerome Forissier  * 2. Redistributions in binary form must reproduce the above copyright notice,
12*883c4be3SJerome Forissier  * this list of conditions and the following disclaimer in the documentation
13*883c4be3SJerome Forissier  * and/or other materials provided with the distribution.
14*883c4be3SJerome Forissier  *
15*883c4be3SJerome Forissier  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
16*883c4be3SJerome Forissier  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17*883c4be3SJerome Forissier  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18*883c4be3SJerome Forissier  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
19*883c4be3SJerome Forissier  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
20*883c4be3SJerome Forissier  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
21*883c4be3SJerome Forissier  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22*883c4be3SJerome Forissier  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23*883c4be3SJerome Forissier  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
24*883c4be3SJerome Forissier  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25*883c4be3SJerome Forissier  * POSSIBILITY OF SUCH DAMAGE.
26*883c4be3SJerome Forissier  */
27*883c4be3SJerome Forissier 
28*883c4be3SJerome Forissier #include <pta_gprof.h>
29*883c4be3SJerome Forissier #include <string.h>
30*883c4be3SJerome Forissier #include <tee_api.h>
31*883c4be3SJerome Forissier #include "gprof_pta.h"
32*883c4be3SJerome Forissier 
33*883c4be3SJerome Forissier static TEE_TASessionHandle sess = TEE_HANDLE_NULL;
34*883c4be3SJerome Forissier 
35*883c4be3SJerome Forissier static TEE_Result invoke_gprof_pta(uint32_t cmd_id, uint32_t param_types,
36*883c4be3SJerome Forissier 				   TEE_Param params[TEE_NUM_PARAMS])
37*883c4be3SJerome Forissier {
38*883c4be3SJerome Forissier 	static const TEE_UUID core_uuid = PTA_GPROF_UUID;
39*883c4be3SJerome Forissier 	TEE_Result res;
40*883c4be3SJerome Forissier 
41*883c4be3SJerome Forissier 	if (!sess) {
42*883c4be3SJerome Forissier 		res = TEE_OpenTASession(&core_uuid, 0, 0, NULL, &sess, NULL);
43*883c4be3SJerome Forissier 		if (res != TEE_SUCCESS)
44*883c4be3SJerome Forissier 			return res;
45*883c4be3SJerome Forissier 	}
46*883c4be3SJerome Forissier 	res = TEE_InvokeTACommand(sess, 0, cmd_id, param_types, params, NULL);
47*883c4be3SJerome Forissier 	return res;
48*883c4be3SJerome Forissier }
49*883c4be3SJerome Forissier 
50*883c4be3SJerome Forissier TEE_Result __pta_gprof_send(void *buf, size_t len, uint32_t *id)
51*883c4be3SJerome Forissier {
52*883c4be3SJerome Forissier 	TEE_Param params[TEE_NUM_PARAMS];
53*883c4be3SJerome Forissier 	uint32_t param_types;
54*883c4be3SJerome Forissier 	TEE_Result res;
55*883c4be3SJerome Forissier 
56*883c4be3SJerome Forissier 	param_types = TEE_PARAM_TYPES(TEE_PARAM_TYPE_VALUE_INOUT,
57*883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_MEMREF_INPUT,
58*883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_NONE,
59*883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_NONE);
60*883c4be3SJerome Forissier 	memset(params, 0, sizeof(params));
61*883c4be3SJerome Forissier 	params[0].value.a = *id;
62*883c4be3SJerome Forissier 	params[1].memref.buffer = buf;
63*883c4be3SJerome Forissier 	params[1].memref.size = len;
64*883c4be3SJerome Forissier 	res = invoke_gprof_pta(PTA_GPROF_SEND, param_types, params);
65*883c4be3SJerome Forissier 	if (res == TEE_SUCCESS)
66*883c4be3SJerome Forissier 		*id = params[0].value.a;
67*883c4be3SJerome Forissier 	return res;
68*883c4be3SJerome Forissier }
69*883c4be3SJerome Forissier 
70*883c4be3SJerome Forissier TEE_Result __pta_gprof_pc_sampling_start(void *buf, size_t len, size_t offset,
71*883c4be3SJerome Forissier 					 size_t scale)
72*883c4be3SJerome Forissier {
73*883c4be3SJerome Forissier 	TEE_Param params[TEE_NUM_PARAMS];
74*883c4be3SJerome Forissier 	uint32_t param_types;
75*883c4be3SJerome Forissier 
76*883c4be3SJerome Forissier 	param_types = TEE_PARAM_TYPES(TEE_PARAM_TYPE_MEMREF_INOUT,
77*883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_VALUE_INPUT,
78*883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_NONE,
79*883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_NONE);
80*883c4be3SJerome Forissier 	memset(params, 0, sizeof(params));
81*883c4be3SJerome Forissier 	params[0].memref.buffer = buf;
82*883c4be3SJerome Forissier 	params[0].memref.size = len;
83*883c4be3SJerome Forissier 	params[1].value.a = offset;
84*883c4be3SJerome Forissier 	params[1].value.b = scale;
85*883c4be3SJerome Forissier 	return invoke_gprof_pta(PTA_GPROF_START_PC_SAMPLING, param_types,
86*883c4be3SJerome Forissier 				params);
87*883c4be3SJerome Forissier }
88*883c4be3SJerome Forissier 
89*883c4be3SJerome Forissier TEE_Result __pta_gprof_pc_sampling_stop(uint32_t *rate)
90*883c4be3SJerome Forissier {
91*883c4be3SJerome Forissier 	TEE_Param params[TEE_NUM_PARAMS];
92*883c4be3SJerome Forissier 	uint32_t param_types;
93*883c4be3SJerome Forissier 	TEE_Result res;
94*883c4be3SJerome Forissier 
95*883c4be3SJerome Forissier 	param_types = TEE_PARAM_TYPES(TEE_PARAM_TYPE_VALUE_OUTPUT,
96*883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_NONE,
97*883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_NONE,
98*883c4be3SJerome Forissier 				      TEE_PARAM_TYPE_NONE);
99*883c4be3SJerome Forissier 	memset(params, 0, sizeof(params));
100*883c4be3SJerome Forissier 	res = invoke_gprof_pta(PTA_GPROF_STOP_PC_SAMPLING, param_types,
101*883c4be3SJerome Forissier 				params);
102*883c4be3SJerome Forissier 	if (res != TEE_SUCCESS)
103*883c4be3SJerome Forissier 		return res;
104*883c4be3SJerome Forissier 	if (rate)
105*883c4be3SJerome Forissier 		*rate = params[0].value.a;
106*883c4be3SJerome Forissier 	return res;
107*883c4be3SJerome Forissier }
108*883c4be3SJerome Forissier 
109*883c4be3SJerome Forissier void __pta_gprof_fini(void)
110*883c4be3SJerome Forissier {
111*883c4be3SJerome Forissier 	if (sess)
112*883c4be3SJerome Forissier 		TEE_CloseTASession(sess);
113*883c4be3SJerome Forissier }
114