]> git.sur5r.net Git - freertos/blob - FreeRTOS/Demo/NEC_V850ES_IAR/LowLevelInit/LowLevelInit_Fx3.c
Update to MIT licensed FreeRTOS V10.0.0 - see https://www.freertos.org/History.txt
[freertos] / FreeRTOS / Demo / NEC_V850ES_IAR / LowLevelInit / LowLevelInit_Fx3.c
1 /*\r
2  * FreeRTOS Kernel V10.0.0\r
3  * Copyright (C) 2017 Amazon.com, Inc. or its affiliates.  All Rights Reserved.\r
4  *\r
5  * Permission is hereby granted, free of charge, to any person obtaining a copy of\r
6  * this software and associated documentation files (the "Software"), to deal in\r
7  * the Software without restriction, including without limitation the rights to\r
8  * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of\r
9  * the Software, and to permit persons to whom the Software is furnished to do so,\r
10  * subject to the following conditions:\r
11  *\r
12  * The above copyright notice and this permission notice shall be included in all\r
13  * copies or substantial portions of the Software. If you wish to use our Amazon\r
14  * FreeRTOS name, please do so in a fair use way that does not cause confusion.\r
15  *\r
16  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r
17  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS\r
18  * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR\r
19  * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER\r
20  * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN\r
21  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\r
22  *\r
23  * http://www.FreeRTOS.org\r
24  * http://aws.amazon.com/freertos\r
25  *\r
26  * 1 tab == 4 spaces!\r
27  */\r
28 \r
29 #include "FreeRTOS.h"\r
30 \r
31 /*-----------------------------------------------------------*/\r
32 \r
33 /* Called by the startup code to initialise the run time system. */\r
34 unsigned char __low_level_init(void);\r
35 \r
36 /*-----------------------------------------------------------*/\r
37 \r
38 unsigned char __low_level_init(void)\r
39 {\r
40 unsigned char resetflag = RESF;\r
41 unsigned char psval = 0;\r
42 \r
43         /* Setup provided by NEC. */\r
44 \r
45         /* Disable global interrupts to ensure no interrupts occur during system\r
46         setup. */\r
47         portDISABLE_INTERRUPTS();\r
48 \r
49         PRCMD = 0x00;\r
50         OCDM = 0x00;\r
51         VSWC = 0x12;\r
52         VSWC = 18;\r
53 \r
54         /* Set main system clock */\r
55         OSTS = 0x06;\r
56         psval = 0x80;\r
57         PRCMD = psval;\r
58         PCC = psval;\r
59         while (!OSTC)\r
60         {\r
61                 ;\r
62         }\r
63 \r
64         PLLS = 0x03;\r
65         PLLON = 1;\r
66         while (LOCKR)\r
67         {\r
68                 ;\r
69         }\r
70 \r
71         psval = 0x01;\r
72         PRCMD = psval;\r
73         MCM = psval;\r
74         SELPLL = 1;\r
75 \r
76         /* Set fCPU */\r
77         psval = PCC | 0x00;\r
78         PRCMD = psval;\r
79         PCC = psval;\r
80         RCM = 0x83;\r
81 \r
82         /* Set fXP1 */\r
83         SELCNT4 = 0x00;\r
84 \r
85         /* Set fBRG */\r
86         PRSM0 = 0x00;\r
87 \r
88         /* Stand-by setting */\r
89         psval = 0x00;\r
90         PRCMD = psval;\r
91         PSC = psval;\r
92 \r
93         /* WDT2 setting */\r
94         WDTM2 = 0x1F;\r
95 \r
96         /* PCL setting */\r
97         PCLM = 0x00;\r
98 \r
99         /* disable dma0 - dma3 */\r
100         E00 = 0;        \r
101         E11 = 0;\r
102         E22 = 0;\r
103         E33 = 0;        \r
104 \r
105         return pdTRUE;\r
106 }\r
107 /*-----------------------------------------------------------*/\r