Files
luban-lite-t3e-pro/bsp/artinchip/sys/d13x/boot_param_gcc.S

61 lines
1.3 KiB
ArmAsm
Raw Normal View History

2023-08-30 16:21:18 +08:00
/*
2024-09-03 11:16:08 +08:00
* Copyright (C) 2023-2024 ArtInChip Technology Co.,Ltd
*
* SPDX-License-Identifier: Apache-2.0
*
2023-08-30 16:21:18 +08:00
* Author: Dehuang Wu <dehuang.wu@artinchip.com>
*/
2024-09-03 11:16:08 +08:00
#include <rtconfig.h>
2023-08-30 16:21:18 +08:00
#define LREG lw
#define SREG sw
#define REGBYTES 4
.extern boot_params_stash
2024-09-03 11:16:08 +08:00
#ifndef AIC_BOOTLOADER
.extern boot_arg
#endif
2023-08-30 16:21:18 +08:00
.global save_boot_params
.type save_boot_params, %function
save_boot_params:
la t0, boot_params_stash
SREG a0, REGBYTES * 0(t0)
SREG a1, REGBYTES * 1(t0)
SREG a2, REGBYTES * 2(t0)
SREG a3, REGBYTES * 3(t0)
SREG a4, REGBYTES * 4(t0)
SREG a5, REGBYTES * 5(t0)
SREG a6, REGBYTES * 6(t0)
SREG a7, REGBYTES * 7(t0)
SREG s0, REGBYTES * 8(t0)
SREG s1, REGBYTES * 9(t0)
SREG s2, REGBYTES * 10(t0)
SREG s3, REGBYTES * 11(t0)
SREG s4, REGBYTES * 12(t0)
SREG s5, REGBYTES * 13(t0)
SREG s6, REGBYTES * 14(t0)
SREG s7, REGBYTES * 15(t0)
SREG s8, REGBYTES * 16(t0)
SREG s9, REGBYTES * 17(t0)
SREG s10, REGBYTES * 18(t0)
SREG s11, REGBYTES * 19(t0)
SREG sp, REGBYTES * 20(t0)
SREG ra, REGBYTES * 21(t0)
2024-09-03 11:16:08 +08:00
#ifndef AIC_BOOTLOADER
beqz a1, 2f
/* copy boot_arg from SPL to OS */
la t0, boot_arg
mv t1, a1
/* boot_arg size is 256 bytes */
addi t2, t1, 0xFF
1:
LREG t3, (t1)
SREG t3, (t0)
addi t0, t0, REGBYTES
addi t1, t1, REGBYTES
bltu t1, t2, 1b
2:
#endif
2023-08-30 16:21:18 +08:00
j save_boot_params_ret