UPD CMSIS driver V1.7.4.0
This commit is contained in:
		
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -0,0 +1,303 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file    stm32l4xx.h | ||||
|   * @author  MCD Application Team | ||||
|   * @brief   CMSIS STM32L4xx Device Peripheral Access Layer Header File. | ||||
|   * | ||||
|   *          The file is the unique include file that the application programmer | ||||
|   *          is using in the C source code, usually in main.c. This file contains: | ||||
|   *           - Configuration section that allows to select: | ||||
|   *              - The STM32L4xx device used in the target application | ||||
|   *              - To use or not the peripheral's drivers in application code(i.e. | ||||
|   *                code will be based on direct access to peripheral's registers | ||||
|   *                rather than drivers API), this option is controlled by | ||||
|   *                "#define USE_HAL_DRIVER" | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2017 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * This software is licensed under terms that can be found in the LICENSE file | ||||
|   * in the root directory of this software component. | ||||
|   * If no LICENSE file comes with this software, it is provided AS-IS. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup CMSIS | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup stm32l4xx | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| #ifndef __STM32L4xx_H | ||||
| #define __STM32L4xx_H | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif /* __cplusplus */ | ||||
|  | ||||
| /** @addtogroup Library_configuration_section | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @brief STM32 Family | ||||
|   */ | ||||
| #if !defined (STM32L4) | ||||
| #define STM32L4 | ||||
| #endif /* STM32L4 */ | ||||
|  | ||||
| /* Uncomment the line below according to the target STM32L4 device used in your | ||||
|    application | ||||
|   */ | ||||
|  | ||||
| #if !defined (STM32L412xx) && !defined (STM32L422xx) && \ | ||||
|     !defined (STM32L431xx) && !defined (STM32L432xx) && !defined (STM32L433xx) && !defined (STM32L442xx) && !defined (STM32L443xx) && \ | ||||
|     !defined (STM32L451xx) && !defined (STM32L452xx) && !defined (STM32L462xx) && \ | ||||
|     !defined (STM32L471xx) && !defined (STM32L475xx) && !defined (STM32L476xx) && !defined (STM32L485xx) && !defined (STM32L486xx) && \ | ||||
|     !defined (STM32L496xx) && !defined (STM32L4A6xx) && \ | ||||
|     !defined (STM32L4P5xx) && !defined (STM32L4Q5xx) && \ | ||||
|     !defined (STM32L4R5xx) && !defined (STM32L4R7xx) && !defined (STM32L4R9xx) && !defined (STM32L4S5xx) && !defined (STM32L4S7xx) && !defined (STM32L4S9xx) | ||||
|   /* #define STM32L412xx */   /*!< STM32L412xx Devices */ | ||||
|   /* #define STM32L422xx */   /*!< STM32L422xx Devices */ | ||||
|   /* #define STM32L431xx */   /*!< STM32L431xx Devices */ | ||||
|   /* #define STM32L432xx */   /*!< STM32L432xx Devices */ | ||||
|   /* #define STM32L433xx */   /*!< STM32L433xx Devices */ | ||||
|   /* #define STM32L442xx */   /*!< STM32L442xx Devices */ | ||||
|   /* #define STM32L443xx */   /*!< STM32L443xx Devices */ | ||||
|   /* #define STM32L451xx */   /*!< STM32L451xx Devices */ | ||||
|   /* #define STM32L452xx */   /*!< STM32L452xx Devices */ | ||||
|   /* #define STM32L462xx */   /*!< STM32L462xx Devices */ | ||||
|   /* #define STM32L471xx */   /*!< STM32L471xx Devices */ | ||||
|   /* #define STM32L475xx */   /*!< STM32L475xx Devices */ | ||||
|   /* #define STM32L476xx */   /*!< STM32L476xx Devices */ | ||||
|   /* #define STM32L485xx */   /*!< STM32L485xx Devices */ | ||||
|   /* #define STM32L486xx */   /*!< STM32L486xx Devices */ | ||||
|   /* #define STM32L496xx */   /*!< STM32L496xx Devices */ | ||||
|   /* #define STM32L4A6xx */   /*!< STM32L4A6xx Devices */ | ||||
|   /* #define STM32L4P5xx */   /*!< STM32L4Q5xx Devices */ | ||||
|   /* #define STM32L4R5xx */   /*!< STM32L4R5xx Devices */ | ||||
|   /* #define STM32L4R7xx */   /*!< STM32L4R7xx Devices */ | ||||
|   /* #define STM32L4R9xx */   /*!< STM32L4R9xx Devices */ | ||||
|   /* #define STM32L4S5xx */   /*!< STM32L4S5xx Devices */ | ||||
|   /* #define STM32L4S7xx */   /*!< STM32L4S7xx Devices */ | ||||
|   /* #define STM32L4S9xx */   /*!< STM32L4S9xx Devices */ | ||||
| #endif | ||||
|  | ||||
| /*  Tip: To avoid modifying this file each time you need to switch between these | ||||
|         devices, you can define the device in your toolchain compiler preprocessor. | ||||
|   */ | ||||
| #if !defined  (USE_HAL_DRIVER) | ||||
| /** | ||||
|  * @brief Comment the line below if you will not use the peripherals drivers. | ||||
|    In this case, these drivers will not be included and the application code will | ||||
|    be based on direct access to peripherals registers | ||||
|    */ | ||||
|   /*#define USE_HAL_DRIVER */ | ||||
| #endif /* USE_HAL_DRIVER */ | ||||
|  | ||||
| /** | ||||
|   * @brief CMSIS Device version number | ||||
|   */ | ||||
| #define __STM32L4_CMSIS_VERSION_MAIN   (0x01) /*!< [31:24] main version */ | ||||
| #define __STM32L4_CMSIS_VERSION_SUB1   (0x07) /*!< [23:16] sub1 version */ | ||||
| #define __STM32L4_CMSIS_VERSION_SUB2   (0x04) /*!< [15:8]  sub2 version */ | ||||
| #define __STM32L4_CMSIS_VERSION_RC     (0x00) /*!< [7:0]  release candidate */ | ||||
| #define __STM32L4_CMSIS_VERSION        ((__STM32L4_CMSIS_VERSION_MAIN << 24)\ | ||||
|                                        |(__STM32L4_CMSIS_VERSION_SUB1 << 16)\ | ||||
|                                        |(__STM32L4_CMSIS_VERSION_SUB2 << 8 )\ | ||||
|                                        |(__STM32L4_CMSIS_VERSION_RC)) | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup Device_Included | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| #if defined(STM32L412xx) | ||||
|   #include "stm32l412xx.h" | ||||
| #elif defined(STM32L422xx) | ||||
|   #include "stm32l422xx.h" | ||||
| #elif defined(STM32L431xx) | ||||
|   #include "stm32l431xx.h" | ||||
| #elif defined(STM32L432xx) | ||||
|   #include "stm32l432xx.h" | ||||
| #elif defined(STM32L433xx) | ||||
|   #include "stm32l433xx.h" | ||||
| #elif defined(STM32L442xx) | ||||
|   #include "stm32l442xx.h" | ||||
| #elif defined(STM32L443xx) | ||||
|   #include "stm32l443xx.h" | ||||
| #elif defined(STM32L451xx) | ||||
|   #include "stm32l451xx.h" | ||||
| #elif defined(STM32L452xx) | ||||
|   #include "stm32l452xx.h" | ||||
| #elif defined(STM32L462xx) | ||||
|   #include "stm32l462xx.h" | ||||
| #elif defined(STM32L471xx) | ||||
|   #include "stm32l471xx.h" | ||||
| #elif defined(STM32L475xx) | ||||
|   #include "stm32l475xx.h" | ||||
| #elif defined(STM32L476xx) | ||||
|   #include "stm32l476xx.h" | ||||
| #elif defined(STM32L485xx) | ||||
|   #include "stm32l485xx.h" | ||||
| #elif defined(STM32L486xx) | ||||
|   #include "stm32l486xx.h" | ||||
| #elif defined(STM32L496xx) | ||||
|   #include "stm32l496xx.h" | ||||
| #elif defined(STM32L4A6xx) | ||||
|   #include "stm32l4a6xx.h" | ||||
| #elif defined(STM32L4P5xx) | ||||
|   #include "stm32l4p5xx.h" | ||||
| #elif defined(STM32L4Q5xx) | ||||
|   #include "stm32l4q5xx.h" | ||||
| #elif defined(STM32L4R5xx) | ||||
|   #include "stm32l4r5xx.h" | ||||
| #elif defined(STM32L4R7xx) | ||||
|   #include "stm32l4r7xx.h" | ||||
| #elif defined(STM32L4R9xx) | ||||
|   #include "stm32l4r9xx.h" | ||||
| #elif defined(STM32L4S5xx) | ||||
|   #include "stm32l4s5xx.h" | ||||
| #elif defined(STM32L4S7xx) | ||||
|   #include "stm32l4s7xx.h" | ||||
| #elif defined(STM32L4S9xx) | ||||
|   #include "stm32l4s9xx.h" | ||||
| #else | ||||
|  #error "Please select first the target STM32L4xx device used in your application (in stm32l4xx.h file)" | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup Exported_types | ||||
|   * @{ | ||||
|   */ | ||||
| typedef enum | ||||
| { | ||||
|   RESET = 0, | ||||
|   SET = !RESET | ||||
| } FlagStatus, ITStatus; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   DISABLE = 0, | ||||
|   ENABLE = !DISABLE | ||||
| } FunctionalState; | ||||
| #define IS_FUNCTIONAL_STATE(STATE) (((STATE) == DISABLE) || ((STATE) == ENABLE)) | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
|   SUCCESS = 0, | ||||
|   ERROR = !SUCCESS | ||||
| } ErrorStatus; | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
|  | ||||
| /** @addtogroup Exported_macros | ||||
|   * @{ | ||||
|   */ | ||||
| #define SET_BIT(REG, BIT)     ((REG) |= (BIT)) | ||||
|  | ||||
| #define CLEAR_BIT(REG, BIT)   ((REG) &= ~(BIT)) | ||||
|  | ||||
| #define READ_BIT(REG, BIT)    ((REG) & (BIT)) | ||||
|  | ||||
| #define CLEAR_REG(REG)        ((REG) = (0x0)) | ||||
|  | ||||
| #define WRITE_REG(REG, VAL)   ((REG) = (VAL)) | ||||
|  | ||||
| #define READ_REG(REG)         ((REG)) | ||||
|  | ||||
| #define MODIFY_REG(REG, CLEARMASK, SETMASK)  WRITE_REG((REG), (((READ_REG(REG)) & (~(CLEARMASK))) | (SETMASK))) | ||||
|  | ||||
| /* Use of CMSIS compiler intrinsics for register exclusive access */ | ||||
| /* Atomic 32-bit register access macro to set one or several bits */ | ||||
| #define ATOMIC_SET_BIT(REG, BIT)                             \ | ||||
|   do {                                                       \ | ||||
|     uint32_t val;                                            \ | ||||
|     do {                                                     \ | ||||
|       val = __LDREXW((__IO uint32_t *)&(REG)) | (BIT);       \ | ||||
|     } while ((__STREXW(val,(__IO uint32_t *)&(REG))) != 0U); \ | ||||
|   } while(0) | ||||
|  | ||||
| /* Atomic 32-bit register access macro to clear one or several bits */ | ||||
| #define ATOMIC_CLEAR_BIT(REG, BIT)                           \ | ||||
|   do {                                                       \ | ||||
|     uint32_t val;                                            \ | ||||
|     do {                                                     \ | ||||
|       val = __LDREXW((__IO uint32_t *)&(REG)) & ~(BIT);      \ | ||||
|     } while ((__STREXW(val,(__IO uint32_t *)&(REG))) != 0U); \ | ||||
|   } while(0) | ||||
|  | ||||
| /* Atomic 32-bit register access macro to clear and set one or several bits */ | ||||
| #define ATOMIC_MODIFY_REG(REG, CLEARMSK, SETMASK)                          \ | ||||
|   do {                                                                     \ | ||||
|     uint32_t val;                                                          \ | ||||
|     do {                                                                   \ | ||||
|       val = (__LDREXW((__IO uint32_t *)&(REG)) & ~(CLEARMSK)) | (SETMASK); \ | ||||
|     } while ((__STREXW(val,(__IO uint32_t *)&(REG))) != 0U);               \ | ||||
|   } while(0) | ||||
|  | ||||
| /* Atomic 16-bit register access macro to set one or several bits */ | ||||
| #define ATOMIC_SETH_BIT(REG, BIT)                            \ | ||||
|   do {                                                       \ | ||||
|     uint16_t val;                                            \ | ||||
|     do {                                                     \ | ||||
|       val = __LDREXH((__IO uint16_t *)&(REG)) | (BIT);       \ | ||||
|     } while ((__STREXH(val,(__IO uint16_t *)&(REG))) != 0U); \ | ||||
|   } while(0) | ||||
|  | ||||
| /* Atomic 16-bit register access macro to clear one or several bits */ | ||||
| #define ATOMIC_CLEARH_BIT(REG, BIT)                          \ | ||||
|   do {                                                       \ | ||||
|     uint16_t val;                                            \ | ||||
|     do {                                                     \ | ||||
|       val = __LDREXH((__IO uint16_t *)&(REG)) & ~(BIT);      \ | ||||
|     } while ((__STREXH(val,(__IO uint16_t *)&(REG))) != 0U); \ | ||||
|   } while(0) | ||||
|  | ||||
| /* Atomic 16-bit register access macro to clear and set one or several bits */ | ||||
| #define ATOMIC_MODIFYH_REG(REG, CLEARMSK, SETMASK)                         \ | ||||
|   do {                                                                     \ | ||||
|     uint16_t val;                                                          \ | ||||
|     do {                                                                   \ | ||||
|       val = (__LDREXH((__IO uint16_t *)&(REG)) & ~(CLEARMSK)) | (SETMASK); \ | ||||
|     } while ((__STREXH(val,(__IO uint16_t *)&(REG))) != 0U);               \ | ||||
|   } while(0) | ||||
|  | ||||
| #define POSITION_VAL(VAL)     (__CLZ(__RBIT(VAL))) | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| #if defined (USE_HAL_DRIVER) | ||||
|  #include "stm32l4xx_hal.h" | ||||
| #endif /* USE_HAL_DRIVER */ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif /* __cplusplus */ | ||||
|  | ||||
| #endif /* __STM32L4xx_H */ | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| @@ -0,0 +1,106 @@ | ||||
| /** | ||||
|   ****************************************************************************** | ||||
|   * @file    system_stm32l4xx.h | ||||
|   * @author  MCD Application Team | ||||
|   * @brief   CMSIS Cortex-M4 Device System Source File for STM32L4xx devices. | ||||
|   ****************************************************************************** | ||||
|   * @attention | ||||
|   * | ||||
|   * Copyright (c) 2017 STMicroelectronics. | ||||
|   * All rights reserved. | ||||
|   * | ||||
|   * This software is licensed under terms that can be found in the LICENSE file | ||||
|   * in the root directory of this software component. | ||||
|   * If no LICENSE file comes with this software, it is provided AS-IS. | ||||
|   * | ||||
|   ****************************************************************************** | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup CMSIS | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup stm32l4xx_system | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @brief Define to prevent recursive inclusion | ||||
|   */ | ||||
| #ifndef __SYSTEM_STM32L4XX_H | ||||
| #define __SYSTEM_STM32L4XX_H | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|  extern "C" { | ||||
| #endif | ||||
|  | ||||
| /** @addtogroup STM32L4xx_System_Includes | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
|  | ||||
| /** @addtogroup STM32L4xx_System_Exported_Variables | ||||
|   * @{ | ||||
|   */ | ||||
|   /* The SystemCoreClock variable is updated in three ways: | ||||
|       1) by calling CMSIS function SystemCoreClockUpdate() | ||||
|       2) by calling HAL API function HAL_RCC_GetSysClockFreq() | ||||
|       3) each time HAL_RCC_ClockConfig() is called to configure the system clock frequency | ||||
|          Note: If you use this function to configure the system clock; then there | ||||
|                is no need to call the 2 first functions listed above, since SystemCoreClock | ||||
|                variable is updated automatically. | ||||
|   */ | ||||
| extern uint32_t SystemCoreClock;            /*!< System Clock Frequency (Core Clock) */ | ||||
|  | ||||
| extern const uint8_t  AHBPrescTable[16];    /*!< AHB prescalers table values */ | ||||
| extern const uint8_t  APBPrescTable[8];     /*!< APB prescalers table values */ | ||||
| extern const uint32_t MSIRangeTable[12];    /*!< MSI ranges table values     */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32L4xx_System_Exported_Constants | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32L4xx_System_Exported_Macros | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** @addtogroup STM32L4xx_System_Exported_Functions | ||||
|   * @{ | ||||
|   */ | ||||
|  | ||||
| extern void SystemInit(void); | ||||
| extern void SystemCoreClockUpdate(void); | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif /*__SYSTEM_STM32L4XX_H */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| /** | ||||
|   * @} | ||||
|   */ | ||||
|  | ||||
| @@ -0,0 +1,6 @@ | ||||
| This software component is provided to you as part of a software package and | ||||
| applicable license terms are in the  Package_license file. If you received this | ||||
| software component outside of a package or without applicable license terms, | ||||
| the terms of the Apache-2.0 license shall apply.  | ||||
| You may obtain a copy of the Apache-2.0 at: | ||||
| https://opensource.org/licenses/Apache-2.0 | ||||
| @@ -0,0 +1,83 @@ | ||||
| Apache License | ||||
|  Version 2.0, January 2004 | ||||
|  http://www.apache.org/licenses/ | ||||
|  | ||||
| TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION | ||||
|  | ||||
| 1. Definitions. | ||||
|  | ||||
| "License" shall mean the terms and conditions for use, reproduction, and distribution as defined by Sections 1 through 9 of this document. | ||||
|  | ||||
| "Licensor" shall mean the copyright owner or entity authorized by the copyright owner that is granting the License. | ||||
|  | ||||
| "Legal Entity" shall mean the union of the acting entity and all other entities that control, are controlled by, or are under common control with that entity. For the purposes of this definition, "control" means (i) the power, direct or indirect, to cause the direction or management of such entity, whether by contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the outstanding shares, or (iii) beneficial ownership of such entity. | ||||
|  | ||||
| "You" (or "Your") shall mean an individual or Legal Entity exercising permissions granted by this License. | ||||
|  | ||||
| "Source" form shall mean the preferred form for making modifications, including but not limited to software source code, documentation source, and configuration files. | ||||
|  | ||||
| "Object" form shall mean any form resulting from mechanical transformation or translation of a Source form, including but not limited to compiled object code, generated documentation, and conversions to other media types. | ||||
|  | ||||
| "Work" shall mean the work of authorship, whether in Source or Object form, made available under the License, as indicated by a copyright notice that is included in or attached to the work (an example is provided in the Appendix below). | ||||
|  | ||||
| "Derivative Works" shall mean any work, whether in Source or Object form, that is based on (or derived from) the Work and for which the editorial revisions, annotations, elaborations, or other modifications represent, as a whole, an original work of authorship. For the purposes of this License, Derivative Works shall not include works that remain separable from, or merely link (or bind by name) to the interfaces of, the Work and Derivative Works thereof. | ||||
|  | ||||
| "Contribution" shall mean any work of authorship, including the original version of the Work and any modifications or additions to that Work or Derivative Works thereof, that is intentionally submitted to Licensor for inclusion in the Work by the copyright owner or by an individual or Legal Entity authorized to submit on behalf of the copyright owner. For the purposes of this definition, "submitted" means any form of electronic, verbal, or written communication sent to the Licensor or its representatives, including but not limited to communication on electronic mailing lists, source code control systems, and issue tracking systems that are managed by, or on behalf of, the Licensor for the purpose of discussing and improving the Work, but excluding communication that is conspicuously marked or otherwise designated in writing by the copyright owner as "Not a Contribution." | ||||
|  | ||||
| "Contributor" shall mean Licensor and any individual or Legal Entity on behalf of whom a Contribution has been received by Licensor and subsequently incorporated within the Work. | ||||
|  | ||||
| 2. Grant of Copyright License. | ||||
|  | ||||
| Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable copyright license to reproduce, prepare Derivative Works of, publicly display, publicly perform, sublicense, and distribute the Work and such Derivative Works in Source or Object form. | ||||
|  | ||||
| 3. Grant of Patent License. | ||||
|  | ||||
| Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable (except as stated in this section) patent license to make, have made, use, offer to sell, sell, import, and otherwise transfer the Work, where such license applies only to those patent claims licensable by such Contributor that are necessarily infringed by their Contribution(s) alone or by combination of their Contribution(s) with the Work to which such Contribution(s) was submitted. If You institute patent litigation against any entity (including a cross-claim or counterclaim in a lawsuit) alleging that the Work or a Contribution incorporated within the Work constitutes direct or contributory patent infringement, then any patent licenses granted to You under this License for that Work shall terminate as of the date such litigation is filed. | ||||
|  | ||||
| 4. Redistribution. | ||||
|  | ||||
| You may reproduce and distribute copies of the Work or Derivative Works thereof in any medium, with or without modifications, and in Source or Object form, provided that You meet the following conditions: | ||||
| 1.You must give any other recipients of the Work or Derivative Works a copy of this License; and | ||||
| 2.You must cause any modified files to carry prominent notices stating that You changed the files; and | ||||
| 3.You must retain, in the Source form of any Derivative Works that You distribute, all copyright, patent, trademark, and attribution notices from the Source form of the Work, excluding those notices that do not pertain to any part of the Derivative Works; and | ||||
| 4.If the Work includes a "NOTICE" text file as part of its distribution, then any Derivative Works that You distribute must include a readable copy of the attribution notices contained within such NOTICE file, excluding those notices that do not pertain to any part of the Derivative Works, in at least one of the following places: within a NOTICE text file distributed as part of the Derivative Works; within the Source form or documentation, if provided along with the Derivative Works; or, within a display generated by the Derivative Works, if and wherever such third-party notices normally appear. The contents of the NOTICE file are for informational purposes only and do not modify the License. You may add Your own attribution notices within Derivative Works that You distribute, alongside or as an addendum to the NOTICE text from the Work, provided that such additional attribution notices cannot be construed as modifying the License. | ||||
|  | ||||
| You may add Your own copyright statement to Your modifications and may provide additional or different license terms and conditions for use, reproduction, or distribution of Your modifications, or for any such Derivative Works as a whole, provided Your use, reproduction, and distribution of the Work otherwise complies with the conditions stated in this License. | ||||
|  | ||||
| 5. Submission of Contributions. | ||||
|  | ||||
| Unless You explicitly state otherwise, any Contribution intentionally submitted for inclusion in the Work by You to the Licensor shall be under the terms and conditions of this License, without any additional terms or conditions. Notwithstanding the above, nothing herein shall supersede or modify the terms of any separate license agreement you may have executed with Licensor regarding such Contributions. | ||||
|  | ||||
| 6. Trademarks. | ||||
|  | ||||
| This License does not grant permission to use the trade names, trademarks, service marks, or product names of the Licensor, except as required for reasonable and customary use in describing the origin of the Work and reproducing the content of the NOTICE file. | ||||
|  | ||||
| 7. Disclaimer of Warranty. | ||||
|  | ||||
| Unless required by applicable law or agreed to in writing, Licensor provides the Work (and each Contributor provides its Contributions) on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied, including, without limitation, any warranties or conditions of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are solely responsible for determining the appropriateness of using or redistributing the Work and assume any risks associated with Your exercise of permissions under this License. | ||||
|  | ||||
| 8. Limitation of Liability. | ||||
|  | ||||
| In no event and under no legal theory, whether in tort (including negligence), contract, or otherwise, unless required by applicable law (such as deliberate and grossly negligent acts) or agreed to in writing, shall any Contributor be liable to You for damages, including any direct, indirect, special, incidental, or consequential damages of any character arising as a result of this License or out of the use or inability to use the Work (including but not limited to damages for loss of goodwill, work stoppage, computer failure or malfunction, or any and all other commercial damages or losses), even if such Contributor has been advised of the possibility of such damages. | ||||
|  | ||||
| 9. Accepting Warranty or Additional Liability. | ||||
|  | ||||
| While redistributing the Work or Derivative Works thereof, You may choose to offer, and charge a fee for, acceptance of support, warranty, indemnity, or other liability obligations and/or rights consistent with this License. However, in accepting such obligations, You may act only on Your own behalf and on Your sole responsibility, not on behalf of any other Contributor, and only if You agree to indemnify, defend, and hold each Contributor harmless for any liability incurred by, or claims asserted against, such Contributor by reason of your accepting any such warranty or additional liability. | ||||
|  | ||||
| END OF TERMS AND CONDITIONS | ||||
|  | ||||
| APPENDIX: | ||||
|  | ||||
|    Copyright [2019] [STMicroelectronics] | ||||
|  | ||||
|    Licensed under the Apache License, Version 2.0 (the "License"); | ||||
|    you may not use this file except in compliance with the License. | ||||
|    You may obtain a copy of the License at | ||||
|  | ||||
|      http://www.apache.org/licenses/LICENSE-2.0 | ||||
|  | ||||
|    Unless required by applicable law or agreed to in writing, software | ||||
|    distributed under the License is distributed on an "AS IS" BASIS, | ||||
|    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|    See the License for the specific language governing permissions and | ||||
|    limitations under the License. | ||||
| @@ -1,411 +0,0 @@ | ||||
| /****************************************************************************** | ||||
|  * @file     cachel1_armv7.h | ||||
|  * @brief    CMSIS Level 1 Cache API for Armv7-M and later | ||||
|  * @version  V1.0.1 | ||||
|  * @date     19. April 2021 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2020-2021 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the License); you may | ||||
|  * not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an AS IS BASIS, WITHOUT | ||||
|  * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
|  | ||||
| #if   defined ( __ICCARM__ ) | ||||
|   #pragma system_include         /* treat file as system include file for MISRA check */ | ||||
| #elif defined (__clang__) | ||||
|   #pragma clang system_header    /* treat file as system include file */ | ||||
| #endif | ||||
|  | ||||
| #ifndef ARM_CACHEL1_ARMV7_H | ||||
| #define ARM_CACHEL1_ARMV7_H | ||||
|  | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   \defgroup CMSIS_Core_CacheFunctions Cache Functions | ||||
|   \brief    Functions that configure Instruction and Data cache. | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
| /* Cache Size ID Register Macros */ | ||||
| #define CCSIDR_WAYS(x)         (((x) & SCB_CCSIDR_ASSOCIATIVITY_Msk) >> SCB_CCSIDR_ASSOCIATIVITY_Pos) | ||||
| #define CCSIDR_SETS(x)         (((x) & SCB_CCSIDR_NUMSETS_Msk      ) >> SCB_CCSIDR_NUMSETS_Pos      ) | ||||
|  | ||||
| #ifndef __SCB_DCACHE_LINE_SIZE | ||||
| #define __SCB_DCACHE_LINE_SIZE  32U /*!< Cortex-M7 cache line size is fixed to 32 bytes (8 words). See also register SCB_CCSIDR */ | ||||
| #endif | ||||
|  | ||||
| #ifndef __SCB_ICACHE_LINE_SIZE | ||||
| #define __SCB_ICACHE_LINE_SIZE  32U /*!< Cortex-M7 cache line size is fixed to 32 bytes (8 words). See also register SCB_CCSIDR */ | ||||
| #endif | ||||
|  | ||||
| /** | ||||
|   \brief   Enable I-Cache | ||||
|   \details Turns on I-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_EnableICache (void) | ||||
| { | ||||
|   #if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U) | ||||
|     if (SCB->CCR & SCB_CCR_IC_Msk) return;  /* return if ICache is already enabled */ | ||||
|  | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     SCB->ICIALLU = 0UL;                     /* invalidate I-Cache */ | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     SCB->CCR |=  (uint32_t)SCB_CCR_IC_Msk;  /* enable I-Cache */ | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Disable I-Cache | ||||
|   \details Turns off I-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_DisableICache (void) | ||||
| { | ||||
|   #if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U) | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     SCB->CCR &= ~(uint32_t)SCB_CCR_IC_Msk;  /* disable I-Cache */ | ||||
|     SCB->ICIALLU = 0UL;                     /* invalidate I-Cache */ | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Invalidate I-Cache | ||||
|   \details Invalidates I-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_InvalidateICache (void) | ||||
| { | ||||
|   #if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U) | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     SCB->ICIALLU = 0UL; | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   I-Cache Invalidate by address | ||||
|   \details Invalidates I-Cache for the given address. | ||||
|            I-Cache is invalidated starting from a 32 byte aligned address in 32 byte granularity. | ||||
|            I-Cache memory blocks which are part of given address + given size are invalidated. | ||||
|   \param[in]   addr    address | ||||
|   \param[in]   isize   size of memory block (in number of bytes) | ||||
| */ | ||||
| __STATIC_FORCEINLINE void SCB_InvalidateICache_by_Addr (volatile void *addr, int32_t isize) | ||||
| { | ||||
|   #if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U) | ||||
|     if ( isize > 0 ) { | ||||
|        int32_t op_size = isize + (((uint32_t)addr) & (__SCB_ICACHE_LINE_SIZE - 1U)); | ||||
|       uint32_t op_addr = (uint32_t)addr /* & ~(__SCB_ICACHE_LINE_SIZE - 1U) */; | ||||
|  | ||||
|       __DSB(); | ||||
|  | ||||
|       do { | ||||
|         SCB->ICIMVAU = op_addr;             /* register accepts only 32byte aligned values, only bits 31..5 are valid */ | ||||
|         op_addr += __SCB_ICACHE_LINE_SIZE; | ||||
|         op_size -= __SCB_ICACHE_LINE_SIZE; | ||||
|       } while ( op_size > 0 ); | ||||
|  | ||||
|       __DSB(); | ||||
|       __ISB(); | ||||
|     } | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Enable D-Cache | ||||
|   \details Turns on D-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_EnableDCache (void) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     uint32_t ccsidr; | ||||
|     uint32_t sets; | ||||
|     uint32_t ways; | ||||
|  | ||||
|     if (SCB->CCR & SCB_CCR_DC_Msk) return;  /* return if DCache is already enabled */ | ||||
|  | ||||
|     SCB->CSSELR = 0U;                       /* select Level 1 data cache */ | ||||
|     __DSB(); | ||||
|  | ||||
|     ccsidr = SCB->CCSIDR; | ||||
|  | ||||
|                                             /* invalidate D-Cache */ | ||||
|     sets = (uint32_t)(CCSIDR_SETS(ccsidr)); | ||||
|     do { | ||||
|       ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); | ||||
|       do { | ||||
|         SCB->DCISW = (((sets << SCB_DCISW_SET_Pos) & SCB_DCISW_SET_Msk) | | ||||
|                       ((ways << SCB_DCISW_WAY_Pos) & SCB_DCISW_WAY_Msk)  ); | ||||
|         #if defined ( __CC_ARM ) | ||||
|           __schedule_barrier(); | ||||
|         #endif | ||||
|       } while (ways-- != 0U); | ||||
|     } while(sets-- != 0U); | ||||
|     __DSB(); | ||||
|  | ||||
|     SCB->CCR |=  (uint32_t)SCB_CCR_DC_Msk;  /* enable D-Cache */ | ||||
|  | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Disable D-Cache | ||||
|   \details Turns off D-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_DisableDCache (void) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     uint32_t ccsidr; | ||||
|     uint32_t sets; | ||||
|     uint32_t ways; | ||||
|  | ||||
|     SCB->CSSELR = 0U;                       /* select Level 1 data cache */ | ||||
|     __DSB(); | ||||
|  | ||||
|     SCB->CCR &= ~(uint32_t)SCB_CCR_DC_Msk;  /* disable D-Cache */ | ||||
|     __DSB(); | ||||
|  | ||||
|     ccsidr = SCB->CCSIDR; | ||||
|  | ||||
|                                             /* clean & invalidate D-Cache */ | ||||
|     sets = (uint32_t)(CCSIDR_SETS(ccsidr)); | ||||
|     do { | ||||
|       ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); | ||||
|       do { | ||||
|         SCB->DCCISW = (((sets << SCB_DCCISW_SET_Pos) & SCB_DCCISW_SET_Msk) | | ||||
|                        ((ways << SCB_DCCISW_WAY_Pos) & SCB_DCCISW_WAY_Msk)  ); | ||||
|         #if defined ( __CC_ARM ) | ||||
|           __schedule_barrier(); | ||||
|         #endif | ||||
|       } while (ways-- != 0U); | ||||
|     } while(sets-- != 0U); | ||||
|  | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Invalidate D-Cache | ||||
|   \details Invalidates D-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_InvalidateDCache (void) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     uint32_t ccsidr; | ||||
|     uint32_t sets; | ||||
|     uint32_t ways; | ||||
|  | ||||
|     SCB->CSSELR = 0U;                       /* select Level 1 data cache */ | ||||
|     __DSB(); | ||||
|  | ||||
|     ccsidr = SCB->CCSIDR; | ||||
|  | ||||
|                                             /* invalidate D-Cache */ | ||||
|     sets = (uint32_t)(CCSIDR_SETS(ccsidr)); | ||||
|     do { | ||||
|       ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); | ||||
|       do { | ||||
|         SCB->DCISW = (((sets << SCB_DCISW_SET_Pos) & SCB_DCISW_SET_Msk) | | ||||
|                       ((ways << SCB_DCISW_WAY_Pos) & SCB_DCISW_WAY_Msk)  ); | ||||
|         #if defined ( __CC_ARM ) | ||||
|           __schedule_barrier(); | ||||
|         #endif | ||||
|       } while (ways-- != 0U); | ||||
|     } while(sets-- != 0U); | ||||
|  | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Clean D-Cache | ||||
|   \details Cleans D-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_CleanDCache (void) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     uint32_t ccsidr; | ||||
|     uint32_t sets; | ||||
|     uint32_t ways; | ||||
|  | ||||
|     SCB->CSSELR = 0U;                       /* select Level 1 data cache */ | ||||
|     __DSB(); | ||||
|  | ||||
|     ccsidr = SCB->CCSIDR; | ||||
|  | ||||
|                                             /* clean D-Cache */ | ||||
|     sets = (uint32_t)(CCSIDR_SETS(ccsidr)); | ||||
|     do { | ||||
|       ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); | ||||
|       do { | ||||
|         SCB->DCCSW = (((sets << SCB_DCCSW_SET_Pos) & SCB_DCCSW_SET_Msk) | | ||||
|                       ((ways << SCB_DCCSW_WAY_Pos) & SCB_DCCSW_WAY_Msk)  ); | ||||
|         #if defined ( __CC_ARM ) | ||||
|           __schedule_barrier(); | ||||
|         #endif | ||||
|       } while (ways-- != 0U); | ||||
|     } while(sets-- != 0U); | ||||
|  | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Clean & Invalidate D-Cache | ||||
|   \details Cleans and Invalidates D-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_CleanInvalidateDCache (void) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     uint32_t ccsidr; | ||||
|     uint32_t sets; | ||||
|     uint32_t ways; | ||||
|  | ||||
|     SCB->CSSELR = 0U;                       /* select Level 1 data cache */ | ||||
|     __DSB(); | ||||
|  | ||||
|     ccsidr = SCB->CCSIDR; | ||||
|  | ||||
|                                             /* clean & invalidate D-Cache */ | ||||
|     sets = (uint32_t)(CCSIDR_SETS(ccsidr)); | ||||
|     do { | ||||
|       ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); | ||||
|       do { | ||||
|         SCB->DCCISW = (((sets << SCB_DCCISW_SET_Pos) & SCB_DCCISW_SET_Msk) | | ||||
|                        ((ways << SCB_DCCISW_WAY_Pos) & SCB_DCCISW_WAY_Msk)  ); | ||||
|         #if defined ( __CC_ARM ) | ||||
|           __schedule_barrier(); | ||||
|         #endif | ||||
|       } while (ways-- != 0U); | ||||
|     } while(sets-- != 0U); | ||||
|  | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   D-Cache Invalidate by address | ||||
|   \details Invalidates D-Cache for the given address. | ||||
|            D-Cache is invalidated starting from a 32 byte aligned address in 32 byte granularity. | ||||
|            D-Cache memory blocks which are part of given address + given size are invalidated. | ||||
|   \param[in]   addr    address | ||||
|   \param[in]   dsize   size of memory block (in number of bytes) | ||||
| */ | ||||
| __STATIC_FORCEINLINE void SCB_InvalidateDCache_by_Addr (volatile void *addr, int32_t dsize) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     if ( dsize > 0 ) { | ||||
|        int32_t op_size = dsize + (((uint32_t)addr) & (__SCB_DCACHE_LINE_SIZE - 1U)); | ||||
|       uint32_t op_addr = (uint32_t)addr /* & ~(__SCB_DCACHE_LINE_SIZE - 1U) */; | ||||
|  | ||||
|       __DSB(); | ||||
|  | ||||
|       do { | ||||
|         SCB->DCIMVAC = op_addr;             /* register accepts only 32byte aligned values, only bits 31..5 are valid */ | ||||
|         op_addr += __SCB_DCACHE_LINE_SIZE; | ||||
|         op_size -= __SCB_DCACHE_LINE_SIZE; | ||||
|       } while ( op_size > 0 ); | ||||
|  | ||||
|       __DSB(); | ||||
|       __ISB(); | ||||
|     } | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   D-Cache Clean by address | ||||
|   \details Cleans D-Cache for the given address | ||||
|            D-Cache is cleaned starting from a 32 byte aligned address in 32 byte granularity. | ||||
|            D-Cache memory blocks which are part of given address + given size are cleaned. | ||||
|   \param[in]   addr    address | ||||
|   \param[in]   dsize   size of memory block (in number of bytes) | ||||
| */ | ||||
| __STATIC_FORCEINLINE void SCB_CleanDCache_by_Addr (volatile void *addr, int32_t dsize) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     if ( dsize > 0 ) { | ||||
|        int32_t op_size = dsize + (((uint32_t)addr) & (__SCB_DCACHE_LINE_SIZE - 1U)); | ||||
|       uint32_t op_addr = (uint32_t)addr /* & ~(__SCB_DCACHE_LINE_SIZE - 1U) */; | ||||
|  | ||||
|       __DSB(); | ||||
|  | ||||
|       do { | ||||
|         SCB->DCCMVAC = op_addr;             /* register accepts only 32byte aligned values, only bits 31..5 are valid */ | ||||
|         op_addr += __SCB_DCACHE_LINE_SIZE; | ||||
|         op_size -= __SCB_DCACHE_LINE_SIZE; | ||||
|       } while ( op_size > 0 ); | ||||
|  | ||||
|       __DSB(); | ||||
|       __ISB(); | ||||
|     } | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   D-Cache Clean and Invalidate by address | ||||
|   \details Cleans and invalidates D_Cache for the given address | ||||
|            D-Cache is cleaned and invalidated starting from a 32 byte aligned address in 32 byte granularity. | ||||
|            D-Cache memory blocks which are part of given address + given size are cleaned and invalidated. | ||||
|   \param[in]   addr    address (aligned to 32-byte boundary) | ||||
|   \param[in]   dsize   size of memory block (in number of bytes) | ||||
| */ | ||||
| __STATIC_FORCEINLINE void SCB_CleanInvalidateDCache_by_Addr (volatile void *addr, int32_t dsize) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     if ( dsize > 0 ) { | ||||
|        int32_t op_size = dsize + (((uint32_t)addr) & (__SCB_DCACHE_LINE_SIZE - 1U)); | ||||
|       uint32_t op_addr = (uint32_t)addr /* & ~(__SCB_DCACHE_LINE_SIZE - 1U) */; | ||||
|  | ||||
|       __DSB(); | ||||
|  | ||||
|       do { | ||||
|         SCB->DCCIMVAC = op_addr;            /* register accepts only 32byte aligned values, only bits 31..5 are valid */ | ||||
|         op_addr +=          __SCB_DCACHE_LINE_SIZE; | ||||
|         op_size -=          __SCB_DCACHE_LINE_SIZE; | ||||
|       } while ( op_size > 0 ); | ||||
|  | ||||
|       __DSB(); | ||||
|       __ISB(); | ||||
|     } | ||||
|   #endif | ||||
| } | ||||
|  | ||||
| /*@} end of CMSIS_Core_CacheFunctions */ | ||||
|  | ||||
| #endif /* ARM_CACHEL1_ARMV7_H */ | ||||
| @@ -1,11 +1,11 @@ | ||||
| /**************************************************************************//** | ||||
|  * @file     cmsis_armcc.h | ||||
|  * @brief    CMSIS compiler ARMCC (Arm Compiler 5) header file | ||||
|  * @version  V5.3.2 | ||||
|  * @date     27. May 2021 | ||||
|  * @version  V5.1.0 | ||||
|  * @date     08. May 2019 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2009-2021 Arm Limited. All rights reserved. | ||||
|  * Copyright (c) 2009-2019 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
| @@ -46,7 +46,6 @@ | ||||
|  | ||||
|   /* __ARM_ARCH_8M_BASE__  not applicable */ | ||||
|   /* __ARM_ARCH_8M_MAIN__  not applicable */ | ||||
|   /* __ARM_ARCH_8_1M_MAIN__  not applicable */ | ||||
|  | ||||
| /* CMSIS compiler control DSP macros */ | ||||
| #if ((defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1))     ) | ||||
| @@ -128,9 +127,282 @@ | ||||
| #endif | ||||
|  | ||||
| #ifndef __VECTOR_TABLE_ATTRIBUTE | ||||
| #define __VECTOR_TABLE_ATTRIBUTE  __attribute__((used, section("RESET"))) | ||||
| #define __VECTOR_TABLE_ATTRIBUTE  __attribute((used, section("RESET"))) | ||||
| #endif | ||||
|  | ||||
| /* ###########################  Core Function Access  ########################### */ | ||||
| /** \ingroup  CMSIS_Core_FunctionInterface | ||||
|     \defgroup CMSIS_Core_RegAccFunctions CMSIS Core Register Access Functions | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief   Enable IRQ Interrupts | ||||
|   \details Enables IRQ interrupts by clearing the I-bit in the CPSR. | ||||
|            Can only be executed in Privileged modes. | ||||
|  */ | ||||
| /* intrinsic void __enable_irq();     */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Disable IRQ Interrupts | ||||
|   \details Disables IRQ interrupts by setting the I-bit in the CPSR. | ||||
|            Can only be executed in Privileged modes. | ||||
|  */ | ||||
| /* intrinsic void __disable_irq();    */ | ||||
|  | ||||
| /** | ||||
|   \brief   Get Control Register | ||||
|   \details Returns the content of the Control Register. | ||||
|   \return               Control Register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_CONTROL(void) | ||||
| { | ||||
|   register uint32_t __regControl         __ASM("control"); | ||||
|   return(__regControl); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Control Register | ||||
|   \details Writes the given value to the Control Register. | ||||
|   \param [in]    control  Control Register value to set | ||||
|  */ | ||||
| __STATIC_INLINE void __set_CONTROL(uint32_t control) | ||||
| { | ||||
|   register uint32_t __regControl         __ASM("control"); | ||||
|   __regControl = control; | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get IPSR Register | ||||
|   \details Returns the content of the IPSR Register. | ||||
|   \return               IPSR Register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_IPSR(void) | ||||
| { | ||||
|   register uint32_t __regIPSR          __ASM("ipsr"); | ||||
|   return(__regIPSR); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get APSR Register | ||||
|   \details Returns the content of the APSR Register. | ||||
|   \return               APSR Register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_APSR(void) | ||||
| { | ||||
|   register uint32_t __regAPSR          __ASM("apsr"); | ||||
|   return(__regAPSR); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get xPSR Register | ||||
|   \details Returns the content of the xPSR Register. | ||||
|   \return               xPSR Register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_xPSR(void) | ||||
| { | ||||
|   register uint32_t __regXPSR          __ASM("xpsr"); | ||||
|   return(__regXPSR); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Process Stack Pointer | ||||
|   \details Returns the current value of the Process Stack Pointer (PSP). | ||||
|   \return               PSP Register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_PSP(void) | ||||
| { | ||||
|   register uint32_t __regProcessStackPointer  __ASM("psp"); | ||||
|   return(__regProcessStackPointer); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Process Stack Pointer | ||||
|   \details Assigns the given value to the Process Stack Pointer (PSP). | ||||
|   \param [in]    topOfProcStack  Process Stack Pointer value to set | ||||
|  */ | ||||
| __STATIC_INLINE void __set_PSP(uint32_t topOfProcStack) | ||||
| { | ||||
|   register uint32_t __regProcessStackPointer  __ASM("psp"); | ||||
|   __regProcessStackPointer = topOfProcStack; | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Main Stack Pointer | ||||
|   \details Returns the current value of the Main Stack Pointer (MSP). | ||||
|   \return               MSP Register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_MSP(void) | ||||
| { | ||||
|   register uint32_t __regMainStackPointer     __ASM("msp"); | ||||
|   return(__regMainStackPointer); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Main Stack Pointer | ||||
|   \details Assigns the given value to the Main Stack Pointer (MSP). | ||||
|   \param [in]    topOfMainStack  Main Stack Pointer value to set | ||||
|  */ | ||||
| __STATIC_INLINE void __set_MSP(uint32_t topOfMainStack) | ||||
| { | ||||
|   register uint32_t __regMainStackPointer     __ASM("msp"); | ||||
|   __regMainStackPointer = topOfMainStack; | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Priority Mask | ||||
|   \details Returns the current state of the priority mask bit from the Priority Mask Register. | ||||
|   \return               Priority Mask value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_PRIMASK(void) | ||||
| { | ||||
|   register uint32_t __regPriMask         __ASM("primask"); | ||||
|   return(__regPriMask); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Priority Mask | ||||
|   \details Assigns the given value to the Priority Mask Register. | ||||
|   \param [in]    priMask  Priority Mask | ||||
|  */ | ||||
| __STATIC_INLINE void __set_PRIMASK(uint32_t priMask) | ||||
| { | ||||
|   register uint32_t __regPriMask         __ASM("primask"); | ||||
|   __regPriMask = (priMask); | ||||
| } | ||||
|  | ||||
|  | ||||
| #if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__  == 1)) || \ | ||||
|      (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1))     ) | ||||
|  | ||||
| /** | ||||
|   \brief   Enable FIQ | ||||
|   \details Enables FIQ interrupts by clearing the F-bit in the CPSR. | ||||
|            Can only be executed in Privileged modes. | ||||
|  */ | ||||
| #define __enable_fault_irq                __enable_fiq | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Disable FIQ | ||||
|   \details Disables FIQ interrupts by setting the F-bit in the CPSR. | ||||
|            Can only be executed in Privileged modes. | ||||
|  */ | ||||
| #define __disable_fault_irq               __disable_fiq | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Base Priority | ||||
|   \details Returns the current value of the Base Priority register. | ||||
|   \return               Base Priority register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t  __get_BASEPRI(void) | ||||
| { | ||||
|   register uint32_t __regBasePri         __ASM("basepri"); | ||||
|   return(__regBasePri); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Base Priority | ||||
|   \details Assigns the given value to the Base Priority register. | ||||
|   \param [in]    basePri  Base Priority value to set | ||||
|  */ | ||||
| __STATIC_INLINE void __set_BASEPRI(uint32_t basePri) | ||||
| { | ||||
|   register uint32_t __regBasePri         __ASM("basepri"); | ||||
|   __regBasePri = (basePri & 0xFFU); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Base Priority with condition | ||||
|   \details Assigns the given value to the Base Priority register only if BASEPRI masking is disabled, | ||||
|            or the new value increases the BASEPRI priority level. | ||||
|   \param [in]    basePri  Base Priority value to set | ||||
|  */ | ||||
| __STATIC_INLINE void __set_BASEPRI_MAX(uint32_t basePri) | ||||
| { | ||||
|   register uint32_t __regBasePriMax      __ASM("basepri_max"); | ||||
|   __regBasePriMax = (basePri & 0xFFU); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Fault Mask | ||||
|   \details Returns the current value of the Fault Mask register. | ||||
|   \return               Fault Mask register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_FAULTMASK(void) | ||||
| { | ||||
|   register uint32_t __regFaultMask       __ASM("faultmask"); | ||||
|   return(__regFaultMask); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Fault Mask | ||||
|   \details Assigns the given value to the Fault Mask register. | ||||
|   \param [in]    faultMask  Fault Mask value to set | ||||
|  */ | ||||
| __STATIC_INLINE void __set_FAULTMASK(uint32_t faultMask) | ||||
| { | ||||
|   register uint32_t __regFaultMask       __ASM("faultmask"); | ||||
|   __regFaultMask = (faultMask & (uint32_t)1U); | ||||
| } | ||||
|  | ||||
| #endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__  == 1)) || \ | ||||
|            (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1))     ) */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get FPSCR | ||||
|   \details Returns the current value of the Floating Point Status/Control register. | ||||
|   \return               Floating Point Status/Control register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_FPSCR(void) | ||||
| { | ||||
| #if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ | ||||
|      (defined (__FPU_USED   ) && (__FPU_USED    == 1U))     ) | ||||
|   register uint32_t __regfpscr         __ASM("fpscr"); | ||||
|   return(__regfpscr); | ||||
| #else | ||||
|    return(0U); | ||||
| #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set FPSCR | ||||
|   \details Assigns the given value to the Floating Point Status/Control register. | ||||
|   \param [in]    fpscr  Floating Point Status/Control value to set | ||||
|  */ | ||||
| __STATIC_INLINE void __set_FPSCR(uint32_t fpscr) | ||||
| { | ||||
| #if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ | ||||
|      (defined (__FPU_USED   ) && (__FPU_USED    == 1U))     ) | ||||
|   register uint32_t __regfpscr         __ASM("fpscr"); | ||||
|   __regfpscr = (fpscr); | ||||
| #else | ||||
|   (void)fpscr; | ||||
| #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /*@} end of CMSIS_Core_RegAccFunctions */ | ||||
|  | ||||
|  | ||||
| /* ##########################  Core Instruction Access  ######################### */ | ||||
| /** \defgroup CMSIS_Core_InstructionInterface CMSIS Core Instruction Interface | ||||
|   Access to dedicated instructions | ||||
| @@ -172,21 +444,33 @@ | ||||
|            so that all instructions following the ISB are fetched from cache or memory, | ||||
|            after the instruction has been completed. | ||||
|  */ | ||||
| #define __ISB()                           __isb(0xF) | ||||
| #define __ISB() do {\ | ||||
|                    __schedule_barrier();\ | ||||
|                    __isb(0xF);\ | ||||
|                    __schedule_barrier();\ | ||||
|                 } while (0U) | ||||
|  | ||||
| /** | ||||
|   \brief   Data Synchronization Barrier | ||||
|   \details Acts as a special kind of Data Memory Barrier. | ||||
|            It completes when all explicit memory accesses before this instruction complete. | ||||
|  */ | ||||
| #define __DSB()                           __dsb(0xF) | ||||
| #define __DSB() do {\ | ||||
|                    __schedule_barrier();\ | ||||
|                    __dsb(0xF);\ | ||||
|                    __schedule_barrier();\ | ||||
|                 } while (0U) | ||||
|  | ||||
| /** | ||||
|   \brief   Data Memory Barrier | ||||
|   \details Ensures the apparent order of the explicit memory operations before | ||||
|            and after the instruction, without ensuring their completion. | ||||
|  */ | ||||
| #define __DMB()                           __dmb(0xF) | ||||
| #define __DMB() do {\ | ||||
|                    __schedule_barrier();\ | ||||
|                    __dmb(0xF);\ | ||||
|                    __schedule_barrier();\ | ||||
|                 } while (0U) | ||||
|  | ||||
|                    | ||||
| /** | ||||
| @@ -526,280 +810,6 @@ __attribute__((always_inline)) __STATIC_INLINE uint32_t __USAT(int32_t val, uint | ||||
| /*@}*/ /* end of group CMSIS_Core_InstructionInterface */ | ||||
|  | ||||
|  | ||||
| /* ###########################  Core Function Access  ########################### */ | ||||
| /** \ingroup  CMSIS_Core_FunctionInterface | ||||
|     \defgroup CMSIS_Core_RegAccFunctions CMSIS Core Register Access Functions | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief   Enable IRQ Interrupts | ||||
|   \details Enables IRQ interrupts by clearing special-purpose register PRIMASK. | ||||
|            Can only be executed in Privileged modes. | ||||
|  */ | ||||
| /* intrinsic void __enable_irq();     */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Disable IRQ Interrupts | ||||
|   \details Disables IRQ interrupts by setting special-purpose register PRIMASK. | ||||
|            Can only be executed in Privileged modes. | ||||
|  */ | ||||
| /* intrinsic void __disable_irq();    */ | ||||
|  | ||||
| /** | ||||
|   \brief   Get Control Register | ||||
|   \details Returns the content of the Control Register. | ||||
|   \return               Control Register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_CONTROL(void) | ||||
| { | ||||
|   register uint32_t __regControl         __ASM("control"); | ||||
|   return(__regControl); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Control Register | ||||
|   \details Writes the given value to the Control Register. | ||||
|   \param [in]    control  Control Register value to set | ||||
|  */ | ||||
| __STATIC_INLINE void __set_CONTROL(uint32_t control) | ||||
| { | ||||
|   register uint32_t __regControl         __ASM("control"); | ||||
|   __regControl = control; | ||||
|   __ISB(); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get IPSR Register | ||||
|   \details Returns the content of the IPSR Register. | ||||
|   \return               IPSR Register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_IPSR(void) | ||||
| { | ||||
|   register uint32_t __regIPSR          __ASM("ipsr"); | ||||
|   return(__regIPSR); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get APSR Register | ||||
|   \details Returns the content of the APSR Register. | ||||
|   \return               APSR Register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_APSR(void) | ||||
| { | ||||
|   register uint32_t __regAPSR          __ASM("apsr"); | ||||
|   return(__regAPSR); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get xPSR Register | ||||
|   \details Returns the content of the xPSR Register. | ||||
|   \return               xPSR Register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_xPSR(void) | ||||
| { | ||||
|   register uint32_t __regXPSR          __ASM("xpsr"); | ||||
|   return(__regXPSR); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Process Stack Pointer | ||||
|   \details Returns the current value of the Process Stack Pointer (PSP). | ||||
|   \return               PSP Register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_PSP(void) | ||||
| { | ||||
|   register uint32_t __regProcessStackPointer  __ASM("psp"); | ||||
|   return(__regProcessStackPointer); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Process Stack Pointer | ||||
|   \details Assigns the given value to the Process Stack Pointer (PSP). | ||||
|   \param [in]    topOfProcStack  Process Stack Pointer value to set | ||||
|  */ | ||||
| __STATIC_INLINE void __set_PSP(uint32_t topOfProcStack) | ||||
| { | ||||
|   register uint32_t __regProcessStackPointer  __ASM("psp"); | ||||
|   __regProcessStackPointer = topOfProcStack; | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Main Stack Pointer | ||||
|   \details Returns the current value of the Main Stack Pointer (MSP). | ||||
|   \return               MSP Register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_MSP(void) | ||||
| { | ||||
|   register uint32_t __regMainStackPointer     __ASM("msp"); | ||||
|   return(__regMainStackPointer); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Main Stack Pointer | ||||
|   \details Assigns the given value to the Main Stack Pointer (MSP). | ||||
|   \param [in]    topOfMainStack  Main Stack Pointer value to set | ||||
|  */ | ||||
| __STATIC_INLINE void __set_MSP(uint32_t topOfMainStack) | ||||
| { | ||||
|   register uint32_t __regMainStackPointer     __ASM("msp"); | ||||
|   __regMainStackPointer = topOfMainStack; | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Priority Mask | ||||
|   \details Returns the current state of the priority mask bit from the Priority Mask Register. | ||||
|   \return               Priority Mask value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_PRIMASK(void) | ||||
| { | ||||
|   register uint32_t __regPriMask         __ASM("primask"); | ||||
|   return(__regPriMask); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Priority Mask | ||||
|   \details Assigns the given value to the Priority Mask Register. | ||||
|   \param [in]    priMask  Priority Mask | ||||
|  */ | ||||
| __STATIC_INLINE void __set_PRIMASK(uint32_t priMask) | ||||
| { | ||||
|   register uint32_t __regPriMask         __ASM("primask"); | ||||
|   __regPriMask = (priMask); | ||||
| } | ||||
|  | ||||
|  | ||||
| #if ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__  == 1)) || \ | ||||
|      (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1))     ) | ||||
|  | ||||
| /** | ||||
|   \brief   Enable FIQ | ||||
|   \details Enables FIQ interrupts by clearing special-purpose register FAULTMASK. | ||||
|            Can only be executed in Privileged modes. | ||||
|  */ | ||||
| #define __enable_fault_irq                __enable_fiq | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Disable FIQ | ||||
|   \details Disables FIQ interrupts by setting special-purpose register FAULTMASK. | ||||
|            Can only be executed in Privileged modes. | ||||
|  */ | ||||
| #define __disable_fault_irq               __disable_fiq | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Base Priority | ||||
|   \details Returns the current value of the Base Priority register. | ||||
|   \return               Base Priority register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t  __get_BASEPRI(void) | ||||
| { | ||||
|   register uint32_t __regBasePri         __ASM("basepri"); | ||||
|   return(__regBasePri); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Base Priority | ||||
|   \details Assigns the given value to the Base Priority register. | ||||
|   \param [in]    basePri  Base Priority value to set | ||||
|  */ | ||||
| __STATIC_INLINE void __set_BASEPRI(uint32_t basePri) | ||||
| { | ||||
|   register uint32_t __regBasePri         __ASM("basepri"); | ||||
|   __regBasePri = (basePri & 0xFFU); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Base Priority with condition | ||||
|   \details Assigns the given value to the Base Priority register only if BASEPRI masking is disabled, | ||||
|            or the new value increases the BASEPRI priority level. | ||||
|   \param [in]    basePri  Base Priority value to set | ||||
|  */ | ||||
| __STATIC_INLINE void __set_BASEPRI_MAX(uint32_t basePri) | ||||
| { | ||||
|   register uint32_t __regBasePriMax      __ASM("basepri_max"); | ||||
|   __regBasePriMax = (basePri & 0xFFU); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Fault Mask | ||||
|   \details Returns the current value of the Fault Mask register. | ||||
|   \return               Fault Mask register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_FAULTMASK(void) | ||||
| { | ||||
|   register uint32_t __regFaultMask       __ASM("faultmask"); | ||||
|   return(__regFaultMask); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Fault Mask | ||||
|   \details Assigns the given value to the Fault Mask register. | ||||
|   \param [in]    faultMask  Fault Mask value to set | ||||
|  */ | ||||
| __STATIC_INLINE void __set_FAULTMASK(uint32_t faultMask) | ||||
| { | ||||
|   register uint32_t __regFaultMask       __ASM("faultmask"); | ||||
|   __regFaultMask = (faultMask & (uint32_t)1U); | ||||
| } | ||||
|  | ||||
| #endif /* ((defined (__ARM_ARCH_7M__ ) && (__ARM_ARCH_7M__  == 1)) || \ | ||||
|            (defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1))     ) */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get FPSCR | ||||
|   \details Returns the current value of the Floating Point Status/Control register. | ||||
|   \return               Floating Point Status/Control register value | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __get_FPSCR(void) | ||||
| { | ||||
| #if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ | ||||
|      (defined (__FPU_USED   ) && (__FPU_USED    == 1U))     ) | ||||
|   register uint32_t __regfpscr         __ASM("fpscr"); | ||||
|   return(__regfpscr); | ||||
| #else | ||||
|    return(0U); | ||||
| #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set FPSCR | ||||
|   \details Assigns the given value to the Floating Point Status/Control register. | ||||
|   \param [in]    fpscr  Floating Point Status/Control value to set | ||||
|  */ | ||||
| __STATIC_INLINE void __set_FPSCR(uint32_t fpscr) | ||||
| { | ||||
| #if ((defined (__FPU_PRESENT) && (__FPU_PRESENT == 1U)) && \ | ||||
|      (defined (__FPU_USED   ) && (__FPU_USED    == 1U))     ) | ||||
|   register uint32_t __regfpscr         __ASM("fpscr"); | ||||
|   __regfpscr = (fpscr); | ||||
| #else | ||||
|   (void)fpscr; | ||||
| #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /*@} end of CMSIS_Core_RegAccFunctions */ | ||||
|  | ||||
|  | ||||
| /* ###################  Compiler specific Intrinsics  ########################### */ | ||||
| /** \defgroup CMSIS_SIMD_intrinsics CMSIS SIMD Intrinsics | ||||
|   Access to dedicated SIMD instructions | ||||
| @@ -877,10 +887,6 @@ __STATIC_INLINE void __set_FPSCR(uint32_t fpscr) | ||||
| #define __SMMLA(ARG1,ARG2,ARG3)          ( (int32_t)((((int64_t)(ARG1) * (ARG2)) + \ | ||||
|                                                       ((int64_t)(ARG3) << 32U)     ) >> 32U)) | ||||
|  | ||||
| #define __SXTB16_RORn(ARG1, ARG2)        __SXTB16(__ROR(ARG1, ARG2)) | ||||
|  | ||||
| #define __SXTAB16_RORn(ARG1, ARG2, ARG3) __SXTAB16(ARG1, __ROR(ARG2, ARG3)) | ||||
|  | ||||
| #endif /* ((defined (__ARM_ARCH_7EM__) && (__ARM_ARCH_7EM__ == 1))     ) */ | ||||
| /*@} end of group CMSIS_SIMD_intrinsics */ | ||||
|  | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,16 +1,14 @@ | ||||
| /**************************************************************************//** | ||||
|  * @file     cmsis_iccarm.h | ||||
|  * @brief    CMSIS compiler ICCARM (IAR Compiler for Arm) header file | ||||
|  * @version  V5.3.0 | ||||
|  * @date     14. April 2021 | ||||
|  * @version  V5.1.0 | ||||
|  * @date     08. May 2019 | ||||
|  ******************************************************************************/ | ||||
|  | ||||
| //------------------------------------------------------------------------------ | ||||
| // | ||||
| // Copyright (c) 2017-2021 IAR Systems | ||||
| // Copyright (c) 2017-2021 Arm Limited. All rights reserved. | ||||
| // | ||||
| // SPDX-License-Identifier: Apache-2.0 | ||||
| // Copyright (c) 2017-2019 IAR Systems | ||||
| // Copyright (c) 2017-2019 Arm Limited. All rights reserved.  | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License") | ||||
| // you may not use this file except in compliance with the License. | ||||
| @@ -238,7 +236,6 @@ __packed struct  __iar_u32 { uint32_t v; }; | ||||
|   #endif | ||||
| #endif | ||||
|  | ||||
| #undef __WEAK                           /* undo the definition from DLib_Defaults.h */ | ||||
| #ifndef   __WEAK | ||||
|   #if __ICCARM_V8 | ||||
|     #define __WEAK __attribute__((weak)) | ||||
| @@ -267,24 +264,6 @@ __packed struct  __iar_u32 { uint32_t v; }; | ||||
| #define __VECTOR_TABLE_ATTRIBUTE  @".intvec" | ||||
| #endif | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
| #ifndef __STACK_SEAL | ||||
| #define __STACK_SEAL              STACKSEAL$$Base | ||||
| #endif | ||||
|  | ||||
| #ifndef __TZ_STACK_SEAL_SIZE | ||||
| #define __TZ_STACK_SEAL_SIZE      8U | ||||
| #endif | ||||
|  | ||||
| #ifndef __TZ_STACK_SEAL_VALUE | ||||
| #define __TZ_STACK_SEAL_VALUE     0xFEF5EDA5FEF5EDA5ULL | ||||
| #endif | ||||
|  | ||||
| __STATIC_FORCEINLINE void __TZ_set_STACKSEAL_S (uint32_t* stackTop) { | ||||
|   *((uint64_t *)stackTop) = __TZ_STACK_SEAL_VALUE; | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #ifndef __ICCARM_INTRINSICS_VERSION__ | ||||
|   #define __ICCARM_INTRINSICS_VERSION__  0 | ||||
| #endif | ||||
| @@ -355,13 +334,7 @@ __STATIC_FORCEINLINE void __TZ_set_STACKSEAL_S (uint32_t* stackTop) { | ||||
|  | ||||
|   #define __set_BASEPRI(VALUE)        (__arm_wsr("BASEPRI", (VALUE))) | ||||
|   #define __set_BASEPRI_MAX(VALUE)    (__arm_wsr("BASEPRI_MAX", (VALUE))) | ||||
|  | ||||
| __STATIC_FORCEINLINE void __set_CONTROL(uint32_t control) | ||||
| { | ||||
|   __arm_wsr("CONTROL", control); | ||||
|   __iar_builtin_ISB(); | ||||
| } | ||||
|  | ||||
|   #define __set_CONTROL(VALUE)        (__arm_wsr("CONTROL", (VALUE))) | ||||
|   #define __set_FAULTMASK(VALUE)      (__arm_wsr("FAULTMASK", (VALUE))) | ||||
|   #define __set_MSP(VALUE)            (__arm_wsr("MSP", (VALUE))) | ||||
|  | ||||
| @@ -383,13 +356,7 @@ __STATIC_FORCEINLINE void __set_CONTROL(uint32_t control) | ||||
|   #endif | ||||
|  | ||||
|   #define __TZ_get_CONTROL_NS()       (__arm_rsr("CONTROL_NS")) | ||||
|  | ||||
| __STATIC_FORCEINLINE void __TZ_set_CONTROL_NS(uint32_t control) | ||||
| { | ||||
|   __arm_wsr("CONTROL_NS", control); | ||||
|   __iar_builtin_ISB(); | ||||
| } | ||||
|  | ||||
|   #define __TZ_set_CONTROL_NS(VALUE)  (__arm_wsr("CONTROL_NS", (VALUE))) | ||||
|   #define __TZ_get_PSP_NS()           (__arm_rsr("PSP_NS")) | ||||
|   #define __TZ_set_PSP_NS(VALUE)      (__arm_wsr("PSP_NS", (VALUE))) | ||||
|   #define __TZ_get_MSP_NS()           (__arm_rsr("MSP_NS")) | ||||
| @@ -629,7 +596,7 @@ __STATIC_FORCEINLINE void __TZ_set_CONTROL_NS(uint32_t control) | ||||
|     __IAR_FT uint32_t __RRX(uint32_t value) | ||||
|     { | ||||
|       uint32_t result; | ||||
|       __ASM volatile("RRX      %0, %1" : "=r"(result) : "r" (value)); | ||||
|       __ASM("RRX      %0, %1" : "=r"(result) : "r" (value) : "cc"); | ||||
|       return(result); | ||||
|     } | ||||
|  | ||||
| @@ -711,7 +678,6 @@ __STATIC_FORCEINLINE void __TZ_set_CONTROL_NS(uint32_t control) | ||||
|     __IAR_FT void   __TZ_set_CONTROL_NS(uint32_t value) | ||||
|     { | ||||
|       __asm volatile("MSR      CONTROL_NS,%0" :: "r" (value)); | ||||
|       __iar_builtin_ISB(); | ||||
|     } | ||||
|  | ||||
|     __IAR_FT uint32_t   __TZ_get_PSP_NS(void) | ||||
| @@ -869,37 +835,37 @@ __STATIC_FORCEINLINE void __TZ_set_CONTROL_NS(uint32_t control) | ||||
|   __IAR_FT uint8_t __LDRBT(volatile uint8_t *addr) | ||||
|   { | ||||
|     uint32_t res; | ||||
|     __ASM volatile ("LDRBT %0, [%1]" : "=r" (res) : "r" (addr) : "memory"); | ||||
|     __ASM("LDRBT %0, [%1]" : "=r" (res) : "r" (addr) : "memory"); | ||||
|     return ((uint8_t)res); | ||||
|   } | ||||
|  | ||||
|   __IAR_FT uint16_t __LDRHT(volatile uint16_t *addr) | ||||
|   { | ||||
|     uint32_t res; | ||||
|     __ASM volatile ("LDRHT %0, [%1]" : "=r" (res) : "r" (addr) : "memory"); | ||||
|     __ASM("LDRHT %0, [%1]" : "=r" (res) : "r" (addr) : "memory"); | ||||
|     return ((uint16_t)res); | ||||
|   } | ||||
|  | ||||
|   __IAR_FT uint32_t __LDRT(volatile uint32_t *addr) | ||||
|   { | ||||
|     uint32_t res; | ||||
|     __ASM volatile ("LDRT %0, [%1]" : "=r" (res) : "r" (addr) : "memory"); | ||||
|     __ASM("LDRT %0, [%1]" : "=r" (res) : "r" (addr) : "memory"); | ||||
|     return res; | ||||
|   } | ||||
|  | ||||
|   __IAR_FT void __STRBT(uint8_t value, volatile uint8_t *addr) | ||||
|   { | ||||
|     __ASM volatile ("STRBT %1, [%0]" : : "r" (addr), "r" ((uint32_t)value) : "memory"); | ||||
|     __ASM("STRBT %1, [%0]" : : "r" (addr), "r" ((uint32_t)value) : "memory"); | ||||
|   } | ||||
|  | ||||
|   __IAR_FT void __STRHT(uint16_t value, volatile uint16_t *addr) | ||||
|   { | ||||
|     __ASM volatile ("STRHT %1, [%0]" : : "r" (addr), "r" ((uint32_t)value) : "memory"); | ||||
|     __ASM("STRHT %1, [%0]" : : "r" (addr), "r" ((uint32_t)value) : "memory"); | ||||
|   } | ||||
|  | ||||
|   __IAR_FT void __STRT(uint32_t value, volatile uint32_t *addr) | ||||
|   { | ||||
|     __ASM volatile ("STRT %1, [%0]" : : "r" (addr), "r" (value) : "memory"); | ||||
|     __ASM("STRT %1, [%0]" : : "r" (addr), "r" (value) : "memory"); | ||||
|   } | ||||
|  | ||||
| #endif /* (__CORTEX_M >= 0x03) */ | ||||
| @@ -995,8 +961,4 @@ __STATIC_FORCEINLINE void __TZ_set_CONTROL_NS(uint32_t control) | ||||
| #pragma diag_default=Pe940 | ||||
| #pragma diag_default=Pe177 | ||||
|  | ||||
| #define __SXTB16_RORn(ARG1, ARG2) __SXTB16(__ROR(ARG1, ARG2)) | ||||
|  | ||||
| #define __SXTAB16_RORn(ARG1, ARG2, ARG3) __SXTAB16(ARG1, __ROR(ARG2, ARG3)) | ||||
|  | ||||
| #endif /* __CMSIS_ICCARM_H__ */ | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
| /**************************************************************************//** | ||||
|  * @file     cmsis_version.h | ||||
|  * @brief    CMSIS Core(M) Version definitions | ||||
|  * @version  V5.0.5 | ||||
|  * @date     02. February 2022 | ||||
|  * @version  V5.0.3 | ||||
|  * @date     24. June 2019 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2009-2022 ARM Limited. All rights reserved. | ||||
|  * Copyright (c) 2009-2019 ARM Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
| @@ -33,7 +33,7 @@ | ||||
|  | ||||
| /*  CMSIS Version definitions */ | ||||
| #define __CM_CMSIS_VERSION_MAIN  ( 5U)                                      /*!< [31:16] CMSIS Core(M) main version */ | ||||
| #define __CM_CMSIS_VERSION_SUB   ( 6U)                                      /*!< [15:0]  CMSIS Core(M) sub version */ | ||||
| #define __CM_CMSIS_VERSION_SUB   ( 3U)                                      /*!< [15:0]  CMSIS Core(M) sub version */ | ||||
| #define __CM_CMSIS_VERSION       ((__CM_CMSIS_VERSION_MAIN << 16U) | \ | ||||
|                                    __CM_CMSIS_VERSION_SUB           )       /*!< CMSIS Core(M) version number */ | ||||
| #endif | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,11 +1,11 @@ | ||||
| /**************************************************************************//** | ||||
|  * @file     core_armv8mbl.h | ||||
|  * @brief    CMSIS Armv8-M Baseline Core Peripheral Access Layer Header File | ||||
|  * @version  V5.1.0 | ||||
|  * @date     27. March 2020 | ||||
|  * @version  V5.0.8 | ||||
|  * @date     12. November 2018 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2009-2020 Arm Limited. All rights reserved. | ||||
|  * Copyright (c) 2009-2018 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
| @@ -26,8 +26,6 @@ | ||||
|   #pragma system_include         /* treat file as system include file for MISRA check */ | ||||
| #elif defined (__clang__) | ||||
|   #pragma clang system_header   /* treat file as system include file */ | ||||
| #elif defined ( __GNUC__ ) | ||||
|   #pragma GCC diagnostic ignored "-Wpedantic"   /* disable pedantic warning due to unnamed structs/unions */ | ||||
| #endif | ||||
|  | ||||
| #ifndef __CORE_ARMV8MBL_H_GENERIC | ||||
| @@ -70,7 +68,7 @@ | ||||
| #define __ARMv8MBL_CMSIS_VERSION       ((__ARMv8MBL_CMSIS_VERSION_MAIN << 16U) | \ | ||||
|                                          __ARMv8MBL_CMSIS_VERSION_SUB           )  /*!< \deprecated CMSIS HAL version number */ | ||||
|  | ||||
| #define __CORTEX_M                     (2U)                                        /*!< Cortex-M Core */ | ||||
| #define __CORTEX_M                     ( 2U)                                            /*!< Cortex-M Core */ | ||||
|  | ||||
| /** __FPU_USED indicates whether an FPU is used or not. | ||||
|     This core does not support an FPU at all | ||||
| @@ -977,7 +975,6 @@ typedef struct | ||||
| #endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ | ||||
|  | ||||
|  | ||||
| /* CoreDebug is deprecated. replaced by DCB (Debug Control Block) */ | ||||
| /** | ||||
|   \ingroup  CMSIS_core_register | ||||
|   \defgroup CMSIS_CoreDebug       Core Debug Registers (CoreDebug) | ||||
| @@ -986,7 +983,7 @@ typedef struct | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief  \deprecated Structure type to access the Core Debug Register (CoreDebug). | ||||
|   \brief  Structure type to access the Core Debug Register (CoreDebug). | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
| @@ -994,276 +991,91 @@ typedef struct | ||||
|   __OM  uint32_t DCRSR;                  /*!< Offset: 0x004 ( /W)  Debug Core Register Selector Register */ | ||||
|   __IOM uint32_t DCRDR;                  /*!< Offset: 0x008 (R/W)  Debug Core Register Data Register */ | ||||
|   __IOM uint32_t DEMCR;                  /*!< Offset: 0x00C (R/W)  Debug Exception and Monitor Control Register */ | ||||
|         uint32_t RESERVED0[1U]; | ||||
|         uint32_t RESERVED4[1U]; | ||||
|   __IOM uint32_t DAUTHCTRL;              /*!< Offset: 0x014 (R/W)  Debug Authentication Control Register */ | ||||
|   __IOM uint32_t DSCSR;                  /*!< Offset: 0x018 (R/W)  Debug Security Control and Status Register */ | ||||
| } CoreDebug_Type; | ||||
|  | ||||
| /* Debug Halting Control and Status Register Definitions */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Pos         16U                                            /*!< \deprecated CoreDebug DHCSR: DBGKEY Position */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Msk         (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos)       /*!< \deprecated CoreDebug DHCSR: DBGKEY Mask */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Pos         16U                                            /*!< CoreDebug DHCSR: DBGKEY Position */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Msk         (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos)       /*!< CoreDebug DHCSR: DBGKEY Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Pos   26U                                            /*!< \deprecated CoreDebug DHCSR: S_RESTART_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Msk   (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos)      /*!< \deprecated CoreDebug DHCSR: S_RESTART_ST Mask */ | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Pos   26U                                            /*!< CoreDebug DHCSR: S_RESTART_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Msk   (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos)      /*!< CoreDebug DHCSR: S_RESTART_ST Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Pos     25U                                            /*!< \deprecated CoreDebug DHCSR: S_RESET_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Msk     (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos)        /*!< \deprecated CoreDebug DHCSR: S_RESET_ST Mask */ | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Pos     25U                                            /*!< CoreDebug DHCSR: S_RESET_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Msk     (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos)        /*!< CoreDebug DHCSR: S_RESET_ST Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Pos    24U                                            /*!< \deprecated CoreDebug DHCSR: S_RETIRE_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Msk    (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos)       /*!< \deprecated CoreDebug DHCSR: S_RETIRE_ST Mask */ | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Pos    24U                                            /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Msk    (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos)       /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Pos       19U                                            /*!< \deprecated CoreDebug DHCSR: S_LOCKUP Position */ | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Msk       (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos)          /*!< \deprecated CoreDebug DHCSR: S_LOCKUP Mask */ | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Pos       19U                                            /*!< CoreDebug DHCSR: S_LOCKUP Position */ | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Msk       (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos)          /*!< CoreDebug DHCSR: S_LOCKUP Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Pos        18U                                            /*!< \deprecated CoreDebug DHCSR: S_SLEEP Position */ | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Msk        (1UL << CoreDebug_DHCSR_S_SLEEP_Pos)           /*!< \deprecated CoreDebug DHCSR: S_SLEEP Mask */ | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Pos        18U                                            /*!< CoreDebug DHCSR: S_SLEEP Position */ | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Msk        (1UL << CoreDebug_DHCSR_S_SLEEP_Pos)           /*!< CoreDebug DHCSR: S_SLEEP Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_HALT_Pos         17U                                            /*!< \deprecated CoreDebug DHCSR: S_HALT Position */ | ||||
| #define CoreDebug_DHCSR_S_HALT_Msk         (1UL << CoreDebug_DHCSR_S_HALT_Pos)            /*!< \deprecated CoreDebug DHCSR: S_HALT Mask */ | ||||
| #define CoreDebug_DHCSR_S_HALT_Pos         17U                                            /*!< CoreDebug DHCSR: S_HALT Position */ | ||||
| #define CoreDebug_DHCSR_S_HALT_Msk         (1UL << CoreDebug_DHCSR_S_HALT_Pos)            /*!< CoreDebug DHCSR: S_HALT Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Pos       16U                                            /*!< \deprecated CoreDebug DHCSR: S_REGRDY Position */ | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Msk       (1UL << CoreDebug_DHCSR_S_REGRDY_Pos)          /*!< \deprecated CoreDebug DHCSR: S_REGRDY Mask */ | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Pos       16U                                            /*!< CoreDebug DHCSR: S_REGRDY Position */ | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Msk       (1UL << CoreDebug_DHCSR_S_REGRDY_Pos)          /*!< CoreDebug DHCSR: S_REGRDY Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Pos      3U                                            /*!< \deprecated CoreDebug DHCSR: C_MASKINTS Position */ | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Msk     (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos)        /*!< \deprecated CoreDebug DHCSR: C_MASKINTS Mask */ | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Pos      3U                                            /*!< CoreDebug DHCSR: C_MASKINTS Position */ | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Msk     (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos)        /*!< CoreDebug DHCSR: C_MASKINTS Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_STEP_Pos          2U                                            /*!< \deprecated CoreDebug DHCSR: C_STEP Position */ | ||||
| #define CoreDebug_DHCSR_C_STEP_Msk         (1UL << CoreDebug_DHCSR_C_STEP_Pos)            /*!< \deprecated CoreDebug DHCSR: C_STEP Mask */ | ||||
| #define CoreDebug_DHCSR_C_STEP_Pos          2U                                            /*!< CoreDebug DHCSR: C_STEP Position */ | ||||
| #define CoreDebug_DHCSR_C_STEP_Msk         (1UL << CoreDebug_DHCSR_C_STEP_Pos)            /*!< CoreDebug DHCSR: C_STEP Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_HALT_Pos          1U                                            /*!< \deprecated CoreDebug DHCSR: C_HALT Position */ | ||||
| #define CoreDebug_DHCSR_C_HALT_Msk         (1UL << CoreDebug_DHCSR_C_HALT_Pos)            /*!< \deprecated CoreDebug DHCSR: C_HALT Mask */ | ||||
| #define CoreDebug_DHCSR_C_HALT_Pos          1U                                            /*!< CoreDebug DHCSR: C_HALT Position */ | ||||
| #define CoreDebug_DHCSR_C_HALT_Msk         (1UL << CoreDebug_DHCSR_C_HALT_Pos)            /*!< CoreDebug DHCSR: C_HALT Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Pos       0U                                            /*!< \deprecated CoreDebug DHCSR: C_DEBUGEN Position */ | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Msk      (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/)     /*!< \deprecated CoreDebug DHCSR: C_DEBUGEN Mask */ | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Pos       0U                                            /*!< CoreDebug DHCSR: C_DEBUGEN Position */ | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Msk      (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/)     /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ | ||||
|  | ||||
| /* Debug Core Register Selector Register Definitions */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Pos         16U                                            /*!< \deprecated CoreDebug DCRSR: REGWnR Position */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Msk         (1UL << CoreDebug_DCRSR_REGWnR_Pos)            /*!< \deprecated CoreDebug DCRSR: REGWnR Mask */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Pos         16U                                            /*!< CoreDebug DCRSR: REGWnR Position */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Msk         (1UL << CoreDebug_DCRSR_REGWnR_Pos)            /*!< CoreDebug DCRSR: REGWnR Mask */ | ||||
|  | ||||
| #define CoreDebug_DCRSR_REGSEL_Pos          0U                                            /*!< \deprecated CoreDebug DCRSR: REGSEL Position */ | ||||
| #define CoreDebug_DCRSR_REGSEL_Msk         (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/)     /*!< \deprecated CoreDebug DCRSR: REGSEL Mask */ | ||||
| #define CoreDebug_DCRSR_REGSEL_Pos          0U                                            /*!< CoreDebug DCRSR: REGSEL Position */ | ||||
| #define CoreDebug_DCRSR_REGSEL_Msk         (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/)     /*!< CoreDebug DCRSR: REGSEL Mask */ | ||||
|  | ||||
| /* Debug Exception and Monitor Control Register Definitions */ | ||||
| #define CoreDebug_DEMCR_DWTENA_Pos         24U                                            /*!< \deprecated CoreDebug DEMCR: DWTENA Position */ | ||||
| #define CoreDebug_DEMCR_DWTENA_Msk         (1UL << CoreDebug_DEMCR_DWTENA_Pos)            /*!< \deprecated CoreDebug DEMCR: DWTENA Mask */ | ||||
| /* Debug Exception and Monitor Control Register */ | ||||
| #define CoreDebug_DEMCR_DWTENA_Pos         24U                                            /*!< CoreDebug DEMCR: DWTENA Position */ | ||||
| #define CoreDebug_DEMCR_DWTENA_Msk         (1UL << CoreDebug_DEMCR_DWTENA_Pos)            /*!< CoreDebug DEMCR: DWTENA Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Pos     10U                                            /*!< \deprecated CoreDebug DEMCR: VC_HARDERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Msk     (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos)        /*!< \deprecated CoreDebug DEMCR: VC_HARDERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Pos     10U                                            /*!< CoreDebug DEMCR: VC_HARDERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Msk     (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos)        /*!< CoreDebug DEMCR: VC_HARDERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Pos    0U                                            /*!< \deprecated CoreDebug DEMCR: VC_CORERESET Position */ | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Msk   (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/)  /*!< \deprecated CoreDebug DEMCR: VC_CORERESET Mask */ | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Pos    0U                                            /*!< CoreDebug DEMCR: VC_CORERESET Position */ | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Msk   (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/)  /*!< CoreDebug DEMCR: VC_CORERESET Mask */ | ||||
|  | ||||
| /* Debug Authentication Control Register Definitions */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos  3U                                            /*!< \deprecated CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos)    /*!< \deprecated CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos  3U                                            /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos)    /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ | ||||
|  | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos  2U                                            /*!< \deprecated CoreDebug DAUTHCTRL: SPNIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos)    /*!< \deprecated CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos  2U                                            /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos)    /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ | ||||
|  | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos   1U                                            /*!< \deprecated CoreDebug DAUTHCTRL: INTSPIDEN Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk  (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos)     /*!< \deprecated CoreDebug DAUTHCTRL: INTSPIDEN Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos   1U                                            /*!< CoreDebug DAUTHCTRL: INTSPIDEN Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk  (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos)     /*!< CoreDebug DAUTHCTRL: INTSPIDEN Mask */ | ||||
|  | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos   0U                                            /*!< \deprecated CoreDebug DAUTHCTRL: SPIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk  (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< \deprecated CoreDebug DAUTHCTRL: SPIDENSEL Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos   0U                                            /*!< CoreDebug DAUTHCTRL: SPIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk  (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< CoreDebug DAUTHCTRL: SPIDENSEL Mask */ | ||||
|  | ||||
| /* Debug Security Control and Status Register Definitions */ | ||||
| #define CoreDebug_DSCSR_CDS_Pos            16U                                            /*!< \deprecated CoreDebug DSCSR: CDS Position */ | ||||
| #define CoreDebug_DSCSR_CDS_Msk            (1UL << CoreDebug_DSCSR_CDS_Pos)               /*!< \deprecated CoreDebug DSCSR: CDS Mask */ | ||||
| #define CoreDebug_DSCSR_CDS_Pos            16U                                            /*!< CoreDebug DSCSR: CDS Position */ | ||||
| #define CoreDebug_DSCSR_CDS_Msk            (1UL << CoreDebug_DSCSR_CDS_Pos)               /*!< CoreDebug DSCSR: CDS Mask */ | ||||
|  | ||||
| #define CoreDebug_DSCSR_SBRSEL_Pos          1U                                            /*!< \deprecated CoreDebug DSCSR: SBRSEL Position */ | ||||
| #define CoreDebug_DSCSR_SBRSEL_Msk         (1UL << CoreDebug_DSCSR_SBRSEL_Pos)            /*!< \deprecated CoreDebug DSCSR: SBRSEL Mask */ | ||||
| #define CoreDebug_DSCSR_SBRSEL_Pos          1U                                            /*!< CoreDebug DSCSR: SBRSEL Position */ | ||||
| #define CoreDebug_DSCSR_SBRSEL_Msk         (1UL << CoreDebug_DSCSR_SBRSEL_Pos)            /*!< CoreDebug DSCSR: SBRSEL Mask */ | ||||
|  | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Pos        0U                                            /*!< \deprecated CoreDebug DSCSR: SBRSELEN Position */ | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Msk       (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/)      /*!< \deprecated CoreDebug DSCSR: SBRSELEN Mask */ | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Pos        0U                                            /*!< CoreDebug DSCSR: SBRSELEN Position */ | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Msk       (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/)      /*!< CoreDebug DSCSR: SBRSELEN Mask */ | ||||
|  | ||||
| /*@} end of group CMSIS_CoreDebug */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup    CMSIS_core_register | ||||
|   \defgroup CMSIS_DCB       Debug Control Block | ||||
|   \brief    Type definitions for the Debug Control Block Registers | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief  Structure type to access the Debug Control Block Registers (DCB). | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
|   __IOM uint32_t DHCSR;                  /*!< Offset: 0x000 (R/W)  Debug Halting Control and Status Register */ | ||||
|   __OM  uint32_t DCRSR;                  /*!< Offset: 0x004 ( /W)  Debug Core Register Selector Register */ | ||||
|   __IOM uint32_t DCRDR;                  /*!< Offset: 0x008 (R/W)  Debug Core Register Data Register */ | ||||
|   __IOM uint32_t DEMCR;                  /*!< Offset: 0x00C (R/W)  Debug Exception and Monitor Control Register */ | ||||
|         uint32_t RESERVED0[1U]; | ||||
|   __IOM uint32_t DAUTHCTRL;              /*!< Offset: 0x014 (R/W)  Debug Authentication Control Register */ | ||||
|   __IOM uint32_t DSCSR;                  /*!< Offset: 0x018 (R/W)  Debug Security Control and Status Register */ | ||||
| } DCB_Type; | ||||
|  | ||||
| /* DHCSR, Debug Halting Control and Status Register Definitions */ | ||||
| #define DCB_DHCSR_DBGKEY_Pos               16U                                            /*!< DCB DHCSR: Debug key Position */ | ||||
| #define DCB_DHCSR_DBGKEY_Msk               (0xFFFFUL << DCB_DHCSR_DBGKEY_Pos)             /*!< DCB DHCSR: Debug key Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_RESTART_ST_Pos         26U                                            /*!< DCB DHCSR: Restart sticky status Position */ | ||||
| #define DCB_DHCSR_S_RESTART_ST_Msk         (0x1UL << DCB_DHCSR_S_RESTART_ST_Pos)          /*!< DCB DHCSR: Restart sticky status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_RESET_ST_Pos           25U                                            /*!< DCB DHCSR: Reset sticky status Position */ | ||||
| #define DCB_DHCSR_S_RESET_ST_Msk           (0x1UL << DCB_DHCSR_S_RESET_ST_Pos)            /*!< DCB DHCSR: Reset sticky status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_RETIRE_ST_Pos          24U                                            /*!< DCB DHCSR: Retire sticky status Position */ | ||||
| #define DCB_DHCSR_S_RETIRE_ST_Msk          (0x1UL << DCB_DHCSR_S_RETIRE_ST_Pos)           /*!< DCB DHCSR: Retire sticky status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_SDE_Pos                20U                                            /*!< DCB DHCSR: Secure debug enabled Position */ | ||||
| #define DCB_DHCSR_S_SDE_Msk                (0x1UL << DCB_DHCSR_S_SDE_Pos)                 /*!< DCB DHCSR: Secure debug enabled Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_LOCKUP_Pos             19U                                            /*!< DCB DHCSR: Lockup status Position */ | ||||
| #define DCB_DHCSR_S_LOCKUP_Msk             (0x1UL << DCB_DHCSR_S_LOCKUP_Pos)              /*!< DCB DHCSR: Lockup status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_SLEEP_Pos              18U                                            /*!< DCB DHCSR: Sleeping status Position */ | ||||
| #define DCB_DHCSR_S_SLEEP_Msk              (0x1UL << DCB_DHCSR_S_SLEEP_Pos)               /*!< DCB DHCSR: Sleeping status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_HALT_Pos               17U                                            /*!< DCB DHCSR: Halted status Position */ | ||||
| #define DCB_DHCSR_S_HALT_Msk               (0x1UL << DCB_DHCSR_S_HALT_Pos)                /*!< DCB DHCSR: Halted status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_REGRDY_Pos             16U                                            /*!< DCB DHCSR: Register ready status Position */ | ||||
| #define DCB_DHCSR_S_REGRDY_Msk             (0x1UL << DCB_DHCSR_S_REGRDY_Pos)              /*!< DCB DHCSR: Register ready status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_MASKINTS_Pos            3U                                            /*!< DCB DHCSR: Mask interrupts control Position */ | ||||
| #define DCB_DHCSR_C_MASKINTS_Msk           (0x1UL << DCB_DHCSR_C_MASKINTS_Pos)            /*!< DCB DHCSR: Mask interrupts control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_STEP_Pos                2U                                            /*!< DCB DHCSR: Step control Position */ | ||||
| #define DCB_DHCSR_C_STEP_Msk               (0x1UL << DCB_DHCSR_C_STEP_Pos)                /*!< DCB DHCSR: Step control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_HALT_Pos                1U                                            /*!< DCB DHCSR: Halt control Position */ | ||||
| #define DCB_DHCSR_C_HALT_Msk               (0x1UL << DCB_DHCSR_C_HALT_Pos)                /*!< DCB DHCSR: Halt control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_DEBUGEN_Pos             0U                                            /*!< DCB DHCSR: Debug enable control Position */ | ||||
| #define DCB_DHCSR_C_DEBUGEN_Msk            (0x1UL /*<< DCB_DHCSR_C_DEBUGEN_Pos*/)         /*!< DCB DHCSR: Debug enable control Mask */ | ||||
|  | ||||
| /* DCRSR, Debug Core Register Select Register Definitions */ | ||||
| #define DCB_DCRSR_REGWnR_Pos               16U                                            /*!< DCB DCRSR: Register write/not-read Position */ | ||||
| #define DCB_DCRSR_REGWnR_Msk               (0x1UL << DCB_DCRSR_REGWnR_Pos)                /*!< DCB DCRSR: Register write/not-read Mask */ | ||||
|  | ||||
| #define DCB_DCRSR_REGSEL_Pos                0U                                            /*!< DCB DCRSR: Register selector Position */ | ||||
| #define DCB_DCRSR_REGSEL_Msk               (0x7FUL /*<< DCB_DCRSR_REGSEL_Pos*/)           /*!< DCB DCRSR: Register selector Mask */ | ||||
|  | ||||
| /* DCRDR, Debug Core Register Data Register Definitions */ | ||||
| #define DCB_DCRDR_DBGTMP_Pos                0U                                            /*!< DCB DCRDR: Data temporary buffer Position */ | ||||
| #define DCB_DCRDR_DBGTMP_Msk               (0xFFFFFFFFUL /*<< DCB_DCRDR_DBGTMP_Pos*/)     /*!< DCB DCRDR: Data temporary buffer Mask */ | ||||
|  | ||||
| /* DEMCR, Debug Exception and Monitor Control Register Definitions */ | ||||
| #define DCB_DEMCR_TRCENA_Pos               24U                                            /*!< DCB DEMCR: Trace enable Position */ | ||||
| #define DCB_DEMCR_TRCENA_Msk               (0x1UL << DCB_DEMCR_TRCENA_Pos)                /*!< DCB DEMCR: Trace enable Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_HARDERR_Pos           10U                                            /*!< DCB DEMCR: Vector Catch HardFault errors Position */ | ||||
| #define DCB_DEMCR_VC_HARDERR_Msk           (0x1UL << DCB_DEMCR_VC_HARDERR_Pos)            /*!< DCB DEMCR: Vector Catch HardFault errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_CORERESET_Pos          0U                                            /*!< DCB DEMCR: Vector Catch Core reset Position */ | ||||
| #define DCB_DEMCR_VC_CORERESET_Msk         (0x1UL /*<< DCB_DEMCR_VC_CORERESET_Pos*/)      /*!< DCB DEMCR: Vector Catch Core reset Mask */ | ||||
|  | ||||
| /* DAUTHCTRL, Debug Authentication Control Register Definitions */ | ||||
| #define DCB_DAUTHCTRL_INTSPNIDEN_Pos        3U                                            /*!< DCB DAUTHCTRL: Internal Secure non-invasive debug enable Position */ | ||||
| #define DCB_DAUTHCTRL_INTSPNIDEN_Msk       (0x1UL << DCB_DAUTHCTRL_INTSPNIDEN_Pos)        /*!< DCB DAUTHCTRL: Internal Secure non-invasive debug enable Mask */ | ||||
|  | ||||
| #define DCB_DAUTHCTRL_SPNIDENSEL_Pos        2U                                            /*!< DCB DAUTHCTRL: Secure non-invasive debug enable select Position */ | ||||
| #define DCB_DAUTHCTRL_SPNIDENSEL_Msk       (0x1UL << DCB_DAUTHCTRL_SPNIDENSEL_Pos)        /*!< DCB DAUTHCTRL: Secure non-invasive debug enable select Mask */ | ||||
|  | ||||
| #define DCB_DAUTHCTRL_INTSPIDEN_Pos         1U                                            /*!< DCB DAUTHCTRL: Internal Secure invasive debug enable Position */ | ||||
| #define DCB_DAUTHCTRL_INTSPIDEN_Msk        (0x1UL << DCB_DAUTHCTRL_INTSPIDEN_Pos)         /*!< DCB DAUTHCTRL: Internal Secure invasive debug enable Mask */ | ||||
|  | ||||
| #define DCB_DAUTHCTRL_SPIDENSEL_Pos         0U                                            /*!< DCB DAUTHCTRL: Secure invasive debug enable select Position */ | ||||
| #define DCB_DAUTHCTRL_SPIDENSEL_Msk        (0x1UL /*<< DCB_DAUTHCTRL_SPIDENSEL_Pos*/)     /*!< DCB DAUTHCTRL: Secure invasive debug enable select Mask */ | ||||
|  | ||||
| /* DSCSR, Debug Security Control and Status Register Definitions */ | ||||
| #define DCB_DSCSR_CDSKEY_Pos               17U                                            /*!< DCB DSCSR: CDS write-enable key Position */ | ||||
| #define DCB_DSCSR_CDSKEY_Msk               (0x1UL << DCB_DSCSR_CDSKEY_Pos)                /*!< DCB DSCSR: CDS write-enable key Mask */ | ||||
|  | ||||
| #define DCB_DSCSR_CDS_Pos                  16U                                            /*!< DCB DSCSR: Current domain Secure Position */ | ||||
| #define DCB_DSCSR_CDS_Msk                  (0x1UL << DCB_DSCSR_CDS_Pos)                   /*!< DCB DSCSR: Current domain Secure Mask */ | ||||
|  | ||||
| #define DCB_DSCSR_SBRSEL_Pos                1U                                            /*!< DCB DSCSR: Secure banked register select Position */ | ||||
| #define DCB_DSCSR_SBRSEL_Msk               (0x1UL << DCB_DSCSR_SBRSEL_Pos)                /*!< DCB DSCSR: Secure banked register select Mask */ | ||||
|  | ||||
| #define DCB_DSCSR_SBRSELEN_Pos              0U                                            /*!< DCB DSCSR: Secure banked register select enable Position */ | ||||
| #define DCB_DSCSR_SBRSELEN_Msk             (0x1UL /*<< DCB_DSCSR_SBRSELEN_Pos*/)          /*!< DCB DSCSR: Secure banked register select enable Mask */ | ||||
|  | ||||
| /*@} end of group CMSIS_DCB */ | ||||
|  | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup  CMSIS_core_register | ||||
|   \defgroup CMSIS_DIB       Debug Identification Block | ||||
|   \brief    Type definitions for the Debug Identification Block Registers | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief  Structure type to access the Debug Identification Block Registers (DIB). | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
|   __OM  uint32_t DLAR;                   /*!< Offset: 0x000 ( /W)  SCS Software Lock Access Register */ | ||||
|   __IM  uint32_t DLSR;                   /*!< Offset: 0x004 (R/ )  SCS Software Lock Status Register */ | ||||
|   __IM  uint32_t DAUTHSTATUS;            /*!< Offset: 0x008 (R/ )  Debug Authentication Status Register */ | ||||
|   __IM  uint32_t DDEVARCH;               /*!< Offset: 0x00C (R/ )  SCS Device Architecture Register */ | ||||
|   __IM  uint32_t DDEVTYPE;               /*!< Offset: 0x010 (R/ )  SCS Device Type Register */ | ||||
| } DIB_Type; | ||||
|  | ||||
| /* DLAR, SCS Software Lock Access Register Definitions */ | ||||
| #define DIB_DLAR_KEY_Pos                    0U                                            /*!< DIB DLAR: KEY Position */ | ||||
| #define DIB_DLAR_KEY_Msk                   (0xFFFFFFFFUL /*<< DIB_DLAR_KEY_Pos */)        /*!< DIB DLAR: KEY Mask */ | ||||
|  | ||||
| /* DLSR, SCS Software Lock Status Register Definitions */ | ||||
| #define DIB_DLSR_nTT_Pos                    2U                                            /*!< DIB DLSR: Not thirty-two bit Position */ | ||||
| #define DIB_DLSR_nTT_Msk                   (0x1UL << DIB_DLSR_nTT_Pos )                   /*!< DIB DLSR: Not thirty-two bit Mask */ | ||||
|  | ||||
| #define DIB_DLSR_SLK_Pos                    1U                                            /*!< DIB DLSR: Software Lock status Position */ | ||||
| #define DIB_DLSR_SLK_Msk                   (0x1UL << DIB_DLSR_SLK_Pos )                   /*!< DIB DLSR: Software Lock status Mask */ | ||||
|  | ||||
| #define DIB_DLSR_SLI_Pos                    0U                                            /*!< DIB DLSR: Software Lock implemented Position */ | ||||
| #define DIB_DLSR_SLI_Msk                   (0x1UL /*<< DIB_DLSR_SLI_Pos*/)                /*!< DIB DLSR: Software Lock implemented Mask */ | ||||
|  | ||||
| /* DAUTHSTATUS, Debug Authentication Status Register Definitions */ | ||||
| #define DIB_DAUTHSTATUS_SNID_Pos            6U                                            /*!< DIB DAUTHSTATUS: Secure Non-invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_SNID_Msk           (0x3UL << DIB_DAUTHSTATUS_SNID_Pos )           /*!< DIB DAUTHSTATUS: Secure Non-invasive Debug Mask */ | ||||
|  | ||||
| #define DIB_DAUTHSTATUS_SID_Pos             4U                                            /*!< DIB DAUTHSTATUS: Secure Invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_SID_Msk            (0x3UL << DIB_DAUTHSTATUS_SID_Pos )            /*!< DIB DAUTHSTATUS: Secure Invasive Debug Mask */ | ||||
|  | ||||
| #define DIB_DAUTHSTATUS_NSNID_Pos           2U                                            /*!< DIB DAUTHSTATUS: Non-secure Non-invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_NSNID_Msk          (0x3UL << DIB_DAUTHSTATUS_NSNID_Pos )          /*!< DIB DAUTHSTATUS: Non-secure Non-invasive Debug Mask */ | ||||
|  | ||||
| #define DIB_DAUTHSTATUS_NSID_Pos            0U                                            /*!< DIB DAUTHSTATUS: Non-secure Invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_NSID_Msk           (0x3UL /*<< DIB_DAUTHSTATUS_NSID_Pos*/)        /*!< DIB DAUTHSTATUS: Non-secure Invasive Debug Mask */ | ||||
|  | ||||
| /* DDEVARCH, SCS Device Architecture Register Definitions */ | ||||
| #define DIB_DDEVARCH_ARCHITECT_Pos         21U                                            /*!< DIB DDEVARCH: Architect Position */ | ||||
| #define DIB_DDEVARCH_ARCHITECT_Msk         (0x7FFUL << DIB_DDEVARCH_ARCHITECT_Pos )       /*!< DIB DDEVARCH: Architect Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_PRESENT_Pos           20U                                            /*!< DIB DDEVARCH: DEVARCH Present Position */ | ||||
| #define DIB_DDEVARCH_PRESENT_Msk           (0x1FUL << DIB_DDEVARCH_PRESENT_Pos )          /*!< DIB DDEVARCH: DEVARCH Present Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_REVISION_Pos          16U                                            /*!< DIB DDEVARCH: Revision Position */ | ||||
| #define DIB_DDEVARCH_REVISION_Msk          (0xFUL << DIB_DDEVARCH_REVISION_Pos )          /*!< DIB DDEVARCH: Revision Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_ARCHVER_Pos           12U                                            /*!< DIB DDEVARCH: Architecture Version Position */ | ||||
| #define DIB_DDEVARCH_ARCHVER_Msk           (0xFUL << DIB_DDEVARCH_ARCHVER_Pos )           /*!< DIB DDEVARCH: Architecture Version Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_ARCHPART_Pos           0U                                            /*!< DIB DDEVARCH: Architecture Part Position */ | ||||
| #define DIB_DDEVARCH_ARCHPART_Msk          (0xFFFUL /*<< DIB_DDEVARCH_ARCHPART_Pos*/)     /*!< DIB DDEVARCH: Architecture Part Mask */ | ||||
|  | ||||
| /* DDEVTYPE, SCS Device Type Register Definitions */ | ||||
| #define DIB_DDEVTYPE_SUB_Pos                4U                                            /*!< DIB DDEVTYPE: Sub-type Position */ | ||||
| #define DIB_DDEVTYPE_SUB_Msk               (0xFUL << DIB_DDEVTYPE_SUB_Pos )               /*!< DIB DDEVTYPE: Sub-type Mask */ | ||||
|  | ||||
| #define DIB_DDEVTYPE_MAJOR_Pos              0U                                            /*!< DIB DDEVTYPE: Major type Position */ | ||||
| #define DIB_DDEVTYPE_MAJOR_Msk             (0xFUL /*<< DIB_DDEVTYPE_MAJOR_Pos*/)          /*!< DIB DDEVTYPE: Major type Mask */ | ||||
|  | ||||
|  | ||||
| /*@} end of group CMSIS_DIB */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup    CMSIS_core_register | ||||
|   \defgroup   CMSIS_core_bitfield     Core register bit field macros | ||||
| @@ -1301,9 +1113,7 @@ typedef struct | ||||
|   #define SCS_BASE            (0xE000E000UL)                             /*!< System Control Space Base Address */ | ||||
|   #define DWT_BASE            (0xE0001000UL)                             /*!< DWT Base Address */ | ||||
|   #define TPI_BASE            (0xE0040000UL)                             /*!< TPI Base Address */ | ||||
|   #define CoreDebug_BASE      (0xE000EDF0UL)                             /*!< \deprecated Core Debug Base Address */ | ||||
|   #define DCB_BASE            (0xE000EDF0UL)                             /*!< DCB Base Address */ | ||||
|   #define DIB_BASE            (0xE000EFB0UL)                             /*!< DIB Base Address */ | ||||
|   #define CoreDebug_BASE      (0xE000EDF0UL)                             /*!< Core Debug Base Address */ | ||||
|   #define SysTick_BASE        (SCS_BASE +  0x0010UL)                     /*!< SysTick Base Address */ | ||||
|   #define NVIC_BASE           (SCS_BASE +  0x0100UL)                     /*!< NVIC Base Address */ | ||||
|   #define SCB_BASE            (SCS_BASE +  0x0D00UL)                     /*!< System Control Block Base Address */ | ||||
| @@ -1314,9 +1124,7 @@ typedef struct | ||||
|   #define NVIC                ((NVIC_Type      *)     NVIC_BASE        ) /*!< NVIC configuration struct */ | ||||
|   #define DWT                 ((DWT_Type       *)     DWT_BASE         ) /*!< DWT configuration struct */ | ||||
|   #define TPI                 ((TPI_Type       *)     TPI_BASE         ) /*!< TPI configuration struct */ | ||||
|   #define CoreDebug           ((CoreDebug_Type *)     CoreDebug_BASE   ) /*!< \deprecated Core Debug configuration struct */ | ||||
|   #define DCB                 ((DCB_Type       *)     DCB_BASE         ) /*!< DCB configuration struct */ | ||||
|   #define DIB                 ((DIB_Type       *)     DIB_BASE         ) /*!< DIB configuration struct */ | ||||
|   #define CoreDebug           ((CoreDebug_Type *)     CoreDebug_BASE   ) /*!< Core Debug configuration struct */ | ||||
|  | ||||
|   #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) | ||||
|     #define MPU_BASE          (SCS_BASE +  0x0D90UL)                     /*!< Memory Protection Unit */ | ||||
| @@ -1330,9 +1138,7 @@ typedef struct | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
|   #define SCS_BASE_NS         (0xE002E000UL)                             /*!< System Control Space Base Address (non-secure address space) */ | ||||
|   #define CoreDebug_BASE_NS   (0xE002EDF0UL)                             /*!< \deprecated Core Debug Base Address           (non-secure address space) */ | ||||
|   #define DCB_BASE_NS         (0xE002EDF0UL)                             /*!< DCB Base Address                  (non-secure address space) */ | ||||
|   #define DIB_BASE_NS         (0xE002EFB0UL)                             /*!< DIB Base Address                  (non-secure address space) */ | ||||
|   #define CoreDebug_BASE_NS   (0xE002EDF0UL)                             /*!< Core Debug Base Address           (non-secure address space) */ | ||||
|   #define SysTick_BASE_NS     (SCS_BASE_NS +  0x0010UL)                  /*!< SysTick Base Address              (non-secure address space) */ | ||||
|   #define NVIC_BASE_NS        (SCS_BASE_NS +  0x0100UL)                  /*!< NVIC Base Address                 (non-secure address space) */ | ||||
|   #define SCB_BASE_NS         (SCS_BASE_NS +  0x0D00UL)                  /*!< System Control Block Base Address (non-secure address space) */ | ||||
| @@ -1340,9 +1146,7 @@ typedef struct | ||||
|   #define SCB_NS              ((SCB_Type       *)     SCB_BASE_NS      ) /*!< SCB configuration struct          (non-secure address space) */ | ||||
|   #define SysTick_NS          ((SysTick_Type   *)     SysTick_BASE_NS  ) /*!< SysTick configuration struct      (non-secure address space) */ | ||||
|   #define NVIC_NS             ((NVIC_Type      *)     NVIC_BASE_NS     ) /*!< NVIC configuration struct         (non-secure address space) */ | ||||
|   #define CoreDebug_NS        ((CoreDebug_Type *)     CoreDebug_BASE_NS) /*!< \deprecated Core Debug configuration struct   (non-secure address space) */ | ||||
|   #define DCB_NS              ((DCB_Type       *)     DCB_BASE_NS      ) /*!< DCB configuration struct          (non-secure address space) */ | ||||
|   #define DIB_NS              ((DIB_Type       *)     DIB_BASE_NS      ) /*!< DIB configuration struct          (non-secure address space) */ | ||||
|   #define CoreDebug_NS        ((CoreDebug_Type *)     CoreDebug_BASE_NS) /*!< Core Debug configuration struct   (non-secure address space) */ | ||||
|  | ||||
|   #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) | ||||
|     #define MPU_BASE_NS       (SCS_BASE_NS +  0x0D90UL)                  /*!< Memory Protection Unit            (non-secure address space) */ | ||||
| @@ -1359,7 +1163,6 @@ typedef struct | ||||
|   Core Function Interface contains: | ||||
|   - Core NVIC Functions | ||||
|   - Core SysTick Functions | ||||
|   - Core Debug Functions | ||||
|   - Core Register Access Functions | ||||
|  ******************************************************************************/ | ||||
| /** | ||||
| @@ -2035,110 +1838,6 @@ __STATIC_INLINE void TZ_SAU_Disable(void) | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    Debug Control function  ############################################ */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   \defgroup CMSIS_Core_DCBFunctions Debug Control Functions | ||||
|   \brief    Functions that access the Debug Control Block. | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
|   | ||||
| /** | ||||
|   \brief   Set Debug Authentication Control Register | ||||
|   \details writes to Debug Authentication Control register. | ||||
|   \param [in]  value  value to be writen. | ||||
|  */ | ||||
| __STATIC_INLINE void DCB_SetAuthCtrl(uint32_t value) | ||||
| { | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     DCB->DAUTHCTRL = value; | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Debug Authentication Control Register | ||||
|   \details Reads Debug Authentication Control register. | ||||
|   \return             Debug Authentication Control Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t DCB_GetAuthCtrl(void) | ||||
| { | ||||
|     return (DCB->DAUTHCTRL); | ||||
| } | ||||
|  | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
| /** | ||||
|   \brief   Set Debug Authentication Control Register (non-secure) | ||||
|   \details writes to non-secure Debug Authentication Control register when in secure state. | ||||
|   \param [in]  value  value to be writen | ||||
|  */ | ||||
| __STATIC_INLINE void TZ_DCB_SetAuthCtrl_NS(uint32_t value) | ||||
| { | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     DCB_NS->DAUTHCTRL = value; | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Debug Authentication Control Register (non-secure) | ||||
|   \details Reads non-secure Debug Authentication Control register when in secure state. | ||||
|   \return             Debug Authentication Control Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t TZ_DCB_GetAuthCtrl_NS(void) | ||||
| { | ||||
|     return (DCB_NS->DAUTHCTRL); | ||||
| } | ||||
| #endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ | ||||
|  | ||||
| /*@} end of CMSIS_Core_DCBFunctions */ | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    Debug Identification function  ############################################ */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   \defgroup CMSIS_Core_DIBFunctions Debug Identification Functions | ||||
|   \brief    Functions that access the Debug Identification Block. | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
|   | ||||
| /** | ||||
|   \brief   Get Debug Authentication Status Register | ||||
|   \details Reads Debug Authentication Status register. | ||||
|   \return             Debug Authentication Status Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t DIB_GetAuthStatus(void) | ||||
| { | ||||
|     return (DIB->DAUTHSTATUS); | ||||
| } | ||||
|  | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
| /** | ||||
|   \brief   Get Debug Authentication Status Register (non-secure) | ||||
|   \details Reads non-secure Debug Authentication Status register when in secure state. | ||||
|   \return             Debug Authentication Status Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t TZ_DIB_GetAuthStatus_NS(void) | ||||
| { | ||||
|     return (DIB_NS->DAUTHSTATUS); | ||||
| } | ||||
| #endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ | ||||
|  | ||||
| /*@} end of CMSIS_Core_DCBFunctions */ | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    SysTick function  ############################################ */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
| /**************************************************************************//** | ||||
|  * @file     core_armv8mml.h | ||||
|  * @brief    CMSIS Armv8-M Mainline Core Peripheral Access Layer Header File | ||||
|  * @version  V5.2.3 | ||||
|  * @date     13. October 2021 | ||||
|  * @version  V5.1.0 | ||||
|  * @date     12. September 2018 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2009-2021 Arm Limited. All rights reserved. | ||||
|  * Copyright (c) 2009-2018 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
| @@ -26,8 +26,6 @@ | ||||
|   #pragma system_include         /* treat file as system include file for MISRA check */ | ||||
| #elif defined (__clang__) | ||||
|   #pragma clang system_header   /* treat file as system include file */ | ||||
| #elif defined ( __GNUC__ ) | ||||
|   #pragma GCC diagnostic ignored "-Wpedantic"   /* disable pedantic warning due to unnamed structs/unions */ | ||||
| #endif | ||||
|  | ||||
| #ifndef __CORE_ARMV8MML_H_GENERIC | ||||
| @@ -70,7 +68,7 @@ | ||||
| #define __ARMv8MML_CMSIS_VERSION       ((__ARMv8MML_CMSIS_VERSION_MAIN << 16U) | \ | ||||
|                                          __ARMv8MML_CMSIS_VERSION_SUB           )  /*!< \deprecated CMSIS HAL version number */ | ||||
|  | ||||
| #define __CORTEX_M                     (80U)                                       /*!< Cortex-M Core */ | ||||
| #define __CORTEX_M                     (81U)                                       /*!< Cortex-M Core */ | ||||
|  | ||||
| /** __FPU_USED indicates whether an FPU is used or not. | ||||
|     For this, __FPU_PRESENT has to be checked prior to making use of FPU specific registers and functions. | ||||
| @@ -250,11 +248,6 @@ | ||||
|     #warning "__DSP_PRESENT not defined in device header file; using default!" | ||||
|   #endif | ||||
|  | ||||
|   #ifndef __VTOR_PRESENT | ||||
|     #define __VTOR_PRESENT             1U | ||||
|     #warning "__VTOR_PRESENT not defined in device header file; using default!" | ||||
|   #endif | ||||
|  | ||||
|   #ifndef __NVIC_PRIO_BITS | ||||
|     #define __NVIC_PRIO_BITS          3U | ||||
|     #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" | ||||
| @@ -519,7 +512,7 @@ typedef struct | ||||
|   __IOM uint32_t AFSR;                   /*!< Offset: 0x03C (R/W)  Auxiliary Fault Status Register */ | ||||
|   __IM  uint32_t ID_PFR[2U];             /*!< Offset: 0x040 (R/ )  Processor Feature Register */ | ||||
|   __IM  uint32_t ID_DFR;                 /*!< Offset: 0x048 (R/ )  Debug Feature Register */ | ||||
|   __IM  uint32_t ID_AFR;                 /*!< Offset: 0x04C (R/ )  Auxiliary Feature Register */ | ||||
|   __IM  uint32_t ID_ADR;                 /*!< Offset: 0x04C (R/ )  Auxiliary Feature Register */ | ||||
|   __IM  uint32_t ID_MMFR[4U];            /*!< Offset: 0x050 (R/ )  Memory Model Feature Register */ | ||||
|   __IM  uint32_t ID_ISAR[6U];            /*!< Offset: 0x060 (R/ )  Instruction Set Attributes Register */ | ||||
|   __IM  uint32_t CLIDR;                  /*!< Offset: 0x078 (R/ )  Cache Level ID register */ | ||||
| @@ -528,10 +521,7 @@ typedef struct | ||||
|   __IOM uint32_t CSSELR;                 /*!< Offset: 0x084 (R/W)  Cache Size Selection Register */ | ||||
|   __IOM uint32_t CPACR;                  /*!< Offset: 0x088 (R/W)  Coprocessor Access Control Register */ | ||||
|   __IOM uint32_t NSACR;                  /*!< Offset: 0x08C (R/W)  Non-Secure Access Control Register */ | ||||
|         uint32_t RESERVED7[21U]; | ||||
|   __IOM uint32_t SFSR;                   /*!< Offset: 0x0E4 (R/W)  Secure Fault Status Register */ | ||||
|   __IOM uint32_t SFAR;                   /*!< Offset: 0x0E8 (R/W)  Secure Fault Address Register */ | ||||
|         uint32_t RESERVED3[69U]; | ||||
|         uint32_t RESERVED3[92U]; | ||||
|   __OM  uint32_t STIR;                   /*!< Offset: 0x200 ( /W)  Software Triggered Interrupt Register */ | ||||
|         uint32_t RESERVED4[15U]; | ||||
|   __IM  uint32_t MVFR0;                  /*!< Offset: 0x240 (R/ )  Media and VFP Feature Register 0 */ | ||||
| @@ -548,7 +538,6 @@ typedef struct | ||||
|   __OM  uint32_t DCCSW;                  /*!< Offset: 0x26C ( /W)  D-Cache Clean by Set-way */ | ||||
|   __OM  uint32_t DCCIMVAC;               /*!< Offset: 0x270 ( /W)  D-Cache Clean and Invalidate by MVA to PoC */ | ||||
|   __OM  uint32_t DCCISW;                 /*!< Offset: 0x274 ( /W)  D-Cache Clean and Invalidate by Set-way */ | ||||
|   __OM  uint32_t BPIALL;                 /*!< Offset: 0x278 ( /W)  Branch Predictor Invalidate All */ | ||||
| } SCB_Type; | ||||
|  | ||||
| /* SCB CPUID Register Definitions */ | ||||
| @@ -749,22 +738,22 @@ typedef struct | ||||
| #define SCB_CFSR_MEMFAULTSR_Msk            (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/)        /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ | ||||
|  | ||||
| /* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ | ||||
| #define SCB_CFSR_MMARVALID_Pos             (SCB_CFSR_MEMFAULTSR_Pos + 7U)                 /*!< SCB CFSR (MMFSR): MMARVALID Position */ | ||||
| #define SCB_CFSR_MMARVALID_Pos             (SCB_SHCSR_MEMFAULTACT_Pos + 7U)               /*!< SCB CFSR (MMFSR): MMARVALID Position */ | ||||
| #define SCB_CFSR_MMARVALID_Msk             (1UL << SCB_CFSR_MMARVALID_Pos)                /*!< SCB CFSR (MMFSR): MMARVALID Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MLSPERR_Pos               (SCB_CFSR_MEMFAULTSR_Pos + 5U)                 /*!< SCB CFSR (MMFSR): MLSPERR Position */ | ||||
| #define SCB_CFSR_MLSPERR_Pos               (SCB_SHCSR_MEMFAULTACT_Pos + 5U)               /*!< SCB CFSR (MMFSR): MLSPERR Position */ | ||||
| #define SCB_CFSR_MLSPERR_Msk               (1UL << SCB_CFSR_MLSPERR_Pos)                  /*!< SCB CFSR (MMFSR): MLSPERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MSTKERR_Pos               (SCB_CFSR_MEMFAULTSR_Pos + 4U)                 /*!< SCB CFSR (MMFSR): MSTKERR Position */ | ||||
| #define SCB_CFSR_MSTKERR_Pos               (SCB_SHCSR_MEMFAULTACT_Pos + 4U)               /*!< SCB CFSR (MMFSR): MSTKERR Position */ | ||||
| #define SCB_CFSR_MSTKERR_Msk               (1UL << SCB_CFSR_MSTKERR_Pos)                  /*!< SCB CFSR (MMFSR): MSTKERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MUNSTKERR_Pos             (SCB_CFSR_MEMFAULTSR_Pos + 3U)                 /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ | ||||
| #define SCB_CFSR_MUNSTKERR_Pos             (SCB_SHCSR_MEMFAULTACT_Pos + 3U)               /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ | ||||
| #define SCB_CFSR_MUNSTKERR_Msk             (1UL << SCB_CFSR_MUNSTKERR_Pos)                /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_DACCVIOL_Pos              (SCB_CFSR_MEMFAULTSR_Pos + 1U)                 /*!< SCB CFSR (MMFSR): DACCVIOL Position */ | ||||
| #define SCB_CFSR_DACCVIOL_Pos              (SCB_SHCSR_MEMFAULTACT_Pos + 1U)               /*!< SCB CFSR (MMFSR): DACCVIOL Position */ | ||||
| #define SCB_CFSR_DACCVIOL_Msk              (1UL << SCB_CFSR_DACCVIOL_Pos)                 /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ | ||||
|  | ||||
| #define SCB_CFSR_IACCVIOL_Pos              (SCB_CFSR_MEMFAULTSR_Pos + 0U)                 /*!< SCB CFSR (MMFSR): IACCVIOL Position */ | ||||
| #define SCB_CFSR_IACCVIOL_Pos              (SCB_SHCSR_MEMFAULTACT_Pos + 0U)               /*!< SCB CFSR (MMFSR): IACCVIOL Position */ | ||||
| #define SCB_CFSR_IACCVIOL_Msk              (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/)             /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ | ||||
|  | ||||
| /* BusFault Status Register (part of SCB Configurable Fault Status Register) */ | ||||
| @@ -1604,9 +1593,8 @@ typedef struct | ||||
|   __IOM uint32_t FPCCR;                  /*!< Offset: 0x004 (R/W)  Floating-Point Context Control Register */ | ||||
|   __IOM uint32_t FPCAR;                  /*!< Offset: 0x008 (R/W)  Floating-Point Context Address Register */ | ||||
|   __IOM uint32_t FPDSCR;                 /*!< Offset: 0x00C (R/W)  Floating-Point Default Status Control Register */ | ||||
|   __IM  uint32_t MVFR0;                  /*!< Offset: 0x010 (R/ )  Media and VFP Feature Register 0 */ | ||||
|   __IM  uint32_t MVFR1;                  /*!< Offset: 0x014 (R/ )  Media and VFP Feature Register 1 */ | ||||
|   __IM  uint32_t MVFR2;                  /*!< Offset: 0x018 (R/ )  Media and VFP Feature Register 2 */ | ||||
|   __IM  uint32_t MVFR0;                  /*!< Offset: 0x010 (R/ )  Media and FP Feature Register 0 */ | ||||
|   __IM  uint32_t MVFR1;                  /*!< Offset: 0x014 (R/ )  Media and FP Feature Register 1 */ | ||||
| } FPU_Type; | ||||
|  | ||||
| /* Floating-Point Context Control Register Definitions */ | ||||
| @@ -1678,7 +1666,7 @@ typedef struct | ||||
| #define FPU_FPDSCR_RMode_Pos               22U                                            /*!< FPDSCR: RMode bit Position */ | ||||
| #define FPU_FPDSCR_RMode_Msk               (3UL << FPU_FPDSCR_RMode_Pos)                  /*!< FPDSCR: RMode bit Mask */ | ||||
|  | ||||
| /* Media and VFP Feature Register 0 Definitions */ | ||||
| /* Media and FP Feature Register 0 Definitions */ | ||||
| #define FPU_MVFR0_FP_rounding_modes_Pos    28U                                            /*!< MVFR0: FP rounding modes bits Position */ | ||||
| #define FPU_MVFR0_FP_rounding_modes_Msk    (0xFUL << FPU_MVFR0_FP_rounding_modes_Pos)     /*!< MVFR0: FP rounding modes bits Mask */ | ||||
|  | ||||
| @@ -1703,7 +1691,7 @@ typedef struct | ||||
| #define FPU_MVFR0_A_SIMD_registers_Pos      0U                                            /*!< MVFR0: A_SIMD registers bits Position */ | ||||
| #define FPU_MVFR0_A_SIMD_registers_Msk     (0xFUL /*<< FPU_MVFR0_A_SIMD_registers_Pos*/)  /*!< MVFR0: A_SIMD registers bits Mask */ | ||||
|  | ||||
| /* Media and VFP Feature Register 1 Definitions */ | ||||
| /* Media and FP Feature Register 1 Definitions */ | ||||
| #define FPU_MVFR1_FP_fused_MAC_Pos         28U                                            /*!< MVFR1: FP fused MAC bits Position */ | ||||
| #define FPU_MVFR1_FP_fused_MAC_Msk         (0xFUL << FPU_MVFR1_FP_fused_MAC_Pos)          /*!< MVFR1: FP fused MAC bits Mask */ | ||||
|  | ||||
| @@ -1716,13 +1704,9 @@ typedef struct | ||||
| #define FPU_MVFR1_FtZ_mode_Pos              0U                                            /*!< MVFR1: FtZ mode bits Position */ | ||||
| #define FPU_MVFR1_FtZ_mode_Msk             (0xFUL /*<< FPU_MVFR1_FtZ_mode_Pos*/)          /*!< MVFR1: FtZ mode bits Mask */ | ||||
|  | ||||
| /* Media and VFP Feature Register 2 Definitions */ | ||||
| #define FPU_MVFR2_FPMisc_Pos                4U                                            /*!< MVFR2: FPMisc bits Position */ | ||||
| #define FPU_MVFR2_FPMisc_Msk               (0xFUL << FPU_MVFR2_FPMisc_Pos)                /*!< MVFR2: FPMisc bits Mask */ | ||||
|  | ||||
| /*@} end of group CMSIS_FPU */ | ||||
|  | ||||
| /* CoreDebug is deprecated. replaced by DCB (Debug Control Block) */ | ||||
|  | ||||
| /** | ||||
|   \ingroup  CMSIS_core_register | ||||
|   \defgroup CMSIS_CoreDebug       Core Debug Registers (CoreDebug) | ||||
| @@ -1731,7 +1715,7 @@ typedef struct | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief  \deprecated Structure type to access the Core Debug Register (CoreDebug). | ||||
|   \brief  Structure type to access the Core Debug Register (CoreDebug). | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
| @@ -1739,354 +1723,124 @@ typedef struct | ||||
|   __OM  uint32_t DCRSR;                  /*!< Offset: 0x004 ( /W)  Debug Core Register Selector Register */ | ||||
|   __IOM uint32_t DCRDR;                  /*!< Offset: 0x008 (R/W)  Debug Core Register Data Register */ | ||||
|   __IOM uint32_t DEMCR;                  /*!< Offset: 0x00C (R/W)  Debug Exception and Monitor Control Register */ | ||||
|         uint32_t RESERVED0[1U]; | ||||
|         uint32_t RESERVED4[1U]; | ||||
|   __IOM uint32_t DAUTHCTRL;              /*!< Offset: 0x014 (R/W)  Debug Authentication Control Register */ | ||||
|   __IOM uint32_t DSCSR;                  /*!< Offset: 0x018 (R/W)  Debug Security Control and Status Register */ | ||||
| } CoreDebug_Type; | ||||
|  | ||||
| /* Debug Halting Control and Status Register Definitions */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Pos         16U                                            /*!< \deprecated CoreDebug DHCSR: DBGKEY Position */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Msk         (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos)       /*!< \deprecated CoreDebug DHCSR: DBGKEY Mask */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Pos         16U                                            /*!< CoreDebug DHCSR: DBGKEY Position */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Msk         (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos)       /*!< CoreDebug DHCSR: DBGKEY Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Pos   26U                                            /*!< \deprecated CoreDebug DHCSR: S_RESTART_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Msk   (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos)      /*!< \deprecated CoreDebug DHCSR: S_RESTART_ST Mask */ | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Pos   26U                                            /*!< CoreDebug DHCSR: S_RESTART_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Msk   (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos)      /*!< CoreDebug DHCSR: S_RESTART_ST Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Pos     25U                                            /*!< \deprecated CoreDebug DHCSR: S_RESET_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Msk     (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos)        /*!< \deprecated CoreDebug DHCSR: S_RESET_ST Mask */ | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Pos     25U                                            /*!< CoreDebug DHCSR: S_RESET_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Msk     (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos)        /*!< CoreDebug DHCSR: S_RESET_ST Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Pos    24U                                            /*!< \deprecated CoreDebug DHCSR: S_RETIRE_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Msk    (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos)       /*!< \deprecated CoreDebug DHCSR: S_RETIRE_ST Mask */ | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Pos    24U                                            /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Msk    (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos)       /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Pos       19U                                            /*!< \deprecated CoreDebug DHCSR: S_LOCKUP Position */ | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Msk       (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos)          /*!< \deprecated CoreDebug DHCSR: S_LOCKUP Mask */ | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Pos       19U                                            /*!< CoreDebug DHCSR: S_LOCKUP Position */ | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Msk       (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos)          /*!< CoreDebug DHCSR: S_LOCKUP Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Pos        18U                                            /*!< \deprecated CoreDebug DHCSR: S_SLEEP Position */ | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Msk        (1UL << CoreDebug_DHCSR_S_SLEEP_Pos)           /*!< \deprecated CoreDebug DHCSR: S_SLEEP Mask */ | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Pos        18U                                            /*!< CoreDebug DHCSR: S_SLEEP Position */ | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Msk        (1UL << CoreDebug_DHCSR_S_SLEEP_Pos)           /*!< CoreDebug DHCSR: S_SLEEP Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_HALT_Pos         17U                                            /*!< \deprecated CoreDebug DHCSR: S_HALT Position */ | ||||
| #define CoreDebug_DHCSR_S_HALT_Msk         (1UL << CoreDebug_DHCSR_S_HALT_Pos)            /*!< \deprecated CoreDebug DHCSR: S_HALT Mask */ | ||||
| #define CoreDebug_DHCSR_S_HALT_Pos         17U                                            /*!< CoreDebug DHCSR: S_HALT Position */ | ||||
| #define CoreDebug_DHCSR_S_HALT_Msk         (1UL << CoreDebug_DHCSR_S_HALT_Pos)            /*!< CoreDebug DHCSR: S_HALT Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Pos       16U                                            /*!< \deprecated CoreDebug DHCSR: S_REGRDY Position */ | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Msk       (1UL << CoreDebug_DHCSR_S_REGRDY_Pos)          /*!< \deprecated CoreDebug DHCSR: S_REGRDY Mask */ | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Pos       16U                                            /*!< CoreDebug DHCSR: S_REGRDY Position */ | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Msk       (1UL << CoreDebug_DHCSR_S_REGRDY_Pos)          /*!< CoreDebug DHCSR: S_REGRDY Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_SNAPSTALL_Pos     5U                                            /*!< \deprecated CoreDebug DHCSR: C_SNAPSTALL Position */ | ||||
| #define CoreDebug_DHCSR_C_SNAPSTALL_Msk    (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos)       /*!< \deprecated CoreDebug DHCSR: C_SNAPSTALL Mask */ | ||||
| #define CoreDebug_DHCSR_C_SNAPSTALL_Pos     5U                                            /*!< CoreDebug DHCSR: C_SNAPSTALL Position */ | ||||
| #define CoreDebug_DHCSR_C_SNAPSTALL_Msk    (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos)       /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Pos      3U                                            /*!< \deprecated CoreDebug DHCSR: C_MASKINTS Position */ | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Msk     (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos)        /*!< \deprecated CoreDebug DHCSR: C_MASKINTS Mask */ | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Pos      3U                                            /*!< CoreDebug DHCSR: C_MASKINTS Position */ | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Msk     (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos)        /*!< CoreDebug DHCSR: C_MASKINTS Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_STEP_Pos          2U                                            /*!< \deprecated CoreDebug DHCSR: C_STEP Position */ | ||||
| #define CoreDebug_DHCSR_C_STEP_Msk         (1UL << CoreDebug_DHCSR_C_STEP_Pos)            /*!< \deprecated CoreDebug DHCSR: C_STEP Mask */ | ||||
| #define CoreDebug_DHCSR_C_STEP_Pos          2U                                            /*!< CoreDebug DHCSR: C_STEP Position */ | ||||
| #define CoreDebug_DHCSR_C_STEP_Msk         (1UL << CoreDebug_DHCSR_C_STEP_Pos)            /*!< CoreDebug DHCSR: C_STEP Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_HALT_Pos          1U                                            /*!< \deprecated CoreDebug DHCSR: C_HALT Position */ | ||||
| #define CoreDebug_DHCSR_C_HALT_Msk         (1UL << CoreDebug_DHCSR_C_HALT_Pos)            /*!< \deprecated CoreDebug DHCSR: C_HALT Mask */ | ||||
| #define CoreDebug_DHCSR_C_HALT_Pos          1U                                            /*!< CoreDebug DHCSR: C_HALT Position */ | ||||
| #define CoreDebug_DHCSR_C_HALT_Msk         (1UL << CoreDebug_DHCSR_C_HALT_Pos)            /*!< CoreDebug DHCSR: C_HALT Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Pos       0U                                            /*!< \deprecated CoreDebug DHCSR: C_DEBUGEN Position */ | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Msk      (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/)     /*!< \deprecated CoreDebug DHCSR: C_DEBUGEN Mask */ | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Pos       0U                                            /*!< CoreDebug DHCSR: C_DEBUGEN Position */ | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Msk      (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/)     /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ | ||||
|  | ||||
| /* Debug Core Register Selector Register Definitions */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Pos         16U                                            /*!< \deprecated CoreDebug DCRSR: REGWnR Position */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Msk         (1UL << CoreDebug_DCRSR_REGWnR_Pos)            /*!< \deprecated CoreDebug DCRSR: REGWnR Mask */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Pos         16U                                            /*!< CoreDebug DCRSR: REGWnR Position */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Msk         (1UL << CoreDebug_DCRSR_REGWnR_Pos)            /*!< CoreDebug DCRSR: REGWnR Mask */ | ||||
|  | ||||
| #define CoreDebug_DCRSR_REGSEL_Pos          0U                                            /*!< \deprecated CoreDebug DCRSR: REGSEL Position */ | ||||
| #define CoreDebug_DCRSR_REGSEL_Msk         (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/)     /*!< \deprecated CoreDebug DCRSR: REGSEL Mask */ | ||||
| #define CoreDebug_DCRSR_REGSEL_Pos          0U                                            /*!< CoreDebug DCRSR: REGSEL Position */ | ||||
| #define CoreDebug_DCRSR_REGSEL_Msk         (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/)     /*!< CoreDebug DCRSR: REGSEL Mask */ | ||||
|  | ||||
| /* Debug Exception and Monitor Control Register Definitions */ | ||||
| #define CoreDebug_DEMCR_TRCENA_Pos         24U                                            /*!< \deprecated CoreDebug DEMCR: TRCENA Position */ | ||||
| #define CoreDebug_DEMCR_TRCENA_Msk         (1UL << CoreDebug_DEMCR_TRCENA_Pos)            /*!< \deprecated CoreDebug DEMCR: TRCENA Mask */ | ||||
| #define CoreDebug_DEMCR_TRCENA_Pos         24U                                            /*!< CoreDebug DEMCR: TRCENA Position */ | ||||
| #define CoreDebug_DEMCR_TRCENA_Msk         (1UL << CoreDebug_DEMCR_TRCENA_Pos)            /*!< CoreDebug DEMCR: TRCENA Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_MON_REQ_Pos        19U                                            /*!< \deprecated CoreDebug DEMCR: MON_REQ Position */ | ||||
| #define CoreDebug_DEMCR_MON_REQ_Msk        (1UL << CoreDebug_DEMCR_MON_REQ_Pos)           /*!< \deprecated CoreDebug DEMCR: MON_REQ Mask */ | ||||
| #define CoreDebug_DEMCR_MON_REQ_Pos        19U                                            /*!< CoreDebug DEMCR: MON_REQ Position */ | ||||
| #define CoreDebug_DEMCR_MON_REQ_Msk        (1UL << CoreDebug_DEMCR_MON_REQ_Pos)           /*!< CoreDebug DEMCR: MON_REQ Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_MON_STEP_Pos       18U                                            /*!< \deprecated CoreDebug DEMCR: MON_STEP Position */ | ||||
| #define CoreDebug_DEMCR_MON_STEP_Msk       (1UL << CoreDebug_DEMCR_MON_STEP_Pos)          /*!< \deprecated CoreDebug DEMCR: MON_STEP Mask */ | ||||
| #define CoreDebug_DEMCR_MON_STEP_Pos       18U                                            /*!< CoreDebug DEMCR: MON_STEP Position */ | ||||
| #define CoreDebug_DEMCR_MON_STEP_Msk       (1UL << CoreDebug_DEMCR_MON_STEP_Pos)          /*!< CoreDebug DEMCR: MON_STEP Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_MON_PEND_Pos       17U                                            /*!< \deprecated CoreDebug DEMCR: MON_PEND Position */ | ||||
| #define CoreDebug_DEMCR_MON_PEND_Msk       (1UL << CoreDebug_DEMCR_MON_PEND_Pos)          /*!< \deprecated CoreDebug DEMCR: MON_PEND Mask */ | ||||
| #define CoreDebug_DEMCR_MON_PEND_Pos       17U                                            /*!< CoreDebug DEMCR: MON_PEND Position */ | ||||
| #define CoreDebug_DEMCR_MON_PEND_Msk       (1UL << CoreDebug_DEMCR_MON_PEND_Pos)          /*!< CoreDebug DEMCR: MON_PEND Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_MON_EN_Pos         16U                                            /*!< \deprecated CoreDebug DEMCR: MON_EN Position */ | ||||
| #define CoreDebug_DEMCR_MON_EN_Msk         (1UL << CoreDebug_DEMCR_MON_EN_Pos)            /*!< \deprecated CoreDebug DEMCR: MON_EN Mask */ | ||||
| #define CoreDebug_DEMCR_MON_EN_Pos         16U                                            /*!< CoreDebug DEMCR: MON_EN Position */ | ||||
| #define CoreDebug_DEMCR_MON_EN_Msk         (1UL << CoreDebug_DEMCR_MON_EN_Pos)            /*!< CoreDebug DEMCR: MON_EN Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Pos     10U                                            /*!< \deprecated CoreDebug DEMCR: VC_HARDERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Msk     (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos)        /*!< \deprecated CoreDebug DEMCR: VC_HARDERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Pos     10U                                            /*!< CoreDebug DEMCR: VC_HARDERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Msk     (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos)        /*!< CoreDebug DEMCR: VC_HARDERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_INTERR_Pos       9U                                            /*!< \deprecated CoreDebug DEMCR: VC_INTERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_INTERR_Msk      (1UL << CoreDebug_DEMCR_VC_INTERR_Pos)         /*!< \deprecated CoreDebug DEMCR: VC_INTERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_INTERR_Pos       9U                                            /*!< CoreDebug DEMCR: VC_INTERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_INTERR_Msk      (1UL << CoreDebug_DEMCR_VC_INTERR_Pos)         /*!< CoreDebug DEMCR: VC_INTERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_BUSERR_Pos       8U                                            /*!< \deprecated CoreDebug DEMCR: VC_BUSERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_BUSERR_Msk      (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos)         /*!< \deprecated CoreDebug DEMCR: VC_BUSERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_BUSERR_Pos       8U                                            /*!< CoreDebug DEMCR: VC_BUSERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_BUSERR_Msk      (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos)         /*!< CoreDebug DEMCR: VC_BUSERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_STATERR_Pos      7U                                            /*!< \deprecated CoreDebug DEMCR: VC_STATERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_STATERR_Msk     (1UL << CoreDebug_DEMCR_VC_STATERR_Pos)        /*!< \deprecated CoreDebug DEMCR: VC_STATERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_STATERR_Pos      7U                                            /*!< CoreDebug DEMCR: VC_STATERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_STATERR_Msk     (1UL << CoreDebug_DEMCR_VC_STATERR_Pos)        /*!< CoreDebug DEMCR: VC_STATERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_CHKERR_Pos       6U                                            /*!< \deprecated CoreDebug DEMCR: VC_CHKERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_CHKERR_Msk      (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos)         /*!< \deprecated CoreDebug DEMCR: VC_CHKERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_CHKERR_Pos       6U                                            /*!< CoreDebug DEMCR: VC_CHKERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_CHKERR_Msk      (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos)         /*!< CoreDebug DEMCR: VC_CHKERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_NOCPERR_Pos      5U                                            /*!< \deprecated CoreDebug DEMCR: VC_NOCPERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_NOCPERR_Msk     (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos)        /*!< \deprecated CoreDebug DEMCR: VC_NOCPERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_NOCPERR_Pos      5U                                            /*!< CoreDebug DEMCR: VC_NOCPERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_NOCPERR_Msk     (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos)        /*!< CoreDebug DEMCR: VC_NOCPERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_MMERR_Pos        4U                                            /*!< \deprecated CoreDebug DEMCR: VC_MMERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_MMERR_Msk       (1UL << CoreDebug_DEMCR_VC_MMERR_Pos)          /*!< \deprecated CoreDebug DEMCR: VC_MMERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_MMERR_Pos        4U                                            /*!< CoreDebug DEMCR: VC_MMERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_MMERR_Msk       (1UL << CoreDebug_DEMCR_VC_MMERR_Pos)          /*!< CoreDebug DEMCR: VC_MMERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Pos    0U                                            /*!< \deprecated CoreDebug DEMCR: VC_CORERESET Position */ | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Msk   (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/)  /*!< \deprecated CoreDebug DEMCR: VC_CORERESET Mask */ | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Pos    0U                                            /*!< CoreDebug DEMCR: VC_CORERESET Position */ | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Msk   (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/)  /*!< CoreDebug DEMCR: VC_CORERESET Mask */ | ||||
|  | ||||
| /* Debug Authentication Control Register Definitions */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos  3U                                            /*!< \deprecated CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos)    /*!< \deprecated CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos  3U                                            /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos)    /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ | ||||
|  | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos  2U                                            /*!< \deprecated CoreDebug DAUTHCTRL: SPNIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos)    /*!< \deprecated CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos  2U                                            /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos)    /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ | ||||
|  | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos   1U                                            /*!< \deprecated CoreDebug DAUTHCTRL: INTSPIDEN Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk  (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos)     /*!< \deprecated CoreDebug DAUTHCTRL: INTSPIDEN Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos   1U                                            /*!< CoreDebug DAUTHCTRL: INTSPIDEN Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk  (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos)     /*!< CoreDebug DAUTHCTRL: INTSPIDEN Mask */ | ||||
|  | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos   0U                                            /*!< \deprecated CoreDebug DAUTHCTRL: SPIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk  (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< \deprecated CoreDebug DAUTHCTRL: SPIDENSEL Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos   0U                                            /*!< CoreDebug DAUTHCTRL: SPIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk  (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< CoreDebug DAUTHCTRL: SPIDENSEL Mask */ | ||||
|  | ||||
| /* Debug Security Control and Status Register Definitions */ | ||||
| #define CoreDebug_DSCSR_CDS_Pos            16U                                            /*!< \deprecated CoreDebug DSCSR: CDS Position */ | ||||
| #define CoreDebug_DSCSR_CDS_Msk            (1UL << CoreDebug_DSCSR_CDS_Pos)               /*!< \deprecated CoreDebug DSCSR: CDS Mask */ | ||||
| #define CoreDebug_DSCSR_CDS_Pos            16U                                            /*!< CoreDebug DSCSR: CDS Position */ | ||||
| #define CoreDebug_DSCSR_CDS_Msk            (1UL << CoreDebug_DSCSR_CDS_Pos)               /*!< CoreDebug DSCSR: CDS Mask */ | ||||
|  | ||||
| #define CoreDebug_DSCSR_SBRSEL_Pos          1U                                            /*!< \deprecated CoreDebug DSCSR: SBRSEL Position */ | ||||
| #define CoreDebug_DSCSR_SBRSEL_Msk         (1UL << CoreDebug_DSCSR_SBRSEL_Pos)            /*!< \deprecated CoreDebug DSCSR: SBRSEL Mask */ | ||||
| #define CoreDebug_DSCSR_SBRSEL_Pos          1U                                            /*!< CoreDebug DSCSR: SBRSEL Position */ | ||||
| #define CoreDebug_DSCSR_SBRSEL_Msk         (1UL << CoreDebug_DSCSR_SBRSEL_Pos)            /*!< CoreDebug DSCSR: SBRSEL Mask */ | ||||
|  | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Pos        0U                                            /*!< \deprecated CoreDebug DSCSR: SBRSELEN Position */ | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Msk       (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/)      /*!< \deprecated CoreDebug DSCSR: SBRSELEN Mask */ | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Pos        0U                                            /*!< CoreDebug DSCSR: SBRSELEN Position */ | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Msk       (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/)      /*!< CoreDebug DSCSR: SBRSELEN Mask */ | ||||
|  | ||||
| /*@} end of group CMSIS_CoreDebug */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup    CMSIS_core_register | ||||
|   \defgroup CMSIS_DCB       Debug Control Block | ||||
|   \brief    Type definitions for the Debug Control Block Registers | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief  Structure type to access the Debug Control Block Registers (DCB). | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
|   __IOM uint32_t DHCSR;                  /*!< Offset: 0x000 (R/W)  Debug Halting Control and Status Register */ | ||||
|   __OM  uint32_t DCRSR;                  /*!< Offset: 0x004 ( /W)  Debug Core Register Selector Register */ | ||||
|   __IOM uint32_t DCRDR;                  /*!< Offset: 0x008 (R/W)  Debug Core Register Data Register */ | ||||
|   __IOM uint32_t DEMCR;                  /*!< Offset: 0x00C (R/W)  Debug Exception and Monitor Control Register */ | ||||
|         uint32_t RESERVED0[1U]; | ||||
|   __IOM uint32_t DAUTHCTRL;              /*!< Offset: 0x014 (R/W)  Debug Authentication Control Register */ | ||||
|   __IOM uint32_t DSCSR;                  /*!< Offset: 0x018 (R/W)  Debug Security Control and Status Register */ | ||||
| } DCB_Type; | ||||
|  | ||||
| /* DHCSR, Debug Halting Control and Status Register Definitions */ | ||||
| #define DCB_DHCSR_DBGKEY_Pos               16U                                            /*!< DCB DHCSR: Debug key Position */ | ||||
| #define DCB_DHCSR_DBGKEY_Msk               (0xFFFFUL << DCB_DHCSR_DBGKEY_Pos)             /*!< DCB DHCSR: Debug key Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_RESTART_ST_Pos         26U                                            /*!< DCB DHCSR: Restart sticky status Position */ | ||||
| #define DCB_DHCSR_S_RESTART_ST_Msk         (0x1UL << DCB_DHCSR_S_RESTART_ST_Pos)          /*!< DCB DHCSR: Restart sticky status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_RESET_ST_Pos           25U                                            /*!< DCB DHCSR: Reset sticky status Position */ | ||||
| #define DCB_DHCSR_S_RESET_ST_Msk           (0x1UL << DCB_DHCSR_S_RESET_ST_Pos)            /*!< DCB DHCSR: Reset sticky status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_RETIRE_ST_Pos          24U                                            /*!< DCB DHCSR: Retire sticky status Position */ | ||||
| #define DCB_DHCSR_S_RETIRE_ST_Msk          (0x1UL << DCB_DHCSR_S_RETIRE_ST_Pos)           /*!< DCB DHCSR: Retire sticky status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_SDE_Pos                20U                                            /*!< DCB DHCSR: Secure debug enabled Position */ | ||||
| #define DCB_DHCSR_S_SDE_Msk                (0x1UL << DCB_DHCSR_S_SDE_Pos)                 /*!< DCB DHCSR: Secure debug enabled Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_LOCKUP_Pos             19U                                            /*!< DCB DHCSR: Lockup status Position */ | ||||
| #define DCB_DHCSR_S_LOCKUP_Msk             (0x1UL << DCB_DHCSR_S_LOCKUP_Pos)              /*!< DCB DHCSR: Lockup status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_SLEEP_Pos              18U                                            /*!< DCB DHCSR: Sleeping status Position */ | ||||
| #define DCB_DHCSR_S_SLEEP_Msk              (0x1UL << DCB_DHCSR_S_SLEEP_Pos)               /*!< DCB DHCSR: Sleeping status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_HALT_Pos               17U                                            /*!< DCB DHCSR: Halted status Position */ | ||||
| #define DCB_DHCSR_S_HALT_Msk               (0x1UL << DCB_DHCSR_S_HALT_Pos)                /*!< DCB DHCSR: Halted status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_REGRDY_Pos             16U                                            /*!< DCB DHCSR: Register ready status Position */ | ||||
| #define DCB_DHCSR_S_REGRDY_Msk             (0x1UL << DCB_DHCSR_S_REGRDY_Pos)              /*!< DCB DHCSR: Register ready status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_SNAPSTALL_Pos           5U                                            /*!< DCB DHCSR: Snap stall control Position */ | ||||
| #define DCB_DHCSR_C_SNAPSTALL_Msk          (0x1UL << DCB_DHCSR_C_SNAPSTALL_Pos)           /*!< DCB DHCSR: Snap stall control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_MASKINTS_Pos            3U                                            /*!< DCB DHCSR: Mask interrupts control Position */ | ||||
| #define DCB_DHCSR_C_MASKINTS_Msk           (0x1UL << DCB_DHCSR_C_MASKINTS_Pos)            /*!< DCB DHCSR: Mask interrupts control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_STEP_Pos                2U                                            /*!< DCB DHCSR: Step control Position */ | ||||
| #define DCB_DHCSR_C_STEP_Msk               (0x1UL << DCB_DHCSR_C_STEP_Pos)                /*!< DCB DHCSR: Step control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_HALT_Pos                1U                                            /*!< DCB DHCSR: Halt control Position */ | ||||
| #define DCB_DHCSR_C_HALT_Msk               (0x1UL << DCB_DHCSR_C_HALT_Pos)                /*!< DCB DHCSR: Halt control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_DEBUGEN_Pos             0U                                            /*!< DCB DHCSR: Debug enable control Position */ | ||||
| #define DCB_DHCSR_C_DEBUGEN_Msk            (0x1UL /*<< DCB_DHCSR_C_DEBUGEN_Pos*/)         /*!< DCB DHCSR: Debug enable control Mask */ | ||||
|  | ||||
| /* DCRSR, Debug Core Register Select Register Definitions */ | ||||
| #define DCB_DCRSR_REGWnR_Pos               16U                                            /*!< DCB DCRSR: Register write/not-read Position */ | ||||
| #define DCB_DCRSR_REGWnR_Msk               (0x1UL << DCB_DCRSR_REGWnR_Pos)                /*!< DCB DCRSR: Register write/not-read Mask */ | ||||
|  | ||||
| #define DCB_DCRSR_REGSEL_Pos                0U                                            /*!< DCB DCRSR: Register selector Position */ | ||||
| #define DCB_DCRSR_REGSEL_Msk               (0x7FUL /*<< DCB_DCRSR_REGSEL_Pos*/)           /*!< DCB DCRSR: Register selector Mask */ | ||||
|  | ||||
| /* DCRDR, Debug Core Register Data Register Definitions */ | ||||
| #define DCB_DCRDR_DBGTMP_Pos                0U                                            /*!< DCB DCRDR: Data temporary buffer Position */ | ||||
| #define DCB_DCRDR_DBGTMP_Msk               (0xFFFFFFFFUL /*<< DCB_DCRDR_DBGTMP_Pos*/)     /*!< DCB DCRDR: Data temporary buffer Mask */ | ||||
|  | ||||
| /* DEMCR, Debug Exception and Monitor Control Register Definitions */ | ||||
| #define DCB_DEMCR_TRCENA_Pos               24U                                            /*!< DCB DEMCR: Trace enable Position */ | ||||
| #define DCB_DEMCR_TRCENA_Msk               (0x1UL << DCB_DEMCR_TRCENA_Pos)                /*!< DCB DEMCR: Trace enable Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_MONPRKEY_Pos             23U                                            /*!< DCB DEMCR: Monitor pend req key Position */ | ||||
| #define DCB_DEMCR_MONPRKEY_Msk             (0x1UL << DCB_DEMCR_MONPRKEY_Pos)              /*!< DCB DEMCR: Monitor pend req key Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_UMON_EN_Pos              21U                                            /*!< DCB DEMCR: Unprivileged monitor enable Position */ | ||||
| #define DCB_DEMCR_UMON_EN_Msk              (0x1UL << DCB_DEMCR_UMON_EN_Pos)               /*!< DCB DEMCR: Unprivileged monitor enable Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_SDME_Pos                 20U                                            /*!< DCB DEMCR: Secure DebugMonitor enable Position */ | ||||
| #define DCB_DEMCR_SDME_Msk                 (0x1UL << DCB_DEMCR_SDME_Pos)                  /*!< DCB DEMCR: Secure DebugMonitor enable Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_MON_REQ_Pos              19U                                            /*!< DCB DEMCR: Monitor request Position */ | ||||
| #define DCB_DEMCR_MON_REQ_Msk              (0x1UL << DCB_DEMCR_MON_REQ_Pos)               /*!< DCB DEMCR: Monitor request Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_MON_STEP_Pos             18U                                            /*!< DCB DEMCR: Monitor step Position */ | ||||
| #define DCB_DEMCR_MON_STEP_Msk             (0x1UL << DCB_DEMCR_MON_STEP_Pos)              /*!< DCB DEMCR: Monitor step Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_MON_PEND_Pos             17U                                            /*!< DCB DEMCR: Monitor pend Position */ | ||||
| #define DCB_DEMCR_MON_PEND_Msk             (0x1UL << DCB_DEMCR_MON_PEND_Pos)              /*!< DCB DEMCR: Monitor pend Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_MON_EN_Pos               16U                                            /*!< DCB DEMCR: Monitor enable Position */ | ||||
| #define DCB_DEMCR_MON_EN_Msk               (0x1UL << DCB_DEMCR_MON_EN_Pos)                /*!< DCB DEMCR: Monitor enable Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_SFERR_Pos             11U                                            /*!< DCB DEMCR: Vector Catch SecureFault Position */ | ||||
| #define DCB_DEMCR_VC_SFERR_Msk             (0x1UL << DCB_DEMCR_VC_SFERR_Pos)              /*!< DCB DEMCR: Vector Catch SecureFault Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_HARDERR_Pos           10U                                            /*!< DCB DEMCR: Vector Catch HardFault errors Position */ | ||||
| #define DCB_DEMCR_VC_HARDERR_Msk           (0x1UL << DCB_DEMCR_VC_HARDERR_Pos)            /*!< DCB DEMCR: Vector Catch HardFault errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_INTERR_Pos             9U                                            /*!< DCB DEMCR: Vector Catch interrupt errors Position */ | ||||
| #define DCB_DEMCR_VC_INTERR_Msk            (0x1UL << DCB_DEMCR_VC_INTERR_Pos)             /*!< DCB DEMCR: Vector Catch interrupt errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_BUSERR_Pos             8U                                            /*!< DCB DEMCR: Vector Catch BusFault errors Position */ | ||||
| #define DCB_DEMCR_VC_BUSERR_Msk            (0x1UL << DCB_DEMCR_VC_BUSERR_Pos)             /*!< DCB DEMCR: Vector Catch BusFault errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_STATERR_Pos            7U                                            /*!< DCB DEMCR: Vector Catch state errors Position */ | ||||
| #define DCB_DEMCR_VC_STATERR_Msk           (0x1UL << DCB_DEMCR_VC_STATERR_Pos)            /*!< DCB DEMCR: Vector Catch state errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_CHKERR_Pos             6U                                            /*!< DCB DEMCR: Vector Catch check errors Position */ | ||||
| #define DCB_DEMCR_VC_CHKERR_Msk            (0x1UL << DCB_DEMCR_VC_CHKERR_Pos)             /*!< DCB DEMCR: Vector Catch check errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_NOCPERR_Pos            5U                                            /*!< DCB DEMCR: Vector Catch NOCP errors Position */ | ||||
| #define DCB_DEMCR_VC_NOCPERR_Msk           (0x1UL << DCB_DEMCR_VC_NOCPERR_Pos)            /*!< DCB DEMCR: Vector Catch NOCP errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_MMERR_Pos              4U                                            /*!< DCB DEMCR: Vector Catch MemManage errors Position */ | ||||
| #define DCB_DEMCR_VC_MMERR_Msk             (0x1UL << DCB_DEMCR_VC_MMERR_Pos)              /*!< DCB DEMCR: Vector Catch MemManage errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_CORERESET_Pos          0U                                            /*!< DCB DEMCR: Vector Catch Core reset Position */ | ||||
| #define DCB_DEMCR_VC_CORERESET_Msk         (0x1UL /*<< DCB_DEMCR_VC_CORERESET_Pos*/)      /*!< DCB DEMCR: Vector Catch Core reset Mask */ | ||||
|  | ||||
| /* DAUTHCTRL, Debug Authentication Control Register Definitions */ | ||||
| #define DCB_DAUTHCTRL_INTSPNIDEN_Pos        3U                                            /*!< DCB DAUTHCTRL: Internal Secure non-invasive debug enable Position */ | ||||
| #define DCB_DAUTHCTRL_INTSPNIDEN_Msk       (0x1UL << DCB_DAUTHCTRL_INTSPNIDEN_Pos)        /*!< DCB DAUTHCTRL: Internal Secure non-invasive debug enable Mask */ | ||||
|  | ||||
| #define DCB_DAUTHCTRL_SPNIDENSEL_Pos        2U                                            /*!< DCB DAUTHCTRL: Secure non-invasive debug enable select Position */ | ||||
| #define DCB_DAUTHCTRL_SPNIDENSEL_Msk       (0x1UL << DCB_DAUTHCTRL_SPNIDENSEL_Pos)        /*!< DCB DAUTHCTRL: Secure non-invasive debug enable select Mask */ | ||||
|  | ||||
| #define DCB_DAUTHCTRL_INTSPIDEN_Pos         1U                                            /*!< DCB DAUTHCTRL: Internal Secure invasive debug enable Position */ | ||||
| #define DCB_DAUTHCTRL_INTSPIDEN_Msk        (0x1UL << DCB_DAUTHCTRL_INTSPIDEN_Pos)         /*!< DCB DAUTHCTRL: Internal Secure invasive debug enable Mask */ | ||||
|  | ||||
| #define DCB_DAUTHCTRL_SPIDENSEL_Pos         0U                                            /*!< DCB DAUTHCTRL: Secure invasive debug enable select Position */ | ||||
| #define DCB_DAUTHCTRL_SPIDENSEL_Msk        (0x1UL /*<< DCB_DAUTHCTRL_SPIDENSEL_Pos*/)     /*!< DCB DAUTHCTRL: Secure invasive debug enable select Mask */ | ||||
|  | ||||
| /* DSCSR, Debug Security Control and Status Register Definitions */ | ||||
| #define DCB_DSCSR_CDSKEY_Pos               17U                                            /*!< DCB DSCSR: CDS write-enable key Position */ | ||||
| #define DCB_DSCSR_CDSKEY_Msk               (0x1UL << DCB_DSCSR_CDSKEY_Pos)                /*!< DCB DSCSR: CDS write-enable key Mask */ | ||||
|  | ||||
| #define DCB_DSCSR_CDS_Pos                  16U                                            /*!< DCB DSCSR: Current domain Secure Position */ | ||||
| #define DCB_DSCSR_CDS_Msk                  (0x1UL << DCB_DSCSR_CDS_Pos)                   /*!< DCB DSCSR: Current domain Secure Mask */ | ||||
|  | ||||
| #define DCB_DSCSR_SBRSEL_Pos                1U                                            /*!< DCB DSCSR: Secure banked register select Position */ | ||||
| #define DCB_DSCSR_SBRSEL_Msk               (0x1UL << DCB_DSCSR_SBRSEL_Pos)                /*!< DCB DSCSR: Secure banked register select Mask */ | ||||
|  | ||||
| #define DCB_DSCSR_SBRSELEN_Pos              0U                                            /*!< DCB DSCSR: Secure banked register select enable Position */ | ||||
| #define DCB_DSCSR_SBRSELEN_Msk             (0x1UL /*<< DCB_DSCSR_SBRSELEN_Pos*/)          /*!< DCB DSCSR: Secure banked register select enable Mask */ | ||||
|  | ||||
| /*@} end of group CMSIS_DCB */ | ||||
|  | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup  CMSIS_core_register | ||||
|   \defgroup CMSIS_DIB       Debug Identification Block | ||||
|   \brief    Type definitions for the Debug Identification Block Registers | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief  Structure type to access the Debug Identification Block Registers (DIB). | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
|   __OM  uint32_t DLAR;                   /*!< Offset: 0x000 ( /W)  SCS Software Lock Access Register */ | ||||
|   __IM  uint32_t DLSR;                   /*!< Offset: 0x004 (R/ )  SCS Software Lock Status Register */ | ||||
|   __IM  uint32_t DAUTHSTATUS;            /*!< Offset: 0x008 (R/ )  Debug Authentication Status Register */ | ||||
|   __IM  uint32_t DDEVARCH;               /*!< Offset: 0x00C (R/ )  SCS Device Architecture Register */ | ||||
|   __IM  uint32_t DDEVTYPE;               /*!< Offset: 0x010 (R/ )  SCS Device Type Register */ | ||||
| } DIB_Type; | ||||
|  | ||||
| /* DLAR, SCS Software Lock Access Register Definitions */ | ||||
| #define DIB_DLAR_KEY_Pos                    0U                                            /*!< DIB DLAR: KEY Position */ | ||||
| #define DIB_DLAR_KEY_Msk                   (0xFFFFFFFFUL /*<< DIB_DLAR_KEY_Pos */)        /*!< DIB DLAR: KEY Mask */ | ||||
|  | ||||
| /* DLSR, SCS Software Lock Status Register Definitions */ | ||||
| #define DIB_DLSR_nTT_Pos                    2U                                            /*!< DIB DLSR: Not thirty-two bit Position */ | ||||
| #define DIB_DLSR_nTT_Msk                   (0x1UL << DIB_DLSR_nTT_Pos )                   /*!< DIB DLSR: Not thirty-two bit Mask */ | ||||
|  | ||||
| #define DIB_DLSR_SLK_Pos                    1U                                            /*!< DIB DLSR: Software Lock status Position */ | ||||
| #define DIB_DLSR_SLK_Msk                   (0x1UL << DIB_DLSR_SLK_Pos )                   /*!< DIB DLSR: Software Lock status Mask */ | ||||
|  | ||||
| #define DIB_DLSR_SLI_Pos                    0U                                            /*!< DIB DLSR: Software Lock implemented Position */ | ||||
| #define DIB_DLSR_SLI_Msk                   (0x1UL /*<< DIB_DLSR_SLI_Pos*/)                /*!< DIB DLSR: Software Lock implemented Mask */ | ||||
|  | ||||
| /* DAUTHSTATUS, Debug Authentication Status Register Definitions */ | ||||
| #define DIB_DAUTHSTATUS_SNID_Pos            6U                                            /*!< DIB DAUTHSTATUS: Secure Non-invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_SNID_Msk           (0x3UL << DIB_DAUTHSTATUS_SNID_Pos )           /*!< DIB DAUTHSTATUS: Secure Non-invasive Debug Mask */ | ||||
|  | ||||
| #define DIB_DAUTHSTATUS_SID_Pos             4U                                            /*!< DIB DAUTHSTATUS: Secure Invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_SID_Msk            (0x3UL << DIB_DAUTHSTATUS_SID_Pos )            /*!< DIB DAUTHSTATUS: Secure Invasive Debug Mask */ | ||||
|  | ||||
| #define DIB_DAUTHSTATUS_NSNID_Pos           2U                                            /*!< DIB DAUTHSTATUS: Non-secure Non-invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_NSNID_Msk          (0x3UL << DIB_DAUTHSTATUS_NSNID_Pos )          /*!< DIB DAUTHSTATUS: Non-secure Non-invasive Debug Mask */ | ||||
|  | ||||
| #define DIB_DAUTHSTATUS_NSID_Pos            0U                                            /*!< DIB DAUTHSTATUS: Non-secure Invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_NSID_Msk           (0x3UL /*<< DIB_DAUTHSTATUS_NSID_Pos*/)        /*!< DIB DAUTHSTATUS: Non-secure Invasive Debug Mask */ | ||||
|  | ||||
| /* DDEVARCH, SCS Device Architecture Register Definitions */ | ||||
| #define DIB_DDEVARCH_ARCHITECT_Pos         21U                                            /*!< DIB DDEVARCH: Architect Position */ | ||||
| #define DIB_DDEVARCH_ARCHITECT_Msk         (0x7FFUL << DIB_DDEVARCH_ARCHITECT_Pos )       /*!< DIB DDEVARCH: Architect Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_PRESENT_Pos           20U                                            /*!< DIB DDEVARCH: DEVARCH Present Position */ | ||||
| #define DIB_DDEVARCH_PRESENT_Msk           (0x1FUL << DIB_DDEVARCH_PRESENT_Pos )          /*!< DIB DDEVARCH: DEVARCH Present Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_REVISION_Pos          16U                                            /*!< DIB DDEVARCH: Revision Position */ | ||||
| #define DIB_DDEVARCH_REVISION_Msk          (0xFUL << DIB_DDEVARCH_REVISION_Pos )          /*!< DIB DDEVARCH: Revision Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_ARCHVER_Pos           12U                                            /*!< DIB DDEVARCH: Architecture Version Position */ | ||||
| #define DIB_DDEVARCH_ARCHVER_Msk           (0xFUL << DIB_DDEVARCH_ARCHVER_Pos )           /*!< DIB DDEVARCH: Architecture Version Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_ARCHPART_Pos           0U                                            /*!< DIB DDEVARCH: Architecture Part Position */ | ||||
| #define DIB_DDEVARCH_ARCHPART_Msk          (0xFFFUL /*<< DIB_DDEVARCH_ARCHPART_Pos*/)     /*!< DIB DDEVARCH: Architecture Part Mask */ | ||||
|  | ||||
| /* DDEVTYPE, SCS Device Type Register Definitions */ | ||||
| #define DIB_DDEVTYPE_SUB_Pos                4U                                            /*!< DIB DDEVTYPE: Sub-type Position */ | ||||
| #define DIB_DDEVTYPE_SUB_Msk               (0xFUL << DIB_DDEVTYPE_SUB_Pos )               /*!< DIB DDEVTYPE: Sub-type Mask */ | ||||
|  | ||||
| #define DIB_DDEVTYPE_MAJOR_Pos              0U                                            /*!< DIB DDEVTYPE: Major type Position */ | ||||
| #define DIB_DDEVTYPE_MAJOR_Msk             (0xFUL /*<< DIB_DDEVTYPE_MAJOR_Pos*/)          /*!< DIB DDEVTYPE: Major type Mask */ | ||||
|  | ||||
|  | ||||
| /*@} end of group CMSIS_DIB */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup    CMSIS_core_register | ||||
|   \defgroup   CMSIS_core_bitfield     Core register bit field macros | ||||
| @@ -2125,9 +1879,7 @@ typedef struct | ||||
|   #define ITM_BASE            (0xE0000000UL)                             /*!< ITM Base Address */ | ||||
|   #define DWT_BASE            (0xE0001000UL)                             /*!< DWT Base Address */ | ||||
|   #define TPI_BASE            (0xE0040000UL)                             /*!< TPI Base Address */ | ||||
|   #define CoreDebug_BASE      (0xE000EDF0UL)                             /*!< \deprecated Core Debug Base Address */ | ||||
|   #define DCB_BASE            (0xE000EDF0UL)                             /*!< DCB Base Address */ | ||||
|   #define DIB_BASE            (0xE000EFB0UL)                             /*!< DIB Base Address */ | ||||
|   #define CoreDebug_BASE      (0xE000EDF0UL)                             /*!< Core Debug Base Address */ | ||||
|   #define SysTick_BASE        (SCS_BASE +  0x0010UL)                     /*!< SysTick Base Address */ | ||||
|   #define NVIC_BASE           (SCS_BASE +  0x0100UL)                     /*!< NVIC Base Address */ | ||||
|   #define SCB_BASE            (SCS_BASE +  0x0D00UL)                     /*!< System Control Block Base Address */ | ||||
| @@ -2139,9 +1891,7 @@ typedef struct | ||||
|   #define ITM                 ((ITM_Type       *)     ITM_BASE         ) /*!< ITM configuration struct */ | ||||
|   #define DWT                 ((DWT_Type       *)     DWT_BASE         ) /*!< DWT configuration struct */ | ||||
|   #define TPI                 ((TPI_Type       *)     TPI_BASE         ) /*!< TPI configuration struct */ | ||||
|   #define CoreDebug           ((CoreDebug_Type *)     CoreDebug_BASE   ) /*!< \deprecated Core Debug configuration struct */ | ||||
|   #define DCB                 ((DCB_Type       *)     DCB_BASE         ) /*!< DCB configuration struct */ | ||||
|   #define DIB                 ((DIB_Type       *)     DIB_BASE         ) /*!< DIB configuration struct */ | ||||
|   #define CoreDebug           ((CoreDebug_Type *)     CoreDebug_BASE   ) /*!< Core Debug configuration struct */ | ||||
|  | ||||
|   #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) | ||||
|     #define MPU_BASE          (SCS_BASE +  0x0D90UL)                     /*!< Memory Protection Unit */ | ||||
| @@ -2158,9 +1908,7 @@ typedef struct | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
|   #define SCS_BASE_NS         (0xE002E000UL)                             /*!< System Control Space Base Address (non-secure address space) */ | ||||
|   #define CoreDebug_BASE_NS   (0xE002EDF0UL)                             /*!< \deprecated Core Debug Base Address           (non-secure address space) */ | ||||
|   #define DCB_BASE_NS         (0xE002EDF0UL)                             /*!< DCB Base Address                  (non-secure address space) */ | ||||
|   #define DIB_BASE_NS         (0xE002EFB0UL)                             /*!< DIB Base Address                  (non-secure address space) */ | ||||
|   #define CoreDebug_BASE_NS   (0xE002EDF0UL)                             /*!< Core Debug Base Address           (non-secure address space) */ | ||||
|   #define SysTick_BASE_NS     (SCS_BASE_NS +  0x0010UL)                  /*!< SysTick Base Address              (non-secure address space) */ | ||||
|   #define NVIC_BASE_NS        (SCS_BASE_NS +  0x0100UL)                  /*!< NVIC Base Address                 (non-secure address space) */ | ||||
|   #define SCB_BASE_NS         (SCS_BASE_NS +  0x0D00UL)                  /*!< System Control Block Base Address (non-secure address space) */ | ||||
| @@ -2169,9 +1917,7 @@ typedef struct | ||||
|   #define SCB_NS              ((SCB_Type       *)     SCB_BASE_NS      ) /*!< SCB configuration struct          (non-secure address space) */ | ||||
|   #define SysTick_NS          ((SysTick_Type   *)     SysTick_BASE_NS  ) /*!< SysTick configuration struct      (non-secure address space) */ | ||||
|   #define NVIC_NS             ((NVIC_Type      *)     NVIC_BASE_NS     ) /*!< NVIC configuration struct         (non-secure address space) */ | ||||
|   #define CoreDebug_NS        ((CoreDebug_Type *)     CoreDebug_BASE_NS) /*!< \deprecated Core Debug configuration struct   (non-secure address space) */ | ||||
|   #define DCB_NS              ((DCB_Type       *)     DCB_BASE_NS      ) /*!< DCB configuration struct          (non-secure address space) */ | ||||
|   #define DIB_NS              ((DIB_Type       *)     DIB_BASE_NS      ) /*!< DIB configuration struct          (non-secure address space) */ | ||||
|   #define CoreDebug_NS        ((CoreDebug_Type *)     CoreDebug_BASE_NS) /*!< Core Debug configuration struct   (non-secure address space) */ | ||||
|  | ||||
|   #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) | ||||
|     #define MPU_BASE_NS       (SCS_BASE_NS +  0x0D90UL)                  /*!< Memory Protection Unit            (non-secure address space) */ | ||||
| @@ -2185,15 +1931,6 @@ typedef struct | ||||
| /*@} */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup    CMSIS_core_register | ||||
|   \defgroup   CMSIS_register_aliases     Backwards Compatibility Aliases | ||||
|   \brief      Register alias definitions for backwards compatibility. | ||||
|   @{ | ||||
|  */ | ||||
| #define ID_ADR  (ID_AFR)    /*!< SCB Auxiliary Feature Register */ | ||||
| /*@} */ | ||||
|  | ||||
|  | ||||
| /******************************************************************************* | ||||
|  *                Hardware Abstraction Layer | ||||
| @@ -2899,13 +2636,6 @@ __STATIC_INLINE uint32_t SCB_GetFPUType(void) | ||||
| /*@} end of CMSIS_Core_FpuFunctions */ | ||||
|  | ||||
|  | ||||
| /* ##########################  Cache functions  #################################### */ | ||||
|  | ||||
| #if ((defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U)) || \ | ||||
|      (defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U))) | ||||
| #include "cachel1_armv7.h" | ||||
| #endif | ||||
|  | ||||
|  | ||||
| /* ##########################   SAU functions  #################################### */ | ||||
| /** | ||||
| @@ -2944,110 +2674,6 @@ __STATIC_INLINE void TZ_SAU_Disable(void) | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    Debug Control function  ############################################ */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   \defgroup CMSIS_Core_DCBFunctions Debug Control Functions | ||||
|   \brief    Functions that access the Debug Control Block. | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Debug Authentication Control Register | ||||
|   \details writes to Debug Authentication Control register. | ||||
|   \param [in]  value  value to be writen. | ||||
|  */ | ||||
| __STATIC_INLINE void DCB_SetAuthCtrl(uint32_t value) | ||||
| { | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     DCB->DAUTHCTRL = value; | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Debug Authentication Control Register | ||||
|   \details Reads Debug Authentication Control register. | ||||
|   \return             Debug Authentication Control Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t DCB_GetAuthCtrl(void) | ||||
| { | ||||
|     return (DCB->DAUTHCTRL); | ||||
| } | ||||
|  | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
| /** | ||||
|   \brief   Set Debug Authentication Control Register (non-secure) | ||||
|   \details writes to non-secure Debug Authentication Control register when in secure state. | ||||
|   \param [in]  value  value to be writen | ||||
|  */ | ||||
| __STATIC_INLINE void TZ_DCB_SetAuthCtrl_NS(uint32_t value) | ||||
| { | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     DCB_NS->DAUTHCTRL = value; | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Debug Authentication Control Register (non-secure) | ||||
|   \details Reads non-secure Debug Authentication Control register when in secure state. | ||||
|   \return             Debug Authentication Control Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t TZ_DCB_GetAuthCtrl_NS(void) | ||||
| { | ||||
|     return (DCB_NS->DAUTHCTRL); | ||||
| } | ||||
| #endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ | ||||
|  | ||||
| /*@} end of CMSIS_Core_DCBFunctions */ | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    Debug Identification function  ############################################ */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   \defgroup CMSIS_Core_DIBFunctions Debug Identification Functions | ||||
|   \brief    Functions that access the Debug Identification Block. | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Debug Authentication Status Register | ||||
|   \details Reads Debug Authentication Status register. | ||||
|   \return             Debug Authentication Status Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t DIB_GetAuthStatus(void) | ||||
| { | ||||
|     return (DIB->DAUTHSTATUS); | ||||
| } | ||||
|  | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
| /** | ||||
|   \brief   Get Debug Authentication Status Register (non-secure) | ||||
|   \details Reads non-secure Debug Authentication Status register when in secure state. | ||||
|   \return             Debug Authentication Status Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t TZ_DIB_GetAuthStatus_NS(void) | ||||
| { | ||||
|     return (DIB_NS->DAUTHSTATUS); | ||||
| } | ||||
| #endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ | ||||
|  | ||||
| /*@} end of CMSIS_Core_DCBFunctions */ | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    SysTick function  ############################################ */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| /**************************************************************************//** | ||||
|  * @file     core_cm0.h | ||||
|  * @brief    CMSIS Cortex-M0 Core Peripheral Access Layer Header File | ||||
|  * @version  V5.0.8 | ||||
|  * @date     21. August 2019 | ||||
|  * @version  V5.0.6 | ||||
|  * @date     13. March 2019 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2009-2019 Arm Limited. All rights reserved. | ||||
| @@ -831,8 +831,8 @@ __STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGr | ||||
|  */ | ||||
| __STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) | ||||
| { | ||||
|   uint32_t *vectors = (uint32_t *)(NVIC_USER_IRQ_OFFSET << 2);      /* point to 1st user interrupt */ | ||||
|   *(vectors + (int32_t)IRQn) = vector;                              /* use pointer arithmetic to access vector */ | ||||
|   uint32_t vectors = 0x0U; | ||||
|   (* (int *) (vectors + ((int32_t)IRQn + NVIC_USER_IRQ_OFFSET) * 4)) = vector; | ||||
|   /* ARM Application Note 321 states that the M0 does not require the architectural barrier */ | ||||
| } | ||||
|  | ||||
| @@ -847,8 +847,8 @@ __STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) | ||||
| { | ||||
|   uint32_t *vectors = (uint32_t *)(NVIC_USER_IRQ_OFFSET << 2);      /* point to 1st user interrupt */ | ||||
|   return *(vectors + (int32_t)IRQn);                                /* use pointer arithmetic to access vector */ | ||||
|   uint32_t vectors = 0x0U; | ||||
|   return (uint32_t)(* (int *) (vectors + ((int32_t)IRQn + NVIC_USER_IRQ_OFFSET) * 4)); | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| /**************************************************************************//** | ||||
|  * @file     core_cm0plus.h | ||||
|  * @brief    CMSIS Cortex-M0+ Core Peripheral Access Layer Header File | ||||
|  * @version  V5.0.9 | ||||
|  * @date     21. August 2019 | ||||
|  * @version  V5.0.7 | ||||
|  * @date     13. March 2019 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2009-2019 Arm Limited. All rights reserved. | ||||
| @@ -950,12 +950,11 @@ __STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGr | ||||
| __STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) | ||||
| { | ||||
| #if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) | ||||
|   uint32_t *vectors = (uint32_t *)SCB->VTOR; | ||||
|   vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; | ||||
|   uint32_t vectors = SCB->VTOR; | ||||
| #else | ||||
|   uint32_t *vectors = (uint32_t *)(NVIC_USER_IRQ_OFFSET << 2);      /* point to 1st user interrupt */ | ||||
|   *(vectors + (int32_t)IRQn) = vector;                              /* use pointer arithmetic to access vector */ | ||||
|   uint32_t vectors = 0x0U; | ||||
| #endif | ||||
|   (* (int *) (vectors + ((int32_t)IRQn + NVIC_USER_IRQ_OFFSET) * 4)) = vector; | ||||
|   /* ARM Application Note 321 states that the M0+ does not require the architectural barrier */ | ||||
| } | ||||
|  | ||||
| @@ -971,12 +970,11 @@ __STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) | ||||
| __STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) | ||||
| { | ||||
| #if defined (__VTOR_PRESENT) && (__VTOR_PRESENT == 1U) | ||||
|   uint32_t *vectors = (uint32_t *)SCB->VTOR; | ||||
|   return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; | ||||
|   uint32_t vectors = SCB->VTOR; | ||||
| #else | ||||
|   uint32_t *vectors = (uint32_t *)(NVIC_USER_IRQ_OFFSET << 2);      /* point to 1st user interrupt */ | ||||
|   return *(vectors + (int32_t)IRQn);                                /* use pointer arithmetic to access vector */ | ||||
|   uint32_t vectors = 0x0U; | ||||
| #endif | ||||
|   return (uint32_t)(* (int *) (vectors + ((int32_t)IRQn + NVIC_USER_IRQ_OFFSET) * 4)); | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
| /**************************************************************************//** | ||||
|  * @file     core_cm23.h | ||||
|  * @brief    CMSIS Cortex-M23 Core Peripheral Access Layer Header File | ||||
|  * @version  V5.1.0 | ||||
|  * @date     11. February 2020 | ||||
|  * @version  V5.0.8 | ||||
|  * @date     12. November 2018 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2009-2020 Arm Limited. All rights reserved. | ||||
|  * Copyright (c) 2009-2018 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
| @@ -26,8 +26,6 @@ | ||||
|   #pragma system_include         /* treat file as system include file for MISRA check */ | ||||
| #elif defined (__clang__) | ||||
|   #pragma clang system_header   /* treat file as system include file */ | ||||
| #elif defined ( __GNUC__ ) | ||||
|   #pragma GCC diagnostic ignored "-Wpedantic"   /* disable pedantic warning due to unnamed structs/unions */ | ||||
| #endif | ||||
|  | ||||
| #ifndef __CORE_CM23_H_GENERIC | ||||
| @@ -1052,7 +1050,6 @@ typedef struct | ||||
| #endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ | ||||
|  | ||||
|  | ||||
| /* CoreDebug is deprecated. replaced by DCB (Debug Control Block) */ | ||||
| /** | ||||
|   \ingroup  CMSIS_core_register | ||||
|   \defgroup CMSIS_CoreDebug       Core Debug Registers (CoreDebug) | ||||
| @@ -1061,7 +1058,7 @@ typedef struct | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief  \deprecated Structure type to access the Core Debug Register (CoreDebug). | ||||
|   \brief  Structure type to access the Core Debug Register (CoreDebug). | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
| @@ -1069,276 +1066,91 @@ typedef struct | ||||
|   __OM  uint32_t DCRSR;                  /*!< Offset: 0x004 ( /W)  Debug Core Register Selector Register */ | ||||
|   __IOM uint32_t DCRDR;                  /*!< Offset: 0x008 (R/W)  Debug Core Register Data Register */ | ||||
|   __IOM uint32_t DEMCR;                  /*!< Offset: 0x00C (R/W)  Debug Exception and Monitor Control Register */ | ||||
|         uint32_t RESERVED0[1U]; | ||||
|         uint32_t RESERVED4[1U]; | ||||
|   __IOM uint32_t DAUTHCTRL;              /*!< Offset: 0x014 (R/W)  Debug Authentication Control Register */ | ||||
|   __IOM uint32_t DSCSR;                  /*!< Offset: 0x018 (R/W)  Debug Security Control and Status Register */ | ||||
| } CoreDebug_Type; | ||||
|  | ||||
| /* Debug Halting Control and Status Register Definitions */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Pos         16U                                            /*!< \deprecated CoreDebug DHCSR: DBGKEY Position */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Msk         (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos)       /*!< \deprecated CoreDebug DHCSR: DBGKEY Mask */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Pos         16U                                            /*!< CoreDebug DHCSR: DBGKEY Position */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Msk         (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos)       /*!< CoreDebug DHCSR: DBGKEY Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Pos   26U                                            /*!< \deprecated CoreDebug DHCSR: S_RESTART_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Msk   (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos)      /*!< \deprecated CoreDebug DHCSR: S_RESTART_ST Mask */ | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Pos   26U                                            /*!< CoreDebug DHCSR: S_RESTART_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Msk   (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos)      /*!< CoreDebug DHCSR: S_RESTART_ST Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Pos     25U                                            /*!< \deprecated CoreDebug DHCSR: S_RESET_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Msk     (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos)        /*!< \deprecated CoreDebug DHCSR: S_RESET_ST Mask */ | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Pos     25U                                            /*!< CoreDebug DHCSR: S_RESET_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Msk     (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos)        /*!< CoreDebug DHCSR: S_RESET_ST Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Pos    24U                                            /*!< \deprecated CoreDebug DHCSR: S_RETIRE_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Msk    (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos)       /*!< \deprecated CoreDebug DHCSR: S_RETIRE_ST Mask */ | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Pos    24U                                            /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Msk    (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos)       /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Pos       19U                                            /*!< \deprecated CoreDebug DHCSR: S_LOCKUP Position */ | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Msk       (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos)          /*!< \deprecated CoreDebug DHCSR: S_LOCKUP Mask */ | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Pos       19U                                            /*!< CoreDebug DHCSR: S_LOCKUP Position */ | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Msk       (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos)          /*!< CoreDebug DHCSR: S_LOCKUP Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Pos        18U                                            /*!< \deprecated CoreDebug DHCSR: S_SLEEP Position */ | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Msk        (1UL << CoreDebug_DHCSR_S_SLEEP_Pos)           /*!< \deprecated CoreDebug DHCSR: S_SLEEP Mask */ | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Pos        18U                                            /*!< CoreDebug DHCSR: S_SLEEP Position */ | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Msk        (1UL << CoreDebug_DHCSR_S_SLEEP_Pos)           /*!< CoreDebug DHCSR: S_SLEEP Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_HALT_Pos         17U                                            /*!< \deprecated CoreDebug DHCSR: S_HALT Position */ | ||||
| #define CoreDebug_DHCSR_S_HALT_Msk         (1UL << CoreDebug_DHCSR_S_HALT_Pos)            /*!< \deprecated CoreDebug DHCSR: S_HALT Mask */ | ||||
| #define CoreDebug_DHCSR_S_HALT_Pos         17U                                            /*!< CoreDebug DHCSR: S_HALT Position */ | ||||
| #define CoreDebug_DHCSR_S_HALT_Msk         (1UL << CoreDebug_DHCSR_S_HALT_Pos)            /*!< CoreDebug DHCSR: S_HALT Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Pos       16U                                            /*!< \deprecated CoreDebug DHCSR: S_REGRDY Position */ | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Msk       (1UL << CoreDebug_DHCSR_S_REGRDY_Pos)          /*!< \deprecated CoreDebug DHCSR: S_REGRDY Mask */ | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Pos       16U                                            /*!< CoreDebug DHCSR: S_REGRDY Position */ | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Msk       (1UL << CoreDebug_DHCSR_S_REGRDY_Pos)          /*!< CoreDebug DHCSR: S_REGRDY Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Pos      3U                                            /*!< \deprecated CoreDebug DHCSR: C_MASKINTS Position */ | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Msk     (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos)        /*!< \deprecated CoreDebug DHCSR: C_MASKINTS Mask */ | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Pos      3U                                            /*!< CoreDebug DHCSR: C_MASKINTS Position */ | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Msk     (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos)        /*!< CoreDebug DHCSR: C_MASKINTS Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_STEP_Pos          2U                                            /*!< \deprecated CoreDebug DHCSR: C_STEP Position */ | ||||
| #define CoreDebug_DHCSR_C_STEP_Msk         (1UL << CoreDebug_DHCSR_C_STEP_Pos)            /*!< \deprecated CoreDebug DHCSR: C_STEP Mask */ | ||||
| #define CoreDebug_DHCSR_C_STEP_Pos          2U                                            /*!< CoreDebug DHCSR: C_STEP Position */ | ||||
| #define CoreDebug_DHCSR_C_STEP_Msk         (1UL << CoreDebug_DHCSR_C_STEP_Pos)            /*!< CoreDebug DHCSR: C_STEP Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_HALT_Pos          1U                                            /*!< \deprecated CoreDebug DHCSR: C_HALT Position */ | ||||
| #define CoreDebug_DHCSR_C_HALT_Msk         (1UL << CoreDebug_DHCSR_C_HALT_Pos)            /*!< \deprecated CoreDebug DHCSR: C_HALT Mask */ | ||||
| #define CoreDebug_DHCSR_C_HALT_Pos          1U                                            /*!< CoreDebug DHCSR: C_HALT Position */ | ||||
| #define CoreDebug_DHCSR_C_HALT_Msk         (1UL << CoreDebug_DHCSR_C_HALT_Pos)            /*!< CoreDebug DHCSR: C_HALT Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Pos       0U                                            /*!< \deprecated CoreDebug DHCSR: C_DEBUGEN Position */ | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Msk      (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/)     /*!< \deprecated CoreDebug DHCSR: C_DEBUGEN Mask */ | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Pos       0U                                            /*!< CoreDebug DHCSR: C_DEBUGEN Position */ | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Msk      (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/)     /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ | ||||
|  | ||||
| /* Debug Core Register Selector Register Definitions */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Pos         16U                                            /*!< \deprecated CoreDebug DCRSR: REGWnR Position */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Msk         (1UL << CoreDebug_DCRSR_REGWnR_Pos)            /*!< \deprecated CoreDebug DCRSR: REGWnR Mask */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Pos         16U                                            /*!< CoreDebug DCRSR: REGWnR Position */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Msk         (1UL << CoreDebug_DCRSR_REGWnR_Pos)            /*!< CoreDebug DCRSR: REGWnR Mask */ | ||||
|  | ||||
| #define CoreDebug_DCRSR_REGSEL_Pos          0U                                            /*!< \deprecated CoreDebug DCRSR: REGSEL Position */ | ||||
| #define CoreDebug_DCRSR_REGSEL_Msk         (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/)     /*!< \deprecated CoreDebug DCRSR: REGSEL Mask */ | ||||
| #define CoreDebug_DCRSR_REGSEL_Pos          0U                                            /*!< CoreDebug DCRSR: REGSEL Position */ | ||||
| #define CoreDebug_DCRSR_REGSEL_Msk         (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/)     /*!< CoreDebug DCRSR: REGSEL Mask */ | ||||
|  | ||||
| /* Debug Exception and Monitor Control Register */ | ||||
| #define CoreDebug_DEMCR_DWTENA_Pos         24U                                            /*!< \deprecated CoreDebug DEMCR: DWTENA Position */ | ||||
| #define CoreDebug_DEMCR_DWTENA_Msk         (1UL << CoreDebug_DEMCR_DWTENA_Pos)            /*!< \deprecated CoreDebug DEMCR: DWTENA Mask */ | ||||
| #define CoreDebug_DEMCR_DWTENA_Pos         24U                                            /*!< CoreDebug DEMCR: DWTENA Position */ | ||||
| #define CoreDebug_DEMCR_DWTENA_Msk         (1UL << CoreDebug_DEMCR_DWTENA_Pos)            /*!< CoreDebug DEMCR: DWTENA Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Pos     10U                                            /*!< \deprecated CoreDebug DEMCR: VC_HARDERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Msk     (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos)        /*!< \deprecated CoreDebug DEMCR: VC_HARDERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Pos     10U                                            /*!< CoreDebug DEMCR: VC_HARDERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Msk     (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos)        /*!< CoreDebug DEMCR: VC_HARDERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Pos    0U                                            /*!< \deprecated CoreDebug DEMCR: VC_CORERESET Position */ | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Msk   (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/)  /*!< \deprecated CoreDebug DEMCR: VC_CORERESET Mask */ | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Pos    0U                                            /*!< CoreDebug DEMCR: VC_CORERESET Position */ | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Msk   (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/)  /*!< CoreDebug DEMCR: VC_CORERESET Mask */ | ||||
|  | ||||
| /* Debug Authentication Control Register Definitions */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos  3U                                            /*!< \deprecated CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos)    /*!< \deprecated CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos  3U                                            /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos)    /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ | ||||
|  | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos  2U                                            /*!< \deprecated CoreDebug DAUTHCTRL: SPNIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos)    /*!< \deprecated CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos  2U                                            /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos)    /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ | ||||
|  | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos   1U                                            /*!< \deprecated CoreDebug DAUTHCTRL: INTSPIDEN Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk  (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos)     /*!< \deprecated CoreDebug DAUTHCTRL: INTSPIDEN Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos   1U                                            /*!< CoreDebug DAUTHCTRL: INTSPIDEN Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk  (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos)     /*!< CoreDebug DAUTHCTRL: INTSPIDEN Mask */ | ||||
|  | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos   0U                                            /*!< \deprecated CoreDebug DAUTHCTRL: SPIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk  (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< \deprecated CoreDebug DAUTHCTRL: SPIDENSEL Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos   0U                                            /*!< CoreDebug DAUTHCTRL: SPIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk  (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< CoreDebug DAUTHCTRL: SPIDENSEL Mask */ | ||||
|  | ||||
| /* Debug Security Control and Status Register Definitions */ | ||||
| #define CoreDebug_DSCSR_CDS_Pos            16U                                            /*!< \deprecated CoreDebug DSCSR: CDS Position */ | ||||
| #define CoreDebug_DSCSR_CDS_Msk            (1UL << CoreDebug_DSCSR_CDS_Pos)               /*!< \deprecated CoreDebug DSCSR: CDS Mask */ | ||||
| #define CoreDebug_DSCSR_CDS_Pos            16U                                            /*!< CoreDebug DSCSR: CDS Position */ | ||||
| #define CoreDebug_DSCSR_CDS_Msk            (1UL << CoreDebug_DSCSR_CDS_Pos)               /*!< CoreDebug DSCSR: CDS Mask */ | ||||
|  | ||||
| #define CoreDebug_DSCSR_SBRSEL_Pos          1U                                            /*!< \deprecated CoreDebug DSCSR: SBRSEL Position */ | ||||
| #define CoreDebug_DSCSR_SBRSEL_Msk         (1UL << CoreDebug_DSCSR_SBRSEL_Pos)            /*!< \deprecated CoreDebug DSCSR: SBRSEL Mask */ | ||||
| #define CoreDebug_DSCSR_SBRSEL_Pos          1U                                            /*!< CoreDebug DSCSR: SBRSEL Position */ | ||||
| #define CoreDebug_DSCSR_SBRSEL_Msk         (1UL << CoreDebug_DSCSR_SBRSEL_Pos)            /*!< CoreDebug DSCSR: SBRSEL Mask */ | ||||
|  | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Pos        0U                                            /*!< \deprecated CoreDebug DSCSR: SBRSELEN Position */ | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Msk       (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/)      /*!< \deprecated CoreDebug DSCSR: SBRSELEN Mask */ | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Pos        0U                                            /*!< CoreDebug DSCSR: SBRSELEN Position */ | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Msk       (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/)      /*!< CoreDebug DSCSR: SBRSELEN Mask */ | ||||
|  | ||||
| /*@} end of group CMSIS_CoreDebug */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup    CMSIS_core_register | ||||
|   \defgroup CMSIS_DCB       Debug Control Block | ||||
|   \brief    Type definitions for the Debug Control Block Registers | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief  Structure type to access the Debug Control Block Registers (DCB). | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
|   __IOM uint32_t DHCSR;                  /*!< Offset: 0x000 (R/W)  Debug Halting Control and Status Register */ | ||||
|   __OM  uint32_t DCRSR;                  /*!< Offset: 0x004 ( /W)  Debug Core Register Selector Register */ | ||||
|   __IOM uint32_t DCRDR;                  /*!< Offset: 0x008 (R/W)  Debug Core Register Data Register */ | ||||
|   __IOM uint32_t DEMCR;                  /*!< Offset: 0x00C (R/W)  Debug Exception and Monitor Control Register */ | ||||
|         uint32_t RESERVED0[1U]; | ||||
|   __IOM uint32_t DAUTHCTRL;              /*!< Offset: 0x014 (R/W)  Debug Authentication Control Register */ | ||||
|   __IOM uint32_t DSCSR;                  /*!< Offset: 0x018 (R/W)  Debug Security Control and Status Register */ | ||||
| } DCB_Type; | ||||
|  | ||||
| /* DHCSR, Debug Halting Control and Status Register Definitions */ | ||||
| #define DCB_DHCSR_DBGKEY_Pos               16U                                            /*!< DCB DHCSR: Debug key Position */ | ||||
| #define DCB_DHCSR_DBGKEY_Msk               (0xFFFFUL << DCB_DHCSR_DBGKEY_Pos)             /*!< DCB DHCSR: Debug key Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_RESTART_ST_Pos         26U                                            /*!< DCB DHCSR: Restart sticky status Position */ | ||||
| #define DCB_DHCSR_S_RESTART_ST_Msk         (0x1UL << DCB_DHCSR_S_RESTART_ST_Pos)          /*!< DCB DHCSR: Restart sticky status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_RESET_ST_Pos           25U                                            /*!< DCB DHCSR: Reset sticky status Position */ | ||||
| #define DCB_DHCSR_S_RESET_ST_Msk           (0x1UL << DCB_DHCSR_S_RESET_ST_Pos)            /*!< DCB DHCSR: Reset sticky status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_RETIRE_ST_Pos          24U                                            /*!< DCB DHCSR: Retire sticky status Position */ | ||||
| #define DCB_DHCSR_S_RETIRE_ST_Msk          (0x1UL << DCB_DHCSR_S_RETIRE_ST_Pos)           /*!< DCB DHCSR: Retire sticky status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_SDE_Pos                20U                                            /*!< DCB DHCSR: Secure debug enabled Position */ | ||||
| #define DCB_DHCSR_S_SDE_Msk                (0x1UL << DCB_DHCSR_S_SDE_Pos)                 /*!< DCB DHCSR: Secure debug enabled Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_LOCKUP_Pos             19U                                            /*!< DCB DHCSR: Lockup status Position */ | ||||
| #define DCB_DHCSR_S_LOCKUP_Msk             (0x1UL << DCB_DHCSR_S_LOCKUP_Pos)              /*!< DCB DHCSR: Lockup status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_SLEEP_Pos              18U                                            /*!< DCB DHCSR: Sleeping status Position */ | ||||
| #define DCB_DHCSR_S_SLEEP_Msk              (0x1UL << DCB_DHCSR_S_SLEEP_Pos)               /*!< DCB DHCSR: Sleeping status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_HALT_Pos               17U                                            /*!< DCB DHCSR: Halted status Position */ | ||||
| #define DCB_DHCSR_S_HALT_Msk               (0x1UL << DCB_DHCSR_S_HALT_Pos)                /*!< DCB DHCSR: Halted status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_REGRDY_Pos             16U                                            /*!< DCB DHCSR: Register ready status Position */ | ||||
| #define DCB_DHCSR_S_REGRDY_Msk             (0x1UL << DCB_DHCSR_S_REGRDY_Pos)              /*!< DCB DHCSR: Register ready status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_MASKINTS_Pos            3U                                            /*!< DCB DHCSR: Mask interrupts control Position */ | ||||
| #define DCB_DHCSR_C_MASKINTS_Msk           (0x1UL << DCB_DHCSR_C_MASKINTS_Pos)            /*!< DCB DHCSR: Mask interrupts control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_STEP_Pos                2U                                            /*!< DCB DHCSR: Step control Position */ | ||||
| #define DCB_DHCSR_C_STEP_Msk               (0x1UL << DCB_DHCSR_C_STEP_Pos)                /*!< DCB DHCSR: Step control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_HALT_Pos                1U                                            /*!< DCB DHCSR: Halt control Position */ | ||||
| #define DCB_DHCSR_C_HALT_Msk               (0x1UL << DCB_DHCSR_C_HALT_Pos)                /*!< DCB DHCSR: Halt control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_DEBUGEN_Pos             0U                                            /*!< DCB DHCSR: Debug enable control Position */ | ||||
| #define DCB_DHCSR_C_DEBUGEN_Msk            (0x1UL /*<< DCB_DHCSR_C_DEBUGEN_Pos*/)         /*!< DCB DHCSR: Debug enable control Mask */ | ||||
|  | ||||
| /* DCRSR, Debug Core Register Select Register Definitions */ | ||||
| #define DCB_DCRSR_REGWnR_Pos               16U                                            /*!< DCB DCRSR: Register write/not-read Position */ | ||||
| #define DCB_DCRSR_REGWnR_Msk               (0x1UL << DCB_DCRSR_REGWnR_Pos)                /*!< DCB DCRSR: Register write/not-read Mask */ | ||||
|  | ||||
| #define DCB_DCRSR_REGSEL_Pos                0U                                            /*!< DCB DCRSR: Register selector Position */ | ||||
| #define DCB_DCRSR_REGSEL_Msk               (0x7FUL /*<< DCB_DCRSR_REGSEL_Pos*/)           /*!< DCB DCRSR: Register selector Mask */ | ||||
|  | ||||
| /* DCRDR, Debug Core Register Data Register Definitions */ | ||||
| #define DCB_DCRDR_DBGTMP_Pos                0U                                            /*!< DCB DCRDR: Data temporary buffer Position */ | ||||
| #define DCB_DCRDR_DBGTMP_Msk               (0xFFFFFFFFUL /*<< DCB_DCRDR_DBGTMP_Pos*/)     /*!< DCB DCRDR: Data temporary buffer Mask */ | ||||
|  | ||||
| /* DEMCR, Debug Exception and Monitor Control Register Definitions */ | ||||
| #define DCB_DEMCR_TRCENA_Pos               24U                                            /*!< DCB DEMCR: Trace enable Position */ | ||||
| #define DCB_DEMCR_TRCENA_Msk               (0x1UL << DCB_DEMCR_TRCENA_Pos)                /*!< DCB DEMCR: Trace enable Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_HARDERR_Pos           10U                                            /*!< DCB DEMCR: Vector Catch HardFault errors Position */ | ||||
| #define DCB_DEMCR_VC_HARDERR_Msk           (0x1UL << DCB_DEMCR_VC_HARDERR_Pos)            /*!< DCB DEMCR: Vector Catch HardFault errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_CORERESET_Pos          0U                                            /*!< DCB DEMCR: Vector Catch Core reset Position */ | ||||
| #define DCB_DEMCR_VC_CORERESET_Msk         (0x1UL /*<< DCB_DEMCR_VC_CORERESET_Pos*/)      /*!< DCB DEMCR: Vector Catch Core reset Mask */ | ||||
|  | ||||
| /* DAUTHCTRL, Debug Authentication Control Register Definitions */ | ||||
| #define DCB_DAUTHCTRL_INTSPNIDEN_Pos        3U                                            /*!< DCB DAUTHCTRL: Internal Secure non-invasive debug enable Position */ | ||||
| #define DCB_DAUTHCTRL_INTSPNIDEN_Msk       (0x1UL << DCB_DAUTHCTRL_INTSPNIDEN_Pos)        /*!< DCB DAUTHCTRL: Internal Secure non-invasive debug enable Mask */ | ||||
|  | ||||
| #define DCB_DAUTHCTRL_SPNIDENSEL_Pos        2U                                            /*!< DCB DAUTHCTRL: Secure non-invasive debug enable select Position */ | ||||
| #define DCB_DAUTHCTRL_SPNIDENSEL_Msk       (0x1UL << DCB_DAUTHCTRL_SPNIDENSEL_Pos)        /*!< DCB DAUTHCTRL: Secure non-invasive debug enable select Mask */ | ||||
|  | ||||
| #define DCB_DAUTHCTRL_INTSPIDEN_Pos         1U                                            /*!< DCB DAUTHCTRL: Internal Secure invasive debug enable Position */ | ||||
| #define DCB_DAUTHCTRL_INTSPIDEN_Msk        (0x1UL << DCB_DAUTHCTRL_INTSPIDEN_Pos)         /*!< DCB DAUTHCTRL: Internal Secure invasive debug enable Mask */ | ||||
|  | ||||
| #define DCB_DAUTHCTRL_SPIDENSEL_Pos         0U                                            /*!< DCB DAUTHCTRL: Secure invasive debug enable select Position */ | ||||
| #define DCB_DAUTHCTRL_SPIDENSEL_Msk        (0x1UL /*<< DCB_DAUTHCTRL_SPIDENSEL_Pos*/)     /*!< DCB DAUTHCTRL: Secure invasive debug enable select Mask */ | ||||
|  | ||||
| /* DSCSR, Debug Security Control and Status Register Definitions */ | ||||
| #define DCB_DSCSR_CDSKEY_Pos               17U                                            /*!< DCB DSCSR: CDS write-enable key Position */ | ||||
| #define DCB_DSCSR_CDSKEY_Msk               (0x1UL << DCB_DSCSR_CDSKEY_Pos)                /*!< DCB DSCSR: CDS write-enable key Mask */ | ||||
|  | ||||
| #define DCB_DSCSR_CDS_Pos                  16U                                            /*!< DCB DSCSR: Current domain Secure Position */ | ||||
| #define DCB_DSCSR_CDS_Msk                  (0x1UL << DCB_DSCSR_CDS_Pos)                   /*!< DCB DSCSR: Current domain Secure Mask */ | ||||
|  | ||||
| #define DCB_DSCSR_SBRSEL_Pos                1U                                            /*!< DCB DSCSR: Secure banked register select Position */ | ||||
| #define DCB_DSCSR_SBRSEL_Msk               (0x1UL << DCB_DSCSR_SBRSEL_Pos)                /*!< DCB DSCSR: Secure banked register select Mask */ | ||||
|  | ||||
| #define DCB_DSCSR_SBRSELEN_Pos              0U                                            /*!< DCB DSCSR: Secure banked register select enable Position */ | ||||
| #define DCB_DSCSR_SBRSELEN_Msk             (0x1UL /*<< DCB_DSCSR_SBRSELEN_Pos*/)          /*!< DCB DSCSR: Secure banked register select enable Mask */ | ||||
|  | ||||
| /*@} end of group CMSIS_DCB */ | ||||
|  | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup  CMSIS_core_register | ||||
|   \defgroup CMSIS_DIB       Debug Identification Block | ||||
|   \brief    Type definitions for the Debug Identification Block Registers | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief  Structure type to access the Debug Identification Block Registers (DIB). | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
|   __OM  uint32_t DLAR;                   /*!< Offset: 0x000 ( /W)  SCS Software Lock Access Register */ | ||||
|   __IM  uint32_t DLSR;                   /*!< Offset: 0x004 (R/ )  SCS Software Lock Status Register */ | ||||
|   __IM  uint32_t DAUTHSTATUS;            /*!< Offset: 0x008 (R/ )  Debug Authentication Status Register */ | ||||
|   __IM  uint32_t DDEVARCH;               /*!< Offset: 0x00C (R/ )  SCS Device Architecture Register */ | ||||
|   __IM  uint32_t DDEVTYPE;               /*!< Offset: 0x010 (R/ )  SCS Device Type Register */ | ||||
| } DIB_Type; | ||||
|  | ||||
| /* DLAR, SCS Software Lock Access Register Definitions */ | ||||
| #define DIB_DLAR_KEY_Pos                    0U                                            /*!< DIB DLAR: KEY Position */ | ||||
| #define DIB_DLAR_KEY_Msk                   (0xFFFFFFFFUL /*<< DIB_DLAR_KEY_Pos */)        /*!< DIB DLAR: KEY Mask */ | ||||
|  | ||||
| /* DLSR, SCS Software Lock Status Register Definitions */ | ||||
| #define DIB_DLSR_nTT_Pos                    2U                                            /*!< DIB DLSR: Not thirty-two bit Position */ | ||||
| #define DIB_DLSR_nTT_Msk                   (0x1UL << DIB_DLSR_nTT_Pos )                   /*!< DIB DLSR: Not thirty-two bit Mask */ | ||||
|  | ||||
| #define DIB_DLSR_SLK_Pos                    1U                                            /*!< DIB DLSR: Software Lock status Position */ | ||||
| #define DIB_DLSR_SLK_Msk                   (0x1UL << DIB_DLSR_SLK_Pos )                   /*!< DIB DLSR: Software Lock status Mask */ | ||||
|  | ||||
| #define DIB_DLSR_SLI_Pos                    0U                                            /*!< DIB DLSR: Software Lock implemented Position */ | ||||
| #define DIB_DLSR_SLI_Msk                   (0x1UL /*<< DIB_DLSR_SLI_Pos*/)                /*!< DIB DLSR: Software Lock implemented Mask */ | ||||
|  | ||||
| /* DAUTHSTATUS, Debug Authentication Status Register Definitions */ | ||||
| #define DIB_DAUTHSTATUS_SNID_Pos            6U                                            /*!< DIB DAUTHSTATUS: Secure Non-invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_SNID_Msk           (0x3UL << DIB_DAUTHSTATUS_SNID_Pos )           /*!< DIB DAUTHSTATUS: Secure Non-invasive Debug Mask */ | ||||
|  | ||||
| #define DIB_DAUTHSTATUS_SID_Pos             4U                                            /*!< DIB DAUTHSTATUS: Secure Invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_SID_Msk            (0x3UL << DIB_DAUTHSTATUS_SID_Pos )            /*!< DIB DAUTHSTATUS: Secure Invasive Debug Mask */ | ||||
|  | ||||
| #define DIB_DAUTHSTATUS_NSNID_Pos           2U                                            /*!< DIB DAUTHSTATUS: Non-secure Non-invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_NSNID_Msk          (0x3UL << DIB_DAUTHSTATUS_NSNID_Pos )          /*!< DIB DAUTHSTATUS: Non-secure Non-invasive Debug Mask */ | ||||
|  | ||||
| #define DIB_DAUTHSTATUS_NSID_Pos            0U                                            /*!< DIB DAUTHSTATUS: Non-secure Invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_NSID_Msk           (0x3UL /*<< DIB_DAUTHSTATUS_NSID_Pos*/)        /*!< DIB DAUTHSTATUS: Non-secure Invasive Debug Mask */ | ||||
|  | ||||
| /* DDEVARCH, SCS Device Architecture Register Definitions */ | ||||
| #define DIB_DDEVARCH_ARCHITECT_Pos         21U                                            /*!< DIB DDEVARCH: Architect Position */ | ||||
| #define DIB_DDEVARCH_ARCHITECT_Msk         (0x7FFUL << DIB_DDEVARCH_ARCHITECT_Pos )       /*!< DIB DDEVARCH: Architect Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_PRESENT_Pos           20U                                            /*!< DIB DDEVARCH: DEVARCH Present Position */ | ||||
| #define DIB_DDEVARCH_PRESENT_Msk           (0x1FUL << DIB_DDEVARCH_PRESENT_Pos )          /*!< DIB DDEVARCH: DEVARCH Present Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_REVISION_Pos          16U                                            /*!< DIB DDEVARCH: Revision Position */ | ||||
| #define DIB_DDEVARCH_REVISION_Msk          (0xFUL << DIB_DDEVARCH_REVISION_Pos )          /*!< DIB DDEVARCH: Revision Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_ARCHVER_Pos           12U                                            /*!< DIB DDEVARCH: Architecture Version Position */ | ||||
| #define DIB_DDEVARCH_ARCHVER_Msk           (0xFUL << DIB_DDEVARCH_ARCHVER_Pos )           /*!< DIB DDEVARCH: Architecture Version Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_ARCHPART_Pos           0U                                            /*!< DIB DDEVARCH: Architecture Part Position */ | ||||
| #define DIB_DDEVARCH_ARCHPART_Msk          (0xFFFUL /*<< DIB_DDEVARCH_ARCHPART_Pos*/)     /*!< DIB DDEVARCH: Architecture Part Mask */ | ||||
|  | ||||
| /* DDEVTYPE, SCS Device Type Register Definitions */ | ||||
| #define DIB_DDEVTYPE_SUB_Pos                4U                                            /*!< DIB DDEVTYPE: Sub-type Position */ | ||||
| #define DIB_DDEVTYPE_SUB_Msk               (0xFUL << DIB_DDEVTYPE_SUB_Pos )               /*!< DIB DDEVTYPE: Sub-type Mask */ | ||||
|  | ||||
| #define DIB_DDEVTYPE_MAJOR_Pos              0U                                            /*!< DIB DDEVTYPE: Major type Position */ | ||||
| #define DIB_DDEVTYPE_MAJOR_Msk             (0xFUL /*<< DIB_DDEVTYPE_MAJOR_Pos*/)          /*!< DIB DDEVTYPE: Major type Mask */ | ||||
|  | ||||
|  | ||||
| /*@} end of group CMSIS_DIB */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup    CMSIS_core_register | ||||
|   \defgroup   CMSIS_core_bitfield     Core register bit field macros | ||||
| @@ -1376,9 +1188,7 @@ typedef struct | ||||
|   #define SCS_BASE            (0xE000E000UL)                             /*!< System Control Space Base Address */ | ||||
|   #define DWT_BASE            (0xE0001000UL)                             /*!< DWT Base Address */ | ||||
|   #define TPI_BASE            (0xE0040000UL)                             /*!< TPI Base Address */ | ||||
|   #define CoreDebug_BASE      (0xE000EDF0UL)                             /*!< \deprecated Core Debug Base Address */ | ||||
|   #define DCB_BASE            (0xE000EDF0UL)                             /*!< DCB Base Address */ | ||||
|   #define DIB_BASE            (0xE000EFB0UL)                             /*!< DIB Base Address */ | ||||
|   #define CoreDebug_BASE      (0xE000EDF0UL)                             /*!< Core Debug Base Address */ | ||||
|   #define SysTick_BASE        (SCS_BASE +  0x0010UL)                     /*!< SysTick Base Address */ | ||||
|   #define NVIC_BASE           (SCS_BASE +  0x0100UL)                     /*!< NVIC Base Address */ | ||||
|   #define SCB_BASE            (SCS_BASE +  0x0D00UL)                     /*!< System Control Block Base Address */ | ||||
| @@ -1389,9 +1199,7 @@ typedef struct | ||||
|   #define NVIC                ((NVIC_Type      *)     NVIC_BASE        ) /*!< NVIC configuration struct */ | ||||
|   #define DWT                 ((DWT_Type       *)     DWT_BASE         ) /*!< DWT configuration struct */ | ||||
|   #define TPI                 ((TPI_Type       *)     TPI_BASE         ) /*!< TPI configuration struct */ | ||||
|   #define CoreDebug           ((CoreDebug_Type *)     CoreDebug_BASE   ) /*!< \deprecated Core Debug configuration struct */ | ||||
|   #define DCB                 ((DCB_Type       *)     DCB_BASE         ) /*!< DCB configuration struct */ | ||||
|   #define DIB                 ((DIB_Type       *)     DIB_BASE         ) /*!< DIB configuration struct */ | ||||
|   #define CoreDebug           ((CoreDebug_Type *)     CoreDebug_BASE   ) /*!< Core Debug configuration struct */ | ||||
|  | ||||
|   #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) | ||||
|     #define MPU_BASE          (SCS_BASE +  0x0D90UL)                     /*!< Memory Protection Unit */ | ||||
| @@ -1405,9 +1213,7 @@ typedef struct | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
|   #define SCS_BASE_NS         (0xE002E000UL)                             /*!< System Control Space Base Address (non-secure address space) */ | ||||
|   #define CoreDebug_BASE_NS   (0xE002EDF0UL)                             /*!< \deprecated Core Debug Base Address           (non-secure address space) */ | ||||
|   #define DCB_BASE_NS         (0xE002EDF0UL)                             /*!< DCB Base Address                  (non-secure address space) */ | ||||
|   #define DIB_BASE_NS         (0xE002EFB0UL)                             /*!< DIB Base Address                  (non-secure address space) */ | ||||
|   #define CoreDebug_BASE_NS   (0xE002EDF0UL)                             /*!< Core Debug Base Address           (non-secure address space) */ | ||||
|   #define SysTick_BASE_NS     (SCS_BASE_NS +  0x0010UL)                  /*!< SysTick Base Address              (non-secure address space) */ | ||||
|   #define NVIC_BASE_NS        (SCS_BASE_NS +  0x0100UL)                  /*!< NVIC Base Address                 (non-secure address space) */ | ||||
|   #define SCB_BASE_NS         (SCS_BASE_NS +  0x0D00UL)                  /*!< System Control Block Base Address (non-secure address space) */ | ||||
| @@ -1415,9 +1221,7 @@ typedef struct | ||||
|   #define SCB_NS              ((SCB_Type       *)     SCB_BASE_NS      ) /*!< SCB configuration struct          (non-secure address space) */ | ||||
|   #define SysTick_NS          ((SysTick_Type   *)     SysTick_BASE_NS  ) /*!< SysTick configuration struct      (non-secure address space) */ | ||||
|   #define NVIC_NS             ((NVIC_Type      *)     NVIC_BASE_NS     ) /*!< NVIC configuration struct         (non-secure address space) */ | ||||
|   #define CoreDebug_NS        ((CoreDebug_Type *)     CoreDebug_BASE_NS) /*!< \deprecated Core Debug configuration struct   (non-secure address space) */ | ||||
|   #define DCB_NS              ((DCB_Type       *)     DCB_BASE_NS      ) /*!< DCB configuration struct          (non-secure address space) */ | ||||
|   #define DIB_NS              ((DIB_Type       *)     DIB_BASE_NS      ) /*!< DIB configuration struct          (non-secure address space) */ | ||||
|   #define CoreDebug_NS        ((CoreDebug_Type *)     CoreDebug_BASE_NS) /*!< Core Debug configuration struct   (non-secure address space) */ | ||||
|  | ||||
|   #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) | ||||
|     #define MPU_BASE_NS       (SCS_BASE_NS +  0x0D90UL)                  /*!< Memory Protection Unit            (non-secure address space) */ | ||||
| @@ -1434,7 +1238,6 @@ typedef struct | ||||
|   Core Function Interface contains: | ||||
|   - Core NVIC Functions | ||||
|   - Core SysTick Functions | ||||
|   - Core Debug Functions | ||||
|   - Core Register Access Functions | ||||
|  ******************************************************************************/ | ||||
| /** | ||||
| @@ -2110,110 +1913,6 @@ __STATIC_INLINE void TZ_SAU_Disable(void) | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    Debug Control function  ############################################ */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   \defgroup CMSIS_Core_DCBFunctions Debug Control Functions | ||||
|   \brief    Functions that access the Debug Control Block. | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
|   | ||||
| /** | ||||
|   \brief   Set Debug Authentication Control Register | ||||
|   \details writes to Debug Authentication Control register. | ||||
|   \param [in]  value  value to be writen. | ||||
|  */ | ||||
| __STATIC_INLINE void DCB_SetAuthCtrl(uint32_t value) | ||||
| { | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     DCB->DAUTHCTRL = value; | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Debug Authentication Control Register | ||||
|   \details Reads Debug Authentication Control register. | ||||
|   \return             Debug Authentication Control Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t DCB_GetAuthCtrl(void) | ||||
| { | ||||
|     return (DCB->DAUTHCTRL); | ||||
| } | ||||
|  | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
| /** | ||||
|   \brief   Set Debug Authentication Control Register (non-secure) | ||||
|   \details writes to non-secure Debug Authentication Control register when in secure state. | ||||
|   \param [in]  value  value to be writen | ||||
|  */ | ||||
| __STATIC_INLINE void TZ_DCB_SetAuthCtrl_NS(uint32_t value) | ||||
| { | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     DCB_NS->DAUTHCTRL = value; | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Debug Authentication Control Register (non-secure) | ||||
|   \details Reads non-secure Debug Authentication Control register when in secure state. | ||||
|   \return             Debug Authentication Control Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t TZ_DCB_GetAuthCtrl_NS(void) | ||||
| { | ||||
|     return (DCB_NS->DAUTHCTRL); | ||||
| } | ||||
| #endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ | ||||
|  | ||||
| /*@} end of CMSIS_Core_DCBFunctions */ | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    Debug Identification function  ############################################ */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   \defgroup CMSIS_Core_DIBFunctions Debug Identification Functions | ||||
|   \brief    Functions that access the Debug Identification Block. | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
|   | ||||
| /** | ||||
|   \brief   Get Debug Authentication Status Register | ||||
|   \details Reads Debug Authentication Status register. | ||||
|   \return             Debug Authentication Status Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t DIB_GetAuthStatus(void) | ||||
| { | ||||
|     return (DIB->DAUTHSTATUS); | ||||
| } | ||||
|  | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
| /** | ||||
|   \brief   Get Debug Authentication Status Register (non-secure) | ||||
|   \details Reads non-secure Debug Authentication Status register when in secure state. | ||||
|   \return             Debug Authentication Status Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t TZ_DIB_GetAuthStatus_NS(void) | ||||
| { | ||||
|     return (DIB_NS->DAUTHSTATUS); | ||||
| } | ||||
| #endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ | ||||
|  | ||||
| /*@} end of CMSIS_Core_DCBFunctions */ | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    SysTick function  ############################################ */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
| /**************************************************************************//** | ||||
|  * @file     core_cm3.h | ||||
|  * @brief    CMSIS Cortex-M3 Core Peripheral Access Layer Header File | ||||
|  * @version  V5.1.2 | ||||
|  * @date     04. June 2021 | ||||
|  * @version  V5.1.0 | ||||
|  * @date     13. March 2019 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2009-2021 Arm Limited. All rights reserved. | ||||
|  * Copyright (c) 2009-2019 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
| @@ -142,11 +142,6 @@ | ||||
|     #warning "__MPU_PRESENT not defined in device header file; using default!" | ||||
|   #endif | ||||
|  | ||||
|   #ifndef __VTOR_PRESENT | ||||
|     #define __VTOR_PRESENT             1U | ||||
|     #warning "__VTOR_PRESENT not defined in device header file; using default!" | ||||
|   #endif | ||||
|  | ||||
|   #ifndef __NVIC_PRIO_BITS | ||||
|     #define __NVIC_PRIO_BITS          3U | ||||
|     #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" | ||||
| @@ -565,19 +560,19 @@ typedef struct | ||||
| #define SCB_CFSR_MEMFAULTSR_Msk            (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/)        /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ | ||||
|  | ||||
| /* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ | ||||
| #define SCB_CFSR_MMARVALID_Pos             (SCB_CFSR_MEMFAULTSR_Pos + 7U)                 /*!< SCB CFSR (MMFSR): MMARVALID Position */ | ||||
| #define SCB_CFSR_MMARVALID_Pos             (SCB_SHCSR_MEMFAULTACT_Pos + 7U)               /*!< SCB CFSR (MMFSR): MMARVALID Position */ | ||||
| #define SCB_CFSR_MMARVALID_Msk             (1UL << SCB_CFSR_MMARVALID_Pos)                /*!< SCB CFSR (MMFSR): MMARVALID Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MSTKERR_Pos               (SCB_CFSR_MEMFAULTSR_Pos + 4U)                 /*!< SCB CFSR (MMFSR): MSTKERR Position */ | ||||
| #define SCB_CFSR_MSTKERR_Pos               (SCB_SHCSR_MEMFAULTACT_Pos + 4U)               /*!< SCB CFSR (MMFSR): MSTKERR Position */ | ||||
| #define SCB_CFSR_MSTKERR_Msk               (1UL << SCB_CFSR_MSTKERR_Pos)                  /*!< SCB CFSR (MMFSR): MSTKERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MUNSTKERR_Pos             (SCB_CFSR_MEMFAULTSR_Pos + 3U)                 /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ | ||||
| #define SCB_CFSR_MUNSTKERR_Pos             (SCB_SHCSR_MEMFAULTACT_Pos + 3U)               /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ | ||||
| #define SCB_CFSR_MUNSTKERR_Msk             (1UL << SCB_CFSR_MUNSTKERR_Pos)                /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_DACCVIOL_Pos              (SCB_CFSR_MEMFAULTSR_Pos + 1U)                 /*!< SCB CFSR (MMFSR): DACCVIOL Position */ | ||||
| #define SCB_CFSR_DACCVIOL_Pos              (SCB_SHCSR_MEMFAULTACT_Pos + 1U)               /*!< SCB CFSR (MMFSR): DACCVIOL Position */ | ||||
| #define SCB_CFSR_DACCVIOL_Msk              (1UL << SCB_CFSR_DACCVIOL_Pos)                 /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ | ||||
|  | ||||
| #define SCB_CFSR_IACCVIOL_Pos              (SCB_CFSR_MEMFAULTSR_Pos + 0U)                 /*!< SCB CFSR (MMFSR): IACCVIOL Position */ | ||||
| #define SCB_CFSR_IACCVIOL_Pos              (SCB_SHCSR_MEMFAULTACT_Pos + 0U)               /*!< SCB CFSR (MMFSR): IACCVIOL Position */ | ||||
| #define SCB_CFSR_IACCVIOL_Msk              (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/)             /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ | ||||
|  | ||||
| /* BusFault Status Register (part of SCB Configurable Fault Status Register) */ | ||||
| @@ -1734,8 +1729,8 @@ __STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGr | ||||
|  */ | ||||
| __STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) | ||||
| { | ||||
|   uint32_t *vectors = (uint32_t *)SCB->VTOR; | ||||
|   vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; | ||||
|   uint32_t vectors = (uint32_t )SCB->VTOR; | ||||
|   (* (int *) (vectors + ((int32_t)IRQn + NVIC_USER_IRQ_OFFSET) * 4)) = vector; | ||||
|   /* ARM Application Note 321 states that the M3 does not require the architectural barrier */ | ||||
| } | ||||
|  | ||||
| @@ -1750,8 +1745,8 @@ __STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) | ||||
| { | ||||
|   uint32_t *vectors = (uint32_t *)SCB->VTOR; | ||||
|   return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; | ||||
|   uint32_t vectors = (uint32_t )SCB->VTOR; | ||||
|   return (uint32_t)(* (int *) (vectors + ((int32_t)IRQn + NVIC_USER_IRQ_OFFSET) * 4)); | ||||
| } | ||||
|  | ||||
|  | ||||
| @@ -1776,7 +1771,6 @@ __NO_RETURN __STATIC_INLINE void __NVIC_SystemReset(void) | ||||
|  | ||||
| /*@} end of CMSIS_Core_NVICFunctions */ | ||||
|  | ||||
|  | ||||
| /* ##########################  MPU functions  #################################### */ | ||||
|  | ||||
| #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
| /**************************************************************************//** | ||||
|  * @file     core_cm33.h | ||||
|  * @brief    CMSIS Cortex-M33 Core Peripheral Access Layer Header File | ||||
|  * @version  V5.2.3 | ||||
|  * @date     13. October 2021 | ||||
|  * @version  V5.1.0 | ||||
|  * @date     12. November 2018 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2009-2021 Arm Limited. All rights reserved. | ||||
|  * Copyright (c) 2009-2018 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
| @@ -26,8 +26,6 @@ | ||||
|   #pragma system_include         /* treat file as system include file for MISRA check */ | ||||
| #elif defined (__clang__) | ||||
|   #pragma clang system_header   /* treat file as system include file */ | ||||
| #elif defined ( __GNUC__ ) | ||||
|   #pragma GCC diagnostic ignored "-Wpedantic"   /* disable pedantic warning due to unnamed structs/unions */ | ||||
| #endif | ||||
|  | ||||
| #ifndef __CORE_CM33_H_GENERIC | ||||
| @@ -250,11 +248,6 @@ | ||||
|     #warning "__DSP_PRESENT not defined in device header file; using default!" | ||||
|   #endif | ||||
|  | ||||
|   #ifndef __VTOR_PRESENT | ||||
|     #define __VTOR_PRESENT             1U | ||||
|     #warning "__VTOR_PRESENT not defined in device header file; using default!" | ||||
|   #endif | ||||
|  | ||||
|   #ifndef __NVIC_PRIO_BITS | ||||
|     #define __NVIC_PRIO_BITS          3U | ||||
|     #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" | ||||
| @@ -519,7 +512,7 @@ typedef struct | ||||
|   __IOM uint32_t AFSR;                   /*!< Offset: 0x03C (R/W)  Auxiliary Fault Status Register */ | ||||
|   __IM  uint32_t ID_PFR[2U];             /*!< Offset: 0x040 (R/ )  Processor Feature Register */ | ||||
|   __IM  uint32_t ID_DFR;                 /*!< Offset: 0x048 (R/ )  Debug Feature Register */ | ||||
|   __IM  uint32_t ID_AFR;                 /*!< Offset: 0x04C (R/ )  Auxiliary Feature Register */ | ||||
|   __IM  uint32_t ID_ADR;                 /*!< Offset: 0x04C (R/ )  Auxiliary Feature Register */ | ||||
|   __IM  uint32_t ID_MMFR[4U];            /*!< Offset: 0x050 (R/ )  Memory Model Feature Register */ | ||||
|   __IM  uint32_t ID_ISAR[6U];            /*!< Offset: 0x060 (R/ )  Instruction Set Attributes Register */ | ||||
|   __IM  uint32_t CLIDR;                  /*!< Offset: 0x078 (R/ )  Cache Level ID register */ | ||||
| @@ -528,10 +521,7 @@ typedef struct | ||||
|   __IOM uint32_t CSSELR;                 /*!< Offset: 0x084 (R/W)  Cache Size Selection Register */ | ||||
|   __IOM uint32_t CPACR;                  /*!< Offset: 0x088 (R/W)  Coprocessor Access Control Register */ | ||||
|   __IOM uint32_t NSACR;                  /*!< Offset: 0x08C (R/W)  Non-Secure Access Control Register */ | ||||
|         uint32_t RESERVED7[21U]; | ||||
|   __IOM uint32_t SFSR;                   /*!< Offset: 0x0E4 (R/W)  Secure Fault Status Register */ | ||||
|   __IOM uint32_t SFAR;                   /*!< Offset: 0x0E8 (R/W)  Secure Fault Address Register */ | ||||
|         uint32_t RESERVED3[69U]; | ||||
|         uint32_t RESERVED3[92U]; | ||||
|   __OM  uint32_t STIR;                   /*!< Offset: 0x200 ( /W)  Software Triggered Interrupt Register */ | ||||
|         uint32_t RESERVED4[15U]; | ||||
|   __IM  uint32_t MVFR0;                  /*!< Offset: 0x240 (R/ )  Media and VFP Feature Register 0 */ | ||||
| @@ -548,7 +538,6 @@ typedef struct | ||||
|   __OM  uint32_t DCCSW;                  /*!< Offset: 0x26C ( /W)  D-Cache Clean by Set-way */ | ||||
|   __OM  uint32_t DCCIMVAC;               /*!< Offset: 0x270 ( /W)  D-Cache Clean and Invalidate by MVA to PoC */ | ||||
|   __OM  uint32_t DCCISW;                 /*!< Offset: 0x274 ( /W)  D-Cache Clean and Invalidate by Set-way */ | ||||
|   __OM  uint32_t BPIALL;                 /*!< Offset: 0x278 ( /W)  Branch Predictor Invalidate All */ | ||||
| } SCB_Type; | ||||
|  | ||||
| /* SCB CPUID Register Definitions */ | ||||
| @@ -749,22 +738,22 @@ typedef struct | ||||
| #define SCB_CFSR_MEMFAULTSR_Msk            (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/)        /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ | ||||
|  | ||||
| /* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ | ||||
| #define SCB_CFSR_MMARVALID_Pos             (SCB_CFSR_MEMFAULTSR_Pos + 7U)                 /*!< SCB CFSR (MMFSR): MMARVALID Position */ | ||||
| #define SCB_CFSR_MMARVALID_Pos             (SCB_SHCSR_MEMFAULTACT_Pos + 7U)               /*!< SCB CFSR (MMFSR): MMARVALID Position */ | ||||
| #define SCB_CFSR_MMARVALID_Msk             (1UL << SCB_CFSR_MMARVALID_Pos)                /*!< SCB CFSR (MMFSR): MMARVALID Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MLSPERR_Pos               (SCB_CFSR_MEMFAULTSR_Pos + 5U)                 /*!< SCB CFSR (MMFSR): MLSPERR Position */ | ||||
| #define SCB_CFSR_MLSPERR_Pos               (SCB_SHCSR_MEMFAULTACT_Pos + 5U)               /*!< SCB CFSR (MMFSR): MLSPERR Position */ | ||||
| #define SCB_CFSR_MLSPERR_Msk               (1UL << SCB_CFSR_MLSPERR_Pos)                  /*!< SCB CFSR (MMFSR): MLSPERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MSTKERR_Pos               (SCB_CFSR_MEMFAULTSR_Pos + 4U)                 /*!< SCB CFSR (MMFSR): MSTKERR Position */ | ||||
| #define SCB_CFSR_MSTKERR_Pos               (SCB_SHCSR_MEMFAULTACT_Pos + 4U)               /*!< SCB CFSR (MMFSR): MSTKERR Position */ | ||||
| #define SCB_CFSR_MSTKERR_Msk               (1UL << SCB_CFSR_MSTKERR_Pos)                  /*!< SCB CFSR (MMFSR): MSTKERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MUNSTKERR_Pos             (SCB_CFSR_MEMFAULTSR_Pos + 3U)                 /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ | ||||
| #define SCB_CFSR_MUNSTKERR_Pos             (SCB_SHCSR_MEMFAULTACT_Pos + 3U)               /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ | ||||
| #define SCB_CFSR_MUNSTKERR_Msk             (1UL << SCB_CFSR_MUNSTKERR_Pos)                /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_DACCVIOL_Pos              (SCB_CFSR_MEMFAULTSR_Pos + 1U)                 /*!< SCB CFSR (MMFSR): DACCVIOL Position */ | ||||
| #define SCB_CFSR_DACCVIOL_Pos              (SCB_SHCSR_MEMFAULTACT_Pos + 1U)               /*!< SCB CFSR (MMFSR): DACCVIOL Position */ | ||||
| #define SCB_CFSR_DACCVIOL_Msk              (1UL << SCB_CFSR_DACCVIOL_Pos)                 /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ | ||||
|  | ||||
| #define SCB_CFSR_IACCVIOL_Pos              (SCB_CFSR_MEMFAULTSR_Pos + 0U)                 /*!< SCB CFSR (MMFSR): IACCVIOL Position */ | ||||
| #define SCB_CFSR_IACCVIOL_Pos              (SCB_SHCSR_MEMFAULTACT_Pos + 0U)               /*!< SCB CFSR (MMFSR): IACCVIOL Position */ | ||||
| #define SCB_CFSR_IACCVIOL_Msk              (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/)             /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ | ||||
|  | ||||
| /* BusFault Status Register (part of SCB Configurable Fault Status Register) */ | ||||
| @@ -1679,9 +1668,8 @@ typedef struct | ||||
|   __IOM uint32_t FPCCR;                  /*!< Offset: 0x004 (R/W)  Floating-Point Context Control Register */ | ||||
|   __IOM uint32_t FPCAR;                  /*!< Offset: 0x008 (R/W)  Floating-Point Context Address Register */ | ||||
|   __IOM uint32_t FPDSCR;                 /*!< Offset: 0x00C (R/W)  Floating-Point Default Status Control Register */ | ||||
|   __IM  uint32_t MVFR0;                  /*!< Offset: 0x010 (R/ )  Media and VFP Feature Register 0 */ | ||||
|   __IM  uint32_t MVFR1;                  /*!< Offset: 0x014 (R/ )  Media and VFP Feature Register 1 */ | ||||
|   __IM  uint32_t MVFR2;                  /*!< Offset: 0x018 (R/ )  Media and VFP Feature Register 2 */ | ||||
|   __IM  uint32_t MVFR0;                  /*!< Offset: 0x010 (R/ )  Media and FP Feature Register 0 */ | ||||
|   __IM  uint32_t MVFR1;                  /*!< Offset: 0x014 (R/ )  Media and FP Feature Register 1 */ | ||||
| } FPU_Type; | ||||
|  | ||||
| /* Floating-Point Context Control Register Definitions */ | ||||
| @@ -1753,7 +1741,7 @@ typedef struct | ||||
| #define FPU_FPDSCR_RMode_Pos               22U                                            /*!< FPDSCR: RMode bit Position */ | ||||
| #define FPU_FPDSCR_RMode_Msk               (3UL << FPU_FPDSCR_RMode_Pos)                  /*!< FPDSCR: RMode bit Mask */ | ||||
|  | ||||
| /* Media and VFP Feature Register 0 Definitions */ | ||||
| /* Media and FP Feature Register 0 Definitions */ | ||||
| #define FPU_MVFR0_FP_rounding_modes_Pos    28U                                            /*!< MVFR0: FP rounding modes bits Position */ | ||||
| #define FPU_MVFR0_FP_rounding_modes_Msk    (0xFUL << FPU_MVFR0_FP_rounding_modes_Pos)     /*!< MVFR0: FP rounding modes bits Mask */ | ||||
|  | ||||
| @@ -1778,7 +1766,7 @@ typedef struct | ||||
| #define FPU_MVFR0_A_SIMD_registers_Pos      0U                                            /*!< MVFR0: A_SIMD registers bits Position */ | ||||
| #define FPU_MVFR0_A_SIMD_registers_Msk     (0xFUL /*<< FPU_MVFR0_A_SIMD_registers_Pos*/)  /*!< MVFR0: A_SIMD registers bits Mask */ | ||||
|  | ||||
| /* Media and VFP Feature Register 1 Definitions */ | ||||
| /* Media and FP Feature Register 1 Definitions */ | ||||
| #define FPU_MVFR1_FP_fused_MAC_Pos         28U                                            /*!< MVFR1: FP fused MAC bits Position */ | ||||
| #define FPU_MVFR1_FP_fused_MAC_Msk         (0xFUL << FPU_MVFR1_FP_fused_MAC_Pos)          /*!< MVFR1: FP fused MAC bits Mask */ | ||||
|  | ||||
| @@ -1791,13 +1779,9 @@ typedef struct | ||||
| #define FPU_MVFR1_FtZ_mode_Pos              0U                                            /*!< MVFR1: FtZ mode bits Position */ | ||||
| #define FPU_MVFR1_FtZ_mode_Msk             (0xFUL /*<< FPU_MVFR1_FtZ_mode_Pos*/)          /*!< MVFR1: FtZ mode bits Mask */ | ||||
|  | ||||
| /* Media and VFP Feature Register 2 Definitions */ | ||||
| #define FPU_MVFR2_FPMisc_Pos                4U                                            /*!< MVFR2: FPMisc bits Position */ | ||||
| #define FPU_MVFR2_FPMisc_Msk               (0xFUL << FPU_MVFR2_FPMisc_Pos)                /*!< MVFR2: FPMisc bits Mask */ | ||||
|  | ||||
| /*@} end of group CMSIS_FPU */ | ||||
|  | ||||
| /* CoreDebug is deprecated. replaced by DCB (Debug Control Block) */ | ||||
|  | ||||
| /** | ||||
|   \ingroup  CMSIS_core_register | ||||
|   \defgroup CMSIS_CoreDebug       Core Debug Registers (CoreDebug) | ||||
| @@ -1806,7 +1790,7 @@ typedef struct | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief  \deprecated Structure type to access the Core Debug Register (CoreDebug). | ||||
|   \brief  Structure type to access the Core Debug Register (CoreDebug). | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
| @@ -1814,354 +1798,124 @@ typedef struct | ||||
|   __OM  uint32_t DCRSR;                  /*!< Offset: 0x004 ( /W)  Debug Core Register Selector Register */ | ||||
|   __IOM uint32_t DCRDR;                  /*!< Offset: 0x008 (R/W)  Debug Core Register Data Register */ | ||||
|   __IOM uint32_t DEMCR;                  /*!< Offset: 0x00C (R/W)  Debug Exception and Monitor Control Register */ | ||||
|         uint32_t RESERVED0[1U]; | ||||
|         uint32_t RESERVED4[1U]; | ||||
|   __IOM uint32_t DAUTHCTRL;              /*!< Offset: 0x014 (R/W)  Debug Authentication Control Register */ | ||||
|   __IOM uint32_t DSCSR;                  /*!< Offset: 0x018 (R/W)  Debug Security Control and Status Register */ | ||||
| } CoreDebug_Type; | ||||
|  | ||||
| /* Debug Halting Control and Status Register Definitions */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Pos         16U                                            /*!< \deprecated CoreDebug DHCSR: DBGKEY Position */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Msk         (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos)       /*!< \deprecated CoreDebug DHCSR: DBGKEY Mask */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Pos         16U                                            /*!< CoreDebug DHCSR: DBGKEY Position */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Msk         (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos)       /*!< CoreDebug DHCSR: DBGKEY Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Pos   26U                                            /*!< \deprecated CoreDebug DHCSR: S_RESTART_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Msk   (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos)      /*!< \deprecated CoreDebug DHCSR: S_RESTART_ST Mask */ | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Pos   26U                                            /*!< CoreDebug DHCSR: S_RESTART_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Msk   (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos)      /*!< CoreDebug DHCSR: S_RESTART_ST Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Pos     25U                                            /*!< \deprecated CoreDebug DHCSR: S_RESET_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Msk     (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos)        /*!< \deprecated CoreDebug DHCSR: S_RESET_ST Mask */ | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Pos     25U                                            /*!< CoreDebug DHCSR: S_RESET_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Msk     (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos)        /*!< CoreDebug DHCSR: S_RESET_ST Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Pos    24U                                            /*!< \deprecated CoreDebug DHCSR: S_RETIRE_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Msk    (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos)       /*!< \deprecated CoreDebug DHCSR: S_RETIRE_ST Mask */ | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Pos    24U                                            /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Msk    (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos)       /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Pos       19U                                            /*!< \deprecated CoreDebug DHCSR: S_LOCKUP Position */ | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Msk       (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos)          /*!< \deprecated CoreDebug DHCSR: S_LOCKUP Mask */ | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Pos       19U                                            /*!< CoreDebug DHCSR: S_LOCKUP Position */ | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Msk       (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos)          /*!< CoreDebug DHCSR: S_LOCKUP Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Pos        18U                                            /*!< \deprecated CoreDebug DHCSR: S_SLEEP Position */ | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Msk        (1UL << CoreDebug_DHCSR_S_SLEEP_Pos)           /*!< \deprecated CoreDebug DHCSR: S_SLEEP Mask */ | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Pos        18U                                            /*!< CoreDebug DHCSR: S_SLEEP Position */ | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Msk        (1UL << CoreDebug_DHCSR_S_SLEEP_Pos)           /*!< CoreDebug DHCSR: S_SLEEP Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_HALT_Pos         17U                                            /*!< \deprecated CoreDebug DHCSR: S_HALT Position */ | ||||
| #define CoreDebug_DHCSR_S_HALT_Msk         (1UL << CoreDebug_DHCSR_S_HALT_Pos)            /*!< \deprecated CoreDebug DHCSR: S_HALT Mask */ | ||||
| #define CoreDebug_DHCSR_S_HALT_Pos         17U                                            /*!< CoreDebug DHCSR: S_HALT Position */ | ||||
| #define CoreDebug_DHCSR_S_HALT_Msk         (1UL << CoreDebug_DHCSR_S_HALT_Pos)            /*!< CoreDebug DHCSR: S_HALT Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Pos       16U                                            /*!< \deprecated CoreDebug DHCSR: S_REGRDY Position */ | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Msk       (1UL << CoreDebug_DHCSR_S_REGRDY_Pos)          /*!< \deprecated CoreDebug DHCSR: S_REGRDY Mask */ | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Pos       16U                                            /*!< CoreDebug DHCSR: S_REGRDY Position */ | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Msk       (1UL << CoreDebug_DHCSR_S_REGRDY_Pos)          /*!< CoreDebug DHCSR: S_REGRDY Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_SNAPSTALL_Pos     5U                                            /*!< \deprecated CoreDebug DHCSR: C_SNAPSTALL Position */ | ||||
| #define CoreDebug_DHCSR_C_SNAPSTALL_Msk    (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos)       /*!< \deprecated CoreDebug DHCSR: C_SNAPSTALL Mask */ | ||||
| #define CoreDebug_DHCSR_C_SNAPSTALL_Pos     5U                                            /*!< CoreDebug DHCSR: C_SNAPSTALL Position */ | ||||
| #define CoreDebug_DHCSR_C_SNAPSTALL_Msk    (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos)       /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Pos      3U                                            /*!< \deprecated CoreDebug DHCSR: C_MASKINTS Position */ | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Msk     (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos)        /*!< \deprecated CoreDebug DHCSR: C_MASKINTS Mask */ | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Pos      3U                                            /*!< CoreDebug DHCSR: C_MASKINTS Position */ | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Msk     (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos)        /*!< CoreDebug DHCSR: C_MASKINTS Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_STEP_Pos          2U                                            /*!< \deprecated CoreDebug DHCSR: C_STEP Position */ | ||||
| #define CoreDebug_DHCSR_C_STEP_Msk         (1UL << CoreDebug_DHCSR_C_STEP_Pos)            /*!< \deprecated CoreDebug DHCSR: C_STEP Mask */ | ||||
| #define CoreDebug_DHCSR_C_STEP_Pos          2U                                            /*!< CoreDebug DHCSR: C_STEP Position */ | ||||
| #define CoreDebug_DHCSR_C_STEP_Msk         (1UL << CoreDebug_DHCSR_C_STEP_Pos)            /*!< CoreDebug DHCSR: C_STEP Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_HALT_Pos          1U                                            /*!< \deprecated CoreDebug DHCSR: C_HALT Position */ | ||||
| #define CoreDebug_DHCSR_C_HALT_Msk         (1UL << CoreDebug_DHCSR_C_HALT_Pos)            /*!< \deprecated CoreDebug DHCSR: C_HALT Mask */ | ||||
| #define CoreDebug_DHCSR_C_HALT_Pos          1U                                            /*!< CoreDebug DHCSR: C_HALT Position */ | ||||
| #define CoreDebug_DHCSR_C_HALT_Msk         (1UL << CoreDebug_DHCSR_C_HALT_Pos)            /*!< CoreDebug DHCSR: C_HALT Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Pos       0U                                            /*!< \deprecated CoreDebug DHCSR: C_DEBUGEN Position */ | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Msk      (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/)     /*!< \deprecated CoreDebug DHCSR: C_DEBUGEN Mask */ | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Pos       0U                                            /*!< CoreDebug DHCSR: C_DEBUGEN Position */ | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Msk      (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/)     /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ | ||||
|  | ||||
| /* Debug Core Register Selector Register Definitions */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Pos         16U                                            /*!< \deprecated CoreDebug DCRSR: REGWnR Position */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Msk         (1UL << CoreDebug_DCRSR_REGWnR_Pos)            /*!< \deprecated CoreDebug DCRSR: REGWnR Mask */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Pos         16U                                            /*!< CoreDebug DCRSR: REGWnR Position */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Msk         (1UL << CoreDebug_DCRSR_REGWnR_Pos)            /*!< CoreDebug DCRSR: REGWnR Mask */ | ||||
|  | ||||
| #define CoreDebug_DCRSR_REGSEL_Pos          0U                                            /*!< \deprecated CoreDebug DCRSR: REGSEL Position */ | ||||
| #define CoreDebug_DCRSR_REGSEL_Msk         (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/)     /*!< \deprecated CoreDebug DCRSR: REGSEL Mask */ | ||||
| #define CoreDebug_DCRSR_REGSEL_Pos          0U                                            /*!< CoreDebug DCRSR: REGSEL Position */ | ||||
| #define CoreDebug_DCRSR_REGSEL_Msk         (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/)     /*!< CoreDebug DCRSR: REGSEL Mask */ | ||||
|  | ||||
| /* Debug Exception and Monitor Control Register Definitions */ | ||||
| #define CoreDebug_DEMCR_TRCENA_Pos         24U                                            /*!< \deprecated CoreDebug DEMCR: TRCENA Position */ | ||||
| #define CoreDebug_DEMCR_TRCENA_Msk         (1UL << CoreDebug_DEMCR_TRCENA_Pos)            /*!< \deprecated CoreDebug DEMCR: TRCENA Mask */ | ||||
| #define CoreDebug_DEMCR_TRCENA_Pos         24U                                            /*!< CoreDebug DEMCR: TRCENA Position */ | ||||
| #define CoreDebug_DEMCR_TRCENA_Msk         (1UL << CoreDebug_DEMCR_TRCENA_Pos)            /*!< CoreDebug DEMCR: TRCENA Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_MON_REQ_Pos        19U                                            /*!< \deprecated CoreDebug DEMCR: MON_REQ Position */ | ||||
| #define CoreDebug_DEMCR_MON_REQ_Msk        (1UL << CoreDebug_DEMCR_MON_REQ_Pos)           /*!< \deprecated CoreDebug DEMCR: MON_REQ Mask */ | ||||
| #define CoreDebug_DEMCR_MON_REQ_Pos        19U                                            /*!< CoreDebug DEMCR: MON_REQ Position */ | ||||
| #define CoreDebug_DEMCR_MON_REQ_Msk        (1UL << CoreDebug_DEMCR_MON_REQ_Pos)           /*!< CoreDebug DEMCR: MON_REQ Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_MON_STEP_Pos       18U                                            /*!< \deprecated CoreDebug DEMCR: MON_STEP Position */ | ||||
| #define CoreDebug_DEMCR_MON_STEP_Msk       (1UL << CoreDebug_DEMCR_MON_STEP_Pos)          /*!< \deprecated CoreDebug DEMCR: MON_STEP Mask */ | ||||
| #define CoreDebug_DEMCR_MON_STEP_Pos       18U                                            /*!< CoreDebug DEMCR: MON_STEP Position */ | ||||
| #define CoreDebug_DEMCR_MON_STEP_Msk       (1UL << CoreDebug_DEMCR_MON_STEP_Pos)          /*!< CoreDebug DEMCR: MON_STEP Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_MON_PEND_Pos       17U                                            /*!< \deprecated CoreDebug DEMCR: MON_PEND Position */ | ||||
| #define CoreDebug_DEMCR_MON_PEND_Msk       (1UL << CoreDebug_DEMCR_MON_PEND_Pos)          /*!< \deprecated CoreDebug DEMCR: MON_PEND Mask */ | ||||
| #define CoreDebug_DEMCR_MON_PEND_Pos       17U                                            /*!< CoreDebug DEMCR: MON_PEND Position */ | ||||
| #define CoreDebug_DEMCR_MON_PEND_Msk       (1UL << CoreDebug_DEMCR_MON_PEND_Pos)          /*!< CoreDebug DEMCR: MON_PEND Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_MON_EN_Pos         16U                                            /*!< \deprecated CoreDebug DEMCR: MON_EN Position */ | ||||
| #define CoreDebug_DEMCR_MON_EN_Msk         (1UL << CoreDebug_DEMCR_MON_EN_Pos)            /*!< \deprecated CoreDebug DEMCR: MON_EN Mask */ | ||||
| #define CoreDebug_DEMCR_MON_EN_Pos         16U                                            /*!< CoreDebug DEMCR: MON_EN Position */ | ||||
| #define CoreDebug_DEMCR_MON_EN_Msk         (1UL << CoreDebug_DEMCR_MON_EN_Pos)            /*!< CoreDebug DEMCR: MON_EN Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Pos     10U                                            /*!< \deprecated CoreDebug DEMCR: VC_HARDERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Msk     (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos)        /*!< \deprecated CoreDebug DEMCR: VC_HARDERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Pos     10U                                            /*!< CoreDebug DEMCR: VC_HARDERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Msk     (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos)        /*!< CoreDebug DEMCR: VC_HARDERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_INTERR_Pos       9U                                            /*!< \deprecated CoreDebug DEMCR: VC_INTERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_INTERR_Msk      (1UL << CoreDebug_DEMCR_VC_INTERR_Pos)         /*!< \deprecated CoreDebug DEMCR: VC_INTERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_INTERR_Pos       9U                                            /*!< CoreDebug DEMCR: VC_INTERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_INTERR_Msk      (1UL << CoreDebug_DEMCR_VC_INTERR_Pos)         /*!< CoreDebug DEMCR: VC_INTERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_BUSERR_Pos       8U                                            /*!< \deprecated CoreDebug DEMCR: VC_BUSERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_BUSERR_Msk      (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos)         /*!< \deprecated CoreDebug DEMCR: VC_BUSERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_BUSERR_Pos       8U                                            /*!< CoreDebug DEMCR: VC_BUSERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_BUSERR_Msk      (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos)         /*!< CoreDebug DEMCR: VC_BUSERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_STATERR_Pos      7U                                            /*!< \deprecated CoreDebug DEMCR: VC_STATERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_STATERR_Msk     (1UL << CoreDebug_DEMCR_VC_STATERR_Pos)        /*!< \deprecated CoreDebug DEMCR: VC_STATERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_STATERR_Pos      7U                                            /*!< CoreDebug DEMCR: VC_STATERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_STATERR_Msk     (1UL << CoreDebug_DEMCR_VC_STATERR_Pos)        /*!< CoreDebug DEMCR: VC_STATERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_CHKERR_Pos       6U                                            /*!< \deprecated CoreDebug DEMCR: VC_CHKERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_CHKERR_Msk      (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos)         /*!< \deprecated CoreDebug DEMCR: VC_CHKERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_CHKERR_Pos       6U                                            /*!< CoreDebug DEMCR: VC_CHKERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_CHKERR_Msk      (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos)         /*!< CoreDebug DEMCR: VC_CHKERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_NOCPERR_Pos      5U                                            /*!< \deprecated CoreDebug DEMCR: VC_NOCPERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_NOCPERR_Msk     (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos)        /*!< \deprecated CoreDebug DEMCR: VC_NOCPERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_NOCPERR_Pos      5U                                            /*!< CoreDebug DEMCR: VC_NOCPERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_NOCPERR_Msk     (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos)        /*!< CoreDebug DEMCR: VC_NOCPERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_MMERR_Pos        4U                                            /*!< \deprecated CoreDebug DEMCR: VC_MMERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_MMERR_Msk       (1UL << CoreDebug_DEMCR_VC_MMERR_Pos)          /*!< \deprecated CoreDebug DEMCR: VC_MMERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_MMERR_Pos        4U                                            /*!< CoreDebug DEMCR: VC_MMERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_MMERR_Msk       (1UL << CoreDebug_DEMCR_VC_MMERR_Pos)          /*!< CoreDebug DEMCR: VC_MMERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Pos    0U                                            /*!< \deprecated CoreDebug DEMCR: VC_CORERESET Position */ | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Msk   (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/)  /*!< \deprecated CoreDebug DEMCR: VC_CORERESET Mask */ | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Pos    0U                                            /*!< CoreDebug DEMCR: VC_CORERESET Position */ | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Msk   (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/)  /*!< CoreDebug DEMCR: VC_CORERESET Mask */ | ||||
|  | ||||
| /* Debug Authentication Control Register Definitions */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos  3U                                            /*!< \deprecated CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos)    /*!< \deprecated CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos  3U                                            /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos)    /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ | ||||
|  | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos  2U                                            /*!< \deprecated CoreDebug DAUTHCTRL: SPNIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos)    /*!< \deprecated CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos  2U                                            /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos)    /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ | ||||
|  | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos   1U                                            /*!< \deprecated CoreDebug DAUTHCTRL: INTSPIDEN Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk  (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos)     /*!< \deprecated CoreDebug DAUTHCTRL: INTSPIDEN Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos   1U                                            /*!< CoreDebug DAUTHCTRL: INTSPIDEN Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk  (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos)     /*!< CoreDebug DAUTHCTRL: INTSPIDEN Mask */ | ||||
|  | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos   0U                                            /*!< \deprecated CoreDebug DAUTHCTRL: SPIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk  (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< \deprecated CoreDebug DAUTHCTRL: SPIDENSEL Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos   0U                                            /*!< CoreDebug DAUTHCTRL: SPIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk  (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< CoreDebug DAUTHCTRL: SPIDENSEL Mask */ | ||||
|  | ||||
| /* Debug Security Control and Status Register Definitions */ | ||||
| #define CoreDebug_DSCSR_CDS_Pos            16U                                            /*!< \deprecated CoreDebug DSCSR: CDS Position */ | ||||
| #define CoreDebug_DSCSR_CDS_Msk            (1UL << CoreDebug_DSCSR_CDS_Pos)               /*!< \deprecated CoreDebug DSCSR: CDS Mask */ | ||||
| #define CoreDebug_DSCSR_CDS_Pos            16U                                            /*!< CoreDebug DSCSR: CDS Position */ | ||||
| #define CoreDebug_DSCSR_CDS_Msk            (1UL << CoreDebug_DSCSR_CDS_Pos)               /*!< CoreDebug DSCSR: CDS Mask */ | ||||
|  | ||||
| #define CoreDebug_DSCSR_SBRSEL_Pos          1U                                            /*!< \deprecated CoreDebug DSCSR: SBRSEL Position */ | ||||
| #define CoreDebug_DSCSR_SBRSEL_Msk         (1UL << CoreDebug_DSCSR_SBRSEL_Pos)            /*!< \deprecated CoreDebug DSCSR: SBRSEL Mask */ | ||||
| #define CoreDebug_DSCSR_SBRSEL_Pos          1U                                            /*!< CoreDebug DSCSR: SBRSEL Position */ | ||||
| #define CoreDebug_DSCSR_SBRSEL_Msk         (1UL << CoreDebug_DSCSR_SBRSEL_Pos)            /*!< CoreDebug DSCSR: SBRSEL Mask */ | ||||
|  | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Pos        0U                                            /*!< \deprecated CoreDebug DSCSR: SBRSELEN Position */ | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Msk       (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/)      /*!< \deprecated CoreDebug DSCSR: SBRSELEN Mask */ | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Pos        0U                                            /*!< CoreDebug DSCSR: SBRSELEN Position */ | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Msk       (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/)      /*!< CoreDebug DSCSR: SBRSELEN Mask */ | ||||
|  | ||||
| /*@} end of group CMSIS_CoreDebug */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup    CMSIS_core_register | ||||
|   \defgroup CMSIS_DCB       Debug Control Block | ||||
|   \brief    Type definitions for the Debug Control Block Registers | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief  Structure type to access the Debug Control Block Registers (DCB). | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
|   __IOM uint32_t DHCSR;                  /*!< Offset: 0x000 (R/W)  Debug Halting Control and Status Register */ | ||||
|   __OM  uint32_t DCRSR;                  /*!< Offset: 0x004 ( /W)  Debug Core Register Selector Register */ | ||||
|   __IOM uint32_t DCRDR;                  /*!< Offset: 0x008 (R/W)  Debug Core Register Data Register */ | ||||
|   __IOM uint32_t DEMCR;                  /*!< Offset: 0x00C (R/W)  Debug Exception and Monitor Control Register */ | ||||
|         uint32_t RESERVED0[1U]; | ||||
|   __IOM uint32_t DAUTHCTRL;              /*!< Offset: 0x014 (R/W)  Debug Authentication Control Register */ | ||||
|   __IOM uint32_t DSCSR;                  /*!< Offset: 0x018 (R/W)  Debug Security Control and Status Register */ | ||||
| } DCB_Type; | ||||
|  | ||||
| /* DHCSR, Debug Halting Control and Status Register Definitions */ | ||||
| #define DCB_DHCSR_DBGKEY_Pos               16U                                            /*!< DCB DHCSR: Debug key Position */ | ||||
| #define DCB_DHCSR_DBGKEY_Msk               (0xFFFFUL << DCB_DHCSR_DBGKEY_Pos)             /*!< DCB DHCSR: Debug key Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_RESTART_ST_Pos         26U                                            /*!< DCB DHCSR: Restart sticky status Position */ | ||||
| #define DCB_DHCSR_S_RESTART_ST_Msk         (0x1UL << DCB_DHCSR_S_RESTART_ST_Pos)          /*!< DCB DHCSR: Restart sticky status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_RESET_ST_Pos           25U                                            /*!< DCB DHCSR: Reset sticky status Position */ | ||||
| #define DCB_DHCSR_S_RESET_ST_Msk           (0x1UL << DCB_DHCSR_S_RESET_ST_Pos)            /*!< DCB DHCSR: Reset sticky status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_RETIRE_ST_Pos          24U                                            /*!< DCB DHCSR: Retire sticky status Position */ | ||||
| #define DCB_DHCSR_S_RETIRE_ST_Msk          (0x1UL << DCB_DHCSR_S_RETIRE_ST_Pos)           /*!< DCB DHCSR: Retire sticky status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_SDE_Pos                20U                                            /*!< DCB DHCSR: Secure debug enabled Position */ | ||||
| #define DCB_DHCSR_S_SDE_Msk                (0x1UL << DCB_DHCSR_S_SDE_Pos)                 /*!< DCB DHCSR: Secure debug enabled Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_LOCKUP_Pos             19U                                            /*!< DCB DHCSR: Lockup status Position */ | ||||
| #define DCB_DHCSR_S_LOCKUP_Msk             (0x1UL << DCB_DHCSR_S_LOCKUP_Pos)              /*!< DCB DHCSR: Lockup status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_SLEEP_Pos              18U                                            /*!< DCB DHCSR: Sleeping status Position */ | ||||
| #define DCB_DHCSR_S_SLEEP_Msk              (0x1UL << DCB_DHCSR_S_SLEEP_Pos)               /*!< DCB DHCSR: Sleeping status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_HALT_Pos               17U                                            /*!< DCB DHCSR: Halted status Position */ | ||||
| #define DCB_DHCSR_S_HALT_Msk               (0x1UL << DCB_DHCSR_S_HALT_Pos)                /*!< DCB DHCSR: Halted status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_REGRDY_Pos             16U                                            /*!< DCB DHCSR: Register ready status Position */ | ||||
| #define DCB_DHCSR_S_REGRDY_Msk             (0x1UL << DCB_DHCSR_S_REGRDY_Pos)              /*!< DCB DHCSR: Register ready status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_SNAPSTALL_Pos           5U                                            /*!< DCB DHCSR: Snap stall control Position */ | ||||
| #define DCB_DHCSR_C_SNAPSTALL_Msk          (0x1UL << DCB_DHCSR_C_SNAPSTALL_Pos)           /*!< DCB DHCSR: Snap stall control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_MASKINTS_Pos            3U                                            /*!< DCB DHCSR: Mask interrupts control Position */ | ||||
| #define DCB_DHCSR_C_MASKINTS_Msk           (0x1UL << DCB_DHCSR_C_MASKINTS_Pos)            /*!< DCB DHCSR: Mask interrupts control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_STEP_Pos                2U                                            /*!< DCB DHCSR: Step control Position */ | ||||
| #define DCB_DHCSR_C_STEP_Msk               (0x1UL << DCB_DHCSR_C_STEP_Pos)                /*!< DCB DHCSR: Step control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_HALT_Pos                1U                                            /*!< DCB DHCSR: Halt control Position */ | ||||
| #define DCB_DHCSR_C_HALT_Msk               (0x1UL << DCB_DHCSR_C_HALT_Pos)                /*!< DCB DHCSR: Halt control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_DEBUGEN_Pos             0U                                            /*!< DCB DHCSR: Debug enable control Position */ | ||||
| #define DCB_DHCSR_C_DEBUGEN_Msk            (0x1UL /*<< DCB_DHCSR_C_DEBUGEN_Pos*/)         /*!< DCB DHCSR: Debug enable control Mask */ | ||||
|  | ||||
| /* DCRSR, Debug Core Register Select Register Definitions */ | ||||
| #define DCB_DCRSR_REGWnR_Pos               16U                                            /*!< DCB DCRSR: Register write/not-read Position */ | ||||
| #define DCB_DCRSR_REGWnR_Msk               (0x1UL << DCB_DCRSR_REGWnR_Pos)                /*!< DCB DCRSR: Register write/not-read Mask */ | ||||
|  | ||||
| #define DCB_DCRSR_REGSEL_Pos                0U                                            /*!< DCB DCRSR: Register selector Position */ | ||||
| #define DCB_DCRSR_REGSEL_Msk               (0x7FUL /*<< DCB_DCRSR_REGSEL_Pos*/)           /*!< DCB DCRSR: Register selector Mask */ | ||||
|  | ||||
| /* DCRDR, Debug Core Register Data Register Definitions */ | ||||
| #define DCB_DCRDR_DBGTMP_Pos                0U                                            /*!< DCB DCRDR: Data temporary buffer Position */ | ||||
| #define DCB_DCRDR_DBGTMP_Msk               (0xFFFFFFFFUL /*<< DCB_DCRDR_DBGTMP_Pos*/)     /*!< DCB DCRDR: Data temporary buffer Mask */ | ||||
|  | ||||
| /* DEMCR, Debug Exception and Monitor Control Register Definitions */ | ||||
| #define DCB_DEMCR_TRCENA_Pos               24U                                            /*!< DCB DEMCR: Trace enable Position */ | ||||
| #define DCB_DEMCR_TRCENA_Msk               (0x1UL << DCB_DEMCR_TRCENA_Pos)                /*!< DCB DEMCR: Trace enable Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_MONPRKEY_Pos             23U                                            /*!< DCB DEMCR: Monitor pend req key Position */ | ||||
| #define DCB_DEMCR_MONPRKEY_Msk             (0x1UL << DCB_DEMCR_MONPRKEY_Pos)              /*!< DCB DEMCR: Monitor pend req key Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_UMON_EN_Pos              21U                                            /*!< DCB DEMCR: Unprivileged monitor enable Position */ | ||||
| #define DCB_DEMCR_UMON_EN_Msk              (0x1UL << DCB_DEMCR_UMON_EN_Pos)               /*!< DCB DEMCR: Unprivileged monitor enable Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_SDME_Pos                 20U                                            /*!< DCB DEMCR: Secure DebugMonitor enable Position */ | ||||
| #define DCB_DEMCR_SDME_Msk                 (0x1UL << DCB_DEMCR_SDME_Pos)                  /*!< DCB DEMCR: Secure DebugMonitor enable Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_MON_REQ_Pos              19U                                            /*!< DCB DEMCR: Monitor request Position */ | ||||
| #define DCB_DEMCR_MON_REQ_Msk              (0x1UL << DCB_DEMCR_MON_REQ_Pos)               /*!< DCB DEMCR: Monitor request Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_MON_STEP_Pos             18U                                            /*!< DCB DEMCR: Monitor step Position */ | ||||
| #define DCB_DEMCR_MON_STEP_Msk             (0x1UL << DCB_DEMCR_MON_STEP_Pos)              /*!< DCB DEMCR: Monitor step Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_MON_PEND_Pos             17U                                            /*!< DCB DEMCR: Monitor pend Position */ | ||||
| #define DCB_DEMCR_MON_PEND_Msk             (0x1UL << DCB_DEMCR_MON_PEND_Pos)              /*!< DCB DEMCR: Monitor pend Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_MON_EN_Pos               16U                                            /*!< DCB DEMCR: Monitor enable Position */ | ||||
| #define DCB_DEMCR_MON_EN_Msk               (0x1UL << DCB_DEMCR_MON_EN_Pos)                /*!< DCB DEMCR: Monitor enable Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_SFERR_Pos             11U                                            /*!< DCB DEMCR: Vector Catch SecureFault Position */ | ||||
| #define DCB_DEMCR_VC_SFERR_Msk             (0x1UL << DCB_DEMCR_VC_SFERR_Pos)              /*!< DCB DEMCR: Vector Catch SecureFault Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_HARDERR_Pos           10U                                            /*!< DCB DEMCR: Vector Catch HardFault errors Position */ | ||||
| #define DCB_DEMCR_VC_HARDERR_Msk           (0x1UL << DCB_DEMCR_VC_HARDERR_Pos)            /*!< DCB DEMCR: Vector Catch HardFault errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_INTERR_Pos             9U                                            /*!< DCB DEMCR: Vector Catch interrupt errors Position */ | ||||
| #define DCB_DEMCR_VC_INTERR_Msk            (0x1UL << DCB_DEMCR_VC_INTERR_Pos)             /*!< DCB DEMCR: Vector Catch interrupt errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_BUSERR_Pos             8U                                            /*!< DCB DEMCR: Vector Catch BusFault errors Position */ | ||||
| #define DCB_DEMCR_VC_BUSERR_Msk            (0x1UL << DCB_DEMCR_VC_BUSERR_Pos)             /*!< DCB DEMCR: Vector Catch BusFault errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_STATERR_Pos            7U                                            /*!< DCB DEMCR: Vector Catch state errors Position */ | ||||
| #define DCB_DEMCR_VC_STATERR_Msk           (0x1UL << DCB_DEMCR_VC_STATERR_Pos)            /*!< DCB DEMCR: Vector Catch state errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_CHKERR_Pos             6U                                            /*!< DCB DEMCR: Vector Catch check errors Position */ | ||||
| #define DCB_DEMCR_VC_CHKERR_Msk            (0x1UL << DCB_DEMCR_VC_CHKERR_Pos)             /*!< DCB DEMCR: Vector Catch check errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_NOCPERR_Pos            5U                                            /*!< DCB DEMCR: Vector Catch NOCP errors Position */ | ||||
| #define DCB_DEMCR_VC_NOCPERR_Msk           (0x1UL << DCB_DEMCR_VC_NOCPERR_Pos)            /*!< DCB DEMCR: Vector Catch NOCP errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_MMERR_Pos              4U                                            /*!< DCB DEMCR: Vector Catch MemManage errors Position */ | ||||
| #define DCB_DEMCR_VC_MMERR_Msk             (0x1UL << DCB_DEMCR_VC_MMERR_Pos)              /*!< DCB DEMCR: Vector Catch MemManage errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_CORERESET_Pos          0U                                            /*!< DCB DEMCR: Vector Catch Core reset Position */ | ||||
| #define DCB_DEMCR_VC_CORERESET_Msk         (0x1UL /*<< DCB_DEMCR_VC_CORERESET_Pos*/)      /*!< DCB DEMCR: Vector Catch Core reset Mask */ | ||||
|  | ||||
| /* DAUTHCTRL, Debug Authentication Control Register Definitions */ | ||||
| #define DCB_DAUTHCTRL_INTSPNIDEN_Pos        3U                                            /*!< DCB DAUTHCTRL: Internal Secure non-invasive debug enable Position */ | ||||
| #define DCB_DAUTHCTRL_INTSPNIDEN_Msk       (0x1UL << DCB_DAUTHCTRL_INTSPNIDEN_Pos)        /*!< DCB DAUTHCTRL: Internal Secure non-invasive debug enable Mask */ | ||||
|  | ||||
| #define DCB_DAUTHCTRL_SPNIDENSEL_Pos        2U                                            /*!< DCB DAUTHCTRL: Secure non-invasive debug enable select Position */ | ||||
| #define DCB_DAUTHCTRL_SPNIDENSEL_Msk       (0x1UL << DCB_DAUTHCTRL_SPNIDENSEL_Pos)        /*!< DCB DAUTHCTRL: Secure non-invasive debug enable select Mask */ | ||||
|  | ||||
| #define DCB_DAUTHCTRL_INTSPIDEN_Pos         1U                                            /*!< DCB DAUTHCTRL: Internal Secure invasive debug enable Position */ | ||||
| #define DCB_DAUTHCTRL_INTSPIDEN_Msk        (0x1UL << DCB_DAUTHCTRL_INTSPIDEN_Pos)         /*!< DCB DAUTHCTRL: Internal Secure invasive debug enable Mask */ | ||||
|  | ||||
| #define DCB_DAUTHCTRL_SPIDENSEL_Pos         0U                                            /*!< DCB DAUTHCTRL: Secure invasive debug enable select Position */ | ||||
| #define DCB_DAUTHCTRL_SPIDENSEL_Msk        (0x1UL /*<< DCB_DAUTHCTRL_SPIDENSEL_Pos*/)     /*!< DCB DAUTHCTRL: Secure invasive debug enable select Mask */ | ||||
|  | ||||
| /* DSCSR, Debug Security Control and Status Register Definitions */ | ||||
| #define DCB_DSCSR_CDSKEY_Pos               17U                                            /*!< DCB DSCSR: CDS write-enable key Position */ | ||||
| #define DCB_DSCSR_CDSKEY_Msk               (0x1UL << DCB_DSCSR_CDSKEY_Pos)                /*!< DCB DSCSR: CDS write-enable key Mask */ | ||||
|  | ||||
| #define DCB_DSCSR_CDS_Pos                  16U                                            /*!< DCB DSCSR: Current domain Secure Position */ | ||||
| #define DCB_DSCSR_CDS_Msk                  (0x1UL << DCB_DSCSR_CDS_Pos)                   /*!< DCB DSCSR: Current domain Secure Mask */ | ||||
|  | ||||
| #define DCB_DSCSR_SBRSEL_Pos                1U                                            /*!< DCB DSCSR: Secure banked register select Position */ | ||||
| #define DCB_DSCSR_SBRSEL_Msk               (0x1UL << DCB_DSCSR_SBRSEL_Pos)                /*!< DCB DSCSR: Secure banked register select Mask */ | ||||
|  | ||||
| #define DCB_DSCSR_SBRSELEN_Pos              0U                                            /*!< DCB DSCSR: Secure banked register select enable Position */ | ||||
| #define DCB_DSCSR_SBRSELEN_Msk             (0x1UL /*<< DCB_DSCSR_SBRSELEN_Pos*/)          /*!< DCB DSCSR: Secure banked register select enable Mask */ | ||||
|  | ||||
| /*@} end of group CMSIS_DCB */ | ||||
|  | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup  CMSIS_core_register | ||||
|   \defgroup CMSIS_DIB       Debug Identification Block | ||||
|   \brief    Type definitions for the Debug Identification Block Registers | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief  Structure type to access the Debug Identification Block Registers (DIB). | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
|   __OM  uint32_t DLAR;                   /*!< Offset: 0x000 ( /W)  SCS Software Lock Access Register */ | ||||
|   __IM  uint32_t DLSR;                   /*!< Offset: 0x004 (R/ )  SCS Software Lock Status Register */ | ||||
|   __IM  uint32_t DAUTHSTATUS;            /*!< Offset: 0x008 (R/ )  Debug Authentication Status Register */ | ||||
|   __IM  uint32_t DDEVARCH;               /*!< Offset: 0x00C (R/ )  SCS Device Architecture Register */ | ||||
|   __IM  uint32_t DDEVTYPE;               /*!< Offset: 0x010 (R/ )  SCS Device Type Register */ | ||||
| } DIB_Type; | ||||
|  | ||||
| /* DLAR, SCS Software Lock Access Register Definitions */ | ||||
| #define DIB_DLAR_KEY_Pos                    0U                                            /*!< DIB DLAR: KEY Position */ | ||||
| #define DIB_DLAR_KEY_Msk                   (0xFFFFFFFFUL /*<< DIB_DLAR_KEY_Pos */)        /*!< DIB DLAR: KEY Mask */ | ||||
|  | ||||
| /* DLSR, SCS Software Lock Status Register Definitions */ | ||||
| #define DIB_DLSR_nTT_Pos                    2U                                            /*!< DIB DLSR: Not thirty-two bit Position */ | ||||
| #define DIB_DLSR_nTT_Msk                   (0x1UL << DIB_DLSR_nTT_Pos )                   /*!< DIB DLSR: Not thirty-two bit Mask */ | ||||
|  | ||||
| #define DIB_DLSR_SLK_Pos                    1U                                            /*!< DIB DLSR: Software Lock status Position */ | ||||
| #define DIB_DLSR_SLK_Msk                   (0x1UL << DIB_DLSR_SLK_Pos )                   /*!< DIB DLSR: Software Lock status Mask */ | ||||
|  | ||||
| #define DIB_DLSR_SLI_Pos                    0U                                            /*!< DIB DLSR: Software Lock implemented Position */ | ||||
| #define DIB_DLSR_SLI_Msk                   (0x1UL /*<< DIB_DLSR_SLI_Pos*/)                /*!< DIB DLSR: Software Lock implemented Mask */ | ||||
|  | ||||
| /* DAUTHSTATUS, Debug Authentication Status Register Definitions */ | ||||
| #define DIB_DAUTHSTATUS_SNID_Pos            6U                                            /*!< DIB DAUTHSTATUS: Secure Non-invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_SNID_Msk           (0x3UL << DIB_DAUTHSTATUS_SNID_Pos )           /*!< DIB DAUTHSTATUS: Secure Non-invasive Debug Mask */ | ||||
|  | ||||
| #define DIB_DAUTHSTATUS_SID_Pos             4U                                            /*!< DIB DAUTHSTATUS: Secure Invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_SID_Msk            (0x3UL << DIB_DAUTHSTATUS_SID_Pos )            /*!< DIB DAUTHSTATUS: Secure Invasive Debug Mask */ | ||||
|  | ||||
| #define DIB_DAUTHSTATUS_NSNID_Pos           2U                                            /*!< DIB DAUTHSTATUS: Non-secure Non-invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_NSNID_Msk          (0x3UL << DIB_DAUTHSTATUS_NSNID_Pos )          /*!< DIB DAUTHSTATUS: Non-secure Non-invasive Debug Mask */ | ||||
|  | ||||
| #define DIB_DAUTHSTATUS_NSID_Pos            0U                                            /*!< DIB DAUTHSTATUS: Non-secure Invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_NSID_Msk           (0x3UL /*<< DIB_DAUTHSTATUS_NSID_Pos*/)        /*!< DIB DAUTHSTATUS: Non-secure Invasive Debug Mask */ | ||||
|  | ||||
| /* DDEVARCH, SCS Device Architecture Register Definitions */ | ||||
| #define DIB_DDEVARCH_ARCHITECT_Pos         21U                                            /*!< DIB DDEVARCH: Architect Position */ | ||||
| #define DIB_DDEVARCH_ARCHITECT_Msk         (0x7FFUL << DIB_DDEVARCH_ARCHITECT_Pos )       /*!< DIB DDEVARCH: Architect Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_PRESENT_Pos           20U                                            /*!< DIB DDEVARCH: DEVARCH Present Position */ | ||||
| #define DIB_DDEVARCH_PRESENT_Msk           (0x1FUL << DIB_DDEVARCH_PRESENT_Pos )          /*!< DIB DDEVARCH: DEVARCH Present Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_REVISION_Pos          16U                                            /*!< DIB DDEVARCH: Revision Position */ | ||||
| #define DIB_DDEVARCH_REVISION_Msk          (0xFUL << DIB_DDEVARCH_REVISION_Pos )          /*!< DIB DDEVARCH: Revision Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_ARCHVER_Pos           12U                                            /*!< DIB DDEVARCH: Architecture Version Position */ | ||||
| #define DIB_DDEVARCH_ARCHVER_Msk           (0xFUL << DIB_DDEVARCH_ARCHVER_Pos )           /*!< DIB DDEVARCH: Architecture Version Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_ARCHPART_Pos           0U                                            /*!< DIB DDEVARCH: Architecture Part Position */ | ||||
| #define DIB_DDEVARCH_ARCHPART_Msk          (0xFFFUL /*<< DIB_DDEVARCH_ARCHPART_Pos*/)     /*!< DIB DDEVARCH: Architecture Part Mask */ | ||||
|  | ||||
| /* DDEVTYPE, SCS Device Type Register Definitions */ | ||||
| #define DIB_DDEVTYPE_SUB_Pos                4U                                            /*!< DIB DDEVTYPE: Sub-type Position */ | ||||
| #define DIB_DDEVTYPE_SUB_Msk               (0xFUL << DIB_DDEVTYPE_SUB_Pos )               /*!< DIB DDEVTYPE: Sub-type Mask */ | ||||
|  | ||||
| #define DIB_DDEVTYPE_MAJOR_Pos              0U                                            /*!< DIB DDEVTYPE: Major type Position */ | ||||
| #define DIB_DDEVTYPE_MAJOR_Msk             (0xFUL /*<< DIB_DDEVTYPE_MAJOR_Pos*/)          /*!< DIB DDEVTYPE: Major type Mask */ | ||||
|  | ||||
|  | ||||
| /*@} end of group CMSIS_DIB */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup    CMSIS_core_register | ||||
|   \defgroup   CMSIS_core_bitfield     Core register bit field macros | ||||
| @@ -2200,9 +1954,7 @@ typedef struct | ||||
|   #define ITM_BASE            (0xE0000000UL)                             /*!< ITM Base Address */ | ||||
|   #define DWT_BASE            (0xE0001000UL)                             /*!< DWT Base Address */ | ||||
|   #define TPI_BASE            (0xE0040000UL)                             /*!< TPI Base Address */ | ||||
|   #define CoreDebug_BASE      (0xE000EDF0UL)                             /*!< \deprecated Core Debug Base Address */ | ||||
|   #define DCB_BASE            (0xE000EDF0UL)                             /*!< DCB Base Address */ | ||||
|   #define DIB_BASE            (0xE000EFB0UL)                             /*!< DIB Base Address */ | ||||
|   #define CoreDebug_BASE      (0xE000EDF0UL)                             /*!< Core Debug Base Address */ | ||||
|   #define SysTick_BASE        (SCS_BASE +  0x0010UL)                     /*!< SysTick Base Address */ | ||||
|   #define NVIC_BASE           (SCS_BASE +  0x0100UL)                     /*!< NVIC Base Address */ | ||||
|   #define SCB_BASE            (SCS_BASE +  0x0D00UL)                     /*!< System Control Block Base Address */ | ||||
| @@ -2214,9 +1966,7 @@ typedef struct | ||||
|   #define ITM                 ((ITM_Type       *)     ITM_BASE         ) /*!< ITM configuration struct */ | ||||
|   #define DWT                 ((DWT_Type       *)     DWT_BASE         ) /*!< DWT configuration struct */ | ||||
|   #define TPI                 ((TPI_Type       *)     TPI_BASE         ) /*!< TPI configuration struct */ | ||||
|   #define CoreDebug           ((CoreDebug_Type *)     CoreDebug_BASE   ) /*!< \deprecated Core Debug configuration struct */ | ||||
|   #define DCB                 ((DCB_Type       *)     DCB_BASE         ) /*!< DCB configuration struct */ | ||||
|   #define DIB                 ((DIB_Type       *)     DIB_BASE         ) /*!< DIB configuration struct */ | ||||
|   #define CoreDebug           ((CoreDebug_Type *)     CoreDebug_BASE   ) /*!< Core Debug configuration struct */ | ||||
|  | ||||
|   #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) | ||||
|     #define MPU_BASE          (SCS_BASE +  0x0D90UL)                     /*!< Memory Protection Unit */ | ||||
| @@ -2233,9 +1983,7 @@ typedef struct | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
|   #define SCS_BASE_NS         (0xE002E000UL)                             /*!< System Control Space Base Address (non-secure address space) */ | ||||
|   #define CoreDebug_BASE_NS   (0xE002EDF0UL)                             /*!< \deprecated Core Debug Base Address           (non-secure address space) */ | ||||
|   #define DCB_BASE_NS         (0xE002EDF0UL)                             /*!< DCB Base Address                  (non-secure address space) */ | ||||
|   #define DIB_BASE_NS         (0xE002EFB0UL)                             /*!< DIB Base Address                  (non-secure address space) */ | ||||
|   #define CoreDebug_BASE_NS   (0xE002EDF0UL)                             /*!< Core Debug Base Address           (non-secure address space) */ | ||||
|   #define SysTick_BASE_NS     (SCS_BASE_NS +  0x0010UL)                  /*!< SysTick Base Address              (non-secure address space) */ | ||||
|   #define NVIC_BASE_NS        (SCS_BASE_NS +  0x0100UL)                  /*!< NVIC Base Address                 (non-secure address space) */ | ||||
|   #define SCB_BASE_NS         (SCS_BASE_NS +  0x0D00UL)                  /*!< System Control Block Base Address (non-secure address space) */ | ||||
| @@ -2244,9 +1992,7 @@ typedef struct | ||||
|   #define SCB_NS              ((SCB_Type       *)     SCB_BASE_NS      ) /*!< SCB configuration struct          (non-secure address space) */ | ||||
|   #define SysTick_NS          ((SysTick_Type   *)     SysTick_BASE_NS  ) /*!< SysTick configuration struct      (non-secure address space) */ | ||||
|   #define NVIC_NS             ((NVIC_Type      *)     NVIC_BASE_NS     ) /*!< NVIC configuration struct         (non-secure address space) */ | ||||
|   #define CoreDebug_NS        ((CoreDebug_Type *)     CoreDebug_BASE_NS) /*!< \deprecated Core Debug configuration struct   (non-secure address space) */ | ||||
|   #define DCB_NS              ((DCB_Type       *)     DCB_BASE_NS      ) /*!< DCB configuration struct          (non-secure address space) */ | ||||
|   #define DIB_NS              ((DIB_Type       *)     DIB_BASE_NS      ) /*!< DIB configuration struct          (non-secure address space) */ | ||||
|   #define CoreDebug_NS        ((CoreDebug_Type *)     CoreDebug_BASE_NS) /*!< Core Debug configuration struct   (non-secure address space) */ | ||||
|  | ||||
|   #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) | ||||
|     #define MPU_BASE_NS       (SCS_BASE_NS +  0x0D90UL)                  /*!< Memory Protection Unit            (non-secure address space) */ | ||||
| @@ -2260,15 +2006,6 @@ typedef struct | ||||
| /*@} */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup    CMSIS_core_register | ||||
|   \defgroup   CMSIS_register_aliases     Backwards Compatibility Aliases | ||||
|   \brief      Register alias definitions for backwards compatibility. | ||||
|   @{ | ||||
|  */ | ||||
| #define ID_ADR  (ID_AFR)    /*!< SCB Auxiliary Feature Register */ | ||||
| /*@} */ | ||||
|  | ||||
|  | ||||
| /******************************************************************************* | ||||
|  *                Hardware Abstraction Layer | ||||
| @@ -3012,110 +2749,6 @@ __STATIC_INLINE void TZ_SAU_Disable(void) | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    Debug Control function  ############################################ */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   \defgroup CMSIS_Core_DCBFunctions Debug Control Functions | ||||
|   \brief    Functions that access the Debug Control Block. | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Debug Authentication Control Register | ||||
|   \details writes to Debug Authentication Control register. | ||||
|   \param [in]  value  value to be writen. | ||||
|  */ | ||||
| __STATIC_INLINE void DCB_SetAuthCtrl(uint32_t value) | ||||
| { | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     DCB->DAUTHCTRL = value; | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Debug Authentication Control Register | ||||
|   \details Reads Debug Authentication Control register. | ||||
|   \return             Debug Authentication Control Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t DCB_GetAuthCtrl(void) | ||||
| { | ||||
|     return (DCB->DAUTHCTRL); | ||||
| } | ||||
|  | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
| /** | ||||
|   \brief   Set Debug Authentication Control Register (non-secure) | ||||
|   \details writes to non-secure Debug Authentication Control register when in secure state. | ||||
|   \param [in]  value  value to be writen | ||||
|  */ | ||||
| __STATIC_INLINE void TZ_DCB_SetAuthCtrl_NS(uint32_t value) | ||||
| { | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     DCB_NS->DAUTHCTRL = value; | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Debug Authentication Control Register (non-secure) | ||||
|   \details Reads non-secure Debug Authentication Control register when in secure state. | ||||
|   \return             Debug Authentication Control Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t TZ_DCB_GetAuthCtrl_NS(void) | ||||
| { | ||||
|     return (DCB_NS->DAUTHCTRL); | ||||
| } | ||||
| #endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ | ||||
|  | ||||
| /*@} end of CMSIS_Core_DCBFunctions */ | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    Debug Identification function  ############################################ */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   \defgroup CMSIS_Core_DIBFunctions Debug Identification Functions | ||||
|   \brief    Functions that access the Debug Identification Block. | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Debug Authentication Status Register | ||||
|   \details Reads Debug Authentication Status register. | ||||
|   \return             Debug Authentication Status Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t DIB_GetAuthStatus(void) | ||||
| { | ||||
|     return (DIB->DAUTHSTATUS); | ||||
| } | ||||
|  | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
| /** | ||||
|   \brief   Get Debug Authentication Status Register (non-secure) | ||||
|   \details Reads non-secure Debug Authentication Status register when in secure state. | ||||
|   \return             Debug Authentication Status Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t TZ_DIB_GetAuthStatus_NS(void) | ||||
| { | ||||
|     return (DIB_NS->DAUTHSTATUS); | ||||
| } | ||||
| #endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ | ||||
|  | ||||
| /*@} end of CMSIS_Core_DCBFunctions */ | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    SysTick function  ############################################ */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
| /**************************************************************************//** | ||||
|  * @file     core_cm35p.h | ||||
|  * @brief    CMSIS Cortex-M35P Core Peripheral Access Layer Header File | ||||
|  * @version  V1.1.3 | ||||
|  * @date     13. October 2021 | ||||
|  * @version  V1.0.0 | ||||
|  * @date     12. November 2018 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2018-2021 Arm Limited. All rights reserved. | ||||
|  * Copyright (c) 2018 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
| @@ -26,8 +26,6 @@ | ||||
|   #pragma system_include         /* treat file as system include file for MISRA check */ | ||||
| #elif defined (__clang__) | ||||
|   #pragma clang system_header   /* treat file as system include file */ | ||||
| #elif defined ( __GNUC__ ) | ||||
|   #pragma GCC diagnostic ignored "-Wpedantic"   /* disable pedantic warning due to unnamed structs/unions */ | ||||
| #endif | ||||
|  | ||||
| #ifndef __CORE_CM35P_H_GENERIC | ||||
| @@ -250,11 +248,6 @@ | ||||
|     #warning "__DSP_PRESENT not defined in device header file; using default!" | ||||
|   #endif | ||||
|  | ||||
|   #ifndef __VTOR_PRESENT | ||||
|     #define __VTOR_PRESENT             1U | ||||
|     #warning "__VTOR_PRESENT not defined in device header file; using default!" | ||||
|   #endif | ||||
|  | ||||
|   #ifndef __NVIC_PRIO_BITS | ||||
|     #define __NVIC_PRIO_BITS          3U | ||||
|     #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" | ||||
| @@ -519,7 +512,7 @@ typedef struct | ||||
|   __IOM uint32_t AFSR;                   /*!< Offset: 0x03C (R/W)  Auxiliary Fault Status Register */ | ||||
|   __IM  uint32_t ID_PFR[2U];             /*!< Offset: 0x040 (R/ )  Processor Feature Register */ | ||||
|   __IM  uint32_t ID_DFR;                 /*!< Offset: 0x048 (R/ )  Debug Feature Register */ | ||||
|   __IM  uint32_t ID_AFR;                 /*!< Offset: 0x04C (R/ )  Auxiliary Feature Register */ | ||||
|   __IM  uint32_t ID_ADR;                 /*!< Offset: 0x04C (R/ )  Auxiliary Feature Register */ | ||||
|   __IM  uint32_t ID_MMFR[4U];            /*!< Offset: 0x050 (R/ )  Memory Model Feature Register */ | ||||
|   __IM  uint32_t ID_ISAR[6U];            /*!< Offset: 0x060 (R/ )  Instruction Set Attributes Register */ | ||||
|   __IM  uint32_t CLIDR;                  /*!< Offset: 0x078 (R/ )  Cache Level ID register */ | ||||
| @@ -528,10 +521,7 @@ typedef struct | ||||
|   __IOM uint32_t CSSELR;                 /*!< Offset: 0x084 (R/W)  Cache Size Selection Register */ | ||||
|   __IOM uint32_t CPACR;                  /*!< Offset: 0x088 (R/W)  Coprocessor Access Control Register */ | ||||
|   __IOM uint32_t NSACR;                  /*!< Offset: 0x08C (R/W)  Non-Secure Access Control Register */ | ||||
|         uint32_t RESERVED7[21U]; | ||||
|   __IOM uint32_t SFSR;                   /*!< Offset: 0x0E4 (R/W)  Secure Fault Status Register */ | ||||
|   __IOM uint32_t SFAR;                   /*!< Offset: 0x0E8 (R/W)  Secure Fault Address Register */ | ||||
|         uint32_t RESERVED3[69U]; | ||||
|         uint32_t RESERVED3[92U]; | ||||
|   __OM  uint32_t STIR;                   /*!< Offset: 0x200 ( /W)  Software Triggered Interrupt Register */ | ||||
|         uint32_t RESERVED4[15U]; | ||||
|   __IM  uint32_t MVFR0;                  /*!< Offset: 0x240 (R/ )  Media and VFP Feature Register 0 */ | ||||
| @@ -548,7 +538,6 @@ typedef struct | ||||
|   __OM  uint32_t DCCSW;                  /*!< Offset: 0x26C ( /W)  D-Cache Clean by Set-way */ | ||||
|   __OM  uint32_t DCCIMVAC;               /*!< Offset: 0x270 ( /W)  D-Cache Clean and Invalidate by MVA to PoC */ | ||||
|   __OM  uint32_t DCCISW;                 /*!< Offset: 0x274 ( /W)  D-Cache Clean and Invalidate by Set-way */ | ||||
|   __OM  uint32_t BPIALL;                 /*!< Offset: 0x278 ( /W)  Branch Predictor Invalidate All */ | ||||
| } SCB_Type; | ||||
|  | ||||
| /* SCB CPUID Register Definitions */ | ||||
| @@ -749,22 +738,22 @@ typedef struct | ||||
| #define SCB_CFSR_MEMFAULTSR_Msk            (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/)        /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ | ||||
|  | ||||
| /* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ | ||||
| #define SCB_CFSR_MMARVALID_Pos             (SCB_CFSR_MEMFAULTSR_Pos + 7U)                 /*!< SCB CFSR (MMFSR): MMARVALID Position */ | ||||
| #define SCB_CFSR_MMARVALID_Pos             (SCB_SHCSR_MEMFAULTACT_Pos + 7U)               /*!< SCB CFSR (MMFSR): MMARVALID Position */ | ||||
| #define SCB_CFSR_MMARVALID_Msk             (1UL << SCB_CFSR_MMARVALID_Pos)                /*!< SCB CFSR (MMFSR): MMARVALID Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MLSPERR_Pos               (SCB_CFSR_MEMFAULTSR_Pos + 5U)                 /*!< SCB CFSR (MMFSR): MLSPERR Position */ | ||||
| #define SCB_CFSR_MLSPERR_Pos               (SCB_SHCSR_MEMFAULTACT_Pos + 5U)               /*!< SCB CFSR (MMFSR): MLSPERR Position */ | ||||
| #define SCB_CFSR_MLSPERR_Msk               (1UL << SCB_CFSR_MLSPERR_Pos)                  /*!< SCB CFSR (MMFSR): MLSPERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MSTKERR_Pos               (SCB_CFSR_MEMFAULTSR_Pos + 4U)                 /*!< SCB CFSR (MMFSR): MSTKERR Position */ | ||||
| #define SCB_CFSR_MSTKERR_Pos               (SCB_SHCSR_MEMFAULTACT_Pos + 4U)               /*!< SCB CFSR (MMFSR): MSTKERR Position */ | ||||
| #define SCB_CFSR_MSTKERR_Msk               (1UL << SCB_CFSR_MSTKERR_Pos)                  /*!< SCB CFSR (MMFSR): MSTKERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MUNSTKERR_Pos             (SCB_CFSR_MEMFAULTSR_Pos + 3U)                 /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ | ||||
| #define SCB_CFSR_MUNSTKERR_Pos             (SCB_SHCSR_MEMFAULTACT_Pos + 3U)               /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ | ||||
| #define SCB_CFSR_MUNSTKERR_Msk             (1UL << SCB_CFSR_MUNSTKERR_Pos)                /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_DACCVIOL_Pos              (SCB_CFSR_MEMFAULTSR_Pos + 1U)                 /*!< SCB CFSR (MMFSR): DACCVIOL Position */ | ||||
| #define SCB_CFSR_DACCVIOL_Pos              (SCB_SHCSR_MEMFAULTACT_Pos + 1U)               /*!< SCB CFSR (MMFSR): DACCVIOL Position */ | ||||
| #define SCB_CFSR_DACCVIOL_Msk              (1UL << SCB_CFSR_DACCVIOL_Pos)                 /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ | ||||
|  | ||||
| #define SCB_CFSR_IACCVIOL_Pos              (SCB_CFSR_MEMFAULTSR_Pos + 0U)                 /*!< SCB CFSR (MMFSR): IACCVIOL Position */ | ||||
| #define SCB_CFSR_IACCVIOL_Pos              (SCB_SHCSR_MEMFAULTACT_Pos + 0U)               /*!< SCB CFSR (MMFSR): IACCVIOL Position */ | ||||
| #define SCB_CFSR_IACCVIOL_Msk              (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/)             /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ | ||||
|  | ||||
| /* BusFault Status Register (part of SCB Configurable Fault Status Register) */ | ||||
| @@ -1679,9 +1668,8 @@ typedef struct | ||||
|   __IOM uint32_t FPCCR;                  /*!< Offset: 0x004 (R/W)  Floating-Point Context Control Register */ | ||||
|   __IOM uint32_t FPCAR;                  /*!< Offset: 0x008 (R/W)  Floating-Point Context Address Register */ | ||||
|   __IOM uint32_t FPDSCR;                 /*!< Offset: 0x00C (R/W)  Floating-Point Default Status Control Register */ | ||||
|   __IM  uint32_t MVFR0;                  /*!< Offset: 0x010 (R/ )  Media and VFP Feature Register 0 */ | ||||
|   __IM  uint32_t MVFR1;                  /*!< Offset: 0x014 (R/ )  Media and VFP Feature Register 1 */ | ||||
|   __IM  uint32_t MVFR2;                  /*!< Offset: 0x018 (R/ )  Media and VFP Feature Register 2 */ | ||||
|   __IM  uint32_t MVFR0;                  /*!< Offset: 0x010 (R/ )  Media and FP Feature Register 0 */ | ||||
|   __IM  uint32_t MVFR1;                  /*!< Offset: 0x014 (R/ )  Media and FP Feature Register 1 */ | ||||
| } FPU_Type; | ||||
|  | ||||
| /* Floating-Point Context Control Register Definitions */ | ||||
| @@ -1753,7 +1741,7 @@ typedef struct | ||||
| #define FPU_FPDSCR_RMode_Pos               22U                                            /*!< FPDSCR: RMode bit Position */ | ||||
| #define FPU_FPDSCR_RMode_Msk               (3UL << FPU_FPDSCR_RMode_Pos)                  /*!< FPDSCR: RMode bit Mask */ | ||||
|  | ||||
| /* Media and VFP Feature Register 0 Definitions */ | ||||
| /* Media and FP Feature Register 0 Definitions */ | ||||
| #define FPU_MVFR0_FP_rounding_modes_Pos    28U                                            /*!< MVFR0: FP rounding modes bits Position */ | ||||
| #define FPU_MVFR0_FP_rounding_modes_Msk    (0xFUL << FPU_MVFR0_FP_rounding_modes_Pos)     /*!< MVFR0: FP rounding modes bits Mask */ | ||||
|  | ||||
| @@ -1778,7 +1766,7 @@ typedef struct | ||||
| #define FPU_MVFR0_A_SIMD_registers_Pos      0U                                            /*!< MVFR0: A_SIMD registers bits Position */ | ||||
| #define FPU_MVFR0_A_SIMD_registers_Msk     (0xFUL /*<< FPU_MVFR0_A_SIMD_registers_Pos*/)  /*!< MVFR0: A_SIMD registers bits Mask */ | ||||
|  | ||||
| /* Media and VFP Feature Register 1 Definitions */ | ||||
| /* Media and FP Feature Register 1 Definitions */ | ||||
| #define FPU_MVFR1_FP_fused_MAC_Pos         28U                                            /*!< MVFR1: FP fused MAC bits Position */ | ||||
| #define FPU_MVFR1_FP_fused_MAC_Msk         (0xFUL << FPU_MVFR1_FP_fused_MAC_Pos)          /*!< MVFR1: FP fused MAC bits Mask */ | ||||
|  | ||||
| @@ -1791,13 +1779,9 @@ typedef struct | ||||
| #define FPU_MVFR1_FtZ_mode_Pos              0U                                            /*!< MVFR1: FtZ mode bits Position */ | ||||
| #define FPU_MVFR1_FtZ_mode_Msk             (0xFUL /*<< FPU_MVFR1_FtZ_mode_Pos*/)          /*!< MVFR1: FtZ mode bits Mask */ | ||||
|  | ||||
| /* Media and VFP Feature Register 2 Definitions */ | ||||
| #define FPU_MVFR2_FPMisc_Pos                4U                                            /*!< MVFR2: FPMisc bits Position */ | ||||
| #define FPU_MVFR2_FPMisc_Msk               (0xFUL << FPU_MVFR2_FPMisc_Pos)                /*!< MVFR2: FPMisc bits Mask */ | ||||
|  | ||||
| /*@} end of group CMSIS_FPU */ | ||||
|  | ||||
| /* CoreDebug is deprecated. replaced by DCB (Debug Control Block) */ | ||||
|  | ||||
| /** | ||||
|   \ingroup  CMSIS_core_register | ||||
|   \defgroup CMSIS_CoreDebug       Core Debug Registers (CoreDebug) | ||||
| @@ -1806,7 +1790,7 @@ typedef struct | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief  \deprecated Structure type to access the Core Debug Register (CoreDebug). | ||||
|   \brief  Structure type to access the Core Debug Register (CoreDebug). | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
| @@ -1814,354 +1798,124 @@ typedef struct | ||||
|   __OM  uint32_t DCRSR;                  /*!< Offset: 0x004 ( /W)  Debug Core Register Selector Register */ | ||||
|   __IOM uint32_t DCRDR;                  /*!< Offset: 0x008 (R/W)  Debug Core Register Data Register */ | ||||
|   __IOM uint32_t DEMCR;                  /*!< Offset: 0x00C (R/W)  Debug Exception and Monitor Control Register */ | ||||
|         uint32_t RESERVED0[1U]; | ||||
|         uint32_t RESERVED4[1U]; | ||||
|   __IOM uint32_t DAUTHCTRL;              /*!< Offset: 0x014 (R/W)  Debug Authentication Control Register */ | ||||
|   __IOM uint32_t DSCSR;                  /*!< Offset: 0x018 (R/W)  Debug Security Control and Status Register */ | ||||
| } CoreDebug_Type; | ||||
|  | ||||
| /* Debug Halting Control and Status Register Definitions */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Pos         16U                                            /*!< \deprecated CoreDebug DHCSR: DBGKEY Position */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Msk         (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos)       /*!< \deprecated CoreDebug DHCSR: DBGKEY Mask */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Pos         16U                                            /*!< CoreDebug DHCSR: DBGKEY Position */ | ||||
| #define CoreDebug_DHCSR_DBGKEY_Msk         (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos)       /*!< CoreDebug DHCSR: DBGKEY Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Pos   26U                                            /*!< \deprecated CoreDebug DHCSR: S_RESTART_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Msk   (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos)      /*!< \deprecated CoreDebug DHCSR: S_RESTART_ST Mask */ | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Pos   26U                                            /*!< CoreDebug DHCSR: S_RESTART_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESTART_ST_Msk   (1UL << CoreDebug_DHCSR_S_RESTART_ST_Pos)      /*!< CoreDebug DHCSR: S_RESTART_ST Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Pos     25U                                            /*!< \deprecated CoreDebug DHCSR: S_RESET_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Msk     (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos)        /*!< \deprecated CoreDebug DHCSR: S_RESET_ST Mask */ | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Pos     25U                                            /*!< CoreDebug DHCSR: S_RESET_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RESET_ST_Msk     (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos)        /*!< CoreDebug DHCSR: S_RESET_ST Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Pos    24U                                            /*!< \deprecated CoreDebug DHCSR: S_RETIRE_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Msk    (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos)       /*!< \deprecated CoreDebug DHCSR: S_RETIRE_ST Mask */ | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Pos    24U                                            /*!< CoreDebug DHCSR: S_RETIRE_ST Position */ | ||||
| #define CoreDebug_DHCSR_S_RETIRE_ST_Msk    (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos)       /*!< CoreDebug DHCSR: S_RETIRE_ST Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Pos       19U                                            /*!< \deprecated CoreDebug DHCSR: S_LOCKUP Position */ | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Msk       (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos)          /*!< \deprecated CoreDebug DHCSR: S_LOCKUP Mask */ | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Pos       19U                                            /*!< CoreDebug DHCSR: S_LOCKUP Position */ | ||||
| #define CoreDebug_DHCSR_S_LOCKUP_Msk       (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos)          /*!< CoreDebug DHCSR: S_LOCKUP Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Pos        18U                                            /*!< \deprecated CoreDebug DHCSR: S_SLEEP Position */ | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Msk        (1UL << CoreDebug_DHCSR_S_SLEEP_Pos)           /*!< \deprecated CoreDebug DHCSR: S_SLEEP Mask */ | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Pos        18U                                            /*!< CoreDebug DHCSR: S_SLEEP Position */ | ||||
| #define CoreDebug_DHCSR_S_SLEEP_Msk        (1UL << CoreDebug_DHCSR_S_SLEEP_Pos)           /*!< CoreDebug DHCSR: S_SLEEP Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_HALT_Pos         17U                                            /*!< \deprecated CoreDebug DHCSR: S_HALT Position */ | ||||
| #define CoreDebug_DHCSR_S_HALT_Msk         (1UL << CoreDebug_DHCSR_S_HALT_Pos)            /*!< \deprecated CoreDebug DHCSR: S_HALT Mask */ | ||||
| #define CoreDebug_DHCSR_S_HALT_Pos         17U                                            /*!< CoreDebug DHCSR: S_HALT Position */ | ||||
| #define CoreDebug_DHCSR_S_HALT_Msk         (1UL << CoreDebug_DHCSR_S_HALT_Pos)            /*!< CoreDebug DHCSR: S_HALT Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Pos       16U                                            /*!< \deprecated CoreDebug DHCSR: S_REGRDY Position */ | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Msk       (1UL << CoreDebug_DHCSR_S_REGRDY_Pos)          /*!< \deprecated CoreDebug DHCSR: S_REGRDY Mask */ | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Pos       16U                                            /*!< CoreDebug DHCSR: S_REGRDY Position */ | ||||
| #define CoreDebug_DHCSR_S_REGRDY_Msk       (1UL << CoreDebug_DHCSR_S_REGRDY_Pos)          /*!< CoreDebug DHCSR: S_REGRDY Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_SNAPSTALL_Pos     5U                                            /*!< \deprecated CoreDebug DHCSR: C_SNAPSTALL Position */ | ||||
| #define CoreDebug_DHCSR_C_SNAPSTALL_Msk    (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos)       /*!< \deprecated CoreDebug DHCSR: C_SNAPSTALL Mask */ | ||||
| #define CoreDebug_DHCSR_C_SNAPSTALL_Pos     5U                                            /*!< CoreDebug DHCSR: C_SNAPSTALL Position */ | ||||
| #define CoreDebug_DHCSR_C_SNAPSTALL_Msk    (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos)       /*!< CoreDebug DHCSR: C_SNAPSTALL Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Pos      3U                                            /*!< \deprecated CoreDebug DHCSR: C_MASKINTS Position */ | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Msk     (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos)        /*!< \deprecated CoreDebug DHCSR: C_MASKINTS Mask */ | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Pos      3U                                            /*!< CoreDebug DHCSR: C_MASKINTS Position */ | ||||
| #define CoreDebug_DHCSR_C_MASKINTS_Msk     (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos)        /*!< CoreDebug DHCSR: C_MASKINTS Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_STEP_Pos          2U                                            /*!< \deprecated CoreDebug DHCSR: C_STEP Position */ | ||||
| #define CoreDebug_DHCSR_C_STEP_Msk         (1UL << CoreDebug_DHCSR_C_STEP_Pos)            /*!< \deprecated CoreDebug DHCSR: C_STEP Mask */ | ||||
| #define CoreDebug_DHCSR_C_STEP_Pos          2U                                            /*!< CoreDebug DHCSR: C_STEP Position */ | ||||
| #define CoreDebug_DHCSR_C_STEP_Msk         (1UL << CoreDebug_DHCSR_C_STEP_Pos)            /*!< CoreDebug DHCSR: C_STEP Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_HALT_Pos          1U                                            /*!< \deprecated CoreDebug DHCSR: C_HALT Position */ | ||||
| #define CoreDebug_DHCSR_C_HALT_Msk         (1UL << CoreDebug_DHCSR_C_HALT_Pos)            /*!< \deprecated CoreDebug DHCSR: C_HALT Mask */ | ||||
| #define CoreDebug_DHCSR_C_HALT_Pos          1U                                            /*!< CoreDebug DHCSR: C_HALT Position */ | ||||
| #define CoreDebug_DHCSR_C_HALT_Msk         (1UL << CoreDebug_DHCSR_C_HALT_Pos)            /*!< CoreDebug DHCSR: C_HALT Mask */ | ||||
|  | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Pos       0U                                            /*!< \deprecated CoreDebug DHCSR: C_DEBUGEN Position */ | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Msk      (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/)     /*!< \deprecated CoreDebug DHCSR: C_DEBUGEN Mask */ | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Pos       0U                                            /*!< CoreDebug DHCSR: C_DEBUGEN Position */ | ||||
| #define CoreDebug_DHCSR_C_DEBUGEN_Msk      (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/)     /*!< CoreDebug DHCSR: C_DEBUGEN Mask */ | ||||
|  | ||||
| /* Debug Core Register Selector Register Definitions */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Pos         16U                                            /*!< \deprecated CoreDebug DCRSR: REGWnR Position */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Msk         (1UL << CoreDebug_DCRSR_REGWnR_Pos)            /*!< \deprecated CoreDebug DCRSR: REGWnR Mask */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Pos         16U                                            /*!< CoreDebug DCRSR: REGWnR Position */ | ||||
| #define CoreDebug_DCRSR_REGWnR_Msk         (1UL << CoreDebug_DCRSR_REGWnR_Pos)            /*!< CoreDebug DCRSR: REGWnR Mask */ | ||||
|  | ||||
| #define CoreDebug_DCRSR_REGSEL_Pos          0U                                            /*!< \deprecated CoreDebug DCRSR: REGSEL Position */ | ||||
| #define CoreDebug_DCRSR_REGSEL_Msk         (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/)     /*!< \deprecated CoreDebug DCRSR: REGSEL Mask */ | ||||
| #define CoreDebug_DCRSR_REGSEL_Pos          0U                                            /*!< CoreDebug DCRSR: REGSEL Position */ | ||||
| #define CoreDebug_DCRSR_REGSEL_Msk         (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/)     /*!< CoreDebug DCRSR: REGSEL Mask */ | ||||
|  | ||||
| /* Debug Exception and Monitor Control Register Definitions */ | ||||
| #define CoreDebug_DEMCR_TRCENA_Pos         24U                                            /*!< \deprecated CoreDebug DEMCR: TRCENA Position */ | ||||
| #define CoreDebug_DEMCR_TRCENA_Msk         (1UL << CoreDebug_DEMCR_TRCENA_Pos)            /*!< \deprecated CoreDebug DEMCR: TRCENA Mask */ | ||||
| #define CoreDebug_DEMCR_TRCENA_Pos         24U                                            /*!< CoreDebug DEMCR: TRCENA Position */ | ||||
| #define CoreDebug_DEMCR_TRCENA_Msk         (1UL << CoreDebug_DEMCR_TRCENA_Pos)            /*!< CoreDebug DEMCR: TRCENA Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_MON_REQ_Pos        19U                                            /*!< \deprecated CoreDebug DEMCR: MON_REQ Position */ | ||||
| #define CoreDebug_DEMCR_MON_REQ_Msk        (1UL << CoreDebug_DEMCR_MON_REQ_Pos)           /*!< \deprecated CoreDebug DEMCR: MON_REQ Mask */ | ||||
| #define CoreDebug_DEMCR_MON_REQ_Pos        19U                                            /*!< CoreDebug DEMCR: MON_REQ Position */ | ||||
| #define CoreDebug_DEMCR_MON_REQ_Msk        (1UL << CoreDebug_DEMCR_MON_REQ_Pos)           /*!< CoreDebug DEMCR: MON_REQ Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_MON_STEP_Pos       18U                                            /*!< \deprecated CoreDebug DEMCR: MON_STEP Position */ | ||||
| #define CoreDebug_DEMCR_MON_STEP_Msk       (1UL << CoreDebug_DEMCR_MON_STEP_Pos)          /*!< \deprecated CoreDebug DEMCR: MON_STEP Mask */ | ||||
| #define CoreDebug_DEMCR_MON_STEP_Pos       18U                                            /*!< CoreDebug DEMCR: MON_STEP Position */ | ||||
| #define CoreDebug_DEMCR_MON_STEP_Msk       (1UL << CoreDebug_DEMCR_MON_STEP_Pos)          /*!< CoreDebug DEMCR: MON_STEP Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_MON_PEND_Pos       17U                                            /*!< \deprecated CoreDebug DEMCR: MON_PEND Position */ | ||||
| #define CoreDebug_DEMCR_MON_PEND_Msk       (1UL << CoreDebug_DEMCR_MON_PEND_Pos)          /*!< \deprecated CoreDebug DEMCR: MON_PEND Mask */ | ||||
| #define CoreDebug_DEMCR_MON_PEND_Pos       17U                                            /*!< CoreDebug DEMCR: MON_PEND Position */ | ||||
| #define CoreDebug_DEMCR_MON_PEND_Msk       (1UL << CoreDebug_DEMCR_MON_PEND_Pos)          /*!< CoreDebug DEMCR: MON_PEND Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_MON_EN_Pos         16U                                            /*!< \deprecated CoreDebug DEMCR: MON_EN Position */ | ||||
| #define CoreDebug_DEMCR_MON_EN_Msk         (1UL << CoreDebug_DEMCR_MON_EN_Pos)            /*!< \deprecated CoreDebug DEMCR: MON_EN Mask */ | ||||
| #define CoreDebug_DEMCR_MON_EN_Pos         16U                                            /*!< CoreDebug DEMCR: MON_EN Position */ | ||||
| #define CoreDebug_DEMCR_MON_EN_Msk         (1UL << CoreDebug_DEMCR_MON_EN_Pos)            /*!< CoreDebug DEMCR: MON_EN Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Pos     10U                                            /*!< \deprecated CoreDebug DEMCR: VC_HARDERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Msk     (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos)        /*!< \deprecated CoreDebug DEMCR: VC_HARDERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Pos     10U                                            /*!< CoreDebug DEMCR: VC_HARDERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_HARDERR_Msk     (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos)        /*!< CoreDebug DEMCR: VC_HARDERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_INTERR_Pos       9U                                            /*!< \deprecated CoreDebug DEMCR: VC_INTERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_INTERR_Msk      (1UL << CoreDebug_DEMCR_VC_INTERR_Pos)         /*!< \deprecated CoreDebug DEMCR: VC_INTERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_INTERR_Pos       9U                                            /*!< CoreDebug DEMCR: VC_INTERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_INTERR_Msk      (1UL << CoreDebug_DEMCR_VC_INTERR_Pos)         /*!< CoreDebug DEMCR: VC_INTERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_BUSERR_Pos       8U                                            /*!< \deprecated CoreDebug DEMCR: VC_BUSERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_BUSERR_Msk      (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos)         /*!< \deprecated CoreDebug DEMCR: VC_BUSERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_BUSERR_Pos       8U                                            /*!< CoreDebug DEMCR: VC_BUSERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_BUSERR_Msk      (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos)         /*!< CoreDebug DEMCR: VC_BUSERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_STATERR_Pos      7U                                            /*!< \deprecated CoreDebug DEMCR: VC_STATERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_STATERR_Msk     (1UL << CoreDebug_DEMCR_VC_STATERR_Pos)        /*!< \deprecated CoreDebug DEMCR: VC_STATERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_STATERR_Pos      7U                                            /*!< CoreDebug DEMCR: VC_STATERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_STATERR_Msk     (1UL << CoreDebug_DEMCR_VC_STATERR_Pos)        /*!< CoreDebug DEMCR: VC_STATERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_CHKERR_Pos       6U                                            /*!< \deprecated CoreDebug DEMCR: VC_CHKERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_CHKERR_Msk      (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos)         /*!< \deprecated CoreDebug DEMCR: VC_CHKERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_CHKERR_Pos       6U                                            /*!< CoreDebug DEMCR: VC_CHKERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_CHKERR_Msk      (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos)         /*!< CoreDebug DEMCR: VC_CHKERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_NOCPERR_Pos      5U                                            /*!< \deprecated CoreDebug DEMCR: VC_NOCPERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_NOCPERR_Msk     (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos)        /*!< \deprecated CoreDebug DEMCR: VC_NOCPERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_NOCPERR_Pos      5U                                            /*!< CoreDebug DEMCR: VC_NOCPERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_NOCPERR_Msk     (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos)        /*!< CoreDebug DEMCR: VC_NOCPERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_MMERR_Pos        4U                                            /*!< \deprecated CoreDebug DEMCR: VC_MMERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_MMERR_Msk       (1UL << CoreDebug_DEMCR_VC_MMERR_Pos)          /*!< \deprecated CoreDebug DEMCR: VC_MMERR Mask */ | ||||
| #define CoreDebug_DEMCR_VC_MMERR_Pos        4U                                            /*!< CoreDebug DEMCR: VC_MMERR Position */ | ||||
| #define CoreDebug_DEMCR_VC_MMERR_Msk       (1UL << CoreDebug_DEMCR_VC_MMERR_Pos)          /*!< CoreDebug DEMCR: VC_MMERR Mask */ | ||||
|  | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Pos    0U                                            /*!< \deprecated CoreDebug DEMCR: VC_CORERESET Position */ | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Msk   (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/)  /*!< \deprecated CoreDebug DEMCR: VC_CORERESET Mask */ | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Pos    0U                                            /*!< CoreDebug DEMCR: VC_CORERESET Position */ | ||||
| #define CoreDebug_DEMCR_VC_CORERESET_Msk   (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/)  /*!< CoreDebug DEMCR: VC_CORERESET Mask */ | ||||
|  | ||||
| /* Debug Authentication Control Register Definitions */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos  3U                                            /*!< \deprecated CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos)    /*!< \deprecated CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos  3U                                            /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPNIDEN_Msk (1UL << CoreDebug_DAUTHCTRL_INTSPNIDEN_Pos)    /*!< CoreDebug DAUTHCTRL: INTSPNIDEN, Mask */ | ||||
|  | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos  2U                                            /*!< \deprecated CoreDebug DAUTHCTRL: SPNIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos)    /*!< \deprecated CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos  2U                                            /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPNIDENSEL_Msk (1UL << CoreDebug_DAUTHCTRL_SPNIDENSEL_Pos)    /*!< CoreDebug DAUTHCTRL: SPNIDENSEL Mask */ | ||||
|  | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos   1U                                            /*!< \deprecated CoreDebug DAUTHCTRL: INTSPIDEN Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk  (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos)     /*!< \deprecated CoreDebug DAUTHCTRL: INTSPIDEN Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Pos   1U                                            /*!< CoreDebug DAUTHCTRL: INTSPIDEN Position */ | ||||
| #define CoreDebug_DAUTHCTRL_INTSPIDEN_Msk  (1UL << CoreDebug_DAUTHCTRL_INTSPIDEN_Pos)     /*!< CoreDebug DAUTHCTRL: INTSPIDEN Mask */ | ||||
|  | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos   0U                                            /*!< \deprecated CoreDebug DAUTHCTRL: SPIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk  (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< \deprecated CoreDebug DAUTHCTRL: SPIDENSEL Mask */ | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Pos   0U                                            /*!< CoreDebug DAUTHCTRL: SPIDENSEL Position */ | ||||
| #define CoreDebug_DAUTHCTRL_SPIDENSEL_Msk  (1UL /*<< CoreDebug_DAUTHCTRL_SPIDENSEL_Pos*/) /*!< CoreDebug DAUTHCTRL: SPIDENSEL Mask */ | ||||
|  | ||||
| /* Debug Security Control and Status Register Definitions */ | ||||
| #define CoreDebug_DSCSR_CDS_Pos            16U                                            /*!< \deprecated CoreDebug DSCSR: CDS Position */ | ||||
| #define CoreDebug_DSCSR_CDS_Msk            (1UL << CoreDebug_DSCSR_CDS_Pos)               /*!< \deprecated CoreDebug DSCSR: CDS Mask */ | ||||
| #define CoreDebug_DSCSR_CDS_Pos            16U                                            /*!< CoreDebug DSCSR: CDS Position */ | ||||
| #define CoreDebug_DSCSR_CDS_Msk            (1UL << CoreDebug_DSCSR_CDS_Pos)               /*!< CoreDebug DSCSR: CDS Mask */ | ||||
|  | ||||
| #define CoreDebug_DSCSR_SBRSEL_Pos          1U                                            /*!< \deprecated CoreDebug DSCSR: SBRSEL Position */ | ||||
| #define CoreDebug_DSCSR_SBRSEL_Msk         (1UL << CoreDebug_DSCSR_SBRSEL_Pos)            /*!< \deprecated CoreDebug DSCSR: SBRSEL Mask */ | ||||
| #define CoreDebug_DSCSR_SBRSEL_Pos          1U                                            /*!< CoreDebug DSCSR: SBRSEL Position */ | ||||
| #define CoreDebug_DSCSR_SBRSEL_Msk         (1UL << CoreDebug_DSCSR_SBRSEL_Pos)            /*!< CoreDebug DSCSR: SBRSEL Mask */ | ||||
|  | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Pos        0U                                            /*!< \deprecated CoreDebug DSCSR: SBRSELEN Position */ | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Msk       (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/)      /*!< \deprecated CoreDebug DSCSR: SBRSELEN Mask */ | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Pos        0U                                            /*!< CoreDebug DSCSR: SBRSELEN Position */ | ||||
| #define CoreDebug_DSCSR_SBRSELEN_Msk       (1UL /*<< CoreDebug_DSCSR_SBRSELEN_Pos*/)      /*!< CoreDebug DSCSR: SBRSELEN Mask */ | ||||
|  | ||||
| /*@} end of group CMSIS_CoreDebug */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup    CMSIS_core_register | ||||
|   \defgroup CMSIS_DCB       Debug Control Block | ||||
|   \brief    Type definitions for the Debug Control Block Registers | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief  Structure type to access the Debug Control Block Registers (DCB). | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
|   __IOM uint32_t DHCSR;                  /*!< Offset: 0x000 (R/W)  Debug Halting Control and Status Register */ | ||||
|   __OM  uint32_t DCRSR;                  /*!< Offset: 0x004 ( /W)  Debug Core Register Selector Register */ | ||||
|   __IOM uint32_t DCRDR;                  /*!< Offset: 0x008 (R/W)  Debug Core Register Data Register */ | ||||
|   __IOM uint32_t DEMCR;                  /*!< Offset: 0x00C (R/W)  Debug Exception and Monitor Control Register */ | ||||
|         uint32_t RESERVED0[1U]; | ||||
|   __IOM uint32_t DAUTHCTRL;              /*!< Offset: 0x014 (R/W)  Debug Authentication Control Register */ | ||||
|   __IOM uint32_t DSCSR;                  /*!< Offset: 0x018 (R/W)  Debug Security Control and Status Register */ | ||||
| } DCB_Type; | ||||
|  | ||||
| /* DHCSR, Debug Halting Control and Status Register Definitions */ | ||||
| #define DCB_DHCSR_DBGKEY_Pos               16U                                            /*!< DCB DHCSR: Debug key Position */ | ||||
| #define DCB_DHCSR_DBGKEY_Msk               (0xFFFFUL << DCB_DHCSR_DBGKEY_Pos)             /*!< DCB DHCSR: Debug key Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_RESTART_ST_Pos         26U                                            /*!< DCB DHCSR: Restart sticky status Position */ | ||||
| #define DCB_DHCSR_S_RESTART_ST_Msk         (0x1UL << DCB_DHCSR_S_RESTART_ST_Pos)          /*!< DCB DHCSR: Restart sticky status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_RESET_ST_Pos           25U                                            /*!< DCB DHCSR: Reset sticky status Position */ | ||||
| #define DCB_DHCSR_S_RESET_ST_Msk           (0x1UL << DCB_DHCSR_S_RESET_ST_Pos)            /*!< DCB DHCSR: Reset sticky status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_RETIRE_ST_Pos          24U                                            /*!< DCB DHCSR: Retire sticky status Position */ | ||||
| #define DCB_DHCSR_S_RETIRE_ST_Msk          (0x1UL << DCB_DHCSR_S_RETIRE_ST_Pos)           /*!< DCB DHCSR: Retire sticky status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_SDE_Pos                20U                                            /*!< DCB DHCSR: Secure debug enabled Position */ | ||||
| #define DCB_DHCSR_S_SDE_Msk                (0x1UL << DCB_DHCSR_S_SDE_Pos)                 /*!< DCB DHCSR: Secure debug enabled Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_LOCKUP_Pos             19U                                            /*!< DCB DHCSR: Lockup status Position */ | ||||
| #define DCB_DHCSR_S_LOCKUP_Msk             (0x1UL << DCB_DHCSR_S_LOCKUP_Pos)              /*!< DCB DHCSR: Lockup status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_SLEEP_Pos              18U                                            /*!< DCB DHCSR: Sleeping status Position */ | ||||
| #define DCB_DHCSR_S_SLEEP_Msk              (0x1UL << DCB_DHCSR_S_SLEEP_Pos)               /*!< DCB DHCSR: Sleeping status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_HALT_Pos               17U                                            /*!< DCB DHCSR: Halted status Position */ | ||||
| #define DCB_DHCSR_S_HALT_Msk               (0x1UL << DCB_DHCSR_S_HALT_Pos)                /*!< DCB DHCSR: Halted status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_S_REGRDY_Pos             16U                                            /*!< DCB DHCSR: Register ready status Position */ | ||||
| #define DCB_DHCSR_S_REGRDY_Msk             (0x1UL << DCB_DHCSR_S_REGRDY_Pos)              /*!< DCB DHCSR: Register ready status Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_SNAPSTALL_Pos           5U                                            /*!< DCB DHCSR: Snap stall control Position */ | ||||
| #define DCB_DHCSR_C_SNAPSTALL_Msk          (0x1UL << DCB_DHCSR_C_SNAPSTALL_Pos)           /*!< DCB DHCSR: Snap stall control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_MASKINTS_Pos            3U                                            /*!< DCB DHCSR: Mask interrupts control Position */ | ||||
| #define DCB_DHCSR_C_MASKINTS_Msk           (0x1UL << DCB_DHCSR_C_MASKINTS_Pos)            /*!< DCB DHCSR: Mask interrupts control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_STEP_Pos                2U                                            /*!< DCB DHCSR: Step control Position */ | ||||
| #define DCB_DHCSR_C_STEP_Msk               (0x1UL << DCB_DHCSR_C_STEP_Pos)                /*!< DCB DHCSR: Step control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_HALT_Pos                1U                                            /*!< DCB DHCSR: Halt control Position */ | ||||
| #define DCB_DHCSR_C_HALT_Msk               (0x1UL << DCB_DHCSR_C_HALT_Pos)                /*!< DCB DHCSR: Halt control Mask */ | ||||
|  | ||||
| #define DCB_DHCSR_C_DEBUGEN_Pos             0U                                            /*!< DCB DHCSR: Debug enable control Position */ | ||||
| #define DCB_DHCSR_C_DEBUGEN_Msk            (0x1UL /*<< DCB_DHCSR_C_DEBUGEN_Pos*/)         /*!< DCB DHCSR: Debug enable control Mask */ | ||||
|  | ||||
| /* DCRSR, Debug Core Register Select Register Definitions */ | ||||
| #define DCB_DCRSR_REGWnR_Pos               16U                                            /*!< DCB DCRSR: Register write/not-read Position */ | ||||
| #define DCB_DCRSR_REGWnR_Msk               (0x1UL << DCB_DCRSR_REGWnR_Pos)                /*!< DCB DCRSR: Register write/not-read Mask */ | ||||
|  | ||||
| #define DCB_DCRSR_REGSEL_Pos                0U                                            /*!< DCB DCRSR: Register selector Position */ | ||||
| #define DCB_DCRSR_REGSEL_Msk               (0x7FUL /*<< DCB_DCRSR_REGSEL_Pos*/)           /*!< DCB DCRSR: Register selector Mask */ | ||||
|  | ||||
| /* DCRDR, Debug Core Register Data Register Definitions */ | ||||
| #define DCB_DCRDR_DBGTMP_Pos                0U                                            /*!< DCB DCRDR: Data temporary buffer Position */ | ||||
| #define DCB_DCRDR_DBGTMP_Msk               (0xFFFFFFFFUL /*<< DCB_DCRDR_DBGTMP_Pos*/)     /*!< DCB DCRDR: Data temporary buffer Mask */ | ||||
|  | ||||
| /* DEMCR, Debug Exception and Monitor Control Register Definitions */ | ||||
| #define DCB_DEMCR_TRCENA_Pos               24U                                            /*!< DCB DEMCR: Trace enable Position */ | ||||
| #define DCB_DEMCR_TRCENA_Msk               (0x1UL << DCB_DEMCR_TRCENA_Pos)                /*!< DCB DEMCR: Trace enable Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_MONPRKEY_Pos             23U                                            /*!< DCB DEMCR: Monitor pend req key Position */ | ||||
| #define DCB_DEMCR_MONPRKEY_Msk             (0x1UL << DCB_DEMCR_MONPRKEY_Pos)              /*!< DCB DEMCR: Monitor pend req key Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_UMON_EN_Pos              21U                                            /*!< DCB DEMCR: Unprivileged monitor enable Position */ | ||||
| #define DCB_DEMCR_UMON_EN_Msk              (0x1UL << DCB_DEMCR_UMON_EN_Pos)               /*!< DCB DEMCR: Unprivileged monitor enable Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_SDME_Pos                 20U                                            /*!< DCB DEMCR: Secure DebugMonitor enable Position */ | ||||
| #define DCB_DEMCR_SDME_Msk                 (0x1UL << DCB_DEMCR_SDME_Pos)                  /*!< DCB DEMCR: Secure DebugMonitor enable Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_MON_REQ_Pos              19U                                            /*!< DCB DEMCR: Monitor request Position */ | ||||
| #define DCB_DEMCR_MON_REQ_Msk              (0x1UL << DCB_DEMCR_MON_REQ_Pos)               /*!< DCB DEMCR: Monitor request Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_MON_STEP_Pos             18U                                            /*!< DCB DEMCR: Monitor step Position */ | ||||
| #define DCB_DEMCR_MON_STEP_Msk             (0x1UL << DCB_DEMCR_MON_STEP_Pos)              /*!< DCB DEMCR: Monitor step Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_MON_PEND_Pos             17U                                            /*!< DCB DEMCR: Monitor pend Position */ | ||||
| #define DCB_DEMCR_MON_PEND_Msk             (0x1UL << DCB_DEMCR_MON_PEND_Pos)              /*!< DCB DEMCR: Monitor pend Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_MON_EN_Pos               16U                                            /*!< DCB DEMCR: Monitor enable Position */ | ||||
| #define DCB_DEMCR_MON_EN_Msk               (0x1UL << DCB_DEMCR_MON_EN_Pos)                /*!< DCB DEMCR: Monitor enable Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_SFERR_Pos             11U                                            /*!< DCB DEMCR: Vector Catch SecureFault Position */ | ||||
| #define DCB_DEMCR_VC_SFERR_Msk             (0x1UL << DCB_DEMCR_VC_SFERR_Pos)              /*!< DCB DEMCR: Vector Catch SecureFault Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_HARDERR_Pos           10U                                            /*!< DCB DEMCR: Vector Catch HardFault errors Position */ | ||||
| #define DCB_DEMCR_VC_HARDERR_Msk           (0x1UL << DCB_DEMCR_VC_HARDERR_Pos)            /*!< DCB DEMCR: Vector Catch HardFault errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_INTERR_Pos             9U                                            /*!< DCB DEMCR: Vector Catch interrupt errors Position */ | ||||
| #define DCB_DEMCR_VC_INTERR_Msk            (0x1UL << DCB_DEMCR_VC_INTERR_Pos)             /*!< DCB DEMCR: Vector Catch interrupt errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_BUSERR_Pos             8U                                            /*!< DCB DEMCR: Vector Catch BusFault errors Position */ | ||||
| #define DCB_DEMCR_VC_BUSERR_Msk            (0x1UL << DCB_DEMCR_VC_BUSERR_Pos)             /*!< DCB DEMCR: Vector Catch BusFault errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_STATERR_Pos            7U                                            /*!< DCB DEMCR: Vector Catch state errors Position */ | ||||
| #define DCB_DEMCR_VC_STATERR_Msk           (0x1UL << DCB_DEMCR_VC_STATERR_Pos)            /*!< DCB DEMCR: Vector Catch state errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_CHKERR_Pos             6U                                            /*!< DCB DEMCR: Vector Catch check errors Position */ | ||||
| #define DCB_DEMCR_VC_CHKERR_Msk            (0x1UL << DCB_DEMCR_VC_CHKERR_Pos)             /*!< DCB DEMCR: Vector Catch check errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_NOCPERR_Pos            5U                                            /*!< DCB DEMCR: Vector Catch NOCP errors Position */ | ||||
| #define DCB_DEMCR_VC_NOCPERR_Msk           (0x1UL << DCB_DEMCR_VC_NOCPERR_Pos)            /*!< DCB DEMCR: Vector Catch NOCP errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_MMERR_Pos              4U                                            /*!< DCB DEMCR: Vector Catch MemManage errors Position */ | ||||
| #define DCB_DEMCR_VC_MMERR_Msk             (0x1UL << DCB_DEMCR_VC_MMERR_Pos)              /*!< DCB DEMCR: Vector Catch MemManage errors Mask */ | ||||
|  | ||||
| #define DCB_DEMCR_VC_CORERESET_Pos          0U                                            /*!< DCB DEMCR: Vector Catch Core reset Position */ | ||||
| #define DCB_DEMCR_VC_CORERESET_Msk         (0x1UL /*<< DCB_DEMCR_VC_CORERESET_Pos*/)      /*!< DCB DEMCR: Vector Catch Core reset Mask */ | ||||
|  | ||||
| /* DAUTHCTRL, Debug Authentication Control Register Definitions */ | ||||
| #define DCB_DAUTHCTRL_INTSPNIDEN_Pos        3U                                            /*!< DCB DAUTHCTRL: Internal Secure non-invasive debug enable Position */ | ||||
| #define DCB_DAUTHCTRL_INTSPNIDEN_Msk       (0x1UL << DCB_DAUTHCTRL_INTSPNIDEN_Pos)        /*!< DCB DAUTHCTRL: Internal Secure non-invasive debug enable Mask */ | ||||
|  | ||||
| #define DCB_DAUTHCTRL_SPNIDENSEL_Pos        2U                                            /*!< DCB DAUTHCTRL: Secure non-invasive debug enable select Position */ | ||||
| #define DCB_DAUTHCTRL_SPNIDENSEL_Msk       (0x1UL << DCB_DAUTHCTRL_SPNIDENSEL_Pos)        /*!< DCB DAUTHCTRL: Secure non-invasive debug enable select Mask */ | ||||
|  | ||||
| #define DCB_DAUTHCTRL_INTSPIDEN_Pos         1U                                            /*!< DCB DAUTHCTRL: Internal Secure invasive debug enable Position */ | ||||
| #define DCB_DAUTHCTRL_INTSPIDEN_Msk        (0x1UL << DCB_DAUTHCTRL_INTSPIDEN_Pos)         /*!< DCB DAUTHCTRL: Internal Secure invasive debug enable Mask */ | ||||
|  | ||||
| #define DCB_DAUTHCTRL_SPIDENSEL_Pos         0U                                            /*!< DCB DAUTHCTRL: Secure invasive debug enable select Position */ | ||||
| #define DCB_DAUTHCTRL_SPIDENSEL_Msk        (0x1UL /*<< DCB_DAUTHCTRL_SPIDENSEL_Pos*/)     /*!< DCB DAUTHCTRL: Secure invasive debug enable select Mask */ | ||||
|  | ||||
| /* DSCSR, Debug Security Control and Status Register Definitions */ | ||||
| #define DCB_DSCSR_CDSKEY_Pos               17U                                            /*!< DCB DSCSR: CDS write-enable key Position */ | ||||
| #define DCB_DSCSR_CDSKEY_Msk               (0x1UL << DCB_DSCSR_CDSKEY_Pos)                /*!< DCB DSCSR: CDS write-enable key Mask */ | ||||
|  | ||||
| #define DCB_DSCSR_CDS_Pos                  16U                                            /*!< DCB DSCSR: Current domain Secure Position */ | ||||
| #define DCB_DSCSR_CDS_Msk                  (0x1UL << DCB_DSCSR_CDS_Pos)                   /*!< DCB DSCSR: Current domain Secure Mask */ | ||||
|  | ||||
| #define DCB_DSCSR_SBRSEL_Pos                1U                                            /*!< DCB DSCSR: Secure banked register select Position */ | ||||
| #define DCB_DSCSR_SBRSEL_Msk               (0x1UL << DCB_DSCSR_SBRSEL_Pos)                /*!< DCB DSCSR: Secure banked register select Mask */ | ||||
|  | ||||
| #define DCB_DSCSR_SBRSELEN_Pos              0U                                            /*!< DCB DSCSR: Secure banked register select enable Position */ | ||||
| #define DCB_DSCSR_SBRSELEN_Msk             (0x1UL /*<< DCB_DSCSR_SBRSELEN_Pos*/)          /*!< DCB DSCSR: Secure banked register select enable Mask */ | ||||
|  | ||||
| /*@} end of group CMSIS_DCB */ | ||||
|  | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup  CMSIS_core_register | ||||
|   \defgroup CMSIS_DIB       Debug Identification Block | ||||
|   \brief    Type definitions for the Debug Identification Block Registers | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|   \brief  Structure type to access the Debug Identification Block Registers (DIB). | ||||
|  */ | ||||
| typedef struct | ||||
| { | ||||
|   __OM  uint32_t DLAR;                   /*!< Offset: 0x000 ( /W)  SCS Software Lock Access Register */ | ||||
|   __IM  uint32_t DLSR;                   /*!< Offset: 0x004 (R/ )  SCS Software Lock Status Register */ | ||||
|   __IM  uint32_t DAUTHSTATUS;            /*!< Offset: 0x008 (R/ )  Debug Authentication Status Register */ | ||||
|   __IM  uint32_t DDEVARCH;               /*!< Offset: 0x00C (R/ )  SCS Device Architecture Register */ | ||||
|   __IM  uint32_t DDEVTYPE;               /*!< Offset: 0x010 (R/ )  SCS Device Type Register */ | ||||
| } DIB_Type; | ||||
|  | ||||
| /* DLAR, SCS Software Lock Access Register Definitions */ | ||||
| #define DIB_DLAR_KEY_Pos                    0U                                            /*!< DIB DLAR: KEY Position */ | ||||
| #define DIB_DLAR_KEY_Msk                   (0xFFFFFFFFUL /*<< DIB_DLAR_KEY_Pos */)        /*!< DIB DLAR: KEY Mask */ | ||||
|  | ||||
| /* DLSR, SCS Software Lock Status Register Definitions */ | ||||
| #define DIB_DLSR_nTT_Pos                    2U                                            /*!< DIB DLSR: Not thirty-two bit Position */ | ||||
| #define DIB_DLSR_nTT_Msk                   (0x1UL << DIB_DLSR_nTT_Pos )                   /*!< DIB DLSR: Not thirty-two bit Mask */ | ||||
|  | ||||
| #define DIB_DLSR_SLK_Pos                    1U                                            /*!< DIB DLSR: Software Lock status Position */ | ||||
| #define DIB_DLSR_SLK_Msk                   (0x1UL << DIB_DLSR_SLK_Pos )                   /*!< DIB DLSR: Software Lock status Mask */ | ||||
|  | ||||
| #define DIB_DLSR_SLI_Pos                    0U                                            /*!< DIB DLSR: Software Lock implemented Position */ | ||||
| #define DIB_DLSR_SLI_Msk                   (0x1UL /*<< DIB_DLSR_SLI_Pos*/)                /*!< DIB DLSR: Software Lock implemented Mask */ | ||||
|  | ||||
| /* DAUTHSTATUS, Debug Authentication Status Register Definitions */ | ||||
| #define DIB_DAUTHSTATUS_SNID_Pos            6U                                            /*!< DIB DAUTHSTATUS: Secure Non-invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_SNID_Msk           (0x3UL << DIB_DAUTHSTATUS_SNID_Pos )           /*!< DIB DAUTHSTATUS: Secure Non-invasive Debug Mask */ | ||||
|  | ||||
| #define DIB_DAUTHSTATUS_SID_Pos             4U                                            /*!< DIB DAUTHSTATUS: Secure Invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_SID_Msk            (0x3UL << DIB_DAUTHSTATUS_SID_Pos )            /*!< DIB DAUTHSTATUS: Secure Invasive Debug Mask */ | ||||
|  | ||||
| #define DIB_DAUTHSTATUS_NSNID_Pos           2U                                            /*!< DIB DAUTHSTATUS: Non-secure Non-invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_NSNID_Msk          (0x3UL << DIB_DAUTHSTATUS_NSNID_Pos )          /*!< DIB DAUTHSTATUS: Non-secure Non-invasive Debug Mask */ | ||||
|  | ||||
| #define DIB_DAUTHSTATUS_NSID_Pos            0U                                            /*!< DIB DAUTHSTATUS: Non-secure Invasive Debug Position */ | ||||
| #define DIB_DAUTHSTATUS_NSID_Msk           (0x3UL /*<< DIB_DAUTHSTATUS_NSID_Pos*/)        /*!< DIB DAUTHSTATUS: Non-secure Invasive Debug Mask */ | ||||
|  | ||||
| /* DDEVARCH, SCS Device Architecture Register Definitions */ | ||||
| #define DIB_DDEVARCH_ARCHITECT_Pos         21U                                            /*!< DIB DDEVARCH: Architect Position */ | ||||
| #define DIB_DDEVARCH_ARCHITECT_Msk         (0x7FFUL << DIB_DDEVARCH_ARCHITECT_Pos )       /*!< DIB DDEVARCH: Architect Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_PRESENT_Pos           20U                                            /*!< DIB DDEVARCH: DEVARCH Present Position */ | ||||
| #define DIB_DDEVARCH_PRESENT_Msk           (0x1FUL << DIB_DDEVARCH_PRESENT_Pos )          /*!< DIB DDEVARCH: DEVARCH Present Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_REVISION_Pos          16U                                            /*!< DIB DDEVARCH: Revision Position */ | ||||
| #define DIB_DDEVARCH_REVISION_Msk          (0xFUL << DIB_DDEVARCH_REVISION_Pos )          /*!< DIB DDEVARCH: Revision Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_ARCHVER_Pos           12U                                            /*!< DIB DDEVARCH: Architecture Version Position */ | ||||
| #define DIB_DDEVARCH_ARCHVER_Msk           (0xFUL << DIB_DDEVARCH_ARCHVER_Pos )           /*!< DIB DDEVARCH: Architecture Version Mask */ | ||||
|  | ||||
| #define DIB_DDEVARCH_ARCHPART_Pos           0U                                            /*!< DIB DDEVARCH: Architecture Part Position */ | ||||
| #define DIB_DDEVARCH_ARCHPART_Msk          (0xFFFUL /*<< DIB_DDEVARCH_ARCHPART_Pos*/)     /*!< DIB DDEVARCH: Architecture Part Mask */ | ||||
|  | ||||
| /* DDEVTYPE, SCS Device Type Register Definitions */ | ||||
| #define DIB_DDEVTYPE_SUB_Pos                4U                                            /*!< DIB DDEVTYPE: Sub-type Position */ | ||||
| #define DIB_DDEVTYPE_SUB_Msk               (0xFUL << DIB_DDEVTYPE_SUB_Pos )               /*!< DIB DDEVTYPE: Sub-type Mask */ | ||||
|  | ||||
| #define DIB_DDEVTYPE_MAJOR_Pos              0U                                            /*!< DIB DDEVTYPE: Major type Position */ | ||||
| #define DIB_DDEVTYPE_MAJOR_Msk             (0xFUL /*<< DIB_DDEVTYPE_MAJOR_Pos*/)          /*!< DIB DDEVTYPE: Major type Mask */ | ||||
|  | ||||
|  | ||||
| /*@} end of group CMSIS_DIB */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup    CMSIS_core_register | ||||
|   \defgroup   CMSIS_core_bitfield     Core register bit field macros | ||||
| @@ -2200,9 +1954,7 @@ typedef struct | ||||
|   #define ITM_BASE            (0xE0000000UL)                             /*!< ITM Base Address */ | ||||
|   #define DWT_BASE            (0xE0001000UL)                             /*!< DWT Base Address */ | ||||
|   #define TPI_BASE            (0xE0040000UL)                             /*!< TPI Base Address */ | ||||
|   #define CoreDebug_BASE      (0xE000EDF0UL)                             /*!< \deprecated Core Debug Base Address */ | ||||
|   #define DCB_BASE            (0xE000EDF0UL)                             /*!< DCB Base Address */ | ||||
|   #define DIB_BASE            (0xE000EFB0UL)                             /*!< DIB Base Address */ | ||||
|   #define CoreDebug_BASE      (0xE000EDF0UL)                             /*!< Core Debug Base Address */ | ||||
|   #define SysTick_BASE        (SCS_BASE +  0x0010UL)                     /*!< SysTick Base Address */ | ||||
|   #define NVIC_BASE           (SCS_BASE +  0x0100UL)                     /*!< NVIC Base Address */ | ||||
|   #define SCB_BASE            (SCS_BASE +  0x0D00UL)                     /*!< System Control Block Base Address */ | ||||
| @@ -2214,9 +1966,7 @@ typedef struct | ||||
|   #define ITM                 ((ITM_Type       *)     ITM_BASE         ) /*!< ITM configuration struct */ | ||||
|   #define DWT                 ((DWT_Type       *)     DWT_BASE         ) /*!< DWT configuration struct */ | ||||
|   #define TPI                 ((TPI_Type       *)     TPI_BASE         ) /*!< TPI configuration struct */ | ||||
|   #define CoreDebug           ((CoreDebug_Type *)     CoreDebug_BASE   ) /*!< \deprecated Core Debug configuration struct */ | ||||
|   #define DCB                 ((DCB_Type       *)     DCB_BASE         ) /*!< DCB configuration struct */ | ||||
|   #define DIB                 ((DIB_Type       *)     DIB_BASE         ) /*!< DIB configuration struct */ | ||||
|   #define CoreDebug           ((CoreDebug_Type *)     CoreDebug_BASE   ) /*!< Core Debug configuration struct */ | ||||
|  | ||||
|   #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) | ||||
|     #define MPU_BASE          (SCS_BASE +  0x0D90UL)                     /*!< Memory Protection Unit */ | ||||
| @@ -2233,9 +1983,7 @@ typedef struct | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
|   #define SCS_BASE_NS         (0xE002E000UL)                             /*!< System Control Space Base Address (non-secure address space) */ | ||||
|   #define CoreDebug_BASE_NS   (0xE002EDF0UL)                             /*!< \deprecated Core Debug Base Address           (non-secure address space) */ | ||||
|   #define DCB_BASE_NS         (0xE002EDF0UL)                             /*!< DCB Base Address                  (non-secure address space) */ | ||||
|   #define DIB_BASE_NS         (0xE002EFB0UL)                             /*!< DIB Base Address                  (non-secure address space) */ | ||||
|   #define CoreDebug_BASE_NS   (0xE002EDF0UL)                             /*!< Core Debug Base Address           (non-secure address space) */ | ||||
|   #define SysTick_BASE_NS     (SCS_BASE_NS +  0x0010UL)                  /*!< SysTick Base Address              (non-secure address space) */ | ||||
|   #define NVIC_BASE_NS        (SCS_BASE_NS +  0x0100UL)                  /*!< NVIC Base Address                 (non-secure address space) */ | ||||
|   #define SCB_BASE_NS         (SCS_BASE_NS +  0x0D00UL)                  /*!< System Control Block Base Address (non-secure address space) */ | ||||
| @@ -2244,9 +1992,7 @@ typedef struct | ||||
|   #define SCB_NS              ((SCB_Type       *)     SCB_BASE_NS      ) /*!< SCB configuration struct          (non-secure address space) */ | ||||
|   #define SysTick_NS          ((SysTick_Type   *)     SysTick_BASE_NS  ) /*!< SysTick configuration struct      (non-secure address space) */ | ||||
|   #define NVIC_NS             ((NVIC_Type      *)     NVIC_BASE_NS     ) /*!< NVIC configuration struct         (non-secure address space) */ | ||||
|   #define CoreDebug_NS        ((CoreDebug_Type *)     CoreDebug_BASE_NS) /*!< \deprecated Core Debug configuration struct   (non-secure address space) */ | ||||
|   #define DCB_NS              ((DCB_Type       *)     DCB_BASE_NS      ) /*!< DCB configuration struct          (non-secure address space) */ | ||||
|   #define DIB_NS              ((DIB_Type       *)     DIB_BASE_NS      ) /*!< DIB configuration struct          (non-secure address space) */ | ||||
|   #define CoreDebug_NS        ((CoreDebug_Type *)     CoreDebug_BASE_NS) /*!< Core Debug configuration struct   (non-secure address space) */ | ||||
|  | ||||
|   #if defined (__MPU_PRESENT) && (__MPU_PRESENT == 1U) | ||||
|     #define MPU_BASE_NS       (SCS_BASE_NS +  0x0D90UL)                  /*!< Memory Protection Unit            (non-secure address space) */ | ||||
| @@ -2260,15 +2006,6 @@ typedef struct | ||||
| /*@} */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \ingroup    CMSIS_core_register | ||||
|   \defgroup   CMSIS_register_aliases     Backwards Compatibility Aliases | ||||
|   \brief      Register alias definitions for backwards compatibility. | ||||
|   @{ | ||||
|  */ | ||||
| #define ID_ADR  (ID_AFR)    /*!< SCB Auxiliary Feature Register */ | ||||
| /*@} */ | ||||
|  | ||||
|  | ||||
| /******************************************************************************* | ||||
|  *                Hardware Abstraction Layer | ||||
| @@ -3012,110 +2749,6 @@ __STATIC_INLINE void TZ_SAU_Disable(void) | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    Debug Control function  ############################################ */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   \defgroup CMSIS_Core_DCBFunctions Debug Control Functions | ||||
|   \brief    Functions that access the Debug Control Block. | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Set Debug Authentication Control Register | ||||
|   \details writes to Debug Authentication Control register. | ||||
|   \param [in]  value  value to be writen. | ||||
|  */ | ||||
| __STATIC_INLINE void DCB_SetAuthCtrl(uint32_t value) | ||||
| { | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     DCB->DAUTHCTRL = value; | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Debug Authentication Control Register | ||||
|   \details Reads Debug Authentication Control register. | ||||
|   \return             Debug Authentication Control Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t DCB_GetAuthCtrl(void) | ||||
| { | ||||
|     return (DCB->DAUTHCTRL); | ||||
| } | ||||
|  | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
| /** | ||||
|   \brief   Set Debug Authentication Control Register (non-secure) | ||||
|   \details writes to non-secure Debug Authentication Control register when in secure state. | ||||
|   \param [in]  value  value to be writen | ||||
|  */ | ||||
| __STATIC_INLINE void TZ_DCB_SetAuthCtrl_NS(uint32_t value) | ||||
| { | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     DCB_NS->DAUTHCTRL = value; | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Debug Authentication Control Register (non-secure) | ||||
|   \details Reads non-secure Debug Authentication Control register when in secure state. | ||||
|   \return             Debug Authentication Control Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t TZ_DCB_GetAuthCtrl_NS(void) | ||||
| { | ||||
|     return (DCB_NS->DAUTHCTRL); | ||||
| } | ||||
| #endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ | ||||
|  | ||||
| /*@} end of CMSIS_Core_DCBFunctions */ | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    Debug Identification function  ############################################ */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   \defgroup CMSIS_Core_DIBFunctions Debug Identification Functions | ||||
|   \brief    Functions that access the Debug Identification Block. | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Get Debug Authentication Status Register | ||||
|   \details Reads Debug Authentication Status register. | ||||
|   \return             Debug Authentication Status Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t DIB_GetAuthStatus(void) | ||||
| { | ||||
|     return (DIB->DAUTHSTATUS); | ||||
| } | ||||
|  | ||||
|  | ||||
| #if defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) | ||||
| /** | ||||
|   \brief   Get Debug Authentication Status Register (non-secure) | ||||
|   \details Reads non-secure Debug Authentication Status register when in secure state. | ||||
|   \return             Debug Authentication Status Register. | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t TZ_DIB_GetAuthStatus_NS(void) | ||||
| { | ||||
|     return (DIB_NS->DAUTHSTATUS); | ||||
| } | ||||
| #endif /* defined (__ARM_FEATURE_CMSE) && (__ARM_FEATURE_CMSE == 3U) */ | ||||
|  | ||||
| /*@} end of CMSIS_Core_DCBFunctions */ | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    SysTick function  ############################################ */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
| /**************************************************************************//** | ||||
|  * @file     core_cm4.h | ||||
|  * @brief    CMSIS Cortex-M4 Core Peripheral Access Layer Header File | ||||
|  * @version  V5.1.2 | ||||
|  * @date     04. June 2021 | ||||
|  * @version  V5.1.0 | ||||
|  * @date     13. March 2019 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2009-2020 Arm Limited. All rights reserved. | ||||
|  * Copyright (c) 2009-2019 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
| @@ -194,11 +194,6 @@ | ||||
|     #warning "__MPU_PRESENT not defined in device header file; using default!" | ||||
|   #endif | ||||
|  | ||||
|   #ifndef __VTOR_PRESENT | ||||
|     #define __VTOR_PRESENT             1U | ||||
|     #warning "__VTOR_PRESENT not defined in device header file; using default!" | ||||
|   #endif | ||||
|  | ||||
|   #ifndef __NVIC_PRIO_BITS | ||||
|     #define __NVIC_PRIO_BITS          3U | ||||
|     #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" | ||||
| @@ -623,22 +618,22 @@ typedef struct | ||||
| #define SCB_CFSR_MEMFAULTSR_Msk            (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/)        /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ | ||||
|  | ||||
| /* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ | ||||
| #define SCB_CFSR_MMARVALID_Pos             (SCB_CFSR_MEMFAULTSR_Pos + 7U)                 /*!< SCB CFSR (MMFSR): MMARVALID Position */ | ||||
| #define SCB_CFSR_MMARVALID_Pos             (SCB_SHCSR_MEMFAULTACT_Pos + 7U)               /*!< SCB CFSR (MMFSR): MMARVALID Position */ | ||||
| #define SCB_CFSR_MMARVALID_Msk             (1UL << SCB_CFSR_MMARVALID_Pos)                /*!< SCB CFSR (MMFSR): MMARVALID Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MLSPERR_Pos               (SCB_CFSR_MEMFAULTSR_Pos + 5U)                 /*!< SCB CFSR (MMFSR): MLSPERR Position */ | ||||
| #define SCB_CFSR_MLSPERR_Pos               (SCB_SHCSR_MEMFAULTACT_Pos + 5U)               /*!< SCB CFSR (MMFSR): MLSPERR Position */ | ||||
| #define SCB_CFSR_MLSPERR_Msk               (1UL << SCB_CFSR_MLSPERR_Pos)                  /*!< SCB CFSR (MMFSR): MLSPERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MSTKERR_Pos               (SCB_CFSR_MEMFAULTSR_Pos + 4U)                 /*!< SCB CFSR (MMFSR): MSTKERR Position */ | ||||
| #define SCB_CFSR_MSTKERR_Pos               (SCB_SHCSR_MEMFAULTACT_Pos + 4U)               /*!< SCB CFSR (MMFSR): MSTKERR Position */ | ||||
| #define SCB_CFSR_MSTKERR_Msk               (1UL << SCB_CFSR_MSTKERR_Pos)                  /*!< SCB CFSR (MMFSR): MSTKERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MUNSTKERR_Pos             (SCB_CFSR_MEMFAULTSR_Pos + 3U)                 /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ | ||||
| #define SCB_CFSR_MUNSTKERR_Pos             (SCB_SHCSR_MEMFAULTACT_Pos + 3U)               /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ | ||||
| #define SCB_CFSR_MUNSTKERR_Msk             (1UL << SCB_CFSR_MUNSTKERR_Pos)                /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_DACCVIOL_Pos              (SCB_CFSR_MEMFAULTSR_Pos + 1U)                 /*!< SCB CFSR (MMFSR): DACCVIOL Position */ | ||||
| #define SCB_CFSR_DACCVIOL_Pos              (SCB_SHCSR_MEMFAULTACT_Pos + 1U)               /*!< SCB CFSR (MMFSR): DACCVIOL Position */ | ||||
| #define SCB_CFSR_DACCVIOL_Msk              (1UL << SCB_CFSR_DACCVIOL_Pos)                 /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ | ||||
|  | ||||
| #define SCB_CFSR_IACCVIOL_Pos              (SCB_CFSR_MEMFAULTSR_Pos + 0U)                 /*!< SCB CFSR (MMFSR): IACCVIOL Position */ | ||||
| #define SCB_CFSR_IACCVIOL_Pos              (SCB_SHCSR_MEMFAULTACT_Pos + 0U)               /*!< SCB CFSR (MMFSR): IACCVIOL Position */ | ||||
| #define SCB_CFSR_IACCVIOL_Msk              (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/)             /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ | ||||
|  | ||||
| /* BusFault Status Register (part of SCB Configurable Fault Status Register) */ | ||||
| @@ -1910,8 +1905,8 @@ __STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGr | ||||
|  */ | ||||
| __STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) | ||||
| { | ||||
|   uint32_t *vectors = (uint32_t *)SCB->VTOR; | ||||
|   vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; | ||||
|   uint32_t vectors = (uint32_t )SCB->VTOR; | ||||
|   (* (int *) (vectors + ((int32_t)IRQn + NVIC_USER_IRQ_OFFSET) * 4)) = vector; | ||||
|   /* ARM Application Note 321 states that the M4 does not require the architectural barrier */ | ||||
| } | ||||
|  | ||||
| @@ -1926,8 +1921,8 @@ __STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) | ||||
| { | ||||
|   uint32_t *vectors = (uint32_t *)SCB->VTOR; | ||||
|   return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; | ||||
|   uint32_t vectors = (uint32_t )SCB->VTOR; | ||||
|   return (uint32_t)(* (int *) (vectors + ((int32_t)IRQn + NVIC_USER_IRQ_OFFSET) * 4)); | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,11 +1,11 @@ | ||||
| /**************************************************************************//** | ||||
|  * @file     core_cm7.h | ||||
|  * @brief    CMSIS Cortex-M7 Core Peripheral Access Layer Header File | ||||
|  * @version  V5.1.6 | ||||
|  * @date     04. June 2021 | ||||
|  * @version  V5.1.1 | ||||
|  * @date     28. March 2019 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2009-2021 Arm Limited. All rights reserved. | ||||
|  * Copyright (c) 2009-2019 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
| @@ -209,11 +209,6 @@ | ||||
|     #warning "__DTCM_PRESENT        not defined in device header file; using default!" | ||||
|   #endif | ||||
|  | ||||
|   #ifndef __VTOR_PRESENT | ||||
|     #define __VTOR_PRESENT             1U | ||||
|     #warning "__VTOR_PRESENT not defined in device header file; using default!" | ||||
|   #endif | ||||
|  | ||||
|   #ifndef __NVIC_PRIO_BITS | ||||
|     #define __NVIC_PRIO_BITS          3U | ||||
|     #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" | ||||
| @@ -501,8 +496,7 @@ typedef struct | ||||
|   __OM  uint32_t DCCSW;                  /*!< Offset: 0x26C ( /W)  D-Cache Clean by Set-way */ | ||||
|   __OM  uint32_t DCCIMVAC;               /*!< Offset: 0x270 ( /W)  D-Cache Clean and Invalidate by MVA to PoC */ | ||||
|   __OM  uint32_t DCCISW;                 /*!< Offset: 0x274 ( /W)  D-Cache Clean and Invalidate by Set-way */ | ||||
|   __OM  uint32_t BPIALL;                 /*!< Offset: 0x278 ( /W)  Branch Predictor Invalidate All */ | ||||
|         uint32_t RESERVED7[5U]; | ||||
|         uint32_t RESERVED7[6U]; | ||||
|   __IOM uint32_t ITCMCR;                 /*!< Offset: 0x290 (R/W)  Instruction Tightly-Coupled Memory Control Register */ | ||||
|   __IOM uint32_t DTCMCR;                 /*!< Offset: 0x294 (R/W)  Data Tightly-Coupled Memory Control Registers */ | ||||
|   __IOM uint32_t AHBPCR;                 /*!< Offset: 0x298 (R/W)  AHBP Control Register */ | ||||
| @@ -677,22 +671,22 @@ typedef struct | ||||
| #define SCB_CFSR_MEMFAULTSR_Msk            (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/)        /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ | ||||
|  | ||||
| /* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ | ||||
| #define SCB_CFSR_MMARVALID_Pos             (SCB_CFSR_MEMFAULTSR_Pos + 7U)                 /*!< SCB CFSR (MMFSR): MMARVALID Position */ | ||||
| #define SCB_CFSR_MMARVALID_Pos             (SCB_SHCSR_MEMFAULTACT_Pos + 7U)               /*!< SCB CFSR (MMFSR): MMARVALID Position */ | ||||
| #define SCB_CFSR_MMARVALID_Msk             (1UL << SCB_CFSR_MMARVALID_Pos)                /*!< SCB CFSR (MMFSR): MMARVALID Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MLSPERR_Pos               (SCB_CFSR_MEMFAULTSR_Pos + 5U)                 /*!< SCB CFSR (MMFSR): MLSPERR Position */ | ||||
| #define SCB_CFSR_MLSPERR_Pos               (SCB_SHCSR_MEMFAULTACT_Pos + 5U)               /*!< SCB CFSR (MMFSR): MLSPERR Position */ | ||||
| #define SCB_CFSR_MLSPERR_Msk               (1UL << SCB_CFSR_MLSPERR_Pos)                  /*!< SCB CFSR (MMFSR): MLSPERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MSTKERR_Pos               (SCB_CFSR_MEMFAULTSR_Pos + 4U)                 /*!< SCB CFSR (MMFSR): MSTKERR Position */ | ||||
| #define SCB_CFSR_MSTKERR_Pos               (SCB_SHCSR_MEMFAULTACT_Pos + 4U)               /*!< SCB CFSR (MMFSR): MSTKERR Position */ | ||||
| #define SCB_CFSR_MSTKERR_Msk               (1UL << SCB_CFSR_MSTKERR_Pos)                  /*!< SCB CFSR (MMFSR): MSTKERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MUNSTKERR_Pos             (SCB_CFSR_MEMFAULTSR_Pos + 3U)                 /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ | ||||
| #define SCB_CFSR_MUNSTKERR_Pos             (SCB_SHCSR_MEMFAULTACT_Pos + 3U)               /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ | ||||
| #define SCB_CFSR_MUNSTKERR_Msk             (1UL << SCB_CFSR_MUNSTKERR_Pos)                /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_DACCVIOL_Pos              (SCB_CFSR_MEMFAULTSR_Pos + 1U)                 /*!< SCB CFSR (MMFSR): DACCVIOL Position */ | ||||
| #define SCB_CFSR_DACCVIOL_Pos              (SCB_SHCSR_MEMFAULTACT_Pos + 1U)               /*!< SCB CFSR (MMFSR): DACCVIOL Position */ | ||||
| #define SCB_CFSR_DACCVIOL_Msk              (1UL << SCB_CFSR_DACCVIOL_Pos)                 /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ | ||||
|  | ||||
| #define SCB_CFSR_IACCVIOL_Pos              (SCB_CFSR_MEMFAULTSR_Pos + 0U)                 /*!< SCB CFSR (MMFSR): IACCVIOL Position */ | ||||
| #define SCB_CFSR_IACCVIOL_Pos              (SCB_SHCSR_MEMFAULTACT_Pos + 0U)               /*!< SCB CFSR (MMFSR): IACCVIOL Position */ | ||||
| #define SCB_CFSR_IACCVIOL_Msk              (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/)             /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ | ||||
|  | ||||
| /* BusFault Status Register (part of SCB Configurable Fault Status Register) */ | ||||
| @@ -876,24 +870,21 @@ typedef struct | ||||
| #define SCB_CACR_FORCEWT_Pos                2U                                            /*!< SCB CACR: FORCEWT Position */ | ||||
| #define SCB_CACR_FORCEWT_Msk               (1UL << SCB_CACR_FORCEWT_Pos)                  /*!< SCB CACR: FORCEWT Mask */ | ||||
|  | ||||
| #define SCB_CACR_ECCEN_Pos                  1U                                            /*!< \deprecated SCB CACR: ECCEN Position */ | ||||
| #define SCB_CACR_ECCEN_Msk                 (1UL << SCB_CACR_ECCEN_Pos)                    /*!< \deprecated SCB CACR: ECCEN Mask */ | ||||
|  | ||||
| #define SCB_CACR_ECCDIS_Pos                 1U                                            /*!< SCB CACR: ECCDIS Position */ | ||||
| #define SCB_CACR_ECCDIS_Msk                (1UL << SCB_CACR_ECCDIS_Pos)                   /*!< SCB CACR: ECCDIS Mask */ | ||||
| #define SCB_CACR_ECCEN_Pos                  1U                                            /*!< SCB CACR: ECCEN Position */ | ||||
| #define SCB_CACR_ECCEN_Msk                 (1UL << SCB_CACR_ECCEN_Pos)                    /*!< SCB CACR: ECCEN Mask */ | ||||
|  | ||||
| #define SCB_CACR_SIWT_Pos                   0U                                            /*!< SCB CACR: SIWT Position */ | ||||
| #define SCB_CACR_SIWT_Msk                  (1UL /*<< SCB_CACR_SIWT_Pos*/)                 /*!< SCB CACR: SIWT Mask */ | ||||
|  | ||||
| /* AHBS Control Register Definitions */ | ||||
| #define SCB_AHBSCR_INITCOUNT_Pos           11U                                            /*!< SCB AHBSCR: INITCOUNT Position */ | ||||
| #define SCB_AHBSCR_INITCOUNT_Msk           (0x1FUL << SCB_AHBSCR_INITCOUNT_Pos)           /*!< SCB AHBSCR: INITCOUNT Mask */ | ||||
| #define SCB_AHBSCR_INITCOUNT_Msk           (0x1FUL << SCB_AHBPCR_INITCOUNT_Pos)           /*!< SCB AHBSCR: INITCOUNT Mask */ | ||||
|  | ||||
| #define SCB_AHBSCR_TPRI_Pos                 2U                                            /*!< SCB AHBSCR: TPRI Position */ | ||||
| #define SCB_AHBSCR_TPRI_Msk                (0x1FFUL << SCB_AHBSCR_TPRI_Pos)               /*!< SCB AHBSCR: TPRI Mask */ | ||||
| #define SCB_AHBSCR_TPRI_Msk                (0x1FFUL << SCB_AHBPCR_TPRI_Pos)               /*!< SCB AHBSCR: TPRI Mask */ | ||||
|  | ||||
| #define SCB_AHBSCR_CTL_Pos                  0U                                            /*!< SCB AHBSCR: CTL Position*/ | ||||
| #define SCB_AHBSCR_CTL_Msk                 (3UL /*<< SCB_AHBSCR_CTL_Pos*/)                /*!< SCB AHBSCR: CTL Mask */ | ||||
| #define SCB_AHBSCR_CTL_Msk                 (3UL /*<< SCB_AHBPCR_CTL_Pos*/)                /*!< SCB AHBSCR: CTL Mask */ | ||||
|  | ||||
| /* Auxiliary Bus Fault Status Register Definitions */ | ||||
| #define SCB_ABFSR_AXIMTYPE_Pos              8U                                            /*!< SCB ABFSR: AXIMTYPE Position*/ | ||||
| @@ -2137,8 +2128,8 @@ __STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGr | ||||
|  */ | ||||
| __STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) | ||||
| { | ||||
|   uint32_t *vectors = (uint32_t *)SCB->VTOR; | ||||
|   vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; | ||||
|   uint32_t vectors = (uint32_t )SCB->VTOR; | ||||
|   (* (int *) (vectors + ((int32_t)IRQn + NVIC_USER_IRQ_OFFSET) * 4)) = vector; | ||||
|   __DSB(); | ||||
| } | ||||
|  | ||||
| @@ -2153,8 +2144,8 @@ __STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) | ||||
| { | ||||
|   uint32_t *vectors = (uint32_t *)SCB->VTOR; | ||||
|   return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; | ||||
|   uint32_t vectors = (uint32_t )SCB->VTOR; | ||||
|   return (uint32_t)(* (int *) (vectors + ((int32_t)IRQn + NVIC_USER_IRQ_OFFSET) * 4)); | ||||
| } | ||||
|  | ||||
|  | ||||
| @@ -2227,12 +2218,380 @@ __STATIC_INLINE uint32_t SCB_GetFPUType(void) | ||||
| /*@} end of CMSIS_Core_FpuFunctions */ | ||||
|  | ||||
|  | ||||
| /* ##########################  Cache functions  #################################### */ | ||||
|  | ||||
| #if ((defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U)) || \ | ||||
|      (defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U))) | ||||
| #include "cachel1_armv7.h" | ||||
| #endif | ||||
| /* ##########################  Cache functions  #################################### */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   \defgroup CMSIS_Core_CacheFunctions Cache Functions | ||||
|   \brief    Functions that configure Instruction and Data cache. | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
| /* Cache Size ID Register Macros */ | ||||
| #define CCSIDR_WAYS(x)         (((x) & SCB_CCSIDR_ASSOCIATIVITY_Msk) >> SCB_CCSIDR_ASSOCIATIVITY_Pos) | ||||
| #define CCSIDR_SETS(x)         (((x) & SCB_CCSIDR_NUMSETS_Msk      ) >> SCB_CCSIDR_NUMSETS_Pos      ) | ||||
|  | ||||
| #define __SCB_DCACHE_LINE_SIZE  32U /*!< Cortex-M7 cache line size is fixed to 32 bytes (8 words). See also register SCB_CCSIDR */ | ||||
| #define __SCB_ICACHE_LINE_SIZE  32U /*!< Cortex-M7 cache line size is fixed to 32 bytes (8 words). See also register SCB_CCSIDR */ | ||||
|  | ||||
| /** | ||||
|   \brief   Enable I-Cache | ||||
|   \details Turns on I-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_EnableICache (void) | ||||
| { | ||||
|   #if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U) | ||||
|     if (SCB->CCR & SCB_CCR_IC_Msk) return;  /* return if ICache is already enabled */ | ||||
|  | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     SCB->ICIALLU = 0UL;                     /* invalidate I-Cache */ | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     SCB->CCR |=  (uint32_t)SCB_CCR_IC_Msk;  /* enable I-Cache */ | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Disable I-Cache | ||||
|   \details Turns off I-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_DisableICache (void) | ||||
| { | ||||
|   #if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U) | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     SCB->CCR &= ~(uint32_t)SCB_CCR_IC_Msk;  /* disable I-Cache */ | ||||
|     SCB->ICIALLU = 0UL;                     /* invalidate I-Cache */ | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Invalidate I-Cache | ||||
|   \details Invalidates I-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_InvalidateICache (void) | ||||
| { | ||||
|   #if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U) | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|     SCB->ICIALLU = 0UL; | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   I-Cache Invalidate by address | ||||
|   \details Invalidates I-Cache for the given address. | ||||
|            I-Cache is invalidated starting from a 32 byte aligned address in 32 byte granularity. | ||||
|            I-Cache memory blocks which are part of given address + given size are invalidated. | ||||
|   \param[in]   addr    address | ||||
|   \param[in]   isize   size of memory block (in number of bytes) | ||||
| */ | ||||
| __STATIC_FORCEINLINE void SCB_InvalidateICache_by_Addr (void *addr, int32_t isize) | ||||
| { | ||||
|   #if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U) | ||||
|     if ( isize > 0 ) { | ||||
|        int32_t op_size = isize + (((uint32_t)addr) & (__SCB_ICACHE_LINE_SIZE - 1U)); | ||||
|       uint32_t op_addr = (uint32_t)addr /* & ~(__SCB_ICACHE_LINE_SIZE - 1U) */; | ||||
|  | ||||
|       __DSB(); | ||||
|  | ||||
|       do { | ||||
|         SCB->ICIMVAU = op_addr;             /* register accepts only 32byte aligned values, only bits 31..5 are valid */ | ||||
|         op_addr += __SCB_ICACHE_LINE_SIZE; | ||||
|         op_size -= __SCB_ICACHE_LINE_SIZE; | ||||
|       } while ( op_size > 0 ); | ||||
|  | ||||
|       __DSB(); | ||||
|       __ISB(); | ||||
|     } | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Enable D-Cache | ||||
|   \details Turns on D-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_EnableDCache (void) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     uint32_t ccsidr; | ||||
|     uint32_t sets; | ||||
|     uint32_t ways; | ||||
|  | ||||
|     if (SCB->CCR & SCB_CCR_DC_Msk) return;  /* return if DCache is already enabled */ | ||||
|  | ||||
|     SCB->CSSELR = 0U;                       /* select Level 1 data cache */ | ||||
|     __DSB(); | ||||
|  | ||||
|     ccsidr = SCB->CCSIDR; | ||||
|  | ||||
|                                             /* invalidate D-Cache */ | ||||
|     sets = (uint32_t)(CCSIDR_SETS(ccsidr)); | ||||
|     do { | ||||
|       ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); | ||||
|       do { | ||||
|         SCB->DCISW = (((sets << SCB_DCISW_SET_Pos) & SCB_DCISW_SET_Msk) | | ||||
|                       ((ways << SCB_DCISW_WAY_Pos) & SCB_DCISW_WAY_Msk)  ); | ||||
|         #if defined ( __CC_ARM ) | ||||
|           __schedule_barrier(); | ||||
|         #endif | ||||
|       } while (ways-- != 0U); | ||||
|     } while(sets-- != 0U); | ||||
|     __DSB(); | ||||
|  | ||||
|     SCB->CCR |=  (uint32_t)SCB_CCR_DC_Msk;  /* enable D-Cache */ | ||||
|  | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Disable D-Cache | ||||
|   \details Turns off D-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_DisableDCache (void) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     uint32_t ccsidr; | ||||
|     uint32_t sets; | ||||
|     uint32_t ways; | ||||
|  | ||||
|     SCB->CSSELR = 0U;                       /* select Level 1 data cache */ | ||||
|     __DSB(); | ||||
|  | ||||
|     SCB->CCR &= ~(uint32_t)SCB_CCR_DC_Msk;  /* disable D-Cache */ | ||||
|     __DSB(); | ||||
|  | ||||
|     ccsidr = SCB->CCSIDR; | ||||
|  | ||||
|                                             /* clean & invalidate D-Cache */ | ||||
|     sets = (uint32_t)(CCSIDR_SETS(ccsidr)); | ||||
|     do { | ||||
|       ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); | ||||
|       do { | ||||
|         SCB->DCCISW = (((sets << SCB_DCCISW_SET_Pos) & SCB_DCCISW_SET_Msk) | | ||||
|                        ((ways << SCB_DCCISW_WAY_Pos) & SCB_DCCISW_WAY_Msk)  ); | ||||
|         #if defined ( __CC_ARM ) | ||||
|           __schedule_barrier(); | ||||
|         #endif | ||||
|       } while (ways-- != 0U); | ||||
|     } while(sets-- != 0U); | ||||
|  | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Invalidate D-Cache | ||||
|   \details Invalidates D-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_InvalidateDCache (void) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     uint32_t ccsidr; | ||||
|     uint32_t sets; | ||||
|     uint32_t ways; | ||||
|  | ||||
|     SCB->CSSELR = 0U;                       /* select Level 1 data cache */ | ||||
|     __DSB(); | ||||
|  | ||||
|     ccsidr = SCB->CCSIDR; | ||||
|  | ||||
|                                             /* invalidate D-Cache */ | ||||
|     sets = (uint32_t)(CCSIDR_SETS(ccsidr)); | ||||
|     do { | ||||
|       ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); | ||||
|       do { | ||||
|         SCB->DCISW = (((sets << SCB_DCISW_SET_Pos) & SCB_DCISW_SET_Msk) | | ||||
|                       ((ways << SCB_DCISW_WAY_Pos) & SCB_DCISW_WAY_Msk)  ); | ||||
|         #if defined ( __CC_ARM ) | ||||
|           __schedule_barrier(); | ||||
|         #endif | ||||
|       } while (ways-- != 0U); | ||||
|     } while(sets-- != 0U); | ||||
|  | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Clean D-Cache | ||||
|   \details Cleans D-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_CleanDCache (void) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     uint32_t ccsidr; | ||||
|     uint32_t sets; | ||||
|     uint32_t ways; | ||||
|  | ||||
|     SCB->CSSELR = 0U;                       /* select Level 1 data cache */ | ||||
|     __DSB(); | ||||
|  | ||||
|     ccsidr = SCB->CCSIDR; | ||||
|  | ||||
|                                             /* clean D-Cache */ | ||||
|     sets = (uint32_t)(CCSIDR_SETS(ccsidr)); | ||||
|     do { | ||||
|       ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); | ||||
|       do { | ||||
|         SCB->DCCSW = (((sets << SCB_DCCSW_SET_Pos) & SCB_DCCSW_SET_Msk) | | ||||
|                       ((ways << SCB_DCCSW_WAY_Pos) & SCB_DCCSW_WAY_Msk)  ); | ||||
|         #if defined ( __CC_ARM ) | ||||
|           __schedule_barrier(); | ||||
|         #endif | ||||
|       } while (ways-- != 0U); | ||||
|     } while(sets-- != 0U); | ||||
|  | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   Clean & Invalidate D-Cache | ||||
|   \details Cleans and Invalidates D-Cache | ||||
|   */ | ||||
| __STATIC_FORCEINLINE void SCB_CleanInvalidateDCache (void) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     uint32_t ccsidr; | ||||
|     uint32_t sets; | ||||
|     uint32_t ways; | ||||
|  | ||||
|     SCB->CSSELR = 0U;                       /* select Level 1 data cache */ | ||||
|     __DSB(); | ||||
|  | ||||
|     ccsidr = SCB->CCSIDR; | ||||
|  | ||||
|                                             /* clean & invalidate D-Cache */ | ||||
|     sets = (uint32_t)(CCSIDR_SETS(ccsidr)); | ||||
|     do { | ||||
|       ways = (uint32_t)(CCSIDR_WAYS(ccsidr)); | ||||
|       do { | ||||
|         SCB->DCCISW = (((sets << SCB_DCCISW_SET_Pos) & SCB_DCCISW_SET_Msk) | | ||||
|                        ((ways << SCB_DCCISW_WAY_Pos) & SCB_DCCISW_WAY_Msk)  ); | ||||
|         #if defined ( __CC_ARM ) | ||||
|           __schedule_barrier(); | ||||
|         #endif | ||||
|       } while (ways-- != 0U); | ||||
|     } while(sets-- != 0U); | ||||
|  | ||||
|     __DSB(); | ||||
|     __ISB(); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   D-Cache Invalidate by address | ||||
|   \details Invalidates D-Cache for the given address. | ||||
|            D-Cache is invalidated starting from a 32 byte aligned address in 32 byte granularity. | ||||
|            D-Cache memory blocks which are part of given address + given size are invalidated. | ||||
|   \param[in]   addr    address | ||||
|   \param[in]   dsize   size of memory block (in number of bytes) | ||||
| */ | ||||
| __STATIC_FORCEINLINE void SCB_InvalidateDCache_by_Addr (void *addr, int32_t dsize) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     if ( dsize > 0 ) {  | ||||
|        int32_t op_size = dsize + (((uint32_t)addr) & (__SCB_DCACHE_LINE_SIZE - 1U)); | ||||
|       uint32_t op_addr = (uint32_t)addr /* & ~(__SCB_DCACHE_LINE_SIZE - 1U) */; | ||||
|      | ||||
|       __DSB(); | ||||
|  | ||||
|       do { | ||||
|         SCB->DCIMVAC = op_addr;             /* register accepts only 32byte aligned values, only bits 31..5 are valid */ | ||||
|         op_addr += __SCB_DCACHE_LINE_SIZE; | ||||
|         op_size -= __SCB_DCACHE_LINE_SIZE; | ||||
|       } while ( op_size > 0 ); | ||||
|  | ||||
|       __DSB(); | ||||
|       __ISB(); | ||||
|     } | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   D-Cache Clean by address | ||||
|   \details Cleans D-Cache for the given address | ||||
|            D-Cache is cleaned starting from a 32 byte aligned address in 32 byte granularity. | ||||
|            D-Cache memory blocks which are part of given address + given size are cleaned. | ||||
|   \param[in]   addr    address | ||||
|   \param[in]   dsize   size of memory block (in number of bytes) | ||||
| */ | ||||
| __STATIC_FORCEINLINE void SCB_CleanDCache_by_Addr (uint32_t *addr, int32_t dsize) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     if ( dsize > 0 ) {  | ||||
|        int32_t op_size = dsize + (((uint32_t)addr) & (__SCB_DCACHE_LINE_SIZE - 1U)); | ||||
|       uint32_t op_addr = (uint32_t)addr /* & ~(__SCB_DCACHE_LINE_SIZE - 1U) */; | ||||
|      | ||||
|       __DSB(); | ||||
|  | ||||
|       do { | ||||
|         SCB->DCCMVAC = op_addr;             /* register accepts only 32byte aligned values, only bits 31..5 are valid */ | ||||
|         op_addr += __SCB_DCACHE_LINE_SIZE; | ||||
|         op_size -= __SCB_DCACHE_LINE_SIZE; | ||||
|       } while ( op_size > 0 ); | ||||
|  | ||||
|       __DSB(); | ||||
|       __ISB(); | ||||
|     } | ||||
|   #endif | ||||
| } | ||||
|  | ||||
|  | ||||
| /** | ||||
|   \brief   D-Cache Clean and Invalidate by address | ||||
|   \details Cleans and invalidates D_Cache for the given address | ||||
|            D-Cache is cleaned and invalidated starting from a 32 byte aligned address in 32 byte granularity. | ||||
|            D-Cache memory blocks which are part of given address + given size are cleaned and invalidated. | ||||
|   \param[in]   addr    address (aligned to 32-byte boundary) | ||||
|   \param[in]   dsize   size of memory block (in number of bytes) | ||||
| */ | ||||
| __STATIC_FORCEINLINE void SCB_CleanInvalidateDCache_by_Addr (uint32_t *addr, int32_t dsize) | ||||
| { | ||||
|   #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U) | ||||
|     if ( dsize > 0 ) {  | ||||
|        int32_t op_size = dsize + (((uint32_t)addr) & (__SCB_DCACHE_LINE_SIZE - 1U)); | ||||
|       uint32_t op_addr = (uint32_t)addr /* & ~(__SCB_DCACHE_LINE_SIZE - 1U) */; | ||||
|      | ||||
|       __DSB(); | ||||
|  | ||||
|       do { | ||||
|         SCB->DCCIMVAC = op_addr;            /* register accepts only 32byte aligned values, only bits 31..5 are valid */ | ||||
|         op_addr +=          __SCB_DCACHE_LINE_SIZE; | ||||
|         op_size -=          __SCB_DCACHE_LINE_SIZE; | ||||
|       } while ( op_size > 0 ); | ||||
|  | ||||
|       __DSB(); | ||||
|       __ISB(); | ||||
|     } | ||||
|   #endif | ||||
| } | ||||
|  | ||||
| /*@} end of CMSIS_Core_CacheFunctions */ | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ##################################    SysTick function  ############################################ */ | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,11 +1,11 @@ | ||||
| /**************************************************************************//** | ||||
|  * @file     core_sc000.h | ||||
|  * @brief    CMSIS SC000 Core Peripheral Access Layer Header File | ||||
|  * @version  V5.0.7 | ||||
|  * @date     27. March 2020 | ||||
|  * @version  V5.0.6 | ||||
|  * @date     12. November 2018 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2009-2020 Arm Limited. All rights reserved. | ||||
|  * Copyright (c) 2009-2018 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
| @@ -142,11 +142,6 @@ | ||||
|     #warning "__MPU_PRESENT not defined in device header file; using default!" | ||||
|   #endif | ||||
|  | ||||
|   #ifndef __VTOR_PRESENT | ||||
|     #define __VTOR_PRESENT             0U | ||||
|     #warning "__VTOR_PRESENT not defined in device header file; using default!" | ||||
|   #endif | ||||
|    | ||||
|   #ifndef __NVIC_PRIO_BITS | ||||
|     #define __NVIC_PRIO_BITS          2U | ||||
|     #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
| /**************************************************************************//** | ||||
|  * @file     core_sc300.h | ||||
|  * @brief    CMSIS SC300 Core Peripheral Access Layer Header File | ||||
|  * @version  V5.0.10 | ||||
|  * @date     04. June 2021 | ||||
|  * @version  V5.0.8 | ||||
|  * @date     31. May 2019 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2009-2021 Arm Limited. All rights reserved. | ||||
|  * Copyright (c) 2009-2019 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
| @@ -142,11 +142,6 @@ | ||||
|     #warning "__MPU_PRESENT not defined in device header file; using default!" | ||||
|   #endif | ||||
|  | ||||
|   #ifndef __VTOR_PRESENT | ||||
|     #define __VTOR_PRESENT             1U | ||||
|     #warning "__VTOR_PRESENT not defined in device header file; using default!" | ||||
|   #endif | ||||
|  | ||||
|   #ifndef __NVIC_PRIO_BITS | ||||
|     #define __NVIC_PRIO_BITS          3U | ||||
|     #warning "__NVIC_PRIO_BITS not defined in device header file; using default!" | ||||
| @@ -562,19 +557,19 @@ typedef struct | ||||
| #define SCB_CFSR_MEMFAULTSR_Msk            (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/)        /*!< SCB CFSR: Memory Manage Fault Status Register Mask */ | ||||
|  | ||||
| /* MemManage Fault Status Register (part of SCB Configurable Fault Status Register) */ | ||||
| #define SCB_CFSR_MMARVALID_Pos             (SCB_CFSR_MEMFAULTSR_Pos + 7U)                 /*!< SCB CFSR (MMFSR): MMARVALID Position */ | ||||
| #define SCB_CFSR_MMARVALID_Pos             (SCB_SHCSR_MEMFAULTACT_Pos + 7U)               /*!< SCB CFSR (MMFSR): MMARVALID Position */ | ||||
| #define SCB_CFSR_MMARVALID_Msk             (1UL << SCB_CFSR_MMARVALID_Pos)                /*!< SCB CFSR (MMFSR): MMARVALID Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MSTKERR_Pos               (SCB_CFSR_MEMFAULTSR_Pos + 4U)                 /*!< SCB CFSR (MMFSR): MSTKERR Position */ | ||||
| #define SCB_CFSR_MSTKERR_Pos               (SCB_SHCSR_MEMFAULTACT_Pos + 4U)               /*!< SCB CFSR (MMFSR): MSTKERR Position */ | ||||
| #define SCB_CFSR_MSTKERR_Msk               (1UL << SCB_CFSR_MSTKERR_Pos)                  /*!< SCB CFSR (MMFSR): MSTKERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_MUNSTKERR_Pos             (SCB_CFSR_MEMFAULTSR_Pos + 3U)                 /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ | ||||
| #define SCB_CFSR_MUNSTKERR_Pos             (SCB_SHCSR_MEMFAULTACT_Pos + 3U)               /*!< SCB CFSR (MMFSR): MUNSTKERR Position */ | ||||
| #define SCB_CFSR_MUNSTKERR_Msk             (1UL << SCB_CFSR_MUNSTKERR_Pos)                /*!< SCB CFSR (MMFSR): MUNSTKERR Mask */ | ||||
|  | ||||
| #define SCB_CFSR_DACCVIOL_Pos              (SCB_CFSR_MEMFAULTSR_Pos + 1U)                 /*!< SCB CFSR (MMFSR): DACCVIOL Position */ | ||||
| #define SCB_CFSR_DACCVIOL_Pos              (SCB_SHCSR_MEMFAULTACT_Pos + 1U)               /*!< SCB CFSR (MMFSR): DACCVIOL Position */ | ||||
| #define SCB_CFSR_DACCVIOL_Msk              (1UL << SCB_CFSR_DACCVIOL_Pos)                 /*!< SCB CFSR (MMFSR): DACCVIOL Mask */ | ||||
|  | ||||
| #define SCB_CFSR_IACCVIOL_Pos              (SCB_CFSR_MEMFAULTSR_Pos + 0U)                 /*!< SCB CFSR (MMFSR): IACCVIOL Position */ | ||||
| #define SCB_CFSR_IACCVIOL_Pos              (SCB_SHCSR_MEMFAULTACT_Pos + 0U)               /*!< SCB CFSR (MMFSR): IACCVIOL Position */ | ||||
| #define SCB_CFSR_IACCVIOL_Msk              (1UL /*<< SCB_CFSR_IACCVIOL_Pos*/)             /*!< SCB CFSR (MMFSR): IACCVIOL Mask */ | ||||
|  | ||||
| /* BusFault Status Register (part of SCB Configurable Fault Status Register) */ | ||||
| @@ -1717,8 +1712,8 @@ __STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGr | ||||
|  */ | ||||
| __STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) | ||||
| { | ||||
|   uint32_t *vectors = (uint32_t *)SCB->VTOR; | ||||
|   vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET] = vector; | ||||
|   uint32_t vectors = (uint32_t )SCB->VTOR; | ||||
|   (* (int *) (vectors + ((int32_t)IRQn + NVIC_USER_IRQ_OFFSET) * 4)) = vector; | ||||
|   /* ARM Application Note 321 states that the M3 does not require the architectural barrier */ | ||||
| } | ||||
|  | ||||
| @@ -1733,8 +1728,8 @@ __STATIC_INLINE void __NVIC_SetVector(IRQn_Type IRQn, uint32_t vector) | ||||
|  */ | ||||
| __STATIC_INLINE uint32_t __NVIC_GetVector(IRQn_Type IRQn) | ||||
| { | ||||
|   uint32_t *vectors = (uint32_t *)SCB->VTOR; | ||||
|   return vectors[(int32_t)IRQn + NVIC_USER_IRQ_OFFSET]; | ||||
|   uint32_t vectors = (uint32_t )SCB->VTOR; | ||||
|   return (uint32_t)(* (int *) (vectors + ((int32_t)IRQn + NVIC_USER_IRQ_OFFSET) * 4)); | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,11 +1,11 @@ | ||||
| /****************************************************************************** | ||||
|  * @file     mpu_armv7.h | ||||
|  * @brief    CMSIS MPU API for Armv7-M MPU | ||||
|  * @version  V5.1.2 | ||||
|  * @date     25. May 2020 | ||||
|  * @version  V5.1.0 | ||||
|  * @date     08. March 2019 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2017-2020 Arm Limited. All rights reserved. | ||||
|  * Copyright (c) 2017-2019 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
| @@ -154,7 +154,7 @@ | ||||
| * \param InnerCp Configures the inner cache policy. | ||||
| * \param IsShareable Configures the memory as shareable or non-shareable. | ||||
| */  | ||||
| #define ARM_MPU_ACCESS_NORMAL(OuterCp, InnerCp, IsShareable) ARM_MPU_ACCESS_((4U | (OuterCp)), IsShareable, ((InnerCp) >> 1U), ((InnerCp) & 1U)) | ||||
| #define ARM_MPU_ACCESS_NORMAL(OuterCp, InnerCp, IsShareable) ARM_MPU_ACCESS_((4U | (OuterCp)), IsShareable, ((InnerCp) & 2U), ((InnerCp) & 1U)) | ||||
|  | ||||
| /** | ||||
| * MPU Memory Access Attribute non-cacheable policy. | ||||
| @@ -190,7 +190,6 @@ typedef struct { | ||||
| */ | ||||
| __STATIC_INLINE void ARM_MPU_Enable(uint32_t MPU_Control) | ||||
| { | ||||
|   __DMB(); | ||||
|   MPU->CTRL = MPU_Control | MPU_CTRL_ENABLE_Msk; | ||||
| #ifdef SCB_SHCSR_MEMFAULTENA_Msk | ||||
|   SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk; | ||||
| @@ -208,8 +207,6 @@ __STATIC_INLINE void ARM_MPU_Disable(void) | ||||
|   SCB->SHCSR &= ~SCB_SHCSR_MEMFAULTENA_Msk; | ||||
| #endif | ||||
|   MPU->CTRL  &= ~MPU_CTRL_ENABLE_Msk; | ||||
|   __DSB(); | ||||
|   __ISB(); | ||||
| } | ||||
|  | ||||
| /** Clear and disable the given MPU region. | ||||
| @@ -223,7 +220,7 @@ __STATIC_INLINE void ARM_MPU_ClrRegion(uint32_t rnr) | ||||
|  | ||||
| /** Configure an MPU region. | ||||
| * \param rbar Value for RBAR register. | ||||
| * \param rasr Value for RASR register. | ||||
| * \param rsar Value for RSAR register. | ||||
| */    | ||||
| __STATIC_INLINE void ARM_MPU_SetRegion(uint32_t rbar, uint32_t rasr) | ||||
| { | ||||
| @@ -234,7 +231,7 @@ __STATIC_INLINE void ARM_MPU_SetRegion(uint32_t rbar, uint32_t rasr) | ||||
| /** Configure the given MPU region. | ||||
| * \param rnr Region number to be configured. | ||||
| * \param rbar Value for RBAR register. | ||||
| * \param rasr Value for RASR register. | ||||
| * \param rsar Value for RSAR register. | ||||
| */    | ||||
| __STATIC_INLINE void ARM_MPU_SetRegionEx(uint32_t rnr, uint32_t rbar, uint32_t rasr) | ||||
| { | ||||
| @@ -243,7 +240,7 @@ __STATIC_INLINE void ARM_MPU_SetRegionEx(uint32_t rnr, uint32_t rbar, uint32_t r | ||||
|   MPU->RASR = rasr; | ||||
| } | ||||
|  | ||||
| /** Memcpy with strictly ordered memory access, e.g. used by code in ARM_MPU_Load(). | ||||
| /** Memcopy with strictly ordered memory access, e.g. for register targets. | ||||
| * \param dst Destination data is copied to. | ||||
| * \param src Source data is copied from. | ||||
| * \param len Amount of data words to be copied. | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
| /****************************************************************************** | ||||
|  * @file     mpu_armv8.h | ||||
|  * @brief    CMSIS MPU API for Armv8-M and Armv8.1-M MPU | ||||
|  * @version  V5.1.3 | ||||
|  * @date     03. February 2021 | ||||
|  * @version  V5.1.0 | ||||
|  * @date     08. March 2019 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2017-2021 Arm Limited. All rights reserved. | ||||
|  * Copyright (c) 2017-2019 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
| @@ -44,7 +44,7 @@ | ||||
| * \param WA Write Allocation: Set to 1 to use cache allocation on write miss. | ||||
| */ | ||||
| #define ARM_MPU_ATTR_MEMORY_(NT, WB, RA, WA) \ | ||||
|   ((((NT) & 1U) << 3U) | (((WB) & 1U) << 2U) | (((RA) & 1U) << 1U) | ((WA) & 1U)) | ||||
|   (((NT & 1U) << 3U) | ((WB & 1U) << 2U) | ((RA & 1U) << 1U) | (WA & 1U)) | ||||
|  | ||||
| /** \brief Device memory type non Gathering, non Re-ordering, non Early Write Acknowledgement */ | ||||
| #define ARM_MPU_ATTR_DEVICE_nGnRnE (0U) | ||||
| @@ -62,7 +62,7 @@ | ||||
| * \param O Outer memory attributes | ||||
| * \param I O == ARM_MPU_ATTR_DEVICE: Device memory attributes, else: Inner memory attributes | ||||
| */ | ||||
| #define ARM_MPU_ATTR(O, I) ((((O) & 0xFU) << 4U) | ((((O) & 0xFU) != 0U) ? ((I) & 0xFU) : (((I) & 0x3U) << 2U))) | ||||
| #define ARM_MPU_ATTR(O, I) (((O & 0xFU) << 4U) | (((O & 0xFU) != 0U) ? (I & 0xFU) : ((I & 0x3U) << 2U))) | ||||
|  | ||||
| /** \brief Normal memory non-shareable  */ | ||||
| #define ARM_MPU_SH_NON   (0U) | ||||
| @@ -77,7 +77,7 @@ | ||||
| * \param RO Read-Only: Set to 1 for read-only memory. | ||||
| * \param NP Non-Privileged: Set to 1 for non-privileged memory. | ||||
| */ | ||||
| #define ARM_MPU_AP_(RO, NP) ((((RO) & 1U) << 1U) | ((NP) & 1U)) | ||||
| #define ARM_MPU_AP_(RO, NP) (((RO & 1U) << 1U) | (NP & 1U)) | ||||
|  | ||||
| /** \brief Region Base Address Register value | ||||
| * \param BASE The base address bits [31:5] of a memory region. The value is zero extended. Effective address gets 32 byte aligned. | ||||
| @@ -87,18 +87,18 @@ | ||||
| * \oaram XN eXecute Never: Set to 1 for a non-executable memory region. | ||||
| */ | ||||
| #define ARM_MPU_RBAR(BASE, SH, RO, NP, XN) \ | ||||
|   (((BASE) & MPU_RBAR_BASE_Msk) | \ | ||||
|   (((SH) << MPU_RBAR_SH_Pos) & MPU_RBAR_SH_Msk) | \ | ||||
|   ((BASE & MPU_RBAR_BASE_Msk) | \ | ||||
|   ((SH << MPU_RBAR_SH_Pos) & MPU_RBAR_SH_Msk) | \ | ||||
|   ((ARM_MPU_AP_(RO, NP) << MPU_RBAR_AP_Pos) & MPU_RBAR_AP_Msk) | \ | ||||
|   (((XN) << MPU_RBAR_XN_Pos) & MPU_RBAR_XN_Msk)) | ||||
|   ((XN << MPU_RBAR_XN_Pos) & MPU_RBAR_XN_Msk)) | ||||
|  | ||||
| /** \brief Region Limit Address Register value | ||||
| * \param LIMIT The limit address bits [31:5] for this memory region. The value is one extended. | ||||
| * \param IDX The attribute index to be associated with this memory region. | ||||
| */ | ||||
| #define ARM_MPU_RLAR(LIMIT, IDX) \ | ||||
|   (((LIMIT) & MPU_RLAR_LIMIT_Msk) | \ | ||||
|   (((IDX) << MPU_RLAR_AttrIndx_Pos) & MPU_RLAR_AttrIndx_Msk) | \ | ||||
|   ((LIMIT & MPU_RLAR_LIMIT_Msk) | \ | ||||
|   ((IDX << MPU_RLAR_AttrIndx_Pos) & MPU_RLAR_AttrIndx_Msk) | \ | ||||
|   (MPU_RLAR_EN_Msk)) | ||||
|  | ||||
| #if defined(MPU_RLAR_PXN_Pos) | ||||
| @@ -109,9 +109,9 @@ | ||||
| * \param IDX The attribute index to be associated with this memory region. | ||||
| */ | ||||
| #define ARM_MPU_RLAR_PXN(LIMIT, PXN, IDX) \ | ||||
|   (((LIMIT) & MPU_RLAR_LIMIT_Msk) | \ | ||||
|   (((PXN) << MPU_RLAR_PXN_Pos) & MPU_RLAR_PXN_Msk) | \ | ||||
|   (((IDX) << MPU_RLAR_AttrIndx_Pos) & MPU_RLAR_AttrIndx_Msk) | \ | ||||
|   ((LIMIT & MPU_RLAR_LIMIT_Msk) | \ | ||||
|   ((PXN << MPU_RLAR_PXN_Pos) & MPU_RLAR_PXN_Msk) | \ | ||||
|   ((IDX << MPU_RLAR_AttrIndx_Pos) & MPU_RLAR_AttrIndx_Msk) | \ | ||||
|   (MPU_RLAR_EN_Msk)) | ||||
|    | ||||
| #endif | ||||
| @@ -129,7 +129,6 @@ typedef struct { | ||||
| */ | ||||
| __STATIC_INLINE void ARM_MPU_Enable(uint32_t MPU_Control) | ||||
| { | ||||
|   __DMB(); | ||||
|   MPU->CTRL = MPU_Control | MPU_CTRL_ENABLE_Msk; | ||||
| #ifdef SCB_SHCSR_MEMFAULTENA_Msk | ||||
|   SCB->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk; | ||||
| @@ -147,8 +146,6 @@ __STATIC_INLINE void ARM_MPU_Disable(void) | ||||
|   SCB->SHCSR &= ~SCB_SHCSR_MEMFAULTENA_Msk; | ||||
| #endif | ||||
|   MPU->CTRL  &= ~MPU_CTRL_ENABLE_Msk; | ||||
|   __DSB(); | ||||
|   __ISB(); | ||||
| } | ||||
|  | ||||
| #ifdef MPU_NS | ||||
| @@ -157,7 +154,6 @@ __STATIC_INLINE void ARM_MPU_Disable(void) | ||||
| */ | ||||
| __STATIC_INLINE void ARM_MPU_Enable_NS(uint32_t MPU_Control) | ||||
| { | ||||
|   __DMB(); | ||||
|   MPU_NS->CTRL = MPU_Control | MPU_CTRL_ENABLE_Msk; | ||||
| #ifdef SCB_SHCSR_MEMFAULTENA_Msk | ||||
|   SCB_NS->SHCSR |= SCB_SHCSR_MEMFAULTENA_Msk; | ||||
| @@ -175,8 +171,6 @@ __STATIC_INLINE void ARM_MPU_Disable_NS(void) | ||||
|   SCB_NS->SHCSR &= ~SCB_SHCSR_MEMFAULTENA_Msk; | ||||
| #endif | ||||
|   MPU_NS->CTRL  &= ~MPU_CTRL_ENABLE_Msk; | ||||
|   __DSB(); | ||||
|   __ISB(); | ||||
| } | ||||
| #endif | ||||
|  | ||||
| @@ -281,7 +275,7 @@ __STATIC_INLINE void ARM_MPU_SetRegion_NS(uint32_t rnr, uint32_t rbar, uint32_t | ||||
| } | ||||
| #endif | ||||
|  | ||||
| /** Memcpy with strictly ordered memory access, e.g. used by code in ARM_MPU_LoadEx() | ||||
| /** Memcopy with strictly ordered memory access, e.g. for register targets. | ||||
| * \param dst Destination data is copied to. | ||||
| * \param src Source data is copied from. | ||||
| * \param len Amount of data words to be copied. | ||||
|   | ||||
| @@ -1,206 +0,0 @@ | ||||
| /****************************************************************************** | ||||
|  * @file     pac_armv81.h | ||||
|  * @brief    CMSIS PAC key functions for Armv8.1-M PAC extension | ||||
|  * @version  V1.0.0 | ||||
|  * @date     23. March 2022 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2022 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the License); you may | ||||
|  * not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an AS IS BASIS, WITHOUT | ||||
|  * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
|  | ||||
| #if   defined ( __ICCARM__ ) | ||||
|   #pragma system_include         /* treat file as system include file for MISRA check */ | ||||
| #elif defined (__clang__) | ||||
|   #pragma clang system_header    /* treat file as system include file */ | ||||
| #endif | ||||
|  | ||||
| #ifndef PAC_ARMV81_H | ||||
| #define PAC_ARMV81_H | ||||
|  | ||||
|  | ||||
| /* ###################  PAC Key functions  ########################### */ | ||||
| /** | ||||
|   \ingroup  CMSIS_Core_FunctionInterface | ||||
|   \defgroup CMSIS_Core_PacKeyFunctions PAC Key functions | ||||
|   \brief    Functions that access the PAC keys. | ||||
|   @{ | ||||
|  */ | ||||
|  | ||||
| #if (defined (__ARM_FEATURE_PAUTH) && (__ARM_FEATURE_PAUTH == 1)) | ||||
|  | ||||
| /** | ||||
|   \brief   read the PAC key used for privileged mode | ||||
|   \details Reads the PAC key stored in the PAC_KEY_P registers. | ||||
|   \param [out]    pPacKey  128bit PAC key | ||||
|  */ | ||||
| __STATIC_FORCEINLINE void __get_PAC_KEY_P (uint32_t* pPacKey) { | ||||
|   __ASM volatile ( | ||||
|   "mrs   r1, pac_key_p_0\n" | ||||
|   "str   r1,[%0,#0]\n" | ||||
|   "mrs   r1, pac_key_p_1\n" | ||||
|   "str   r1,[%0,#4]\n" | ||||
|   "mrs   r1, pac_key_p_2\n" | ||||
|   "str   r1,[%0,#8]\n" | ||||
|   "mrs   r1, pac_key_p_3\n" | ||||
|   "str   r1,[%0,#12]\n" | ||||
|   : : "r" (pPacKey) : "memory", "r1" | ||||
|   ); | ||||
| } | ||||
|  | ||||
| /** | ||||
|   \brief   write the PAC key used for privileged mode | ||||
|   \details writes the given PAC key to the PAC_KEY_P registers. | ||||
|   \param [in]    pPacKey  128bit PAC key | ||||
|  */ | ||||
| __STATIC_FORCEINLINE void __set_PAC_KEY_P (uint32_t* pPacKey) { | ||||
|   __ASM volatile ( | ||||
|   "ldr   r1,[%0,#0]\n" | ||||
|   "msr   pac_key_p_0, r1\n" | ||||
|   "ldr   r1,[%0,#4]\n" | ||||
|   "msr   pac_key_p_1, r1\n" | ||||
|   "ldr   r1,[%0,#8]\n" | ||||
|   "msr   pac_key_p_2, r1\n" | ||||
|   "ldr   r1,[%0,#12]\n" | ||||
|   "msr   pac_key_p_3, r1\n" | ||||
|   : : "r" (pPacKey) : "memory", "r1" | ||||
|   ); | ||||
| } | ||||
|  | ||||
| /** | ||||
|   \brief   read the PAC key used for unprivileged mode | ||||
|   \details Reads the PAC key stored in the PAC_KEY_U registers. | ||||
|   \param [out]    pPacKey  128bit PAC key | ||||
|  */ | ||||
| __STATIC_FORCEINLINE void __get_PAC_KEY_U (uint32_t* pPacKey) { | ||||
|   __ASM volatile ( | ||||
|   "mrs   r1, pac_key_u_0\n" | ||||
|   "str   r1,[%0,#0]\n" | ||||
|   "mrs   r1, pac_key_u_1\n" | ||||
|   "str   r1,[%0,#4]\n" | ||||
|   "mrs   r1, pac_key_u_2\n" | ||||
|   "str   r1,[%0,#8]\n" | ||||
|   "mrs   r1, pac_key_u_3\n" | ||||
|   "str   r1,[%0,#12]\n" | ||||
|   : : "r" (pPacKey) : "memory", "r1" | ||||
|   ); | ||||
| } | ||||
|  | ||||
| /** | ||||
|   \brief   write the PAC key used for unprivileged mode | ||||
|   \details writes the given PAC key to the PAC_KEY_U registers. | ||||
|   \param [in]    pPacKey  128bit PAC key | ||||
|  */ | ||||
| __STATIC_FORCEINLINE void __set_PAC_KEY_U (uint32_t* pPacKey) { | ||||
|   __ASM volatile ( | ||||
|   "ldr   r1,[%0,#0]\n" | ||||
|   "msr   pac_key_u_0, r1\n" | ||||
|   "ldr   r1,[%0,#4]\n" | ||||
|   "msr   pac_key_u_1, r1\n" | ||||
|   "ldr   r1,[%0,#8]\n" | ||||
|   "msr   pac_key_u_2, r1\n" | ||||
|   "ldr   r1,[%0,#12]\n" | ||||
|   "msr   pac_key_u_3, r1\n" | ||||
|   : : "r" (pPacKey) : "memory", "r1" | ||||
|   ); | ||||
| } | ||||
|  | ||||
| #if (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) | ||||
|  | ||||
| /** | ||||
|   \brief   read the PAC key used for privileged mode (non-secure) | ||||
|   \details Reads the PAC key stored in the non-secure PAC_KEY_P registers when in secure mode. | ||||
|   \param [out]    pPacKey  128bit PAC key | ||||
|  */ | ||||
| __STATIC_FORCEINLINE void __TZ_get_PAC_KEY_P_NS (uint32_t* pPacKey) { | ||||
|   __ASM volatile ( | ||||
|   "mrs   r1, pac_key_p_0_ns\n" | ||||
|   "str   r1,[%0,#0]\n" | ||||
|   "mrs   r1, pac_key_p_1_ns\n" | ||||
|   "str   r1,[%0,#4]\n" | ||||
|   "mrs   r1, pac_key_p_2_ns\n" | ||||
|   "str   r1,[%0,#8]\n" | ||||
|   "mrs   r1, pac_key_p_3_ns\n" | ||||
|   "str   r1,[%0,#12]\n" | ||||
|   : : "r" (pPacKey) : "memory", "r1" | ||||
|   ); | ||||
| } | ||||
|  | ||||
| /** | ||||
|   \brief   write the PAC key used for privileged mode (non-secure) | ||||
|   \details writes the given PAC key to the non-secure PAC_KEY_P registers when in secure mode. | ||||
|   \param [in]    pPacKey  128bit PAC key | ||||
|  */ | ||||
| __STATIC_FORCEINLINE void __TZ_set_PAC_KEY_P_NS (uint32_t* pPacKey) { | ||||
|   __ASM volatile ( | ||||
|   "ldr   r1,[%0,#0]\n" | ||||
|   "msr   pac_key_p_0_ns, r1\n" | ||||
|   "ldr   r1,[%0,#4]\n" | ||||
|   "msr   pac_key_p_1_ns, r1\n" | ||||
|   "ldr   r1,[%0,#8]\n" | ||||
|   "msr   pac_key_p_2_ns, r1\n" | ||||
|   "ldr   r1,[%0,#12]\n" | ||||
|   "msr   pac_key_p_3_ns, r1\n" | ||||
|   : : "r" (pPacKey) : "memory", "r1" | ||||
|   ); | ||||
| } | ||||
|  | ||||
| /** | ||||
|   \brief   read the PAC key used for unprivileged mode (non-secure) | ||||
|   \details Reads the PAC key stored in the non-secure PAC_KEY_U registers when in secure mode. | ||||
|   \param [out]    pPacKey  128bit PAC key | ||||
|  */ | ||||
| __STATIC_FORCEINLINE void __TZ_get_PAC_KEY_U_NS (uint32_t* pPacKey) { | ||||
|   __ASM volatile ( | ||||
|   "mrs   r1, pac_key_u_0_ns\n" | ||||
|   "str   r1,[%0,#0]\n" | ||||
|   "mrs   r1, pac_key_u_1_ns\n" | ||||
|   "str   r1,[%0,#4]\n" | ||||
|   "mrs   r1, pac_key_u_2_ns\n" | ||||
|   "str   r1,[%0,#8]\n" | ||||
|   "mrs   r1, pac_key_u_3_ns\n" | ||||
|   "str   r1,[%0,#12]\n" | ||||
|   : : "r" (pPacKey) : "memory", "r1" | ||||
|   ); | ||||
| } | ||||
|  | ||||
| /** | ||||
|   \brief   write the PAC key used for unprivileged mode (non-secure) | ||||
|   \details writes the given PAC key to the non-secure PAC_KEY_U registers when in secure mode. | ||||
|   \param [in]    pPacKey  128bit PAC key | ||||
|  */ | ||||
| __STATIC_FORCEINLINE void __TZ_set_PAC_KEY_U_NS (uint32_t* pPacKey) { | ||||
|   __ASM volatile ( | ||||
|   "ldr   r1,[%0,#0]\n" | ||||
|   "msr   pac_key_u_0_ns, r1\n" | ||||
|   "ldr   r1,[%0,#4]\n" | ||||
|   "msr   pac_key_u_1_ns, r1\n" | ||||
|   "ldr   r1,[%0,#8]\n" | ||||
|   "msr   pac_key_u_2_ns, r1\n" | ||||
|   "ldr   r1,[%0,#12]\n" | ||||
|   "msr   pac_key_u_3_ns, r1\n" | ||||
|   : : "r" (pPacKey) : "memory", "r1" | ||||
|   ); | ||||
| } | ||||
|  | ||||
| #endif /* (defined (__ARM_FEATURE_CMSE ) && (__ARM_FEATURE_CMSE == 3)) */ | ||||
|  | ||||
| #endif /* (defined (__ARM_FEATURE_PAUTH) && (__ARM_FEATURE_PAUTH == 1)) */ | ||||
|  | ||||
| /*@} end of CMSIS_Core_PacKeyFunctions */ | ||||
|  | ||||
|  | ||||
| #endif /* PAC_ARMV81_H */ | ||||
| @@ -1,337 +0,0 @@ | ||||
| /****************************************************************************** | ||||
|  * @file     pmu_armv8.h | ||||
|  * @brief    CMSIS PMU API for Armv8.1-M PMU | ||||
|  * @version  V1.0.1 | ||||
|  * @date     15. April 2020 | ||||
|  ******************************************************************************/ | ||||
| /* | ||||
|  * Copyright (c) 2020 Arm Limited. All rights reserved. | ||||
|  * | ||||
|  * SPDX-License-Identifier: Apache-2.0 | ||||
|  * | ||||
|  * Licensed under the Apache License, Version 2.0 (the License); you may | ||||
|  * not use this file except in compliance with the License. | ||||
|  * You may obtain a copy of the License at | ||||
|  * | ||||
|  * www.apache.org/licenses/LICENSE-2.0 | ||||
|  * | ||||
|  * Unless required by applicable law or agreed to in writing, software | ||||
|  * distributed under the License is distributed on an AS IS BASIS, WITHOUT | ||||
|  * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
|  * See the License for the specific language governing permissions and | ||||
|  * limitations under the License. | ||||
|  */ | ||||
|  | ||||
| #if   defined ( __ICCARM__ ) | ||||
|   #pragma system_include         /* treat file as system include file for MISRA check */ | ||||
| #elif defined (__clang__) | ||||
|   #pragma clang system_header    /* treat file as system include file */ | ||||
| #endif | ||||
|  | ||||
| #ifndef ARM_PMU_ARMV8_H | ||||
| #define ARM_PMU_ARMV8_H | ||||
|  | ||||
| /** | ||||
|  * \brief PMU Events | ||||
|  * \note  See the Armv8.1-M Architecture Reference Manual for full details on these PMU events. | ||||
|  * */ | ||||
|  | ||||
| #define ARM_PMU_SW_INCR                              0x0000             /*!< Software update to the PMU_SWINC register, architecturally executed and condition code check pass */ | ||||
| #define ARM_PMU_L1I_CACHE_REFILL                     0x0001             /*!< L1 I-Cache refill */ | ||||
| #define ARM_PMU_L1D_CACHE_REFILL                     0x0003             /*!< L1 D-Cache refill */ | ||||
| #define ARM_PMU_L1D_CACHE                            0x0004             /*!< L1 D-Cache access */ | ||||
| #define ARM_PMU_LD_RETIRED                           0x0006             /*!< Memory-reading instruction architecturally executed and condition code check pass */ | ||||
| #define ARM_PMU_ST_RETIRED                           0x0007             /*!< Memory-writing instruction architecturally executed and condition code check pass */ | ||||
| #define ARM_PMU_INST_RETIRED                         0x0008             /*!< Instruction architecturally executed */ | ||||
| #define ARM_PMU_EXC_TAKEN                            0x0009             /*!< Exception entry */ | ||||
| #define ARM_PMU_EXC_RETURN                           0x000A             /*!< Exception return instruction architecturally executed and the condition code check pass */ | ||||
| #define ARM_PMU_PC_WRITE_RETIRED                     0x000C             /*!< Software change to the Program Counter (PC). Instruction is architecturally executed and condition code check pass */ | ||||
| #define ARM_PMU_BR_IMMED_RETIRED                     0x000D             /*!< Immediate branch architecturally executed */ | ||||
| #define ARM_PMU_BR_RETURN_RETIRED                    0x000E             /*!< Function return instruction architecturally executed and the condition code check pass */ | ||||
| #define ARM_PMU_UNALIGNED_LDST_RETIRED               0x000F             /*!< Unaligned memory memory-reading or memory-writing instruction architecturally executed and condition code check pass */ | ||||
| #define ARM_PMU_BR_MIS_PRED                          0x0010             /*!< Mispredicted or not predicted branch speculatively executed */ | ||||
| #define ARM_PMU_CPU_CYCLES                           0x0011             /*!< Cycle */ | ||||
| #define ARM_PMU_BR_PRED                              0x0012             /*!< Predictable branch speculatively executed */ | ||||
| #define ARM_PMU_MEM_ACCESS                           0x0013             /*!< Data memory access */ | ||||
| #define ARM_PMU_L1I_CACHE                            0x0014             /*!< Level 1 instruction cache access */ | ||||
| #define ARM_PMU_L1D_CACHE_WB                         0x0015             /*!< Level 1 data cache write-back */ | ||||
| #define ARM_PMU_L2D_CACHE                            0x0016             /*!< Level 2 data cache access */ | ||||
| #define ARM_PMU_L2D_CACHE_REFILL                     0x0017             /*!< Level 2 data cache refill */ | ||||
| #define ARM_PMU_L2D_CACHE_WB                         0x0018             /*!< Level 2 data cache write-back */ | ||||
| #define ARM_PMU_BUS_ACCESS                           0x0019             /*!< Bus access */ | ||||
| #define ARM_PMU_MEMORY_ERROR                         0x001A             /*!< Local memory error */ | ||||
| #define ARM_PMU_INST_SPEC                            0x001B             /*!< Instruction speculatively executed */ | ||||
| #define ARM_PMU_BUS_CYCLES                           0x001D             /*!< Bus cycles */ | ||||
| #define ARM_PMU_CHAIN                                0x001E             /*!< For an odd numbered counter, increment when an overflow occurs on the preceding even-numbered counter on the same PE */ | ||||
| #define ARM_PMU_L1D_CACHE_ALLOCATE                   0x001F             /*!< Level 1 data cache allocation without refill */ | ||||
| #define ARM_PMU_L2D_CACHE_ALLOCATE                   0x0020             /*!< Level 2 data cache allocation without refill */ | ||||
| #define ARM_PMU_BR_RETIRED                           0x0021             /*!< Branch instruction architecturally executed */ | ||||
| #define ARM_PMU_BR_MIS_PRED_RETIRED                  0x0022             /*!< Mispredicted branch instruction architecturally executed */ | ||||
| #define ARM_PMU_STALL_FRONTEND                       0x0023             /*!< No operation issued because of the frontend */ | ||||
| #define ARM_PMU_STALL_BACKEND                        0x0024             /*!< No operation issued because of the backend */ | ||||
| #define ARM_PMU_L2I_CACHE                            0x0027             /*!< Level 2 instruction cache access */ | ||||
| #define ARM_PMU_L2I_CACHE_REFILL                     0x0028             /*!< Level 2 instruction cache refill */ | ||||
| #define ARM_PMU_L3D_CACHE_ALLOCATE                   0x0029             /*!< Level 3 data cache allocation without refill */ | ||||
| #define ARM_PMU_L3D_CACHE_REFILL                     0x002A             /*!< Level 3 data cache refill */ | ||||
| #define ARM_PMU_L3D_CACHE                            0x002B             /*!< Level 3 data cache access */ | ||||
| #define ARM_PMU_L3D_CACHE_WB                         0x002C             /*!< Level 3 data cache write-back */ | ||||
| #define ARM_PMU_LL_CACHE_RD                          0x0036             /*!< Last level data cache read */ | ||||
| #define ARM_PMU_LL_CACHE_MISS_RD                     0x0037             /*!< Last level data cache read miss */ | ||||
| #define ARM_PMU_L1D_CACHE_MISS_RD                    0x0039             /*!< Level 1 data cache read miss */ | ||||
| #define ARM_PMU_OP_COMPLETE                          0x003A             /*!< Operation retired */ | ||||
| #define ARM_PMU_OP_SPEC                              0x003B             /*!< Operation speculatively executed */ | ||||
| #define ARM_PMU_STALL                                0x003C             /*!< Stall cycle for instruction or operation not sent for execution */ | ||||
| #define ARM_PMU_STALL_OP_BACKEND                     0x003D             /*!< Stall cycle for instruction or operation not sent for execution due to pipeline backend */ | ||||
| #define ARM_PMU_STALL_OP_FRONTEND                    0x003E             /*!< Stall cycle for instruction or operation not sent for execution due to pipeline frontend */ | ||||
| #define ARM_PMU_STALL_OP                             0x003F             /*!< Instruction or operation slots not occupied each cycle */ | ||||
| #define ARM_PMU_L1D_CACHE_RD                         0x0040             /*!< Level 1 data cache read */ | ||||
| #define ARM_PMU_LE_RETIRED                           0x0100             /*!< Loop end instruction executed */ | ||||
| #define ARM_PMU_LE_SPEC                              0x0101             /*!< Loop end instruction speculatively executed */ | ||||
| #define ARM_PMU_BF_RETIRED                           0x0104             /*!< Branch future instruction architecturally executed and condition code check pass */ | ||||
| #define ARM_PMU_BF_SPEC                              0x0105             /*!< Branch future instruction speculatively executed and condition code check pass */ | ||||
| #define ARM_PMU_LE_CANCEL                            0x0108             /*!< Loop end instruction not taken */ | ||||
| #define ARM_PMU_BF_CANCEL                            0x0109             /*!< Branch future instruction not taken */ | ||||
| #define ARM_PMU_SE_CALL_S                            0x0114             /*!< Call to secure function, resulting in Security state change */ | ||||
| #define ARM_PMU_SE_CALL_NS                           0x0115             /*!< Call to non-secure function, resulting in Security state change */ | ||||
| #define ARM_PMU_DWT_CMPMATCH0                        0x0118             /*!< DWT comparator 0 match */ | ||||
| #define ARM_PMU_DWT_CMPMATCH1                        0x0119             /*!< DWT comparator 1 match */ | ||||
| #define ARM_PMU_DWT_CMPMATCH2                        0x011A             /*!< DWT comparator 2 match */ | ||||
| #define ARM_PMU_DWT_CMPMATCH3                        0x011B             /*!< DWT comparator 3 match */ | ||||
| #define ARM_PMU_MVE_INST_RETIRED                     0x0200             /*!< MVE instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_INST_SPEC                        0x0201             /*!< MVE instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_FP_RETIRED                       0x0204             /*!< MVE floating-point instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_FP_SPEC                          0x0205             /*!< MVE floating-point instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_FP_HP_RETIRED                    0x0208             /*!< MVE half-precision floating-point instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_FP_HP_SPEC                       0x0209             /*!< MVE half-precision floating-point instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_FP_SP_RETIRED                    0x020C             /*!< MVE single-precision floating-point instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_FP_SP_SPEC                       0x020D             /*!< MVE single-precision floating-point instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_FP_MAC_RETIRED                   0x0214             /*!< MVE floating-point multiply or multiply-accumulate instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_FP_MAC_SPEC                      0x0215             /*!< MVE floating-point multiply or multiply-accumulate instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_INT_RETIRED                      0x0224             /*!< MVE integer instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_INT_SPEC                         0x0225             /*!< MVE integer instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_INT_MAC_RETIRED                  0x0228             /*!< MVE multiply or multiply-accumulate instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_INT_MAC_SPEC                     0x0229             /*!< MVE multiply or multiply-accumulate instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_LDST_RETIRED                     0x0238             /*!< MVE load or store instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_LDST_SPEC                        0x0239             /*!< MVE load or store instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_LD_RETIRED                       0x023C             /*!< MVE load instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_LD_SPEC                          0x023D             /*!< MVE load instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_ST_RETIRED                       0x0240             /*!< MVE store instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_ST_SPEC                          0x0241             /*!< MVE store instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_LDST_CONTIG_RETIRED              0x0244             /*!< MVE contiguous load or store instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_LDST_CONTIG_SPEC                 0x0245             /*!< MVE contiguous load or store instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_LD_CONTIG_RETIRED                0x0248             /*!< MVE contiguous load instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_LD_CONTIG_SPEC                   0x0249             /*!< MVE contiguous load instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_ST_CONTIG_RETIRED                0x024C             /*!< MVE contiguous store instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_ST_CONTIG_SPEC                   0x024D             /*!< MVE contiguous store instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_LDST_NONCONTIG_RETIRED           0x0250             /*!< MVE non-contiguous load or store instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_LDST_NONCONTIG_SPEC              0x0251             /*!< MVE non-contiguous load or store instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_LD_NONCONTIG_RETIRED             0x0254             /*!< MVE non-contiguous load instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_LD_NONCONTIG_SPEC                0x0255             /*!< MVE non-contiguous load instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_ST_NONCONTIG_RETIRED             0x0258             /*!< MVE non-contiguous store instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_ST_NONCONTIG_SPEC                0x0259             /*!< MVE non-contiguous store instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_LDST_MULTI_RETIRED               0x025C             /*!< MVE memory instruction targeting multiple registers architecturally executed */ | ||||
| #define ARM_PMU_MVE_LDST_MULTI_SPEC                  0x025D             /*!< MVE memory instruction targeting multiple registers speculatively executed */ | ||||
| #define ARM_PMU_MVE_LD_MULTI_RETIRED                 0x0260             /*!< MVE memory load instruction targeting multiple registers architecturally executed */ | ||||
| #define ARM_PMU_MVE_LD_MULTI_SPEC                    0x0261             /*!< MVE memory load instruction targeting multiple registers speculatively executed */ | ||||
| #define ARM_PMU_MVE_ST_MULTI_RETIRED                 0x0261             /*!< MVE memory store instruction targeting multiple registers architecturally executed */ | ||||
| #define ARM_PMU_MVE_ST_MULTI_SPEC                    0x0265             /*!< MVE memory store instruction targeting multiple registers speculatively executed */ | ||||
| #define ARM_PMU_MVE_LDST_UNALIGNED_RETIRED           0x028C             /*!< MVE unaligned memory load or store instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_LDST_UNALIGNED_SPEC              0x028D             /*!< MVE unaligned memory load or store instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_LD_UNALIGNED_RETIRED             0x0290             /*!< MVE unaligned load instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_LD_UNALIGNED_SPEC                0x0291             /*!< MVE unaligned load instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_ST_UNALIGNED_RETIRED             0x0294             /*!< MVE unaligned store instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_ST_UNALIGNED_SPEC                0x0295             /*!< MVE unaligned store instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_LDST_UNALIGNED_NONCONTIG_RETIRED 0x0298             /*!< MVE unaligned noncontiguous load or store instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_LDST_UNALIGNED_NONCONTIG_SPEC    0x0299             /*!< MVE unaligned noncontiguous load or store instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_VREDUCE_RETIRED                  0x02A0             /*!< MVE vector reduction instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_VREDUCE_SPEC                     0x02A1             /*!< MVE vector reduction instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_VREDUCE_FP_RETIRED               0x02A4             /*!< MVE floating-point vector reduction instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_VREDUCE_FP_SPEC                  0x02A5             /*!< MVE floating-point vector reduction instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_VREDUCE_INT_RETIRED              0x02A8             /*!< MVE integer vector reduction instruction architecturally executed */ | ||||
| #define ARM_PMU_MVE_VREDUCE_INT_SPEC                 0x02A9             /*!< MVE integer vector reduction instruction speculatively executed */ | ||||
| #define ARM_PMU_MVE_PRED                             0x02B8             /*!< Cycles where one or more predicated beats architecturally executed */ | ||||
| #define ARM_PMU_MVE_STALL                            0x02CC             /*!< Stall cycles caused by an MVE instruction */ | ||||
| #define ARM_PMU_MVE_STALL_RESOURCE                   0x02CD             /*!< Stall cycles caused by an MVE instruction because of resource conflicts */ | ||||
| #define ARM_PMU_MVE_STALL_RESOURCE_MEM               0x02CE             /*!< Stall cycles caused by an MVE instruction because of memory resource conflicts */ | ||||
| #define ARM_PMU_MVE_STALL_RESOURCE_FP                0x02CF             /*!< Stall cycles caused by an MVE instruction because of floating-point resource conflicts */ | ||||
| #define ARM_PMU_MVE_STALL_RESOURCE_INT               0x02D0             /*!< Stall cycles caused by an MVE instruction because of integer resource conflicts */ | ||||
| #define ARM_PMU_MVE_STALL_BREAK                      0x02D3             /*!< Stall cycles caused by an MVE chain break */ | ||||
| #define ARM_PMU_MVE_STALL_DEPENDENCY                 0x02D4             /*!< Stall cycles caused by MVE register dependency */ | ||||
| #define ARM_PMU_ITCM_ACCESS                          0x4007             /*!< Instruction TCM access */ | ||||
| #define ARM_PMU_DTCM_ACCESS                          0x4008             /*!< Data TCM access */ | ||||
| #define ARM_PMU_TRCEXTOUT0                           0x4010             /*!< ETM external output 0 */ | ||||
| #define ARM_PMU_TRCEXTOUT1                           0x4011             /*!< ETM external output 1 */ | ||||
| #define ARM_PMU_TRCEXTOUT2                           0x4012             /*!< ETM external output 2 */ | ||||
| #define ARM_PMU_TRCEXTOUT3                           0x4013             /*!< ETM external output 3 */ | ||||
| #define ARM_PMU_CTI_TRIGOUT4                         0x4018             /*!< Cross-trigger Interface output trigger 4 */ | ||||
| #define ARM_PMU_CTI_TRIGOUT5                         0x4019             /*!< Cross-trigger Interface output trigger 5 */ | ||||
| #define ARM_PMU_CTI_TRIGOUT6                         0x401A             /*!< Cross-trigger Interface output trigger 6 */ | ||||
| #define ARM_PMU_CTI_TRIGOUT7                         0x401B             /*!< Cross-trigger Interface output trigger 7 */ | ||||
|  | ||||
| /** \brief PMU Functions */ | ||||
|  | ||||
| __STATIC_INLINE void ARM_PMU_Enable(void); | ||||
| __STATIC_INLINE void ARM_PMU_Disable(void); | ||||
|  | ||||
| __STATIC_INLINE void ARM_PMU_Set_EVTYPER(uint32_t num, uint32_t type); | ||||
|  | ||||
| __STATIC_INLINE void ARM_PMU_CYCCNT_Reset(void); | ||||
| __STATIC_INLINE void ARM_PMU_EVCNTR_ALL_Reset(void); | ||||
|  | ||||
| __STATIC_INLINE void ARM_PMU_CNTR_Enable(uint32_t mask); | ||||
| __STATIC_INLINE void ARM_PMU_CNTR_Disable(uint32_t mask); | ||||
|  | ||||
| __STATIC_INLINE uint32_t ARM_PMU_Get_CCNTR(void); | ||||
| __STATIC_INLINE uint32_t ARM_PMU_Get_EVCNTR(uint32_t num); | ||||
|  | ||||
| __STATIC_INLINE uint32_t ARM_PMU_Get_CNTR_OVS(void); | ||||
| __STATIC_INLINE void ARM_PMU_Set_CNTR_OVS(uint32_t mask); | ||||
|  | ||||
| __STATIC_INLINE void ARM_PMU_Set_CNTR_IRQ_Enable(uint32_t mask); | ||||
| __STATIC_INLINE void ARM_PMU_Set_CNTR_IRQ_Disable(uint32_t mask); | ||||
|  | ||||
| __STATIC_INLINE void ARM_PMU_CNTR_Increment(uint32_t mask); | ||||
|  | ||||
| /**  | ||||
|   \brief   Enable the PMU | ||||
| */ | ||||
| __STATIC_INLINE void ARM_PMU_Enable(void)  | ||||
| { | ||||
|   PMU->CTRL |= PMU_CTRL_ENABLE_Msk; | ||||
| } | ||||
|  | ||||
| /**  | ||||
|   \brief   Disable the PMU | ||||
| */ | ||||
| __STATIC_INLINE void ARM_PMU_Disable(void)  | ||||
| { | ||||
|   PMU->CTRL &= ~PMU_CTRL_ENABLE_Msk; | ||||
| } | ||||
|  | ||||
| /**  | ||||
|   \brief   Set event to count for PMU eventer counter | ||||
|   \param [in]    num     Event counter (0-30) to configure | ||||
|   \param [in]    type    Event to count | ||||
| */ | ||||
| __STATIC_INLINE void ARM_PMU_Set_EVTYPER(uint32_t num, uint32_t type) | ||||
| { | ||||
|   PMU->EVTYPER[num] = type; | ||||
| } | ||||
|  | ||||
| /**  | ||||
|   \brief  Reset cycle counter | ||||
| */ | ||||
| __STATIC_INLINE void ARM_PMU_CYCCNT_Reset(void) | ||||
| { | ||||
|   PMU->CTRL |= PMU_CTRL_CYCCNT_RESET_Msk; | ||||
| } | ||||
|  | ||||
| /**  | ||||
|   \brief  Reset all event counters | ||||
| */ | ||||
| __STATIC_INLINE void ARM_PMU_EVCNTR_ALL_Reset(void) | ||||
| { | ||||
|   PMU->CTRL |= PMU_CTRL_EVENTCNT_RESET_Msk; | ||||
| } | ||||
|  | ||||
| /**  | ||||
|   \brief  Enable counters  | ||||
|   \param [in]     mask    Counters to enable | ||||
|   \note   Enables one or more of the following: | ||||
|           - event counters (0-30) | ||||
|           - cycle counter | ||||
| */ | ||||
| __STATIC_INLINE void ARM_PMU_CNTR_Enable(uint32_t mask) | ||||
| { | ||||
|   PMU->CNTENSET = mask; | ||||
| } | ||||
|  | ||||
| /**  | ||||
|   \brief  Disable counters | ||||
|   \param [in]     mask    Counters to enable | ||||
|   \note   Disables one or more of the following: | ||||
|           - event counters (0-30) | ||||
|           - cycle counter | ||||
| */ | ||||
| __STATIC_INLINE void ARM_PMU_CNTR_Disable(uint32_t mask) | ||||
| { | ||||
|   PMU->CNTENCLR = mask; | ||||
| } | ||||
|  | ||||
| /**  | ||||
|   \brief  Read cycle counter | ||||
|   \return                 Cycle count | ||||
| */ | ||||
| __STATIC_INLINE uint32_t ARM_PMU_Get_CCNTR(void) | ||||
| { | ||||
|   return PMU->CCNTR; | ||||
| } | ||||
|  | ||||
| /**  | ||||
|   \brief   Read event counter | ||||
|   \param [in]     num     Event counter (0-30) to read | ||||
|   \return                 Event count | ||||
| */ | ||||
| __STATIC_INLINE uint32_t ARM_PMU_Get_EVCNTR(uint32_t num) | ||||
| { | ||||
|   return PMU_EVCNTR_CNT_Msk & PMU->EVCNTR[num]; | ||||
| } | ||||
|  | ||||
| /**  | ||||
|   \brief   Read counter overflow status | ||||
|   \return  Counter overflow status bits for the following: | ||||
|           - event counters (0-30) | ||||
|           - cycle counter | ||||
| */ | ||||
| __STATIC_INLINE uint32_t ARM_PMU_Get_CNTR_OVS(void) | ||||
| { | ||||
|   return PMU->OVSSET;	 | ||||
| } | ||||
|  | ||||
| /**  | ||||
|   \brief   Clear counter overflow status | ||||
|   \param [in]     mask    Counter overflow status bits to clear | ||||
|   \note    Clears overflow status bits for one or more of the following: | ||||
|            - event counters (0-30) | ||||
|            - cycle counter | ||||
| */ | ||||
| __STATIC_INLINE void ARM_PMU_Set_CNTR_OVS(uint32_t mask) | ||||
| { | ||||
|   PMU->OVSCLR = mask; | ||||
| } | ||||
|  | ||||
| /**  | ||||
|   \brief   Enable counter overflow interrupt request  | ||||
|   \param [in]     mask    Counter overflow interrupt request bits to set | ||||
|   \note    Sets overflow interrupt request bits for one or more of the following: | ||||
|            - event counters (0-30) | ||||
|            - cycle counter | ||||
| */ | ||||
| __STATIC_INLINE void ARM_PMU_Set_CNTR_IRQ_Enable(uint32_t mask) | ||||
| { | ||||
|   PMU->INTENSET = mask; | ||||
| } | ||||
|  | ||||
| /**  | ||||
|   \brief   Disable counter overflow interrupt request  | ||||
|   \param [in]     mask    Counter overflow interrupt request bits to clear | ||||
|   \note    Clears overflow interrupt request bits for one or more of the following: | ||||
|            - event counters (0-30) | ||||
|            - cycle counter | ||||
| */ | ||||
| __STATIC_INLINE void ARM_PMU_Set_CNTR_IRQ_Disable(uint32_t mask) | ||||
| { | ||||
|   PMU->INTENCLR = mask; | ||||
| } | ||||
|  | ||||
| /**  | ||||
|   \brief   Software increment event counter  | ||||
|   \param [in]     mask    Counters to increment | ||||
|   \note    Software increment bits for one or more event counters (0-30) | ||||
| */ | ||||
| __STATIC_INLINE void ARM_PMU_CNTR_Increment(uint32_t mask) | ||||
| { | ||||
|   PMU->SWINC = mask; | ||||
| } | ||||
|  | ||||
| #endif | ||||
		Reference in New Issue
	
	Block a user