blob: 02d332c8aa753ba399bf443d051fdd0610e98331 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
/* $OpenBSD: setjmp.h,v 1.5 2018/06/22 15:18:50 kettenis Exp $ */
/* $NetBSD: setjmp.h,v 1.2 2001/08/25 14:45:59 bjh21 Exp $ */
/*
* machine/setjmp.h: machine dependent setjmp-related information.
*/
#define _JBLEN 64 /* size, in longs, of a jmp_buf */
/*
* Description of the setjmp buffer
*
* word 0 magic number (dependant on creator)
* 1 fpscr fpscr
* 2 - 17 d8 - d15 vfp registers
* 18 r13 register 13 (sp) XOR cookie0
* 19 r14 register 14 (lr) XOR cookie1
* 20 r4 register 4
* 21 r5 register 5
* 22 r6 register 6
* 23 r7 register 7
* 24 r8 register 8
* 25 r9 register 9
* 26 r10 register 10 (sl)
* 27 r11 register 11 (fp)
* 28 unused unused
* 29 signal mask (dependant on magic)
* 30 (con't)
* 31 (con't)
* 32 (con't)
*
* The magic number number identifies the jmp_buf and
* how the buffer was created as well as providing
* a sanity check.
*
* A side note I should mention - please do not tamper
* with the floating point fields. While they are
* always saved and restored at the moment this cannot
* be guaranteed especially if the compiler happens
* to be generating soft-float code so no fp
* registers will be used.
*
* Whilst this can be seen an encouraging people to
* use the setjmp buffer in this way I think that it
* is for the best then if changes occur compiles will
* break rather than just having new builds falling over
* mysteriously.
*/
#define _JB_MAGIC__SETJMP 0x4278f500
#define _JB_MAGIC_SETJMP 0x4278f501
/* Valid for all jmp_buf's */
#define _JB_MAGIC 0
#define _JB_REG_R4 20
#define _JB_REG_R5 21
#define _JB_REG_R6 22
#define _JB_REG_R7 23
#define _JB_REG_R8 24
#define _JB_REG_R9 25
#define _JB_REG_R10 26
#define _JB_REG_R11 27
/* Only valid with the _JB_MAGIC_SETJMP magic */
#define _JB_SIGMASK 29
|