opt
/
hc_python
/
lib
/
python3.12
/
site-packages
/
greenlet
/
platform
/
Go to Home Directory
+
Upload
Create File
root@0UT1S:~$
Execute
By Order of Mr.0UT1S
[DIR] ..
N/A
[DIR] __pycache__
N/A
__init__.py
0 bytes
Rename
Delete
setup_switch_x64_masm.cmd
143 bytes
Rename
Delete
switch_aarch64_gcc.h
4.21 KB
Rename
Delete
switch_alpha_unix.h
671 bytes
Rename
Delete
switch_amd64_unix.h
2.68 KB
Rename
Delete
switch_arm32_gcc.h
2.42 KB
Rename
Delete
switch_arm32_ios.h
1.85 KB
Rename
Delete
switch_arm64_masm.asm
1.22 KB
Rename
Delete
switch_arm64_masm.obj
746 bytes
Rename
Delete
switch_arm64_msvc.h
398 bytes
Rename
Delete
switch_csky_gcc.h
1.30 KB
Rename
Delete
switch_loongarch64_linux.h
779 bytes
Rename
Delete
switch_m68k_gcc.h
928 bytes
Rename
Delete
switch_mips_unix.h
1.39 KB
Rename
Delete
switch_ppc64_aix.h
3.77 KB
Rename
Delete
switch_ppc64_linux.h
3.73 KB
Rename
Delete
switch_ppc_aix.h
2.87 KB
Rename
Delete
switch_ppc_linux.h
2.69 KB
Rename
Delete
switch_ppc_macosx.h
2.56 KB
Rename
Delete
switch_ppc_unix.h
2.59 KB
Rename
Delete
switch_riscv_unix.h
865 bytes
Rename
Delete
switch_s390_unix.h
2.70 KB
Rename
Delete
switch_sh_gcc.h
901 bytes
Rename
Delete
switch_sparc_sun_gcc.h
2.73 KB
Rename
Delete
switch_x32_unix.h
1.47 KB
Rename
Delete
switch_x64_masm.asm
1.80 KB
Rename
Delete
switch_x64_masm.obj
1.05 KB
Rename
Delete
switch_x64_msvc.h
1.76 KB
Rename
Delete
switch_x86_msvc.h
12.54 KB
Rename
Delete
switch_x86_unix.h
2.99 KB
Rename
Delete
/* * this is the internal transfer function. * * HISTORY * 31-May-15 iOS support. Ported from arm32. Proton <feisuzhu@163.com> * * 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" #define REG_FP "r7" #define REG_FPFP "r7,r7" #define REGS_TO_SAVE_GENERAL "r4", "r5", "r6", "r8", "r10", "r11", "lr" #define REGS_TO_SAVE REGS_TO_SAVE_GENERAL, "d8", "d9", "d10", "d11", \ "d12", "d13", "d14", "d15" static int #ifdef __GNUC__ __attribute__((optimize("no-omit-frame-pointer"))) #endif slp_switch(void) { void *fp; int *stackref, stsizediff, result; __asm__ volatile ("" : : : REGS_TO_SAVE); __asm__ volatile ("str " REG_FP ",%0" : "=m" (fp)); __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) : REGS_TO_SAVE /* Clobber registers, force compiler to * recalculate address of void *fp from REG_SP or REG_FP */ ); SLP_RESTORE_STATE(); } __asm__ volatile ( "ldr " REG_FP ", %1\n\t" "mov %0, #0" : "=r" (result) : "m" (fp) : REGS_TO_SAVE /* Force compiler to restore saved registers after this */ ); return result; } #endif
Save