blob: 69115c159a1b59d0c8fd5e4de658858684499a99 [file] [log] [blame]
rjw1f884582022-01-06 17:20:42 +08001/*
2 * Copyright (c) 2018 MediaTek Inc.
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining
5 * a copy of this software and associated documentation files
6 * (the "Software"), to deal in the Software without restriction,
7 * including without limitation the rights to use, copy, modify, merge,
8 * publish, distribute, sublicense, and/or sell copies of the Software,
9 * and to permit persons to whom the Software is furnished to do so,
10 * subject to the following conditions:
11 *
12 * The above copyright notice and this permission notice shall be
13 * included in all copies or substantial portions of the Software.
14 *
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
16 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
17 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
18 * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
19 * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
20 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
21 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
22*/
23
24#include <platform/nand.h>
25
26#include <platform/mmc_core.h>
27#include <platform/mt_reg_base.h>
28
29extern void platform_memory_init(void);
30
31struct mmc_card *card;
32bool retry_opcond;
33
34void target_early_init(void)
35{
36 card = emmc_init_stage1(&retry_opcond);
37}
38
39void target_init(void)
40{
41 if (card) {
42 emmc_init_stage2(card, retry_opcond);
43 }
44 writel(0x7, GPIO_BASE + 0x408);//set gpio80 gpio mode
45 writel(0x1, GPIO_BASE + 0x054);//set gpio80 output
46 writel(0x1, GPIO_BASE + 0x154);//set gpio80 output-high
47}