|
3 | 3 | #define __ASM_EXTABLE_H
|
4 | 4 |
|
5 | 5 | #include <linux/stringify.h>
|
| 6 | +#include <linux/bits.h> |
6 | 7 | #include <asm/asm-const.h>
|
7 | 8 |
|
8 |
| -#define EX_TYPE_NONE 0 |
9 |
| -#define EX_TYPE_FIXUP 1 |
10 |
| -#define EX_TYPE_BPF 2 |
11 |
| -#define EX_TYPE_UACCESS 3 |
| 9 | +#define EX_TYPE_NONE 0 |
| 10 | +#define EX_TYPE_FIXUP 1 |
| 11 | +#define EX_TYPE_BPF 2 |
| 12 | +#define EX_TYPE_UA_STORE 3 |
| 13 | +#define EX_TYPE_UA_LOAD_MEM 4 |
| 14 | +#define EX_TYPE_UA_LOAD_REG 5 |
| 15 | + |
| 16 | +#define EX_DATA_REG_ERR_SHIFT 0 |
| 17 | +#define EX_DATA_REG_ERR GENMASK(3, 0) |
| 18 | + |
| 19 | +#define EX_DATA_REG_ADDR_SHIFT 4 |
| 20 | +#define EX_DATA_REG_ADDR GENMASK(7, 4) |
| 21 | + |
| 22 | +#define EX_DATA_LEN_SHIFT 8 |
| 23 | +#define EX_DATA_LEN GENMASK(11, 8) |
12 | 24 |
|
13 | 25 | #define __EX_TABLE(_section, _fault, _target, _type) \
|
14 | 26 | stringify_in_c(.section _section,"a";) \
|
|
19 | 31 | stringify_in_c(.short 0;) \
|
20 | 32 | stringify_in_c(.previous)
|
21 | 33 |
|
22 |
| -#define __EX_TABLE_UA(_section, _fault, _target, _type, _reg) \ |
23 |
| - stringify_in_c(.section _section,"a";) \ |
24 |
| - stringify_in_c(.align 4;) \ |
25 |
| - stringify_in_c(.long (_fault) - .;) \ |
26 |
| - stringify_in_c(.long (_target) - .;) \ |
27 |
| - stringify_in_c(.short (_type);) \ |
28 |
| - stringify_in_c(.macro extable_reg reg;) \ |
29 |
| - stringify_in_c(.set .Lfound, 0;) \ |
30 |
| - stringify_in_c(.set .Lregnr, 0;) \ |
31 |
| - stringify_in_c(.irp rs,r0,r1,r2,r3,r4,r5,r6,r7,r8,r9,r10,r11,r12,r13,r14,r15;) \ |
32 |
| - stringify_in_c(.ifc "\reg", "%%\rs";) \ |
33 |
| - stringify_in_c(.set .Lfound, 1;) \ |
34 |
| - stringify_in_c(.short .Lregnr;) \ |
35 |
| - stringify_in_c(.endif;) \ |
36 |
| - stringify_in_c(.set .Lregnr, .Lregnr+1;) \ |
37 |
| - stringify_in_c(.endr;) \ |
38 |
| - stringify_in_c(.ifne (.Lfound != 1);) \ |
39 |
| - stringify_in_c(.error "extable_reg: bad register argument";) \ |
40 |
| - stringify_in_c(.endif;) \ |
41 |
| - stringify_in_c(.endm;) \ |
42 |
| - stringify_in_c(extable_reg _reg;) \ |
43 |
| - stringify_in_c(.purgem extable_reg;) \ |
| 34 | +#define __EX_TABLE_UA(_section, _fault, _target, _type, _regerr, _regaddr, _len)\ |
| 35 | + stringify_in_c(.section _section,"a";) \ |
| 36 | + stringify_in_c(.align 4;) \ |
| 37 | + stringify_in_c(.long (_fault) - .;) \ |
| 38 | + stringify_in_c(.long (_target) - .;) \ |
| 39 | + stringify_in_c(.short (_type);) \ |
| 40 | + stringify_in_c(.macro extable_reg regerr, regaddr;) \ |
| 41 | + stringify_in_c(.set .Lfound, 0;) \ |
| 42 | + stringify_in_c(.set .Lcurr, 0;) \ |
| 43 | + stringify_in_c(.irp rs,0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15;) \ |
| 44 | + stringify_in_c( .ifc "\regerr", "%%r\rs";) \ |
| 45 | + stringify_in_c( .set .Lfound, 1;) \ |
| 46 | + stringify_in_c( .set .Lregerr, .Lcurr;) \ |
| 47 | + stringify_in_c( .endif;) \ |
| 48 | + stringify_in_c( .set .Lcurr, .Lcurr+1;) \ |
| 49 | + stringify_in_c(.endr;) \ |
| 50 | + stringify_in_c(.ifne (.Lfound != 1);) \ |
| 51 | + stringify_in_c( .error "extable_reg: bad register argument1";) \ |
| 52 | + stringify_in_c(.endif;) \ |
| 53 | + stringify_in_c(.set .Lfound, 0;) \ |
| 54 | + stringify_in_c(.set .Lcurr, 0;) \ |
| 55 | + stringify_in_c(.irp rs,0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15;) \ |
| 56 | + stringify_in_c( .ifc "\regaddr", "%%r\rs";) \ |
| 57 | + stringify_in_c( .set .Lfound, 1;) \ |
| 58 | + stringify_in_c( .set .Lregaddr, .Lcurr;) \ |
| 59 | + stringify_in_c( .endif;) \ |
| 60 | + stringify_in_c( .set .Lcurr, .Lcurr+1;) \ |
| 61 | + stringify_in_c(.endr;) \ |
| 62 | + stringify_in_c(.ifne (.Lfound != 1);) \ |
| 63 | + stringify_in_c( .error "extable_reg: bad register argument2";) \ |
| 64 | + stringify_in_c(.endif;) \ |
| 65 | + stringify_in_c(.short .Lregerr << EX_DATA_REG_ERR_SHIFT | \ |
| 66 | + .Lregaddr << EX_DATA_REG_ADDR_SHIFT | \ |
| 67 | + _len << EX_DATA_LEN_SHIFT;) \ |
| 68 | + stringify_in_c(.endm;) \ |
| 69 | + stringify_in_c(extable_reg _regerr,_regaddr;) \ |
| 70 | + stringify_in_c(.purgem extable_reg;) \ |
44 | 71 | stringify_in_c(.previous)
|
45 | 72 |
|
46 | 73 | #define EX_TABLE(_fault, _target) \
|
47 | 74 | __EX_TABLE(__ex_table, _fault, _target, EX_TYPE_FIXUP)
|
| 75 | + |
48 | 76 | #define EX_TABLE_AMODE31(_fault, _target) \
|
49 | 77 | __EX_TABLE(.amode31.ex_table, _fault, _target, EX_TYPE_FIXUP)
|
50 |
| -#define EX_TABLE_UA(_fault, _target, _reg) \ |
51 |
| - __EX_TABLE_UA(__ex_table, _fault, _target, EX_TYPE_UACCESS, _reg) |
| 78 | + |
| 79 | +#define EX_TABLE_UA_STORE(_fault, _target, _regerr) \ |
| 80 | + __EX_TABLE_UA(__ex_table, _fault, _target, EX_TYPE_UA_STORE, _regerr, _regerr, 0) |
| 81 | + |
| 82 | +#define EX_TABLE_UA_LOAD_MEM(_fault, _target, _regerr, _regmem, _len) \ |
| 83 | + __EX_TABLE_UA(__ex_table, _fault, _target, EX_TYPE_UA_LOAD_MEM, _regerr, _regmem, _len) |
| 84 | + |
| 85 | +#define EX_TABLE_UA_LOAD_REG(_fault, _target, _regerr, _regzero) \ |
| 86 | + __EX_TABLE_UA(__ex_table, _fault, _target, EX_TYPE_UA_LOAD_REG, _regerr, _regzero, 0) |
52 | 87 |
|
53 | 88 | #endif /* __ASM_EXTABLE_H */
|
0 commit comments