Qucs-S S-parameter Viewer & RF Synthesis Tools
Loading...
Searching...
No Matches
switch_arm32_gcc.h
1/*
2 * this is the internal transfer function.
3 *
4 * HISTORY
5 * 14-Aug-06 File creation. Ported from Arm Thumb. Sylvain Baro
6 * 3-Sep-06 Commented out saving of r1-r3 (r4 already commented out) as I
7 * read that these do not need to be saved. Also added notes and
8 * errors related to the frame pointer. Richard Tew.
9 *
10 * NOTES
11 *
12 * It is not possible to detect if fp is used or not, so the supplied
13 * switch function needs to support it, so that you can remove it if
14 * it does not apply to you.
15 *
16 * POSSIBLE ERRORS
17 *
18 * "fp cannot be used in asm here"
19 *
20 * - Try commenting out "fp" in REGS_TO_SAVE.
21 *
22 */
23
24#define STACK_REFPLUS 1
25
26#ifdef SLP_EVAL
27#define STACK_MAGIC 0
28#define REG_SP "sp"
29#define REG_SPSP "sp,sp"
30#ifdef __thumb__
31#define REG_FP "r7"
32#define REG_FPFP "r7,r7"
33#define REGS_TO_SAVE_GENERAL "r4", "r5", "r6", "r8", "r9", "r10", "r11", "lr"
34#else
35#define REG_FP "fp"
36#define REG_FPFP "fp,fp"
37#define REGS_TO_SAVE_GENERAL "r4", "r5", "r6", "r7", "r8", "r9", "r10", "lr"
38#endif
39#if defined(__SOFTFP__)
40#define REGS_TO_SAVE REGS_TO_SAVE_GENERAL
41#elif defined(__VFP_FP__)
42#define REGS_TO_SAVE REGS_TO_SAVE_GENERAL, "d8", "d9", "d10", "d11", \
43 "d12", "d13", "d14", "d15"
44#elif defined(__MAVERICK__)
45#define REGS_TO_SAVE REGS_TO_SAVE_GENERAL, "mvf4", "mvf5", "mvf6", "mvf7", \
46 "mvf8", "mvf9", "mvf10", "mvf11", \
47 "mvf12", "mvf13", "mvf14", "mvf15"
48#else
49#define REGS_TO_SAVE REGS_TO_SAVE_GENERAL, "f4", "f5", "f6", "f7"
50#endif
51
52static int
53#ifdef __GNUC__
54__attribute__((optimize("no-omit-frame-pointer")))
55#endif
56slp_switch(void)
57{
58 void *fp;
59 int *stackref, stsizediff;
60 int result;
61 __asm__ volatile ("" : : : REGS_TO_SAVE);
62 __asm__ volatile ("mov r0," REG_FP "\n\tstr r0,%0" : "=m" (fp) : : "r0");
63 __asm__ ("mov %0," REG_SP : "=r" (stackref));
64 {
65 SLP_SAVE_STATE(stackref, stsizediff);
66 __asm__ volatile (
67 "add " REG_SPSP ",%0\n"
68 "add " REG_FPFP ",%0\n"
69 :
70 : "r" (stsizediff)
71 );
72 SLP_RESTORE_STATE();
73 }
74 __asm__ volatile ("ldr r0,%1\n\tmov " REG_FP ",r0\n\tmov %0, #0" : "=r" (result) : "m" (fp) : "r0");
75 __asm__ volatile ("" : : : REGS_TO_SAVE);
76 return result;
77}
78
79#endif
nodes.Node optimize(nodes.Node node, "Environment" environment)
Definition optimizer.py:20