1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
|
/* extracted from gdb sources */
typedef unsigned long long CORE_ADDR;
struct blockvector;
struct symtab {
struct blockvector *blockvector;
};
struct sec {
void *unused;
};
struct symbol {
int len;
char *name;
};
struct block {
CORE_ADDR startaddr, endaddr;
struct symbol *function;
struct block *superblock;
unsigned char gcc_compile_flag;
int nsyms;
struct symbol syms[1];
};
struct blockvector {
int nblocks;
struct block *block[2];
};
struct blockvector *blockvector_for_pc_sect(register CORE_ADDR pc,
struct symtab *symtab)
{
register struct block *b;
register int bot, top, half;
struct blockvector *bl;
bl = symtab->blockvector;
b = bl->block[0];
bot = 0;
top = bl->nblocks;
while (top - bot > 1)
{
half = (top - bot + 1) >> 1;
b = bl->block[bot + half];
if (b->startaddr <= pc)
bot += half;
else
top = bot + half;
}
while (bot >= 0)
{
b = bl->block[bot];
if (b->endaddr > pc)
{
return bl;
}
bot--;
}
return 0;
}
int main(void)
{
struct block a = { 0, 0x10000, 0, 0, 1, 20 };
struct block b = { 0x10000, 0x20000, 0, 0, 1, 20 };
struct blockvector bv = { 2, { &a, &b } };
struct symtab s = { &bv };
struct blockvector *ret;
ret = blockvector_for_pc_sect(0x500, &s);
return 0;
}
|