1 1.6 skrll /* $NetBSD: setjmp.h,v 1.6 2024/05/06 07:29:30 skrll Exp $ */ 2 1.1 bjh21 3 1.1 bjh21 /* 4 1.1 bjh21 * machine/setjmp.h: machine dependent setjmp-related information. 5 1.1 bjh21 */ 6 1.1 bjh21 7 1.2 bjh21 #define _JBLEN 64 /* size, in longs, of a jmp_buf */ 8 1.1 bjh21 9 1.1 bjh21 /* 10 1.1 bjh21 * NOTE: The internal structure of a jmp_buf is *PRIVATE* 11 1.1 bjh21 * This information is provided as there is software 12 1.1 bjh21 * that fiddles with this with obtain the stack pointer 13 1.6 skrll * (yes really ! and it's commercial !). 14 1.1 bjh21 * 15 1.1 bjh21 * Description of the setjmp buffer 16 1.1 bjh21 * 17 1.6 skrll * Word Field Comment 18 1.6 skrll * 0 magic number (dependent on creator) 19 1.5 matt * 13 fpscr vfp status control register 20 1.1 bjh21 * 14 r4 register 4 21 1.1 bjh21 * 15 r5 register 5 22 1.1 bjh21 * 16 r6 register 6 23 1.1 bjh21 * 17 r7 register 7 24 1.1 bjh21 * 18 r8 register 8 25 1.1 bjh21 * 19 r9 register 9 26 1.1 bjh21 * 20 r10 register 10 (sl) 27 1.1 bjh21 * 21 r11 register 11 (fp) 28 1.1 bjh21 * 22 r12 register 12 (ip) 29 1.1 bjh21 * 23 r13 register 13 (sp) 30 1.1 bjh21 * 24 r14 register 14 (lr) 31 1.4 wiz * 25 signal mask (dependent on magic) 32 1.1 bjh21 * 26 (con't) 33 1.1 bjh21 * 27 (con't) 34 1.1 bjh21 * 28 (con't) 35 1.5 matt * 32-33 d8 (vfp register d8) 36 1.5 matt * 34-35 d9 (vfp register d9) 37 1.5 matt * 36-37 d10 (vfp register d10) 38 1.5 matt * 38-39 d11 (vfp register d11) 39 1.5 matt * 40-41 d12 (vfp register d12) 40 1.5 matt * 42-43 d13 (vfp register d13) 41 1.5 matt * 44-45 d14 (vfp register d14) 42 1.5 matt * 46-47 d15 (vfp register d15) 43 1.1 bjh21 * 44 1.1 bjh21 * The magic number number identifies the jmp_buf and 45 1.1 bjh21 * how the buffer was created as well as providing 46 1.1 bjh21 * a sanity check 47 1.1 bjh21 * 48 1.1 bjh21 * A side note I should mention - Please do not tamper 49 1.1 bjh21 * with the floating point fields. While they are 50 1.1 bjh21 * always saved and restored at the moment this cannot 51 1.6 skrll * be guaranteed especially if the compiler happens 52 1.1 bjh21 * to be generating soft-float code so no fp 53 1.1 bjh21 * registers will be used. 54 1.1 bjh21 * 55 1.6 skrll * Whilst this can be seen as encouraging people to 56 1.1 bjh21 * use the setjmp buffer in this way I think that it 57 1.6 skrll * is for the best then, if changes occur, compiles will 58 1.1 bjh21 * break rather than just having new builds falling over 59 1.1 bjh21 * mysteriously. 60 1.1 bjh21 */ 61 1.1 bjh21 62 1.1 bjh21 #define _JB_MAGIC__SETJMP 0x4278f500 63 1.1 bjh21 #define _JB_MAGIC_SETJMP 0x4278f501 64 1.5 matt #define _JB_MAGIC__SETJMP_VFP 0x4278f502 65 1.5 matt #define _JB_MAGIC_SETJMP_VFP 0x4278f503 66 1.1 bjh21 67 1.1 bjh21 /* Valid for all jmp_buf's */ 68 1.1 bjh21 69 1.1 bjh21 #define _JB_MAGIC 0 70 1.5 matt #define _JB_REG_FPSCR 13 71 1.1 bjh21 #define _JB_REG_R4 14 72 1.1 bjh21 #define _JB_REG_R5 15 73 1.1 bjh21 #define _JB_REG_R6 16 74 1.1 bjh21 #define _JB_REG_R7 17 75 1.1 bjh21 #define _JB_REG_R8 18 76 1.1 bjh21 #define _JB_REG_R9 19 77 1.1 bjh21 #define _JB_REG_R10 20 78 1.1 bjh21 #define _JB_REG_R11 21 79 1.1 bjh21 #define _JB_REG_R12 22 80 1.1 bjh21 #define _JB_REG_R13 23 81 1.1 bjh21 #define _JB_REG_R14 24 82 1.1 bjh21 83 1.1 bjh21 /* Only valid with the _JB_MAGIC_SETJMP magic */ 84 1.1 bjh21 85 1.1 bjh21 #define _JB_SIGMASK 25 86 1.5 matt 87 1.5 matt #define _JB_REG_D8 32 88 1.5 matt #define _JB_REG_D9 34 89 1.5 matt #define _JB_REG_D10 36 90 1.5 matt #define _JB_REG_D11 38 91 1.5 matt #define _JB_REG_D12 40 92 1.5 matt #define _JB_REG_D13 42 93 1.5 matt #define _JB_REG_D14 44 94 1.5 matt #define _JB_REG_D15 46 95