omap_common.h 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  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_MMC3 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. #elif defined(CONFIG_OMAP34XX) /* OMAP3 */
  54. #define BOOT_DEVICE_NONE 0
  55. #define BOOT_DEVICE_XIP 1
  56. #define BOOT_DEVICE_NAND 2
  57. #define BOOT_DEVICE_ONE_NAND 3
  58. #define BOOT_DEVICE_MMC2 5 /*emmc*/
  59. #define BOOT_DEVICE_MMC1 6
  60. #define BOOT_DEVICE_XIPWAIT 7
  61. #endif
  62. /* Boot type */
  63. #define MMCSD_MODE_UNDEFINED 0
  64. #define MMCSD_MODE_RAW 1
  65. #define MMCSD_MODE_FAT 2
  66. #define NAND_MODE_HW_ECC 3
  67. struct spl_image_info {
  68. const char *name;
  69. u8 os;
  70. u32 load_addr;
  71. u32 entry_point;
  72. u32 size;
  73. };
  74. extern struct spl_image_info spl_image;
  75. extern u32* boot_params_ptr;
  76. u32 omap_boot_device(void);
  77. u32 omap_boot_mode(void);
  78. /* SPL common function s*/
  79. void spl_parse_image_header(const struct image_header *header);
  80. void omap_rev_string(char *omap_rev_string);
  81. /* NAND SPL functions */
  82. void spl_nand_load_image(void);
  83. /* MMC SPL functions */
  84. void spl_mmc_load_image(void);
  85. #ifdef CONFIG_SPL_BOARD_INIT
  86. void spl_board_init(void);
  87. #endif
  88. /*
  89. * silicon revisions.
  90. * Moving this to common, so that most of code can be moved to common,
  91. * directories.
  92. */
  93. /* omap4 */
  94. #define OMAP4430_SILICON_ID_INVALID 0xFFFFFFFF
  95. #define OMAP4430_ES1_0 0x44300100
  96. #define OMAP4430_ES2_0 0x44300200
  97. #define OMAP4430_ES2_1 0x44300210
  98. #define OMAP4430_ES2_2 0x44300220
  99. #define OMAP4430_ES2_3 0x44300230
  100. #define OMAP4460_ES1_0 0x44600100
  101. #define OMAP4460_ES1_1 0x44600110
  102. /* omap5 */
  103. #define OMAP5430_SILICON_ID_INVALID 0
  104. #define OMAP5430_ES1_0 0x54300100
  105. #endif /* _OMAP_COMMON_H_ */