spl.c 946 B

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. /*
  2. * (C) Copyright 2012
  3. * NVIDIA Inc, <www.nvidia.com>
  4. *
  5. * Allen Martin <amartin@nvidia.com>
  6. *
  7. * SPDX-License-Identifier: GPL-2.0+
  8. */
  9. #include <common.h>
  10. #include <spl.h>
  11. #include <asm/io.h>
  12. #include <asm/arch/clock.h>
  13. #include <asm/arch/pinmux.h>
  14. #include <asm/arch/tegra.h>
  15. #include <asm/arch-tegra/apb_misc.h>
  16. #include <asm/arch-tegra/board.h>
  17. #include <asm/spl.h>
  18. #include "cpu.h"
  19. void spl_board_init(void)
  20. {
  21. struct apb_misc_pp_ctlr *apb_misc =
  22. (struct apb_misc_pp_ctlr *)NV_PA_APB_MISC_BASE;
  23. /* enable JTAG */
  24. writel(0xC0, &apb_misc->cfg_ctl);
  25. board_init_uart_f();
  26. /* Initialize periph GPIOs */
  27. gpio_early_init_uart();
  28. clock_early_init();
  29. preloader_console_init();
  30. }
  31. u32 spl_boot_device(void)
  32. {
  33. return BOOT_DEVICE_RAM;
  34. }
  35. void __noreturn jump_to_image_no_args(struct spl_image_info *spl_image)
  36. {
  37. debug("image entry point: 0x%X\n", spl_image->entry_point);
  38. start_cpu((u32)spl_image->entry_point);
  39. halt_avp();
  40. }