forked from FreeRTOS/FreeRTOS
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Create Cortex-M3 QEMU project for testing with the IAR compiler (Free…
…RTOS#503) * Initial version of the CORTEX_MPS2_QEMU_IAR - needs tidying up and so far only contains the comprehensive demo. * Update the comment block at the top of the source files to match the latest official release. * Split out the main_full() demo from main(). Still need to add in the main_blinky() demo. * Add the blinky demo option. * Tidy up the QEMU/IAR project. * Configure the QEMU IAR project to only create the blinky demo. * Delete readme.txt which was in the wrong directory. * Fix errors in the comments at the top of the file as highlighted by the auto checks. Co-authored-by: alfred gedeon <[email protected]>
- Loading branch information
1 parent
006c6dd
commit 2e4485a
Showing
20 changed files
with
10,306 additions
and
0 deletions.
There are no files selected for viewing
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
/* MPS2 CMSIS Library | ||
* | ||
* Copyright (c) 2006-2016 ARM Limited | ||
* SPDX-License-Identifier: BSD-3-Clause | ||
* All rights reserved. | ||
* | ||
* Redistribution and use in source and binary forms, with or without | ||
* modification, are permitted provided that the following conditions are met: | ||
* | ||
* 1. Redistributions of source code must retain the above copyright notice, | ||
* this list of conditions and the following disclaimer. | ||
* | ||
* 2. Redistributions in binary form must reproduce the above copyright notice, | ||
* this list of conditions and the following disclaimer in the documentation | ||
* and/or other materials provided with the distribution. | ||
* | ||
* 3. Neither the name of the copyright holder nor the names of its contributors | ||
* may be used to endorse or promote products derived from this software without | ||
* specific prior written permission. | ||
* | ||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | ||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | ||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | ||
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE | ||
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR | ||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF | ||
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS | ||
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN | ||
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | ||
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE | ||
* POSSIBILITY OF SUCH DAMAGE. | ||
******************************************************************************* | ||
* A generic CMSIS include header, pulling in MPS2 specifics | ||
*******************************************************************************/ | ||
|
||
#ifndef MBED_CMSIS_H | ||
#define MBED_CMSIS_H | ||
|
||
#include "SMM_MPS2.h" | ||
|
||
#endif |
283 changes: 283 additions & 0 deletions
283
FreeRTOS/Demo/CORTEX_MPS2_QEMU_IAR/CMSIS/cmsis_compiler.h
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,283 @@ | ||
/**************************************************************************//** | ||
* @file cmsis_compiler.h | ||
* @brief CMSIS compiler generic header file | ||
* @version V5.1.0 | ||
* @date 09. October 2018 | ||
******************************************************************************/ | ||
/* | ||
* Copyright (c) 2009-2018 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. | ||
*/ | ||
|
||
#ifndef __CMSIS_COMPILER_H | ||
#define __CMSIS_COMPILER_H | ||
|
||
#include <stdint.h> | ||
|
||
/* | ||
* Arm Compiler 4/5 | ||
*/ | ||
#if defined ( __CC_ARM ) | ||
#include "cmsis_armcc.h" | ||
|
||
|
||
/* | ||
* Arm Compiler 6.6 LTM (armclang) | ||
*/ | ||
#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050) && (__ARMCC_VERSION < 6100100) | ||
#include "cmsis_armclang_ltm.h" | ||
|
||
/* | ||
* Arm Compiler above 6.10.1 (armclang) | ||
*/ | ||
#elif defined (__ARMCC_VERSION) && (__ARMCC_VERSION >= 6100100) | ||
#include "cmsis_armclang.h" | ||
|
||
|
||
/* | ||
* GNU Compiler | ||
*/ | ||
#elif defined ( __GNUC__ ) | ||
#include "cmsis_gcc.h" | ||
|
||
|
||
/* | ||
* IAR Compiler | ||
*/ | ||
#elif defined ( __ICCARM__ ) | ||
#include <cmsis_iccarm.h> | ||
|
||
|
||
/* | ||
* TI Arm Compiler | ||
*/ | ||
#elif defined ( __TI_ARM__ ) | ||
#include <cmsis_ccs.h> | ||
|
||
#ifndef __ASM | ||
#define __ASM __asm | ||
#endif | ||
#ifndef __INLINE | ||
#define __INLINE inline | ||
#endif | ||
#ifndef __STATIC_INLINE | ||
#define __STATIC_INLINE static inline | ||
#endif | ||
#ifndef __STATIC_FORCEINLINE | ||
#define __STATIC_FORCEINLINE __STATIC_INLINE | ||
#endif | ||
#ifndef __NO_RETURN | ||
#define __NO_RETURN __attribute__((noreturn)) | ||
#endif | ||
#ifndef __USED | ||
#define __USED __attribute__((used)) | ||
#endif | ||
#ifndef __WEAK | ||
#define __WEAK __attribute__((weak)) | ||
#endif | ||
#ifndef __PACKED | ||
#define __PACKED __attribute__((packed)) | ||
#endif | ||
#ifndef __PACKED_STRUCT | ||
#define __PACKED_STRUCT struct __attribute__((packed)) | ||
#endif | ||
#ifndef __PACKED_UNION | ||
#define __PACKED_UNION union __attribute__((packed)) | ||
#endif | ||
#ifndef __UNALIGNED_UINT32 /* deprecated */ | ||
struct __attribute__((packed)) T_UINT32 { uint32_t v; }; | ||
#define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) | ||
#endif | ||
#ifndef __UNALIGNED_UINT16_WRITE | ||
__PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; | ||
#define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void*)(addr))->v) = (val)) | ||
#endif | ||
#ifndef __UNALIGNED_UINT16_READ | ||
__PACKED_STRUCT T_UINT16_READ { uint16_t v; }; | ||
#define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) | ||
#endif | ||
#ifndef __UNALIGNED_UINT32_WRITE | ||
__PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; | ||
#define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) | ||
#endif | ||
#ifndef __UNALIGNED_UINT32_READ | ||
__PACKED_STRUCT T_UINT32_READ { uint32_t v; }; | ||
#define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) | ||
#endif | ||
#ifndef __ALIGNED | ||
#define __ALIGNED(x) __attribute__((aligned(x))) | ||
#endif | ||
#ifndef __RESTRICT | ||
#define __RESTRICT __restrict | ||
#endif | ||
#ifndef __COMPILER_BARRIER | ||
#warning No compiler specific solution for __COMPILER_BARRIER. __COMPILER_BARRIER is ignored. | ||
#define __COMPILER_BARRIER() (void)0 | ||
#endif | ||
|
||
|
||
/* | ||
* TASKING Compiler | ||
*/ | ||
#elif defined ( __TASKING__ ) | ||
/* | ||
* The CMSIS functions have been implemented as intrinsics in the compiler. | ||
* Please use "carm -?i" to get an up to date list of all intrinsics, | ||
* Including the CMSIS ones. | ||
*/ | ||
|
||
#ifndef __ASM | ||
#define __ASM __asm | ||
#endif | ||
#ifndef __INLINE | ||
#define __INLINE inline | ||
#endif | ||
#ifndef __STATIC_INLINE | ||
#define __STATIC_INLINE static inline | ||
#endif | ||
#ifndef __STATIC_FORCEINLINE | ||
#define __STATIC_FORCEINLINE __STATIC_INLINE | ||
#endif | ||
#ifndef __NO_RETURN | ||
#define __NO_RETURN __attribute__((noreturn)) | ||
#endif | ||
#ifndef __USED | ||
#define __USED __attribute__((used)) | ||
#endif | ||
#ifndef __WEAK | ||
#define __WEAK __attribute__((weak)) | ||
#endif | ||
#ifndef __PACKED | ||
#define __PACKED __packed__ | ||
#endif | ||
#ifndef __PACKED_STRUCT | ||
#define __PACKED_STRUCT struct __packed__ | ||
#endif | ||
#ifndef __PACKED_UNION | ||
#define __PACKED_UNION union __packed__ | ||
#endif | ||
#ifndef __UNALIGNED_UINT32 /* deprecated */ | ||
struct __packed__ T_UINT32 { uint32_t v; }; | ||
#define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) | ||
#endif | ||
#ifndef __UNALIGNED_UINT16_WRITE | ||
__PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; | ||
#define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val)) | ||
#endif | ||
#ifndef __UNALIGNED_UINT16_READ | ||
__PACKED_STRUCT T_UINT16_READ { uint16_t v; }; | ||
#define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) | ||
#endif | ||
#ifndef __UNALIGNED_UINT32_WRITE | ||
__PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; | ||
#define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) | ||
#endif | ||
#ifndef __UNALIGNED_UINT32_READ | ||
__PACKED_STRUCT T_UINT32_READ { uint32_t v; }; | ||
#define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) | ||
#endif | ||
#ifndef __ALIGNED | ||
#define __ALIGNED(x) __align(x) | ||
#endif | ||
#ifndef __RESTRICT | ||
#warning No compiler specific solution for __RESTRICT. __RESTRICT is ignored. | ||
#define __RESTRICT | ||
#endif | ||
#ifndef __COMPILER_BARRIER | ||
#warning No compiler specific solution for __COMPILER_BARRIER. __COMPILER_BARRIER is ignored. | ||
#define __COMPILER_BARRIER() (void)0 | ||
#endif | ||
|
||
|
||
/* | ||
* COSMIC Compiler | ||
*/ | ||
#elif defined ( __CSMC__ ) | ||
#include <cmsis_csm.h> | ||
|
||
#ifndef __ASM | ||
#define __ASM _asm | ||
#endif | ||
#ifndef __INLINE | ||
#define __INLINE inline | ||
#endif | ||
#ifndef __STATIC_INLINE | ||
#define __STATIC_INLINE static inline | ||
#endif | ||
#ifndef __STATIC_FORCEINLINE | ||
#define __STATIC_FORCEINLINE __STATIC_INLINE | ||
#endif | ||
#ifndef __NO_RETURN | ||
// NO RETURN is automatically detected hence no warning here | ||
#define __NO_RETURN | ||
#endif | ||
#ifndef __USED | ||
#warning No compiler specific solution for __USED. __USED is ignored. | ||
#define __USED | ||
#endif | ||
#ifndef __WEAK | ||
#define __WEAK __weak | ||
#endif | ||
#ifndef __PACKED | ||
#define __PACKED @packed | ||
#endif | ||
#ifndef __PACKED_STRUCT | ||
#define __PACKED_STRUCT @packed struct | ||
#endif | ||
#ifndef __PACKED_UNION | ||
#define __PACKED_UNION @packed union | ||
#endif | ||
#ifndef __UNALIGNED_UINT32 /* deprecated */ | ||
@packed struct T_UINT32 { uint32_t v; }; | ||
#define __UNALIGNED_UINT32(x) (((struct T_UINT32 *)(x))->v) | ||
#endif | ||
#ifndef __UNALIGNED_UINT16_WRITE | ||
__PACKED_STRUCT T_UINT16_WRITE { uint16_t v; }; | ||
#define __UNALIGNED_UINT16_WRITE(addr, val) (void)((((struct T_UINT16_WRITE *)(void *)(addr))->v) = (val)) | ||
#endif | ||
#ifndef __UNALIGNED_UINT16_READ | ||
__PACKED_STRUCT T_UINT16_READ { uint16_t v; }; | ||
#define __UNALIGNED_UINT16_READ(addr) (((const struct T_UINT16_READ *)(const void *)(addr))->v) | ||
#endif | ||
#ifndef __UNALIGNED_UINT32_WRITE | ||
__PACKED_STRUCT T_UINT32_WRITE { uint32_t v; }; | ||
#define __UNALIGNED_UINT32_WRITE(addr, val) (void)((((struct T_UINT32_WRITE *)(void *)(addr))->v) = (val)) | ||
#endif | ||
#ifndef __UNALIGNED_UINT32_READ | ||
__PACKED_STRUCT T_UINT32_READ { uint32_t v; }; | ||
#define __UNALIGNED_UINT32_READ(addr) (((const struct T_UINT32_READ *)(const void *)(addr))->v) | ||
#endif | ||
#ifndef __ALIGNED | ||
#warning No compiler specific solution for __ALIGNED. __ALIGNED is ignored. | ||
#define __ALIGNED(x) | ||
#endif | ||
#ifndef __RESTRICT | ||
#warning No compiler specific solution for __RESTRICT. __RESTRICT is ignored. | ||
#define __RESTRICT | ||
#endif | ||
#ifndef __COMPILER_BARRIER | ||
#warning No compiler specific solution for __COMPILER_BARRIER. __COMPILER_BARRIER is ignored. | ||
#define __COMPILER_BARRIER() (void)0 | ||
#endif | ||
|
||
|
||
#else | ||
#error Unknown compiler. | ||
#endif | ||
|
||
|
||
#endif /* __CMSIS_COMPILER_H */ | ||
|
Oops, something went wrong.