1 /* 2 * Copyright (c) 2017-2020 Arm Limited 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 */ 6 7 /* 8 * This file is derivative of CMSIS V5.01 Device\_Template_Vendor\Vendor\Device\Include\Device.h 9 */ 10 11 #ifndef SYSTEM_CMSDK_MUSCA_S1_H 12 #define SYSTEM_CMSDK_MUSCA_S1_H 13 14 #ifdef __cplusplus 15 extern "C" { 16 #endif 17 18 /* =========================================================================================================================== */ 19 /* ================ Interrupt Number Definition ================ */ 20 /* =========================================================================================================================== */ 21 22 typedef enum IRQn { 23 /* =========================================== Core Specific Interrupt Numbers ============================================= */ 24 NonMaskableInt_IRQn = -14, /* -14 Non Maskable Interrupt */ 25 HardFault_IRQn = -13, /* -13 HardFault Interrupt */ 26 MemoryManagement_IRQn = -12, /* -12 Memory Management Interrupt */ 27 BusFault_IRQn = -11, /* -11 Bus Fault Interrupt */ 28 UsageFault_IRQn = -10, /* -10 Usage Fault Interrupt */ 29 SecureFault_IRQn = -9, /* -9 Secure Fault Interrupt */ 30 SVCall_IRQn = -5, /* -5 SV Call Interrupt */ 31 DebugMonitor_IRQn = -4, /* -4 Debug Monitor Interrupt */ 32 PendSV_IRQn = -2, /* -2 Pend SV Interrupt */ 33 SysTick_IRQn = -1, /* -1 System Tick Interrupt */ 34 35 /* ======================================== Musca Specific SSE-200 Interrupt Numbers ====================================== */ 36 NS_WATCHDOG_RESET_IRQn = 0, /* Non-Secure Watchdog Reset Request Interrupt */ 37 NS_WATCHDOG_IRQn = 1, /* Non-Secure Watchdog Interrupt */ 38 S32K_TIMER_IRQn = 2, /* S32K Timer Interrupt */ 39 TIMER0_IRQn = 3, /* CMSDK Timer 0 Interrupt */ 40 TIMER1_IRQn = 4, /* CMSDK Timer 1 Interrupt */ 41 DUALTIMER_IRQn = 5, /* CMSDK Dual Timer Interrupt */ 42 MHU0_IRQn = 6, /* Message Handling Unit 0 Interrupt */ 43 MHU1_IRQn = 7, /* Message Handling Unit 1 Interrupt */ 44 CRYPTOCELL_IRQn = 8, /* CryptoCell-312 Interrupt */ 45 S_MPC_COMBINED_IRQn = 9, /* Secure Combined MPC Interrupt */ 46 S_PPC_COMBINED_IRQn = 10, /* Secure Combined PPC Interrupt */ 47 S_MSC_COMBINED_IRQn = 11, /* Secure Combined MSC Interrupt */ 48 S_BRIDGE_ERR_IRQn = 12, /* Secure Bridge Error Combined Interrupt */ 49 I_CACHE_INV_ERR_IRQn = 13, /* Instruction Cache Invalidation Interrupt */ 50 /* Reserved = 14, Reserved */ 51 SYS_PPU_IRQn = 15, /* System PPU Interrupt */ 52 CPU0_PPU_IRQn = 16, /* CPU0 PPU Interrupt */ 53 CPU1_PPU_IRQn = 17, /* CPU1 PPU Interrupt */ 54 CPU0_DGB_PPU_IRQn = 18, /* CPU0 Debug PPU Interrupt */ 55 CPU1_DGB_PPU_IRQn = 19, /* CPU1 Debug PPU Interrupt */ 56 CRYPTOCELL_PPU_IRQn = 20, /* CryptoCell PPU Interrupt */ 57 /* Reserved = 21, Reserved */ 58 RAM0_PPU_IRQn = 22, /* RAM 0 PPU Interrupt */ 59 RAM1_PPU_IRQn = 23, /* RAM 1 PPU Interrupt */ 60 RAM2_PPU_IRQn = 24, /* RAM 2 PPU Interrupt */ 61 RAM3_PPU_IRQn = 25, /* RAM 3 PPU Interrupt */ 62 DEBUG_PPU_IRQn = 26, /* Debug PPU Interrupt */ 63 /* Reserved = 27, Reserved */ 64 CPU0_CTI_IRQn = 28, /* CPU0 CTI Interrupt */ 65 CPU1_CTI_IRQn = 29, /* CPU1 CTI Interrupt */ 66 /* Reserved = 30, Reserved */ 67 /* Reserved = 31, Reserved */ 68 /* ========================================== Musca Specific Expansion Interrupt Numbers =================================== */ 69 /* None = 32, Not used. Tied to 0 */ 70 GpTimer_IRQn = 33, /* General Purpose Timer Interrupt */ 71 I2C0_IRQn = 34, /* I2C0 Interrupt */ 72 I2C1_IRQn = 35, /* I2C1 Interrupt */ 73 I2S_IRQn = 36, /* I2S Interrupt */ 74 SPI_IRQn = 37, /* SPI Interrupt */ 75 QSPI_IRQn = 38, /* QSPI Interrupt */ 76 UART0_Rx_IRQn = 39, /* UART0 receive FIFO interrupt */ 77 UART0_Tx_IRQn = 40, /* UART0 transmit FIFO interrupt */ 78 UART0_RxTimeout_IRQn = 41, /* UART0 receive timeout interrupt */ 79 UART0_ModemStatus_IRQn = 42, /* UART0 modem status interrupt */ 80 UART0_Error_IRQn = 43, /* UART0 error interrupt */ 81 UART0_IRQn = 44, /* UART0 interrupt */ 82 UART1_Rx_IRQn = 45, /* UART1 receive FIFO interrupt */ 83 UART1_Tx_IRQn = 46, /* UART1 transmit FIFO interrupt */ 84 UART1_RxTimeout_IRQn = 47, /* UART1 receive timeout interrupt */ 85 UART1_ModemStatus_IRQn = 48, /* UART1 modem status interrupt */ 86 UART1_Error_IRQn = 49, /* UART1 error interrupt */ 87 UART1_IRQn = 50, /* UART1 interrupt */ 88 GPIO_0_IRQn = 51, /* GPIO 0 interrupt */ 89 GPIO_1_IRQn = 52, /* GPIO 1 interrupt */ 90 GPIO_2_IRQn = 53, /* GPIO 2 interrupt */ 91 GPIO_3_IRQn = 54, /* GPIO 3 interrupt */ 92 GPIO_4_IRQn = 55, /* GPIO 4 interrupt */ 93 GPIO_5_IRQn = 56, /* GPIO 5 interrupt */ 94 GPIO_6_IRQn = 57, /* GPIO 6 interrupt */ 95 GPIO_7_IRQn = 58, /* GPIO 7 interrupt */ 96 GPIO_8_IRQn = 59, /* GPIO 8 interrupt */ 97 GPIO_9_IRQn = 60, /* GPIO 9 interrupt */ 98 GPIO_10_IRQn = 61, /* GPIO 10 interrupt */ 99 GPIO_11_IRQn = 62, /* GPIO 11 interrupt */ 100 GPIO_12_IRQn = 63, /* GPIO 12 interrupt */ 101 GPIO_13_IRQn = 64, /* GPIO 13 interrupt */ 102 GPIO_14_IRQn = 65, /* GPIO 14 interrupt */ 103 GPIO_15_IRQn = 66, /* GPIO 15 interrupt */ 104 Combined_IRQn = 67, /* Combined interrupt */ 105 PVT_IRQn = 68, /* PVT sensor interrupt */ 106 /* Reserved = 69, Reserved */ 107 PWM_0_IRQn = 70, /* PWM0 interrupt */ 108 RTC_IRQn = 71, /* RTC interrupt */ 109 GpTimer0_IRQn = 72, /* General Purpose Timer0 Interrupt */ 110 GpTimer1_IRQn = 73, /* General Purpose Timer1 Interrupt */ 111 PWM_1_IRQn = 74, /* PWM1 interrupt */ 112 PWM_2_IRQn = 75, /* PWM2 interrupt */ 113 IOMUX_IRQn = 76, /* IOMUX interrupt */ 114 } IRQn_Type; 115 116 117 118 /* =========================================================================================================================== */ 119 /* ================ Processor and Core Peripheral Section ================ */ 120 /* =========================================================================================================================== */ 121 122 /* -------- Configuration of the Cortex-M33 Processor and Core Peripherals ------ */ 123 #define __CM33_REV 0x0000U /* Core revision r0p1 */ 124 #define __SAUREGION_PRESENT 1U /* SAU regions present */ 125 #define __MPU_PRESENT 1U /* MPU present */ 126 #define __VTOR_PRESENT 1U /* VTOR present */ 127 #define __NVIC_PRIO_BITS 3U /* Number of Bits used for Priority Levels */ 128 #define __Vendor_SysTickConfig 0U /* Set to 1 if different SysTick Config is used */ 129 130 /* CORE 0 has FPU or DSP */ 131 #define __FPU_PRESENT 1U /* FPU present */ 132 #define __DSP_PRESENT 1U /* DSP extension present */ 133 134 #ifdef __cplusplus 135 } 136 #endif 137 138 #include <core_cm33.h> /*!< ARM Cortex-M33 processor and core peripherals */ 139 140 #endif /* SYSTEM_CMSDK_MUSCA_S1_H */ 141