23 ".seh_proc __seh2_global_filter_func\n"
24 "__seh2_global_filter_func:\n"
28 "\t.seh_pushreg %rbp\n"
30 "\t.seh_stackalloc 32\n"
31 "\t.seh_endprologue\n"
38 "__seh2_global_filter_func_exit:\n"
45#define STRINGIFY(a) #a
46#define EMIT_PRAGMA_(params) \
47 _Pragma( STRINGIFY(params) )
48#define EMIT_PRAGMA(type,line) \
49 EMIT_PRAGMA_(REACTOS seh(type,line))
51#define _SEH3$_EMIT_DEFS_AND_PRAGMA__(Line, Type) \
53 __asm__ __volatile__ goto ("\n" \
54 "\t__seh2$$begin_try__" #Line "=%l0\n"
\
55 "\t__seh2$$end_try__" #Line "=%l1 + 1\n"
\
56 "\t__seh2$$filter__" #Line "=%l2\n"
\
57 "\t__seh2$$begin_except__" #Line "=%l3\n"
\
61 : __seh2$$begin_try__, \
64 __seh2$$begin_except__); \
66 EMIT_PRAGMA(Type,Line)
68#define _SEH3$_EMIT_DEFS_AND_PRAGMA_(Line, Type) _SEH3$_EMIT_DEFS_AND_PRAGMA__(Line, Type)
69#define _SEH3$_EMIT_DEFS_AND_PRAGMA(Type) _SEH3$_EMIT_DEFS_AND_PRAGMA_(__LINE__, Type)
73 __label__ __seh2$$filter__; \
74 __label__ __seh2$$begin_except__; \
75 __label__ __seh2$$begin_try__; \
76 __label__ __seh2$$end_try__; \
86 __label__ __seh2$$leave_scope__;
88#define _SEH2_EXCEPT(...) \
89__seh2$$leave_scope__: __MINGW_ATTRIB_UNUSED; \
91__seh2$$end_try__:(void)0; \
93 _SEH3$_EMIT_DEFS_AND_PRAGMA(__seh$$except); \
96 __label__ __seh2$$leave_scope__; \
97 long __MINGW_ATTRIB_UNUSED __seh2$$exception_code__; \
102 __label__ __seh2$$filter_funclet__; \
104 __asm__ __volatile__ goto( \
105 "\tleaq %l1(%%rip), %%r8\n" \
106 "\tjmp __seh2_global_filter_func\n" \
108 : "a"(__builtin_frame_address(0)) \
110 : __seh2$$filter_funclet__); \
112 struct _SEH$$_EXCEPTION_POINTERS* __seh2$$exception_ptr__; \
113 __seh2$$filter_funclet__: \
115 __asm__ __volatile__("" \
116 : "=c"(__seh2$$exception_ptr__)
\
119 "%rax", "%rbx","%rdx", "%rdi", "%rsi", \
120 "%r8", "%r9", "%r10", "%r11", "%r12", "%r13", "%r14", "%r15"); \
122 __seh2$$exception_code__ = __seh2$$exception_ptr__->ExceptionRecord->ExceptionCode; \
124 register long __MINGW_ATTRIB_UNUSED __seh2$$filter_funclet_ret __asm__("eax") = \
127 __asm__("jmp __seh2_global_filter_func_exit"); \
132 __seh2$$abnormal_termination__ = 0 \
134 __seh2$$begin_except__:
136#define _SEH2_FINALLY \
137__seh2$$leave_scope__: __MINGW_ATTRIB_UNUSED; \
140__seh2$$begin_except__: __MINGW_ATTRIB_UNUSED; \
142 _SEH3$_EMIT_DEFS_AND_PRAGMA(__seh$$finally); \
145 __label__ __seh2$$finally__; \
146 __label__ __seh2$$begin_finally__; \
147 __label__ __seh2$$leave_scope__; \
148 __asm__ __volatile__ goto("" : : : : __seh2$$finally__); \
149 int __seh2$$abnormal_termination__; \
153 __seh2$$filter__: __MINGW_ATTRIB_UNUSED; \
154 __seh2$$finally__: __MINGW_ATTRIB_UNUSED; \
155 __asm__ __volatile__ goto( \
157 "\tleaq %l1(%%rip), %%r8\n" \
158 "\tjmp __seh2_global_filter_func\n" \
160 : "a"(__builtin_frame_address(0)) \
162 : __seh2$$begin_finally__); \
166 __asm__ __volatile__("xor %%rcx, %%rcx" \
170 "%rax", "%rbx", "%rcx", "%rdx", "%rdi", "%rsi", \
171 "%r8", "%r9", "%r10", "%r11", "%r12", "%r13", "%r14", "%r15"); \
173 __seh2$$begin_finally__: \
174 __asm__ __volatile__("" \
175 : "=c" (__seh2$$abnormal_termination__));
178 __seh2$$leave_scope__: __MINGW_ATTRIB_UNUSED; \
179 if (__seh2$$abnormal_termination__) \
181 __asm__("jmp __seh2_global_filter_func_exit"); \
186#define _SEH2_GetExceptionInformation() ((struct _EXCEPTION_POINTERS*)__seh2$$exception_ptr__)
187#define _SEH2_GetExceptionCode() __seh2$$exception_code__
188#define _SEH2_AbnormalTermination() __seh2$$abnormal_termination__
189#define _SEH2_LEAVE goto __seh2$$leave_scope__
190#define _SEH2_YIELD(__stmt) __stmt
191#define _SEH2_VOLATILE volatile
194#define __try _SEH2_TRY
195#define __except _SEH2_EXCEPT
196#define __finally _SEH2_FINALLY
197#define __endtry _SEH2_END
198#define __leave goto __seh2$$leave_scope__
199#define _exception_info() ((struct _EXCEPTION_POINTERS*)__seh2$$exception_ptr__)
200#define _exception_code() __seh2$$exception_code__
201#define _abnormal_termination() __seh2$$abnormal_termination__
__asm__(".p2align 4, 0x90\n" ".seh_proc __seh2_global_filter_func\n" "__seh2_global_filter_func:\n" "\tsub %rbp, %rax\n" "\tpush %rbp\n" "\t.seh_pushreg %rbp\n" "\tsub $32, %rsp\n" "\t.seh_stackalloc 32\n" "\t.seh_endprologue\n" "\tsub %rax, %rdx\n" "\tmov %rdx, %rbp\n" "\tjmp *%r8\n" "__seh2_global_filter_func_exit:\n" "\t.p2align 4\n" "\tadd $32, %rsp\n" "\tpop %rbp\n" "\tret\n" "\t.seh_endproc")
struct _SEH$$_EXCEPTION_RECORD * ExceptionRecord
struct _CONTEXT * ContextRecord
unsigned long long ExceptionInformation[15]
unsigned long ExceptionCode
struct _EXCEPTION_RECORD * ExceptionRecord
unsigned long ExceptionFlags
unsigned long NumberParameters