blob: 33b9c5b73d1be1bd45cda92216b1a738fe2f4045 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Masahiro Yamada8e0a4502017-05-15 14:26:33 +09002/*
3 * Copyright (C) 2017 Socionext Inc.
Masahiro Yamada8e0a4502017-05-15 14:26:33 +09004 */
5
Masahiro Yamada6ffe71a2017-09-15 21:43:22 +09006#include <linux/bitops.h>
Masahiro Yamada8e0a4502017-05-15 14:26:33 +09007#include <linux/io.h>
8
9#include "../init.h"
Masahiro Yamada6ffe71a2017-09-15 21:43:22 +090010#include "../sc64-regs.h"
Masahiro Yamada8e0a4502017-05-15 14:26:33 +090011
12#define SDCTRL_EMMC_HW_RESET 0x59810280
13
14void uniphier_pxs3_clk_init(void)
15{
Masahiro Yamada6ffe71a2017-09-15 21:43:22 +090016 u32 tmp;
17
Masahiro Yamadac84024c2019-07-10 20:07:41 +090018 tmp = readl(sc_base + SC_RSTCTRL6);
Masahiro Yamada6ffe71a2017-09-15 21:43:22 +090019 tmp |= BIT(8); /* Mali */
Masahiro Yamadac84024c2019-07-10 20:07:41 +090020 writel(tmp, sc_base + SC_RSTCTRL6);
Masahiro Yamada6ffe71a2017-09-15 21:43:22 +090021
Masahiro Yamadac84024c2019-07-10 20:07:41 +090022 tmp = readl(sc_base + SC_CLKCTRL6);
Masahiro Yamada6ffe71a2017-09-15 21:43:22 +090023 tmp |= BIT(8); /* Mali */
Masahiro Yamadac84024c2019-07-10 20:07:41 +090024 writel(tmp, sc_base + SC_CLKCTRL6);
Masahiro Yamada6ffe71a2017-09-15 21:43:22 +090025
Masahiro Yamada8e0a4502017-05-15 14:26:33 +090026 /* TODO: use "mmc-pwrseq-emmc" */
27 writel(1, SDCTRL_EMMC_HW_RESET);
28}