ARM: tegra12: set CPU rate to 2.2GHz for sku 0x87
[linux-3.10.git] / arch / arm / mach-tegra / board-loki-pinmux.c
1 /*
2  * arch/arm/mach-tegra/board-loki-pinmux.c
3  *
4  * Copyright (c) 2013, NVIDIA Corporation. All rights reserved.
5  *
6  * This software is licensed under the terms of the GNU General Public
7  * License version 2, as published by the Free Software Foundation, and
8  * may be copied, distributed, and modified under those terms.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU General Public License for more details.
14  *
15  */
16
17 #include <linux/kernel.h>
18 #include <linux/init.h>
19 #include <linux/gpio.h>
20 #include <mach/pinmux.h>
21 #include <mach/gpio-tegra.h>
22
23 #include "board.h"
24 #include "board-loki.h"
25 #include "tegra-board-id.h"
26 #include "devices.h"
27 #include "gpio-names.h"
28
29 #include <mach/pinmux-t12.h>
30
31 /* Pinmux changes to support UART over uSD adapter E2542 */
32 static __initdata struct tegra_pingroup_config loki_sdmmc3_uart_pinmux[] = {
33
34         DEFAULT_PINMUX(SDMMC3_CMD,    UARTA,      NORMAL,   NORMAL,   INPUT),
35         DEFAULT_PINMUX(SDMMC3_DAT1,   UARTA,      NORMAL,   NORMAL,   OUTPUT),
36 };
37
38 static __initdata struct tegra_pingroup_config loki_ffd_pinmux_common[] = { 
39         GPIO_PINMUX_NON_OD(DP_HPD, PULL_DOWN, NORMAL, OUTPUT),
40 };
41
42 static struct gpio_init_pin_info init_gpio_mode_loki_ffd_common[] = {
43         GPIO_INIT_PIN_MODE(TEGRA_GPIO_PFF0, false, 0),
44 };
45
46 static void __init loki_gpio_init_configure(void)
47 {
48         int len;
49         int i;
50         struct gpio_init_pin_info *pins_info;
51
52         len = ARRAY_SIZE(init_gpio_mode_loki_ffd_common);
53         pins_info = init_gpio_mode_loki_ffd_common;
54
55         for (i = 0; i < len; ++i) {
56                 tegra_gpio_init_configure(pins_info->gpio_nr,
57                         pins_info->is_input, pins_info->value);
58                 pins_info++;
59         }
60 }
61
62 int __init loki_pinmux_init(void)
63 {
64         struct board_info bi;
65
66         tegra_get_board_info(&bi);
67         if (bi.board_id == BOARD_P2530) {
68                 loki_gpio_init_configure();
69                 tegra_pinmux_config_table(loki_ffd_pinmux_common,
70                         ARRAY_SIZE(loki_ffd_pinmux_common));
71         };
72
73         if (is_uart_over_sd_enabled()) {
74                 tegra_pinmux_config_table(loki_sdmmc3_uart_pinmux,
75                                  ARRAY_SIZE(loki_sdmmc3_uart_pinmux));
76                 /* On loki, UART-A is the physical device for
77                  * UART over uSD card
78                  */
79                 set_sd_uart_port_id(0);
80         }
81         return 0;
82 }