tamonten.c 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. /*
  2. * (C) Copyright 2010,2011
  3. * NVIDIA Corporation <www.nvidia.com>
  4. * (C) Copyright 2011
  5. * Avionic Design GmbH <www.avionic-design.de>
  6. *
  7. * See file CREDITS for list of people who contributed to this
  8. * project.
  9. *
  10. * This program is free software; you can redistribute it and/or
  11. * modify it under the terms of the GNU General Public License as
  12. * published by the Free Software Foundation; either version 2 of
  13. * the License, or (at your option) any later version.
  14. *
  15. * This program is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. * GNU General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU General Public License
  21. * along with this program; if not, write to the Free Software
  22. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  23. * MA 02111-1307 USA
  24. */
  25. #include <common.h>
  26. #include <ns16550.h>
  27. #include <asm/io.h>
  28. #include <asm/gpio.h>
  29. #include <asm/arch/tegra2.h>
  30. #include <asm/arch/sys_proto.h>
  31. #include <asm/arch/clk_rst.h>
  32. #include <asm/arch/clock.h>
  33. #include <asm/arch/pinmux.h>
  34. #include <asm/arch/uart.h>
  35. #include <asm/arch/mmc.h>
  36. #include "tamonten.h"
  37. #ifdef CONFIG_TEGRA2_MMC
  38. #include <mmc.h>
  39. #endif
  40. DECLARE_GLOBAL_DATA_PTR;
  41. const struct tegra2_sysinfo sysinfo = {
  42. CONFIG_TEGRA2_BOARD_STRING
  43. };
  44. /*
  45. * Routine: timer_init
  46. * Description: init the timestamp and lastinc value
  47. */
  48. int timer_init(void)
  49. {
  50. return 0;
  51. }
  52. static void enable_uart(enum periph_id pid)
  53. {
  54. /* Assert UART reset and enable clock */
  55. reset_set_enable(pid, 1);
  56. clock_enable(pid);
  57. clock_ll_set_source(pid, 0); /* UARTx_CLK_SRC = 00, PLLP_OUT0 */
  58. /* wait for 2us */
  59. udelay(2);
  60. /* De-assert reset to UART */
  61. reset_set_enable(pid, 0);
  62. }
  63. /*
  64. * Routine: clock_init_uart
  65. * Description: init the PLL and clock for the UART(s)
  66. */
  67. static void clock_init_uart(void)
  68. {
  69. #if defined(CONFIG_TEGRA2_ENABLE_UARTD)
  70. enable_uart(PERIPH_ID_UART4);
  71. #endif /* CONFIG_TEGRA2_ENABLE_UARTD */
  72. }
  73. /*
  74. * Routine: pin_mux_uart
  75. * Description: setup the pin muxes/tristate values for the UART(s)
  76. */
  77. static void pin_mux_uart(void)
  78. {
  79. #if defined(CONFIG_TEGRA2_ENABLE_UARTD)
  80. pinmux_set_func(PINGRP_GMC, PMUX_FUNC_UARTD);
  81. pinmux_tristate_disable(PINGRP_GMC);
  82. #endif /* CONFIG_TEGRA2_ENABLE_UARTD */
  83. }
  84. #ifdef CONFIG_TEGRA2_MMC
  85. /*
  86. * Routine: pin_mux_mmc
  87. * Description: setup the pin muxes/tristate values for the SDMMC(s)
  88. */
  89. static void pin_mux_mmc(void)
  90. {
  91. /* SDMMC4: config 3, x8 on 2nd set of pins */
  92. pinmux_set_func(PINGRP_ATB, PMUX_FUNC_SDIO4);
  93. pinmux_set_func(PINGRP_GMA, PMUX_FUNC_SDIO4);
  94. pinmux_set_func(PINGRP_GME, PMUX_FUNC_SDIO4);
  95. pinmux_tristate_disable(PINGRP_ATB);
  96. pinmux_tristate_disable(PINGRP_GMA);
  97. pinmux_tristate_disable(PINGRP_GME);
  98. }
  99. #endif
  100. /*
  101. * Routine: board_init
  102. * Description: Early hardware init.
  103. */
  104. int board_init(void)
  105. {
  106. clock_init();
  107. clock_verify();
  108. /* boot param addr */
  109. gd->bd->bi_boot_params = (NV_PA_SDRAM_BASE + 0x100);
  110. return 0;
  111. }
  112. #ifdef CONFIG_TEGRA2_MMC
  113. /* this is a weak define that we are overriding */
  114. int board_mmc_init(bd_t *bd)
  115. {
  116. debug("board_mmc_init called\n");
  117. /* Enable muxes, etc. for SDMMC controllers */
  118. pin_mux_mmc();
  119. gpio_config_mmc();
  120. debug("board_mmc_init: init eMMC\n");
  121. /* init dev 0, eMMC chip, with 4-bit bus */
  122. tegra2_mmc_init(0, 4, -1, GPIO_PH2);
  123. return 0;
  124. }
  125. #endif
  126. #ifdef CONFIG_BOARD_EARLY_INIT_F
  127. int board_early_init_f(void)
  128. {
  129. /* Initialize essential common plls */
  130. clock_early_init();
  131. /* Initialize UART clocks */
  132. clock_init_uart();
  133. /* Initialize periph pinmuxes */
  134. pin_mux_uart();
  135. return 0;
  136. }
  137. #endif /* EARLY_INIT */