Teensy 4.1 core updated for C++20
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 10 година
пре 10 година
пре 11 година
пре 10 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 9 година
пре 11 година
пре 11 година
пре 9 година
пре 11 година
пре 11 година
пре 9 година
пре 11 година
пре 9 година
пре 11 година
пре 10 година
пре 11 година
пре 11 година
пре 9 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 9 година
пре 11 година
пре 11 година
пре 9 година
пре 11 година
пре 10 година
пре 11 година
пре 9 година
пре 11 година
пре 11 година
пре 10 година
пре 11 година
пре 10 година
пре 10 година
пре 9 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 9 година
пре 11 година
пре 10 година
пре 9 година
пре 9 година
пре 11 година
пре 11 година
пре 11 година
пре 10 година
пре 11 година
пре 10 година
пре 11 година
пре 10 година
пре 7 година
пре 9 година
пре 11 година
пре 11 година
пре 11 година
пре 10 година
пре 11 година
пре 10 година
пре 11 година
пре 10 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 9 година
пре 8 година
пре 9 година
пре 10 година
пре 11 година
пре 9 година
пре 10 година
пре 11 година
пре 10 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 10 година
пре 11 година
пре 10 година
пре 11 година
пре 10 година
пре 9 година
пре 8 година
пре 9 година
пре 9 година
пре 9 година
пре 11 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 9 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
пре 11 година
пре 8 година
пре 10 година
пре 11 година
пре 10 година
пре 8 година
пре 10 година
пре 10 година
пре 11 година
пре 11 година
пре 10 година
пре 10 година
пре 11 година
пре 11 година
пре 11 година
пре 10 година
пре 10 година
пре 10 година
пре 10 година
пре 10 година
пре 10 година
пре 10 година
пре 10 година
пре 10 година
пре 10 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 11 година
пре 8 година
пре 8 година
пре 8 година
пре 8 година
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344
  1. /* Teensyduino Core Library
  2. * http://www.pjrc.com/teensy/
  3. * Copyright (c) 2017 PJRC.COM, LLC.
  4. *
  5. * Permission is hereby granted, free of charge, to any person obtaining
  6. * a copy of this software and associated documentation files (the
  7. * "Software"), to deal in the Software without restriction, including
  8. * without limitation the rights to use, copy, modify, merge, publish,
  9. * distribute, sublicense, and/or sell copies of the Software, and to
  10. * permit persons to whom the Software is furnished to do so, subject to
  11. * the following conditions:
  12. *
  13. * 1. The above copyright notice and this permission notice shall be
  14. * included in all copies or substantial portions of the Software.
  15. *
  16. * 2. If the Software is incorporated into a build system that allows
  17. * selection among a list of target devices, then similar target
  18. * devices manufactured by PJRC.COM must be included in the list of
  19. * target devices and selectable in the same manner.
  20. *
  21. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  22. * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  23. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  24. * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
  25. * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
  26. * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  27. * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  28. * SOFTWARE.
  29. */
  30. #include "kinetis.h"
  31. #include "core_pins.h" // testing only
  32. #include "ser_print.h" // testing only
  33. #include <errno.h>
  34. // Flash Security Setting. On Teensy 3.2, you can lock the MK20 chip to prevent
  35. // anyone from reading your code. You CAN still reprogram your Teensy while
  36. // security is set, but the bootloader will be unable to respond to auto-reboot
  37. // requests from Arduino. Pressing the program button will cause a full chip
  38. // erase to gain access, because the bootloader chip is locked out. Normally,
  39. // erase occurs when uploading begins, so if you press the Program button
  40. // accidentally, simply power cycling will run your program again. When
  41. // security is locked, any Program button press causes immediate full erase.
  42. // Special care must be used with the Program button, because it must be made
  43. // accessible to initiate reprogramming, but it must not be accidentally
  44. // pressed when Teensy Loader is not being used to reprogram. To set lock the
  45. // security change this to 0xDC. Teensy 3.0 and 3.1 do not support security lock.
  46. #define FSEC 0xDE
  47. // Flash Options
  48. #define FOPT 0xF9
  49. extern unsigned long _stext;
  50. extern unsigned long _etext;
  51. extern unsigned long _sdata;
  52. extern unsigned long _edata;
  53. extern unsigned long _sbss;
  54. extern unsigned long _ebss;
  55. extern unsigned long _estack;
  56. //extern void __init_array_start(void);
  57. //extern void __init_array_end(void);
  58. extern int main (void);
  59. void ResetHandler(void);
  60. void _init_Teensyduino_internal_(void) __attribute__((noinline));
  61. void __libc_init_array(void);
  62. void fault_isr(void)
  63. {
  64. #if 0
  65. uint32_t addr;
  66. SIM_SCGC4 |= 0x00000400;
  67. UART0_BDH = 0;
  68. UART0_BDL = 26; // 115200 at 48 MHz
  69. UART0_C2 = UART_C2_TE;
  70. PORTB_PCR17 = PORT_PCR_MUX(3);
  71. ser_print("\nfault: \n??: ");
  72. asm("ldr %0, [sp, #52]" : "=r" (addr) ::);
  73. ser_print_hex32(addr);
  74. ser_print("\n??: ");
  75. asm("ldr %0, [sp, #48]" : "=r" (addr) ::);
  76. ser_print_hex32(addr);
  77. ser_print("\n??: ");
  78. asm("ldr %0, [sp, #44]" : "=r" (addr) ::);
  79. ser_print_hex32(addr);
  80. ser_print("\npsr:");
  81. asm("ldr %0, [sp, #40]" : "=r" (addr) ::);
  82. ser_print_hex32(addr);
  83. ser_print("\nadr:");
  84. asm("ldr %0, [sp, #36]" : "=r" (addr) ::);
  85. ser_print_hex32(addr);
  86. ser_print("\nlr: ");
  87. asm("ldr %0, [sp, #32]" : "=r" (addr) ::);
  88. ser_print_hex32(addr);
  89. ser_print("\nr12:");
  90. asm("ldr %0, [sp, #28]" : "=r" (addr) ::);
  91. ser_print_hex32(addr);
  92. ser_print("\nr3: ");
  93. asm("ldr %0, [sp, #24]" : "=r" (addr) ::);
  94. ser_print_hex32(addr);
  95. ser_print("\nr2: ");
  96. asm("ldr %0, [sp, #20]" : "=r" (addr) ::);
  97. ser_print_hex32(addr);
  98. ser_print("\nr1: ");
  99. asm("ldr %0, [sp, #16]" : "=r" (addr) ::);
  100. ser_print_hex32(addr);
  101. ser_print("\nr0: ");
  102. asm("ldr %0, [sp, #12]" : "=r" (addr) ::);
  103. ser_print_hex32(addr);
  104. ser_print("\nr4: ");
  105. asm("ldr %0, [sp, #8]" : "=r" (addr) ::);
  106. ser_print_hex32(addr);
  107. ser_print("\nlr: ");
  108. asm("ldr %0, [sp, #4]" : "=r" (addr) ::);
  109. ser_print_hex32(addr);
  110. ser_print("\n");
  111. asm("ldr %0, [sp, #0]" : "=r" (addr) ::);
  112. #endif
  113. while (1) {
  114. // keep polling some communication while in fault
  115. // mode, so we don't completely die.
  116. if (SIM_SCGC4 & SIM_SCGC4_USBOTG) usb_isr();
  117. if (SIM_SCGC4 & SIM_SCGC4_UART0) uart0_status_isr();
  118. if (SIM_SCGC4 & SIM_SCGC4_UART1) uart1_status_isr();
  119. if (SIM_SCGC4 & SIM_SCGC4_UART2) uart2_status_isr();
  120. }
  121. }
  122. void unused_isr(void)
  123. {
  124. fault_isr();
  125. }
  126. extern volatile uint32_t systick_millis_count;
  127. void systick_default_isr(void)
  128. {
  129. systick_millis_count++;
  130. }
  131. void nmi_isr(void) __attribute__ ((weak, alias("unused_isr")));
  132. void hard_fault_isr(void) __attribute__ ((weak, alias("fault_isr")));
  133. void memmanage_fault_isr(void) __attribute__ ((weak, alias("fault_isr")));
  134. void bus_fault_isr(void) __attribute__ ((weak, alias("fault_isr")));
  135. void usage_fault_isr(void) __attribute__ ((weak, alias("fault_isr")));
  136. void svcall_isr(void) __attribute__ ((weak, alias("unused_isr")));
  137. void debugmonitor_isr(void) __attribute__ ((weak, alias("unused_isr")));
  138. void pendablesrvreq_isr(void) __attribute__ ((weak, alias("unused_isr")));
  139. void systick_isr(void) __attribute__ ((weak, alias("systick_default_isr")));
  140. void dma_ch0_isr(void) __attribute__ ((weak, alias("unused_isr")));
  141. void dma_ch1_isr(void) __attribute__ ((weak, alias("unused_isr")));
  142. void dma_ch2_isr(void) __attribute__ ((weak, alias("unused_isr")));
  143. void dma_ch3_isr(void) __attribute__ ((weak, alias("unused_isr")));
  144. void dma_ch4_isr(void) __attribute__ ((weak, alias("unused_isr")));
  145. void dma_ch5_isr(void) __attribute__ ((weak, alias("unused_isr")));
  146. void dma_ch6_isr(void) __attribute__ ((weak, alias("unused_isr")));
  147. void dma_ch7_isr(void) __attribute__ ((weak, alias("unused_isr")));
  148. void dma_ch8_isr(void) __attribute__ ((weak, alias("unused_isr")));
  149. void dma_ch9_isr(void) __attribute__ ((weak, alias("unused_isr")));
  150. void dma_ch10_isr(void) __attribute__ ((weak, alias("unused_isr")));
  151. void dma_ch11_isr(void) __attribute__ ((weak, alias("unused_isr")));
  152. void dma_ch12_isr(void) __attribute__ ((weak, alias("unused_isr")));
  153. void dma_ch13_isr(void) __attribute__ ((weak, alias("unused_isr")));
  154. void dma_ch14_isr(void) __attribute__ ((weak, alias("unused_isr")));
  155. void dma_ch15_isr(void) __attribute__ ((weak, alias("unused_isr")));
  156. void dma_error_isr(void) __attribute__ ((weak, alias("unused_isr")));
  157. void mcm_isr(void) __attribute__ ((weak, alias("unused_isr")));
  158. void randnum_isr(void) __attribute__ ((weak, alias("unused_isr")));
  159. void flash_cmd_isr(void) __attribute__ ((weak, alias("unused_isr")));
  160. void flash_error_isr(void) __attribute__ ((weak, alias("unused_isr")));
  161. void low_voltage_isr(void) __attribute__ ((weak, alias("unused_isr")));
  162. void wakeup_isr(void) __attribute__ ((weak, alias("unused_isr")));
  163. void watchdog_isr(void) __attribute__ ((weak, alias("unused_isr")));
  164. void i2c0_isr(void) __attribute__ ((weak, alias("unused_isr")));
  165. void i2c1_isr(void) __attribute__ ((weak, alias("unused_isr")));
  166. void i2c2_isr(void) __attribute__ ((weak, alias("unused_isr")));
  167. void i2c3_isr(void) __attribute__ ((weak, alias("unused_isr")));
  168. void spi0_isr(void) __attribute__ ((weak, alias("unused_isr")));
  169. void spi1_isr(void) __attribute__ ((weak, alias("unused_isr")));
  170. void spi2_isr(void) __attribute__ ((weak, alias("unused_isr")));
  171. void sdhc_isr(void) __attribute__ ((weak, alias("unused_isr")));
  172. void enet_timer_isr(void) __attribute__ ((weak, alias("unused_isr")));
  173. void enet_tx_isr(void) __attribute__ ((weak, alias("unused_isr")));
  174. void enet_rx_isr(void) __attribute__ ((weak, alias("unused_isr")));
  175. void enet_error_isr(void) __attribute__ ((weak, alias("unused_isr")));
  176. void can0_message_isr(void) __attribute__ ((weak, alias("unused_isr")));
  177. void can0_bus_off_isr(void) __attribute__ ((weak, alias("unused_isr")));
  178. void can0_error_isr(void) __attribute__ ((weak, alias("unused_isr")));
  179. void can0_tx_warn_isr(void) __attribute__ ((weak, alias("unused_isr")));
  180. void can0_rx_warn_isr(void) __attribute__ ((weak, alias("unused_isr")));
  181. void can0_wakeup_isr(void) __attribute__ ((weak, alias("unused_isr")));
  182. void can1_message_isr(void) __attribute__ ((weak, alias("unused_isr")));
  183. void can1_bus_off_isr(void) __attribute__ ((weak, alias("unused_isr")));
  184. void can1_error_isr(void) __attribute__ ((weak, alias("unused_isr")));
  185. void can1_tx_warn_isr(void) __attribute__ ((weak, alias("unused_isr")));
  186. void can1_rx_warn_isr(void) __attribute__ ((weak, alias("unused_isr")));
  187. void can1_wakeup_isr(void) __attribute__ ((weak, alias("unused_isr")));
  188. void i2s0_tx_isr(void) __attribute__ ((weak, alias("unused_isr")));
  189. void i2s0_rx_isr(void) __attribute__ ((weak, alias("unused_isr")));
  190. void i2s0_isr(void) __attribute__ ((weak, alias("unused_isr")));
  191. void uart0_lon_isr(void) __attribute__ ((weak, alias("unused_isr")));
  192. void uart0_status_isr(void) __attribute__ ((weak, alias("unused_isr")));
  193. void uart0_error_isr(void) __attribute__ ((weak, alias("unused_isr")));
  194. void uart1_status_isr(void) __attribute__ ((weak, alias("unused_isr")));
  195. void uart1_error_isr(void) __attribute__ ((weak, alias("unused_isr")));
  196. void uart2_status_isr(void) __attribute__ ((weak, alias("unused_isr")));
  197. void uart2_error_isr(void) __attribute__ ((weak, alias("unused_isr")));
  198. void uart3_status_isr(void) __attribute__ ((weak, alias("unused_isr")));
  199. void uart3_error_isr(void) __attribute__ ((weak, alias("unused_isr")));
  200. void uart4_status_isr(void) __attribute__ ((weak, alias("unused_isr")));
  201. void uart4_error_isr(void) __attribute__ ((weak, alias("unused_isr")));
  202. void uart5_status_isr(void) __attribute__ ((weak, alias("unused_isr")));
  203. void uart5_error_isr(void) __attribute__ ((weak, alias("unused_isr")));
  204. void lpuart0_status_isr(void) __attribute__ ((weak, alias("unused_isr")));
  205. void adc0_isr(void) __attribute__ ((weak, alias("unused_isr")));
  206. void adc1_isr(void) __attribute__ ((weak, alias("unused_isr")));
  207. void cmp0_isr(void) __attribute__ ((weak, alias("unused_isr")));
  208. void cmp1_isr(void) __attribute__ ((weak, alias("unused_isr")));
  209. void cmp2_isr(void) __attribute__ ((weak, alias("unused_isr")));
  210. void cmp3_isr(void) __attribute__ ((weak, alias("unused_isr")));
  211. void ftm0_isr(void) __attribute__ ((weak, alias("unused_isr")));
  212. void ftm1_isr(void) __attribute__ ((weak, alias("unused_isr")));
  213. void ftm2_isr(void) __attribute__ ((weak, alias("unused_isr")));
  214. void ftm3_isr(void) __attribute__ ((weak, alias("unused_isr")));
  215. void tpm0_isr(void) __attribute__ ((weak, alias("unused_isr")));
  216. void tpm1_isr(void) __attribute__ ((weak, alias("unused_isr")));
  217. void tpm2_isr(void) __attribute__ ((weak, alias("unused_isr")));
  218. void cmt_isr(void) __attribute__ ((weak, alias("unused_isr")));
  219. void rtc_alarm_isr(void) __attribute__ ((weak, alias("unused_isr")));
  220. void rtc_seconds_isr(void) __attribute__ ((weak, alias("unused_isr")));
  221. void pit_isr(void) __attribute__ ((weak, alias("unused_isr")));
  222. void pit0_isr(void) __attribute__ ((weak, alias("unused_isr")));
  223. void pit1_isr(void) __attribute__ ((weak, alias("unused_isr")));
  224. void pit2_isr(void) __attribute__ ((weak, alias("unused_isr")));
  225. void pit3_isr(void) __attribute__ ((weak, alias("unused_isr")));
  226. void pdb_isr(void) __attribute__ ((weak, alias("unused_isr")));
  227. void usb_isr(void) __attribute__ ((weak, alias("unused_isr")));
  228. void usb_charge_isr(void) __attribute__ ((weak, alias("unused_isr")));
  229. void usbhs_isr(void) __attribute__ ((weak, alias("unused_isr")));
  230. void usbhs_phy_isr(void) __attribute__ ((weak, alias("unused_isr")));
  231. void dac0_isr(void) __attribute__ ((weak, alias("unused_isr")));
  232. void dac1_isr(void) __attribute__ ((weak, alias("unused_isr")));
  233. void tsi0_isr(void) __attribute__ ((weak, alias("unused_isr")));
  234. void mcg_isr(void) __attribute__ ((weak, alias("unused_isr")));
  235. void lptmr_isr(void) __attribute__ ((weak, alias("unused_isr")));
  236. void porta_isr(void) __attribute__ ((weak, alias("unused_isr")));
  237. void portb_isr(void) __attribute__ ((weak, alias("unused_isr")));
  238. void portc_isr(void) __attribute__ ((weak, alias("unused_isr")));
  239. void portd_isr(void) __attribute__ ((weak, alias("unused_isr")));
  240. void porte_isr(void) __attribute__ ((weak, alias("unused_isr")));
  241. void portcd_isr(void) __attribute__ ((weak, alias("unused_isr")));
  242. void software_isr(void) __attribute__ ((weak, alias("unused_isr")));
  243. #if defined(__MK20DX128__)
  244. __attribute__ ((section(".dmabuffers"), used, aligned(256)))
  245. #elif defined(__MK20DX256__)
  246. __attribute__ ((section(".dmabuffers"), used, aligned(512)))
  247. #elif defined(__MKL26Z64__)
  248. __attribute__ ((section(".dmabuffers"), used, aligned(256)))
  249. #elif defined(__MK64FX512__)
  250. __attribute__ ((section(".dmabuffers"), used, aligned(512)))
  251. #elif defined(__MK66FX1M0__)
  252. __attribute__ ((section(".dmabuffers"), used, aligned(512)))
  253. #endif
  254. void (* _VectorsRam[NVIC_NUM_INTERRUPTS+16])(void);
  255. __attribute__ ((section(".vectors"), used))
  256. void (* const _VectorsFlash[NVIC_NUM_INTERRUPTS+16])(void) =
  257. {
  258. (void (*)(void))((unsigned long)&_estack), // 0 ARM: Initial Stack Pointer
  259. ResetHandler, // 1 ARM: Initial Program Counter
  260. nmi_isr, // 2 ARM: Non-maskable Interrupt (NMI)
  261. hard_fault_isr, // 3 ARM: Hard Fault
  262. memmanage_fault_isr, // 4 ARM: MemManage Fault
  263. bus_fault_isr, // 5 ARM: Bus Fault
  264. usage_fault_isr, // 6 ARM: Usage Fault
  265. fault_isr, // 7 --
  266. fault_isr, // 8 --
  267. fault_isr, // 9 --
  268. fault_isr, // 10 --
  269. svcall_isr, // 11 ARM: Supervisor call (SVCall)
  270. debugmonitor_isr, // 12 ARM: Debug Monitor
  271. fault_isr, // 13 --
  272. pendablesrvreq_isr, // 14 ARM: Pendable req serv(PendableSrvReq)
  273. systick_isr, // 15 ARM: System tick timer (SysTick)
  274. #if defined(__MK20DX128__)
  275. dma_ch0_isr, // 16 DMA channel 0 transfer complete
  276. dma_ch1_isr, // 17 DMA channel 1 transfer complete
  277. dma_ch2_isr, // 18 DMA channel 2 transfer complete
  278. dma_ch3_isr, // 19 DMA channel 3 transfer complete
  279. dma_error_isr, // 20 DMA error interrupt channel
  280. unused_isr, // 21 DMA --
  281. flash_cmd_isr, // 22 Flash Memory Command complete
  282. flash_error_isr, // 23 Flash Read collision
  283. low_voltage_isr, // 24 Low-voltage detect/warning
  284. wakeup_isr, // 25 Low Leakage Wakeup
  285. watchdog_isr, // 26 Both EWM and WDOG interrupt
  286. i2c0_isr, // 27 I2C0
  287. spi0_isr, // 28 SPI0
  288. i2s0_tx_isr, // 29 I2S0 Transmit
  289. i2s0_rx_isr, // 30 I2S0 Receive
  290. uart0_lon_isr, // 31 UART0 CEA709.1-B (LON) status
  291. uart0_status_isr, // 32 UART0 status
  292. uart0_error_isr, // 33 UART0 error
  293. uart1_status_isr, // 34 UART1 status
  294. uart1_error_isr, // 35 UART1 error
  295. uart2_status_isr, // 36 UART2 status
  296. uart2_error_isr, // 37 UART2 error
  297. adc0_isr, // 38 ADC0
  298. cmp0_isr, // 39 CMP0
  299. cmp1_isr, // 40 CMP1
  300. ftm0_isr, // 41 FTM0
  301. ftm1_isr, // 42 FTM1
  302. cmt_isr, // 43 CMT
  303. rtc_alarm_isr, // 44 RTC Alarm interrupt
  304. rtc_seconds_isr, // 45 RTC Seconds interrupt
  305. pit0_isr, // 46 PIT Channel 0
  306. pit1_isr, // 47 PIT Channel 1
  307. pit2_isr, // 48 PIT Channel 2
  308. pit3_isr, // 49 PIT Channel 3
  309. pdb_isr, // 50 PDB Programmable Delay Block
  310. usb_isr, // 51 USB OTG
  311. usb_charge_isr, // 52 USB Charger Detect
  312. tsi0_isr, // 53 TSI0
  313. mcg_isr, // 54 MCG
  314. lptmr_isr, // 55 Low Power Timer
  315. porta_isr, // 56 Pin detect (Port A)
  316. portb_isr, // 57 Pin detect (Port B)
  317. portc_isr, // 58 Pin detect (Port C)
  318. portd_isr, // 59 Pin detect (Port D)
  319. porte_isr, // 60 Pin detect (Port E)
  320. software_isr, // 61 Software interrupt
  321. #elif defined(__MK20DX256__)
  322. dma_ch0_isr, // 16 DMA channel 0 transfer complete
  323. dma_ch1_isr, // 17 DMA channel 1 transfer complete
  324. dma_ch2_isr, // 18 DMA channel 2 transfer complete
  325. dma_ch3_isr, // 19 DMA channel 3 transfer complete
  326. dma_ch4_isr, // 20 DMA channel 4 transfer complete
  327. dma_ch5_isr, // 21 DMA channel 5 transfer complete
  328. dma_ch6_isr, // 22 DMA channel 6 transfer complete
  329. dma_ch7_isr, // 23 DMA channel 7 transfer complete
  330. dma_ch8_isr, // 24 DMA channel 8 transfer complete
  331. dma_ch9_isr, // 25 DMA channel 9 transfer complete
  332. dma_ch10_isr, // 26 DMA channel 10 transfer complete
  333. dma_ch11_isr, // 27 DMA channel 11 transfer complete
  334. dma_ch12_isr, // 28 DMA channel 12 transfer complete
  335. dma_ch13_isr, // 29 DMA channel 13 transfer complete
  336. dma_ch14_isr, // 30 DMA channel 14 transfer complete
  337. dma_ch15_isr, // 31 DMA channel 15 transfer complete
  338. dma_error_isr, // 32 DMA error interrupt channel
  339. unused_isr, // 33 --
  340. flash_cmd_isr, // 34 Flash Memory Command complete
  341. flash_error_isr, // 35 Flash Read collision
  342. low_voltage_isr, // 36 Low-voltage detect/warning
  343. wakeup_isr, // 37 Low Leakage Wakeup
  344. watchdog_isr, // 38 Both EWM and WDOG interrupt
  345. unused_isr, // 39 --
  346. i2c0_isr, // 40 I2C0
  347. i2c1_isr, // 41 I2C1
  348. spi0_isr, // 42 SPI0
  349. spi1_isr, // 43 SPI1
  350. unused_isr, // 44 --
  351. can0_message_isr, // 45 CAN OR'ed Message buffer (0-15)
  352. can0_bus_off_isr, // 46 CAN Bus Off
  353. can0_error_isr, // 47 CAN Error
  354. can0_tx_warn_isr, // 48 CAN Transmit Warning
  355. can0_rx_warn_isr, // 49 CAN Receive Warning
  356. can0_wakeup_isr, // 50 CAN Wake Up
  357. i2s0_tx_isr, // 51 I2S0 Transmit
  358. i2s0_rx_isr, // 52 I2S0 Receive
  359. unused_isr, // 53 --
  360. unused_isr, // 54 --
  361. unused_isr, // 55 --
  362. unused_isr, // 56 --
  363. unused_isr, // 57 --
  364. unused_isr, // 58 --
  365. unused_isr, // 59 --
  366. uart0_lon_isr, // 60 UART0 CEA709.1-B (LON) status
  367. uart0_status_isr, // 61 UART0 status
  368. uart0_error_isr, // 62 UART0 error
  369. uart1_status_isr, // 63 UART1 status
  370. uart1_error_isr, // 64 UART1 error
  371. uart2_status_isr, // 65 UART2 status
  372. uart2_error_isr, // 66 UART2 error
  373. unused_isr, // 67 --
  374. unused_isr, // 68 --
  375. unused_isr, // 69 --
  376. unused_isr, // 70 --
  377. unused_isr, // 71 --
  378. unused_isr, // 72 --
  379. adc0_isr, // 73 ADC0
  380. adc1_isr, // 74 ADC1
  381. cmp0_isr, // 75 CMP0
  382. cmp1_isr, // 76 CMP1
  383. cmp2_isr, // 77 CMP2
  384. ftm0_isr, // 78 FTM0
  385. ftm1_isr, // 79 FTM1
  386. ftm2_isr, // 80 FTM2
  387. cmt_isr, // 81 CMT
  388. rtc_alarm_isr, // 82 RTC Alarm interrupt
  389. rtc_seconds_isr, // 83 RTC Seconds interrupt
  390. pit0_isr, // 84 PIT Channel 0
  391. pit1_isr, // 85 PIT Channel 1
  392. pit2_isr, // 86 PIT Channel 2
  393. pit3_isr, // 87 PIT Channel 3
  394. pdb_isr, // 88 PDB Programmable Delay Block
  395. usb_isr, // 89 USB OTG
  396. usb_charge_isr, // 90 USB Charger Detect
  397. unused_isr, // 91 --
  398. unused_isr, // 92 --
  399. unused_isr, // 93 --
  400. unused_isr, // 94 --
  401. unused_isr, // 95 --
  402. unused_isr, // 96 --
  403. dac0_isr, // 97 DAC0
  404. unused_isr, // 98 --
  405. tsi0_isr, // 99 TSI0
  406. mcg_isr, // 100 MCG
  407. lptmr_isr, // 101 Low Power Timer
  408. unused_isr, // 102 --
  409. porta_isr, // 103 Pin detect (Port A)
  410. portb_isr, // 104 Pin detect (Port B)
  411. portc_isr, // 105 Pin detect (Port C)
  412. portd_isr, // 106 Pin detect (Port D)
  413. porte_isr, // 107 Pin detect (Port E)
  414. unused_isr, // 108 --
  415. unused_isr, // 109 --
  416. software_isr, // 110 Software interrupt
  417. #elif defined(__MKL26Z64__)
  418. dma_ch0_isr, // 16 DMA channel 0 transfer complete
  419. dma_ch1_isr, // 17 DMA channel 1 transfer complete
  420. dma_ch2_isr, // 18 DMA channel 2 transfer complete
  421. dma_ch3_isr, // 19 DMA channel 3 transfer complete
  422. unused_isr, // 20 --
  423. flash_cmd_isr, // 21 Flash Memory Command complete
  424. low_voltage_isr, // 22 Low-voltage detect/warning
  425. wakeup_isr, // 23 Low Leakage Wakeup
  426. i2c0_isr, // 24 I2C0
  427. i2c1_isr, // 25 I2C1
  428. spi0_isr, // 26 SPI0
  429. spi1_isr, // 27 SPI1
  430. uart0_status_isr, // 28 UART0 status & error
  431. uart1_status_isr, // 29 UART1 status & error
  432. uart2_status_isr, // 30 UART2 status & error
  433. adc0_isr, // 31 ADC0
  434. cmp0_isr, // 32 CMP0
  435. ftm0_isr, // 33 FTM0
  436. ftm1_isr, // 34 FTM1
  437. ftm2_isr, // 35 FTM2
  438. rtc_alarm_isr, // 36 RTC Alarm interrupt
  439. rtc_seconds_isr, // 37 RTC Seconds interrupt
  440. pit_isr, // 38 PIT Both Channels
  441. i2s0_isr, // 39 I2S0 Transmit & Receive
  442. usb_isr, // 40 USB OTG
  443. dac0_isr, // 41 DAC0
  444. tsi0_isr, // 42 TSI0
  445. mcg_isr, // 43 MCG
  446. lptmr_isr, // 44 Low Power Timer
  447. software_isr, // 45 Software interrupt
  448. porta_isr, // 46 Pin detect (Port A)
  449. portcd_isr, // 47 Pin detect (Port C and D)
  450. #elif defined(__MK64FX512__)
  451. dma_ch0_isr, // 16 DMA channel 0 transfer complete
  452. dma_ch1_isr, // 17 DMA channel 1 transfer complete
  453. dma_ch2_isr, // 18 DMA channel 2 transfer complete
  454. dma_ch3_isr, // 19 DMA channel 3 transfer complete
  455. dma_ch4_isr, // 20 DMA channel 4 transfer complete
  456. dma_ch5_isr, // 21 DMA channel 5 transfer complete
  457. dma_ch6_isr, // 22 DMA channel 6 transfer complete
  458. dma_ch7_isr, // 23 DMA channel 7 transfer complete
  459. dma_ch8_isr, // 24 DMA channel 8 transfer complete
  460. dma_ch9_isr, // 25 DMA channel 9 transfer complete
  461. dma_ch10_isr, // 26 DMA channel 10 transfer complete
  462. dma_ch11_isr, // 27 DMA channel 11 transfer complete
  463. dma_ch12_isr, // 28 DMA channel 12 transfer complete
  464. dma_ch13_isr, // 29 DMA channel 13 transfer complete
  465. dma_ch14_isr, // 30 DMA channel 14 transfer complete
  466. dma_ch15_isr, // 31 DMA channel 15 transfer complete
  467. dma_error_isr, // 32 DMA error interrupt channel
  468. mcm_isr, // 33 MCM
  469. flash_cmd_isr, // 34 Flash Memory Command complete
  470. flash_error_isr, // 35 Flash Read collision
  471. low_voltage_isr, // 36 Low-voltage detect/warning
  472. wakeup_isr, // 37 Low Leakage Wakeup
  473. watchdog_isr, // 38 Both EWM and WDOG interrupt
  474. randnum_isr, // 39 Random Number Generator
  475. i2c0_isr, // 40 I2C0
  476. i2c1_isr, // 41 I2C1
  477. spi0_isr, // 42 SPI0
  478. spi1_isr, // 43 SPI1
  479. i2s0_tx_isr, // 44 I2S0 Transmit
  480. i2s0_rx_isr, // 45 I2S0 Receive
  481. unused_isr, // 46 --
  482. uart0_status_isr, // 47 UART0 status
  483. uart0_error_isr, // 48 UART0 error
  484. uart1_status_isr, // 49 UART1 status
  485. uart1_error_isr, // 50 UART1 error
  486. uart2_status_isr, // 51 UART2 status
  487. uart2_error_isr, // 52 UART2 error
  488. uart3_status_isr, // 53 UART3 status
  489. uart3_error_isr, // 54 UART3 error
  490. adc0_isr, // 55 ADC0
  491. cmp0_isr, // 56 CMP0
  492. cmp1_isr, // 57 CMP1
  493. ftm0_isr, // 58 FTM0
  494. ftm1_isr, // 59 FTM1
  495. ftm2_isr, // 60 FTM2
  496. cmt_isr, // 61 CMT
  497. rtc_alarm_isr, // 62 RTC Alarm interrupt
  498. rtc_seconds_isr, // 63 RTC Seconds interrupt
  499. pit0_isr, // 64 PIT Channel 0
  500. pit1_isr, // 65 PIT Channel 1
  501. pit2_isr, // 66 PIT Channel 2
  502. pit3_isr, // 67 PIT Channel 3
  503. pdb_isr, // 68 PDB Programmable Delay Block
  504. usb_isr, // 69 USB OTG
  505. usb_charge_isr, // 70 USB Charger Detect
  506. unused_isr, // 71 --
  507. dac0_isr, // 72 DAC0
  508. mcg_isr, // 73 MCG
  509. lptmr_isr, // 74 Low Power Timer
  510. porta_isr, // 75 Pin detect (Port A)
  511. portb_isr, // 76 Pin detect (Port B)
  512. portc_isr, // 77 Pin detect (Port C)
  513. portd_isr, // 78 Pin detect (Port D)
  514. porte_isr, // 79 Pin detect (Port E)
  515. software_isr, // 80 Software interrupt
  516. spi2_isr, // 81 SPI2
  517. uart4_status_isr, // 82 UART4 status
  518. uart4_error_isr, // 83 UART4 error
  519. uart5_status_isr, // 84 UART4 status
  520. uart5_error_isr, // 85 UART4 error
  521. cmp2_isr, // 86 CMP2
  522. ftm3_isr, // 87 FTM3
  523. dac1_isr, // 88 DAC1
  524. adc1_isr, // 89 ADC1
  525. i2c2_isr, // 90 I2C2
  526. can0_message_isr, // 91 CAN OR'ed Message buffer (0-15)
  527. can0_bus_off_isr, // 92 CAN Bus Off
  528. can0_error_isr, // 93 CAN Error
  529. can0_tx_warn_isr, // 94 CAN Transmit Warning
  530. can0_rx_warn_isr, // 95 CAN Receive Warning
  531. can0_wakeup_isr, // 96 CAN Wake Up
  532. sdhc_isr, // 97 SDHC
  533. enet_timer_isr, // 98 Ethernet IEEE1588 Timers
  534. enet_tx_isr, // 99 Ethernet Transmit
  535. enet_rx_isr, // 100 Ethernet Receive
  536. enet_error_isr, // 101 Ethernet Error
  537. #elif defined(__MK66FX1M0__)
  538. dma_ch0_isr, // 16 DMA channel 0 transfer complete
  539. dma_ch1_isr, // 17 DMA channel 1 transfer complete
  540. dma_ch2_isr, // 18 DMA channel 2 transfer complete
  541. dma_ch3_isr, // 19 DMA channel 3 transfer complete
  542. dma_ch4_isr, // 20 DMA channel 4 transfer complete
  543. dma_ch5_isr, // 21 DMA channel 5 transfer complete
  544. dma_ch6_isr, // 22 DMA channel 6 transfer complete
  545. dma_ch7_isr, // 23 DMA channel 7 transfer complete
  546. dma_ch8_isr, // 24 DMA channel 8 transfer complete
  547. dma_ch9_isr, // 25 DMA channel 9 transfer complete
  548. dma_ch10_isr, // 26 DMA channel 10 transfer complete
  549. dma_ch11_isr, // 27 DMA channel 11 transfer complete
  550. dma_ch12_isr, // 28 DMA channel 12 transfer complete
  551. dma_ch13_isr, // 29 DMA channel 13 transfer complete
  552. dma_ch14_isr, // 30 DMA channel 14 transfer complete
  553. dma_ch15_isr, // 31 DMA channel 15 transfer complete
  554. dma_error_isr, // 32 DMA error interrupt channel
  555. mcm_isr, // 33 MCM
  556. flash_cmd_isr, // 34 Flash Memory Command complete
  557. flash_error_isr, // 35 Flash Read collision
  558. low_voltage_isr, // 36 Low-voltage detect/warning
  559. wakeup_isr, // 37 Low Leakage Wakeup
  560. watchdog_isr, // 38 Both EWM and WDOG interrupt
  561. randnum_isr, // 39 Random Number Generator
  562. i2c0_isr, // 40 I2C0
  563. i2c1_isr, // 41 I2C1
  564. spi0_isr, // 42 SPI0
  565. spi1_isr, // 43 SPI1
  566. i2s0_tx_isr, // 44 I2S0 Transmit
  567. i2s0_rx_isr, // 45 I2S0 Receive
  568. unused_isr, // 46 --
  569. uart0_status_isr, // 47 UART0 status
  570. uart0_error_isr, // 48 UART0 error
  571. uart1_status_isr, // 49 UART1 status
  572. uart1_error_isr, // 50 UART1 error
  573. uart2_status_isr, // 51 UART2 status
  574. uart2_error_isr, // 52 UART2 error
  575. uart3_status_isr, // 53 UART3 status
  576. uart3_error_isr, // 54 UART3 error
  577. adc0_isr, // 55 ADC0
  578. cmp0_isr, // 56 CMP0
  579. cmp1_isr, // 57 CMP1
  580. ftm0_isr, // 58 FTM0
  581. ftm1_isr, // 59 FTM1
  582. ftm2_isr, // 60 FTM2
  583. cmt_isr, // 61 CMT
  584. rtc_alarm_isr, // 62 RTC Alarm interrupt
  585. rtc_seconds_isr, // 63 RTC Seconds interrupt
  586. pit0_isr, // 64 PIT Channel 0
  587. pit1_isr, // 65 PIT Channel 1
  588. pit2_isr, // 66 PIT Channel 2
  589. pit3_isr, // 67 PIT Channel 3
  590. pdb_isr, // 68 PDB Programmable Delay Block
  591. usb_isr, // 69 USB OTG
  592. usb_charge_isr, // 70 USB Charger Detect
  593. unused_isr, // 71 --
  594. dac0_isr, // 72 DAC0
  595. mcg_isr, // 73 MCG
  596. lptmr_isr, // 74 Low Power Timer
  597. porta_isr, // 75 Pin detect (Port A)
  598. portb_isr, // 76 Pin detect (Port B)
  599. portc_isr, // 77 Pin detect (Port C)
  600. portd_isr, // 78 Pin detect (Port D)
  601. porte_isr, // 79 Pin detect (Port E)
  602. software_isr, // 80 Software interrupt
  603. spi2_isr, // 81 SPI2
  604. uart4_status_isr, // 82 UART4 status
  605. uart4_error_isr, // 83 UART4 error
  606. unused_isr, // 84 --
  607. unused_isr, // 85 --
  608. cmp2_isr, // 86 CMP2
  609. ftm3_isr, // 87 FTM3
  610. dac1_isr, // 88 DAC1
  611. adc1_isr, // 89 ADC1
  612. i2c2_isr, // 90 I2C2
  613. can0_message_isr, // 91 CAN OR'ed Message buffer (0-15)
  614. can0_bus_off_isr, // 92 CAN Bus Off
  615. can0_error_isr, // 93 CAN Error
  616. can0_tx_warn_isr, // 94 CAN Transmit Warning
  617. can0_rx_warn_isr, // 95 CAN Receive Warning
  618. can0_wakeup_isr, // 96 CAN Wake Up
  619. sdhc_isr, // 97 SDHC
  620. enet_timer_isr, // 98 Ethernet IEEE1588 Timers
  621. enet_tx_isr, // 99 Ethernet Transmit
  622. enet_rx_isr, // 100 Ethernet Receive
  623. enet_error_isr, // 101 Ethernet Error
  624. lpuart0_status_isr, // 102 LPUART
  625. tsi0_isr, // 103 TSI0
  626. tpm1_isr, // 104 FTM1
  627. tpm2_isr, // 105 FTM2
  628. usbhs_phy_isr, // 106 USB-HS Phy
  629. i2c3_isr, // 107 I2C3
  630. cmp3_isr, // 108 CMP3
  631. usbhs_isr, // 109 USB-HS
  632. can1_message_isr, // 110 CAN OR'ed Message buffer (0-15)
  633. can1_bus_off_isr, // 111 CAN Bus Off
  634. can1_error_isr, // 112 CAN Error
  635. can1_tx_warn_isr, // 113 CAN Transmit Warning
  636. can1_rx_warn_isr, // 114 CAN Receive Warning
  637. can1_wakeup_isr, // 115 CAN Wake Up
  638. #endif
  639. };
  640. __attribute__ ((section(".flashconfig"), used))
  641. const uint8_t flashconfigbytes[16] = {
  642. 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,
  643. 0xFF, 0xFF, 0xFF, 0xFF, FSEC, FOPT, 0xFF, 0xFF
  644. };
  645. // Automatically initialize the RTC. When the build defines the compile
  646. // time, and the user has added a crystal, the RTC will automatically
  647. // begin at the time of the first upload.
  648. #ifndef TIME_T
  649. #define TIME_T 1349049600 // default 1 Oct 2012 (never used, Arduino sets this)
  650. #endif
  651. extern void *__rtc_localtime; // Arduino build process sets this
  652. extern void rtc_set(unsigned long t);
  653. static void startup_default_early_hook(void) {
  654. #if defined(KINETISK)
  655. WDOG_STCTRLH = WDOG_STCTRLH_ALLOWUPDATE;
  656. #elif defined(KINETISL)
  657. SIM_COPC = 0; // disable the watchdog
  658. #endif
  659. }
  660. static void startup_default_late_hook(void) {}
  661. void startup_early_hook(void) __attribute__ ((weak, alias("startup_default_early_hook")));
  662. void startup_late_hook(void) __attribute__ ((weak, alias("startup_default_late_hook")));
  663. #if defined(__PURE_CODE__) || !defined(__OPTIMIZE__) || defined(__clang__)
  664. // cases known to compile too large for 0-0x400 memory region
  665. __attribute__ ((optimize("-Os")))
  666. #else
  667. // hopefully all others fit into startup section (below 0x400)
  668. __attribute__ ((section(".startup"),optimize("-Os")))
  669. #endif
  670. void ResetHandler(void)
  671. {
  672. uint32_t *src = &_etext;
  673. uint32_t *dest = &_sdata;
  674. unsigned int i;
  675. #if F_CPU <= 2000000
  676. volatile int n;
  677. #endif
  678. //volatile int count;
  679. #ifdef KINETISK
  680. WDOG_UNLOCK = WDOG_UNLOCK_SEQ1;
  681. WDOG_UNLOCK = WDOG_UNLOCK_SEQ2;
  682. __asm__ volatile ("nop");
  683. __asm__ volatile ("nop");
  684. #endif
  685. // programs using the watchdog timer or needing to initialize hardware as
  686. // early as possible can implement startup_early_hook()
  687. startup_early_hook();
  688. // enable clocks to always-used peripherals
  689. #if defined(__MK20DX128__)
  690. SIM_SCGC5 = 0x00043F82; // clocks active to all GPIO
  691. SIM_SCGC6 = SIM_SCGC6_RTC | SIM_SCGC6_FTM0 | SIM_SCGC6_FTM1 | SIM_SCGC6_ADC0 | SIM_SCGC6_FTFL;
  692. #elif defined(__MK20DX256__)
  693. SIM_SCGC3 = SIM_SCGC3_ADC1 | SIM_SCGC3_FTM2;
  694. SIM_SCGC5 = 0x00043F82; // clocks active to all GPIO
  695. SIM_SCGC6 = SIM_SCGC6_RTC | SIM_SCGC6_FTM0 | SIM_SCGC6_FTM1 | SIM_SCGC6_ADC0 | SIM_SCGC6_FTFL;
  696. #elif defined(__MK64FX512__) || defined(__MK66FX1M0__)
  697. SIM_SCGC3 = SIM_SCGC3_ADC1 | SIM_SCGC3_FTM2 | SIM_SCGC3_FTM3;
  698. SIM_SCGC5 = 0x00043F82; // clocks active to all GPIO
  699. SIM_SCGC6 = SIM_SCGC6_RTC | SIM_SCGC6_FTM0 | SIM_SCGC6_FTM1 | SIM_SCGC6_ADC0 | SIM_SCGC6_FTFL;
  700. //PORTC_PCR5 = PORT_PCR_MUX(1) | PORT_PCR_DSE | PORT_PCR_SRE;
  701. //GPIOC_PDDR |= (1<<5);
  702. //GPIOC_PSOR = (1<<5);
  703. //while (1);
  704. #elif defined(__MKL26Z64__)
  705. SIM_SCGC4 = SIM_SCGC4_USBOTG | 0xF0000030;
  706. SIM_SCGC5 = 0x00003F82; // clocks active to all GPIO
  707. SIM_SCGC6 = SIM_SCGC6_ADC0 | SIM_SCGC6_TPM0 | SIM_SCGC6_TPM1 | SIM_SCGC6_TPM2 | SIM_SCGC6_FTFL;
  708. #endif
  709. #if defined(__MK64FX512__) || defined(__MK66FX1M0__)
  710. SCB_CPACR = 0x00F00000;
  711. #endif
  712. #if defined(__MK66FX1M0__)
  713. LMEM_PCCCR = 0x85000003;
  714. #endif
  715. #if 0
  716. // testing only, enable ser_print
  717. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV4(1);
  718. MCG_C4 |= MCG_C4_DMX32 | MCG_C4_DRST_DRS(1);
  719. SIM_SOPT2 = SIM_SOPT2_UART0SRC(1) | SIM_SOPT2_TPMSRC(1);
  720. SIM_SCGC4 |= 0x00000400;
  721. UART0_BDH = 0;
  722. UART0_BDL = 26; // 115200 at 48 MHz
  723. UART0_C2 = UART_C2_TE;
  724. PORTB_PCR17 = PORT_PCR_MUX(3);
  725. #endif
  726. #ifdef KINETISK
  727. // if the RTC oscillator isn't enabled, get it started early
  728. if (!(RTC_CR & RTC_CR_OSCE)) {
  729. RTC_SR = 0;
  730. RTC_CR = RTC_CR_SC16P | RTC_CR_SC4P | RTC_CR_OSCE;
  731. }
  732. #endif
  733. // release I/O pins hold, if we woke up from VLLS mode
  734. if (PMC_REGSC & PMC_REGSC_ACKISO) PMC_REGSC |= PMC_REGSC_ACKISO;
  735. // since this is a write once register, make it visible to all F_CPU's
  736. // so we can into other sleep modes in the future at any speed
  737. #if defined(__MK66FX1M0__)
  738. SMC_PMPROT = SMC_PMPROT_AHSRUN | SMC_PMPROT_AVLP | SMC_PMPROT_ALLS | SMC_PMPROT_AVLLS;
  739. #else
  740. SMC_PMPROT = SMC_PMPROT_AVLP | SMC_PMPROT_ALLS | SMC_PMPROT_AVLLS;
  741. #endif
  742. // TODO: do this while the PLL is waiting to lock....
  743. while (dest < &_edata) *dest++ = *src++;
  744. dest = &_sbss;
  745. while (dest < &_ebss) *dest++ = 0;
  746. // default all interrupts to medium priority level
  747. for (i=0; i < NVIC_NUM_INTERRUPTS + 16; i++) _VectorsRam[i] = _VectorsFlash[i];
  748. for (i=0; i < NVIC_NUM_INTERRUPTS; i++) NVIC_SET_PRIORITY(i, 128);
  749. SCB_VTOR = (uint32_t)_VectorsRam; // use vector table in RAM
  750. // hardware always starts in FEI mode
  751. // C1[CLKS] bits are written to 00
  752. // C1[IREFS] bit is written to 1
  753. // C6[PLLS] bit is written to 0
  754. // MCG_SC[FCDIV] defaults to divide by two for internal ref clock
  755. // I tried changing MSG_SC to divide by 1, it didn't work for me
  756. #if F_CPU <= 2000000
  757. #if defined(KINETISK)
  758. MCG_C1 = MCG_C1_CLKS(1) | MCG_C1_IREFS;
  759. #elif defined(KINETISL)
  760. // use the internal oscillator
  761. MCG_C1 = MCG_C1_CLKS(1) | MCG_C1_IREFS | MCG_C1_IRCLKEN;
  762. #endif
  763. // wait for MCGOUT to use oscillator
  764. while ((MCG_S & MCG_S_CLKST_MASK) != MCG_S_CLKST(1)) ;
  765. for (n=0; n<10; n++) ; // TODO: why do we get 2 mA extra without this delay?
  766. MCG_C2 = MCG_C2_IRCS;
  767. while (!(MCG_S & MCG_S_IRCST)) ;
  768. // now in FBI mode:
  769. // C1[CLKS] bits are written to 01
  770. // C1[IREFS] bit is written to 1
  771. // C6[PLLS] is written to 0
  772. // C2[LP] is written to 0
  773. MCG_C2 = MCG_C2_IRCS | MCG_C2_LP;
  774. // now in BLPI mode:
  775. // C1[CLKS] bits are written to 01
  776. // C1[IREFS] bit is written to 1
  777. // C6[PLLS] bit is written to 0
  778. // C2[LP] bit is written to 1
  779. #else
  780. #if defined(KINETISK)
  781. // enable capacitors for crystal
  782. OSC0_CR = OSC_SC8P | OSC_SC2P | OSC_ERCLKEN;
  783. #elif defined(KINETISL)
  784. // enable capacitors for crystal
  785. OSC0_CR = OSC_SC8P | OSC_SC2P | OSC_ERCLKEN;
  786. #endif
  787. // enable osc, 8-32 MHz range, low power mode
  788. MCG_C2 = MCG_C2_RANGE0(2) | MCG_C2_EREFS;
  789. // switch to crystal as clock source, FLL input = 16 MHz / 512
  790. MCG_C1 = MCG_C1_CLKS(2) | MCG_C1_FRDIV(4);
  791. // wait for crystal oscillator to begin
  792. while ((MCG_S & MCG_S_OSCINIT0) == 0) ;
  793. // wait for FLL to use oscillator
  794. while ((MCG_S & MCG_S_IREFST) != 0) ;
  795. // wait for MCGOUT to use oscillator
  796. while ((MCG_S & MCG_S_CLKST_MASK) != MCG_S_CLKST(2)) ;
  797. // now in FBE mode
  798. // C1[CLKS] bits are written to 10
  799. // C1[IREFS] bit is written to 0
  800. // C1[FRDIV] must be written to divide xtal to 31.25-39 kHz
  801. // C6[PLLS] bit is written to 0
  802. // C2[LP] is written to 0
  803. #if F_CPU <= 16000000
  804. // if the crystal is fast enough, use it directly (no FLL or PLL)
  805. MCG_C2 = MCG_C2_RANGE0(2) | MCG_C2_EREFS | MCG_C2_LP;
  806. // BLPE mode:
  807. // C1[CLKS] bits are written to 10
  808. // C1[IREFS] bit is written to 0
  809. // C2[LP] bit is written to 1
  810. #else
  811. // if we need faster than the crystal, turn on the PLL
  812. #if defined(__MK66FX1M0__)
  813. #if F_CPU > 120000000
  814. SMC_PMCTRL = SMC_PMCTRL_RUNM(3); // enter HSRUN mode
  815. while (SMC_PMSTAT != SMC_PMSTAT_HSRUN) ; // wait for HSRUN
  816. #endif
  817. #if F_CPU == 240000000
  818. MCG_C5 = MCG_C5_PRDIV0(0);
  819. MCG_C6 = MCG_C6_PLLS | MCG_C6_VDIV0(14);
  820. #elif F_CPU == 216000000
  821. MCG_C5 = MCG_C5_PRDIV0(0);
  822. MCG_C6 = MCG_C6_PLLS | MCG_C6_VDIV0(11);
  823. #elif F_CPU == 192000000
  824. MCG_C5 = MCG_C5_PRDIV0(0);
  825. MCG_C6 = MCG_C6_PLLS | MCG_C6_VDIV0(8);
  826. #elif F_CPU == 180000000
  827. MCG_C5 = MCG_C5_PRDIV0(1);
  828. MCG_C6 = MCG_C6_PLLS | MCG_C6_VDIV0(29);
  829. #elif F_CPU == 168000000
  830. MCG_C5 = MCG_C5_PRDIV0(0);
  831. MCG_C6 = MCG_C6_PLLS | MCG_C6_VDIV0(5);
  832. #elif F_CPU == 144000000
  833. MCG_C5 = MCG_C5_PRDIV0(0);
  834. MCG_C6 = MCG_C6_PLLS | MCG_C6_VDIV0(2);
  835. #elif F_CPU == 120000000
  836. MCG_C5 = MCG_C5_PRDIV0(1);
  837. MCG_C6 = MCG_C6_PLLS | MCG_C6_VDIV0(14);
  838. #elif F_CPU == 96000000 || F_CPU == 48000000 || F_CPU == 24000000
  839. MCG_C5 = MCG_C5_PRDIV0(1);
  840. MCG_C6 = MCG_C6_PLLS | MCG_C6_VDIV0(8);
  841. #elif F_CPU == 72000000
  842. MCG_C5 = MCG_C5_PRDIV0(1);
  843. MCG_C6 = MCG_C6_PLLS | MCG_C6_VDIV0(2);
  844. #elif F_CPU > 16000000
  845. #error "MK66FX1M0 does not support this clock speed yet...."
  846. #endif
  847. #else
  848. #if F_CPU == 72000000
  849. MCG_C5 = MCG_C5_PRDIV0(5); // config PLL input for 16 MHz Crystal / 6 = 2.667 Hz
  850. #else
  851. MCG_C5 = MCG_C5_PRDIV0(3); // config PLL input for 16 MHz Crystal / 4 = 4 MHz
  852. #endif
  853. #if F_CPU == 168000000
  854. MCG_C6 = MCG_C6_PLLS | MCG_C6_VDIV0(18); // config PLL for 168 MHz output
  855. #elif F_CPU == 144000000
  856. MCG_C6 = MCG_C6_PLLS | MCG_C6_VDIV0(12); // config PLL for 144 MHz output
  857. #elif F_CPU == 120000000
  858. MCG_C6 = MCG_C6_PLLS | MCG_C6_VDIV0(6); // config PLL for 120 MHz output
  859. #elif F_CPU == 72000000
  860. MCG_C6 = MCG_C6_PLLS | MCG_C6_VDIV0(3); // config PLL for 72 MHz output
  861. #elif F_CPU == 96000000 || F_CPU == 48000000 || F_CPU == 24000000
  862. MCG_C6 = MCG_C6_PLLS | MCG_C6_VDIV0(0); // config PLL for 96 MHz output
  863. #elif F_CPU > 16000000
  864. #error "This clock speed isn't supported..."
  865. #endif
  866. #endif
  867. // wait for PLL to start using xtal as its input
  868. while (!(MCG_S & MCG_S_PLLST)) ;
  869. // wait for PLL to lock
  870. while (!(MCG_S & MCG_S_LOCK0)) ;
  871. // now we're in PBE mode
  872. #endif
  873. #endif
  874. // now program the clock dividers
  875. #if F_CPU == 240000000
  876. // config divisors: 240 MHz core, 60 MHz bus, 30 MHz flash, USB = 240 / 5
  877. // TODO: gradual ramp-up for HSRUN mode
  878. #if F_BUS == 60000000
  879. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(3) | SIM_CLKDIV1_OUTDIV4(7);
  880. #elif F_BUS == 80000000
  881. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(2) | SIM_CLKDIV1_OUTDIV4(7);
  882. #elif F_BUS == 120000000
  883. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(1) | SIM_CLKDIV1_OUTDIV4(7);
  884. #else
  885. #error "This F_CPU & F_BUS combination is not supported"
  886. #endif
  887. SIM_CLKDIV2 = SIM_CLKDIV2_USBDIV(4);
  888. #elif F_CPU == 216000000
  889. // config divisors: 216 MHz core, 54 MHz bus, 27 MHz flash, USB = IRC48M
  890. // TODO: gradual ramp-up for HSRUN mode
  891. #if F_BUS == 54000000
  892. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(3) | SIM_CLKDIV1_OUTDIV4(7);
  893. #elif F_BUS == 72000000
  894. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(2) | SIM_CLKDIV1_OUTDIV4(7);
  895. #elif F_BUS == 108000000
  896. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(1) | SIM_CLKDIV1_OUTDIV4(7);
  897. #else
  898. #error "This F_CPU & F_BUS combination is not supported"
  899. #endif
  900. SIM_CLKDIV2 = SIM_CLKDIV2_USBDIV(0);
  901. #elif F_CPU == 192000000
  902. // config divisors: 192 MHz core, 48 MHz bus, 27.4 MHz flash, USB = 192 / 4
  903. // TODO: gradual ramp-up for HSRUN mode
  904. #if F_BUS == 48000000
  905. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(3) | SIM_CLKDIV1_OUTDIV4(6);
  906. #elif F_BUS == 64000000
  907. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(2) | SIM_CLKDIV1_OUTDIV4(6);
  908. #elif F_BUS == 96000000
  909. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(1) | SIM_CLKDIV1_OUTDIV4(6);
  910. #else
  911. #error "This F_CPU & F_BUS combination is not supported"
  912. #endif
  913. SIM_CLKDIV2 = SIM_CLKDIV2_USBDIV(3);
  914. #elif F_CPU == 180000000
  915. // config divisors: 180 MHz core, 60 MHz bus, 25.7 MHz flash, USB = IRC48M
  916. #if F_BUS == 60000000
  917. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(2) | SIM_CLKDIV1_OUTDIV4(6);
  918. #elif F_BUS == 90000000
  919. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(1) | SIM_CLKDIV1_OUTDIV4(6);
  920. #else
  921. #error "This F_CPU & F_BUS combination is not supported"
  922. #endif
  923. SIM_CLKDIV2 = SIM_CLKDIV2_USBDIV(0);
  924. #elif F_CPU == 168000000
  925. // config divisors: 168 MHz core, 56 MHz bus, 28 MHz flash, USB = 168 * 2 / 7
  926. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(2) | SIM_CLKDIV1_OUTDIV4(5);
  927. SIM_CLKDIV2 = SIM_CLKDIV2_USBDIV(6) | SIM_CLKDIV2_USBFRAC;
  928. #elif F_CPU == 144000000
  929. // config divisors: 144 MHz core, 48 MHz bus, 28.8 MHz flash, USB = 144 / 3
  930. #if F_BUS == 48000000
  931. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(2) | SIM_CLKDIV1_OUTDIV4(4);
  932. #elif F_BUS == 72000000
  933. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(1) | SIM_CLKDIV1_OUTDIV4(4);
  934. #else
  935. #error "This F_CPU & F_BUS combination is not supported"
  936. #endif
  937. SIM_CLKDIV2 = SIM_CLKDIV2_USBDIV(2);
  938. #elif F_CPU == 120000000
  939. // config divisors: 120 MHz core, 60 MHz bus, 24 MHz flash, USB = 128 * 2 / 5
  940. #if F_BUS == 60000000
  941. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(1) | SIM_CLKDIV1_OUTDIV4(4);
  942. #elif F_BUS == 120000000
  943. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(0) | SIM_CLKDIV1_OUTDIV4(4);
  944. #else
  945. #error "This F_CPU & F_BUS combination is not supported"
  946. #endif
  947. SIM_CLKDIV2 = SIM_CLKDIV2_USBDIV(4) | SIM_CLKDIV2_USBFRAC;
  948. #elif F_CPU == 96000000
  949. // config divisors: 96 MHz core, 48 MHz bus, 24 MHz flash, USB = 96 / 2
  950. #if F_BUS == 48000000
  951. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(1) | SIM_CLKDIV1_OUTDIV4(3);
  952. #elif F_BUS == 96000000
  953. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(0) | SIM_CLKDIV1_OUTDIV4(3);
  954. #else
  955. #error "This F_CPU & F_BUS combination is not supported"
  956. #endif
  957. SIM_CLKDIV2 = SIM_CLKDIV2_USBDIV(1);
  958. #elif F_CPU == 72000000
  959. // config divisors: 72 MHz core, 36 MHz bus, 24 MHz flash, USB = 72 * 2 / 3
  960. #if F_BUS == 36000000
  961. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(1) | SIM_CLKDIV1_OUTDIV4(2);
  962. #elif F_BUS == 72000000
  963. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(0) | SIM_CLKDIV1_OUTDIV4(2);
  964. #else
  965. #error "This F_CPU & F_BUS combination is not supported"
  966. #endif
  967. SIM_CLKDIV2 = SIM_CLKDIV2_USBDIV(2) | SIM_CLKDIV2_USBFRAC;
  968. #elif F_CPU == 48000000
  969. // config divisors: 48 MHz core, 48 MHz bus, 24 MHz flash, USB = 96 / 2
  970. #if defined(KINETISK)
  971. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(1) | SIM_CLKDIV1_OUTDIV2(1) | SIM_CLKDIV1_OUTDIV3(1) | SIM_CLKDIV1_OUTDIV4(3);
  972. SIM_CLKDIV2 = SIM_CLKDIV2_USBDIV(1);
  973. #elif defined(KINETISL)
  974. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(1) | SIM_CLKDIV1_OUTDIV4(1);
  975. #endif
  976. #elif F_CPU == 24000000
  977. // config divisors: 24 MHz core, 24 MHz bus, 24 MHz flash, USB = 96 / 2
  978. #if defined(KINETISK)
  979. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(3) | SIM_CLKDIV1_OUTDIV2(3) | SIM_CLKDIV1_OUTDIV3(3) | SIM_CLKDIV1_OUTDIV4(3);
  980. SIM_CLKDIV2 = SIM_CLKDIV2_USBDIV(1);
  981. #elif defined(KINETISL)
  982. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(3) | SIM_CLKDIV1_OUTDIV4(0);
  983. #endif
  984. #elif F_CPU == 16000000
  985. // config divisors: 16 MHz core, 16 MHz bus, 16 MHz flash
  986. #if defined(KINETISK)
  987. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(0) | SIM_CLKDIV1_OUTDIV3(0) | SIM_CLKDIV1_OUTDIV4(0);
  988. #elif defined(KINETISL)
  989. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV4(0);
  990. #endif
  991. #elif F_CPU == 8000000
  992. // config divisors: 8 MHz core, 8 MHz bus, 8 MHz flash
  993. #if defined(KINETISK)
  994. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(1) | SIM_CLKDIV1_OUTDIV2(1) | SIM_CLKDIV1_OUTDIV3(1) | SIM_CLKDIV1_OUTDIV4(1);
  995. #elif defined(KINETISL)
  996. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(1) | SIM_CLKDIV1_OUTDIV4(0);
  997. #endif
  998. #elif F_CPU == 4000000
  999. // config divisors: 4 MHz core, 4 MHz bus, 2 MHz flash
  1000. // since we are running from external clock 16MHz
  1001. // fix outdiv too -> cpu 16/4, bus 16/4, flash 16/4
  1002. // here we can go into vlpr?
  1003. // config divisors: 4 MHz core, 4 MHz bus, 4 MHz flash
  1004. #if defined(KINETISK)
  1005. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(3) | SIM_CLKDIV1_OUTDIV2(3) | SIM_CLKDIV1_OUTDIV3(3) | SIM_CLKDIV1_OUTDIV4(3);
  1006. #elif defined(KINETISL)
  1007. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(3) | SIM_CLKDIV1_OUTDIV4(0);
  1008. #endif
  1009. #elif F_CPU == 2000000
  1010. // since we are running from the fast internal reference clock 4MHz
  1011. // but is divided down by 2 so we actually have a 2MHz, MCG_SC[FCDIV] default is 2
  1012. // fix outdiv -> cpu 2/1, bus 2/1, flash 2/2
  1013. // config divisors: 2 MHz core, 2 MHz bus, 1 MHz flash
  1014. #if defined(KINETISK)
  1015. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV2(0) | SIM_CLKDIV1_OUTDIV4(1);
  1016. #elif defined(KINETISL)
  1017. // config divisors: 2 MHz core, 1 MHz bus, 1 MHz flash
  1018. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIV1(0) | SIM_CLKDIV1_OUTDIV4(1);
  1019. #endif
  1020. #else
  1021. #error "Error, F_CPU must be 192, 180, 168, 144, 120, 96, 72, 48, 24, 16, 8, 4, or 2 MHz"
  1022. #endif
  1023. #if F_CPU > 16000000
  1024. // switch to PLL as clock source, FLL input = 16 MHz / 512
  1025. MCG_C1 = MCG_C1_CLKS(0) | MCG_C1_FRDIV(4);
  1026. // wait for PLL clock to be used
  1027. while ((MCG_S & MCG_S_CLKST_MASK) != MCG_S_CLKST(3)) ;
  1028. // now we're in PEE mode
  1029. // USB uses PLL clock, trace is CPU clock, CLKOUT=OSCERCLK0
  1030. #if defined(KINETISK)
  1031. #if F_CPU == 216000000 || F_CPU == 180000000
  1032. SIM_SOPT2 = SIM_SOPT2_USBSRC | SIM_SOPT2_IRC48SEL | SIM_SOPT2_TRACECLKSEL | SIM_SOPT2_CLKOUTSEL(6);
  1033. #else
  1034. SIM_SOPT2 = SIM_SOPT2_USBSRC | SIM_SOPT2_PLLFLLSEL | SIM_SOPT2_TRACECLKSEL | SIM_SOPT2_CLKOUTSEL(6);
  1035. #endif
  1036. #elif defined(KINETISL)
  1037. SIM_SOPT2 = SIM_SOPT2_USBSRC | SIM_SOPT2_PLLFLLSEL | SIM_SOPT2_CLKOUTSEL(6)
  1038. | SIM_SOPT2_UART0SRC(1) | SIM_SOPT2_TPMSRC(1);
  1039. #endif
  1040. #else
  1041. #if F_CPU == 2000000
  1042. SIM_SOPT2 = SIM_SOPT2_TRACECLKSEL | SIM_SOPT2_CLKOUTSEL(4) | SIM_SOPT2_UART0SRC(3);
  1043. #else
  1044. SIM_SOPT2 = SIM_SOPT2_TRACECLKSEL | SIM_SOPT2_CLKOUTSEL(6) | SIM_SOPT2_UART0SRC(2);
  1045. #endif
  1046. #endif
  1047. #if F_CPU <= 2000000
  1048. // since we are not going into "stop mode" i removed it
  1049. SMC_PMCTRL = SMC_PMCTRL_RUNM(2); // VLPR mode :-)
  1050. #endif
  1051. // initialize the SysTick counter
  1052. SYST_RVR = (F_CPU / 1000) - 1;
  1053. SYST_CVR = 0;
  1054. SYST_CSR = SYST_CSR_CLKSOURCE | SYST_CSR_TICKINT | SYST_CSR_ENABLE;
  1055. SCB_SHPR3 = 0x20200000; // Systick = priority 32
  1056. //init_pins();
  1057. __enable_irq();
  1058. _init_Teensyduino_internal_();
  1059. #if defined(KINETISK)
  1060. // RTC initialization
  1061. if (RTC_SR & RTC_SR_TIF) {
  1062. // this code will normally run on a power-up reset
  1063. // when VBAT has detected a power-up. Normally our
  1064. // compiled-in time will be stale. Write a special
  1065. // flag into the VBAT register file indicating the
  1066. // RTC is set with known-stale time and should be
  1067. // updated when fresh time is known.
  1068. #if ARDUINO >= 10600
  1069. rtc_set((uint32_t)&__rtc_localtime);
  1070. #else
  1071. rtc_set(TIME_T);
  1072. #endif
  1073. *(uint32_t *)0x4003E01C = 0x5A94C3A5;
  1074. }
  1075. if ((RCM_SRS0 & RCM_SRS0_PIN) && (*(uint32_t *)0x4003E01C == 0x5A94C3A5)) {
  1076. // this code should run immediately after an upload
  1077. // where the Teensy Loader causes the Mini54 to reset.
  1078. // Our compiled-in time will be very fresh, so set
  1079. // the RTC with this, and clear the VBAT resister file
  1080. // data so we don't mess with the time after it's been
  1081. // set well.
  1082. #if ARDUINO >= 10600
  1083. rtc_set((uint32_t)&__rtc_localtime);
  1084. #else
  1085. rtc_set(TIME_T);
  1086. #endif
  1087. *(uint32_t *)0x4003E01C = 0;
  1088. }
  1089. #endif
  1090. __libc_init_array();
  1091. startup_late_hook();
  1092. main();
  1093. while (1) ;
  1094. }
  1095. char *__brkval = (char *)&_ebss;
  1096. #ifndef STACK_MARGIN
  1097. #if defined(__MKL26Z64__)
  1098. #define STACK_MARGIN 512
  1099. #elif defined(__MK20DX128__)
  1100. #define STACK_MARGIN 1024
  1101. #elif defined(__MK20DX256__)
  1102. #define STACK_MARGIN 4096
  1103. #elif defined(__MK64FX512__) || defined(__MK66FX1M0__)
  1104. #define STACK_MARGIN 8192
  1105. #endif
  1106. #endif
  1107. #pragma GCC diagnostic push
  1108. #pragma GCC diagnostic ignored "-Wunused-parameter"
  1109. void * _sbrk(int incr)
  1110. {
  1111. char *prev, *stack;
  1112. prev = __brkval;
  1113. if (incr != 0) {
  1114. __asm__ volatile("mov %0, sp" : "=r" (stack) ::);
  1115. if (prev + incr >= stack - STACK_MARGIN) {
  1116. errno = ENOMEM;
  1117. return (void *)-1;
  1118. }
  1119. __brkval = prev + incr;
  1120. }
  1121. return prev;
  1122. }
  1123. __attribute__((weak))
  1124. int _read(int file, char *ptr, int len)
  1125. {
  1126. return 0;
  1127. }
  1128. __attribute__((weak))
  1129. int _close(int fd)
  1130. {
  1131. return -1;
  1132. }
  1133. #include <sys/stat.h>
  1134. __attribute__((weak))
  1135. int _fstat(int fd, struct stat *st)
  1136. {
  1137. st->st_mode = S_IFCHR;
  1138. return 0;
  1139. }
  1140. __attribute__((weak))
  1141. int _isatty(int fd)
  1142. {
  1143. return 1;
  1144. }
  1145. __attribute__((weak))
  1146. int _lseek(int fd, long long offset, int whence)
  1147. {
  1148. return -1;
  1149. }
  1150. __attribute__((weak))
  1151. void _exit(int status)
  1152. {
  1153. while (1);
  1154. }
  1155. __attribute__((weak))
  1156. void __cxa_pure_virtual()
  1157. {
  1158. while (1);
  1159. }
  1160. __attribute__((weak))
  1161. int __cxa_guard_acquire (char *g)
  1162. {
  1163. return !(*g);
  1164. }
  1165. __attribute__((weak))
  1166. void __cxa_guard_release(char *g)
  1167. {
  1168. *g = 1;
  1169. }
  1170. #pragma GCC diagnostic pop
  1171. int nvic_execution_priority(void)
  1172. {
  1173. uint32_t priority=256;
  1174. uint32_t primask, faultmask, basepri, ipsr;
  1175. // full algorithm in ARM DDI0403D, page B1-639
  1176. // this isn't quite complete, but hopefully good enough
  1177. __asm__ volatile("mrs %0, faultmask\n" : "=r" (faultmask)::);
  1178. if (faultmask) return -1;
  1179. __asm__ volatile("mrs %0, primask\n" : "=r" (primask)::);
  1180. if (primask) return 0;
  1181. __asm__ volatile("mrs %0, ipsr\n" : "=r" (ipsr)::);
  1182. if (ipsr) {
  1183. if (ipsr < 16) priority = 0; // could be non-zero
  1184. else priority = NVIC_GET_PRIORITY(ipsr - 16);
  1185. }
  1186. __asm__ volatile("mrs %0, basepri\n" : "=r" (basepri)::);
  1187. if (basepri > 0 && basepri < priority) priority = basepri;
  1188. return priority;
  1189. }
  1190. #if defined(HAS_KINETIS_HSRUN) && F_CPU > 120000000
  1191. int kinetis_hsrun_disable(void)
  1192. {
  1193. if (SMC_PMSTAT == SMC_PMSTAT_HSRUN) {
  1194. // First, reduce the CPU clock speed, but do not change
  1195. // the peripheral speed (F_BUS). Serial1 & Serial2 baud
  1196. // rates will be impacted, but most other peripherals
  1197. // will continue functioning at the same speed.
  1198. #if F_CPU == 240000000 && F_BUS == 60000000
  1199. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(1, 3, 1, 7); // ok
  1200. #elif F_CPU == 240000000 && F_BUS == 80000000
  1201. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(2, 2, 2, 8); // ok
  1202. #elif F_CPU == 240000000 && F_BUS == 120000000
  1203. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(1, 1, 1, 7); // ok
  1204. #elif F_CPU == 216000000 && F_BUS == 54000000
  1205. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(1, 3, 1, 7); // ok
  1206. #elif F_CPU == 216000000 && F_BUS == 72000000
  1207. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(2, 2, 2, 8); // ok
  1208. #elif F_CPU == 216000000 && F_BUS == 108000000
  1209. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(1, 1, 1, 7); // ok
  1210. #elif F_CPU == 192000000 && F_BUS == 48000000
  1211. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(1, 3, 1, 7); // ok
  1212. #elif F_CPU == 192000000 && F_BUS == 64000000
  1213. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(2, 2, 2, 8); // ok
  1214. #elif F_CPU == 192000000 && F_BUS == 96000000
  1215. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(1, 1, 1, 7); // ok
  1216. #elif F_CPU == 180000000 && F_BUS == 60000000
  1217. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(2, 2, 2, 8); // ok
  1218. #elif F_CPU == 180000000 && F_BUS == 90000000
  1219. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(1, 1, 1, 7); // ok
  1220. #elif F_CPU == 168000000 && F_BUS == 56000000
  1221. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(2, 2, 2, 5); // ok
  1222. #elif F_CPU == 144000000 && F_BUS == 48000000
  1223. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(2, 2, 2, 5); // ok
  1224. #elif F_CPU == 144000000 && F_BUS == 72000000
  1225. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(1, 1, 1, 5); // ok
  1226. #else
  1227. return 0;
  1228. #endif
  1229. // Then turn off HSRUN mode
  1230. SMC_PMCTRL = SMC_PMCTRL_RUNM(0);
  1231. while (SMC_PMSTAT == SMC_PMSTAT_HSRUN) ; // wait
  1232. return 1;
  1233. }
  1234. return 0;
  1235. }
  1236. int kinetis_hsrun_enable(void)
  1237. {
  1238. if (SMC_PMSTAT == SMC_PMSTAT_RUN) {
  1239. // Turn HSRUN mode on
  1240. SMC_PMCTRL = SMC_PMCTRL_RUNM(3);
  1241. while (SMC_PMSTAT != SMC_PMSTAT_HSRUN) {;} // wait
  1242. // Then configure clock for full speed
  1243. #if F_CPU == 240000000 && F_BUS == 60000000
  1244. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(0, 3, 0, 7);
  1245. #elif F_CPU == 240000000 && F_BUS == 80000000
  1246. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(0, 2, 0, 7);
  1247. #elif F_CPU == 240000000 && F_BUS == 120000000
  1248. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(0, 1, 0, 7);
  1249. #elif F_CPU == 216000000 && F_BUS == 54000000
  1250. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(0, 3, 0, 7);
  1251. #elif F_CPU == 216000000 && F_BUS == 72000000
  1252. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(0, 2, 0, 7);
  1253. #elif F_CPU == 216000000 && F_BUS == 108000000
  1254. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(0, 1, 0, 7);
  1255. #elif F_CPU == 192000000 && F_BUS == 48000000
  1256. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(0, 3, 0, 6);
  1257. #elif F_CPU == 192000000 && F_BUS == 64000000
  1258. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(0, 2, 0, 6);
  1259. #elif F_CPU == 192000000 && F_BUS == 96000000
  1260. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(0, 1, 0, 6);
  1261. #elif F_CPU == 180000000 && F_BUS == 60000000
  1262. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(0, 2, 0, 6);
  1263. #elif F_CPU == 180000000 && F_BUS == 90000000
  1264. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(0, 1, 0, 6);
  1265. #elif F_CPU == 168000000 && F_BUS == 56000000
  1266. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(0, 2, 0, 5);
  1267. #elif F_CPU == 144000000 && F_BUS == 48000000
  1268. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(0, 2, 0, 4);
  1269. #elif F_CPU == 144000000 && F_BUS == 72000000
  1270. SIM_CLKDIV1 = SIM_CLKDIV1_OUTDIVS(0, 1, 0, 4);
  1271. #else
  1272. return 0;
  1273. #endif
  1274. return 1;
  1275. }
  1276. return 0;
  1277. }
  1278. #endif // HAS_KINETIS_HSRUN && F_CPU > 120000000