mirror of
https://github.com/FreeRTOS/FreeRTOS-Kernel.git
synced 2025-08-20 01:58:32 -04:00
Added demo for the MB9A314 - the IAR project is working, the Keil one is not set up for the correct chip yet.
This commit is contained in:
parent
9c92745440
commit
bcbd6c8a7d
24 changed files with 27442 additions and 0 deletions
359
Demo/CORTEX_MB9A310_IAR_Keil/Fujitu_source/core_cm3.c
Normal file
359
Demo/CORTEX_MB9A310_IAR_Keil/Fujitu_source/core_cm3.c
Normal file
|
@ -0,0 +1,359 @@
|
|||
/**************************************************************************//**
|
||||
* @file core_cm3.c
|
||||
* @brief CMSIS Cortex-M3 Core Peripheral Access Layer Source File
|
||||
* @version V1.40
|
||||
* @date 18. February 2010
|
||||
*
|
||||
* @note
|
||||
* Copyright (C) 2009-2010 ARM Limited. All rights reserved.
|
||||
*
|
||||
* @par
|
||||
* ARM Limited (ARM) is supplying this software for use with Cortex-M
|
||||
* processor based microcontrollers. This file can be freely distributed
|
||||
* within development tools that are supporting such ARM based processors.
|
||||
*
|
||||
* @par
|
||||
* THIS SOFTWARE IS PROVIDED "AS IS". NO WARRANTIES, WHETHER EXPRESS, IMPLIED
|
||||
* OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF
|
||||
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE.
|
||||
* ARM SHALL NOT, IN ANY CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR
|
||||
* CONSEQUENTIAL DAMAGES, FOR ANY REASON WHATSOEVER.
|
||||
*
|
||||
******************************************************************************/
|
||||
|
||||
#include <stdint.h>
|
||||
|
||||
/* define compiler specific symbols */
|
||||
#if defined ( __CC_ARM )
|
||||
#define __ASM __asm /*!< asm keyword for ARM Compiler */
|
||||
#define __INLINE __inline /*!< inline keyword for ARM Compiler */
|
||||
|
||||
#elif defined ( __ICCARM__ )
|
||||
#define __ASM __asm /*!< asm keyword for IAR Compiler */
|
||||
#define __INLINE inline /*!< inline keyword for IAR Compiler. Only avaiable in High optimization mode! */
|
||||
|
||||
#elif defined ( __GNUC__ )
|
||||
#define __ASM __asm /*!< asm keyword for GNU Compiler */
|
||||
#define __INLINE inline /*!< inline keyword for GNU Compiler */
|
||||
|
||||
#elif defined ( __TASKING__ )
|
||||
#define __ASM __asm /*!< asm keyword for TASKING Compiler */
|
||||
#define __INLINE inline /*!< inline keyword for TASKING Compiler */
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
/* ########################## Core Instruction Access ######################### */
|
||||
|
||||
#if defined ( __CC_ARM ) /*------------------ RealView Compiler ----------------*/
|
||||
|
||||
/**
|
||||
* @brief Reverse byte order (16 bit)
|
||||
*
|
||||
* @param value value to reverse
|
||||
* @return reversed value
|
||||
*
|
||||
* Reverse byte order in unsigned short value
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400677)
|
||||
__ASM uint32_t __REV16(uint16_t value)
|
||||
{
|
||||
rev16 r0, r0
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Reverse byte order in signed short value with sign extension to integer
|
||||
*
|
||||
* @param value value to reverse
|
||||
* @return reversed value
|
||||
*
|
||||
* Reverse byte order in signed short value with sign extension to integer
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400677)
|
||||
__ASM int32_t __REVSH(int16_t value)
|
||||
{
|
||||
revsh r0, r0
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Remove the exclusive lock created by ldrex
|
||||
*
|
||||
* Removes the exclusive lock which is created by ldrex.
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM void __CLREX(void)
|
||||
{
|
||||
clrex
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
|
||||
#elif (defined (__ICCARM__)) /*---------------- ICC Compiler ---------------------*/
|
||||
/* obsolete */
|
||||
#elif (defined (__GNUC__)) /*------------------ GNU Compiler ---------------------*/
|
||||
/* obsolete */
|
||||
#elif (defined (__TASKING__)) /*--------------- TASKING Compiler -----------------*/
|
||||
/* obsolete */
|
||||
#endif
|
||||
|
||||
|
||||
/* ########################### Core Function Access ########################### */
|
||||
|
||||
#if defined ( __CC_ARM ) /*------------------ RealView Compiler ----------------*/
|
||||
|
||||
/**
|
||||
* @brief Return the Control Register value
|
||||
*
|
||||
* @return Control value
|
||||
*
|
||||
* Return the content of the control register
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM uint32_t __get_CONTROL(void)
|
||||
{
|
||||
mrs r0, control
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Set the Control Register value
|
||||
*
|
||||
* @param control Control value
|
||||
*
|
||||
* Set the control register
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM void __set_CONTROL(uint32_t control)
|
||||
{
|
||||
msr control, r0
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Get IPSR Register value
|
||||
*
|
||||
* @return uint32_t IPSR value
|
||||
*
|
||||
* return the content of the IPSR register
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM uint32_t __get_IPSR(void)
|
||||
{
|
||||
mrs r0, ipsr
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Get APSR Register value
|
||||
*
|
||||
* @return uint32_t APSR value
|
||||
*
|
||||
* return the content of the APSR register
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM uint32_t __get_APSR(void)
|
||||
{
|
||||
mrs r0, apsr
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Get xPSR Register value
|
||||
*
|
||||
* @return uint32_t xPSR value
|
||||
*
|
||||
* return the content of the xPSR register
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM uint32_t __get_xPSR(void)
|
||||
{
|
||||
mrs r0, xpsr
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Return the Process Stack Pointer
|
||||
*
|
||||
* @return ProcessStackPointer
|
||||
*
|
||||
* Return the actual process stack pointer
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM uint32_t __get_PSP(void)
|
||||
{
|
||||
mrs r0, psp
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Set the Process Stack Pointer
|
||||
*
|
||||
* @param topOfProcStack Process Stack Pointer
|
||||
*
|
||||
* Assign the value ProcessStackPointer to the MSP
|
||||
* (process stack pointer) Cortex processor register
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM void __set_PSP(uint32_t topOfProcStack)
|
||||
{
|
||||
msr psp, r0
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Return the Main Stack Pointer
|
||||
*
|
||||
* @return Main Stack Pointer
|
||||
*
|
||||
* Return the current value of the MSP (main stack pointer)
|
||||
* Cortex processor register
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM uint32_t __get_MSP(void)
|
||||
{
|
||||
mrs r0, msp
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Set the Main Stack Pointer
|
||||
*
|
||||
* @param topOfMainStack Main Stack Pointer
|
||||
*
|
||||
* Assign the value mainStackPointer to the MSP
|
||||
* (main stack pointer) Cortex processor register
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM void __set_MSP(uint32_t mainStackPointer)
|
||||
{
|
||||
msr msp, r0
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Return the Base Priority value
|
||||
*
|
||||
* @return BasePriority
|
||||
*
|
||||
* Return the content of the base priority register
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM uint32_t __get_BASEPRI(void)
|
||||
{
|
||||
mrs r0, basepri
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Set the Base Priority value
|
||||
*
|
||||
* @param basePri BasePriority
|
||||
*
|
||||
* Set the base priority register
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM void __set_BASEPRI(uint32_t basePri)
|
||||
{
|
||||
msr basepri, r0
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Return the Priority Mask value
|
||||
*
|
||||
* @return PriMask
|
||||
*
|
||||
* Return state of the priority mask bit from the priority mask register
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM uint32_t __get_PRIMASK(void)
|
||||
{
|
||||
mrs r0, primask
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Set the Priority Mask value
|
||||
*
|
||||
* @param priMask PriMask
|
||||
*
|
||||
* Set the priority mask bit in the priority mask register
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM void __set_PRIMASK(uint32_t priMask)
|
||||
{
|
||||
msr primask, r0
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Return the Fault Mask value
|
||||
*
|
||||
* @return FaultMask
|
||||
*
|
||||
* Return the content of the fault mask register
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM uint32_t __get_FAULTMASK(void)
|
||||
{
|
||||
mrs r0, faultmask
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Set the Fault Mask value
|
||||
*
|
||||
* @param faultMask faultMask value
|
||||
*
|
||||
* Set the fault mask register
|
||||
*/
|
||||
#if (__ARMCC_VERSION < 400000)
|
||||
__ASM void __set_FAULTMASK(uint32_t faultMask)
|
||||
{
|
||||
msr faultmask, r0
|
||||
bx lr
|
||||
}
|
||||
#endif /* __ARMCC_VERSION */
|
||||
|
||||
/**
|
||||
* @brief Return the FPSCR value
|
||||
*
|
||||
* @return FloatingPointStatusControlRegister
|
||||
*
|
||||
* Return the content of the FPSCR register
|
||||
*/
|
||||
|
||||
/**
|
||||
* @brief Set the FPSCR value
|
||||
*
|
||||
* @param fpscr FloatingPointStatusControlRegister
|
||||
*
|
||||
* Set the FPSCR register
|
||||
*/
|
||||
|
||||
|
||||
#elif (defined (__ICCARM__)) /*---------------- ICC Compiler ---------------------*/
|
||||
/* obsolete */
|
||||
#elif (defined (__GNUC__)) /*------------------ GNU Compiler ---------------------*/
|
||||
/* obsolete */
|
||||
#elif (defined (__TASKING__)) /*--------------- TASKING Compiler -----------------*/
|
||||
/* obsolete */
|
||||
#endif
|
13785
Demo/CORTEX_MB9A310_IAR_Keil/Fujitu_source/mb9af314l.h
Normal file
13785
Demo/CORTEX_MB9A310_IAR_Keil/Fujitu_source/mb9af314l.h
Normal file
File diff suppressed because it is too large
Load diff
62
Demo/CORTEX_MB9A310_IAR_Keil/Fujitu_source/mcu.h
Normal file
62
Demo/CORTEX_MB9A310_IAR_Keil/Fujitu_source/mcu.h
Normal file
|
@ -0,0 +1,62 @@
|
|||
/************************************************************************/
|
||||
/* (C) Fujitsu Semiconductor Europe GmbH (FSEU) */
|
||||
/* */
|
||||
/* The following software deliverable is intended for and must only be */
|
||||
/* used for reference and in an evaluation laboratory environment. */
|
||||
/* It is provided on an as-is basis without charge and is subject to */
|
||||
/* alterations. */
|
||||
/* It is the user's obligation to fully test the software in its */
|
||||
/* environment and to ensure proper functionality, qualification and */
|
||||
/* compliance with component specifications. */
|
||||
/* */
|
||||
/* In the event the software deliverable includes the use of open */
|
||||
/* source components, the provisions of the governing open source */
|
||||
/* license agreement shall apply with respect to such software */
|
||||
/* deliverable. */
|
||||
/* FSEU does not warrant that the deliverables do not infringe any */
|
||||
/* third party intellectual property right (IPR). In the event that */
|
||||
/* the deliverables infringe a third party IPR it is the sole */
|
||||
/* responsibility of the customer to obtain necessary licenses to */
|
||||
/* continue the usage of the deliverable. */
|
||||
/* */
|
||||
/* To the maximum extent permitted by applicable law FSEU disclaims all */
|
||||
/* warranties, whether express or implied, in particular, but not */
|
||||
/* limited to, warranties of merchantability and fitness for a */
|
||||
/* particular purpose for which the deliverable is not designated. */
|
||||
/* */
|
||||
/* To the maximum extent permitted by applicable law, FSEU's liability */
|
||||
/* is restricted to intentional misconduct and gross negligence. */
|
||||
/* FSEU is not liable for consequential damages. */
|
||||
/* */
|
||||
/* (V1.5) */
|
||||
/************************************************************************/
|
||||
/**
|
||||
******************************************************************************
|
||||
** \file mcu.h
|
||||
**
|
||||
** Header File for device dependent includes
|
||||
**
|
||||
** History:
|
||||
** 2011-05-19 V1.00 MWi first version
|
||||
**
|
||||
******************************************************************************/
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief MCU header file include
|
||||
**
|
||||
******************************************************************************/
|
||||
#ifndef _MB9AF314L_H_
|
||||
#include "mb9af314l.h"
|
||||
#endif
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief MCU system start-up header file include
|
||||
**
|
||||
******************************************************************************/
|
||||
#ifndef _SYSTEM_MB9AF31X_H_
|
||||
#include "system_mb9af31x.h"
|
||||
#endif
|
||||
|
||||
|
|
@ -0,0 +1,392 @@
|
|||
;/************************************************************************/
|
||||
;/* (C) Fujitsu Semiconductor Europe GmbH (FSEU) */
|
||||
;/* */
|
||||
;/* The following software deliverable is intended for and must only be */
|
||||
;/* used for reference and in an evaluation laboratory environment. */
|
||||
;/* It is provided on an as-is basis without charge and is subject to */
|
||||
;/* alterations. */
|
||||
;/* It is the user's obligation to fully test the software in its */
|
||||
;/* environment and to ensure proper functionality, qualification and */
|
||||
;/* compliance with component specifications. */
|
||||
;/* */
|
||||
;/* In the event the software deliverable includes the use of open */
|
||||
;/* source components, the provisions of the governing open source */
|
||||
;/* license agreement shall apply with respect to such software */
|
||||
;/* deliverable. */
|
||||
;/* FSEU does not warrant that the deliverables do not infringe any */
|
||||
;/* third party intellectual property right (IPR). In the event that */
|
||||
;/* the deliverables infringe a third party IPR it is the sole */
|
||||
;/* responsibility of the customer to obtain necessary licenses to */
|
||||
;/* continue the usage of the deliverable. */
|
||||
;/* */
|
||||
;/* To the maximum extent permitted by applicable law FSEU disclaims all */
|
||||
;/* warranties, whether express or implied, in particular, but not */
|
||||
;/* limited to, warranties of merchantability and fitness for a */
|
||||
;/* particular purpose for which the deliverable is not designated. */
|
||||
;/* */
|
||||
;/* To the maximum extent permitted by applicable law, FSEU's liability */
|
||||
;/* is restricted to intentional misconduct and gross negligence. */
|
||||
;/* FSEU is not liable for consequential damages. */
|
||||
;/* */
|
||||
;/* (V1.5) */
|
||||
;/************************************************************************/
|
||||
;/* Startup for IAR */
|
||||
;/* Version V1.03 */
|
||||
;/* Date 2011-05-17 */
|
||||
;/* Target-mcu MB9A310 */
|
||||
;/************************************************************************/
|
||||
|
||||
|
||||
MODULE ?cstartup
|
||||
|
||||
;; Forward declaration of sections.
|
||||
SECTION CSTACK:DATA:NOROOT(3)
|
||||
|
||||
SECTION .intvec:CODE:NOROOT(2)
|
||||
|
||||
EXTERN __iar_program_start
|
||||
EXTERN SystemInit
|
||||
PUBLIC __vector_table
|
||||
|
||||
DATA
|
||||
__vector_table DCD sfe(CSTACK) ; Top of Stack
|
||||
DCD Reset_Handler ; Reset
|
||||
DCD NMI_Handler ; NMI
|
||||
DCD HardFault_Handler ; Hard Fault
|
||||
DCD MemManage_Handler ; MPU Fault
|
||||
DCD BusFault_Handler ; Bus Fault
|
||||
DCD UsageFault_Handler ; Usage Fault
|
||||
DCD 0 ; Reserved
|
||||
DCD 0 ; Reserved
|
||||
DCD 0 ; Reserved
|
||||
DCD 0 ; Reserved
|
||||
DCD SVC_Handler ; SVCall
|
||||
DCD DebugMon_Handler ; Debug Monitor
|
||||
DCD 0 ; Reserved
|
||||
DCD PendSV_Handler ; PendSV
|
||||
DCD SysTick_Handler ; SysTick
|
||||
|
||||
DCD CSV_Handler ; 0: Clock Super Visor
|
||||
DCD SWDT_Handler ; 1: Software Watchdog Timer
|
||||
DCD LVD_Handler ; 2: Low Voltage Detector
|
||||
DCD MFT_WG_IRQHandler ; 3: Wave Form Generator / DTIF
|
||||
DCD INT0_7_Handler ; 4: External Interrupt Request ch.0 to ch.7
|
||||
DCD INT8_15_Handler ; 5: External Interrupt Request ch.8 to ch.15
|
||||
DCD DT_Handler ; 6: Dual Timer / Quad Decoder
|
||||
DCD MFS0RX_IRQHandler ; 7: MultiFunction Serial ch.0
|
||||
DCD MFS0TX_IRQHandler ; 8: MultiFunction Serial ch.0
|
||||
DCD MFS1RX_IRQHandler ; 9: MultiFunction Serial ch.1
|
||||
DCD MFS1TX_IRQHandler ; 10: MultiFunction Serial ch.1
|
||||
DCD MFS2RX_IRQHandler ; 11: MultiFunction Serial ch.2
|
||||
DCD MFS2TX_IRQHandler ; 12: MultiFunction Serial ch.2
|
||||
DCD MFS3RX_IRQHandler ; 13: MultiFunction Serial ch.3
|
||||
DCD MFS3TX_IRQHandler ; 14: MultiFunction Serial ch.3
|
||||
DCD MFS4RX_IRQHandler ; 15: MultiFunction Serial ch.4
|
||||
DCD MFS4TX_IRQHandler ; 16: MultiFunction Serial ch.4
|
||||
DCD MFS5RX_IRQHandler ; 17: MultiFunction Serial ch.5
|
||||
DCD MFS5TX_IRQHandler ; 18: MultiFunction Serial ch.5
|
||||
DCD MFS6RX_IRQHandler ; 19: MultiFunction Serial ch.6
|
||||
DCD MFS6TX_IRQHandler ; 20: MultiFunction Serial ch.6
|
||||
DCD MFS7RX_IRQHandler ; 21: MultiFunction Serial ch.7
|
||||
DCD MFS7TX_IRQHandler ; 22: MultiFunction Serial ch.7
|
||||
DCD PPG_Handler ; 23: PPG
|
||||
DCD TIM_IRQHandler ; 24: OSC / PLL / Watch Counter
|
||||
DCD ADC0_IRQHandler ; 25: ADC0
|
||||
DCD ADC1_IRQHandler ; 26: ADC1
|
||||
DCD ADC2_IRQHandler ; 27: ADC2
|
||||
DCD MFT_FRT_IRQHandler ; 28: Free-run Timer
|
||||
DCD MFT_IPC_IRQHandler ; 29: Input Capture
|
||||
DCD MFT_OPC_IRQHandler ; 30: Output Compare
|
||||
DCD BT_IRQHandler ; 31: Base Timer ch.0 to ch.7
|
||||
DCD DummyHandler ; 32: Reserved
|
||||
DCD DummyHandler ; 33: Reserved
|
||||
DCD USBF_Handler ; 34: USB Function
|
||||
DCD USB_Handler ; 35: USB Function / USB HOST
|
||||
DCD DummyHandler ; 36: Reserved
|
||||
DCD DummyHandler ; 37: Reserved
|
||||
DCD DMAC0_Handler ; 38: DMAC ch.0
|
||||
DCD DMAC1_Handler ; 39: DMAC ch.1
|
||||
DCD DMAC2_Handler ; 40: DMAC ch.2
|
||||
DCD DMAC3_Handler ; 41: DMAC ch.3
|
||||
DCD DMAC4_Handler ; 42: DMAC ch.4
|
||||
DCD DMAC5_Handler ; 43: DMAC ch.5
|
||||
DCD DMAC6_Handler ; 44: DMAC ch.6
|
||||
DCD DMAC7_Handler ; 45: DMAC ch.7
|
||||
DCD DummyHandler ; 46: Reserved
|
||||
DCD DummyHandler ; 47: Reserved
|
||||
|
||||
THUMB
|
||||
; Dummy Exception Handlers (infinite loops which can be modified)
|
||||
|
||||
PUBWEAK Reset_Handler
|
||||
SECTION .text:CODE:REORDER(2)
|
||||
Reset_Handler
|
||||
LDR R0, =SystemInit
|
||||
BLX R0
|
||||
LDR R0, =__iar_program_start
|
||||
BX R0
|
||||
|
||||
PUBWEAK NMI_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
NMI_Handler
|
||||
B NMI_Handler
|
||||
|
||||
PUBWEAK HardFault_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
HardFault_Handler
|
||||
B HardFault_Handler
|
||||
|
||||
PUBWEAK MemManage_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MemManage_Handler
|
||||
B MemManage_Handler
|
||||
|
||||
PUBWEAK BusFault_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
BusFault_Handler
|
||||
B BusFault_Handler
|
||||
|
||||
PUBWEAK UsageFault_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
UsageFault_Handler
|
||||
B UsageFault_Handler
|
||||
|
||||
PUBWEAK SVC_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
SVC_Handler
|
||||
B SVC_Handler
|
||||
|
||||
PUBWEAK DebugMon_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
DebugMon_Handler
|
||||
B DebugMon_Handler
|
||||
|
||||
PUBWEAK PendSV_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
PendSV_Handler
|
||||
B PendSV_Handler
|
||||
|
||||
PUBWEAK SysTick_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
SysTick_Handler
|
||||
B SysTick_Handler
|
||||
|
||||
|
||||
|
||||
PUBWEAK CSV_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
CSV_Handler
|
||||
B CSV_Handler
|
||||
|
||||
PUBWEAK SWDT_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
SWDT_Handler
|
||||
B SWDT_Handler
|
||||
|
||||
PUBWEAK LVD_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
LVD_Handler
|
||||
B LVD_Handler
|
||||
|
||||
PUBWEAK MFT_WG_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFT_WG_IRQHandler
|
||||
B MFT_WG_IRQHandler
|
||||
|
||||
PUBWEAK INT0_7_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
INT0_7_Handler
|
||||
B INT0_7_Handler
|
||||
|
||||
PUBWEAK INT8_15_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
INT8_15_Handler
|
||||
B INT8_15_Handler
|
||||
|
||||
PUBWEAK DT_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
DT_Handler
|
||||
B DT_Handler
|
||||
|
||||
PUBWEAK MFS0RX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS0RX_IRQHandler
|
||||
B MFS0RX_IRQHandler
|
||||
|
||||
PUBWEAK MFS0TX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS0TX_IRQHandler
|
||||
B MFS0TX_IRQHandler
|
||||
|
||||
PUBWEAK MFS1RX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS1RX_IRQHandler
|
||||
B MFS1RX_IRQHandler
|
||||
|
||||
PUBWEAK MFS1TX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS1TX_IRQHandler
|
||||
B MFS1TX_IRQHandler
|
||||
|
||||
PUBWEAK MFS2RX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS2RX_IRQHandler
|
||||
B MFS2RX_IRQHandler
|
||||
|
||||
PUBWEAK MFS2TX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS2TX_IRQHandler
|
||||
B MFS2TX_IRQHandler
|
||||
|
||||
PUBWEAK MFS3RX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS3RX_IRQHandler
|
||||
B MFS3RX_IRQHandler
|
||||
|
||||
PUBWEAK MFS3TX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS3TX_IRQHandler
|
||||
B MFS3TX_IRQHandler
|
||||
|
||||
PUBWEAK MFS4RX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS4RX_IRQHandler
|
||||
B MFS4RX_IRQHandler
|
||||
|
||||
PUBWEAK MFS4TX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS4TX_IRQHandler
|
||||
B MFS4TX_IRQHandler
|
||||
|
||||
PUBWEAK MFS5RX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS5RX_IRQHandler
|
||||
B MFS5RX_IRQHandler
|
||||
|
||||
PUBWEAK MFS5TX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS5TX_IRQHandler
|
||||
B MFS5TX_IRQHandler
|
||||
|
||||
PUBWEAK MFS6RX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS6RX_IRQHandler
|
||||
B MFS6RX_IRQHandler
|
||||
|
||||
PUBWEAK MFS6TX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS6TX_IRQHandler
|
||||
B MFS6TX_IRQHandler
|
||||
|
||||
PUBWEAK MFS7RX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS7RX_IRQHandler
|
||||
B MFS7RX_IRQHandler
|
||||
|
||||
PUBWEAK MFS7TX_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFS7TX_IRQHandler
|
||||
B MFS7TX_IRQHandler
|
||||
|
||||
PUBWEAK PPG_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
PPG_Handler
|
||||
B PPG_Handler
|
||||
|
||||
PUBWEAK TIM_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
TIM_IRQHandler
|
||||
B TIM_IRQHandler
|
||||
|
||||
PUBWEAK ADC0_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
ADC0_IRQHandler
|
||||
B ADC0_IRQHandler
|
||||
|
||||
PUBWEAK ADC1_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
ADC1_IRQHandler
|
||||
B ADC1_IRQHandler
|
||||
|
||||
PUBWEAK ADC2_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
ADC2_IRQHandler
|
||||
B ADC2_IRQHandler
|
||||
|
||||
PUBWEAK MFT_FRT_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFT_FRT_IRQHandler
|
||||
B MFT_FRT_IRQHandler
|
||||
|
||||
PUBWEAK MFT_IPC_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFT_IPC_IRQHandler
|
||||
B MFT_IPC_IRQHandler
|
||||
|
||||
PUBWEAK MFT_OPC_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
MFT_OPC_IRQHandler
|
||||
B MFT_OPC_IRQHandler
|
||||
|
||||
PUBWEAK BT_IRQHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
BT_IRQHandler
|
||||
B BT_IRQHandler
|
||||
|
||||
PUBWEAK USBF_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
USBF_Handler
|
||||
B USBF_Handler
|
||||
|
||||
PUBWEAK USB_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
USB_Handler
|
||||
B USB_Handler
|
||||
|
||||
PUBWEAK DMAC0_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
DMAC0_Handler
|
||||
B DMAC0_Handler
|
||||
|
||||
|
||||
PUBWEAK DMAC1_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
DMAC1_Handler
|
||||
B DMAC1_Handler
|
||||
|
||||
PUBWEAK DMAC2_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
DMAC2_Handler
|
||||
B DMAC2_Handler
|
||||
|
||||
PUBWEAK DMAC3_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
DMAC3_Handler
|
||||
B DMAC3_Handler
|
||||
|
||||
PUBWEAK DMAC4_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
DMAC4_Handler
|
||||
B DMAC4_Handler
|
||||
|
||||
PUBWEAK DMAC5_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
DMAC5_Handler
|
||||
B DMAC5_Handler
|
||||
|
||||
PUBWEAK DMAC6_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
DMAC6_Handler
|
||||
B DMAC6_Handler
|
||||
|
||||
PUBWEAK DMAC7_Handler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
DMAC7_Handler
|
||||
B DMAC7_Handler
|
||||
|
||||
PUBWEAK DummyHandler
|
||||
SECTION .text:CODE:REORDER(1)
|
||||
DummyHandler
|
||||
B DummyHandler
|
||||
|
||||
END
|
|
@ -0,0 +1,327 @@
|
|||
;/************************************************************************/
|
||||
;/* (C) Fujitsu Semiconductor Europe GmbH */
|
||||
;/* */
|
||||
;/* The following software deliverable is intended for and must only be */
|
||||
;/* used for reference and in an evaluation laboratory environment. */
|
||||
;/* It is provided on an as-is basis without charge and is subject to */
|
||||
;/* alterations. */
|
||||
;/* It is the user’s obligation to fully test the software in its */
|
||||
;/* environment and to ensure proper functionality, qualification and */
|
||||
;/* compliance with component specifications. */
|
||||
;/* */
|
||||
;/* In the event the software deliverable includes the use of open */
|
||||
;/* source components, the provisions of the governing open source */
|
||||
;/* license agreement shall apply with respect to such software */
|
||||
;/* deliverable. */
|
||||
;/* FSEU does not warrant that the deliverables do not infringe any */
|
||||
;/* third party intellectual property right (IPR). In the event that */
|
||||
;/* the deliverables infringe a third party IPR it is the sole */
|
||||
;/* responsibility of the customer to obtain necessary licenses to */
|
||||
;/* continue the usage of the deliverable. */
|
||||
;/* */
|
||||
;/* To the maximum extent permitted by applicable law FSEU disclaims all */
|
||||
;/* warranties, whether express or implied, in particular, but not */
|
||||
;/* limited to, warranties of merchantability and fitness for a */
|
||||
;/* particular purpose for which the deliverable is not designated. */
|
||||
;/* */
|
||||
;/* To the maximum extent permitted by applicable law, FSEU's liability */
|
||||
;/* is restricted to intention and gross negligence. */
|
||||
;/* FSEU is not liable for consequential damages. */
|
||||
;/* */
|
||||
;/* (V1.4) */
|
||||
;/************************************************************************/
|
||||
;/* Startup for ARM */
|
||||
;/* Version V1.02 */
|
||||
;/* Date 2011-01-12 */
|
||||
;/* Target-mcu MB9B5xx */
|
||||
;/************************************************************************/
|
||||
|
||||
; Stack Configuration
|
||||
; Stack Size (in Bytes) <0x0-0xFFFFFFFF:8>
|
||||
|
||||
Stack_Size EQU 0x00000200
|
||||
|
||||
AREA STACK, NOINIT, READWRITE, ALIGN=3
|
||||
Stack_Mem SPACE Stack_Size
|
||||
__initial_sp
|
||||
|
||||
|
||||
; Heap Configuration
|
||||
; Heap Size (in Bytes) <0x0-0xFFFFFFFF:8>
|
||||
|
||||
Heap_Size EQU 0x00000000
|
||||
|
||||
AREA HEAP, NOINIT, READWRITE, ALIGN=3
|
||||
__heap_base
|
||||
Heap_Mem SPACE Heap_Size
|
||||
__heap_limit
|
||||
|
||||
|
||||
PRESERVE8
|
||||
THUMB
|
||||
|
||||
|
||||
; Vector Table Mapped to Address 0 at Reset
|
||||
|
||||
AREA RESET, DATA, READONLY
|
||||
EXPORT __Vectors
|
||||
EXPORT __Vectors_End
|
||||
EXPORT __Vectors_Size
|
||||
|
||||
__Vectors DCD __initial_sp ; Top of Stack
|
||||
DCD Reset_Handler ; Reset Handler
|
||||
DCD NMI_Handler ; NMI Handler
|
||||
DCD HardFault_Handler ; Hard Fault Handler
|
||||
DCD MemManage_Handler ; MPU Fault Handler
|
||||
DCD BusFault_Handler ; Bus Fault Handler
|
||||
DCD UsageFault_Handler ; Usage Fault Handler
|
||||
DCD 0 ; Reserved
|
||||
DCD 0 ; Reserved
|
||||
DCD 0 ; Reserved
|
||||
DCD 0 ; Reserved
|
||||
DCD SVC_Handler ; SVCall Handler
|
||||
DCD DebugMon_Handler ; Debug Monitor Handler
|
||||
DCD 0 ; Reserved
|
||||
DCD PendSV_Handler ; PendSV Handler
|
||||
DCD SysTick_Handler ; SysTick Handler
|
||||
|
||||
DCD CSV_Handler ; 0: Clock Super Visor
|
||||
DCD SWDT_Handler ; 1: Software Watchdog Timer
|
||||
DCD LVD_Handler ; 2: Low Voltage Detector
|
||||
DCD MFT_WG_IRQHandler ; 3: Wave Form Generator / DTIF
|
||||
DCD INT0_7_Handler ; 4: External Interrupt Request ch.0 to ch.7
|
||||
DCD INT8_15_Handler ; 5: External Interrupt Request ch.8 to ch.15
|
||||
DCD DT_Handler ; 6: Dual Timer / Quad Decoder
|
||||
DCD MFS0RX_IRQHandler ; 7: MultiFunction Serial ch.0
|
||||
DCD MFS0TX_IRQHandler ; 8: MultiFunction Serial ch.0
|
||||
DCD MFS1RX_IRQHandler ; 9: MultiFunction Serial ch.1
|
||||
DCD MFS1TX_IRQHandler ; 10: MultiFunction Serial ch.1
|
||||
DCD MFS2RX_IRQHandler ; 11: MultiFunction Serial ch.2
|
||||
DCD MFS2TX_IRQHandler ; 12: MultiFunction Serial ch.2
|
||||
DCD MFS3RX_IRQHandler ; 13: MultiFunction Serial ch.3
|
||||
DCD MFS3TX_IRQHandler ; 14: MultiFunction Serial ch.3
|
||||
DCD MFS4RX_IRQHandler ; 15: MultiFunction Serial ch.4
|
||||
DCD MFS4TX_IRQHandler ; 16: MultiFunction Serial ch.4
|
||||
DCD MFS5RX_IRQHandler ; 17: MultiFunction Serial ch.5
|
||||
DCD MFS5TX_IRQHandler ; 18: MultiFunction Serial ch.5
|
||||
DCD MFS6RX_IRQHandler ; 19: MultiFunction Serial ch.6
|
||||
DCD MFS6TX_IRQHandler ; 20: MultiFunction Serial ch.6
|
||||
DCD MFS7RX_IRQHandler ; 21: MultiFunction Serial ch.7
|
||||
DCD MFS7TX_IRQHandler ; 22: MultiFunction Serial ch.7
|
||||
DCD PPG_Handler ; 23: PPG
|
||||
DCD TIM_IRQHandler ; 24: OSC / PLL / Watch Counter
|
||||
DCD ADC0_IRQHandler ; 25: ADC0
|
||||
DCD ADC1_IRQHandler ; 26: ADC1
|
||||
DCD ADC2_IRQHandler ; 27: ADC2
|
||||
DCD MFT_FRT_IRQHandler ; 28: Free-run Timer
|
||||
DCD MFT_IPC_IRQHandler ; 29: Input Capture
|
||||
DCD MFT_OPC_IRQHandler ; 30: Output Compare
|
||||
DCD BT_IRQHandler ; 31: Base Timer ch.0 to ch.7
|
||||
DCD CAN0_IRQHandler ; 32: CAN ch.0
|
||||
DCD CAN1_IRQHandler ; 33: CAN ch.1
|
||||
DCD USBF_Handler ; 34: USB Function
|
||||
DCD USB_Handler ; 35: USB Function / USB HOST
|
||||
DCD DummyHandler ; 36: Reserved
|
||||
DCD DummyHandler ; 37: Reserved
|
||||
DCD DMAC0_Handler ; 38: DMAC ch.0
|
||||
DCD DMAC1_Handler ; 39: DMAC ch.1
|
||||
DCD DMAC2_Handler ; 40: DMAC ch.2
|
||||
DCD DMAC3_Handler ; 41: DMAC ch.3
|
||||
DCD DMAC4_Handler ; 42: DMAC ch.4
|
||||
DCD DMAC5_Handler ; 43: DMAC ch.5
|
||||
DCD DMAC6_Handler ; 44: DMAC ch.6
|
||||
DCD DMAC7_Handler ; 45: DMAC ch.7
|
||||
DCD DummyHandler ; 46: Reserved
|
||||
DCD DummyHandler ; 47: Reserved
|
||||
__Vectors_End
|
||||
|
||||
__Vectors_Size EQU __Vectors_End - __Vectors
|
||||
|
||||
AREA |.text|, CODE, READONLY
|
||||
|
||||
|
||||
; Reset Handler
|
||||
|
||||
Reset_Handler PROC
|
||||
EXPORT Reset_Handler [WEAK]
|
||||
IMPORT SystemInit
|
||||
IMPORT __main
|
||||
LDR R0, =SystemInit
|
||||
BLX R0
|
||||
LDR R0, =__main
|
||||
BX R0
|
||||
ENDP
|
||||
|
||||
|
||||
; Dummy Exception Handlers (infinite loops which can be modified)
|
||||
|
||||
NMI_Handler PROC
|
||||
EXPORT NMI_Handler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
HardFault_Handler\
|
||||
PROC
|
||||
EXPORT HardFault_Handler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
MemManage_Handler\
|
||||
PROC
|
||||
EXPORT MemManage_Handler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
BusFault_Handler\
|
||||
PROC
|
||||
EXPORT BusFault_Handler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
UsageFault_Handler\
|
||||
PROC
|
||||
EXPORT UsageFault_Handler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
SVC_Handler PROC
|
||||
EXPORT SVC_Handler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
DebugMon_Handler\
|
||||
PROC
|
||||
EXPORT DebugMon_Handler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
PendSV_Handler PROC
|
||||
EXPORT PendSV_Handler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
SysTick_Handler PROC
|
||||
EXPORT SysTick_Handler [WEAK]
|
||||
B .
|
||||
ENDP
|
||||
|
||||
Default_Handler PROC
|
||||
|
||||
EXPORT CSV_Handler [WEAK]
|
||||
EXPORT SWDT_Handler [WEAK]
|
||||
EXPORT LVD_Handler [WEAK]
|
||||
EXPORT MFT_WG_IRQHandler [WEAK]
|
||||
EXPORT INT0_7_Handler [WEAK]
|
||||
EXPORT INT8_15_Handler [WEAK]
|
||||
EXPORT DT_Handler [WEAK]
|
||||
EXPORT MFS0RX_IRQHandler [WEAK]
|
||||
EXPORT MFS0TX_IRQHandler [WEAK]
|
||||
EXPORT MFS1RX_IRQHandler [WEAK]
|
||||
EXPORT MFS1TX_IRQHandler [WEAK]
|
||||
EXPORT MFS2RX_IRQHandler [WEAK]
|
||||
EXPORT MFS2TX_IRQHandler [WEAK]
|
||||
EXPORT MFS3RX_IRQHandler [WEAK]
|
||||
EXPORT MFS3TX_IRQHandler [WEAK]
|
||||
EXPORT MFS4RX_IRQHandler [WEAK]
|
||||
EXPORT MFS4TX_IRQHandler [WEAK]
|
||||
EXPORT MFS5RX_IRQHandler [WEAK]
|
||||
EXPORT MFS5TX_IRQHandler [WEAK]
|
||||
EXPORT MFS6RX_IRQHandler [WEAK]
|
||||
EXPORT MFS6TX_IRQHandler [WEAK]
|
||||
EXPORT MFS7RX_IRQHandler [WEAK]
|
||||
EXPORT MFS7TX_IRQHandler [WEAK]
|
||||
EXPORT PPG_Handler [WEAK]
|
||||
EXPORT TIM_IRQHandler [WEAK]
|
||||
EXPORT ADC0_IRQHandler [WEAK]
|
||||
EXPORT ADC1_IRQHandler [WEAK]
|
||||
EXPORT ADC2_IRQHandler [WEAK]
|
||||
EXPORT MFT_FRT_IRQHandler [WEAK]
|
||||
EXPORT MFT_IPC_IRQHandler [WEAK]
|
||||
EXPORT MFT_OPC_IRQHandler [WEAK]
|
||||
EXPORT BT_IRQHandler [WEAK]
|
||||
EXPORT CAN0_IRQHandler [WEAK]
|
||||
EXPORT CAN1_IRQHandler [WEAK]
|
||||
EXPORT USBF_Handler [WEAK]
|
||||
EXPORT USB_Handler [WEAK]
|
||||
EXPORT DMAC0_Handler [WEAK]
|
||||
EXPORT DMAC1_Handler [WEAK]
|
||||
EXPORT DMAC2_Handler [WEAK]
|
||||
EXPORT DMAC3_Handler [WEAK]
|
||||
EXPORT DMAC4_Handler [WEAK]
|
||||
EXPORT DMAC5_Handler [WEAK]
|
||||
EXPORT DMAC6_Handler [WEAK]
|
||||
EXPORT DMAC7_Handler [WEAK]
|
||||
EXPORT DummyHandler [WEAK]
|
||||
|
||||
CSV_Handler
|
||||
SWDT_Handler
|
||||
LVD_Handler
|
||||
MFT_WG_IRQHandler
|
||||
INT0_7_Handler
|
||||
INT8_15_Handler
|
||||
DT_Handler
|
||||
MFS0RX_IRQHandler
|
||||
MFS0TX_IRQHandler
|
||||
MFS1RX_IRQHandler
|
||||
MFS1TX_IRQHandler
|
||||
MFS2RX_IRQHandler
|
||||
MFS2TX_IRQHandler
|
||||
MFS3RX_IRQHandler
|
||||
MFS3TX_IRQHandler
|
||||
MFS4RX_IRQHandler
|
||||
MFS4TX_IRQHandler
|
||||
MFS5RX_IRQHandler
|
||||
MFS5TX_IRQHandler
|
||||
MFS6RX_IRQHandler
|
||||
MFS6TX_IRQHandler
|
||||
MFS7RX_IRQHandler
|
||||
MFS7TX_IRQHandler
|
||||
PPG_Handler
|
||||
TIM_IRQHandler
|
||||
ADC0_IRQHandler
|
||||
ADC1_IRQHandler
|
||||
ADC2_IRQHandler
|
||||
MFT_FRT_IRQHandler
|
||||
MFT_IPC_IRQHandler
|
||||
MFT_OPC_IRQHandler
|
||||
BT_IRQHandler
|
||||
CAN0_IRQHandler
|
||||
CAN1_IRQHandler
|
||||
USBF_Handler
|
||||
USB_Handler
|
||||
DMAC0_Handler
|
||||
DMAC1_Handler
|
||||
DMAC2_Handler
|
||||
DMAC3_Handler
|
||||
DMAC4_Handler
|
||||
DMAC5_Handler
|
||||
DMAC6_Handler
|
||||
DMAC7_Handler
|
||||
DummyHandler
|
||||
|
||||
B .
|
||||
|
||||
ENDP
|
||||
|
||||
|
||||
ALIGN
|
||||
|
||||
|
||||
; User Initial Stack & Heap
|
||||
|
||||
IF :DEF:__MICROLIB
|
||||
|
||||
EXPORT __initial_sp
|
||||
EXPORT __heap_base
|
||||
EXPORT __heap_limit
|
||||
|
||||
ELSE
|
||||
|
||||
IMPORT __use_two_region_memory
|
||||
EXPORT __user_initial_stackheap
|
||||
__user_initial_stackheap
|
||||
|
||||
LDR R0, = Heap_Mem
|
||||
LDR R1, =(Stack_Mem + Stack_Size)
|
||||
LDR R2, = (Heap_Mem + Heap_Size)
|
||||
LDR R3, = Stack_Mem
|
||||
BX LR
|
||||
|
||||
ALIGN
|
||||
|
||||
ENDIF
|
||||
|
||||
|
||||
END
|
202
Demo/CORTEX_MB9A310_IAR_Keil/Fujitu_source/system_mb9af31x.c
Normal file
202
Demo/CORTEX_MB9A310_IAR_Keil/Fujitu_source/system_mb9af31x.c
Normal file
|
@ -0,0 +1,202 @@
|
|||
/************************************************************************/
|
||||
/* (C) Fujitsu Semiconductor Europe GmbH (FSEU) */
|
||||
/* */
|
||||
/* The following software deliverable is intended for and must only be */
|
||||
/* used for reference and in an evaluation laboratory environment. */
|
||||
/* It is provided on an as-is basis without charge and is subject to */
|
||||
/* alterations. */
|
||||
/* It is the user's obligation to fully test the software in its */
|
||||
/* environment and to ensure proper functionality, qualification and */
|
||||
/* compliance with component specifications. */
|
||||
/* */
|
||||
/* In the event the software deliverable includes the use of open */
|
||||
/* source components, the provisions of the governing open source */
|
||||
/* license agreement shall apply with respect to such software */
|
||||
/* deliverable. */
|
||||
/* FSEU does not warrant that the deliverables do not infringe any */
|
||||
/* third party intellectual property right (IPR). In the event that */
|
||||
/* the deliverables infringe a third party IPR it is the sole */
|
||||
/* responsibility of the customer to obtain necessary licenses to */
|
||||
/* continue the usage of the deliverable. */
|
||||
/* */
|
||||
/* To the maximum extent permitted by applicable law FSEU disclaims all */
|
||||
/* warranties, whether express or implied, in particular, but not */
|
||||
/* limited to, warranties of merchantability and fitness for a */
|
||||
/* particular purpose for which the deliverable is not designated. */
|
||||
/* */
|
||||
/* To the maximum extent permitted by applicable law, FSEU's liability */
|
||||
/* is restricted to intentional misconduct and gross negligence. */
|
||||
/* FSEU is not liable for consequential damages. */
|
||||
/* */
|
||||
/* (V1.5) */
|
||||
/************************************************************************/
|
||||
|
||||
#include "mcu.h"
|
||||
|
||||
/** \file system_mb9af31x.c
|
||||
**
|
||||
** FM3 system initialization functions
|
||||
** All adjustments can be done in belonging header file.
|
||||
**
|
||||
** History:
|
||||
** 2011-05-16 V1.0 MWi original version
|
||||
******************************************************************************/
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** System Clock Frequency (Core Clock) Variable according CMSIS
|
||||
******************************************************************************/
|
||||
uint32_t SystemCoreClock = __HCLK;
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Update the System Core Clock with current core Clock retrieved from
|
||||
** cpu registers.
|
||||
** \param none
|
||||
** \return none
|
||||
******************************************************************************/
|
||||
void SystemCoreClockUpdate (void) {
|
||||
uint32_t masterClk;
|
||||
uint32_t u32RegisterRead; // Workaround variable for MISRA C rule conformance
|
||||
|
||||
switch ((FM3_CRG->SCM_CTL >> 5) & 0x07) {
|
||||
case 0: /* internal High-speed Cr osc. */
|
||||
masterClk = __CLKHC;
|
||||
break;
|
||||
|
||||
case 1: /* external main osc. */
|
||||
masterClk = __CLKMO;
|
||||
break;
|
||||
|
||||
case 2: /* PLL clock */
|
||||
// Workaround for preventing MISRA C:1998 Rule 46 (MISRA C:2004 Rule 12.2)
|
||||
// violation:
|
||||
// "Unordered accesses to a volatile location"
|
||||
u32RegisterRead = (__CLKMO * (((FM3_CRG->PLL_CTL2) & 0x1F) + 1));
|
||||
masterClk = (u32RegisterRead / (((FM3_CRG->PLL_CTL1 >> 4) & 0x0F) + 1));
|
||||
break;
|
||||
|
||||
case 4: /* internal Low-speed CR osc. */
|
||||
masterClk = __CLKLC;
|
||||
break;
|
||||
|
||||
case 5: /* external Sub osc. */
|
||||
masterClk = __CLKSO;
|
||||
break;
|
||||
|
||||
default:
|
||||
masterClk = 0Ul;
|
||||
break;
|
||||
}
|
||||
|
||||
switch (FM3_CRG->BSC_PSR & 0x07) {
|
||||
case 0:
|
||||
SystemCoreClock = masterClk;
|
||||
break;
|
||||
|
||||
case 1:
|
||||
SystemCoreClock = masterClk / 2;
|
||||
break;
|
||||
|
||||
case 2:
|
||||
SystemCoreClock = masterClk / 3;
|
||||
break;
|
||||
|
||||
case 3:
|
||||
SystemCoreClock = masterClk / 4;
|
||||
break;
|
||||
|
||||
case 4:
|
||||
SystemCoreClock = masterClk / 6;
|
||||
break;
|
||||
|
||||
case 5:
|
||||
SystemCoreClock = masterClk /8;
|
||||
break;
|
||||
|
||||
case 6:
|
||||
SystemCoreClock = masterClk /16;
|
||||
break;
|
||||
|
||||
default:
|
||||
SystemCoreClock = 0Ul;
|
||||
break;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Setup the microcontroller system. Initialize the System and update
|
||||
** the SystemCoreClock variable.
|
||||
**
|
||||
** \param none
|
||||
** \return none
|
||||
******************************************************************************/
|
||||
void SystemInit (void) {
|
||||
|
||||
static uint32_t u32IoRegisterRead; // Workaround variable for MISRA C rule conformance
|
||||
|
||||
#if (HWWD_DISABLE) /* HW Watchdog Disable */
|
||||
FM3_HWWDT->WDG_LCK = 0x1ACCE551; /* HW Watchdog Unlock */
|
||||
FM3_HWWDT->WDG_LCK = 0xE5331AAE;
|
||||
FM3_HWWDT->WDG_CTL = 0; /* HW Watchdog stop */
|
||||
#endif
|
||||
|
||||
#if (CLOCK_SETUP) /* Clock Setup */
|
||||
FM3_CRG->BSC_PSR = BSC_PSR_Val; /* set System Clock presacaler */
|
||||
FM3_CRG->APBC0_PSR = APBC0_PSR_Val; /* set APB0 presacaler */
|
||||
FM3_CRG->APBC1_PSR = APBC1_PSR_Val; /* set APB1 presacaler */
|
||||
FM3_CRG->APBC2_PSR = APBC2_PSR_Val; /* set APB2 presacaler */
|
||||
FM3_CRG->SWC_PSR = SWC_PSR_Val | (1UL << 7); /* set SW Watchdog presacaler */
|
||||
FM3_CRG->TTC_PSR = TTC_PSR_Val; /* set Trace Clock presacaler */
|
||||
|
||||
FM3_CRG->CSW_TMR = CSW_TMR_Val; /* set oscillation stabilization wait time */
|
||||
|
||||
if (SCM_CTL_Val & (1UL << 1)) { /* Main clock oscillator enabled ? */
|
||||
FM3_CRG->SCM_CTL |= (1UL << 1); /* enable main oscillator */
|
||||
while (!(FM3_CRG->SCM_STR & (1UL << 1))); /* wait for Main clock oscillation stable */
|
||||
}
|
||||
|
||||
if (SCM_CTL_Val & (1UL << 3)) { /* Sub clock oscillator enabled ? */
|
||||
FM3_CRG->SCM_CTL |= (1UL << 3); /* enable sub oscillator */
|
||||
while (!(FM3_CRG->SCM_STR & (1UL << 3))); /* wait for Sub clock oscillation stable */
|
||||
}
|
||||
|
||||
FM3_CRG->PSW_TMR = PSW_TMR_Val; /* set PLL stabilization wait time */
|
||||
FM3_CRG->PLL_CTL1 = PLL_CTL1_Val; /* set PLLM and PLLK */
|
||||
FM3_CRG->PLL_CTL2 = PLL_CTL2_Val; /* set PLLN */
|
||||
|
||||
if (SCM_CTL_Val & (1UL << 4)) { /* PLL enabled ? */
|
||||
FM3_CRG->SCM_CTL |= (1UL << 4); /* enable PLL */
|
||||
while (!(FM3_CRG->SCM_STR & (1UL << 4))); /* wait for PLL stable */
|
||||
}
|
||||
|
||||
FM3_CRG->SCM_CTL |= (SCM_CTL_Val & 0xE0); /* Set Master Clock switch */
|
||||
|
||||
// Workaround for preventing MISRA C:1998 Rule 46 (MISRA C:2004 Rule 12.2)
|
||||
// violations:
|
||||
// "Unordered reads and writes to or from same location" and
|
||||
// "Unordered accesses to a volatile location"
|
||||
do
|
||||
{
|
||||
u32IoRegisterRead = (FM3_CRG->SCM_CTL & 0xE0);
|
||||
}while ((FM3_CRG->SCM_STR & 0xE0) != u32IoRegisterRead);
|
||||
#endif // (CLOCK_SETUP)
|
||||
|
||||
#if (CR_TRIM_SETUP)
|
||||
/* CR Trimming Data */
|
||||
if( 0x000003FF != (FM3_FLASH_IF->CRTRMM & 0x000003FF) )
|
||||
{
|
||||
/* UnLock (MCR_FTRM) */
|
||||
FM3_CRTRIM->MCR_RLR = 0x1ACCE554;
|
||||
/* Set MCR_FTRM */
|
||||
FM3_CRTRIM->MCR_FTRM = FM3_FLASH_IF->CRTRMM;
|
||||
/* Lock (MCR_FTRM) */
|
||||
FM3_CRTRIM->MCR_RLR = 0x00000000;
|
||||
}
|
||||
#endif // (CR_TRIM_SETUP)
|
||||
}
|
||||
|
||||
|
||||
|
674
Demo/CORTEX_MB9A310_IAR_Keil/Fujitu_source/system_mb9af31x.h
Normal file
674
Demo/CORTEX_MB9A310_IAR_Keil/Fujitu_source/system_mb9af31x.h
Normal file
|
@ -0,0 +1,674 @@
|
|||
/************************************************************************/
|
||||
/* (C) Fujitsu Semiconductor Europe GmbH (FSEU) */
|
||||
/* */
|
||||
/* The following software deliverable is intended for and must only be */
|
||||
/* used for reference and in an evaluation laboratory environment. */
|
||||
/* It is provided on an as-is basis without charge and is subject to */
|
||||
/* alterations. */
|
||||
/* It is the user's obligation to fully test the software in its */
|
||||
/* environment and to ensure proper functionality, qualification and */
|
||||
/* compliance with component specifications. */
|
||||
/* */
|
||||
/* In the event the software deliverable includes the use of open */
|
||||
/* source components, the provisions of the governing open source */
|
||||
/* license agreement shall apply with respect to such software */
|
||||
/* deliverable. */
|
||||
/* FSEU does not warrant that the deliverables do not infringe any */
|
||||
/* third party intellectual property right (IPR). In the event that */
|
||||
/* the deliverables infringe a third party IPR it is the sole */
|
||||
/* responsibility of the customer to obtain necessary licenses to */
|
||||
/* continue the usage of the deliverable. */
|
||||
/* */
|
||||
/* To the maximum extent permitted by applicable law FSEU disclaims all */
|
||||
/* warranties, whether express or implied, in particular, but not */
|
||||
/* limited to, warranties of merchantability and fitness for a */
|
||||
/* particular purpose for which the deliverable is not designated. */
|
||||
/* */
|
||||
/* To the maximum extent permitted by applicable law, FSEU's liability */
|
||||
/* is restricted to intentional misconduct and gross negligence. */
|
||||
/* FSEU is not liable for consequential damages. */
|
||||
/* */
|
||||
/* (V1.5) */
|
||||
/************************************************************************/
|
||||
/** \file system_mb9af31x.h
|
||||
**
|
||||
** Headerfile for FM3 system parameters
|
||||
**
|
||||
** User clock definitions can be done for the following clock settings:
|
||||
** - CLOCK_SETUP : Execute the clock settings form the settings below in
|
||||
** SystemInit()
|
||||
** - __CLKMO : External clock frequency for main oscillion
|
||||
** - __CLKSO : External clock frequency for sub oscillion
|
||||
** - SCM_CTL : System Clock Mode Control Register
|
||||
** - BSC_PSR : Base Clock Prescaler Register
|
||||
** - APBC0_PSR : APB0 Prescaler Register
|
||||
** - APBC1_PSR : APB1 Prescaler Register
|
||||
** - APBC2_PSR : APB2 Prescaler Register
|
||||
** - SWC_PSR : Software Watchdog Clock Prescaler Register
|
||||
** - TTC_PSR : Trace Clock Prescaler Register
|
||||
** - CSW_TMR : Clock Stabilization Wait Time Register
|
||||
** - PSW_TMR : PLL Clock Stabilization Wait Time Setup Register
|
||||
** - PLL_CTL1 : PLL Control Register 1
|
||||
** - PLL_CTL2 : PLL Control Register 2
|
||||
**
|
||||
** The register settings are check for correct values of reserved bits.
|
||||
** Otherwise a preprocessor error is output and stops the build process.
|
||||
** Furthermore the 'master clock' is retrieved from the register settings
|
||||
** and the system clock (HCLK) is calculated from the Base Clock Prescaler
|
||||
** Register (BSC_PSR). This value is used for the global CMSIS variable
|
||||
** #SystemCoreClock. Also the absolute external, PLL and HCL freqeuncy is
|
||||
** is checked. Note that not all possible wrong setting are checked! The
|
||||
** user has to take care to fulfill the settings stated in the according
|
||||
** device's data sheet!
|
||||
**
|
||||
** User definition for Hardware Watchdog:
|
||||
** - HWWD_DISABLE : Disables Hardware Watchdog in SystemInit()
|
||||
**
|
||||
** User definition for CR Trimming:
|
||||
** - CR_TRIM_SETUP : Enables CR trimming in SystemInit()
|
||||
**
|
||||
** History:
|
||||
** 2011-05-16 V1.0 MWi original version
|
||||
*****************************************************************************/
|
||||
|
||||
#ifndef _SYSTEM_MB9AF31X_H_
|
||||
#define _SYSTEM_MB9AF31X_H_
|
||||
|
||||
/******************************************************************************/
|
||||
/* Include files */
|
||||
/******************************************************************************/
|
||||
|
||||
#include <stdint.h>
|
||||
|
||||
/******************************************************************************/
|
||||
/* Global pre-processor symbols/macros ('define') */
|
||||
/******************************************************************************/
|
||||
|
||||
/******************************************************************************/
|
||||
/* */
|
||||
/* START OF USER SETTINGS HERE */
|
||||
/* =========================== */
|
||||
/* */
|
||||
/* All lines with '<<<' can be set by user. */
|
||||
/* */
|
||||
/******************************************************************************/
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Clock Setup Enable
|
||||
** <i>(USER SETTING)</i>
|
||||
**
|
||||
** - 0 = No clock setup done by system_mb9xfxxx.c
|
||||
** - 1 = Clock setup done by system_mb9xfxxx.c
|
||||
******************************************************************************/
|
||||
#define CLOCK_SETUP 1 // <<< Define clock setup here
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief External Main Clock Frequency (in Hz, [value]UL)
|
||||
** <i>(USER SETTING)</i>
|
||||
******************************************************************************/
|
||||
#define __CLKMO ( 4000000UL) // <<< External 4MHz Crystal
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief External Sub Clock Frequency (in Hz, [value]UL)
|
||||
** <i>(USER SETTING)</i>
|
||||
******************************************************************************/
|
||||
#define __CLKSO ( 32768UL) // <<< External 32KHz Crystal
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief System Clock Mode Control Register value definition
|
||||
** <i>(USER SETTING)</i>
|
||||
**
|
||||
** SCM_CTL
|
||||
**
|
||||
** Bit#7-5 : RCS[2:0]
|
||||
** - 0 = Internal high-speed CR oscillation (default)
|
||||
** - 1 = Main oscillation clock
|
||||
** - 2 = PLL oscillation clock
|
||||
** - 3 = (not allowed)
|
||||
** - 4 = Internal low-speed CR oscillation
|
||||
** - 5 = Sub clock oscillation
|
||||
** - 6 = (not allowed)
|
||||
** - 7 = (not allowed)
|
||||
**
|
||||
** Bit#4 : PLLE
|
||||
** - 0 = Disable PLL (default)
|
||||
** - 1 = Enable PLL
|
||||
**
|
||||
** Bit#3 : SOSCE
|
||||
** - 0 = Disable sub oscillation (default)
|
||||
** - 1 = Enable sub oscillation
|
||||
**
|
||||
** Bit#2 : (reserved)
|
||||
**
|
||||
** Bit#1 : MOSCE
|
||||
** - 0 = Disable main oscillation (default)
|
||||
** - 1 = Enable main oscillation
|
||||
**
|
||||
** Bit#0 : (reserved)
|
||||
******************************************************************************/
|
||||
#define SCM_CTL_Val 0x00000052 // <<< Define SCM_CTL here
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Base Clock Prescaler Register value definition
|
||||
** <i>(USER SETTING)</i>
|
||||
**
|
||||
** BSC_PSR
|
||||
**
|
||||
** Bit#7-3 : (reserved)
|
||||
**
|
||||
** Bit#2-0 : BSR[2:0]
|
||||
** - 0 = HCLK = Master Clock
|
||||
** - 1 = HCLK = Master Clock / 2
|
||||
** - 2 = HCLK = Master Clock / 3
|
||||
** - 3 = HCLK = Master Clock / 4
|
||||
** - 4 = HCLK = Master Clock / 6
|
||||
** - 5 = HCLK = Master Clock / 8
|
||||
** - 6 = HCLK = Master Clock / 16
|
||||
** - 7 = (reserved)
|
||||
******************************************************************************/
|
||||
#define BSC_PSR_Val 0x00000000 // <<< Define BSC_PSR here
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief APB0 Prescaler Register value definition
|
||||
** <i>(USER SETTING)</i>
|
||||
**
|
||||
** APBC0_PSR
|
||||
**
|
||||
** Bit#7-2 : (reserved)
|
||||
**
|
||||
** Bit#1-0 : BSR[2:0]
|
||||
** - 0 = PCLK0 = HCLK
|
||||
** - 1 = PCLK0 = HCLK / 2
|
||||
** - 2 = PCLK0 = HCLK / 4
|
||||
** - 3 = PCLK0 = HCLK / 8
|
||||
******************************************************************************/
|
||||
#define APBC0_PSR_Val 0x00000001 // <<< Define APBC0_PSR here
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief APB1 Prescaler Register value definition
|
||||
** <i>(USER SETTING)</i>
|
||||
**
|
||||
** APBC1_PSR
|
||||
**
|
||||
** Bit#7 : APBC1EN
|
||||
** - 0 = Disable PCLK1 output
|
||||
** - 1 = Enables PCLK1 (default)
|
||||
**
|
||||
** Bit#6-5 : (reserved)
|
||||
**
|
||||
** Bit#4 : APBC1RST
|
||||
** - 0 = APB1 bus reset, inactive (default)
|
||||
** - 1 = APB1 bus reset, active
|
||||
**
|
||||
** Bit#3-2 : (reserved)
|
||||
**
|
||||
** Bit#1-0 : APBC1[2:0]
|
||||
** - 0 = PCLK1 = HCLK
|
||||
** - 1 = PCLK1 = HCLK / 2
|
||||
** - 2 = PCLK1 = HCLK / 4
|
||||
** - 3 = PCLK1 = HCLK / 8
|
||||
******************************************************************************/
|
||||
#define APBC1_PSR_Val 0x00000081 // <<< Define APBC1_PSR here
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief APB2 Prescaler Register value definition
|
||||
** <i>(USER SETTING)</i>
|
||||
**
|
||||
** APBC2_PSR
|
||||
**
|
||||
** Bit#7 : APBC2EN
|
||||
** - 0 = Disable PCLK2 output
|
||||
** - 1 = Enables PCLK2 (default)
|
||||
**
|
||||
** Bit#6-5 : (reserved)
|
||||
**
|
||||
** Bit#4 : APBC2RST
|
||||
** - 0 = APB2 bus reset, inactive (default)
|
||||
** - 1 = APB2 bus reset, active
|
||||
**
|
||||
** Bit#3-2 : (reserved)
|
||||
**
|
||||
** Bit#1-0 : APBC2[1:0]
|
||||
** - 0 = PCLK2 = HCLK
|
||||
** - 1 = PCLK2 = HCLK / 2
|
||||
** - 2 = PCLK2 = HCLK / 4
|
||||
** - 3 = PCLK2 = HCLK / 8
|
||||
******************************************************************************/
|
||||
#define APBC2_PSR_Val 0x00000081 // <<< Define APBC2_PSR here
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Software Watchdog Clock Prescaler Register value definition
|
||||
** <i>(USER SETTING)</i>
|
||||
**
|
||||
** SWC_PSR
|
||||
**
|
||||
** Bit#7 : TESTB
|
||||
** - 0 = (not allowed)
|
||||
** - 1 = (always write "1" to this bit)
|
||||
**
|
||||
** Bit#6-2 : (reserved)
|
||||
**
|
||||
** Bit#1-0 : SWDS[2:0]
|
||||
** - 0 = SWDGOGCLK = PCLK0
|
||||
** - 1 = SWDGOGCLK = PCLK0 / 2
|
||||
** - 2 = SWDGOGCLK = PCLK0 / 4
|
||||
** - 3 = SWDGOGCLK = PCLK0 / 8
|
||||
******************************************************************************/
|
||||
#define SWC_PSR_Val 0x00000003 // <<< Define SWC_PSR here
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Trace Clock Prescaler Register value definition
|
||||
** <i>(USER SETTING)</i>
|
||||
**
|
||||
** TTC_PSR
|
||||
**
|
||||
** Bit#7-1 : (reserved)
|
||||
**
|
||||
** Bit#0 : TTC
|
||||
** - 0 = TPIUCLK = HCLK
|
||||
** - 1 = TPIUCLK = HCLK / 2
|
||||
******************************************************************************/
|
||||
#define TTC_PSR_Val 0x00000000 // <<< Define TTC_PSR here
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Clock Stabilization Wait Time Register value definition
|
||||
** <i>(USER SETTING)</i>
|
||||
**
|
||||
** CSW_TMR
|
||||
**
|
||||
** Bit#7 : (reserved)
|
||||
**
|
||||
** Bit#6-4 : SOWT[2:0]
|
||||
** - 0 = ~10.3 ms (default)
|
||||
** - 1 = ~20.5 ms
|
||||
** - 2 = ~41 ms
|
||||
** - 3 = ~82 ms
|
||||
** - 4 = ~164 ms
|
||||
** - 5 = ~327 ms
|
||||
** - 6 = ~655 ms
|
||||
** - 7 = ~1.31 s
|
||||
**
|
||||
** Bit#3-0 : MOWT[3:0]
|
||||
** - 0 = ~500 ns (default)
|
||||
** - 1 = ~8 us
|
||||
** - 2 = ~16 us
|
||||
** - 3 = ~32 us
|
||||
** - 4 = ~64 us
|
||||
** - 5 = ~128 us
|
||||
** - 6 = ~256 us
|
||||
** - 7 = ~512 us
|
||||
** - 8 = ~1.0 ms
|
||||
** - 9 = ~2.0 ms
|
||||
** - 10 = ~4.0 ms
|
||||
** - 11 = ~8.0 ms
|
||||
** - 12 = ~33.0 ms
|
||||
** - 13 = ~131 ms
|
||||
** - 14 = ~524 ms
|
||||
** - 15 = ~2.0 s
|
||||
******************************************************************************/
|
||||
#define CSW_TMR_Val 0x0000005C // <<< Define CSW_TMR here
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief PLL Clock Stabilization Wait Time Setup Register value definition
|
||||
** <i>(USER SETTING)</i>
|
||||
**
|
||||
** PSW_TMR
|
||||
**
|
||||
** Bit#7-5 : (reserved)
|
||||
**
|
||||
** Bit#4 : PINC
|
||||
** - 0 = Selects CLKMO (main oscillation) (default)
|
||||
** - 1 = (setting diabled)
|
||||
**
|
||||
** Bit#3 : (reserved)
|
||||
**
|
||||
** Bit#2-0 : POWT[2:0]
|
||||
** - 0 = ~128 us (default)
|
||||
** - 1 = ~256 us
|
||||
** - 2 = ~512 us
|
||||
** - 3 = ~1.02 ms
|
||||
** - 4 = ~2.05 ms
|
||||
** - 5 = ~4.10 ms
|
||||
** - 6 = ~8.20 ms
|
||||
** - 7 = ~16.40 ms
|
||||
******************************************************************************/
|
||||
#define PSW_TMR_Val 0x00000000 // <<< Define PSW_TMR here
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief PLL Control Register 1 value definition
|
||||
** <i>(USER SETTING)</i>
|
||||
**
|
||||
** PLL_CTL1
|
||||
**
|
||||
** Bit#7-4 : PLLK[3:0]
|
||||
** - 0 = Division(PLLK) = 1/1 (default)
|
||||
** - 1 = Division(PLLK) = 1/2
|
||||
** - 2 = Division(PLLK) = 1/3
|
||||
** - . . .
|
||||
** - 15 = Division(PLLK) = 1/16
|
||||
**
|
||||
** Bit#3-0 : PLLM[3:0]
|
||||
** - 0 = Division(PLLM) = 1/1 (default)
|
||||
** - 1 = Division(PLLM) = 1/2
|
||||
** - 2 = Division(PLLM) = 1/3
|
||||
** - . . .
|
||||
** - 15 = Division(PLLM) = 1/16
|
||||
******************************************************************************/
|
||||
#define PLL_CTL1_Val 0x00000004 // <<< Define PLL_CTL1 here
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief PLL Control Register 2 value definition
|
||||
** <i>(USER SETTING)</i>
|
||||
**
|
||||
** PLL_CTL2
|
||||
**
|
||||
** Bit#7-6 : (reserved)
|
||||
**
|
||||
** Bit#5-0 : PLLM[5:0]
|
||||
** - 0 = Division(PLLN) = 1/1 (default)
|
||||
** - 1 = Division(PLLN) = 1/2
|
||||
** - 2 = Division(PLLN) = 1/3
|
||||
** - . . .
|
||||
** - 63 = Division(PLLN) = 1/64
|
||||
******************************************************************************/
|
||||
#define PLL_CTL2_Val 0x00000009 // <<< Define PLL_CTL2 here
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Hardware Watchdog disable definition
|
||||
** <i>(USER SETTING)</i>
|
||||
**
|
||||
** - 0 = Hardware Watchdog enable
|
||||
** - 1 = Hardware Watchdog disable
|
||||
******************************************************************************/
|
||||
#define HWWD_DISABLE 1 // <<< Define HW Watach dog enable here
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Trimming CR
|
||||
** <i>(USER SETTING)</i>
|
||||
**
|
||||
** - 0 = CR is not trimmed at startup
|
||||
** - 1 = CR is trimmed at startup
|
||||
******************************************************************************/
|
||||
#define CR_TRIM_SETUP 1 // <<< Define CR trimming at startup enable here
|
||||
|
||||
|
||||
/******************************************************************************/
|
||||
/* */
|
||||
/* END OF USER SETTINGS HERE */
|
||||
/* ========================= */
|
||||
/* */
|
||||
/******************************************************************************/
|
||||
|
||||
/******************************************************************************/
|
||||
/* Device dependent System Clock absolute maximum ranges */
|
||||
/******************************************************************************/
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Internal High-Speed CR Oscillator Frequency (in Hz, [value]UL)
|
||||
** <i>(USER SETTING)</i>
|
||||
******************************************************************************/
|
||||
#define __CLKHC ( 4000000UL) /* Internal 4MHz CR Oscillator */
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Internal Low-Speed CR Oscillator Frequency (in Hz, [value]UL)
|
||||
** <i>(USER SETTING)</i>
|
||||
******************************************************************************/
|
||||
#define __CLKLC ( 100000UL) /* Internal 100KHz CR Oscillator */
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Any case minimum Main Clock frequency (in Hz, [value]UL)
|
||||
** <i>(DEVICE DEPENDENT SETTING)</i>
|
||||
******************************************************************************/
|
||||
#define __CLKMOMIN ( 4000000UL)
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Maximum Main Clock frequency using external clock
|
||||
** <i>(DEVICE DEPENDENT SETTING)</i>
|
||||
******************************************************************************/
|
||||
#define __CLKMOMAX ( 48000000UL)
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Any case minimum Sub Clock frequency
|
||||
** <i>(DEVICE DEPENDENT SETTING)</i>
|
||||
******************************************************************************/
|
||||
#define __CLKSOMIN ( 32000UL)
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Maximum Sub Clock frequency using external clock
|
||||
** <i>(DEVICE DEPENDENT SETTING)</i>
|
||||
******************************************************************************/
|
||||
#define __CLKSOMAX ( 100000UL)
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Absolute minimum PLL input frequency
|
||||
** <i>(DEVICE DEPENDENT SETTING)</i>
|
||||
******************************************************************************/
|
||||
#define __PLLCLKINMIN ( 4000000UL)
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Absolute maximum PLL input frequency
|
||||
** <i>(DEVICE DEPENDENT SETTING)</i>
|
||||
******************************************************************************/
|
||||
#define __PLLCLKINMAX ( 16000000UL)
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Absolute minimum PLL oscillation frequency
|
||||
** <i>(DEVICE DEPENDENT SETTING)</i>
|
||||
******************************************************************************/
|
||||
#define __PLLCLKMIN (200000000UL)
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Absolute maximum PLL oscillation frequency
|
||||
** <i>(DEVICE DEPENDENT SETTING)</i>
|
||||
******************************************************************************/
|
||||
#define __PLLCLKMAX (300000000UL)
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Absolute maximum System Clock frequency (HCLK)
|
||||
** <i>(DEVICE DEPENDENT SETTING)</i>
|
||||
******************************************************************************/
|
||||
#define __HCLKMAX ( 40000000UL)
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Preprocessor macro for checking range (clock settings)
|
||||
******************************************************************************/
|
||||
#define CHECK_RANGE(val, min, max) ((val < min) || (val > max))
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Preprocessor macro for checking bits with mask (clock settings)
|
||||
******************************************************************************/
|
||||
#define CHECK_RSVD(val, mask) (val & mask)
|
||||
|
||||
|
||||
/******************************************************************************/
|
||||
/* Check register settings */
|
||||
/******************************************************************************/
|
||||
#if (CHECK_RSVD((SCM_CTL_Val), ~0x000000FA))
|
||||
#error "SCM_CTL: Invalid values of reserved bits!"
|
||||
#endif
|
||||
|
||||
#if ((SCM_CTL_Val & 0xE0) == 0x40) && ((SCM_CTL_Val & 0x10) != 0x10)
|
||||
#error "SCM_CTL: CLKPLL is selected but PLL is not enabled!"
|
||||
#endif
|
||||
|
||||
#if (CHECK_RSVD((CSW_TMR_Val), ~0x0000007F))
|
||||
#error "CSW_TMR: Invalid values of reserved bits!"
|
||||
#endif
|
||||
|
||||
#if ((SCM_CTL_Val & 0x10)) /* if PLL is used */
|
||||
#if (CHECK_RSVD((PSW_TMR_val), ~0x00000007))
|
||||
#error "PSW_TMR: Invalid values of reserved bits!"
|
||||
#endif
|
||||
|
||||
#if (CHECK_RSVD((PLL_CTL1_Val), ~0x000000FF))
|
||||
#error "PLL_CTL1: Invalid values of reserved bits!"
|
||||
#endif
|
||||
|
||||
#if (CHECK_RSVD((PLL_CTL2_Val), ~0x0000003F))
|
||||
#error "PLL_CTL2: Invalid values of reserved bits!"
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#if (CHECK_RSVD((BSC_PSR_Val), ~0x00000007))
|
||||
#error "BSC_PSR: Invalid values of reserved bits!"
|
||||
#endif
|
||||
|
||||
#if (CHECK_RSVD((APBC0_PSR_Val), ~0x00000003))
|
||||
#error "APBC0_PSR: Invalid values of reserved bits!"
|
||||
#endif
|
||||
|
||||
#if (CHECK_RSVD((APBC1_PSR_Val), ~0x00000083))
|
||||
#error "APBC1_PSR: Invalid values of reserved bits!"
|
||||
#endif
|
||||
|
||||
#if (CHECK_RSVD((APBC2_PSR_Val), ~0x00000083))
|
||||
#error "APBC2_PSR: Invalid values of reserved bits!"
|
||||
#endif
|
||||
|
||||
#if (CHECK_RSVD((SWC_PSR_Val), ~0x00000003))
|
||||
#error "SWC_PSR: Invalid values of reserved bits!"
|
||||
#endif
|
||||
|
||||
#if (CHECK_RSVD((TTC_PSR_Val), ~0x00000001))
|
||||
#error "TTC_PSR: Invalid values of reserved bits!"
|
||||
#endif
|
||||
|
||||
/******************************************************************************/
|
||||
/* Define clocks with checking settings */
|
||||
/******************************************************************************/
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Calculate PLL K factor from settings
|
||||
******************************************************************************/
|
||||
#define __PLLK (((PLL_CTL1_Val >> 4) & 0x0F) + 1)
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Calculate PLL N factor from settings
|
||||
******************************************************************************/
|
||||
#define __PLLN (((PLL_CTL2_Val ) & 0x1F) + 1)
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Calculate PLL M factor from settings
|
||||
******************************************************************************/
|
||||
#define __PLLM (((PLL_CTL1_Val ) & 0x0F) + 1)
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Calculate PLL output frequency from settings
|
||||
******************************************************************************/
|
||||
#define __PLLCLK ((__CLKMO * __PLLN) / __PLLK)
|
||||
|
||||
/******************************************************************************/
|
||||
/* Determine core clock frequency according to settings */
|
||||
/******************************************************************************/
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Define Master Clock from settings
|
||||
******************************************************************************/
|
||||
#if (((SCM_CTL_Val >> 5) & 0x07) == 0)
|
||||
#define __MASTERCLK (__CLKHC)
|
||||
#elif (((SCM_CTL_Val >> 5) & 0x07) == 1)
|
||||
#define __MASTERCLK (__CLKMO)
|
||||
#elif (((SCM_CTL_Val >> 5) & 0x07) == 2)
|
||||
#define __MASTERCLK (__PLLCLK)
|
||||
#elif (((SCM_CTL_Val >> 5) & 0x07) == 4)
|
||||
#define __MASTERCLK (__CLKLC)
|
||||
#elif (((SCM_CTL_Val >> 5) & 0x07) == 5)
|
||||
#define __MASTERCLK (__CLKSO)
|
||||
#else
|
||||
#define __MASTERCLK (0UL)
|
||||
#endif
|
||||
|
||||
/**
|
||||
******************************************************************************
|
||||
** \brief Define System Clock Frequency (Core Clock) from settings
|
||||
******************************************************************************/
|
||||
#if ((BSC_PSR_Val & 0x07) == 0)
|
||||
#define __HCLK (__MASTERCLK / 1)
|
||||
#elif ((BSC_PSR_Val & 0x07) == 1)
|
||||
#define __HCLK (__MASTERCLK / 2)
|
||||
#elif ((BSC_PSR_Val & 0x07) == 2)
|
||||
#define __HCLK (__MASTERCLK / 3)
|
||||
#elif ((BSC_PSR_Val & 0x07) == 3)
|
||||
#define __HCLK (__MASTERCLK / 4)
|
||||
#elif ((BSC_PSR_Val & 0x07) == 4)
|
||||
#define __HCLK (__MASTERCLK / 6)
|
||||
#elif ((BSC_PSR_Val & 0x07) == 5)
|
||||
#define __HCLK (__MASTERCLK / 8)
|
||||
#elif ((BSC_PSR_Val & 0x07) == 6)
|
||||
#define __HCLK (__MASTERCLK /16)
|
||||
#else
|
||||
#define __HCLK (0UL)
|
||||
#endif
|
||||
|
||||
/******************************************************************************/
|
||||
/* HCLK range check */
|
||||
/******************************************************************************/
|
||||
#if (CHECK_RANGE(__CLKMO, __CLKMOMIN, __CLKMOMAX) != 0)
|
||||
#error "Main Oscillator Clock (CLKMO) out of range!"
|
||||
#endif
|
||||
|
||||
#if (CHECK_RANGE(__CLKSO, __CLKSOMIN, __CLKSOMAX) != 0)
|
||||
#error "Sub Oscillator Clock (CLKMO) out of range!"
|
||||
#endif
|
||||
|
||||
#if (CHECK_RANGE((__CLKMO / __PLLK), __PLLCLKINMIN, __PLLCLKINMAX) != 0)
|
||||
#error "PLL input frequency out of range!"
|
||||
#endif
|
||||
|
||||
#if (CHECK_RANGE(((__CLKMO * __PLLN * __PLLM) / __PLLK), __PLLCLKMIN, __PLLCLKMAX) != 0)
|
||||
#error "PLL oscillation frequency out of range!"
|
||||
#endif
|
||||
|
||||
#if (CHECK_RANGE(__HCLK, 0, __HCLKMAX) != 0)
|
||||
#error "System Clock (HCLK) out of range!"
|
||||
#endif
|
||||
|
||||
/******************************************************************************/
|
||||
/* Global function prototypes ('extern', definition in C source) */
|
||||
/******************************************************************************/
|
||||
|
||||
extern uint32_t SystemCoreClock; // System Clock Frequency (Core Clock)
|
||||
|
||||
extern void SystemInit (void); // Initialize the system
|
||||
|
||||
extern void SystemCoreClockUpdate (void); // Update SystemCoreClock variable
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif /* __SYSTEM_MB9AF31X_H */
|
Loading…
Add table
Add a link
Reference in a new issue