Ken Liu | 2e43489 | 2022-02-16 12:10:16 +0800 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (c) 2022, Arm Limited. All rights reserved. |
| 3 | * |
| 4 | * SPDX-License-Identifier: BSD-3-Clause |
| 5 | * |
| 6 | */ |
| 7 | #include "cmsis.h" |
Joakim Andersson | 7df331f | 2022-05-30 16:21:13 +0200 | [diff] [blame] | 8 | #include "utilities.h" |
Dávid Házi | be7f0de | 2023-07-19 11:25:38 +0200 | [diff] [blame] | 9 | /* "exception_info.h" must be the last include because of the IAR pragma */ |
| 10 | #include "exception_info.h" |
Ken Liu | 2e43489 | 2022-02-16 12:10:16 +0800 | [diff] [blame] | 11 | |
Joakim Andersson | 7df331f | 2022-05-30 16:21:13 +0200 | [diff] [blame] | 12 | void C_HardFault_Handler(void) |
Ken Liu | 2e43489 | 2022-02-16 12:10:16 +0800 | [diff] [blame] | 13 | { |
Ken Liu | 2e43489 | 2022-02-16 12:10:16 +0800 | [diff] [blame] | 14 | /* A HardFault may indicate corruption of secure state, so it is essential |
| 15 | * that Non-secure code does not regain control after one is raised. |
| 16 | * Returning from this exception could allow a pending NS exception to be |
| 17 | * taken, so the current solution is not to return. |
| 18 | */ |
Joakim Andersson | 7df331f | 2022-05-30 16:21:13 +0200 | [diff] [blame] | 19 | tfm_core_panic(); |
| 20 | } |
| 21 | |
| 22 | __attribute__((naked)) void HardFault_Handler(void) |
| 23 | { |
| 24 | EXCEPTION_INFO(EXCEPTION_TYPE_HARDFAULT); |
| 25 | |
| 26 | __ASM volatile( |
| 27 | "bl C_HardFault_Handler \n" |
| 28 | "b . \n" |
| 29 | ); |
| 30 | } |
| 31 | |
| 32 | void C_MemManage_Handler(void) |
| 33 | { |
| 34 | /* A MemManage fault may indicate corruption of secure state, so it is |
| 35 | * essential that Non-secure code does not regain control after one is |
| 36 | * raised. Returning from this exception could allow a pending NS exception |
| 37 | * to be taken, so the current solution is to panic. |
| 38 | */ |
| 39 | tfm_core_panic(); |
Ken Liu | 2e43489 | 2022-02-16 12:10:16 +0800 | [diff] [blame] | 40 | } |
| 41 | |
| 42 | __attribute__((naked)) void MemManage_Handler(void) |
| 43 | { |
| 44 | EXCEPTION_INFO(EXCEPTION_TYPE_MEMFAULT); |
| 45 | |
Joakim Andersson | 7df331f | 2022-05-30 16:21:13 +0200 | [diff] [blame] | 46 | __ASM volatile( |
| 47 | "bl C_MemManage_Handler \n" |
| 48 | "b . \n" |
| 49 | ); |
| 50 | } |
| 51 | |
| 52 | void C_BusFault_Handler(void) |
| 53 | { |
| 54 | /* A BusFault may indicate corruption of secure state, so it is essential |
| 55 | * that Non-secure code does not regain control after one is raised. |
| 56 | * Returning from this exception could allow a pending NS exception to be |
| 57 | * taken, so the current solution is to panic. |
Ken Liu | 2e43489 | 2022-02-16 12:10:16 +0800 | [diff] [blame] | 58 | */ |
Joakim Andersson | 7df331f | 2022-05-30 16:21:13 +0200 | [diff] [blame] | 59 | tfm_core_panic(); |
Ken Liu | 2e43489 | 2022-02-16 12:10:16 +0800 | [diff] [blame] | 60 | } |
| 61 | |
| 62 | __attribute__((naked)) void BusFault_Handler(void) |
| 63 | { |
| 64 | EXCEPTION_INFO(EXCEPTION_TYPE_BUSFAULT); |
| 65 | |
Joakim Andersson | 7df331f | 2022-05-30 16:21:13 +0200 | [diff] [blame] | 66 | __ASM volatile( |
| 67 | "bl C_BusFault_Handler \n" |
| 68 | "b . \n" |
| 69 | ); |
| 70 | } |
| 71 | |
| 72 | void C_SecureFault_Handler(void) |
| 73 | { |
| 74 | /* A SecureFault may indicate corruption of secure state, so it is essential |
Ken Liu | 2e43489 | 2022-02-16 12:10:16 +0800 | [diff] [blame] | 75 | * that Non-secure code does not regain control after one is raised. |
| 76 | * Returning from this exception could allow a pending NS exception to be |
Joakim Andersson | 7df331f | 2022-05-30 16:21:13 +0200 | [diff] [blame] | 77 | * taken, so the current solution is to panic. |
Ken Liu | 2e43489 | 2022-02-16 12:10:16 +0800 | [diff] [blame] | 78 | */ |
Joakim Andersson | 7df331f | 2022-05-30 16:21:13 +0200 | [diff] [blame] | 79 | tfm_core_panic(); |
Ken Liu | 2e43489 | 2022-02-16 12:10:16 +0800 | [diff] [blame] | 80 | } |
| 81 | |
| 82 | __attribute__((naked)) void SecureFault_Handler(void) |
| 83 | { |
| 84 | EXCEPTION_INFO(EXCEPTION_TYPE_SECUREFAULT); |
| 85 | |
Joakim Andersson | 7df331f | 2022-05-30 16:21:13 +0200 | [diff] [blame] | 86 | __ASM volatile( |
| 87 | "bl C_SecureFault_Handler \n" |
| 88 | "b . \n" |
| 89 | ); |
| 90 | } |
| 91 | |
| 92 | void C_UsageFault_Handler(void) |
| 93 | { |
| 94 | tfm_core_panic(); |
Ken Liu | 2e43489 | 2022-02-16 12:10:16 +0800 | [diff] [blame] | 95 | } |
| 96 | |
| 97 | __attribute__((naked)) void UsageFault_Handler(void) |
| 98 | { |
| 99 | EXCEPTION_INFO(EXCEPTION_TYPE_USAGEFAULT); |
Joakim Andersson | 7df331f | 2022-05-30 16:21:13 +0200 | [diff] [blame] | 100 | |
| 101 | __ASM volatile( |
| 102 | "bl C_UsageFault_Handler \n" |
| 103 | "b . \n" |
| 104 | ); |
Ken Liu | 2e43489 | 2022-02-16 12:10:16 +0800 | [diff] [blame] | 105 | } |