mirror of
				https://github.com/openresty/openresty.git
				synced 2024-10-13 00:29:41 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			242 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			242 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* Exception handling and frame unwind runtime interface routines.
 | |
|    Copyright (C) 2001, 2003, 2004, 2006 Free Software Foundation, Inc.
 | |
| 
 | |
|    This file is part of GCC.
 | |
| 
 | |
|    GCC is free software; you can redistribute it and/or modify it
 | |
|    under the terms of the GNU General Public License as published by
 | |
|    the Free Software Foundation; either version 2, or (at your option)
 | |
|    any later version.
 | |
| 
 | |
|    GCC is distributed in the hope that it will be useful, but WITHOUT
 | |
|    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
 | |
|    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
 | |
|    License for more details.
 | |
| 
 | |
|    You should have received a copy of the GNU General Public License
 | |
|    along with GCC; see the file COPYING.  If not, write to the Free
 | |
|    Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA
 | |
|    02110-1301, USA.  */
 | |
| 
 | |
| /* As a special exception, if you include this header file into source
 | |
|    files compiled by GCC, this header file does not by itself cause
 | |
|    the resulting executable to be covered by the GNU General Public
 | |
|    License.  This exception does not however invalidate any other
 | |
|    reasons why the executable file might be covered by the GNU General
 | |
|    Public License.  */
 | |
| 
 | |
| /* This is derived from the C++ ABI for IA-64.  Where we diverge
 | |
|    for cross-architecture compatibility are noted with "@@@".  */
 | |
| 
 | |
| #ifndef _UNWIND_H
 | |
| #define _UNWIND_H
 | |
| 
 | |
| #ifndef HIDE_EXPORTS
 | |
| #pragma GCC visibility push(default)
 | |
| #endif
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| /* Level 1: Base ABI  */
 | |
| 
 | |
| /* @@@ The IA-64 ABI uses uint64 throughout.  Most places this is
 | |
|    inefficient for 32-bit and smaller machines.  */
 | |
| typedef unsigned _Unwind_Word __attribute__((__mode__(__word__)));
 | |
| typedef signed _Unwind_Sword __attribute__((__mode__(__word__)));
 | |
| #if defined(__ia64__) && defined(__hpux__)
 | |
| typedef unsigned _Unwind_Ptr __attribute__((__mode__(__word__)));
 | |
| #else
 | |
| typedef unsigned _Unwind_Ptr __attribute__((__mode__(__pointer__)));
 | |
| #endif
 | |
| typedef unsigned _Unwind_Internal_Ptr __attribute__((__mode__(__pointer__)));
 | |
| 
 | |
| /* @@@ The IA-64 ABI uses a 64-bit word to identify the producer and
 | |
|    consumer of an exception.  We'll go along with this for now even on
 | |
|    32-bit machines.  We'll need to provide some other option for
 | |
|    16-bit machines and for machines with > 8 bits per byte.  */
 | |
| typedef unsigned _Unwind_Exception_Class __attribute__((__mode__(__DI__)));
 | |
| 
 | |
| /* The unwind interface uses reason codes in several contexts to
 | |
|    identify the reasons for failures or other actions.  */
 | |
| typedef enum
 | |
| {
 | |
|   _URC_NO_REASON = 0,
 | |
|   _URC_FOREIGN_EXCEPTION_CAUGHT = 1,
 | |
|   _URC_FATAL_PHASE2_ERROR = 2,
 | |
|   _URC_FATAL_PHASE1_ERROR = 3,
 | |
|   _URC_NORMAL_STOP = 4,
 | |
|   _URC_END_OF_STACK = 5,
 | |
|   _URC_HANDLER_FOUND = 6,
 | |
|   _URC_INSTALL_CONTEXT = 7,
 | |
|   _URC_CONTINUE_UNWIND = 8
 | |
| } _Unwind_Reason_Code;
 | |
| 
 | |
| 
 | |
| /* The unwind interface uses a pointer to an exception header object
 | |
|    as its representation of an exception being thrown. In general, the
 | |
|    full representation of an exception object is language- and
 | |
|    implementation-specific, but it will be prefixed by a header
 | |
|    understood by the unwind interface.  */
 | |
| 
 | |
| struct _Unwind_Exception;
 | |
| 
 | |
