xref: /titanic_50/usr/src/lib/libdwarf/common/pro_frame.h (revision f3e7f55e73a39377d55a030f124cc86b3b66a9cc)
1*f3e7f55eSRobert Mustacchi /*
2*f3e7f55eSRobert Mustacchi 
3*f3e7f55eSRobert Mustacchi   Copyright (C) 2000,2004 Silicon Graphics, Inc.  All Rights Reserved.
4*f3e7f55eSRobert Mustacchi 
5*f3e7f55eSRobert Mustacchi   This program is free software; you can redistribute it and/or modify it
6*f3e7f55eSRobert Mustacchi   under the terms of version 2.1 of the GNU Lesser General Public License
7*f3e7f55eSRobert Mustacchi   as published by the Free Software Foundation.
8*f3e7f55eSRobert Mustacchi 
9*f3e7f55eSRobert Mustacchi   This program is distributed in the hope that it would be useful, but
10*f3e7f55eSRobert Mustacchi   WITHOUT ANY WARRANTY; without even the implied warranty of
11*f3e7f55eSRobert Mustacchi   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
12*f3e7f55eSRobert Mustacchi 
13*f3e7f55eSRobert Mustacchi   Further, this software is distributed without any warranty that it is
14*f3e7f55eSRobert Mustacchi   free of the rightful claim of any third person regarding infringement
15*f3e7f55eSRobert Mustacchi   or the like.  Any license provided herein, whether implied or
16*f3e7f55eSRobert Mustacchi   otherwise, applies only to this software file.  Patent licenses, if
17*f3e7f55eSRobert Mustacchi   any, provided herein do not apply to combinations of this program with
18*f3e7f55eSRobert Mustacchi   other software, or any other product whatsoever.
19*f3e7f55eSRobert Mustacchi 
20*f3e7f55eSRobert Mustacchi   You should have received a copy of the GNU Lesser General Public
21*f3e7f55eSRobert Mustacchi   License along with this program; if not, write the Free Software
22*f3e7f55eSRobert Mustacchi   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston MA 02110-1301,
23*f3e7f55eSRobert Mustacchi   USA.
24*f3e7f55eSRobert Mustacchi 
25*f3e7f55eSRobert Mustacchi   Contact information:  Silicon Graphics, Inc., 1500 Crittenden Lane,
26*f3e7f55eSRobert Mustacchi   Mountain View, CA 94043, or:
27*f3e7f55eSRobert Mustacchi 
28*f3e7f55eSRobert Mustacchi   http://www.sgi.com
29*f3e7f55eSRobert Mustacchi 
30*f3e7f55eSRobert Mustacchi   For further information regarding this notice, see:
31*f3e7f55eSRobert Mustacchi 
32*f3e7f55eSRobert Mustacchi   http://oss.sgi.com/projects/GenInfo/NoticeExplan
33*f3e7f55eSRobert Mustacchi 
34*f3e7f55eSRobert Mustacchi */
35*f3e7f55eSRobert Mustacchi 
36*f3e7f55eSRobert Mustacchi 
37*f3e7f55eSRobert Mustacchi 
38*f3e7f55eSRobert Mustacchi /*
39*f3e7f55eSRobert Mustacchi     Largest register value that can be coded into
40*f3e7f55eSRobert Mustacchi     the opcode since there are only 6 bits in the
41*f3e7f55eSRobert Mustacchi     register field.
42*f3e7f55eSRobert Mustacchi */
43*f3e7f55eSRobert Mustacchi #define MAX_6_BIT_VALUE		0x3f
44*f3e7f55eSRobert Mustacchi 
45*f3e7f55eSRobert Mustacchi /*
46*f3e7f55eSRobert Mustacchi 	This struct holds debug_frame instructions
47*f3e7f55eSRobert Mustacchi */
48*f3e7f55eSRobert Mustacchi typedef struct Dwarf_P_Frame_Pgm_s *Dwarf_P_Frame_Pgm;
49*f3e7f55eSRobert Mustacchi 
50*f3e7f55eSRobert Mustacchi struct Dwarf_P_Frame_Pgm_s {
51*f3e7f55eSRobert Mustacchi     Dwarf_Ubyte dfp_opcode;	/* opcode - includes reg # */
52*f3e7f55eSRobert Mustacchi     char *dfp_args;		/* operands */
53*f3e7f55eSRobert Mustacchi     int dfp_nbytes;		/* number of bytes in args */
54*f3e7f55eSRobert Mustacchi #if 0
55*f3e7f55eSRobert Mustacchi     Dwarf_Unsigned dfp_sym_index;	/* 0 unless reloc needed */
56*f3e7f55eSRobert Mustacchi #endif
57*f3e7f55eSRobert Mustacchi     Dwarf_P_Frame_Pgm dfp_next;
58*f3e7f55eSRobert Mustacchi };
59*f3e7f55eSRobert Mustacchi 
60*f3e7f55eSRobert Mustacchi 
61*f3e7f55eSRobert Mustacchi /*
62*f3e7f55eSRobert Mustacchi 	This struct has cie related information. Used to gather data
63*f3e7f55eSRobert Mustacchi 	from user program, and later to transform to disk form
64*f3e7f55eSRobert Mustacchi */
65*f3e7f55eSRobert Mustacchi struct Dwarf_P_Cie_s {
66*f3e7f55eSRobert Mustacchi     Dwarf_Ubyte cie_version;
67*f3e7f55eSRobert Mustacchi     char *cie_aug;		/* augmentation */
68*f3e7f55eSRobert Mustacchi     Dwarf_Ubyte cie_code_align;	/* alignment of code */
69*f3e7f55eSRobert Mustacchi     Dwarf_Sbyte cie_data_align;
70*f3e7f55eSRobert Mustacchi     Dwarf_Ubyte cie_ret_reg;	/* return register # */
71*f3e7f55eSRobert Mustacchi     char *cie_inst;		/* initial instruction */
72*f3e7f55eSRobert Mustacchi     long cie_inst_bytes;
73*f3e7f55eSRobert Mustacchi     /* no of init_inst */
74*f3e7f55eSRobert Mustacchi     Dwarf_P_Cie cie_next;
75*f3e7f55eSRobert Mustacchi };
76*f3e7f55eSRobert Mustacchi 
77*f3e7f55eSRobert Mustacchi 
78*f3e7f55eSRobert Mustacchi /* producer fields */
79*f3e7f55eSRobert Mustacchi struct Dwarf_P_Fde_s {
80*f3e7f55eSRobert Mustacchi     Dwarf_Unsigned fde_unused1;
81*f3e7f55eSRobert Mustacchi 
82*f3e7f55eSRobert Mustacchi     /* function/subr die for this fde */
83*f3e7f55eSRobert Mustacchi     Dwarf_P_Die fde_die;
84*f3e7f55eSRobert Mustacchi 
85*f3e7f55eSRobert Mustacchi     /* index to asso. cie */
86*f3e7f55eSRobert Mustacchi     Dwarf_Word fde_cie;
87*f3e7f55eSRobert Mustacchi 
88*f3e7f55eSRobert Mustacchi     /* Address of first location of the code this frame applies to If
89*f3e7f55eSRobert Mustacchi        fde_end_symbol non-zero, this represents the offset from the
90*f3e7f55eSRobert Mustacchi        symbol indicated by fde_r_symidx */
91*f3e7f55eSRobert Mustacchi     Dwarf_Addr fde_initloc;
92*f3e7f55eSRobert Mustacchi 
93*f3e7f55eSRobert Mustacchi     /* Relocation symbol for address of the code this frame applies to.
94*f3e7f55eSRobert Mustacchi      */
95*f3e7f55eSRobert Mustacchi     Dwarf_Unsigned fde_r_symidx;
96*f3e7f55eSRobert Mustacchi 
97*f3e7f55eSRobert Mustacchi     /* Bytes of instr for this fde, if known */
98*f3e7f55eSRobert Mustacchi     Dwarf_Unsigned fde_addr_range;
99*f3e7f55eSRobert Mustacchi 
100*f3e7f55eSRobert Mustacchi     /* linked list of instructions we will put in fde. */
101*f3e7f55eSRobert Mustacchi     Dwarf_P_Frame_Pgm fde_inst;
102*f3e7f55eSRobert Mustacchi 
103*f3e7f55eSRobert Mustacchi     /* number of instructions in fde */
104*f3e7f55eSRobert Mustacchi     long fde_n_inst;
105*f3e7f55eSRobert Mustacchi 
106*f3e7f55eSRobert Mustacchi     /* number of bytes of inst in fde */
107*f3e7f55eSRobert Mustacchi     long fde_n_bytes;
108*f3e7f55eSRobert Mustacchi 
109*f3e7f55eSRobert Mustacchi     /* offset into exception table for this function. */
110*f3e7f55eSRobert Mustacchi     Dwarf_Signed fde_offset_into_exception_tables;
111*f3e7f55eSRobert Mustacchi 
112*f3e7f55eSRobert Mustacchi     /* The symbol for the exception table elf section. */
113*f3e7f55eSRobert Mustacchi     Dwarf_Unsigned fde_exception_table_symbol;
114*f3e7f55eSRobert Mustacchi 
115*f3e7f55eSRobert Mustacchi     /* pointer to last inst */
116*f3e7f55eSRobert Mustacchi     Dwarf_P_Frame_Pgm fde_last_inst;
117*f3e7f55eSRobert Mustacchi 
118*f3e7f55eSRobert Mustacchi     Dwarf_P_Fde fde_next;
119*f3e7f55eSRobert Mustacchi 
120*f3e7f55eSRobert Mustacchi     /* The symbol and offset of the end symbol. When fde_end_symbol is
121*f3e7f55eSRobert Mustacchi        non-zero we must represent the */
122*f3e7f55eSRobert Mustacchi     Dwarf_Addr fde_end_symbol_offset;
123*f3e7f55eSRobert Mustacchi     Dwarf_Unsigned fde_end_symbol;
124*f3e7f55eSRobert Mustacchi 
125*f3e7f55eSRobert Mustacchi     int fde_uwordb_size;
126*f3e7f55eSRobert Mustacchi     Dwarf_P_Debug fde_dbg;
127*f3e7f55eSRobert Mustacchi 
128*f3e7f55eSRobert Mustacchi     /* If fde_block is non-null, then it is the set of instructions.
129*f3e7f55eSRobert Mustacchi        so we should use it rather than fde_inst. */
130*f3e7f55eSRobert Mustacchi     Dwarf_Unsigned fde_inst_block_size;
131*f3e7f55eSRobert Mustacchi     void *fde_block;
132*f3e7f55eSRobert Mustacchi };
133