aboutsummaryrefslogtreecommitdiff
path: root/lib/chibios-contrib/ext/mcux-sdk/devices/MK22F51212/system_MK22F51212.h
diff options
context:
space:
mode:
authorAkshay <[email protected]>2022-04-10 12:13:40 +0100
committerAkshay <[email protected]>2022-04-10 12:13:40 +0100
commitdc90387ce7d8ba7b607d9c48540bf6d8b560f14d (patch)
tree4ccb8fa5886b66fa9d480edef74236c27f035e16 /lib/chibios-contrib/ext/mcux-sdk/devices/MK22F51212/system_MK22F51212.h
Diffstat (limited to 'lib/chibios-contrib/ext/mcux-sdk/devices/MK22F51212/system_MK22F51212.h')
-rw-r--r--lib/chibios-contrib/ext/mcux-sdk/devices/MK22F51212/system_MK22F51212.h159
1 files changed, 159 insertions, 0 deletions
diff --git a/lib/chibios-contrib/ext/mcux-sdk/devices/MK22F51212/system_MK22F51212.h b/lib/chibios-contrib/ext/mcux-sdk/devices/MK22F51212/system_MK22F51212.h
new file mode 100644
index 000000000..43ac81a00
--- /dev/null
+++ b/lib/chibios-contrib/ext/mcux-sdk/devices/MK22F51212/system_MK22F51212.h
@@ -0,0 +1,159 @@
1/*
2** ###################################################################
3** Processors: MK22FN512CAP12
4** MK22FN512VDC12
5** MK22FN512VFX12
6** MK22FN512VLH12
7** MK22FN512VLL12
8** MK22FN512VMP12
9**
10** Compilers: Freescale C/C++ for Embedded ARM
11** GNU C Compiler
12** IAR ANSI C/C++ Compiler for ARM
13** Keil ARM C/C++ Compiler
14** MCUXpresso Compiler
15**
16** Reference manual: K22P121M120SF7RM, Rev. 1, March 24, 2014
17** Version: rev. 2.9, 2016-03-21
18** Build: b181105
19**
20** Abstract:
21** Provides a system configuration function and a global variable that
22** contains the system frequency. It configures the device and initializes
23** the oscillator (PLL) that is part of the microcontroller device.
24**
25** Copyright 2016 Freescale Semiconductor, Inc.
26** Copyright 2016-2018 NXP
27** All rights reserved.
28**
29** SPDX-License-Identifier: BSD-3-Clause
30**
31** http: www.nxp.com
32** mail: [email protected]
33**
34** Revisions:
35** - rev. 1.0 (2013-07-23)
36** Initial version.
37** - rev. 1.1 (2013-09-17)
38** RM rev. 0.4 update.
39** - rev. 2.0 (2013-10-29)
40** Register accessor macros added to the memory map.
41** Symbols for Processor Expert memory map compatibility added to the memory map.
42** Startup file for gcc has been updated according to CMSIS 3.2.
43** System initialization updated.
44** - rev. 2.1 (2013-10-30)
45** Definition of BITBAND macros updated to support peripherals with 32-bit acces disabled.
46** - rev. 2.2 (2013-12-20)
47** Update according to reference manual rev. 0.6,
48** - rev. 2.3 (2014-01-13)
49** Update according to reference manual rev. 0.61,
50** - rev. 2.4 (2014-02-10)
51** The declaration of clock configurations has been moved to separate header file system_MK22F51212.h
52** - rev. 2.5 (2014-05-06)
53** Update according to reference manual rev. 1.0,
54** Update of system and startup files.
55** Module access macro module_BASES replaced by module_BASE_PTRS.
56** - rev. 2.6 (2014-08-28)
57** Update of system files - default clock configuration changed.
58** Update of startup files - possibility to override DefaultISR added.
59** - rev. 2.7 (2014-10-14)
60** Interrupt INT_LPTimer renamed to INT_LPTMR0, interrupt INT_Watchdog renamed to INT_WDOG_EWM.
61** - rev. 2.8 (2015-02-19)
62** Renamed interrupt vector LLW to LLWU.
63** - rev. 2.9 (2016-03-21)
64** Added MK22FN512VFX12 part.
65** GPIO - renamed port instances: PTx -> GPIOx.
66**
67** ###################################################################
68*/
69
70/*!
71 * @file MK22F51212
72 * @version 2.9
73 * @date 2016-03-21
74 * @brief Device specific configuration file for MK22F51212 (header file)
75 *
76 * Provides a system configuration function and a global variable that contains
77 * the system frequency. It configures the device and initializes the oscillator
78 * (PLL) that is part of the microcontroller device.
79 */
80
81#ifndef _SYSTEM_MK22F51212_H_
82#define _SYSTEM_MK22F51212_H_ /**< Symbol preventing repeated inclusion */
83
84#ifdef __cplusplus
85extern "C" {
86#endif
87
88#include <stdint.h>
89
90
91#ifndef DISABLE_WDOG
92 #define DISABLE_WDOG 1
93#endif
94
95/* Define clock source values */
96
97#define CPU_XTAL_CLK_HZ 8000000u /* Value of the external crystal or oscillator clock frequency in Hz */
98#define CPU_XTAL32k_CLK_HZ 32768u /* Value of the external 32k crystal or oscillator clock frequency in Hz */
99#define CPU_INT_SLOW_CLK_HZ 32768u /* Value of the slow internal oscillator clock frequency in Hz */
100#define CPU_INT_FAST_CLK_HZ 4000000u /* Value of the fast internal oscillator clock frequency in Hz */
101#define CPU_INT_IRC_CLK_HZ 48000000u /* Value of the 48M internal oscillator clock frequency in Hz */
102
103/* RTC oscillator setting */
104/* RTC_CR: SC2P=0,SC4P=0,SC8P=0,SC16P=0,CLKO=1,OSCE=1,WPS=0,UM=0,SUP=0,WPE=0,SWR=0 */
105#define SYSTEM_RTC_CR_VALUE 0x0300U /* RTC_CR */
106
107/* Low power mode enable */
108/* SMC_PMPROT: AHSRUN=1,AVLP=1,ALLS=1,AVLLS=1 */
109#define SYSTEM_SMC_PMPROT_VALUE 0xAAU /* SMC_PMPROT */
110
111#define DEFAULT_SYSTEM_CLOCK 20971520u /* Default System clock value */
112
113
114/**
115 * @brief System clock frequency (core clock)
116 *
117 * The system clock frequency supplied to the SysTick timer and the processor
118 * core clock. This variable can be used by the user application to setup the
119 * SysTick timer or configure other parameters. It may also be used by debugger to
120 * query the frequency of the debug timer or configure the trace clock speed
121 * SystemCoreClock is initialized with a correct predefined value.
122 */
123extern uint32_t SystemCoreClock;
124
125/**
126 * @brief Setup the microcontroller system.
127 *
128 * Typically this function configures the oscillator (PLL) that is part of the
129 * microcontroller device. For systems with variable clock speed it also updates
130 * the variable SystemCoreClock. SystemInit is called from startup_device file.
131 */
132void SystemInit (void);
133
134/**
135 * @brief Updates the SystemCoreClock variable.
136 *
137 * It must be called whenever the core clock is changed during program
138 * execution. SystemCoreClockUpdate() evaluates the clock register settings and calculates
139 * the current core clock.
140 */
141void SystemCoreClockUpdate (void);
142
143/**
144 * @brief SystemInit function hook.
145 *
146 * This weak function allows to call specific initialization code during the
147 * SystemInit() execution.This can be used when an application specific code needs
148 * to be called as close to the reset entry as possible (for example the Multicore
149 * Manager MCMGR_EarlyInit() function call).
150 * NOTE: No global r/w variables can be used in this hook function because the
151 * initialization of these variables happens after this function.
152 */
153void SystemInitHook (void);
154
155#ifdef __cplusplus
156}
157#endif
158
159#endif /* _SYSTEM_MK22F51212_H_ */