| typedef void (*_Unwind_Exception_Cleanup_Fn) (_Unwind_Reason_Code,
 | |
| 					      struct _Unwind_Exception *);
 | |
| 
 | |
| struct _Unwind_Exception
 | |
| {
 | |
|   _Unwind_Exception_Class exception_class;
 | |
|   _Unwind_Exception_Cleanup_Fn exception_cleanup;
 | |
|   _Unwind_Word private_1;
 | |
|   _Unwind_Word private_2;
 | |
| 
 | |
|   /* @@@ The IA-64 ABI says that this structure must be double-word aligned.
 | |
|      Taking that literally does not make much sense generically.  Instead we
 | |
|      provide the maximum alignment required by any type for the machine.  */
 | |
| } __attribute__((__aligned__));
 | |
| 
 | |
| 
 | |
| /* The ACTIONS argument to the personality routine is a bitwise OR of one
 | |
|    or more of the following constants.  */
 | |
| typedef int _Unwind_Action;
 | |
| 
 | |
| #define _UA_SEARCH_PHASE	1
 | |
| #define _UA_CLEANUP_PHASE	2
 | |
| #define _UA_HANDLER_FRAME	4
 | |
| #define _UA_FORCE_UNWIND	8
 | |
| #define _UA_END_OF_STACK	16
 | |
| 
 | |
| /* This is an opaque type used to refer to a system-specific data
 | |
|    structure used by the system unwinder. This context is created and
 | |
|    destroyed by the system, and passed to the personality routine
 | |
|    during unwinding.  */
 | |
| struct _Unwind_Context;
 | |
| 
 | |
| /* Raise an exception, passing along the given exception object.  */
 | |
| extern _Unwind_Reason_Code _Unwind_RaiseException (struct _Unwind_Exception *);
 | |
| 
 | |
| /* Raise an exception for forced unwinding.  */
 | |
| 
 | |
| typedef _Unwind_Reason_Code (*_Unwind_Stop_Fn)
 | |
|      (int, _Unwind_Action, _Unwind_Exception_Class,
 | |
|       struct _Unwind_Exception *, struct _Unwind_Context *, void *);
 | |
| 
 | |
| extern _Unwind_Reason_Code _Unwind_ForcedUnwind (struct _Unwind_Exception *,
 | |
| 						 _Unwind_Stop_Fn,
 | |
| 						 void *);
 | |
| 
 | |
| /* Helper to invoke the exception_cleanup routine.  */
 | |
| extern void _Unwind_DeleteException (struct _Unwind_Exception *);
 | |
| 
 | |
| /* Resume propagation of an existing exception.  This is used after
 | |
|    e.g. executing cleanup code, and not to implement rethrowing.  */
 | |
| extern void _Unwind_Resume (struct _Unwind_Exception *);
 | |
| 
 | |
| /* @@@ Resume propagation of an FORCE_UNWIND exception, or to rethrow
 | |
|    a normal exception that was handled.  */
 | |
| extern _Unwind_Reason_Code _Unwind_Resume_or_Rethrow (struct _Unwind_Exception *);
 | |
| 
 | |
| /* @@@ Use unwind data to perform a stack backtrace.  The trace callback
 | |
|    is called for every stack frame in the call chain, but no cleanup
 | |
|    actions are performed.  */
 | |
| typedef _Unwind_Reason_Code (*_Unwind_Trace_Fn)
 | |
|      (struct _Unwind_Context *, void *);
 | |
| 
 | |
| extern _Unwind_Reason_Code _Unwind_Backtrace (_Unwind_Trace_Fn, void *);
 | |
| 
 | |
| /* These functions are used for communicating information about the unwind
 | |
|    context (i.e. the unwind descriptors and the user register state) between
 | |
|    the unwind library and the personality routine and landing pad.  Only
 | |
|    selected registers maybe manipulated.  */
 | |
| 
 | |
| extern _Unwind_Word _Unwind_GetGR (struct _Unwind_Context *, int);
 | |
| extern void _Unwind_SetGR (struct _Unwind_Context *, int, _Unwind_Word);
 | |
| 
 | |
| extern _Unwind_Ptr _Unwind_GetIP (struct _Unwind_Context *);
 | |
| extern _Unwind_Ptr _Unwind_GetIPInfo (struct _Unwind_Context *, int *);
 | |
