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