xref: /optee_os/lib/libutee/include/pta_invoke_tests.h (revision 620e4edf164b22c44e59d1ed8f96d05a4a08f9d9)
1*620e4edfSEtienne Carriere /*
2*620e4edfSEtienne Carriere  * Copyright (c) 2017, Linaro Limited
3*620e4edfSEtienne Carriere  * All rights reserved.
4*620e4edfSEtienne Carriere  *
5*620e4edfSEtienne Carriere  * Redistribution and use in source and binary forms, with or without
6*620e4edfSEtienne Carriere  * modification, are permitted provided that the following conditions are met:
7*620e4edfSEtienne Carriere  *
8*620e4edfSEtienne Carriere  * 1. Redistributions of source code must retain the above copyright notice,
9*620e4edfSEtienne Carriere  * this list of conditions and the following disclaimer.
10*620e4edfSEtienne Carriere  *
11*620e4edfSEtienne Carriere  * 2. Redistributions in binary form must reproduce the above copyright notice,
12*620e4edfSEtienne Carriere  * this list of conditions and the following disclaimer in the documentation
13*620e4edfSEtienne Carriere  * and/or other materials provided with the distribution.
14*620e4edfSEtienne Carriere  *
15*620e4edfSEtienne Carriere  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
16*620e4edfSEtienne Carriere  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17*620e4edfSEtienne Carriere  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18*620e4edfSEtienne Carriere  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
19*620e4edfSEtienne Carriere  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
20*620e4edfSEtienne Carriere  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
21*620e4edfSEtienne Carriere  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
22*620e4edfSEtienne Carriere  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
23*620e4edfSEtienne Carriere  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
24*620e4edfSEtienne Carriere  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
25*620e4edfSEtienne Carriere  * POSSIBILITY OF SUCH DAMAGE.
26*620e4edfSEtienne Carriere  */
27*620e4edfSEtienne Carriere 
28*620e4edfSEtienne Carriere #ifndef __PTA_INVOKE_TESTS_H
29*620e4edfSEtienne Carriere #define __PTA_INVOKE_TESTS_H
30*620e4edfSEtienne Carriere 
31*620e4edfSEtienne Carriere #define PTA_INVOKE_TESTS_UUID \
32*620e4edfSEtienne Carriere 		{ 0xd96a5b40, 0xc3e5, 0x21e3, \
33*620e4edfSEtienne Carriere 			{ 0x87, 0x94, 0x10, 0x02, 0xa5, 0xd5, 0xc6, 0x1b } }
34*620e4edfSEtienne Carriere 
35*620e4edfSEtienne Carriere /* Trace some hello string. Parameters are not used/checked. */
36*620e4edfSEtienne Carriere #define PTA_INVOKE_TESTS_CMD_TRACE		0
37*620e4edfSEtienne Carriere 
38*620e4edfSEtienne Carriere /*
39*620e4edfSEtienne Carriere  * Types of parameter drives the test sequences:
40*620e4edfSEtienne Carriere  * - test on value parameters
41*620e4edfSEtienne Carriere  * - test on SHM memory reference parameters
42*620e4edfSEtienne Carriere  * - test on SDP memory reference parameters
43*620e4edfSEtienne Carriere  */
44*620e4edfSEtienne Carriere #define PTA_INVOKE_TESTS_CMD_PARAMS		1
45*620e4edfSEtienne Carriere 
46*620e4edfSEtienne Carriere /* Run some core internal tests. Parameters are not used/checked. */
47*620e4edfSEtienne Carriere #define PTA_INVOKE_TESTS_CMD_SELF_TESTS		2
48*620e4edfSEtienne Carriere 
49*620e4edfSEtienne Carriere /*
50*620e4edfSEtienne Carriere  * Secure data path: check that pTA can copy data from non-secure shared memory
51*620e4edfSEtienne Carriere  * to SDP secure memory
52*620e4edfSEtienne Carriere  *
53*620e4edfSEtienne Carriere  * [in]     memref[0]        source (non-secure shared memory)
54*620e4edfSEtienne Carriere  * [out]    memref[1]        destination (SDP secure memory)
55*620e4edfSEtienne Carriere  */
56*620e4edfSEtienne Carriere #define PTA_INVOKE_TESTS_CMD_COPY_NSEC_TO_SEC	3
57*620e4edfSEtienne Carriere 
58*620e4edfSEtienne Carriere /*
59*620e4edfSEtienne Carriere  * Secure data path: check that pTA can read data from SDP secure memory and
60*620e4edfSEtienne Carriere  * write it back. Data are processed so that client check the expected
61*620e4edfSEtienne Carriere  * read/write sequence succeed.
62*620e4edfSEtienne Carriere  *
63*620e4edfSEtienne Carriere  * [in/out]     memref[0]        SDP secure buffer to read from and write to
64*620e4edfSEtienne Carriere  */
65*620e4edfSEtienne Carriere #define PTA_INVOKE_TESTS_CMD_READ_MODIFY_SEC	4
66*620e4edfSEtienne Carriere 
67*620e4edfSEtienne Carriere /*
68*620e4edfSEtienne Carriere  * Secure data path: check that pTA can copy data from SDP secure memory to
69*620e4edfSEtienne Carriere  * non-secure shared memory
70*620e4edfSEtienne Carriere  *
71*620e4edfSEtienne Carriere  * [in]     memref[0]        source (SDP secure memory)
72*620e4edfSEtienne Carriere  * [out]    memref[1]        destination (non-secure shared memory)
73*620e4edfSEtienne Carriere  */
74*620e4edfSEtienne Carriere #define PTA_INVOKE_TESTS_CMD_COPY_SEC_TO_NSEC	5
75*620e4edfSEtienne Carriere 
76*620e4edfSEtienne Carriere #endif /*__PTA_INVOKE_TESTS_H*/
77*620e4edfSEtienne Carriere 
78