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