overo.c 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. /*
  2. * Maintainer : Steve Sakoman <steve@sakoman.com>
  3. *
  4. * Derived from Beagle Board, 3430 SDP, and OMAP3EVM code by
  5. * Richard Woodruff <r-woodruff2@ti.com>
  6. * Syed Mohammed Khasim <khasim@ti.com>
  7. * Sunil Kumar <sunilsaini05@gmail.com>
  8. * Shashi Ranjan <shashiranjanmca05@gmail.com>
  9. *
  10. * (C) Copyright 2004-2008
  11. * Texas Instruments, <www.ti.com>
  12. *
  13. * See file CREDITS for list of people who contributed to this
  14. * project.
  15. *
  16. * This program is free software; you can redistribute it and/or
  17. * modify it under the terms of the GNU General Public License as
  18. * published by the Free Software Foundation; either version 2 of
  19. * the License, or (at your option) any later version.
  20. *
  21. * This program is distributed in the hope that it will be useful,
  22. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  23. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  24. * GNU General Public License for more details.
  25. *
  26. * You should have received a copy of the GNU General Public License
  27. * along with this program; if not, write to the Free Software
  28. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  29. * MA 02111-1307 USA
  30. */
  31. #include <common.h>
  32. #include <asm/io.h>
  33. #include <asm/arch/mux.h>
  34. #include <asm/arch/sys_proto.h>
  35. #include <asm/mach-types.h>
  36. #include "overo.h"
  37. /******************************************************************************
  38. * Routine: board_init
  39. * Description: Early hardware init.
  40. *****************************************************************************/
  41. int board_init(void)
  42. {
  43. DECLARE_GLOBAL_DATA_PTR;
  44. gpmc_init(); /* in SRAM or SDRAM, finish GPMC */
  45. /* board id for Linux */
  46. gd->bd->bi_arch_number = MACH_TYPE_OVERO;
  47. /* boot param addr */
  48. gd->bd->bi_boot_params = (OMAP34XX_SDRC_CS0 + 0x100);
  49. return 0;
  50. }
  51. /******************************************************************************
  52. * Routine: misc_init_r
  53. * Description: Configure board specific parts
  54. *****************************************************************************/
  55. int misc_init_r(void)
  56. {
  57. gpio_t *gpio5_base = (gpio_t *)OMAP34XX_GPIO5_BASE;
  58. gpio_t *gpio6_base = (gpio_t *)OMAP34XX_GPIO6_BASE;
  59. power_init_r();
  60. /* Configure GPIOs to output */
  61. writel(~((GPIO10) | GPIO9 | GPIO3 | GPIO2), &gpio6_base->oe);
  62. writel(~(GPIO31 | GPIO30 | GPIO29 | GPIO28 | GPIO22 | GPIO21 |
  63. GPIO15 | GPIO14 | GPIO13 | GPIO12), &gpio5_base->oe);
  64. /* Set GPIOs */
  65. writel(GPIO10 | GPIO9 | GPIO3 | GPIO2, &gpio6_base->setdataout);
  66. writel(GPIO31 | GPIO30 | GPIO29 | GPIO28 | GPIO22 | GPIO21 |
  67. GPIO15 | GPIO14 | GPIO13 | GPIO12, &gpio5_base->setdataout);
  68. return 0;
  69. }
  70. /******************************************************************************
  71. * Routine: set_muxconf_regs
  72. * Description: Setting up the configuration Mux registers specific to the
  73. * hardware. Many pins need to be moved from protect to primary
  74. * mode.
  75. *****************************************************************************/
  76. void set_muxconf_regs(void)
  77. {
  78. MUX_OVERO();
  79. }