|
@@ -18,80 +18,15 @@
|
|
|
#include "libbpf.h"
|
|
|
#include "bpf_load.h"
|
|
|
|
|
|
-#define MAX_SYMS 300000
|
|
|
#define PRINT_RAW_ADDR 0
|
|
|
|
|
|
-static struct ksym {
|
|
|
- long addr;
|
|
|
- char *name;
|
|
|
-} syms[MAX_SYMS];
|
|
|
-static int sym_cnt;
|
|
|
-
|
|
|
-static int ksym_cmp(const void *p1, const void *p2)
|
|
|
-{
|
|
|
- return ((struct ksym *)p1)->addr - ((struct ksym *)p2)->addr;
|
|
|
-}
|
|
|
-
|
|
|
-static int load_kallsyms(void)
|
|
|
-{
|
|
|
- FILE *f = fopen("/proc/kallsyms", "r");
|
|
|
- char func[256], buf[256];
|
|
|
- char symbol;
|
|
|
- void *addr;
|
|
|
- int i = 0;
|
|
|
-
|
|
|
- if (!f)
|
|
|
- return -ENOENT;
|
|
|
-
|
|
|
- while (!feof(f)) {
|
|
|
- if (!fgets(buf, sizeof(buf), f))
|
|
|
- break;
|
|
|
- if (sscanf(buf, "%p %c %s", &addr, &symbol, func) != 3)
|
|
|
- break;
|
|
|
- if (!addr)
|
|
|
- continue;
|
|
|
- syms[i].addr = (long) addr;
|
|
|
- syms[i].name = strdup(func);
|
|
|
- i++;
|
|
|
- }
|
|
|
- sym_cnt = i;
|
|
|
- qsort(syms, sym_cnt, sizeof(struct ksym), ksym_cmp);
|
|
|
- return 0;
|
|
|
-}
|
|
|
-
|
|
|
-static void *search(long key)
|
|
|
-{
|
|
|
- int start = 0, end = sym_cnt;
|
|
|
- int result;
|
|
|
-
|
|
|
- while (start < end) {
|
|
|
- size_t mid = start + (end - start) / 2;
|
|
|
-
|
|
|
- result = key - syms[mid].addr;
|
|
|
- if (result < 0)
|
|
|
- end = mid;
|
|
|
- else if (result > 0)
|
|
|
- start = mid + 1;
|
|
|
- else
|
|
|
- return &syms[mid];
|
|
|
- }
|
|
|
-
|
|
|
- if (start >= 1 && syms[start - 1].addr < key &&
|
|
|
- key < syms[start].addr)
|
|
|
- /* valid ksym */
|
|
|
- return &syms[start - 1];
|
|
|
-
|
|
|
- /* out of range. return _stext */
|
|
|
- return &syms[0];
|
|
|
-}
|
|
|
-
|
|
|
static void print_ksym(__u64 addr)
|
|
|
{
|
|
|
struct ksym *sym;
|
|
|
|
|
|
if (!addr)
|
|
|
return;
|
|
|
- sym = search(addr);
|
|
|
+ sym = ksym_search(addr);
|
|
|
if (PRINT_RAW_ADDR)
|
|
|
printf("%s/%llx;", sym->name, addr);
|
|
|
else
|