49{
52 int i,
first, firstline,
op,
a,
l, quantum, isstmt, linebase, linerange, opcodebase, nf;
58
60
63 return -1;
64
66 werrstr(
"no line mapping information for 0x%x", pc);
67 return -1;
68 }
70 if(off >=
d->line.len){
72 goto bad;
73 }
74
76
79 b.p =
d->line.data + off;
80 b.ep =
b.p +
d->line.len;
82
86 goto bad;
87 }
88
91 if(vers != 2){
92 werrstr(
"bad dwarf version 0x%x", vers);
93 return -1;
94 }
95
99 goto bad;
100 }
102
108
113 goto bad;
114 }
115
116
121
123 while(
b.p!=
nil && *
b.p!=0){
128 }
130
131
134 goto bad;
135 }
137
144
147 nf = 0;
149 if(
trace)
werrstr(
"program @ %lu ... %.*H opbase = %d\n",
b.p -
d->line.data,
b.ep-
b.p,
b.p, opcodebase);
152 firstline = 0;
155 if(
op >= opcodebase){
156 a = (
op - opcodebase) / linerange;
157 l = (
op - opcodebase) % linerange + linebase;
159 cur.addr +=
a * quantum;
161 emit:
164 werrstr(
"found wrong line mapping 0x%x for pc 0x%x",
cur.addr, pc);
165
166
167
168
169 firstline = 1;
170 }
173 }
174 if(
cur.addr > pc && !firstline)
175 break;
177 werrstr(
"buffer underflow in line mapping");
179 }
182 werrstr(
"found wrong line mapping 0x%x-0x%x for pc 0x%x",
start,
cur.addr, pc);
184 }
186 }else{
188 case 0:
193 goto bad;
195 case 1:
198 goto emit;
199 case 2:
202 break;
203 case 3:
204 newf =
malloc(nf+1*
sizeof(
f[0]));
205 if (newf)
215 break;
216 }
218 goto bad;
220 break;
221 case 1:
223 goto emit;
224 case 2:
227 cur.addr +=
a * quantum;
228 break;
229 case 3:
233 break;
234 case 4:
237 break;
238 case 5:
241 break;
242 case 6:
245 break;
246 case 7:
249 break;
250 case 8:
251 a = (255 - opcodebase) / linerange * quantum;
254 break;
255 case 9:
259 break;
260 case 10:
263 break;
264 case 11:
267 break;
268 case 12:
271 break;
272 default:
274 for(
i=0;
i<opcount[
op];
i++)
276 break;
277 }
278 }
279 }
281 goto bad;
282
283
284
286 werrstr(
"invalid file index in mapping data");
288 }
291
292
299 }
301 werrstr(
"problem parsing file data second time (cannot happen)");
302 goto bad;
303 }
306 werrstr(
"bad file index in mapping data");
307 goto bad;
308 }
310 }
316 if(mtime)
321
322
323 if(cdir)
325
329 for (
x = 1;
b.p && *
b.p;
x++)
332 break;
333 }
334 }
335
337 lastline = 0;
338#if 0
343 proc.attrs.have.name &&
346 proc.attrs.declline > lastline) {
347 lastline =
proc.attrs.declline;
351 }
352 }
353 }
354#elif 1
357 for (
i = 0;
i <
d->pe->nsymbols;
i++) {
358 if (
d->pe->symtab[
i].address > lastaddr &&
359 d->pe->symtab[
i].address <= pc -
d->pe->imagebase &&
360 d->pe->symtab[
i].address <
d->pe->imagesize) {
361 lastaddr =
d->pe->symtab[
i].address;
362 *function =
d->pe->symtab[
i].
name;
363 }
364 }
365#else
366
367
371 }
372#endif
373
374
376 return 0;
377
378bad:
379 werrstr(
"corrupted line mapping for 0x%x", pc);
382 return -1;
383}
ACPI_SIZE strlen(const char *String)
char * strcpy(char *DstString, const char *SrcString)
GLint GLint GLint GLint GLint x
GLboolean GLboolean GLboolean b
GLuint GLsizei GLsizei * length
GLboolean GLboolean GLboolean GLboolean a
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
png_const_structrp png_const_inforp int * unit
ulong dwarfget128(DwarfBuf *)
ulong dwarfget2(DwarfBuf *)
int dwarfenumunit(Dwarf *, ulong, DwarfSym *)
int dwarflookuptag(Dwarf *, ulong, ulong, DwarfSym *)
int dwarflookupfn(Dwarf *, ulong, ulong, DwarfSym *)
char * dwarfgetstring(DwarfBuf *)
ulong dwarfget1(DwarfBuf *)
long dwarfget128s(DwarfBuf *)
ulong dwarfgetaddr(DwarfBuf *)
uchar * dwarfgetnref(DwarfBuf *, ulong)
int dwarfaddrtounit(Dwarf *, ulong, ulong *)
int dwarfnextsymat(Dwarf *, DwarfSym *, int)
ulong dwarfget4(DwarfBuf *)
struct DwarfAttrs::@4965 have
#define RtlMoveMemory(Destination, Source, Length)