omap_common.h 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. /*
  2. * (C) Copyright 2010
  3. * Texas Instruments, <www.ti.com>
  4. *
  5. * Aneesh V <aneesh@ti.com>
  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. #ifndef _OMAP_COMMON_H_
  26. #define _OMAP_COMMON_H_
  27. /* Max value for DPLL multiplier M */
  28. #define OMAP_DPLL_MAX_N 127
  29. /* HW Init Context */
  30. #define OMAP_INIT_CONTEXT_SPL 0
  31. #define OMAP_INIT_CONTEXT_UBOOT_FROM_NOR 1
  32. #define OMAP_INIT_CONTEXT_UBOOT_AFTER_SPL 2
  33. #define OMAP_INIT_CONTEXT_UBOOT_AFTER_CH 3
  34. void preloader_console_init(void);
  35. /* Boot device */
  36. #ifdef CONFIG_OMAP54XX
  37. #define BOOT_DEVICE_NONE 0
  38. #define BOOT_DEVICE_XIP 1
  39. #define BOOT_DEVICE_XIPWAIT 2
  40. #define BOOT_DEVICE_NAND 3
  41. #define BOOT_DEVICE_ONE_NAND 4
  42. #define BOOT_DEVICE_MMC1 5
  43. #define BOOT_DEVICE_MMC2 6
  44. #define BOOT_DEVICE_MMC2_2 7
  45. #elif defined(CONFIG_OMAP44XX) /* OMAP4 */
  46. #define BOOT_DEVICE_NONE 0
  47. #define BOOT_DEVICE_XIP 1
  48. #define BOOT_DEVICE_XIPWAIT 2
  49. #define BOOT_DEVICE_NAND 3
  50. #define BOOT_DEVICE_ONE_NAND 4
  51. #define BOOT_DEVICE_MMC1 5
  52. #define BOOT_DEVICE_MMC2 6
  53. #define BOOT_DEVICE_MMC2_2 0xFF
  54. #elif defined(CONFIG_OMAP34XX) /* OMAP3 */
  55. #define BOOT_DEVICE_NONE 0
  56. #define BOOT_DEVICE_XIP 1
  57. #define BOOT_DEVICE_NAND 2
  58. #define BOOT_DEVICE_ONE_NAND 3
  59. #define BOOT_DEVICE_MMC2 5 /*emmc*/
  60. #define BOOT_DEVICE_MMC1 6
  61. #define BOOT_DEVICE_XIPWAIT 7
  62. #define BOOT_DEVICE_MMC2_2 0xFF
  63. #elif defined(CONFIG_AM33XX) /* AM33XX */
  64. #define BOOT_DEVICE_NAND 5
  65. #define BOOT_DEVICE_MMC1 8
  66. #define BOOT_DEVICE_MMC2 9 /* eMMC or daughter card */
  67. #define BOOT_DEVICE_UART 65
  68. #define BOOT_DEVICE_MMC2_2 0xFF
  69. #endif
  70. /* Boot type */
  71. #define MMCSD_MODE_UNDEFINED 0
  72. #define MMCSD_MODE_RAW 1
  73. #define MMCSD_MODE_FAT 2
  74. #define NAND_MODE_HW_ECC 3
  75. struct spl_image_info {
  76. const char *name;
  77. u8 os;
  78. u32 load_addr;
  79. u32 entry_point;
  80. u32 size;
  81. };
  82. extern struct spl_image_info spl_image;
  83. extern u32* boot_params_ptr;
  84. u32 spl_boot_device(void);
  85. u32 omap_boot_mode(void);
  86. /* SPL common function s*/
  87. void spl_parse_image_header(const struct image_header *header);
  88. void spl_board_prepare_for_linux(void);
  89. int spl_start_uboot(void);
  90. void spl_display_print(void);
  91. /* NAND SPL functions */
  92. void spl_nand_load_image(void);
  93. /* MMC SPL functions */
  94. void spl_mmc_load_image(void);
  95. /* YMODEM SPL functions */
  96. void spl_ymodem_load_image(void);
  97. #ifdef CONFIG_SPL_BOARD_INIT
  98. void spl_board_init(void);
  99. #endif
  100. static inline u32 omap_revision(void)
  101. {
  102. extern u32 *const omap_si_rev;
  103. return *omap_si_rev;
  104. }
  105. /*
  106. * silicon revisions.
  107. * Moving this to common, so that most of code can be moved to common,
  108. * directories.
  109. */
  110. /* omap4 */
  111. #define OMAP4430_SILICON_ID_INVALID 0xFFFFFFFF
  112. #define OMAP4430_ES1_0 0x44300100
  113. #define OMAP4430_ES2_0 0x44300200
  114. #define OMAP4430_ES2_1 0x44300210
  115. #define OMAP4430_ES2_2 0x44300220
  116. #define OMAP4430_ES2_3 0x44300230
  117. #define OMAP4460_ES1_0 0x44600100
  118. #define OMAP4460_ES1_1 0x44600110
  119. /* omap5 */
  120. #define OMAP5430_SILICON_ID_INVALID 0
  121. #define OMAP5430_ES1_0 0x54300100
  122. #define OMAP5432_ES1_0 0x54320100
  123. #endif /* _OMAP_COMMON_H_ */