| 1 | @ 32 bit ARM context switch | 
|---|
| 2 | @ This function assumes that r9 has no special meaning on the platform it's | 
|---|
| 3 | @ being built on. | 
|---|
| 4 | @ If r9 is special, uncomment the following line and it will be left alone | 
|---|
| 5 |  | 
|---|
| 6 | @ #define R9_SPECIAL | 
|---|
| 7 |  | 
|---|
| 8 | #define PTR_BYTE        4 | 
|---|
| 9 | #define SP_OFFSET       ( 0 * PTR_BYTE ) | 
|---|
| 10 | #define FP_OFFSET       ( 1 * PTR_BYTE ) | 
|---|
| 11 | #define PC_OFFSET       ( 2 * PTR_BYTE ) | 
|---|
| 12 |  | 
|---|
| 13 | .text | 
|---|
| 14 | .align  2 | 
|---|
| 15 | .global __cfactx_switch | 
|---|
| 16 | .type   __cfactx_switch, %function | 
|---|
| 17 |  | 
|---|
| 18 | __cfactx_switch: | 
|---|
| 19 | @ save callee-saved registers: r4-r8, r10, r11, r13(sp) (plus r9 depending on platform specification) | 
|---|
| 20 | @ I've seen reference to 31 registers on 64-bit, if this is the case, more need to be saved | 
|---|
| 21 | @ save thread state registers: r14(lr) | 
|---|
| 22 | @ r12(ip) is intra-procedure-call scratch register, does not need saving between function calls | 
|---|
| 23 |  | 
|---|
| 24 | #ifdef R9_SPECIAL | 
|---|
| 25 | stmfd r13!, {r4-r8,r10,r11,r14} | 
|---|
| 26 | #else | 
|---|
| 27 | stmfd r13!, {r4-r11,r14} | 
|---|
| 28 | #endif // R9_SPECIAL | 
|---|
| 29 |  | 
|---|
| 30 | @ save floating point registers: s16-s31 | 
|---|
| 31 | vstmdb r13!, {s16-s31} | 
|---|
| 32 |  | 
|---|
| 33 | @ save frame pointer and stack pointer to outgoing datastructure | 
|---|
| 34 | str sp, [r0, #SP_OFFSET] | 
|---|
| 35 | str fp, [r0, #FP_OFFSET] | 
|---|
| 36 |  | 
|---|
| 37 | @ restore frame pointer and stack pointer from incoming datastructure | 
|---|
| 38 | ldr fp, [r1, #FP_OFFSET] | 
|---|
| 39 | ldr sp, [r1, #SP_OFFSET] | 
|---|
| 40 |  | 
|---|
| 41 | @ restore floating point registers: s16-s31 | 
|---|
| 42 | vldm r13!, {s16-s31} | 
|---|
| 43 | @ restore r14(lr) | 
|---|
| 44 | @ restore 64-bit extra registers? | 
|---|
| 45 | @ restore callee-saved registers: r4-r8, r10, r11, r13 | 
|---|
| 46 |  | 
|---|
| 47 | #ifdef R9_SPECIAL | 
|---|
| 48 | ldmfd r13!, {r4-r8,r10,r11,r15} | 
|---|
| 49 | #else | 
|---|
| 50 | ldmfd r13!, {r4-r11,r14}    @ loading r14 back into r15 returns | 
|---|
| 51 |  | 
|---|
| 52 | mov r15, r14 | 
|---|
| 53 | #endif // R9_SPECIAL | 
|---|
| 54 |  | 
|---|
| 55 | .text | 
|---|
| 56 | .align  2 | 
|---|
| 57 | .global __cfactx_invoke_stub | 
|---|
| 58 | .type   __cfactx_invoke_stub, %function | 
|---|
| 59 |  | 
|---|
| 60 | __cfactx_invoke_stub: | 
|---|
| 61 | ldmfd r13!, {r0-r1} | 
|---|
| 62 | mov r15, r1 | 
|---|