__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ 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
* 3-May-13 Ralf Schmitt <ralf@systemexit.de>
* Add support for strange GCC caller-save decisions
* (ported from switch_aarch64_gcc.h)
* 18-Aug-11 Alexey Borzenkov <snaury@gmail.com>
* Correctly save rbp, csr and cw
* 01-Apr-04 Hye-Shik Chang <perky@FreeBSD.org>
* Ported from i386 to amd64.
* 24-Nov-02 Christian Tismer <tismer@tismer.com>
* needed to add another magic constant to insure
* that f in slp_eval_frame(PyFrameObject *f)
* STACK_REFPLUS will probably be 1 in most cases.
* gets included into the saved stack area.
* 17-Sep-02 Christian Tismer <tismer@tismer.com>
* after virtualizing stack save/restore, the
* stack size shrunk a bit. Needed to introduce
* an adjustment STACK_MAGIC per platform.
* 15-Sep-02 Gerd Woetzel <gerd.woetzel@GMD.DE>
* slightly changed framework for spark
* 31-Avr-02 Armin Rigo <arigo@ulb.ac.be>
* Added ebx, esi and edi register-saves.
* 01-Mar-02 Samual M. Rushing <rushing@ironport.com>
* Ported from i386.
*/
#define STACK_REFPLUS 1
#ifdef SLP_EVAL
/* #define STACK_MAGIC 3 */
/* the above works fine with gcc 2.96, but 2.95.3 wants this */
#define STACK_MAGIC 0
#define REGS_TO_SAVE "r12", "r13", "r14", "r15"
static int
slp_switch(void)
{
int err;
void* rbp;
void* rbx;
unsigned int csr;
unsigned short cw;
/* This used to be declared 'register', but that does nothing in
modern compilers and is explicitly forbidden in some new
standards. */
long *stackref, stsizediff;
__asm__ volatile ("" : : : REGS_TO_SAVE);
__asm__ volatile ("fstcw %0" : "=m" (cw));
__asm__ volatile ("stmxcsr %0" : "=m" (csr));
__asm__ volatile ("movq %%rbp, %0" : "=m" (rbp));
__asm__ volatile ("movq %%rbx, %0" : "=m" (rbx));
__asm__ ("movq %%rsp, %0" : "=g" (stackref));
{
SLP_SAVE_STATE(stackref, stsizediff);
__asm__ volatile (
"addq %0, %%rsp\n"
"addq %0, %%rbp\n"
:
: "r" (stsizediff)
);
SLP_RESTORE_STATE();
__asm__ volatile ("xorq %%rax, %%rax" : "=a" (err));
}
__asm__ volatile ("movq %0, %%rbx" : : "m" (rbx));
__asm__ volatile ("movq %0, %%rbp" : : "m" (rbp));
__asm__ volatile ("ldmxcsr %0" : : "m" (csr));
__asm__ volatile ("fldcw %0" : : "m" (cw));
__asm__ volatile ("" : : : REGS_TO_SAVE);
return err;
}
#endif
/*
* further self-processing support
*/
/*
* if you want to add self-inspection tools, place them
* here. See the x86_msvc for the necessary defines.
* These features are highly experimental und not
* essential yet.
*/
| 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 |
|