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 #include "config.h"
39*f3e7f55eSRobert Mustacchi #include "dwarf_incl.h"
40*f3e7f55eSRobert Mustacchi #include <stdio.h>
41*f3e7f55eSRobert Mustacchi
42*f3e7f55eSRobert Mustacchi
43*f3e7f55eSRobert Mustacchi /*
44*f3e7f55eSRobert Mustacchi decode ULEB
45*f3e7f55eSRobert Mustacchi */
46*f3e7f55eSRobert Mustacchi Dwarf_Unsigned
_dwarf_decode_u_leb128(Dwarf_Small * leb128,Dwarf_Word * leb128_length)47*f3e7f55eSRobert Mustacchi _dwarf_decode_u_leb128(Dwarf_Small * leb128, Dwarf_Word * leb128_length)
48*f3e7f55eSRobert Mustacchi {
49*f3e7f55eSRobert Mustacchi unsigned char byte;
50*f3e7f55eSRobert Mustacchi Dwarf_Word word_number;
51*f3e7f55eSRobert Mustacchi Dwarf_Unsigned number;
52*f3e7f55eSRobert Mustacchi Dwarf_Sword shift;
53*f3e7f55eSRobert Mustacchi Dwarf_Sword byte_length;
54*f3e7f55eSRobert Mustacchi
55*f3e7f55eSRobert Mustacchi /* The following unrolls-the-loop for the first few bytes and
56*f3e7f55eSRobert Mustacchi unpacks into 32 bits to make this as fast as possible.
57*f3e7f55eSRobert Mustacchi word_number is assumed big enough that the shift has a defined
58*f3e7f55eSRobert Mustacchi result. */
59*f3e7f55eSRobert Mustacchi if ((*leb128 & 0x80) == 0) {
60*f3e7f55eSRobert Mustacchi if (leb128_length != NULL)
61*f3e7f55eSRobert Mustacchi *leb128_length = 1;
62*f3e7f55eSRobert Mustacchi return (*leb128);
63*f3e7f55eSRobert Mustacchi } else if ((*(leb128 + 1) & 0x80) == 0) {
64*f3e7f55eSRobert Mustacchi if (leb128_length != NULL)
65*f3e7f55eSRobert Mustacchi *leb128_length = 2;
66*f3e7f55eSRobert Mustacchi
67*f3e7f55eSRobert Mustacchi word_number = *leb128 & 0x7f;
68*f3e7f55eSRobert Mustacchi word_number |= (*(leb128 + 1) & 0x7f) << 7;
69*f3e7f55eSRobert Mustacchi return (word_number);
70*f3e7f55eSRobert Mustacchi } else if ((*(leb128 + 2) & 0x80) == 0) {
71*f3e7f55eSRobert Mustacchi if (leb128_length != NULL)
72*f3e7f55eSRobert Mustacchi *leb128_length = 3;
73*f3e7f55eSRobert Mustacchi
74*f3e7f55eSRobert Mustacchi word_number = *leb128 & 0x7f;
75*f3e7f55eSRobert Mustacchi word_number |= (*(leb128 + 1) & 0x7f) << 7;
76*f3e7f55eSRobert Mustacchi word_number |= (*(leb128 + 2) & 0x7f) << 14;
77*f3e7f55eSRobert Mustacchi return (word_number);
78*f3e7f55eSRobert Mustacchi } else if ((*(leb128 + 3) & 0x80) == 0) {
79*f3e7f55eSRobert Mustacchi if (leb128_length != NULL)
80*f3e7f55eSRobert Mustacchi *leb128_length = 4;
81*f3e7f55eSRobert Mustacchi
82*f3e7f55eSRobert Mustacchi word_number = *leb128 & 0x7f;
83*f3e7f55eSRobert Mustacchi word_number |= (*(leb128 + 1) & 0x7f) << 7;
84*f3e7f55eSRobert Mustacchi word_number |= (*(leb128 + 2) & 0x7f) << 14;
85*f3e7f55eSRobert Mustacchi word_number |= (*(leb128 + 3) & 0x7f) << 21;
86*f3e7f55eSRobert Mustacchi return (word_number);
87*f3e7f55eSRobert Mustacchi }
88*f3e7f55eSRobert Mustacchi
89*f3e7f55eSRobert Mustacchi /* The rest handles long numbers Because the 'number' may be larger
90*f3e7f55eSRobert Mustacchi than the default int/unsigned, we must cast the 'byte' before
91*f3e7f55eSRobert Mustacchi the shift for the shift to have a defined result. */
92*f3e7f55eSRobert Mustacchi number = 0;
93*f3e7f55eSRobert Mustacchi shift = 0;
94*f3e7f55eSRobert Mustacchi byte_length = 1;
95*f3e7f55eSRobert Mustacchi byte = *(leb128);
96*f3e7f55eSRobert Mustacchi for (;;) {
97*f3e7f55eSRobert Mustacchi number |= ((Dwarf_Unsigned) (byte & 0x7f)) << shift;
98*f3e7f55eSRobert Mustacchi
99*f3e7f55eSRobert Mustacchi if ((byte & 0x80) == 0) {
100*f3e7f55eSRobert Mustacchi if (leb128_length != NULL)
101*f3e7f55eSRobert Mustacchi *leb128_length = byte_length;
102*f3e7f55eSRobert Mustacchi return (number);
103*f3e7f55eSRobert Mustacchi }
104*f3e7f55eSRobert Mustacchi shift += 7;
105*f3e7f55eSRobert Mustacchi
106*f3e7f55eSRobert Mustacchi byte_length++;
107*f3e7f55eSRobert Mustacchi ++leb128;
108*f3e7f55eSRobert Mustacchi byte = *leb128;
109*f3e7f55eSRobert Mustacchi }
110*f3e7f55eSRobert Mustacchi }
111*f3e7f55eSRobert Mustacchi
112*f3e7f55eSRobert Mustacchi #define BITSINBYTE 8
113*f3e7f55eSRobert Mustacchi
114*f3e7f55eSRobert Mustacchi /*
115*f3e7f55eSRobert Mustacchi decode SLEB
116*f3e7f55eSRobert Mustacchi */
117*f3e7f55eSRobert Mustacchi Dwarf_Signed
_dwarf_decode_s_leb128(Dwarf_Small * leb128,Dwarf_Word * leb128_length)118*f3e7f55eSRobert Mustacchi _dwarf_decode_s_leb128(Dwarf_Small * leb128, Dwarf_Word * leb128_length)
119*f3e7f55eSRobert Mustacchi {
120*f3e7f55eSRobert Mustacchi Dwarf_Signed number = 0;
121*f3e7f55eSRobert Mustacchi Dwarf_Bool sign = 0;
122*f3e7f55eSRobert Mustacchi Dwarf_Sword shift = 0;
123*f3e7f55eSRobert Mustacchi unsigned char byte = *leb128;
124*f3e7f55eSRobert Mustacchi Dwarf_Sword byte_length = 1;
125*f3e7f55eSRobert Mustacchi
126*f3e7f55eSRobert Mustacchi /* byte_length being the number of bytes of data absorbed so far in
127*f3e7f55eSRobert Mustacchi turning the leb into a Dwarf_Signed. */
128*f3e7f55eSRobert Mustacchi
129*f3e7f55eSRobert Mustacchi for (;;) {
130*f3e7f55eSRobert Mustacchi sign = byte & 0x40;
131*f3e7f55eSRobert Mustacchi number |= ((Dwarf_Signed) ((byte & 0x7f))) << shift;
132*f3e7f55eSRobert Mustacchi shift += 7;
133*f3e7f55eSRobert Mustacchi
134*f3e7f55eSRobert Mustacchi if ((byte & 0x80) == 0) {
135*f3e7f55eSRobert Mustacchi break;
136*f3e7f55eSRobert Mustacchi }
137*f3e7f55eSRobert Mustacchi ++leb128;
138*f3e7f55eSRobert Mustacchi byte = *leb128;
139*f3e7f55eSRobert Mustacchi byte_length++;
140*f3e7f55eSRobert Mustacchi }
141*f3e7f55eSRobert Mustacchi
142*f3e7f55eSRobert Mustacchi if ((shift < sizeof(Dwarf_Signed) * BITSINBYTE) && sign) {
143*f3e7f55eSRobert Mustacchi number |= -((Dwarf_Signed) 1 << shift);
144*f3e7f55eSRobert Mustacchi }
145*f3e7f55eSRobert Mustacchi
146*f3e7f55eSRobert Mustacchi if (leb128_length != NULL)
147*f3e7f55eSRobert Mustacchi *leb128_length = byte_length;
148*f3e7f55eSRobert Mustacchi return (number);
149*f3e7f55eSRobert Mustacchi }
150