]> git.sur5r.net Git - freertos/blob - FreeRTOS/Demo/CORTEX_A53_64-bit_UltraScale_MPSoC/RTOSDemo_A53/src/platform.c
commit 9f316c246baafa15c542a5aea81a94f26e3d6507
[freertos] / FreeRTOS / Demo / CORTEX_A53_64-bit_UltraScale_MPSoC / RTOSDemo_A53 / 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 #ifdef __MICROBLAZE__
72 #ifdef XPAR_MICROBLAZE_USE_DCACHE
73     Xil_DCacheDisable();
74 #endif
75 #ifdef XPAR_MICROBLAZE_USE_ICACHE
76     Xil_ICacheDisable();
77 #endif
78 #endif
79 }
80
81 void
82 init_uart()
83 {
84 #ifdef STDOUT_IS_16550
85     XUartNs550_SetBaud(STDOUT_BASEADDR, XPAR_XUARTNS550_CLOCK_HZ, UART_BAUD);
86     XUartNs550_SetLineControlReg(STDOUT_BASEADDR, XUN_LCR_8_DATA_BITS);
87 #endif
88     /* Bootrom/BSP configures PS7/PSU UART to 115200 bps */
89 }
90
91 void
92 init_platform()
93 {
94     /*
95      * If you want to run this example outside of SDK,
96      * uncomment one of the following two lines and also #include "ps7_init.h"
97      * or #include "ps7_init.h" at the top, depending on the target.
98      * Make sure that the ps7/psu_init.c and ps7/psu_init.h files are included
99      * along with this example source files for compilation.
100      */
101     /* ps7_init();*/
102     /* psu_init();*/
103     enable_caches();
104     init_uart();
105 }
106
107 void
108 cleanup_platform()
109 {
110     disable_caches();
111 }