1 /*
2  * FreeRTOS Kernel V11.1.0
3  * Copyright (C) 2021 Amazon.com, Inc. or its affiliates. All Rights Reserved.
4  *
5  * SPDX-License-Identifier: MIT
6  *
7  * Permission is hereby granted, free of charge, to any person obtaining a copy of
8  * this software and associated documentation files (the "Software"), to deal in
9  * the Software without restriction, including without limitation the rights to
10  * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
11  * the Software, and to permit persons to whom the Software is furnished to do so,
12  * subject to the following conditions:
13  *
14  * The above copyright notice and this permission notice shall be included in all
15  * copies or substantial portions of the Software.
16  *
17  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
19  * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
20  * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
21  * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
22  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
23  *
24  * https://www.FreeRTOS.org
25  * https://github.com/FreeRTOS
26  *
27  */
28 
29 #ifndef PORTMACRO_H
30 #define PORTMACRO_H
31 
32 /* *INDENT-OFF* */
33 #ifdef __cplusplus
34     extern "C" {
35 #endif
36 /* *INDENT-ON* */
37 
38 /*------------------------------------------------------------------------------
39  * Port specific definitions.
40  *
41  * The settings in this file configure FreeRTOS correctly for the given hardware
42  * and compiler.
43  *
44  * These settings should not be altered.
45  *------------------------------------------------------------------------------
46  */
47 
48 #ifndef configENABLE_MVE
49     #error configENABLE_MVE must be defined in FreeRTOSConfig.h. Set configENABLE_MVE to 1 to enable the MVE or 0 to disable the MVE.
50 #endif /* configENABLE_MVE */
51 /*-----------------------------------------------------------*/
52 
53 /**
54  * Architecture specifics.
55  */
56 #define portARCH_NAME                    "Cortex-M85"
57 #define portHAS_ARMV8M_MAIN_EXTENSION    1
58 #define portDONT_DISCARD                 __root
59 /*-----------------------------------------------------------*/
60 
61 /* ARMv8-M common port configurations. */
62 #include "portmacrocommon.h"
63 /*-----------------------------------------------------------*/
64 
65 #if ( configTOTAL_MPU_REGIONS == 16 )
66     #error 16 MPU regions are not yet supported for this port.
67 #endif
68 /*-----------------------------------------------------------*/
69 
70 /**
71  * @brief Critical section management.
72  */
73 #define portDISABLE_INTERRUPTS()    ulSetInterruptMask()
74 #define portENABLE_INTERRUPTS()     vClearInterruptMask( 0 )
75 /*-----------------------------------------------------------*/
76 
77 /* Suppress warnings that are generated by the IAR tools, but cannot be fixed in
78  * the source code because to do so would cause other compilers to generate
79  * warnings. */
80 #pragma diag_suppress=Be006
81 #pragma diag_suppress=Pa082
82 /*-----------------------------------------------------------*/
83 
84 /* *INDENT-OFF* */
85 #ifdef __cplusplus
86     }
87 #endif
88 /* *INDENT-ON* */
89 
90 #endif /* PORTMACRO_H */
91