blob: f50644c52bbc9ef078b7d62dc3525e5def94c1e0 [file] [log] [blame]
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +09001/*
Masahiro Yamada663a23f2015-05-29 17:30:00 +09002 * Copyright (C) 2011-2015 Masahiro Yamada <yamada.masahiro@socionext.com>
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +09003 *
4 * SPDX-License-Identifier: GPL-2.0+
5 */
6
Masahiro Yamada663a23f2015-05-29 17:30:00 +09007#include <linux/io.h>
Masahiro Yamada75f16f82015-09-22 00:27:39 +09008#include <mach/init.h>
Masahiro Yamada95387e22015-02-27 02:26:44 +09009#include <mach/sg-regs.h>
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090010
Masahiro Yamada75f16f82015-09-22 00:27:39 +090011void ph1_pro4_pin_init(void)
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090012{
13 /* Comment format: PAD Name -> Function Name */
14
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090015#ifdef CONFIG_NAND_DENALI
Masahiro Yamada6e429742015-09-11 20:17:48 +090016 sg_set_pinsel(40, 0, 4, 8); /* NFD0 -> NFD0 */
17 sg_set_pinsel(41, 0, 4, 8); /* NFD1 -> NFD1 */
18 sg_set_pinsel(42, 0, 4, 8); /* NFD2 -> NFD2 */
19 sg_set_pinsel(43, 0, 4, 8); /* NFD3 -> NFD3 */
20 sg_set_pinsel(44, 0, 4, 8); /* NFD4 -> NFD4 */
21 sg_set_pinsel(45, 0, 4, 8); /* NFD5 -> NFD5 */
22 sg_set_pinsel(46, 0, 4, 8); /* NFD6 -> NFD6 */
23 sg_set_pinsel(47, 0, 4, 8); /* NFD7 -> NFD7 */
24 sg_set_pinsel(48, 0, 4, 8); /* NFALE -> NFALE */
25 sg_set_pinsel(49, 0, 4, 8); /* NFCLE -> NFCLE */
26 sg_set_pinsel(50, 0, 4, 8); /* XNFRE -> XNFRE */
27 sg_set_pinsel(51, 0, 4, 8); /* XNFWE -> XNFWE */
28 sg_set_pinsel(52, 0, 4, 8); /* XNFWP -> XNFWP */
29 sg_set_pinsel(53, 0, 4, 8); /* XNFCE0 -> XNFCE0 */
30 sg_set_pinsel(54, 0, 4, 8); /* NRYBY0 -> NRYBY0 */
31 /* sg_set_pinsel(131, 1, 4, 8); */ /* RXD2 -> NRYBY1 */
32 /* sg_set_pinsel(132, 1, 4, 8); */ /* TXD2 -> XNFCE1 */
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090033#endif
34
Masahiro Yamadaf73264b2015-02-27 02:26:57 +090035#ifdef CONFIG_USB_XHCI_UNIPHIER
Masahiro Yamada6e429742015-09-11 20:17:48 +090036 sg_set_pinsel(180, 0, 4, 8); /* USB0VBUS -> USB0VBUS */
37 sg_set_pinsel(181, 0, 4, 8); /* USB0OD -> USB0OD */
38 sg_set_pinsel(182, 0, 4, 8); /* USB1VBUS -> USB1VBUS */
39 sg_set_pinsel(183, 0, 4, 8); /* USB1OD -> USB1OD */
Masahiro Yamadaf73264b2015-02-27 02:26:57 +090040#endif
41
Masahiro Yamadac5f67ba2014-11-07 18:33:52 +090042#ifdef CONFIG_USB_EHCI_UNIPHIER
Masahiro Yamada6e429742015-09-11 20:17:48 +090043 sg_set_pinsel(184, 0, 4, 8); /* USB2VBUS -> USB2VBUS */
44 sg_set_pinsel(185, 0, 4, 8); /* USB2OD -> USB2OD */
45 sg_set_pinsel(187, 0, 4, 8); /* USB3VBUS -> USB3VBUS */
46 sg_set_pinsel(188, 0, 4, 8); /* USB3OD -> USB3OD */
Masahiro Yamadac5f67ba2014-11-07 18:33:52 +090047#endif
48
Masahiro Yamadabb2ff9d2014-10-03 19:21:06 +090049 writel(1, SG_LOADPINCTRL);
50}