Prepare v2023.10
[platform/kernel/u-boot.git] / lib / efi_selftest / efi_selftest_miniapp_exception.c
1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * efi_selftest_miniapp_return
4  *
5  * Copyright (c) 2019 Heinrich Schuchardt
6  *
7  * This EFI application triggers an exception.
8  */
9
10 #include <common.h>
11 #include <efi_api.h>
12 #include <host_arch.h>
13
14 /*
15  * Entry point of the EFI application.
16  *
17  * @handle      handle of the loaded image
18  * @systable    system table
19  * Return:      status code
20  */
21 efi_status_t EFIAPI efi_main(efi_handle_t handle,
22                              struct efi_system_table *systable)
23 {
24         struct efi_simple_text_output_protocol *con_out = systable->con_out;
25
26         con_out->output_string(con_out,
27                                u"EFI application triggers exception.\n");
28
29 #if defined(CONFIG_ARM)
30         /*
31          * 0xe7f...f.   is undefined in ARM mode
32          * 0xde..       is undefined in Thumb mode
33          */
34         asm volatile (".word 0xe7f7defb\n");
35 #elif defined(CONFIG_RISCV)
36         asm volatile (".word 0xffffffff\n");
37 #elif defined(CONFIG_X86)
38         asm volatile (".word 0xffff\n");
39 #elif defined(CONFIG_SANDBOX)
40 #if (HOST_ARCH == HOST_ARCH_ARM || HOST_ARCH == HOST_ARCH_AARCH64)
41         asm volatile (".word 0xe7f7defb\n");
42 #elif (HOST_ARCH == HOST_ARCH_RISCV32 || HOST_ARCH == HOST_ARCH_RISCV64)
43         asm volatile (".word 0xffffffff\n");
44 #elif (HOST_ARCH == HOST_ARCH_X86 || HOST_ARCH == HOST_ARCH_X86_64)
45         asm volatile (".word 0xffff\n");
46 #endif
47 #endif
48         con_out->output_string(con_out, u"Exception not triggered.\n");
49         return EFI_ABORTED;
50 }