__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
/*
* this is the internal transfer function.
*
* HISTORY
* 14-Aug-06 File creation. Ported from Arm Thumb. Sylvain Baro
* 3-Sep-06 Commented out saving of r1-r3 (r4 already commented out) as I
* read that these do not need to be saved. Also added notes and
* errors related to the frame pointer. Richard Tew.
*
* NOTES
*
* It is not possible to detect if fp is used or not, so the supplied
* switch function needs to support it, so that you can remove it if
* it does not apply to you.
*
* POSSIBLE ERRORS
*
* "fp cannot be used in asm here"
*
* - Try commenting out "fp" in REGS_TO_SAVE.
*
*/
#define STACK_REFPLUS 1
#ifdef SLP_EVAL
#define STACK_MAGIC 0
#define REG_SP "sp"
#define REG_SPSP "sp,sp"
#ifdef __thumb__
#define REG_FP "r7"
#define REG_FPFP "r7,r7"
#define REGS_TO_SAVE_GENERAL "r4", "r5", "r6", "r8", "r9", "r10", "r11", "lr"
#else
#define REG_FP "fp"
#define REG_FPFP "fp,fp"
#define REGS_TO_SAVE_GENERAL "r4", "r5", "r6", "r7", "r8", "r9", "r10", "lr"
#endif
#if defined(__SOFTFP__)
#define REGS_TO_SAVE REGS_TO_SAVE_GENERAL
#elif defined(__VFP_FP__)
#define REGS_TO_SAVE REGS_TO_SAVE_GENERAL, "d8", "d9", "d10", "d11", \
"d12", "d13", "d14", "d15"
#elif defined(__MAVERICK__)
#define REGS_TO_SAVE REGS_TO_SAVE_GENERAL, "mvf4", "mvf5", "mvf6", "mvf7", \
"mvf8", "mvf9", "mvf10", "mvf11", \
"mvf12", "mvf13", "mvf14", "mvf15"
#else
#define REGS_TO_SAVE REGS_TO_SAVE_GENERAL, "f4", "f5", "f6", "f7"
#endif
static int
#ifdef __GNUC__
__attribute__((optimize("no-omit-frame-pointer")))
#endif
slp_switch(void)
{
void *fp;
int *stackref, stsizediff;
int result;
__asm__ volatile ("" : : : REGS_TO_SAVE);
__asm__ volatile ("mov r0," REG_FP "\n\tstr r0,%0" : "=m" (fp) : : "r0");
__asm__ ("mov %0," REG_SP : "=r" (stackref));
{
SLP_SAVE_STATE(stackref, stsizediff);
__asm__ volatile (
"add " REG_SPSP ",%0\n"
"add " REG_FPFP ",%0\n"
:
: "r" (stsizediff)
);
SLP_RESTORE_STATE();
}
__asm__ volatile ("ldr r0,%1\n\tmov " REG_FP ",r0\n\tmov %0, #0" : "=r" (result) : "m" (fp) : "r0");
__asm__ volatile ("" : : : REGS_TO_SAVE);
return result;
}
#endif
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| __pycache__ | Folder | 0755 |
|
|
| __init__.py | File | 0 B | 0644 |
|
| setup_switch_x64_masm.cmd | File | 143 B | 0644 |
|
| switch_aarch64_gcc.h | File | 4.21 KB | 0644 |
|
| switch_alpha_unix.h | File | 671 B | 0644 |
|
| switch_amd64_unix.h | File | 2.68 KB | 0644 |
|
| switch_arm32_gcc.h | File | 2.42 KB | 0644 |
|
| switch_arm32_ios.h | File | 1.85 KB | 0644 |
|
| switch_arm64_masm.asm | File | 1.22 KB | 0644 |
|
| switch_arm64_masm.obj | File | 746 B | 0644 |
|
| switch_arm64_msvc.h | File | 398 B | 0644 |
|
| switch_csky_gcc.h | File | 1.3 KB | 0644 |
|
| switch_loongarch64_linux.h | File | 779 B | 0644 |
|
| switch_m68k_gcc.h | File | 928 B | 0644 |
|
| switch_mips_unix.h | File | 1.43 KB | 0644 |
|
| switch_ppc64_aix.h | File | 3.77 KB | 0644 |
|
| switch_ppc64_linux.h | File | 3.73 KB | 0644 |
|
| switch_ppc_aix.h | File | 2.87 KB | 0644 |
|
| switch_ppc_linux.h | File | 2.69 KB | 0644 |
|
| switch_ppc_macosx.h | File | 2.56 KB | 0644 |
|
| switch_ppc_unix.h | File | 2.59 KB | 0644 |
|
| switch_riscv_unix.h | File | 949 B | 0644 |
|
| switch_s390_unix.h | File | 2.7 KB | 0644 |
|
| switch_sh_gcc.h | File | 901 B | 0644 |
|
| switch_sparc_sun_gcc.h | File | 2.73 KB | 0644 |
|
| switch_x32_unix.h | File | 1.47 KB | 0644 |
|
| switch_x64_masm.asm | File | 1.8 KB | 0644 |
|
| switch_x64_masm.obj | File | 1.05 KB | 0644 |
|
| switch_x64_msvc.h | File | 1.76 KB | 0644 |
|
| switch_x86_msvc.h | File | 12.54 KB | 0644 |
|
| switch_x86_unix.h | File | 2.99 KB | 0644 |
|