fel_utils.S 951 B

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. /* SPDX-License-Identifier: GPL-2.0+ */
  2. /*
  3. * Utility functions for FEL mode.
  4. *
  5. * Copyright (c) 2015 Google, Inc
  6. */
  7. #include <asm-offsets.h>
  8. #include <config.h>
  9. #include <asm/system.h>
  10. #include <linux/linkage.h>
  11. ENTRY(save_boot_params)
  12. ldr r0, =fel_stash
  13. str sp, [r0, #0]
  14. str lr, [r0, #4]
  15. mrs lr, cpsr @ Read CPSR
  16. str lr, [r0, #8]
  17. mrc p15, 0, lr, c1, c0, 0 @ Read CP15 SCTLR Register
  18. str lr, [r0, #12]
  19. mrc p15, 0, lr, c12, c0, 0 @ Read VBAR
  20. str lr, [r0, #16]
  21. mrc p15, 0, lr, c1, c0, 0 @ Read CP15 Control Register
  22. str lr, [r0, #20]
  23. b save_boot_params_ret
  24. ENDPROC(save_boot_params)
  25. ENTRY(return_to_fel)
  26. mov sp, r0
  27. mov lr, r1
  28. ldr r0, =fel_stash
  29. ldr r1, [r0, #20]
  30. mcr p15, 0, r1, c1, c0, 0 @ Write CP15 Control Register
  31. ldr r1, [r0, #16]
  32. mcr p15, 0, r1, c12, c0, 0 @ Write VBAR
  33. ldr r1, [r0, #12]
  34. mcr p15, 0, r1, c1, c0, 0 @ Write CP15 SCTLR Register
  35. ldr r1, [r0, #8]
  36. msr cpsr, r1 @ Write CPSR
  37. bx lr
  38. ENDPROC(return_to_fel)