summaryrefslogtreecommitdiff
path: root/tftf/tests/misc_tests/test_single_fault.c
blob: f55d8de8d24ec432a673c54b308c90097a2949ce (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/*
 * Copyright (c) 2018-2020, Arm Limited. All rights reserved.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */


#include <arch_helpers.h>
#include <sdei.h>
#include <tftf_lib.h>

#ifdef __aarch64__

uint64_t serror_received;

extern void inject_serror(void);

int serror_handler(int ev, uint64_t arg)
{
	serror_received = 1;
	tftf_testcase_printf("SError SDEI event received.\n");

	return 0;
}

extern int serror_sdei_event_handler(int ev, uint64_t arg);

test_result_t test_single_fault(void)
{
	int64_t ret;
	const int event_id = 5000;

	/* Register SDEI handler */
	ret = sdei_event_register(event_id, serror_sdei_event_handler, 0,
			SDEI_REGF_RM_PE, read_mpidr_el1());
	if (ret < 0) {
		tftf_testcase_printf("SDEI event register failed: 0x%llx\n",
			ret);
		return TEST_RESULT_FAIL;
	}

	ret = sdei_event_enable(event_id);
	if (ret < 0) {
		tftf_testcase_printf("SDEI event enable failed: 0x%llx\n", ret);
		return TEST_RESULT_FAIL;
	}

	ret = sdei_pe_unmask();
	if (ret < 0) {
		tftf_testcase_printf("SDEI pe unmask failed: 0x%llx\n", ret);
		return TEST_RESULT_FAIL;
	}

	inject_serror();

	return TEST_RESULT_SUCCESS;
}

#else

test_result_t test_single_fault(void)
{
	tftf_testcase_printf("Not supported on AArch32.\n");
	return TEST_RESULT_SKIPPED;
}

#endif