X7ROOT File Manager
Current Path:
/opt/hc_python/lib/python3.12/site-packages/greenlet/platform
opt
/
hc_python
/
lib
/
python3.12
/
site-packages
/
greenlet
/
platform
/
ðŸ“
..
📄
__init__.py
(0 B)
ðŸ“
__pycache__
📄
setup_switch_x64_masm.cmd
(143 B)
📄
switch_aarch64_gcc.h
(4.21 KB)
📄
switch_alpha_unix.h
(671 B)
📄
switch_amd64_unix.h
(2.68 KB)
📄
switch_arm32_gcc.h
(2.42 KB)
📄
switch_arm32_ios.h
(1.85 KB)
📄
switch_arm64_masm.asm
(1.22 KB)
📄
switch_arm64_masm.obj
(746 B)
📄
switch_arm64_msvc.h
(398 B)
📄
switch_csky_gcc.h
(1.3 KB)
📄
switch_loongarch64_linux.h
(779 B)
📄
switch_m68k_gcc.h
(928 B)
📄
switch_mips_unix.h
(1.39 KB)
📄
switch_ppc64_aix.h
(3.77 KB)
📄
switch_ppc64_linux.h
(3.73 KB)
📄
switch_ppc_aix.h
(2.87 KB)
📄
switch_ppc_linux.h
(2.69 KB)
📄
switch_ppc_macosx.h
(2.56 KB)
📄
switch_ppc_unix.h
(2.59 KB)
📄
switch_riscv_unix.h
(949 B)
📄
switch_s390_unix.h
(2.7 KB)
📄
switch_sh_gcc.h
(901 B)
📄
switch_sparc_sun_gcc.h
(2.73 KB)
📄
switch_x32_unix.h
(1.47 KB)
📄
switch_x64_masm.asm
(1.8 KB)
📄
switch_x64_masm.obj
(1.05 KB)
📄
switch_x64_msvc.h
(1.76 KB)
📄
switch_x86_msvc.h
(12.54 KB)
📄
switch_x86_unix.h
(2.99 KB)
Editing: switch_arm32_gcc.h
/* * 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
Upload File
Create Folder