1 /* Header file for unwinding stack frames for exception handling. */
2 /* Compile this one with gcc. */
3 /* Copyright (C) 1997, 1998, 1999, 2000 Free Software Foundation, Inc.
4 Contributed by Jason Merrill <jason@cygnus.com>.
6 This file is part of GNU CC.
8 GNU CC is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2, or (at your option)
13 GNU CC is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with GNU CC; see the file COPYING. If not, write to
20 the Free Software Foundation, 59 Temple Place - Suite 330,
21 Boston, MA 02111-1307, USA. */
24 #ifndef DWARF_FRAME_REGISTERS
25 #define DWARF_FRAME_REGISTERS FIRST_PSEUDO_REGISTER
28 typedef struct frame_state
34 long reg_or_offset
[DWARF_FRAME_REGISTERS
+1];
35 unsigned short cfa_reg
;
36 unsigned short retaddr_column
;
37 char saved
[DWARF_FRAME_REGISTERS
+1];
42 /* Values for 'saved' above. */
44 #define REG_SAVED_OFFSET 1
45 #define REG_SAVED_REG 2
47 /* The representation for an "object" to be searched for frame unwind info.
48 For targets with named sections, one object is an executable or shared
49 library; for other targets, one object is one translation unit.
51 A copy of this structure declaration is printed by collect2.c;
52 keep the copies synchronized! */
55 #ifdef IA64_UNWIND_INFO
56 void *pc_base
; /* This field will be set by find_fde. */
60 struct dwarf_fde
*fde_begin
;
61 #ifdef IA64_UNWIND_INFO
62 struct dwarf_fde
*fde_end
;
64 struct dwarf_fde
**fde_array
;
69 /* Note the following routines are exported interfaces from libgcc; do not
70 change these interfaces. Instead create new interfaces. Also note
71 references to these functions may be made weak in files where they
74 extern void __register_frame (void * );
75 extern void __register_frame_table (void *);
76 extern void __deregister_frame (void *);
78 /* Called either from crtbegin.o or a static constructor to register the
79 unwind info for an object or translation unit, respectively. */
81 extern void __register_frame_info (void *, struct object
*);
83 /* Similar, but BEGIN is actually a pointer to a table of unwind entries
84 for different translation units. Called from the file generated by
86 extern void __register_frame_info_table (void *, struct object
*);
88 /* Called from crtend.o to deregister the unwind info for an object. */
90 extern void *__deregister_frame_info (void *);
92 /* Called from __throw to find the registers to restore for a given
93 PC_TARGET. The caller should allocate a local variable of `struct
94 frame_state' (declared in frame.h) and pass its address to STATE_IN.
95 Returns NULL on failure, otherwise returns STATE_IN. */
97 extern struct frame_state
*__frame_state_for (void *, struct frame_state
*);
99 #ifdef IA64_UNWIND_INFO
101 /* This is the information required for unwind records in an ia64
102 object file. This is required by GAS and the compiler runtime. */
104 /* These are the starting point masks for the various types of
105 unwind records. To create a record of type R3 for instance, one
106 starts by using the value UNW_R3 and or-ing in any other required values.
107 These values are also unique (in context), so they can be used to identify
108 the various record types as well. UNW_Bx and some UNW_Px do have the
109 same value, but Px can only occur in a prologue context, and Bx in
134 /* These are all the various types of unwind records. */
138 prologue
, prologue_gr
, body
, mem_stack_f
, mem_stack_v
, psp_gr
, psp_sprel
,
139 rp_when
, rp_gr
, rp_br
, rp_psprel
, rp_sprel
, pfs_when
, pfs_gr
, pfs_psprel
,
140 pfs_sprel
, preds_when
, preds_gr
, preds_psprel
, preds_sprel
,
141 fr_mem
, frgr_mem
, gr_gr
, gr_mem
, br_mem
, br_gr
, spill_base
, spill_mask
,
142 unat_when
, unat_gr
, unat_psprel
, unat_sprel
, lc_when
, lc_gr
, lc_psprel
,
143 lc_sprel
, fpsr_when
, fpsr_gr
, fpsr_psprel
, fpsr_sprel
,
144 priunat_when_gr
, priunat_when_mem
, priunat_gr
, priunat_psprel
,
145 priunat_sprel
, bsp_when
, bsp_gr
, bsp_psprel
, bsp_sprel
, bspstore_when
,
146 bspstore_gr
, bspstore_psprel
, bspstore_sprel
, rnat_when
, rnat_gr
,
147 rnat_psprel
, rnat_sprel
, epilogue
, label_state
, copy_state
,
148 spill_psprel
, spill_sprel
, spill_reg
, spill_psprel_p
, spill_sprel_p
,
153 /* These structures declare the fields that can be used in each of the
154 4 record formats, R, P, B and X. */
156 typedef struct unw_r_record
160 unsigned short grsave
;
163 typedef struct unw_p_record
170 unsigned long pspoff
;
172 unsigned short rmask
;
173 unsigned short grmask
;
174 unsigned long frmask
;
175 unsigned short brmask
;
178 typedef struct unw_b_record
182 unsigned short ecount
;
185 typedef struct unw_x_record
189 unsigned long pspoff
;
193 unsigned short xy
; /* Value of the XY field.. */
196 /* This structure is used to determine the specific record type and
198 typedef struct unwind_record
200 unw_record_type type
;
209 #define IA64_UNW_LOC_TYPE_NONE 0
210 #define IA64_UNW_LOC_TYPE_MEM 1
211 #define IA64_UNW_LOC_TYPE_GR 2
212 #define IA64_UNW_LOC_TYPE_FR 3
213 #define IA64_UNW_LOC_TYPE_BR 4
214 #define IA64_UNW_LOC_TYPE_SPOFF 5
215 #define IA64_UNW_LOC_TYPE_PSPOFF 6
216 #define IA64_UNW_LOC_TYPE_OFFSET 7
217 #define IA64_UNW_LOC_TYPE_SPILLBASE 8
219 typedef struct ia64_reg_loc
221 long when
; /* PC relative offset from start of function. */
222 union { /* In memory or another register? */
227 short loc_type
; /* Where to find value. */
231 /* Frame information record. */
233 typedef struct ia64_frame_state
235 ia64_reg_loc gr
[4]; /* gr4 to gr7. */
236 ia64_reg_loc fr
[20]; /* fr2 to fr5, fr16 to fr31. */
237 ia64_reg_loc br
[5]; /* br1 to br5. */
241 ia64_reg_loc bspstore
;
247 ia64_reg_loc priunat
;
250 ia64_reg_loc spill_base
;
256 /* This structure represents the start of an unwind information pointer.
257 'unwind_descriptors' is the beginninng of the unwind descriptors, which
258 use up 'length' bytes of storage. */
260 typedef struct unwind_info_ptr
262 unsigned long header
; /* version, flags, & length */
263 unsigned char unwind_descriptors
[1];
266 #define IA64_UNW_HDR_LENGTH(x) ((x) & 0x00000000ffffffffUL)
267 #define IA64_UNW_HDR_FLAGS(x) (((x) >> 32) & 0xffffUL)
268 #define IA64_UNW_HDR_VERSION(x) (((x) >> 48) & 0xffffUL)
270 /* Header flag bits, after extraction by IA64_UNW_HDR_FLAGS. */
271 #define IA64_UNW_EHANDLER 0x1
272 #define IA64_UNW_UHANDLER 0x2
274 extern void * __ia64_personality_v1 (void *pc
, old_exception_table
*table
);
276 extern unwind_info_ptr
*__build_ia64_frame_state (unsigned char *,
280 extern void *__get_real_reg_value (ia64_reg_loc
*);
281 extern void *__get_personality (unwind_info_ptr
*);
282 extern void *__get_except_table (unwind_info_ptr
*);
283 extern void __set_real_reg_value (ia64_reg_loc
*, void *);
284 void *__calc_caller_bsp (long, unsigned char *);
285 void __copy_saved_reg_state (ia64_frame_state
*, ia64_frame_state
*);
286 #endif /* IA64_UNWIND_INFO */