spl.c 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /*
  2. * Copyright (C) 2013 Atmel Corporation
  3. * Bo Shen <voice.shen@atmel.com>
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #include <common.h>
  8. #include <asm/io.h>
  9. #include <asm/arch/at91_common.h>
  10. #include <asm/arch/at91_wdt.h>
  11. #include <asm/arch/clk.h>
  12. #include <spl.h>
  13. #if defined(CONFIG_AT91SAM9_WATCHDOG)
  14. void at91_disable_wdt(void) { }
  15. #else
  16. void at91_disable_wdt(void)
  17. {
  18. struct at91_wdt *wdt = (struct at91_wdt *)ATMEL_BASE_WDT;
  19. writel(AT91_WDT_MR_WDDIS, &wdt->mr);
  20. }
  21. #endif
  22. #if defined(CONFIG_SAMA5D2) || defined(CONFIG_SAMA5D3) || \
  23. defined(CONFIG_SAMA5D4)
  24. #include <asm/arch/sama5_boot.h>
  25. struct {
  26. u32 r4;
  27. } bootrom_stash __attribute__((section(".data")));
  28. u32 spl_boot_device(void)
  29. {
  30. u32 dev = (bootrom_stash.r4 >> ATMEL_SAMA5_BOOT_FROM_OFF) &
  31. ATMEL_SAMA5_BOOT_FROM_MASK;
  32. u32 off = (bootrom_stash.r4 >> ATMEL_SAMA5_BOOT_DEV_ID_OFF) &
  33. ATMEL_SAMA5_BOOT_DEV_ID_MASK;
  34. #if defined(CONFIG_SYS_USE_MMC)
  35. if (dev == ATMEL_SAMA5_BOOT_FROM_MCI) {
  36. #if defined(CONFIG_SPL_OF_CONTROL)
  37. return BOOT_DEVICE_MMC1;
  38. #else
  39. if (off == 0)
  40. return BOOT_DEVICE_MMC1;
  41. if (off == 1)
  42. return BOOT_DEVICE_MMC2;
  43. printf("ERROR: MMC controller %i not present!\n", dev);
  44. hang();
  45. #endif
  46. }
  47. #endif
  48. #if defined(CONFIG_SYS_USE_SERIALFLASH) || defined(CONFIG_SYS_USE_SPIFLASH)
  49. if (dev == ATMEL_SAMA5_BOOT_FROM_SPI)
  50. return BOOT_DEVICE_SPI;
  51. #endif
  52. if (dev == ATMEL_SAMA5_BOOT_FROM_QSPI)
  53. return BOOT_DEVICE_SPI;
  54. if (dev == ATMEL_SAMA5_BOOT_FROM_SMC)
  55. return BOOT_DEVICE_NAND;
  56. if (dev == ATMEL_SAMA5_BOOT_FROM_SAMBA)
  57. return BOOT_DEVICE_USB;
  58. printf("ERROR: SMC/TWI/QSPI boot device not supported!\n"
  59. " Boot device %i, controller number %i\n", dev, off);
  60. return BOOT_DEVICE_NONE;
  61. }
  62. #else
  63. u32 spl_boot_device(void)
  64. {
  65. #ifdef CONFIG_SYS_USE_MMC
  66. return BOOT_DEVICE_MMC1;
  67. #elif CONFIG_SYS_USE_NANDFLASH
  68. return BOOT_DEVICE_NAND;
  69. #elif CONFIG_SYS_USE_SERIALFLASH || CONFIG_SYS_USE_SPIFLASH
  70. return BOOT_DEVICE_SPI;
  71. #endif
  72. return BOOT_DEVICE_NONE;
  73. }
  74. #endif
  75. u32 spl_boot_mode(const u32 boot_device)
  76. {
  77. switch (boot_device) {
  78. #ifdef CONFIG_SYS_USE_MMC
  79. case BOOT_DEVICE_MMC1:
  80. case BOOT_DEVICE_MMC2:
  81. return MMCSD_MODE_FS;
  82. break;
  83. #endif
  84. case BOOT_DEVICE_NONE:
  85. default:
  86. hang();
  87. }
  88. }