mbed official / mbed

Dependents:   hello SerialTestv11 SerialTestv12 Sierpinski ... more

Committer:
AnnaBridge
Date:
Mon Oct 02 15:20:36 2017 +0100
Revision:
152:235179ab3f27
Parent:
148:fd96258d940d
Release 152 of the mbed library.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Kojto 148:fd96258d940d 1 /**************************************************************************//**
Kojto 148:fd96258d940d 2 * @file cmsis_compiler.h
Kojto 148:fd96258d940d 3 * @brief CMSIS compiler generic header file
Kojto 148:fd96258d940d 4 * @version V5.0.2
Kojto 148:fd96258d940d 5 * @date 13. February 2017
Kojto 148:fd96258d940d 6 ******************************************************************************/
Kojto 148:fd96258d940d 7 /*
Kojto 148:fd96258d940d 8 * Copyright (c) 2009-2017 ARM Limited. All rights reserved.
Kojto 148:fd96258d940d 9 *
Kojto 148:fd96258d940d 10 * SPDX-License-Identifier: Apache-2.0
Kojto 148:fd96258d940d 11 *
Kojto 148:fd96258d940d 12 * Licensed under the Apache License, Version 2.0 (the License); you may
Kojto 148:fd96258d940d 13 * not use this file except in compliance with the License.
Kojto 148:fd96258d940d 14 * You may obtain a copy of the License at
Kojto 148:fd96258d940d 15 *
Kojto 148:fd96258d940d 16 * www.apache.org/licenses/LICENSE-2.0
Kojto 148:fd96258d940d 17 *
Kojto 148:fd96258d940d 18 * Unless required by applicable law or agreed to in writing, software
Kojto 148:fd96258d940d 19 * distributed under the License is distributed on an AS IS BASIS, WITHOUT
Kojto 148:fd96258d940d 20 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
Kojto 148:fd96258d940d 21 * See the License for the specific language governing permissions and
Kojto 148:fd96258d940d 22 * limitations under the License.
Kojto 148:fd96258d940d 23 */
Kojto 148:fd96258d940d 24
Kojto 148:fd96258d940d 25 #ifndef __CMSIS_COMPILER_H
Kojto 148:fd96258d940d 26 #define __CMSIS_COMPILER_H
Kojto 148:fd96258d940d 27
Kojto 148:fd96258d940d 28 #include <stdint.h>
Kojto 148:fd96258d940d 29
Kojto 148:fd96258d940d 30 /*
Kojto 148:fd96258d940d 31 * ARM Compiler 4/5
Kojto 148:fd96258d940d 32 */
Kojto 148:fd96258d940d 33 #if defined ( __CC_ARM )
Kojto 148:fd96258d940d 34 #include "cmsis_armcc.h"
Kojto 148:fd96258d940d 35
Kojto 148:fd96258d940d 36
Kojto 148:fd96258d940d 37 /*
Kojto 148:fd96258d940d 38 * ARM Compiler 6 (armclang)
Kojto 148:fd96258d940d 39 */
Kojto 148:fd96258d940d 40 #elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050)
Kojto 148:fd96258d940d 41 #include "cmsis_armclang.h"
Kojto 148:fd96258d940d 42
Kojto 148:fd96258d940d 43
Kojto 148:fd96258d940d 44 /*
Kojto 148:fd96258d940d 45 * GNU Compiler
Kojto 148:fd96258d940d 46 */
Kojto 148:fd96258d940d 47 #elif defined ( __GNUC__ )
Kojto 148:fd96258d940d 48 #include "cmsis_gcc.h"
Kojto 148:fd96258d940d 49
Kojto 148:fd96258d940d 50
Kojto 148:fd96258d940d 51 /*
Kojto 148:fd96258d940d 52 * IAR Compiler
Kojto 148:fd96258d940d 53 */
Kojto 148:fd96258d940d 54 #elif defined ( __ICCARM__ )
Kojto 148:fd96258d940d 55
Kojto 148:fd96258d940d 56 #ifndef __ASM
Kojto 148:fd96258d940d 57 #define __ASM __asm
Kojto 148:fd96258d940d 58 #endif
Kojto 148:fd96258d940d 59 #ifndef __INLINE
Kojto 148:fd96258d940d 60 #define __INLINE inline
Kojto 148:fd96258d940d 61 #endif
Kojto 148:fd96258d940d 62 #ifndef __STATIC_INLINE
Kojto 148:fd96258d940d 63 #define __STATIC_INLINE static inline
Kojto 148:fd96258d940d 64 #endif
Kojto 148:fd96258d940d 65
Kojto 148:fd96258d940d 66 #include <cmsis_iar.h>
Kojto 148:fd96258d940d 67
Kojto 148:fd96258d940d 68 /* CMSIS compiler control architecture macros */
Kojto 148:fd96258d940d 69 #if (__CORE__ == __ARM6M__) || (__CORE__ == __ARM6SM__)
Kojto 148:fd96258d940d 70 #ifndef __ARM_ARCH_6M__
Kojto 148:fd96258d940d 71 #define __ARM_ARCH_6M__ 1
Kojto 148:fd96258d940d 72 #endif
Kojto 148:fd96258d940d 73 #elif (__CORE__ == __ARM7M__)
Kojto 148:fd96258d940d 74 #ifndef __ARM_ARCH_7M__
Kojto 148:fd96258d940d 75 #define __ARM_ARCH_7M__ 1
Kojto 148:fd96258d940d 76 #endif
Kojto 148:fd96258d940d 77 #elif (__CORE__ == __ARM7EM__)
Kojto 148:fd96258d940d 78 #ifndef __ARM_ARCH_7EM__
Kojto 148:fd96258d940d 79 #define __ARM_ARCH_7EM__ 1
Kojto 148:fd96258d940d 80 #endif
AnnaBridge 152:235179ab3f27 81 #elif (__CORE__ == __ARM8M_BASELINE__)
AnnaBridge 152:235179ab3f27 82 #ifndef __ARM_ARCH_8M_BASE__
AnnaBridge 152:235179ab3f27 83 #define __ARM_ARCH_8M_BASE__ 1
AnnaBridge 152:235179ab3f27 84 #endif
AnnaBridge 152:235179ab3f27 85 #elif (__CORE__ == __ARM8M_MAINLINE__)
AnnaBridge 152:235179ab3f27 86 #ifndef __ARM_ARCH_8M_MAIN__
AnnaBridge 152:235179ab3f27 87 #define __ARM_ARCH_8M_MAIN__ 1
AnnaBridge 152:235179ab3f27 88 #endif
Kojto 148:fd96258d940d 89 #endif
Kojto 148:fd96258d940d 90
Kojto 148:fd96258d940d 91 // IAR version 7.8.1 and earlier do not include __ALIGNED
Kojto 148:fd96258d940d 92 #ifndef __ALIGNED
Kojto 148:fd96258d940d 93 #define __ALIGNED(x) __attribute__((aligned(x)))
Kojto 148:fd96258d940d 94 #endif
Kojto 148:fd96258d940d 95
Kojto 148:fd96258d940d 96 #ifndef __NO_RETURN
Kojto 148:fd96258d940d 97 #define __NO_RETURN __noreturn
Kojto 148:fd96258d940d 98 #endif
Kojto 148:fd96258d940d 99 #ifndef __USED
Kojto 148:fd96258d940d 100 #define __USED __root
Kojto 148:fd96258d940d 101 #endif
Kojto 148:fd96258d940d 102 #ifndef __WEAK
Kojto 148:fd96258d940d 103 #define __WEAK __weak
Kojto 148:fd96258d940d 104 #endif
Kojto 148:fd96258d940d 105 #ifndef __PACKED
Kojto 148:fd96258d940d 106 #define __PACKED __packed
Kojto 148:fd96258d940d 107 #endif
Kojto 148:fd96258d940d 108 #ifndef __PACKED_STRUCT
Kojto 148:fd96258d940d 109 #define __PACKED_STRUCT __packed struct
Kojto 148:fd96258d940d 110 #endif
Kojto 148:fd96258d940d 111 #ifndef __UNALIGNED_UINT32 /* deprecated */
Kojto 148:fd96258d940d 112 __packed struct T_UINT32 { uint32_t v; };
Kojto 148:fd96258d940d 113 #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v)
Kojto 148:fd96258d940d 114 #endif
Kojto 148:fd96258d940d 115 #ifndef __UNALIGNED_UINT16_WRITE
Kojto 148:fd96258d940d 116 __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; };
Kojto 148:fd96258d940d 117 #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val))
Kojto 148:fd96258d940d 118 #endif
Kojto 148:fd96258d940d 119 #ifndef __UNALIGNED_UINT16_READ
Kojto 148:fd96258d940d 120 __PACKED_STRUCT T_UINT16_READ { uint16_t v; };
Kojto 148:fd96258d940d 121 #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v)
Kojto 148:fd96258d940d 122 #endif
Kojto 148:fd96258d940d 123 #ifndef __UNALIGNED_UINT32_WRITE
Kojto 148:fd96258d940d 124 __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; };
Kojto 148:fd96258d940d 125 #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val))
Kojto 148:fd96258d940d 126 #endif
Kojto 148:fd96258d940d 127 #ifndef __UNALIGNED_UINT32_READ
Kojto 148:fd96258d940d 128 __PACKED_STRUCT T_UINT32_READ { uint32_t v; };
Kojto 148:fd96258d940d 129 #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v)
Kojto 148:fd96258d940d 130 #endif
Kojto 148:fd96258d940d 131 #ifndef __ALIGNED
Kojto 148:fd96258d940d 132 #warning No compiler specific solution for __ALIGNED. __ALIGNED is ignored.
Kojto 148:fd96258d940d 133 #define __ALIGNED(x)
Kojto 148:fd96258d940d 134 #endif
Kojto 148:fd96258d940d 135
Kojto 148:fd96258d940d 136
Kojto 148:fd96258d940d 137 /*
Kojto 148:fd96258d940d 138 * TI ARM Compiler
Kojto 148:fd96258d940d 139 */
Kojto 148:fd96258d940d 140 #elif defined ( __TI_ARM__ )
Kojto 148:fd96258d940d 141 #include <cmsis_ccs.h>
Kojto 148:fd96258d940d 142
Kojto 148:fd96258d940d 143 #ifndef __ASM
Kojto 148:fd96258d940d 144 #define __ASM __asm
Kojto 148:fd96258d940d 145 #endif
Kojto 148:fd96258d940d 146 #ifndef __INLINE
Kojto 148:fd96258d940d 147 #define __INLINE inline
Kojto 148:fd96258d940d 148 #endif
Kojto 148:fd96258d940d 149 #ifndef __STATIC_INLINE
Kojto 148:fd96258d940d 150 #define __STATIC_INLINE static inline
Kojto 148:fd96258d940d 151 #endif
Kojto 148:fd96258d940d 152 #ifndef __NO_RETURN
Kojto 148:fd96258d940d 153 #define __NO_RETURN __attribute__((noreturn))
Kojto 148:fd96258d940d 154 #endif
Kojto 148:fd96258d940d 155 #ifndef __USED
Kojto 148:fd96258d940d 156 #define __USED __attribute__((used))
Kojto 148:fd96258d940d 157 #endif
Kojto 148:fd96258d940d 158 #ifndef __WEAK
Kojto 148:fd96258d940d 159 #define __WEAK __attribute__((weak))
Kojto 148:fd96258d940d 160 #endif
Kojto 148:fd96258d940d 161 #ifndef __PACKED
Kojto 148:fd96258d940d 162 #define __PACKED __attribute__((packed))
Kojto 148:fd96258d940d 163 #endif
Kojto 148:fd96258d940d 164 #ifndef __PACKED_STRUCT
Kojto 148:fd96258d940d 165 #define __PACKED_STRUCT struct __attribute__((packed))
Kojto 148:fd96258d940d 166 #endif
Kojto 148:fd96258d940d 167 #ifndef __UNALIGNED_UINT32 /* deprecated */
Kojto 148:fd96258d940d 168 struct __attribute__((packed)) T_UINT32 { uint32_t v; };
Kojto 148:fd96258d940d 169 #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v)
Kojto 148:fd96258d940d 170 #endif
Kojto 148:fd96258d940d 171 #ifndef __UNALIGNED_UINT16_WRITE
Kojto 148:fd96258d940d 172 __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; };
Kojto 148:fd96258d940d 173 #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void*)(addr))->v) = (val))
Kojto 148:fd96258d940d 174 #endif
Kojto 148:fd96258d940d 175 #ifndef __UNALIGNED_UINT16_READ
Kojto 148:fd96258d940d 176 __PACKED_STRUCT T_UINT16_READ { uint16_t v; };
Kojto 148:fd96258d940d 177 #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v)
Kojto 148:fd96258d940d 178 #endif
Kojto 148:fd96258d940d 179 #ifndef __UNALIGNED_UINT32_WRITE
Kojto 148:fd96258d940d 180 __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; };
Kojto 148:fd96258d940d 181 #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val))
Kojto 148:fd96258d940d 182 #endif
Kojto 148:fd96258d940d 183 #ifndef __UNALIGNED_UINT32_READ
Kojto 148:fd96258d940d 184 __PACKED_STRUCT T_UINT32_READ { uint32_t v; };
Kojto 148:fd96258d940d 185 #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v)
Kojto 148:fd96258d940d 186 #endif
Kojto 148:fd96258d940d 187 #ifndef __ALIGNED
Kojto 148:fd96258d940d 188 #define __ALIGNED(x) __attribute__((aligned(x)))
Kojto 148:fd96258d940d 189 #endif
Kojto 148:fd96258d940d 190
Kojto 148:fd96258d940d 191
Kojto 148:fd96258d940d 192 /*
Kojto 148:fd96258d940d 193 * TASKING Compiler
Kojto 148:fd96258d940d 194 */
Kojto 148:fd96258d940d 195 #elif defined ( __TASKING__ )
Kojto 148:fd96258d940d 196 /*
Kojto 148:fd96258d940d 197 * The CMSIS functions have been implemented as intrinsics in the compiler.
Kojto 148:fd96258d940d 198 * Please use "carm -?i" to get an up to date list of all intrinsics,
Kojto 148:fd96258d940d 199 * Including the CMSIS ones.
Kojto 148:fd96258d940d 200 */
Kojto 148:fd96258d940d 201
Kojto 148:fd96258d940d 202 #ifndef __ASM
Kojto 148:fd96258d940d 203 #define __ASM __asm
Kojto 148:fd96258d940d 204 #endif
Kojto 148:fd96258d940d 205 #ifndef __INLINE
Kojto 148:fd96258d940d 206 #define __INLINE inline
Kojto 148:fd96258d940d 207 #endif
Kojto 148:fd96258d940d 208 #ifndef __STATIC_INLINE
Kojto 148:fd96258d940d 209 #define __STATIC_INLINE static inline
Kojto 148:fd96258d940d 210 #endif
Kojto 148:fd96258d940d 211 #ifndef __NO_RETURN
Kojto 148:fd96258d940d 212 #define __NO_RETURN __attribute__((noreturn))
Kojto 148:fd96258d940d 213 #endif
Kojto 148:fd96258d940d 214 #ifndef __USED
Kojto 148:fd96258d940d 215 #define __USED __attribute__((used))
Kojto 148:fd96258d940d 216 #endif
Kojto 148:fd96258d940d 217 #ifndef __WEAK
Kojto 148:fd96258d940d 218 #define __WEAK __attribute__((weak))
Kojto 148:fd96258d940d 219 #endif
Kojto 148:fd96258d940d 220 #ifndef __PACKED
Kojto 148:fd96258d940d 221 #define __PACKED __packed__
Kojto 148:fd96258d940d 222 #endif
Kojto 148:fd96258d940d 223 #ifndef __PACKED_STRUCT
Kojto 148:fd96258d940d 224 #define __PACKED_STRUCT struct __packed__
Kojto 148:fd96258d940d 225 #endif
Kojto 148:fd96258d940d 226 #ifndef __UNALIGNED_UINT32 /* deprecated */
Kojto 148:fd96258d940d 227 struct __packed__ T_UINT32 { uint32_t v; };
Kojto 148:fd96258d940d 228 #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v)
Kojto 148:fd96258d940d 229 #endif
Kojto 148:fd96258d940d 230 #ifndef __UNALIGNED_UINT16_WRITE
Kojto 148:fd96258d940d 231 __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; };
Kojto 148:fd96258d940d 232 #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val))
Kojto 148:fd96258d940d 233 #endif
Kojto 148:fd96258d940d 234 #ifndef __UNALIGNED_UINT16_READ
Kojto 148:fd96258d940d 235 __PACKED_STRUCT T_UINT16_READ { uint16_t v; };
Kojto 148:fd96258d940d 236 #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v)
Kojto 148:fd96258d940d 237 #endif
Kojto 148:fd96258d940d 238 #ifndef __UNALIGNED_UINT32_WRITE
Kojto 148:fd96258d940d 239 __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; };
Kojto 148:fd96258d940d 240 #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val))
Kojto 148:fd96258d940d 241 #endif
Kojto 148:fd96258d940d 242 #ifndef __UNALIGNED_UINT32_READ
Kojto 148:fd96258d940d 243 __PACKED_STRUCT T_UINT32_READ { uint32_t v; };
Kojto 148:fd96258d940d 244 #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v)
Kojto 148:fd96258d940d 245 #endif
Kojto 148:fd96258d940d 246 #ifndef __ALIGNED
Kojto 148:fd96258d940d 247 #define __ALIGNED(x) __align(x)
Kojto 148:fd96258d940d 248 #endif
Kojto 148:fd96258d940d 249
Kojto 148:fd96258d940d 250
Kojto 148:fd96258d940d 251 /*
Kojto 148:fd96258d940d 252 * COSMIC Compiler
Kojto 148:fd96258d940d 253 */
Kojto 148:fd96258d940d 254 #elif defined ( __CSMC__ )
Kojto 148:fd96258d940d 255 #include <cmsis_csm.h>
Kojto 148:fd96258d940d 256
Kojto 148:fd96258d940d 257 #ifndef __ASM
Kojto 148:fd96258d940d 258 #define __ASM _asm
Kojto 148:fd96258d940d 259 #endif
Kojto 148:fd96258d940d 260 #ifndef __INLINE
Kojto 148:fd96258d940d 261 #define __INLINE inline
Kojto 148:fd96258d940d 262 #endif
Kojto 148:fd96258d940d 263 #ifndef __STATIC_INLINE
Kojto 148:fd96258d940d 264 #define __STATIC_INLINE static inline
Kojto 148:fd96258d940d 265 #endif
Kojto 148:fd96258d940d 266 #ifndef __NO_RETURN
Kojto 148:fd96258d940d 267 // NO RETURN is automatically detected hence no warning here
Kojto 148:fd96258d940d 268 #define __NO_RETURN
Kojto 148:fd96258d940d 269 #endif
Kojto 148:fd96258d940d 270 #ifndef __USED
Kojto 148:fd96258d940d 271 #warning No compiler specific solution for __USED. __USED is ignored.
Kojto 148:fd96258d940d 272 #define __USED
Kojto 148:fd96258d940d 273 #endif
Kojto 148:fd96258d940d 274 #ifndef __WEAK
Kojto 148:fd96258d940d 275 #define __WEAK __weak
Kojto 148:fd96258d940d 276 #endif
Kojto 148:fd96258d940d 277 #ifndef __PACKED
Kojto 148:fd96258d940d 278 #define __PACKED @packed
Kojto 148:fd96258d940d 279 #endif
Kojto 148:fd96258d940d 280 #ifndef __PACKED_STRUCT
Kojto 148:fd96258d940d 281 #define __PACKED_STRUCT @packed struct
Kojto 148:fd96258d940d 282 #endif
Kojto 148:fd96258d940d 283 #ifndef __UNALIGNED_UINT32 /* deprecated */
Kojto 148:fd96258d940d 284 @packed struct T_UINT32 { uint32_t v; };
Kojto 148:fd96258d940d 285 #define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v)
Kojto 148:fd96258d940d 286 #endif
Kojto 148:fd96258d940d 287 #ifndef __UNALIGNED_UINT16_WRITE
Kojto 148:fd96258d940d 288 __PACKED_STRUCT T_UINT16_WRITE { uint16_t v; };
Kojto 148:fd96258d940d 289 #define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val))
Kojto 148:fd96258d940d 290 #endif
Kojto 148:fd96258d940d 291 #ifndef __UNALIGNED_UINT16_READ
Kojto 148:fd96258d940d 292 __PACKED_STRUCT T_UINT16_READ { uint16_t v; };
Kojto 148:fd96258d940d 293 #define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v)
Kojto 148:fd96258d940d 294 #endif
Kojto 148:fd96258d940d 295 #ifndef __UNALIGNED_UINT32_WRITE
Kojto 148:fd96258d940d 296 __PACKED_STRUCT T_UINT32_WRITE { uint32_t v; };
Kojto 148:fd96258d940d 297 #define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val))
Kojto 148:fd96258d940d 298 #endif
Kojto 148:fd96258d940d 299 #ifndef __UNALIGNED_UINT32_READ
Kojto 148:fd96258d940d 300 __PACKED_STRUCT T_UINT32_READ { uint32_t v; };
Kojto 148:fd96258d940d 301 #define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v)
Kojto 148:fd96258d940d 302 #endif
Kojto 148:fd96258d940d 303 #ifndef __ALIGNED
Kojto 148:fd96258d940d 304 #warning No compiler specific solution for __ALIGNED. __ALIGNED is ignored.
Kojto 148:fd96258d940d 305 #define __ALIGNED(x)
Kojto 148:fd96258d940d 306 #endif
Kojto 148:fd96258d940d 307
Kojto 148:fd96258d940d 308
Kojto 148:fd96258d940d 309 #else
Kojto 148:fd96258d940d 310 #error Unknown compiler.
Kojto 148:fd96258d940d 311 #endif
Kojto 148:fd96258d940d 312
Kojto 148:fd96258d940d 313
Kojto 148:fd96258d940d 314 #endif /* __CMSIS_COMPILER_H */
Kojto 148:fd96258d940d 315