| extern void _Unwind_SetIP (struct _Unwind_Context *, _Unwind_Ptr);
 | |
| 
 | |
| /* @@@ Retrieve the CFA of the given context.  */
 | |
| extern _Unwind_Word _Unwind_GetCFA (struct _Unwind_Context *);
 | |
| 
 | |
| extern void *_Unwind_GetLanguageSpecificData (struct _Unwind_Context *);
 | |
| 
 | |
| extern _Unwind_Ptr _Unwind_GetRegionStart (struct _Unwind_Context *);
 | |
| 
 | |
| 
 | |
| /* The personality routine is the function in the C++ (or other language)
 | |
|    runtime library which serves as an interface between the system unwind
 | |
|    library and language-specific exception handling semantics.  It is
 | |
|    specific to the code fragment described by an unwind info block, and
 | |
|    it is always referenced via the pointer in the unwind info block, and
 | |
|    hence it has no ABI-specified name.
 | |
| 
 | |
|    Note that this implies that two different C++ implementations can
 | |
|    use different names, and have different contents in the language
 | |
|    specific data area.  Moreover, that the language specific data
 | |
|    area contains no version info because name of the function invoked
 | |
|    provides more effective versioning by detecting at link time the
 | |
|    lack of code to handle the different data format.  */
 | |
| 
 | |
| typedef _Unwind_Reason_Code (*_Unwind_Personality_Fn)
 | |
|      (int, _Unwind_Action, _Unwind_Exception_Class,
 | |
|       struct _Unwind_Exception *, struct _Unwind_Context *);
 | |
| 
 | |
| /* @@@ The following alternate entry points are for setjmp/longjmp
 | |
|    based unwinding.  */
 | |
| 
 | |
| struct SjLj_Function_Context;
 | |
| extern void _Unwind_SjLj_Register (struct SjLj_Function_Context *);
 | |
| extern void _Unwind_SjLj_Unregister (struct SjLj_Function_Context *);
 | |
| 
 | |
| extern _Unwind_Reason_Code _Unwind_SjLj_RaiseException
 | |
|      (struct _Unwind_Exception *);
 | |
| extern _Unwind_Reason_Code _Unwind_SjLj_ForcedUnwind
 | |
|      (struct _Unwind_Exception *, _Unwind_Stop_Fn, void *);
 | |
| extern void _Unwind_SjLj_Resume (struct _Unwind_Exception *);
 | |
| extern _Unwind_Reason_Code _Unwind_SjLj_Resume_or_Rethrow (struct _Unwind_Exception *);
 | |
| 
 | |
| /* @@@ The following provide access to the base addresses for text
 | |
|    and data-relative addressing in the LDSA.  In order to stay link
 | |
|    compatible with the standard ABI for IA-64, we inline these.  */
 | |
| 
 | |
| #ifdef __ia64__
 | |
| #include <stdlib.h>
 | |
| 
 | |
| static inline _Unwind_Ptr
 | |
| _Unwind_GetDataRelBase (struct _Unwind_Context *_C)
 | |
| {
 | |
|   /* The GP is stored in R1.  */
 | |
|   return _Unwind_GetGR (_C, 1);
 | |
| }
 | |
| 
 | |
| static inline _Unwind_Ptr
 | |
| _Unwind_GetTextRelBase (struct _Unwind_Context *_C __attribute__ ((__unused__)))
 | |
| {
 | |
|   abort ();
 | |
|   return 0;
 | |
| }
 | |
| 
 | |
| /* @@@ Retrieve the Backing Store Pointer of the given context.  */
 | |
| extern _Unwind_Word _Unwind_GetBSP (struct _Unwind_Context *);
 | |
| #else
 | |
| extern _Unwind_Ptr _Unwind_GetDataRelBase (struct _Unwind_Context *);
 | |
| extern _Unwind_Ptr _Unwind_GetTextRelBase (struct _Unwind_Context *);
 | |
| #endif
 | |
| 
 | |
| /* @@@ Given an address, return the entry point of the function that
 | |
|    contains it.  */
 | |
| extern void * _Unwind_FindEnclosingFunction (void *pc);
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #ifndef HIDE_EXPORTS
 | |
| #pragma GCC visibility pop
 | |
| #endif
 | |
| 
 | |
| #endif /* unwind.h */
 |