]> git.sur5r.net Git - freertos/blob - FreeRTOS/Demo/CORTEX_A9_Zynq_ZC702/RTOSDemo/src/platform.c
Update version number in readiness for V10.3.0 release. Sync SVN with reviewed releas...
[freertos] / FreeRTOS / Demo / CORTEX_A9_Zynq_ZC702 / RTOSDemo / src / platform.c
1 /******************************************************************************
2 *
3 * Copyright (C) 2010 - 2015 Xilinx, Inc.  All rights reserved.
4 *
5 * Permission is hereby granted, free of charge, to any person obtaining a copy
6 * of this software and associated documentation files (the "Software"), to deal
7 * in the Software without restriction, including without limitation the rights
8 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 * copies of the Software, and to permit persons to whom the Software is
10 * furnished to do so, subject to the following conditions:
11 *
12 * The above copyright notice and this permission notice shall be included in
13 * all copies or substantial portions of the Software.
14 *
15 * Use of the Software is limited solely to applications:
16 * (a) running on a Xilinx device, or
17 * (b) that interact with a Xilinx device through a bus or interconnect.
18 *
19 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
20 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
22 * XILINX  BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
23 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF
24 * OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
25 * SOFTWARE.
26 *
27 * Except as contained in this notice, the name of the Xilinx shall not be used
28 * in advertising or otherwise to promote the sale, use or other dealings in
29 * this Software without prior written authorization from Xilinx.
30 *
31 ******************************************************************************/
32
33 #include "xparameters.h"
34 #include "xil_cache.h"
35
36 #include "platform_config.h"
37
38 /*
39  * Uncomment one of the following two lines, depending on the target,
40  * if ps7/psu init source files are added in the source directory for
41  * compiling example outside of SDK.
42  */
43 /*#include "ps7_init.h"*/
44 /*#include "psu_init.h"*/
45
46 #ifdef STDOUT_IS_16550
47  #include "xuartns550_l.h"
48
49  #define UART_BAUD 9600
50 #endif
51
52 void
53 enable_caches()
54 {
55 #ifdef __PPC__
56     Xil_ICacheEnableRegion(CACHEABLE_REGION_MASK);
57     Xil_DCacheEnableRegion(CACHEABLE_REGION_MASK);
58 #elif __MICROBLAZE__
59 #ifdef XPAR_MICROBLAZE_USE_ICACHE
60     Xil_ICacheEnable();
61 #endif
62 #ifdef XPAR_MICROBLAZE_USE_DCACHE
63     Xil_DCacheEnable();
64 #endif
65 #endif
66 }
67
68 void
69 disable_caches()
70 {
71     Xil_DCacheDisable();
72     Xil_ICacheDisable();
73 }
74
75 void
76 init_uart()
77 {
78 #ifdef STDOUT_IS_16550
79     XUartNs550_SetBaud(STDOUT_BASEADDR, XPAR_XUARTNS550_CLOCK_HZ, UART_BAUD);
80     XUartNs550_SetLineControlReg(STDOUT_BASEADDR, XUN_LCR_8_DATA_BITS);
81 #endif
82     /* Bootrom/BSP configures PS7/PSU UART to 115200 bps */
83 }
84
85 void
86 init_platform()
87 {
88     /*
89      * If you want to run this example outside of SDK,
90      * uncomment one of the following two lines and also #include "ps7_init.h"
91      * or #include "ps7_init.h" at the top, depending on the target.
92      * Make sure that the ps7/psu_init.c and ps7/psu_init.h files are included
93      * along with this example source files for compilation.
94      */
95     /* ps7_init();*/
96     /* psu_init();*/
97     enable_caches();
98     init_uart();
99 }
100
101 void
102 cleanup_platform()
103 {
104     disable_caches();
105 }