blob: 8313c5a3e5372deb39776e65d3e0a4305d878e2c [file] [log] [blame]
Masahiro Yamada5894ca02014-10-03 19:21:06 +09001/*
Masahiro Yamadaf6e7f072015-05-29 17:30:00 +09002 * Copyright (C) 2011-2015 Masahiro Yamada <yamada.masahiro@socionext.com>
Masahiro Yamada5894ca02014-10-03 19:21:06 +09003 *
4 * SPDX-License-Identifier: GPL-2.0+
5 */
6
7#include <common.h>
Masahiro Yamadaf6e7f072015-05-29 17:30:00 +09008#include <linux/io.h>
Masahiro Yamada107b3fb2016-01-09 01:51:13 +09009
10#include "../init.h"
11#include "../sg-regs.h"
12#include "sbc-regs.h"
Masahiro Yamada5894ca02014-10-03 19:21:06 +090013
Masahiro Yamada323d1f92015-09-22 00:27:39 +090014int ph1_pro4_sbc_init(const struct uniphier_board_data *bd)
Masahiro Yamada5894ca02014-10-03 19:21:06 +090015{
Masahiro Yamada5894ca02014-10-03 19:21:06 +090016 /*
17 * Only CS1 is connected to support card.
18 * BKSZ[1:0] should be set to "01".
19 */
20 writel(SBCTRL0_SAVEPIN_PERI_VALUE, SBCTRL10);
21 writel(SBCTRL1_SAVEPIN_PERI_VALUE, SBCTRL11);
22 writel(SBCTRL2_SAVEPIN_PERI_VALUE, SBCTRL12);
23 writel(SBCTRL4_SAVEPIN_PERI_VALUE, SBCTRL14);
24
Masahiro Yamadab1156782014-12-06 00:03:19 +090025 if (boot_is_swapped()) {
Masahiro Yamada5894ca02014-10-03 19:21:06 +090026 /*
27 * Boot Swap On: boot from external NOR/SRAM
Masahiro Yamadad5ed8c52015-09-11 20:17:47 +090028 * 0x42000000-0x43ffffff is a mirror of 0x40000000-0x41ffffff.
Masahiro Yamada5894ca02014-10-03 19:21:06 +090029 *
Masahiro Yamadad5ed8c52015-09-11 20:17:47 +090030 * 0x40000000-0x41efffff, 0x42000000-0x43efffff: memory bank
31 * 0x41f00000-0x41ffffff, 0x43f00000-0x43ffffff: peripherals
Masahiro Yamada5894ca02014-10-03 19:21:06 +090032 */
33 writel(0x0000bc01, SBBASE0);
Masahiro Yamadab1156782014-12-06 00:03:19 +090034 } else {
35 /*
36 * Boot Swap Off: boot from mask ROM
Masahiro Yamadad5ed8c52015-09-11 20:17:47 +090037 * 0x40000000-0x41ffffff: mask ROM
38 * 0x42000000-0x43efffff: memory bank (31MB)
39 * 0x43f00000-0x43ffffff: peripherals (1MB)
Masahiro Yamadab1156782014-12-06 00:03:19 +090040 */
41 writel(0x0000be01, SBBASE0); /* dummy */
42 writel(0x0200be01, SBBASE1);
Masahiro Yamada5894ca02014-10-03 19:21:06 +090043 }
Masahiro Yamada323d1f92015-09-22 00:27:39 +090044
45 return 0;
Masahiro Yamada5894ca02014-10-03 19:21:06 +090046}