]> git.sur5r.net Git - freertos/blobdiff - FreeRTOS/Demo/CORTEX_M7_SAME70_Xplained_AtmelStudio/src/ASF/sam/utils/cmsis/same70/source/templates/system_same70.c
Rename DummyTCB_t to StaticTCB_t.
[freertos] / FreeRTOS / Demo / CORTEX_M7_SAME70_Xplained_AtmelStudio / src / ASF / sam / utils / cmsis / same70 / source / templates / system_same70.c
diff --git a/FreeRTOS/Demo/CORTEX_M7_SAME70_Xplained_AtmelStudio/src/ASF/sam/utils/cmsis/same70/source/templates/system_same70.c b/FreeRTOS/Demo/CORTEX_M7_SAME70_Xplained_AtmelStudio/src/ASF/sam/utils/cmsis/same70/source/templates/system_same70.c
new file mode 100644 (file)
index 0000000..af29a7c
--- /dev/null
@@ -0,0 +1,258 @@
+/**\r
+ * \file\r
+ *\r
+ * Copyright (c) 2015 Atmel Corporation. All rights reserved.\r
+ *\r
+ * \asf_license_start\r
+ *\r
+ * \page License\r
+ *\r
+ * Redistribution and use in source and binary forms, with or without\r
+ * modification, are permitted provided that the following conditions are met:\r
+ *\r
+ * 1. Redistributions of source code must retain the above copyright notice,\r
+ *    this list of conditions and the following disclaimer.\r
+ *\r
+ * 2. Redistributions in binary form must reproduce the above copyright notice,\r
+ *    this list of conditions and the following disclaimer in the documentation\r
+ *    and/or other materials provided with the distribution.\r
+ *\r
+ * 3. The name of Atmel may not be used to endorse or promote products derived\r
+ *    from this software without specific prior written permission.\r
+ *\r
+ * 4. This software may only be redistributed and used in connection with an\r
+ *    Atmel microcontroller product.\r
+ *\r
+ * THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR IMPLIED\r
+ * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF\r
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE\r
+ * EXPRESSLY AND SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR\r
+ * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\r
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\r
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\r
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,\r
+ * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN\r
+ * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE\r
+ * POSSIBILITY OF SUCH DAMAGE.\r
+ *\r
+ * \asf_license_stop\r
+ *\r
+ */\r
+/*\r
+ * Support and FAQ: visit <a href="http://www.atmel.com/design-support/">Atmel Support</a>\r
+ */\r
+\r
+#include "same70.h"\r
+\r
+/* @cond 0 */\r
+/**INDENT-OFF**/\r
+#ifdef __cplusplus\r
+extern "C" {\r
+#endif\r
+/**INDENT-ON**/\r
+/* @endcond */\r
+\r
+/* %ATMEL_SYSTEM% */\r
+/* Clock Settings (600MHz PLL VDDIO 3.3V and VDDCORE 1.2V) */\r
+/* Clock Settings (300MHz HCLK, 150MHz MCK)=> PRESC = 2, MDIV = 2 */\r
+#define SYS_BOARD_OSCOUNT   (CKGR_MOR_MOSCXTST(0x8U))\r
+#define SYS_BOARD_PLLAR     (CKGR_PLLAR_ONE | CKGR_PLLAR_MULA(0x31U) | \\r
+                            CKGR_PLLAR_PLLACOUNT(0x3fU) | CKGR_PLLAR_DIVA(0x1U))\r
+#define SYS_BOARD_MCKR      (PMC_MCKR_PRES_CLK_2 | PMC_MCKR_CSS_PLLA_CLK | (1<<8))\r
+\r
+uint32_t SystemCoreClock = CHIP_FREQ_MAINCK_RC_4MHZ;\r
+\r
+/**\r
+ * \brief Setup the microcontroller system.\r
+ * Initialize the System and update the SystemFrequency variable.\r
+ */\r
+ void SystemInit( void )\r
+{\r
+  /* Set FWS according to SYS_BOARD_MCKR configuration */\r
+  EFC->EEFC_FMR = EEFC_FMR_FWS(5);\r
+\r
+  /* Initialize main oscillator */\r
+  if ( !(PMC->CKGR_MOR & CKGR_MOR_MOSCSEL) )\r
+  {\r
+    PMC->CKGR_MOR = CKGR_MOR_KEY_PASSWD | SYS_BOARD_OSCOUNT | CKGR_MOR_MOSCRCEN | CKGR_MOR_MOSCXTEN;\r
+\r
+    while ( !(PMC->PMC_SR & PMC_SR_MOSCXTS) )\r
+    {\r
+    }\r
+  }\r
+\r
+  /* Switch to 3-20MHz Xtal oscillator */\r
+  PMC->CKGR_MOR = CKGR_MOR_KEY_PASSWD | SYS_BOARD_OSCOUNT | CKGR_MOR_MOSCRCEN | CKGR_MOR_MOSCXTEN | CKGR_MOR_MOSCSEL;\r
+\r
+  while ( !(PMC->PMC_SR & PMC_SR_MOSCSELS) )\r
+  {\r
+  }\r
+\r
+  PMC->PMC_MCKR = (PMC->PMC_MCKR & ~(uint32_t)PMC_MCKR_CSS_Msk) | PMC_MCKR_CSS_MAIN_CLK;\r
+\r
+  while ( !(PMC->PMC_SR & PMC_SR_MCKRDY) )\r
+  {\r
+  }\r
+\r
+  /* Initialize PLLA */\r
+  PMC->CKGR_PLLAR = SYS_BOARD_PLLAR;\r
+  while ( !(PMC->PMC_SR & PMC_SR_LOCKA) )\r
+  {\r
+  }\r
+\r
+  /* Switch to main clock */\r
+  PMC->PMC_MCKR = (SYS_BOARD_MCKR & ~PMC_MCKR_CSS_Msk) | PMC_MCKR_CSS_MAIN_CLK;\r
+  while ( !(PMC->PMC_SR & PMC_SR_MCKRDY) )\r
+  {\r
+  }\r
+\r
+  /* Switch to PLLA */\r
+  PMC->PMC_MCKR = SYS_BOARD_MCKR;\r
+  while ( !(PMC->PMC_SR & PMC_SR_MCKRDY) )\r
+  {\r
+  }\r
+\r
+  SystemCoreClock = CHIP_FREQ_CPU_MAX;\r
+}\r
+\r
+void SystemCoreClockUpdate( void )\r
+{\r
+  /* Determine clock frequency according to clock register values */\r
+  switch (PMC->PMC_MCKR & (uint32_t) PMC_MCKR_CSS_Msk)\r
+  {\r
+    case PMC_MCKR_CSS_SLOW_CLK: /* Slow clock */\r
+      if ( SUPC->SUPC_SR & SUPC_SR_OSCSEL )\r
+      {\r
+        SystemCoreClock = CHIP_FREQ_XTAL_32K;\r
+      }\r
+      else\r
+      {\r
+        SystemCoreClock = CHIP_FREQ_SLCK_RC;\r
+      }\r
+    break;\r
+\r
+    case PMC_MCKR_CSS_MAIN_CLK: /* Main clock */\r
+      if ( PMC->CKGR_MOR & CKGR_MOR_MOSCSEL )\r
+      {\r
+        SystemCoreClock = CHIP_FREQ_XTAL_12M;\r
+      }\r
+      else\r
+      {\r
+        SystemCoreClock = CHIP_FREQ_MAINCK_RC_4MHZ;\r
+\r
+        switch ( PMC->CKGR_MOR & CKGR_MOR_MOSCRCF_Msk )\r
+        {\r
+          case CKGR_MOR_MOSCRCF_4_MHz:\r
+          break;\r
+\r
+          case CKGR_MOR_MOSCRCF_8_MHz:\r
+            SystemCoreClock *= 2U;\r
+          break;\r
+\r
+          case CKGR_MOR_MOSCRCF_12_MHz:\r
+            SystemCoreClock *= 3U;\r
+          break;\r
+\r
+          default:\r
+          break;\r
+        }\r
+      }\r
+    break;\r
+\r
+    case PMC_MCKR_CSS_PLLA_CLK:        /* PLLA clock */\r
+      if ( PMC->CKGR_MOR & CKGR_MOR_MOSCSEL )\r
+      {\r
+        SystemCoreClock = CHIP_FREQ_XTAL_12M ;\r
+      }\r
+      else\r
+      {\r
+        SystemCoreClock = CHIP_FREQ_MAINCK_RC_4MHZ;\r
+\r
+        switch ( PMC->CKGR_MOR & CKGR_MOR_MOSCRCF_Msk )\r
+        {\r
+          case CKGR_MOR_MOSCRCF_4_MHz:\r
+          break;\r
+\r
+          case CKGR_MOR_MOSCRCF_8_MHz:\r
+            SystemCoreClock *= 2U;\r
+          break;\r
+\r
+          case CKGR_MOR_MOSCRCF_12_MHz:\r
+            SystemCoreClock *= 3U;\r
+          break;\r
+\r
+          default:\r
+          break;\r
+        }\r
+      }\r
+\r
+      if ( (uint32_t) (PMC->PMC_MCKR & (uint32_t) PMC_MCKR_CSS_Msk) == PMC_MCKR_CSS_PLLA_CLK )\r
+      {\r
+        SystemCoreClock *= ((((PMC->CKGR_PLLAR) & CKGR_PLLAR_MULA_Msk) >> CKGR_PLLAR_MULA_Pos) + 1U);\r
+        SystemCoreClock /= ((((PMC->CKGR_PLLAR) & CKGR_PLLAR_DIVA_Msk) >> CKGR_PLLAR_DIVA_Pos));\r
+      }\r
+    break;\r
+\r
+    default:\r
+    break;\r
+  }\r
+\r
+  if ( (PMC->PMC_MCKR & PMC_MCKR_PRES_Msk) == PMC_MCKR_PRES_CLK_3 )\r
+  {\r
+    SystemCoreClock /= 3U;\r
+  }\r
+  else\r
+  {\r
+    SystemCoreClock >>= ((PMC->PMC_MCKR & PMC_MCKR_PRES_Msk) >> PMC_MCKR_PRES_Pos);\r
+  }\r
+}\r
+/**\r
+ * Initialize flash.\r
+ */\r
+void system_init_flash( uint32_t ul_clk )\r
+{\r
+  /* Set FWS for embedded Flash access according to operating frequency */\r
+  if ( ul_clk < CHIP_FREQ_FWS_0 )\r
+  {\r
+    EFC->EEFC_FMR = EEFC_FMR_FWS(0)|EEFC_FMR_CLOE;\r
+  }\r
+  else\r
+  {\r
+    if (ul_clk < CHIP_FREQ_FWS_1)\r
+    {\r
+      EFC->EEFC_FMR = EEFC_FMR_FWS(1)|EEFC_FMR_CLOE;\r
+    }\r
+    else\r
+    {\r
+      if (ul_clk < CHIP_FREQ_FWS_2)\r
+      {\r
+        EFC->EEFC_FMR = EEFC_FMR_FWS(2)|EEFC_FMR_CLOE;\r
+      }\r
+      else\r
+      {\r
+        if ( ul_clk < CHIP_FREQ_FWS_3 )\r
+        {\r
+          EFC->EEFC_FMR = EEFC_FMR_FWS(3)|EEFC_FMR_CLOE;\r
+        }\r
+        else\r
+        {\r
+          if ( ul_clk < CHIP_FREQ_FWS_4 )\r
+          {\r
+            EFC->EEFC_FMR = EEFC_FMR_FWS(4)|EEFC_FMR_CLOE;\r
+          }\r
+          else\r
+          {\r
+            EFC->EEFC_FMR = EEFC_FMR_FWS(5)|EEFC_FMR_CLOE;\r
+          }\r
+        }\r
+      }\r
+    }\r
+  }\r
+}\r
+/* @cond 0 */\r
+/**INDENT-OFF**/\r
+#ifdef __cplusplus\r
+}\r
+#endif\r
+/**INDENT-ON**/\r
+/* @endcond */\r