forked from ariadne/libucontext
57 lines
1.6 KiB
ArmAsm
57 lines
1.6 KiB
ArmAsm
|
/*
|
||
|
* Copyright (c) 2020 Ariadne Conill <ariadne@dereferenced.org>
|
||
|
*
|
||
|
* Permission to use, copy, modify, and/or distribute this software for any
|
||
|
* purpose with or without fee is hereby granted, provided that the above
|
||
|
* copyright notice and this permission notice appear in all copies.
|
||
|
*
|
||
|
* This software is provided 'as is' and without any warranty, express or
|
||
|
* implied. In no event shall the authors be liable for any damages arising
|
||
|
* from the use of this software.
|
||
|
*/
|
||
|
|
||
|
#include "defs.h"
|
||
|
|
||
|
ALIAS(setcontext, libucontext_setcontext)
|
||
|
ALIAS(__setcontext, libucontext_setcontext)
|
||
|
|
||
|
FUNC(libucontext_setcontext)
|
||
|
/* move $a0 to $t0 to avoid clobbering. */
|
||
|
mv t0, a0
|
||
|
|
||
|
lw t1, PC_OFFSET(t0)
|
||
|
lw ra, REG_OFFSET(REG_RA)(t0)
|
||
|
lw sp, REG_OFFSET(REG_SP)(t0)
|
||
|
|
||
|
/* first saved register block */
|
||
|
lw s0, REG_OFFSET(REG_S0)(t0)
|
||
|
lw s1, REG_OFFSET(REG_S1)(t0)
|
||
|
|
||
|
/* return register block */
|
||
|
lw a0, REG_OFFSET(REG_A0)(t0)
|
||
|
lw a1, REG_OFFSET(REG_A1)(t0)
|
||
|
|
||
|
/* argument register block */
|
||
|
lw a2, REG_OFFSET(REG_A2)(t0)
|
||
|
lw a3, REG_OFFSET(REG_A3)(t0)
|
||
|
lw a4, REG_OFFSET(REG_A4)(t0)
|
||
|
lw a5, REG_OFFSET(REG_A5)(t0)
|
||
|
lw a6, REG_OFFSET(REG_A6)(t0)
|
||
|
lw a7, REG_OFFSET(REG_A7)(t0)
|
||
|
|
||
|
/* second saved register block */
|
||
|
lw s2, REG_OFFSET(REG_S2)(t0)
|
||
|
lw s3, REG_OFFSET(REG_S3)(t0)
|
||
|
lw s4, REG_OFFSET(REG_S4)(t0)
|
||
|
lw s5, REG_OFFSET(REG_S5)(t0)
|
||
|
lw s6, REG_OFFSET(REG_S6)(t0)
|
||
|
lw s7, REG_OFFSET(REG_S7)(t0)
|
||
|
lw s8, REG_OFFSET(REG_S8)(t0)
|
||
|
lw s9, REG_OFFSET(REG_S9)(t0)
|
||
|
lw s10, REG_OFFSET(REG_S10)(t0)
|
||
|
lw s11, REG_OFFSET(REG_S11)(t0)
|
||
|
|
||
|
/* done restoring, jump to new pc in S1 */
|
||
|
jr t1
|
||
|
END(libucontext_setcontext)
|