xref: /btstack/port/renesas-ek-ra6m4a-da14531/e2-project/ra/fsp/src/bsp/mcu/all/bsp_arm_exceptions.h (revision c30869498fb8e98c1408c9db0e7624f02f483b73)
1 /***********************************************************************************************************************
2  * Copyright [2020-2022] Renesas Electronics Corporation and/or its affiliates.  All Rights Reserved.
3  *
4  * This software and documentation are supplied by Renesas Electronics America Inc. and may only be used with products
5  * of Renesas Electronics Corp. and its affiliates ("Renesas").  No other uses are authorized.  Renesas products are
6  * sold pursuant to Renesas terms and conditions of sale.  Purchasers are solely responsible for the selection and use
7  * of Renesas products and Renesas assumes no liability.  No license, express or implied, to any intellectual property
8  * right is granted by Renesas. This software is protected under all applicable laws, including copyright laws. Renesas
9  * reserves the right to change or discontinue this software and/or this documentation. THE SOFTWARE AND DOCUMENTATION
10  * IS DELIVERED TO YOU "AS IS," AND RENESAS MAKES NO REPRESENTATIONS OR WARRANTIES, AND TO THE FULLEST EXTENT
11  * PERMISSIBLE UNDER APPLICABLE LAW, DISCLAIMS ALL WARRANTIES, WHETHER EXPLICITLY OR IMPLICITLY, INCLUDING WARRANTIES
12  * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NONINFRINGEMENT, WITH RESPECT TO THE SOFTWARE OR
13  * DOCUMENTATION.  RENESAS SHALL HAVE NO LIABILITY ARISING OUT OF ANY SECURITY VULNERABILITY OR BREACH.  TO THE MAXIMUM
14  * EXTENT PERMITTED BY LAW, IN NO EVENT WILL RENESAS BE LIABLE TO YOU IN CONNECTION WITH THE SOFTWARE OR DOCUMENTATION
15  * (OR ANY PERSON OR ENTITY CLAIMING RIGHTS DERIVED FROM YOU) FOR ANY LOSS, DAMAGES, OR CLAIMS WHATSOEVER, INCLUDING,
16  * WITHOUT LIMITATION, ANY DIRECT, CONSEQUENTIAL, SPECIAL, INDIRECT, PUNITIVE, OR INCIDENTAL DAMAGES; ANY LOST PROFITS,
17  * OTHER ECONOMIC DAMAGE, PROPERTY DAMAGE, OR PERSONAL INJURY; AND EVEN IF RENESAS HAS BEEN ADVISED OF THE POSSIBILITY
18  * OF SUCH LOSS, DAMAGES, CLAIMS OR COSTS.
19  **********************************************************************************************************************/
20 
21 /** @} (end addtogroup BSP_MCU) */
22 
23 #ifndef BSP_ARM_EXCEPTIONS_H
24  #define BSP_ARM_EXCEPTIONS_H
25 
26  #ifdef __cplusplus
27 extern "C" {
28  #endif
29 
30 /***********************************************************************************************************************
31  * Macro definitions
32  **********************************************************************************************************************/
33 
34 /***********************************************************************************************************************
35  * Typedef definitions
36  **********************************************************************************************************************/
37 
38 /* This list includes only Arm standard exceptions. Renesas interrupts are defined in vector_data.h. */
39 typedef enum IRQn
40 {
41     Reset_IRQn            = -15,       /*  1 Reset Vector invoked on Power up and warm reset */
42     NonMaskableInt_IRQn   = -14,       /*  2 Non maskable Interrupt cannot be stopped or preempted */
43     HardFault_IRQn        = -13,       /*  3 Hard Fault all classes of Fault */
44     MemoryManagement_IRQn = -12,       /*  4 Memory Management MPU mismatch, including Access Violation and No Match */
45     BusFault_IRQn         = -11,       /*  5 Bus Fault Pre-Fetch-, Memory Access, other address/memory Fault */
46     UsageFault_IRQn       = -10,       /*  6 Usage Fault i.e. Undef Instruction, Illegal State Transition */
47     SecureFault_IRQn      = -9,        /*  7 Secure Fault Interrupt */
48     SVCall_IRQn           = -5,        /* 11 System Service Call via SVC instruction */
49     DebugMonitor_IRQn     = -4,        /* 12 Debug Monitor */
50     PendSV_IRQn           = -2,        /* 14 Pendable request for system service */
51     SysTick_IRQn          = -1,        /* 15 System Tick Timer */
52 } IRQn_Type;
53 
54  #ifdef __cplusplus
55 }
56  #endif
57 
58 #endif
59