blob: 2e13a6f96b3f9ae3a4e982d617c4bc7a5fe83dde [file] [log] [blame]
Sandrine Bailleux3cd87d72018-10-09 11:12:55 +02001/*
J-Alves9f6f0142020-06-17 15:37:59 +01002 * Copyright (c) 2017-2020, Arm Limited. All rights reserved.
Sandrine Bailleux3cd87d72018-10-09 11:12:55 +02003 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 */
6
Antonio Nino Diaz1486f3b2018-06-26 10:30:10 +01007#ifndef CACTUS_TESTS_H
8#define CACTUS_TESTS_H
Sandrine Bailleux3cd87d72018-10-09 11:12:55 +02009
Max Shvetsovc32f4782020-06-23 09:41:15 +010010#include <ffa_helpers.h>
11
Sandrine Bailleux3cd87d72018-10-09 11:12:55 +020012/*
13 * Test functions
14 */
15
16/*
J-Alves9f6f0142020-06-17 15:37:59 +010017 * Test to FFA interfaces.
18 */
Max Shvetsovc32f4782020-06-23 09:41:15 +010019void ffa_tests(struct mailbox_buffers *mb);
J-Alves9f6f0142020-06-17 15:37:59 +010020
21/*
Sandrine Bailleux3cd87d72018-10-09 11:12:55 +020022 * Test other things like the version number returned by SPM.
23 */
24void misc_tests(void);
25
26/*
27 * The Arm TF is responsible for setting up system registers on behalf of the
28 * Secure Partition. For example, TF is supposed to allow Secure Partitions to
29 * perform cache maintenance operations (by setting the SCTLR_EL1.UCI bit).
30 *
31 * This function attempts to verify that we indeed have access to these system
32 * features from S-EL0. These tests report their results on the UART. They do
33 * not recover from a failure : when an error is encountered they will most
34 * likely trigger an exception into S-EL1.
35 */
36void system_setup_tests(void);
37
38/*
39 * Exercise the SP_MEMORY_ATTRIBUTES_SET_AARCH64 SMC interface. A variety of
40 * valid and invalid requests to change memory attributes are tested.
41 *
42 * These tests report their results on the UART. They do not recover from a
43 * failure : when an error is encountered they endlessly loop.
Sandrine Bailleux3cd87d72018-10-09 11:12:55 +020044 */
Antonio Nino Diaz1486f3b2018-06-26 10:30:10 +010045void mem_attr_changes_tests(void);
Sandrine Bailleux3cd87d72018-10-09 11:12:55 +020046
Antonio Nino Diaz1486f3b2018-06-26 10:30:10 +010047#endif /* CACTUS_TESTS_H */