blob: e6522118e7e2029ca1ea97d6535ad249cadb66bf (
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, Arm Limited. All rights reserved.
*
* SPDX-License-Identifier: BSD-3-Clause
*/
#include <arch_helpers.h>
#include <sdei.h>
#include <tftf_lib.h>
#ifndef AARCH32
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
|